From 126b14066291c15cbeb5842e930228d7d19f2249 Mon Sep 17 00:00:00 2001 From: Giorgos Bamparopoulos Date: Mon, 28 Mar 2022 11:27:04 +0100 Subject: [PATCH 001/160] Add database statement in span flyout for all db types (#128266) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../waterfall/span_flyout/span_db.tsx | 43 ++++++++++--------- 1 file changed, 22 insertions(+), 21 deletions(-) diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/span_db.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/span_db.tsx index 0d9af40888192..ee2c09de2a1a4 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/span_db.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/span_db.tsx @@ -42,9 +42,27 @@ export function SpanDatabase({ spanDb }: Props) { return null; } - if (spanDb.type !== 'sql') { - return {spanDb.statement}; - } + const statementItem = + spanDb.type !== 'sql' ? ( + spanDb.statement + ) : ( + + + {spanDb.statement} + + + ); return ( @@ -59,24 +77,7 @@ export function SpanDatabase({ spanDb }: Props) { - - - - {spanDb.statement} - - - + {statementItem} ); From 3704642366854ec36543d82fba0b4160c68c8feb Mon Sep 17 00:00:00 2001 From: Giorgos Bamparopoulos Date: Mon, 28 Mar 2022 11:27:40 +0100 Subject: [PATCH 002/160] Add inspect flag to api test script for debugging (#128275) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/apm/scripts/test/api.js | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/x-pack/plugins/apm/scripts/test/api.js b/x-pack/plugins/apm/scripts/test/api.js index 1905c8eb7c2dd..5769224f90ac2 100644 --- a/x-pack/plugins/apm/scripts/test/api.js +++ b/x-pack/plugins/apm/scripts/test/api.js @@ -39,9 +39,22 @@ const { argv } = yargs(process.argv.slice(2)) type: 'string', description: 'Specify the spec files to run', }) + .option('inspect', { + default: false, + type: 'boolean', + description: 'Add --inspect-brk flag to the ftr for debugging', + }) + .check((argv) => { + const { inspect, runner } = argv; + if (inspect && !runner) { + throw new Error('--inspect can only be used with --runner'); + } else { + return true; + } + }) .help(); -const { trial, server, runner, grep } = argv; +const { trial, server, runner, grep, inspect } = argv; const license = trial ? 'trial' : 'basic'; console.log(`License: ${license}`); @@ -53,8 +66,9 @@ if (server) { ftrScript = 'functional_test_runner'; } +const inspectArg = inspect ? '--inspect-brk' : ''; const grepArg = grep ? `--grep "${grep}"` : ''; -const cmd = `node ../../../../scripts/${ftrScript} ${grepArg} --config ../../../../test/apm_api_integration/${license}/config.ts`; +const cmd = `node ${inspectArg} ../../../../scripts/${ftrScript} ${grepArg} --config ../../../../test/apm_api_integration/${license}/config.ts`; console.log(`Running ${cmd}`); From c1b7448e547a1f4f4870dba3bd52c36977b8443b Mon Sep 17 00:00:00 2001 From: Pablo Machado Date: Mon, 28 Mar 2022 12:41:46 +0200 Subject: [PATCH 003/160] [Security Solutions] Create all users tab on user page (#128375) * Create all users tab on user page * Fix unrelated bug on user details flyout * Fix unit test Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../security_solution/index.ts | 5 + .../security_solution/users/all/index.ts | 29 +++ .../security_solution/users/common/index.ts | 23 ++- .../security_solution/users/details/index.ts | 6 +- .../security_solution/users/index.ts | 1 + .../integration/users/all_users_tab.spec.ts | 2 +- .../users/authentications_tab.spec.ts | 38 ++++ .../cypress/integration/users/inspect.spec.ts | 8 + .../cypress/screens/users/all_users.ts | 2 +- .../screens/users/user_authentications.ts | 11 ++ .../public/common/components/links/index.tsx | 2 +- .../components/paginated_table/index.tsx | 4 +- .../use_search_strategy/index.test.ts | 6 +- .../containers/use_search_strategy/index.tsx | 14 +- .../public/common/mock/global_state.ts | 6 + .../users/components/all_users/index.test.tsx | 52 +++++ .../users/components/all_users/index.tsx | 186 ++++++++++++++++++ .../components/all_users/translations.ts | 40 ++++ .../kpi_users/total_users/index.test.tsx | 4 +- .../kpi_users/total_users/index.tsx | 4 +- .../public/users/pages/constants.ts | 2 +- .../public/users/pages/details/utils.ts | 1 + .../public/users/pages/nav_tabs.tsx | 6 + .../all_users_query_tab_body.test.tsx | 58 +++--- .../navigation/all_users_query_tab_body.tsx | 96 ++++++--- .../authentications_query_tab_body.test.tsx | 68 +++++++ .../authentications_query_tab_body.tsx | 74 +++++++ .../public/users/pages/navigation/index.ts | 1 + .../users/pages/navigation/translations.ts | 14 ++ .../public/users/pages/translations.ts | 7 + .../public/users/pages/users_tabs.tsx | 5 +- .../public/users/store/actions.ts | 5 +- .../public/users/store/model.ts | 9 +- .../public/users/store/reducer.ts | 9 + .../factory/users/all/__mocks__/index.ts | 100 ++++++++++ .../all/__snapshots__/index.test.ts.snap | 21 ++ .../query.all_users.dsl.test.ts.snap | 95 +++++++++ .../factory/users/all/index.test.ts | 51 +++++ .../factory/users/all/index.ts | 71 +++++++ .../users/all/query.all_users.dsl.test.ts | 15 ++ .../factory/users/all/query.all_users.dsl.ts | 92 +++++++++ .../security_solution/factory/users/index.ts | 2 + 42 files changed, 1166 insertions(+), 79 deletions(-) create mode 100644 x-pack/plugins/security_solution/common/search_strategy/security_solution/users/all/index.ts create mode 100644 x-pack/plugins/security_solution/cypress/integration/users/authentications_tab.spec.ts create mode 100644 x-pack/plugins/security_solution/cypress/screens/users/user_authentications.ts create mode 100644 x-pack/plugins/security_solution/public/users/components/all_users/index.test.tsx create mode 100644 x-pack/plugins/security_solution/public/users/components/all_users/index.tsx create mode 100644 x-pack/plugins/security_solution/public/users/components/all_users/translations.ts create mode 100644 x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.test.tsx create mode 100644 x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.tsx create mode 100644 x-pack/plugins/security_solution/public/users/pages/navigation/translations.ts create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__mocks__/index.ts create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/index.test.ts.snap create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/query.all_users.dsl.test.ts.snap create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.test.ts create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.ts create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.test.ts create mode 100644 x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts diff --git a/x-pack/plugins/security_solution/common/search_strategy/security_solution/index.ts b/x-pack/plugins/security_solution/common/search_strategy/security_solution/index.ts index a7176b3d30930..1902f0a0618ff 100644 --- a/x-pack/plugins/security_solution/common/search_strategy/security_solution/index.ts +++ b/x-pack/plugins/security_solution/common/search_strategy/security_solution/index.ts @@ -87,6 +87,7 @@ import { TotalUsersKpiRequestOptions, TotalUsersKpiStrategyResponse, } from './users/kpi/total_users'; +import { UsersRequestOptions, UsersStrategyResponse } from './users/all'; export * from './cti'; export * from './hosts'; @@ -147,6 +148,8 @@ export type StrategyResponseType = T extends HostsQ ? UserDetailsStrategyResponse : T extends UsersQueries.kpiTotalUsers ? TotalUsersKpiStrategyResponse + : T extends UsersQueries.users + ? UsersStrategyResponse : T extends NetworkQueries.details ? NetworkDetailsStrategyResponse : T extends NetworkQueries.dns @@ -207,6 +210,8 @@ export type StrategyRequestType = T extends HostsQu ? UserDetailsRequestOptions : T extends UsersQueries.kpiTotalUsers ? TotalUsersKpiRequestOptions + : T extends UsersQueries.users + ? UsersRequestOptions : T extends NetworkQueries.details ? NetworkDetailsRequestOptions : T extends NetworkQueries.dns diff --git a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/all/index.ts b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/all/index.ts new file mode 100644 index 0000000000000..3e50bbe68b5f8 --- /dev/null +++ b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/all/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { IEsSearchResponse } from '../../../../../../../../src/plugins/data/common'; + +import { Inspect, Maybe, PageInfoPaginated } from '../../../common'; +import { RequestOptionsPaginated } from '../..'; +import { SortableUsersFields } from '../common'; + +export interface User { + name: string; + lastSeen: string; + domain: string; +} + +export interface UsersStrategyResponse extends IEsSearchResponse { + users: User[]; + totalCount: number; + pageInfo: PageInfoPaginated; + inspect?: Maybe; +} + +export interface UsersRequestOptions extends RequestOptionsPaginated { + defaultIndex: string[]; +} diff --git a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/common/index.ts b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/common/index.ts index a522cd4d89218..9b9d3028594d3 100644 --- a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/common/index.ts +++ b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/common/index.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { Maybe, RiskSeverity } from '../../..'; +import { Maybe, RiskSeverity, SortField } from '../../..'; import { HostEcs } from '../../../../ecs/host'; import { UserEcs } from '../../../../ecs/user'; @@ -30,9 +30,14 @@ export interface UserItem { firstSeen?: Maybe; } +export type SortableUsersFields = Exclude; + +export type SortUsersField = SortField; + export enum UsersFields { lastSeen = 'lastSeen', - hostName = 'userName', + name = 'name', + domain = 'domain', } export interface UserAggEsItem { @@ -52,3 +57,17 @@ export interface UserBuckets { doc_count: number; }>; } + +export interface AllUsersAggEsItem { + key: string; + domain?: UsersDomainHitsItem; + lastSeen?: { value_as_string: string }; +} + +export interface UsersDomainHitsItem { + hits: { + hits: Array<{ + _source: { user: { domain: Maybe } }; + }>; + }; +} diff --git a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/details/index.ts b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/details/index.ts index 941e8081d1143..43de36a50802d 100644 --- a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/details/index.ts +++ b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/details/index.ts @@ -9,15 +9,15 @@ import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import type { IEsSearchResponse } from '../../../../../../../../src/plugins/data/common'; import { Inspect, Maybe, TimerangeInput } from '../../../common'; -import { UserItem, UsersFields } from '../common'; -import { RequestOptionsPaginated } from '../..'; +import { UserItem } from '../common'; +import { RequestBasicOptions } from '../..'; export interface UserDetailsStrategyResponse extends IEsSearchResponse { userDetails: UserItem; inspect?: Maybe; } -export interface UserDetailsRequestOptions extends Partial> { +export interface UserDetailsRequestOptions extends Partial { userName: string; skip?: boolean; timerange: TimerangeInput; diff --git a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/index.ts b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/index.ts index d8f6172dd80c2..d7b50ded32039 100644 --- a/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/index.ts +++ b/x-pack/plugins/security_solution/common/search_strategy/security_solution/users/index.ts @@ -10,6 +10,7 @@ import { TotalUsersKpiStrategyResponse } from './kpi/total_users'; export enum UsersQueries { details = 'userDetails', kpiTotalUsers = 'usersKpiTotalUsers', + users = 'allUsers', } export type UserskKpiStrategyResponse = Omit; diff --git a/x-pack/plugins/security_solution/cypress/integration/users/all_users_tab.spec.ts b/x-pack/plugins/security_solution/cypress/integration/users/all_users_tab.spec.ts index 070afc12cf53e..e040d032033f4 100644 --- a/x-pack/plugins/security_solution/cypress/integration/users/all_users_tab.spec.ts +++ b/x-pack/plugins/security_solution/cypress/integration/users/all_users_tab.spec.ts @@ -20,7 +20,7 @@ describe('Users stats and tables', () => { }); it(`renders all users`, () => { - const totalUsers = 35; + const totalUsers = 72; const usersPerPage = 10; cy.get(HEADER_SUBTITLE).should('have.text', `Showing: ${totalUsers} users`); diff --git a/x-pack/plugins/security_solution/cypress/integration/users/authentications_tab.spec.ts b/x-pack/plugins/security_solution/cypress/integration/users/authentications_tab.spec.ts new file mode 100644 index 0000000000000..1a7910a00fc49 --- /dev/null +++ b/x-pack/plugins/security_solution/cypress/integration/users/authentications_tab.spec.ts @@ -0,0 +1,38 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { + AUTHENTICATIONS_TAB, + AUTHENTICATIONS_TABLE, + HEADER_SUBTITLE, + USER_NAME_CELL, +} from '../../screens/users/user_authentications'; +import { cleanKibana } from '../../tasks/common'; + +import { loginAndWaitForPage } from '../../tasks/login'; + +import { USERS_URL } from '../../urls/navigation'; + +describe('Authentications stats and tables', () => { + before(() => { + cleanKibana(); + + loginAndWaitForPage(USERS_URL); + }); + + it(`renders all authentications`, () => { + const totalUsers = 35; + const usersPerPage = 10; + + cy.get(AUTHENTICATIONS_TAB).click(); + + cy.get(AUTHENTICATIONS_TABLE) + .find(HEADER_SUBTITLE) + .should('have.text', `Showing: ${totalUsers} users`); + cy.get(USER_NAME_CELL).should('have.length', usersPerPage); + }); +}); diff --git a/x-pack/plugins/security_solution/cypress/integration/users/inspect.spec.ts b/x-pack/plugins/security_solution/cypress/integration/users/inspect.spec.ts index f092949ec56aa..70927b3f7c518 100644 --- a/x-pack/plugins/security_solution/cypress/integration/users/inspect.spec.ts +++ b/x-pack/plugins/security_solution/cypress/integration/users/inspect.spec.ts @@ -5,8 +5,10 @@ * 2.0. */ +import { AUTHENTICATIONS_TABLE } from '../../screens/hosts/authentications'; import { INSPECT_MODAL } from '../../screens/inspect'; import { ALL_USERS_TABLE } from '../../screens/users/all_users'; +import { AUTHENTICATIONS_TAB } from '../../screens/users/user_authentications'; import { cleanKibana } from '../../tasks/common'; import { clickInspectButton, closesModal } from '../../tasks/inspect'; @@ -30,5 +32,11 @@ describe('Inspect', () => { clickInspectButton(ALL_USERS_TABLE); cy.get(INSPECT_MODAL).should('be.visible'); }); + + it(`inspects authentications table`, () => { + cy.get(AUTHENTICATIONS_TAB).click(); + clickInspectButton(AUTHENTICATIONS_TABLE); + cy.get(INSPECT_MODAL).should('be.visible'); + }); }); }); diff --git a/x-pack/plugins/security_solution/cypress/screens/users/all_users.ts b/x-pack/plugins/security_solution/cypress/screens/users/all_users.ts index a1d6e9edebf56..96009834dc7a3 100644 --- a/x-pack/plugins/security_solution/cypress/screens/users/all_users.ts +++ b/x-pack/plugins/security_solution/cypress/screens/users/all_users.ts @@ -5,7 +5,7 @@ * 2.0. */ -export const ALL_USERS_TABLE = '[data-test-subj="table-authentications-loading-false"]'; +export const ALL_USERS_TABLE = '[data-test-subj="table-allUsers-loading-false"]'; export const HEADER_SUBTITLE = '[data-test-subj="header-panel-subtitle"]'; diff --git a/x-pack/plugins/security_solution/cypress/screens/users/user_authentications.ts b/x-pack/plugins/security_solution/cypress/screens/users/user_authentications.ts new file mode 100644 index 0000000000000..32340803c4eb1 --- /dev/null +++ b/x-pack/plugins/security_solution/cypress/screens/users/user_authentications.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export const AUTHENTICATIONS_TAB = '[data-test-subj="navigation-authentications"]'; +export const HEADER_SUBTITLE = '[data-test-subj="header-panel-subtitle"]'; +export const USER_NAME_CELL = '[data-test-subj="render-content-user.name"]'; +export const AUTHENTICATIONS_TABLE = '[data-test-subj="table-authentications-loading-false"]'; diff --git a/x-pack/plugins/security_solution/public/common/components/links/index.tsx b/x-pack/plugins/security_solution/public/common/components/links/index.tsx index ab76c848ce16f..6020b0def0aed 100644 --- a/x-pack/plugins/security_solution/public/common/components/links/index.tsx +++ b/x-pack/plugins/security_solution/public/common/components/links/index.tsx @@ -78,7 +78,7 @@ const UserDetailsLinkComponent: React.FC<{ dataTestSubj="data-grid-user-details" href={formatUrl(getUsersDetailsUrl(encodedUserName))} onClick={onClick ?? goToUsersDetails} - title={title ?? encodedUserName} + title={title ?? userName} > {children ? children : userName} diff --git a/x-pack/plugins/security_solution/public/common/components/paginated_table/index.tsx b/x-pack/plugins/security_solution/public/common/components/paginated_table/index.tsx index b9de144c5735e..3b27dc0fcfac6 100644 --- a/x-pack/plugins/security_solution/public/common/components/paginated_table/index.tsx +++ b/x-pack/plugins/security_solution/public/common/components/paginated_table/index.tsx @@ -50,6 +50,7 @@ import * as i18n from './translations'; import { Panel } from '../panel'; import { InspectButtonContainer } from '../inspect'; import { useQueryToggle } from '../../containers/query_toggle'; +import { UsersTableColumns } from '../../../users/components/all_users'; const DEFAULT_DATA_TEST_SUBJ = 'paginated-table'; @@ -89,7 +90,8 @@ declare type BasicTableColumns = | HostRiskScoreColumns | TlsColumns | UncommonProcessTableColumns - | UsersColumns; + | UsersColumns + | UsersTableColumns; declare type SiemTables = BasicTableProps; diff --git a/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.test.ts b/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.test.ts index c1513b7a0485b..131242513e583 100644 --- a/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.test.ts +++ b/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.test.ts @@ -200,18 +200,18 @@ describe('useSearchStrategy', () => { expect(start).toBeCalledWith(expect.objectContaining({ signal })); }); - it('skip = true will cancel any running request', () => { + it('abort = true will cancel any running request', () => { const abortSpy = jest.fn(); const signal = new AbortController().signal; jest.spyOn(window, 'AbortController').mockReturnValue({ abort: abortSpy, signal }); const factoryQueryType = 'fakeQueryType' as FactoryQueryTypes; const localProps = { ...userSearchStrategyProps, - skip: false, + abort: false, factoryQueryType, }; const { rerender } = renderHook(() => useSearchStrategy(localProps)); - localProps.skip = true; + localProps.abort = true; act(() => rerender()); expect(abortSpy).toHaveBeenCalledTimes(1); }); diff --git a/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.tsx b/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.tsx index 234cf039024ba..8e284c7c29413 100644 --- a/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.tsx +++ b/x-pack/plugins/security_solution/public/common/containers/use_search_strategy/index.tsx @@ -33,6 +33,7 @@ import { getInspectResponse } from '../../../helpers'; import { inputsModel } from '../../store'; import { useKibana } from '../../lib/kibana'; import { useAppToasts } from '../../hooks/use_app_toasts'; +import { AbortError } from '../../../../../../../src/plugins/kibana_utils/common'; type UseSearchStrategyRequestArgs = RequestBasicOptions & { data: DataPublicPluginStart; @@ -96,7 +97,7 @@ export const useSearchStrategy = ({ factoryQueryType, initialResult, errorMessage, - skip = false, + abort = false, }: { factoryQueryType: QueryType; /** @@ -107,7 +108,10 @@ export const useSearchStrategy = ({ * Message displayed to the user on a Toast when an erro happens. */ errorMessage?: string; - skip?: boolean; + /** + * When the flag switches from `false` to `true`, it will abort any ongoing request. + */ + abort?: boolean; }) => { const abortCtrl = useRef(new AbortController()); const { getTransformChangesIfTheyExist } = useTransforms(); @@ -122,7 +126,7 @@ export const useSearchStrategy = ({ >(searchComplete); useEffect(() => { - if (error != null) { + if (error != null && !(error instanceof AbortError)) { addError(error, { title: errorMessage ?? i18n.DEFAULT_ERROR_SEARCH_STRATEGY(factoryQueryType), }); @@ -157,10 +161,10 @@ export const useSearchStrategy = ({ }, []); useEffect(() => { - if (skip) { + if (abort) { abortCtrl.current.abort(); } - }, [skip]); + }, [abort]); const [formatedResult, inspect] = useMemo( () => [ diff --git a/x-pack/plugins/security_solution/public/common/mock/global_state.ts b/x-pack/plugins/security_solution/public/common/mock/global_state.ts index 52f0b1a682097..9882ca9f3ab3d 100644 --- a/x-pack/plugins/security_solution/public/common/mock/global_state.ts +++ b/x-pack/plugins/security_solution/public/common/mock/global_state.ts @@ -41,6 +41,7 @@ import { mockRuntimeMappings, } from '../containers/source/mock'; import { usersModel } from '../../users/store'; +import { UsersFields } from '../../../common/search_strategy/security_solution/users/common'; export const mockSourcererState = { ...initialSourcererState, @@ -203,6 +204,11 @@ export const mockGlobalState: State = { [usersModel.UsersTableType.allUsers]: { activePage: 0, limit: 10, + sort: { field: UsersFields.name, direction: Direction.asc }, + }, + [usersModel.UsersTableType.authentications]: { + activePage: 0, + limit: 10, }, [usersModel.UsersTableType.anomalies]: null, [usersModel.UsersTableType.risk]: { diff --git a/x-pack/plugins/security_solution/public/users/components/all_users/index.test.tsx b/x-pack/plugins/security_solution/public/users/components/all_users/index.test.tsx new file mode 100644 index 0000000000000..117a62e0494df --- /dev/null +++ b/x-pack/plugins/security_solution/public/users/components/all_users/index.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import '../../../common/mock/match_media'; +import { TestProviders } from '../../../common/mock'; + +import { UsersTable } from '.'; +import { usersModel } from '../../store'; +import { Direction } from '../../../../common/search_strategy'; +import { UsersFields } from '../../../../common/search_strategy/security_solution/users/common'; +import { render } from '@testing-library/react'; + +describe('Users Table Component', () => { + const loadPage = jest.fn(); + + describe('rendering', () => { + test('it renders the users table', () => { + const userName = 'testUser'; + const { getByTestId, getAllByRole, getByText } = render( + + {}} + /> + + ); + + expect(getByTestId('table-allUsers-loading-false')).toBeInTheDocument(); + expect(getAllByRole('columnheader').length).toBe(3); + expect(getByText(userName)).toBeInTheDocument(); + }); + }); +}); diff --git a/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx b/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx new file mode 100644 index 0000000000000..15626d0650ac8 --- /dev/null +++ b/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx @@ -0,0 +1,186 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useCallback, useMemo } from 'react'; +import { useDispatch } from 'react-redux'; + +import { FormattedRelativePreferenceDate } from '../../../common/components/formatted_date'; +import { UserDetailsLink } from '../../../common/components/links'; + +import { + Columns, + Criteria, + ItemsPerRow, + PaginatedTable, +} from '../../../common/components/paginated_table'; + +import { getRowItemDraggables } from '../../../common/components/tables/helpers'; +import { useDeepEqualSelector } from '../../../common/hooks/use_selector'; + +import * as i18n from './translations'; +import { usersActions, usersModel, usersSelectors } from '../../store'; +import { User } from '../../../../common/search_strategy/security_solution/users/all'; +import { SortUsersField } from '../../../../common/search_strategy/security_solution/users/common'; + +const tableType = usersModel.UsersTableType.allUsers; + +interface UsersTableProps { + users: User[]; + fakeTotalCount: number; + loading: boolean; + loadPage: (newActivePage: number) => void; + id: string; + showMorePagesIndicator: boolean; + totalCount: number; + type: usersModel.UsersType; + sort: SortUsersField; + setQuerySkip: (skip: boolean) => void; +} + +export type UsersTableColumns = [ + Columns, + Columns, + Columns +]; + +const rowItems: ItemsPerRow[] = [ + { + text: i18n.ROWS_5, + numberOfRow: 5, + }, + { + text: i18n.ROWS_10, + numberOfRow: 10, + }, +]; + +const UsersTableComponent: React.FC = ({ + users, + totalCount, + type, + id, + fakeTotalCount, + loading, + loadPage, + showMorePagesIndicator, + sort, + setQuerySkip, +}) => { + const dispatch = useDispatch(); + const getUsersSelector = useMemo(() => usersSelectors.allUsersSelector(), []); + const { activePage, limit } = useDeepEqualSelector((state) => getUsersSelector(state)); + + const updateLimitPagination = useCallback( + (newLimit) => { + dispatch( + usersActions.updateTableLimit({ + usersType: type, + limit: newLimit, + tableType, + }) + ); + }, + [type, dispatch] + ); + + const updateActivePage = useCallback( + (newPage) => { + dispatch( + usersActions.updateTableActivePage({ + activePage: newPage, + usersType: type, + tableType, + }) + ); + }, + [type, dispatch] + ); + + const onSort = useCallback( + (criteria: Criteria) => { + if (criteria.sort != null) { + const newSort = criteria.sort; + if (newSort.direction !== sort.direction || newSort.field !== sort.field) { + dispatch( + usersActions.updateTableSorting({ + sort: newSort as SortUsersField, + tableType, + }) + ); + } + } + }, + [dispatch, sort] + ); + const columns = useMemo(() => getUsersColumns(), []); + + return ( + + ); +}; + +UsersTableComponent.displayName = 'UsersTableComponent'; + +export const UsersTable = React.memo(UsersTableComponent); + +const getUsersColumns = (): UsersTableColumns => [ + { + field: 'name', + name: i18n.USER_NAME, + truncateText: false, + sortable: true, + mobileOptions: { show: true }, + render: (name) => + getRowItemDraggables({ + rowItems: [name], + attrName: 'user.name', + idPrefix: `users-table-${name}-name`, + render: (item) => , + }), + }, + { + field: 'lastSeen', + name: i18n.LAST_SEEN, + sortable: true, + truncateText: false, + mobileOptions: { show: true }, + render: (lastSeen) => , + }, + { + field: 'domain', + name: i18n.DOMAIN, + sortable: false, + truncateText: false, + mobileOptions: { show: true }, + render: (domain) => + getRowItemDraggables({ + rowItems: [domain], + attrName: 'user.domain', + idPrefix: `users-table-${domain}-domain`, + }), + }, +]; diff --git a/x-pack/plugins/security_solution/public/users/components/all_users/translations.ts b/x-pack/plugins/security_solution/public/users/components/all_users/translations.ts new file mode 100644 index 0000000000000..e24c8575f0ef0 --- /dev/null +++ b/x-pack/plugins/security_solution/public/users/components/all_users/translations.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { i18n } from '@kbn/i18n'; + +export const USERS = i18n.translate('xpack.securitySolution.usersTable.title', { + defaultMessage: 'Users', +}); + +export const USER_NAME = i18n.translate('xpack.securitySolution.usersTable.userNameTitle', { + defaultMessage: 'User name', +}); + +export const LAST_SEEN = i18n.translate('xpack.securitySolution.usersTable.lastSeenTitle', { + defaultMessage: 'Last seen', +}); + +export const DOMAIN = i18n.translate('xpack.securitySolution.usersTable.domainTitle', { + defaultMessage: 'Domain', +}); + +export const ROWS_5 = i18n.translate('xpack.securitySolution.usersTable.rows', { + values: { numRows: 5 }, + defaultMessage: '{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}', +}); + +export const ROWS_10 = i18n.translate('xpack.securitySolution.usersTable.rows', { + values: { numRows: 10 }, + defaultMessage: '{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}', +}); + +export const UNIT = (totalCount: number) => + i18n.translate('xpack.securitySolution.usersTable.unit', { + values: { totalCount }, + defaultMessage: `{totalCount, plural, =1 {user} other {users}}`, + }); diff --git a/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.test.tsx b/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.test.tsx index 6425f40016fb9..cedfd6b50153d 100644 --- a/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.test.tsx +++ b/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.test.tsx @@ -52,7 +52,7 @@ describe('Total Users KPI', () => { ); - expect(mockUseSearchStrategy.mock.calls[0][0].skip).toEqual(false); + expect(mockUseSearchStrategy.mock.calls[0][0].abort).toEqual(false); expect(mockSearch).toHaveBeenCalled(); }); it('toggleStatus=false, skip', () => { @@ -62,7 +62,7 @@ describe('Total Users KPI', () => { ); - expect(mockUseSearchStrategy.mock.calls[0][0].skip).toEqual(true); + expect(mockUseSearchStrategy.mock.calls[0][0].abort).toEqual(true); expect(mockSearch).not.toHaveBeenCalled(); }); }); diff --git a/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.tsx b/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.tsx index ffa5d851875ce..d4f1ac9df22c8 100644 --- a/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.tsx +++ b/x-pack/plugins/security_solution/public/users/components/kpi_users/total_users/index.tsx @@ -61,7 +61,7 @@ const TotalUsersKpiComponent: React.FC = ({ setQuery, skip, }) => { - const { toggleStatus } = useQueryToggle(UsersQueries.kpiTotalUsers); + const { toggleStatus } = useQueryToggle(QUERY_ID); const [querySkip, setQuerySkip] = useState(skip || !toggleStatus); useEffect(() => { setQuerySkip(skip || !toggleStatus); @@ -71,7 +71,7 @@ const TotalUsersKpiComponent: React.FC = ({ factoryQueryType: UsersQueries.kpiTotalUsers, initialResult: { users: 0, usersHistogram: [] }, errorMessage: i18n.ERROR_USERS_KPI, - skip: querySkip, + abort: querySkip, }); useEffect(() => { diff --git a/x-pack/plugins/security_solution/public/users/pages/constants.ts b/x-pack/plugins/security_solution/public/users/pages/constants.ts index 793d7c6164b2d..39d8c1546c863 100644 --- a/x-pack/plugins/security_solution/public/users/pages/constants.ts +++ b/x-pack/plugins/security_solution/public/users/pages/constants.ts @@ -10,6 +10,6 @@ import { UsersTableType } from '../store/model'; export const usersDetailsPagePath = `${USERS_PATH}/:detailName`; -export const usersTabPath = `${USERS_PATH}/:tabName(${UsersTableType.allUsers}|${UsersTableType.anomalies}|${UsersTableType.risk}|${UsersTableType.events}|${UsersTableType.alerts})`; +export const usersTabPath = `${USERS_PATH}/:tabName(${UsersTableType.allUsers}|${UsersTableType.authentications}|${UsersTableType.anomalies}|${UsersTableType.risk}|${UsersTableType.events}|${UsersTableType.alerts})`; export const usersDetailsTabPath = `${usersDetailsPagePath}/:tabName(${UsersTableType.anomalies}|${UsersTableType.events}|${UsersTableType.alerts})`; diff --git a/x-pack/plugins/security_solution/public/users/pages/details/utils.ts b/x-pack/plugins/security_solution/public/users/pages/details/utils.ts index f4bdd7e6caa67..e648a8998a989 100644 --- a/x-pack/plugins/security_solution/public/users/pages/details/utils.ts +++ b/x-pack/plugins/security_solution/public/users/pages/details/utils.ts @@ -22,6 +22,7 @@ export const type = usersModel.UsersType.details; const TabNameMappedToI18nKey: Record = { [UsersTableType.allUsers]: i18n.NAVIGATION_ALL_USERS_TITLE, + [UsersTableType.authentications]: i18n.NAVIGATION_AUTHENTICATIONS_TITLE, [UsersTableType.anomalies]: i18n.NAVIGATION_ANOMALIES_TITLE, [UsersTableType.risk]: i18n.NAVIGATION_RISK_TITLE, [UsersTableType.events]: i18n.NAVIGATION_EVENTS_TITLE, diff --git a/x-pack/plugins/security_solution/public/users/pages/nav_tabs.tsx b/x-pack/plugins/security_solution/public/users/pages/nav_tabs.tsx index 254807eae27cc..3097fdeb604f3 100644 --- a/x-pack/plugins/security_solution/public/users/pages/nav_tabs.tsx +++ b/x-pack/plugins/security_solution/public/users/pages/nav_tabs.tsx @@ -26,6 +26,12 @@ export const navTabsUsers = ( href: getTabsOnUsersUrl(UsersTableType.allUsers), disabled: false, }, + [UsersTableType.authentications]: { + id: UsersTableType.authentications, + name: i18n.NAVIGATION_AUTHENTICATIONS_TITLE, + href: getTabsOnUsersUrl(UsersTableType.authentications), + disabled: false, + }, [UsersTableType.anomalies]: { id: UsersTableType.anomalies, name: i18n.NAVIGATION_ANOMALIES_TITLE, diff --git a/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.test.tsx b/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.test.tsx index 98b69d531c4dc..b0147258b178c 100644 --- a/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.test.tsx +++ b/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.test.tsx @@ -8,61 +8,69 @@ import React from 'react'; import { render } from '@testing-library/react'; import { TestProviders } from '../../../common/mock'; -import { useAuthentications } from '../../../hosts/containers/authentications'; + import { useQueryToggle } from '../../../common/containers/query_toggle'; import { AllUsersQueryTabBody } from './all_users_query_tab_body'; import { UsersType } from '../../store/model'; -jest.mock('../../../hosts/containers/authentications'); jest.mock('../../../common/containers/query_toggle'); jest.mock('../../../common/lib/kibana'); +const mockSearch = jest.fn(); + +jest.mock('../../../common/containers/use_search_strategy', () => { + const original = jest.requireActual('../../../common/containers/use_search_strategy'); + return { + ...original, + useSearchStrategy: () => ({ + search: mockSearch, + loading: false, + inspect: { + dsl: [], + response: [], + }, + result: { + users: [], + totalCount: 0, + pageInfo: { activePage: 1, fakeTotalCount: 100, showMorePagesIndicator: false }, + }, + refetch: jest.fn(), + }), + }; +}); + describe('All users query tab body', () => { - const mockUseAuthentications = useAuthentications as jest.Mock; const mockUseQueryToggle = useQueryToggle as jest.Mock; const defaultProps = { + skip: false, indexNames: [], setQuery: jest.fn(), - skip: false, startDate: '2019-06-25T04:31:59.345Z', endDate: '2019-06-25T06:31:59.345Z', type: UsersType.page, }; + beforeEach(() => { jest.clearAllMocks(); - mockUseQueryToggle.mockReturnValue({ toggleStatus: true, setToggleStatus: jest.fn() }); - mockUseAuthentications.mockReturnValue([ - false, - { - authentications: [], - id: '123', - inspect: { - dsl: [], - response: [], - }, - isInspected: false, - totalCount: 0, - pageInfo: { activePage: 1, fakeTotalCount: 100, showMorePagesIndicator: false }, - loadPage: jest.fn(), - refetch: jest.fn(), - }, - ]); }); - it('toggleStatus=true, do not skip', () => { + + it('calls search when toggleStatus=true', () => { + mockUseQueryToggle.mockReturnValue({ toggleStatus: true, setToggleStatus: jest.fn() }); render( ); - expect(mockUseAuthentications.mock.calls[0][0].skip).toEqual(false); + expect(mockSearch).toHaveBeenCalled(); }); - it('toggleStatus=false, skip', () => { + + it("doesn't calls search when toggleStatus=false", () => { mockUseQueryToggle.mockReturnValue({ toggleStatus: false, setToggleStatus: jest.fn() }); render( ); - expect(mockUseAuthentications.mock.calls[0][0].skip).toEqual(true); + expect(mockSearch).not.toHaveBeenCalled(); }); }); diff --git a/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.tsx b/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.tsx index b5c8b199fda54..164df6325bb09 100644 --- a/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.tsx +++ b/x-pack/plugins/security_solution/public/users/pages/navigation/all_users_query_tab_body.tsx @@ -5,16 +5,24 @@ * 2.0. */ -import { getOr } from 'lodash/fp'; -import React, { useEffect, useState } from 'react'; -import { useAuthentications, ID } from '../../../hosts/containers/authentications'; +import { getOr, noop } from 'lodash/fp'; +import React, { useEffect, useMemo, useState } from 'react'; + import { UsersComponentsQueryProps } from './types'; -import { AuthenticationTable } from '../../../hosts/components/authentications_table'; import { manageQuery } from '../../../common/components/page/manage_query'; +import { UsersTable } from '../../components/all_users'; +import { useSearchStrategy } from '../../../common/containers/use_search_strategy'; +import { UsersQueries } from '../../../../common/search_strategy/security_solution/users'; +import * as i18n from './translations'; +import { generateTablePaginationOptions } from '../../../common/components/paginated_table/helpers'; +import { useDeepEqualSelector } from '../../../common/hooks/use_selector'; +import { usersSelectors } from '../../store'; import { useQueryToggle } from '../../../common/containers/query_toggle'; -const AuthenticationTableManage = manageQuery(AuthenticationTable); +const UsersTableManage = manageQuery(UsersTable); + +const QUERY_ID = 'UsersTable'; export const AllUsersQueryTabBody = ({ endDate, @@ -27,46 +35,80 @@ export const AllUsersQueryTabBody = ({ docValueFields, deleteQuery, }: UsersComponentsQueryProps) => { - const { toggleStatus } = useQueryToggle(ID); + const { toggleStatus } = useQueryToggle(QUERY_ID); const [querySkip, setQuerySkip] = useState(skip || !toggleStatus); useEffect(() => { setQuerySkip(skip || !toggleStatus); }, [skip, toggleStatus]); - const [ + + const getUsersSelector = useMemo(() => usersSelectors.allUsersSelector(), []); + const { activePage, limit, sort } = useDeepEqualSelector((state) => getUsersSelector(state)); + + const { loading, - { authentications, totalCount, pageInfo, loadPage, id, inspect, isInspected, refetch }, - ] = useAuthentications({ - docValueFields, + result: { users, pageInfo, totalCount }, + search, + refetch, + inspect, + } = useSearchStrategy({ + factoryQueryType: UsersQueries.users, + initialResult: { + users: [], + totalCount: 0, + pageInfo: { + activePage: 0, + fakeTotalCount: 0, + showMorePagesIndicator: false, + }, + }, + errorMessage: i18n.ERROR_FETCHING_USERS_DATA, + abort: querySkip, + }); + + useEffect(() => { + if (!querySkip) { + search({ + filterQuery, + defaultIndex: indexNames, + docValueFields, + timerange: { + interval: '12h', + from: startDate, + to: endDate, + }, + pagination: generateTablePaginationOptions(activePage, limit), + sort, + }); + } + }, [ + search, + startDate, endDate, filterQuery, indexNames, - skip: querySkip, - startDate, - // TODO Move authentication table and hook store to 'public/common' folder when 'usersEnabled' FF is removed - // @ts-ignore - type, - deleteQuery, - }); + querySkip, + docValueFields, + activePage, + limit, + sort, + ]); + return ( - ); }; diff --git a/x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.test.tsx b/x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.test.tsx new file mode 100644 index 0000000000000..83c2b0dfa6b72 --- /dev/null +++ b/x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { render } from '@testing-library/react'; +import { TestProviders } from '../../../common/mock'; +import { useAuthentications } from '../../../hosts/containers/authentications'; +import { useQueryToggle } from '../../../common/containers/query_toggle'; +import { AuthenticationsQueryTabBody } from './authentications_query_tab_body'; +import { UsersType } from '../../store/model'; + +jest.mock('../../../hosts/containers/authentications'); +jest.mock('../../../common/containers/query_toggle'); +jest.mock('../../../common/lib/kibana'); + +describe('Authentications query tab body', () => { + const mockUseAuthentications = useAuthentications as jest.Mock; + const mockUseQueryToggle = useQueryToggle as jest.Mock; + const defaultProps = { + indexNames: [], + setQuery: jest.fn(), + skip: false, + startDate: '2019-06-25T04:31:59.345Z', + endDate: '2019-06-25T06:31:59.345Z', + type: UsersType.page, + }; + beforeEach(() => { + jest.clearAllMocks(); + mockUseQueryToggle.mockReturnValue({ toggleStatus: true, setToggleStatus: jest.fn() }); + mockUseAuthentications.mockReturnValue([ + false, + { + authentications: [], + id: '123', + inspect: { + dsl: [], + response: [], + }, + isInspected: false, + totalCount: 0, + pageInfo: { activePage: 1, fakeTotalCount: 100, showMorePagesIndicator: false }, + loadPage: jest.fn(), + refetch: jest.fn(), + }, + ]); + }); + it('toggleStatus=true, do not skip', () => { + render( + + + + ); + expect(mockUseAuthentications.mock.calls[0][0].skip).toEqual(false); + }); + it('toggleStatus=false, skip', () => { + mockUseQueryToggle.mockReturnValue({ toggleStatus: false, setToggleStatus: jest.fn() }); + render( + + + + ); + expect(mockUseAuthentications.mock.calls[0][0].skip).toEqual(true); + }); +}); diff --git a/x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.tsx b/x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.tsx new file mode 100644 index 0000000000000..6926a1e755f01 --- /dev/null +++ b/x-pack/plugins/security_solution/public/users/pages/navigation/authentications_query_tab_body.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { getOr } from 'lodash/fp'; +import React, { useEffect, useState } from 'react'; +import { useAuthentications, ID } from '../../../hosts/containers/authentications'; +import { UsersComponentsQueryProps } from './types'; +import { AuthenticationTable } from '../../../hosts/components/authentications_table'; +import { manageQuery } from '../../../common/components/page/manage_query'; +import { useQueryToggle } from '../../../common/containers/query_toggle'; + +const AuthenticationTableManage = manageQuery(AuthenticationTable); + +export const AuthenticationsQueryTabBody = ({ + endDate, + filterQuery, + indexNames, + skip, + setQuery, + startDate, + type, + docValueFields, + deleteQuery, +}: UsersComponentsQueryProps) => { + const { toggleStatus } = useQueryToggle(ID); + const [querySkip, setQuerySkip] = useState(skip || !toggleStatus); + useEffect(() => { + setQuerySkip(skip || !toggleStatus); + }, [skip, toggleStatus]); + + const [ + loading, + { authentications, totalCount, pageInfo, loadPage, id, inspect, isInspected, refetch }, + ] = useAuthentications({ + docValueFields, + endDate, + filterQuery, + indexNames, + skip: querySkip, + startDate, + // TODO Move authentication table and hook store to 'public/common' folder when 'usersEnabled' FF is removed + // @ts-ignore + type, + deleteQuery, + }); + return ( + + ); +}; + +AuthenticationsQueryTabBody.displayName = 'AllUsersQueryTabBody'; diff --git a/x-pack/plugins/security_solution/public/users/pages/navigation/index.ts b/x-pack/plugins/security_solution/public/users/pages/navigation/index.ts index 0d6393bee9369..5cc5e255719ba 100644 --- a/x-pack/plugins/security_solution/public/users/pages/navigation/index.ts +++ b/x-pack/plugins/security_solution/public/users/pages/navigation/index.ts @@ -6,3 +6,4 @@ */ export * from './all_users_query_tab_body'; +export * from './authentications_query_tab_body'; diff --git a/x-pack/plugins/security_solution/public/users/pages/navigation/translations.ts b/x-pack/plugins/security_solution/public/users/pages/navigation/translations.ts new file mode 100644 index 0000000000000..c625927320ba1 --- /dev/null +++ b/x-pack/plugins/security_solution/public/users/pages/navigation/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { i18n } from '@kbn/i18n'; + +export const ERROR_FETCHING_USERS_DATA = i18n.translate( + 'xpack.securitySolution.userTab.errorFetchingsData', + { + defaultMessage: 'Failed to query users data', + } +); diff --git a/x-pack/plugins/security_solution/public/users/pages/translations.ts b/x-pack/plugins/security_solution/public/users/pages/translations.ts index 96dcf8d2c8871..41fec21c5bfb0 100644 --- a/x-pack/plugins/security_solution/public/users/pages/translations.ts +++ b/x-pack/plugins/security_solution/public/users/pages/translations.ts @@ -18,6 +18,13 @@ export const NAVIGATION_ALL_USERS_TITLE = i18n.translate( } ); +export const NAVIGATION_AUTHENTICATIONS_TITLE = i18n.translate( + 'xpack.securitySolution.users.navigation.authenticationsTitle', + { + defaultMessage: 'Authentications', + } +); + export const NAVIGATION_ANOMALIES_TITLE = i18n.translate( 'xpack.securitySolution.users.navigation.anomaliesTitle', { diff --git a/x-pack/plugins/security_solution/public/users/pages/users_tabs.tsx b/x-pack/plugins/security_solution/public/users/pages/users_tabs.tsx index 522ff4c009504..c0e3fb3e4ab18 100644 --- a/x-pack/plugins/security_solution/public/users/pages/users_tabs.tsx +++ b/x-pack/plugins/security_solution/public/users/pages/users_tabs.tsx @@ -11,7 +11,7 @@ import { Route, Switch } from 'react-router-dom'; import { UsersTabsProps } from './types'; import { UsersTableType } from '../store/model'; import { USERS_PATH } from '../../../common/constants'; -import { AllUsersQueryTabBody } from './navigation'; +import { AllUsersQueryTabBody, AuthenticationsQueryTabBody } from './navigation'; import { AnomaliesQueryTabBody } from '../../common/containers/anomalies/anomalies_query_tab_body'; import { AnomaliesUserTable } from '../../common/components/ml/tables/anomalies_user_table'; import { Anomaly } from '../../common/components/ml/types'; @@ -80,6 +80,9 @@ export const UsersTabs = memo( + + + diff --git a/x-pack/plugins/security_solution/public/users/store/actions.ts b/x-pack/plugins/security_solution/public/users/store/actions.ts index b1d83f29da8c8..9e68891ba3975 100644 --- a/x-pack/plugins/security_solution/public/users/store/actions.ts +++ b/x-pack/plugins/security_solution/public/users/store/actions.ts @@ -8,6 +8,7 @@ import actionCreatorFactory from 'typescript-fsa'; import { usersModel } from '.'; import { RiskScoreSortField, RiskSeverity } from '../../../common/search_strategy'; +import { SortUsersField } from '../../../common/search_strategy/security_solution/users/common'; const actionCreator = actionCreatorFactory('x-pack/security_solution/local/users'); @@ -30,8 +31,8 @@ export const updateTableActivePage = actionCreator<{ }>('UPDATE_USERS_ACTIVE_PAGE'); export const updateTableSorting = actionCreator<{ - sort: RiskScoreSortField; - tableType: usersModel.UsersTableType.risk; + tableType: usersModel.UsersTableType; + sort: RiskScoreSortField | SortUsersField; }>('UPDATE_USERS_SORTING'); export const updateUserRiskScoreSeverityFilter = actionCreator<{ diff --git a/x-pack/plugins/security_solution/public/users/store/model.ts b/x-pack/plugins/security_solution/public/users/store/model.ts index 6e4a3730eca86..491f35c5efd12 100644 --- a/x-pack/plugins/security_solution/public/users/store/model.ts +++ b/x-pack/plugins/security_solution/public/users/store/model.ts @@ -6,6 +6,7 @@ */ import { RiskScoreSortField, RiskSeverity } from '../../../common/search_strategy'; +import { SortUsersField } from '../../../common/search_strategy/security_solution/users/common'; export enum UsersType { page = 'page', @@ -14,6 +15,7 @@ export enum UsersType { export enum UsersTableType { allUsers = 'allUsers', + authentications = 'authentications', anomalies = 'anomalies', risk = 'userRisk', events = 'events', @@ -27,15 +29,18 @@ export interface BasicQueryPaginated { limit: number; } -export type AllUsersQuery = BasicQueryPaginated; +export interface AllUsersQuery extends BasicQueryPaginated { + sort: SortUsersField; +} export interface UsersRiskScoreQuery extends BasicQueryPaginated { - sort: RiskScoreSortField; // TODO fix it when be is implemented + sort: RiskScoreSortField; severitySelection: RiskSeverity[]; } export interface UsersQueries { [UsersTableType.allUsers]: AllUsersQuery; + [UsersTableType.authentications]: BasicQueryPaginated; [UsersTableType.anomalies]: null | undefined; [UsersTableType.risk]: UsersRiskScoreQuery; [UsersTableType.events]: BasicQueryPaginated; diff --git a/x-pack/plugins/security_solution/public/users/store/reducer.ts b/x-pack/plugins/security_solution/public/users/store/reducer.ts index 4b263eecb8c5a..3eaf57a37bda3 100644 --- a/x-pack/plugins/security_solution/public/users/store/reducer.ts +++ b/x-pack/plugins/security_solution/public/users/store/reducer.ts @@ -19,6 +19,7 @@ import { setUsersPageQueriesActivePageToZero } from './helpers'; import { UsersTableType, UsersModel } from './model'; import { Direction } from '../../../common/search_strategy/common'; import { RiskScoreFields } from '../../../common/search_strategy'; +import { UsersFields } from '../../../common/search_strategy/security_solution/users/common'; export const initialUsersState: UsersModel = { page: { @@ -26,6 +27,14 @@ export const initialUsersState: UsersModel = { [UsersTableType.allUsers]: { activePage: DEFAULT_TABLE_ACTIVE_PAGE, limit: DEFAULT_TABLE_LIMIT, + sort: { + field: UsersFields.lastSeen, + direction: Direction.desc, + }, + }, + [UsersTableType.authentications]: { + activePage: DEFAULT_TABLE_ACTIVE_PAGE, + limit: DEFAULT_TABLE_LIMIT, }, [UsersTableType.risk]: { activePage: DEFAULT_TABLE_ACTIVE_PAGE, diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__mocks__/index.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__mocks__/index.ts new file mode 100644 index 0000000000000..753a648d307e8 --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__mocks__/index.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { IEsSearchResponse } from '../../../../../../../../../../src/plugins/data/common'; +import { Direction } from '../../../../../../../common/search_strategy'; +import { UsersQueries } from '../../../../../../../common/search_strategy/security_solution/users'; +import { UsersRequestOptions } from '../../../../../../../common/search_strategy/security_solution/users/all'; +import { UsersFields } from '../../../../../../../common/search_strategy/security_solution/users/common'; + +export const mockOptions: UsersRequestOptions = { + defaultIndex: ['test_indices*'], + docValueFields: [ + { + field: '@timestamp', + format: 'date_time', + }, + ], + factoryQueryType: UsersQueries.users, + filterQuery: + '{"bool":{"must":[],"filter":[{"match_all":{}},{"match_phrase":{"user.name":{"query":"test_user"}}}],"should":[],"must_not":[]}}', + timerange: { + interval: '12h', + from: '2020-09-02T15:17:13.678Z', + to: '2020-09-03T15:17:13.678Z', + }, + params: {}, + pagination: { + activePage: 0, + cursorStart: 0, + fakePossibleCount: 50, + querySize: 10, + }, + sort: { field: UsersFields.name, direction: Direction.asc }, +}; + +export const mockSearchStrategyResponse: IEsSearchResponse = { + rawResponse: { + took: 2, + timed_out: false, + _shards: { + total: 2, + successful: 2, + skipped: 1, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + user_count: { + value: 1, + }, + user_data: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [ + { + key: 'vagrant', + doc_count: 780, + lastSeen: { + value: 1644837532000, + value_as_string: '2022-02-14T11:18:52.000Z', + }, + domain: { + hits: { + total: { + value: 780, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: 'endgame-00001', + _id: 'inT0934BjUd1_U2597Vf', + _score: null, + _source: { + user: { + domain: 'ENDPOINT-W-8-03', + }, + }, + sort: [1644837532000], + }, + ], + }, + }, + }, + ], + }, + }, + }, + isPartial: false, + isRunning: false, + total: 2, + loaded: 2, +}; diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/index.test.ts.snap b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/index.test.ts.snap new file mode 100644 index 0000000000000..b52d0b1fc1cfd --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/index.test.ts.snap @@ -0,0 +1,21 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`allHosts search strategy parse should parse data correctly 1`] = ` +Array [ + Object { + "domain": "ENDPOINT-W-8-03", + "lastSeen": "2022-02-14T11:18:52.000Z", + "name": "vagrant", + }, +] +`; + +exports[`allHosts search strategy parse should parse data correctly 2`] = `1`; + +exports[`allHosts search strategy parse should parse data correctly 3`] = ` +Object { + "activePage": 0, + "fakeTotalCount": 1, + "showMorePagesIndicator": false, +} +`; diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/query.all_users.dsl.test.ts.snap b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/query.all_users.dsl.test.ts.snap new file mode 100644 index 0000000000000..99f85724d2f5c --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/__snapshots__/query.all_users.dsl.test.ts.snap @@ -0,0 +1,95 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`buildUsersQuery build query from options correctly 1`] = ` +Object { + "allow_no_indices": true, + "body": Object { + "aggregations": Object { + "user_count": Object { + "cardinality": Object { + "field": "user.name", + }, + }, + "user_data": Object { + "aggs": Object { + "domain": Object { + "top_hits": Object { + "_source": Object { + "includes": Array [ + "user.domain", + ], + }, + "size": 1, + "sort": Array [ + Object { + "@timestamp": Object { + "order": "desc", + }, + }, + ], + }, + }, + "lastSeen": Object { + "max": Object { + "field": "@timestamp", + }, + }, + }, + "terms": Object { + "field": "user.name", + "order": Object { + "_key": "asc", + }, + "size": 10, + }, + }, + }, + "docvalue_fields": Array [ + Object { + "field": "@timestamp", + "format": "date_time", + }, + ], + "query": Object { + "bool": Object { + "filter": Array [ + Object { + "bool": Object { + "filter": Array [ + Object { + "match_all": Object {}, + }, + Object { + "match_phrase": Object { + "user.name": Object { + "query": "test_user", + }, + }, + }, + ], + "must": Array [], + "must_not": Array [], + "should": Array [], + }, + }, + Object { + "range": Object { + "@timestamp": Object { + "format": "strict_date_optional_time", + "gte": "2020-09-02T15:17:13.678Z", + "lte": "2020-09-03T15:17:13.678Z", + }, + }, + }, + ], + }, + }, + "size": 0, + }, + "ignore_unavailable": true, + "index": Array [ + "test_indices*", + ], + "track_total_hits": false, +} +`; diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.test.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.test.ts new file mode 100644 index 0000000000000..5d7562e1e0a7f --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.test.ts @@ -0,0 +1,51 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { DEFAULT_MAX_TABLE_QUERY_SIZE } from '../../../../../../common/constants'; + +import * as buildQuery from './query.all_users.dsl'; +import { allUsers } from '.'; +import { mockOptions, mockSearchStrategyResponse } from './__mocks__'; +import { UsersRequestOptions } from '../../../../../../common/search_strategy/security_solution/users/all'; + +describe('allHosts search strategy', () => { + const buildAllHostsQuery = jest.spyOn(buildQuery, 'buildUsersQuery'); + + afterEach(() => { + buildAllHostsQuery.mockClear(); + }); + + describe('buildDsl', () => { + test('should build dsl query', () => { + allUsers.buildDsl(mockOptions); + expect(buildAllHostsQuery).toHaveBeenCalledWith(mockOptions); + }); + + test('should throw error if query size is greater equal than DEFAULT_MAX_TABLE_QUERY_SIZE ', () => { + const overSizeOptions = { + ...mockOptions, + pagination: { + ...mockOptions.pagination, + querySize: DEFAULT_MAX_TABLE_QUERY_SIZE, + }, + } as UsersRequestOptions; + + expect(() => { + allUsers.buildDsl(overSizeOptions); + }).toThrowError(`No query size above ${DEFAULT_MAX_TABLE_QUERY_SIZE}`); + }); + }); + + describe('parse', () => { + test('should parse data correctly', async () => { + const result = await allUsers.parse(mockOptions, mockSearchStrategyResponse); + expect(result.users).toMatchSnapshot(); + expect(result.totalCount).toMatchSnapshot(); + expect(result.pageInfo).toMatchSnapshot(); + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.ts new file mode 100644 index 0000000000000..645a5350ca988 --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/index.ts @@ -0,0 +1,71 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { getOr } from 'lodash/fp'; + +import type { IEsSearchResponse } from '../../../../../../../../../src/plugins/data/common'; +import { DEFAULT_MAX_TABLE_QUERY_SIZE } from '../../../../../../common/constants'; + +import { inspectStringifyObject } from '../../../../../utils/build_query'; +import { SecuritySolutionFactory } from '../../types'; +import { buildUsersQuery } from './query.all_users.dsl'; +import { UsersQueries } from '../../../../../../common/search_strategy/security_solution/users'; +import { + UsersRequestOptions, + UsersStrategyResponse, +} from '../../../../../../common/search_strategy/security_solution/users/all'; +import { AllUsersAggEsItem } from '../../../../../../common/search_strategy/security_solution/users/common'; + +export const allUsers: SecuritySolutionFactory = { + buildDsl: (options: UsersRequestOptions) => { + if (options.pagination && options.pagination.querySize >= DEFAULT_MAX_TABLE_QUERY_SIZE) { + throw new Error(`No query size above ${DEFAULT_MAX_TABLE_QUERY_SIZE}`); + } + return buildUsersQuery(options); + }, + parse: async ( + options: UsersRequestOptions, + response: IEsSearchResponse + ): Promise => { + const { activePage, cursorStart, fakePossibleCount, querySize } = options.pagination; + const inspect = { + dsl: [inspectStringifyObject(buildUsersQuery(options))], + }; + + const buckets: AllUsersAggEsItem[] = getOr( + [], + 'aggregations.user_data.buckets', + response.rawResponse + ); + + const totalCount = getOr(0, 'aggregations.user_count.value', response.rawResponse); + + const fakeTotalCount = fakePossibleCount <= totalCount ? fakePossibleCount : totalCount; + + const users = buckets.map( + (bucket: AllUsersAggEsItem) => ({ + name: bucket.key, + lastSeen: getOr(null, `lastSeen.value_as_string`, bucket), + domain: getOr(null, `domain.hits.hits[0]._source.user.domain`, bucket), + }), + {} + ); + + const showMorePagesIndicator = totalCount > fakeTotalCount; + return { + ...response, + inspect, + totalCount, + users: users.splice(cursorStart, querySize - cursorStart), + pageInfo: { + activePage: activePage ?? 0, + fakeTotalCount, + showMorePagesIndicator, + }, + }; + }, +}; diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.test.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.test.ts new file mode 100644 index 0000000000000..3a0e209044514 --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { buildUsersQuery } from './query.all_users.dsl'; +import { mockOptions } from './__mocks__/'; + +describe('buildUsersQuery', () => { + test('build query from options correctly', () => { + expect(buildUsersQuery(mockOptions)).toMatchSnapshot(); + }); +}); diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts new file mode 100644 index 0000000000000..ee98c92d2ac6b --- /dev/null +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts @@ -0,0 +1,92 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { isEmpty } from 'lodash/fp'; +import type { ISearchRequestParams } from '../../../../../../../../../src/plugins/data/common'; +import { Direction } from '../../../../../../common/search_strategy'; +import { createQueryFilterClauses } from '../../../../../utils/build_query'; +import { UsersRequestOptions } from '../../../../../../common/search_strategy/security_solution/users/all'; +import { + SortUsersField, + UsersFields, +} from '../../../../../../common/search_strategy/security_solution/users/common'; +import { assertUnreachable } from '../../../../../../common/utility_types'; + +export const buildUsersQuery = ({ + defaultIndex, + docValueFields, + filterQuery, + pagination: { querySize }, + sort, + timerange: { from, to }, +}: UsersRequestOptions): ISearchRequestParams => { + const filter = [ + ...createQueryFilterClauses(filterQuery), + { + range: { + '@timestamp': { + gte: from, + lte: to, + format: 'strict_date_optional_time', + }, + }, + }, + ]; + + const agg = { user_count: { cardinality: { field: 'user.name' } } }; + + const dslQuery = { + allow_no_indices: true, + index: defaultIndex, + ignore_unavailable: true, + track_total_hits: false, + body: { + ...(!isEmpty(docValueFields) ? { docvalue_fields: docValueFields } : {}), + aggregations: { + ...agg, + user_data: { + terms: { size: querySize, field: 'user.name', order: getQueryOrder(sort) }, + aggs: { + lastSeen: { max: { field: '@timestamp' } }, + domain: { + top_hits: { + size: 1, + sort: [ + { + '@timestamp': { + order: 'desc' as const, + }, + }, + ], + _source: { + includes: ['user.domain'], + }, + }, + }, + }, + }, + }, + query: { bool: { filter } }, + size: 0, + }, + }; + + return dslQuery; +}; + +type QueryOrder = { lastSeen: Direction } | { domain: Direction } | { _key: Direction }; + +const getQueryOrder = (sort: SortUsersField): QueryOrder => { + switch (sort.field) { + case UsersFields.lastSeen: + return { lastSeen: sort.direction }; + case UsersFields.name: + return { _key: sort.direction }; + default: + return assertUnreachable(sort.field); + } +}; diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/index.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/index.ts index 2fe2f44c94e8d..dce2195867358 100644 --- a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/index.ts +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/index.ts @@ -9,10 +9,12 @@ import { FactoryQueryTypes } from '../../../../../common/search_strategy/securit import { UsersQueries } from '../../../../../common/search_strategy/security_solution/users'; import { SecuritySolutionFactory } from '../types'; +import { allUsers } from './all'; import { userDetails } from './details'; import { totalUsersKpi } from './kpi/total_users'; export const usersFactory: Record> = { [UsersQueries.details]: userDetails, [UsersQueries.kpiTotalUsers]: totalUsersKpi, + [UsersQueries.users]: allUsers, }; From 817d732fead30542108087f35bdc7f7e47c3ca91 Mon Sep 17 00:00:00 2001 From: James Gowdy Date: Mon, 28 Mar 2022 12:13:18 +0100 Subject: [PATCH 004/160] [ML] Removing Boom wrappers from filter api errors (#128497) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../ml/server/models/filter/filter_manager.ts | 153 ++++++++---------- .../apis/ml/filters/get_filters.ts | 6 +- .../apis/ml/filters/update_filters.ts | 2 +- 3 files changed, 71 insertions(+), 90 deletions(-) diff --git a/x-pack/plugins/ml/server/models/filter/filter_manager.ts b/x-pack/plugins/ml/server/models/filter/filter_manager.ts index a4e902ff44994..84f5ae9d7e5a7 100644 --- a/x-pack/plugins/ml/server/models/filter/filter_manager.ts +++ b/x-pack/plugins/ml/server/models/filter/filter_manager.ts @@ -45,108 +45,89 @@ export class FilterManager { constructor(private _mlClient: MlClient) {} async getFilter(filterId: string) { - try { - const { - filters: [filter], - } = await this._mlClient.getFilters({ filter_id: filterId }); - if (filter === undefined) { - // could be an empty list rather than a 404 if a wildcard was used, - // so throw our own 404 - throw Boom.notFound(`Filter with the id "${filterId}" not found`); - } - - const { jobs } = await this._mlClient.getJobs(); - const filtersInUse = this.buildFiltersInUse(jobs); - - return { - ...filter, - used_by: filtersInUse[filter.filter_id], - item_count: 0, - } as FilterStats; - } catch (error) { - throw Boom.badRequest(error); + const { + filters: [filter], + } = await this._mlClient.getFilters({ filter_id: filterId }); + if (filter === undefined) { + // could be an empty list rather than a 404 if a wildcard was used, + // so throw our own 404 + throw Boom.notFound(`Filter with the id "${filterId}" not found`); } + + const { jobs } = await this._mlClient.getJobs(); + const filtersInUse = this.buildFiltersInUse(jobs); + + return { + ...filter, + used_by: filtersInUse[filter.filter_id], + item_count: 0, + } as FilterStats; } async getAllFilters() { - try { - const body = await this._mlClient.getFilters({ size: 1000 }); - return body.filters; - } catch (error) { - throw Boom.badRequest(error); - } + const body = await this._mlClient.getFilters({ size: 1000 }); + return body.filters; } async getAllFilterStats() { - try { - const [JOBS, FILTERS] = [0, 1]; - const results = await Promise.all([ - this._mlClient.getJobs(), - this._mlClient.getFilters({ size: 1000 }), - ]); - - // Build a map of filter_ids against jobs and detectors using that filter. - let filtersInUse: FiltersInUse = {}; - if (results[JOBS] && (results[JOBS] as estypes.MlGetJobsResponse).jobs) { - filtersInUse = this.buildFiltersInUse((results[JOBS] as estypes.MlGetJobsResponse).jobs); - } - - // For each filter, return just - // filter_id - // description - // item_count - // jobs using the filter - const filterStats: FilterStats[] = []; - if (results[FILTERS] && (results[FILTERS] as estypes.MlGetFiltersResponse).filters) { - (results[FILTERS] as estypes.MlGetFiltersResponse).filters.forEach((filter: Filter) => { - const stats: FilterStats = { - filter_id: filter.filter_id, - description: filter.description, - item_count: filter.items.length, - used_by: filtersInUse[filter.filter_id], - }; - filterStats.push(stats); - }); - } - - return filterStats; - } catch (error) { - throw Boom.badRequest(error); + const [JOBS, FILTERS] = [0, 1]; + const results = await Promise.all([ + this._mlClient.getJobs(), + this._mlClient.getFilters({ size: 1000 }), + ]); + + // Build a map of filter_ids against jobs and detectors using that filter. + let filtersInUse: FiltersInUse = {}; + if (results[JOBS] && (results[JOBS] as estypes.MlGetJobsResponse).jobs) { + filtersInUse = this.buildFiltersInUse((results[JOBS] as estypes.MlGetJobsResponse).jobs); + } + + // For each filter, return just + // filter_id + // description + // item_count + // jobs using the filter + const filterStats: FilterStats[] = []; + if (results[FILTERS] && (results[FILTERS] as estypes.MlGetFiltersResponse).filters) { + (results[FILTERS] as estypes.MlGetFiltersResponse).filters.forEach((filter: Filter) => { + const stats: FilterStats = { + filter_id: filter.filter_id, + description: filter.description, + item_count: filter.items.length, + used_by: filtersInUse[filter.filter_id], + }; + filterStats.push(stats); + }); } + + return filterStats; } async newFilter(filter: FormFilter) { const { filterId, ...body } = filter; - try { - // Returns the newly created filter. - return await this._mlClient.putFilter({ filter_id: filterId, body }); - } catch (error) { - throw Boom.badRequest(error); - } + + // Returns the newly created filter. + return await this._mlClient.putFilter({ filter_id: filterId, body }); } async updateFilter(filterId: string, filter: UpdateFilter) { - try { - const body: FilterRequest = { filter_id: filterId }; - if (filter.description !== undefined) { - body.description = filter.description; - } - if (filter.addItems !== undefined) { - body.add_items = filter.addItems; - } - if (filter.removeItems !== undefined) { - body.remove_items = filter.removeItems; - } - - // Returns the newly updated filter. - const resp = await this._mlClient.updateFilter({ - filter_id: filterId, - body, - }); - return resp; - } catch (error) { - throw Boom.badRequest(error); + const body: FilterRequest = { filter_id: filterId }; + if (filter.description !== undefined) { + body.description = filter.description; } + if (filter.addItems !== undefined) { + body.add_items = filter.addItems; + } + if (filter.removeItems !== undefined) { + body.remove_items = filter.removeItems; + } + + // Returns the newly updated filter. + const resp = await this._mlClient.updateFilter({ + filter_id: filterId, + body, + }); + return resp; } async deleteFilter(filterId: string) { diff --git a/x-pack/test/api_integration/apis/ml/filters/get_filters.ts b/x-pack/test/api_integration/apis/ml/filters/get_filters.ts index 8d99650f6d509..0cfd91ffb9035 100644 --- a/x-pack/test/api_integration/apis/ml/filters/get_filters.ts +++ b/x-pack/test/api_integration/apis/ml/filters/get_filters.ts @@ -87,14 +87,14 @@ export default ({ getService }: FtrProviderContext) => { expect(body.items).to.eql(requestBody.items); }); - it(`should return 400 if filterId does not exist`, async () => { + it(`should return 404 if filterId does not exist`, async () => { const { body, status } = await supertest .get(`/api/ml/filters/filter_id_dne`) .auth(USER.ML_POWERUSER, ml.securityCommon.getPasswordForUser(USER.ML_POWERUSER)) .set(COMMON_REQUEST_HEADERS); - ml.api.assertResponseStatusCode(400, status, body); + ml.api.assertResponseStatusCode(404, status, body); - expect(body.error).to.eql('Bad Request'); + expect(body.error).to.eql('Not Found'); expect(body.message).to.contain('resource_not_found_exception'); }); }); diff --git a/x-pack/test/api_integration/apis/ml/filters/update_filters.ts b/x-pack/test/api_integration/apis/ml/filters/update_filters.ts index 737e2c21cf0f6..7515cabca7998 100644 --- a/x-pack/test/api_integration/apis/ml/filters/update_filters.ts +++ b/x-pack/test/api_integration/apis/ml/filters/update_filters.ts @@ -110,7 +110,7 @@ export default ({ getService }: FtrProviderContext) => { .auth(USER.ML_POWERUSER, ml.securityCommon.getPasswordForUser(USER.ML_POWERUSER)) .set(COMMON_REQUEST_HEADERS) .send(updateFilterRequestBody); - ml.api.assertResponseStatusCode(400, status, body); + ml.api.assertResponseStatusCode(404, status, body); expect(body.message).to.contain('resource_not_found_exception'); }); From 31fffac3943d3c695542e820d8b5e5d73f7d008b Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Mon, 28 Mar 2022 14:28:47 +0300 Subject: [PATCH 005/160] Update dependency vega to ^5.22.1 (#128571) Co-authored-by: Renovate Bot Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- package.json | 2 +- yarn.lock | 24 ++++++++++++++++++------ 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index ca95f41569310..b8ec92ab796d6 100644 --- a/package.json +++ b/package.json @@ -418,7 +418,7 @@ "usng.js": "^0.4.5", "utility-types": "^3.10.0", "uuid": "3.3.2", - "vega": "^5.22.0", + "vega": "^5.22.1", "vega-interpreter": "^1.0.4", "vega-lite": "^5.2.0", "vega-schema-url-parser": "^2.2.0", diff --git a/yarn.lock b/yarn.lock index 9a480a2a16295..ce17dc8768523 100644 --- a/yarn.lock +++ b/yarn.lock @@ -29254,7 +29254,7 @@ vega-scale@^7.0.3, vega-scale@^7.1.1, vega-scale@^7.2.0, vega-scale@~7.2.0: vega-time "^2.1.0" vega-util "^1.17.0" -vega-scenegraph@^4.10.0, vega-scenegraph@^4.9.2, vega-scenegraph@^4.9.3, vega-scenegraph@~4.10.0: +vega-scenegraph@^4.10.0, vega-scenegraph@^4.9.2, vega-scenegraph@^4.9.3: version "4.10.0" resolved "https://registry.yarnpkg.com/vega-scenegraph/-/vega-scenegraph-4.10.0.tgz#232643372760ea081f2a899f640530777c2e2ba8" integrity sha512-znUQAulNJnuXSza8+Qg1objNpXcHxP9KZwwp0XW4H/AHbzVhHEigZagb8xKDpQI1/8OSk2WZf9Bkr7CrsFC0hg== @@ -29266,6 +29266,18 @@ vega-scenegraph@^4.10.0, vega-scenegraph@^4.9.2, vega-scenegraph@^4.9.3, vega-sc vega-scale "^7.2.0" vega-util "^1.15.2" +vega-scenegraph@~4.10.1: + version "4.10.1" + resolved "https://registry.yarnpkg.com/vega-scenegraph/-/vega-scenegraph-4.10.1.tgz#944da67b8a28758fab2e1306259fb7ff6be89f6b" + integrity sha512-takIpkmNxYHhJYALOYzhTin3EDzbys6U4g+l1yJZVlXG9YTdiCMuEVAdtaQOCqF9/7qytD6pCrMxJY2HaoN0qQ== + dependencies: + d3-path "^3.0.1" + d3-shape "^3.1.0" + vega-canvas "^1.2.5" + vega-loader "^4.4.0" + vega-scale "^7.2.0" + vega-util "^1.15.2" + vega-schema-url-parser@^2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/vega-schema-url-parser/-/vega-schema-url-parser-2.2.0.tgz#a0d1e02915adfbfcb1fd517c8c2ebe2419985c1e" @@ -29375,10 +29387,10 @@ vega-wordcloud@~4.1.3: vega-statistics "^1.7.9" vega-util "^1.15.2" -vega@^5.22.0: - version "5.22.0" - resolved "https://registry.yarnpkg.com/vega/-/vega-5.22.0.tgz#9286832a0bc523ee39b1f3baff9a2ca1957a61f0" - integrity sha512-ZIehKTrMY93sWaWIn/2N2LwsCN8XymQthxQA5fQwTmefVl7OOvcYmsGFJ9nttXUF4n0z5WRXkSsPZcJHHBlOKw== +vega@^5.22.1: + version "5.22.1" + resolved "https://registry.yarnpkg.com/vega/-/vega-5.22.1.tgz#e028f3645de18e0070317bc04410282975549e1e" + integrity sha512-KJBI7OWSzpfCPbmWl3GQCqBqbf2TIdpWS0mzO6MmWbvdMhWHf74P9IVnx1B1mhg0ZTqWFualx9ZYhWzMMwudaQ== dependencies: vega-crossfilter "~4.1.0" vega-dataflow "~5.7.4" @@ -29397,7 +29409,7 @@ vega@^5.22.0: vega-regression "~1.1.0" vega-runtime "~6.1.3" vega-scale "~7.2.0" - vega-scenegraph "~4.10.0" + vega-scenegraph "~4.10.1" vega-statistics "~1.8.0" vega-time "~2.1.0" vega-transforms "~4.10.0" From 398520ba2329a9a64fd99773069c4349fa901ac3 Mon Sep 17 00:00:00 2001 From: Dmitry Tomashevich <39378793+Dmitriynj@users.noreply.github.com> Date: Mon, 28 Mar 2022 16:43:02 +0500 Subject: [PATCH 006/160] [Discover] fix selection popover close (#128124) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../discover_grid/discover_grid_document_selection.tsx | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/plugins/discover/public/components/discover_grid/discover_grid_document_selection.tsx b/src/plugins/discover/public/components/discover_grid/discover_grid_document_selection.tsx index de8abf8c01134..e804dcb8eca7a 100644 --- a/src/plugins/discover/public/components/discover_grid/discover_grid_document_selection.tsx +++ b/src/plugins/discover/public/components/discover_grid/discover_grid_document_selection.tsx @@ -149,6 +149,11 @@ export function DiscoverGridDocumentToolbarBtn({ setSelectedDocs, ]); + const toggleSelectionToolbar = useCallback( + () => setIsSelectionPopoverOpen((prevIsOpen) => !prevIsOpen), + [] + ); + return ( setIsSelectionPopoverOpen(false)} @@ -159,7 +164,7 @@ export function DiscoverGridDocumentToolbarBtn({ size="xs" color="text" iconType="documents" - onClick={() => setIsSelectionPopoverOpen(true)} + onClick={toggleSelectionToolbar} data-selected-documents={selectedDocs.length} data-test-subj="dscGridSelectionBtn" isSelected={isFilterActive} From 34bb992e73c70057b402346f73e24a3c9262b524 Mon Sep 17 00:00:00 2001 From: Byron Hulcher Date: Mon, 28 Mar 2022 08:26:41 -0400 Subject: [PATCH 007/160] [Workplace Search] Update UX for custom api source detail view (#128327) --- .../applications/workplace_search/types.ts | 1 + .../add_custom_source/save_custom.test.tsx | 18 +-- .../add_custom_source/save_custom.tsx | 86 +--------- .../custom_source_deployment.test.tsx | 99 ++++++++++++ .../components/custom_source_deployment.tsx | 104 ++++++++++++ .../components/overview.test.tsx | 55 +++++-- .../content_sources/components/overview.tsx | 152 +++++++----------- .../views/content_sources/source_data.tsx | 7 + .../translations/translations/fr-FR.json | 1 - .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - 11 files changed, 324 insertions(+), 201 deletions(-) create mode 100644 x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.test.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.tsx diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/types.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/types.ts index 971b00b6529ee..19263f057e40f 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/types.ts +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/types.ts @@ -92,6 +92,7 @@ export interface SourceDataItem { export interface ContentSource { id: string; serviceType: string; + baseServiceType?: string; name: string; } diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.test.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.test.tsx index 73add51b87955..3de514a3e4d71 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.test.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.test.tsx @@ -15,7 +15,7 @@ import { EuiButtonTo } from '../../../../../../shared/react_router_helpers'; import { staticCustomSourceData } from '../../../source_data'; -import { SourceIdentifier } from '../../source_identifier'; +import { CustomSourceDeployment } from '../../custom_source_deployment'; import { SaveCustom } from './save_custom'; @@ -43,12 +43,8 @@ describe('SaveCustom', () => { expect(wrapper.find(EuiButtonTo)).toHaveLength(1); }); - it('contains a source identifier', () => { - expect(wrapper.find(SourceIdentifier)).toHaveLength(1); - }); - - it('includes a link to generic documentation', () => { - expect(wrapper.find('[data-test-subj="GenericDocumentationLink"]')).toHaveLength(1); + it('includes deployment instructions', () => { + expect(wrapper.find(CustomSourceDeployment)).toHaveLength(1); }); }); @@ -72,14 +68,6 @@ describe('SaveCustom', () => { wrapper = shallow(); }); - it('includes a to the github repository', () => { - expect(wrapper.find('[data-test-subj="GithubRepositoryLink"]')).toHaveLength(1); - }); - - it('includes a link to service-type specific documentation', () => { - expect(wrapper.find('[data-test-subj="PreconfiguredDocumentationLink"]')).toHaveLength(1); - }); - it('includes a link to provide feedback', () => { expect(wrapper.find('[data-test-subj="FeedbackCallout"]')).toHaveLength(1); }); diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.tsx index 8d0612f36fc0d..de87d82d8712e 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_custom_source/save_custom.tsx @@ -17,9 +17,7 @@ import { EuiText, EuiTextAlign, EuiTitle, - EuiLink, EuiPanel, - EuiHorizontalRule, EuiCallOut, } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; @@ -27,10 +25,9 @@ import { FormattedMessage } from '@kbn/i18n-react'; import { EuiButtonTo, EuiLinkTo } from '../../../../../../shared/react_router_helpers'; import { AppLogic } from '../../../../../app_logic'; -import { API_KEY_LABEL } from '../../../../../constants'; -import { SOURCES_PATH, getSourcesPath, API_KEYS_PATH } from '../../../../../routes'; +import { SOURCES_PATH, getSourcesPath } from '../../../../../routes'; -import { SourceIdentifier } from '../../source_identifier'; +import { CustomSourceDeployment } from '../../custom_source_deployment'; import { AddSourceHeader } from '../add_source_header'; import { SAVE_CUSTOM_BODY1 as READY_TO_ACCEPT_REQUESTS_LABEL } from '../constants'; @@ -40,12 +37,7 @@ import { AddCustomSourceLogic } from './add_custom_source_logic'; export const SaveCustom: React.FC = () => { const { newCustomSource, sourceData } = useValues(AddCustomSourceLogic); const { isOrganization } = useValues(AppLogic); - const { - serviceType, - configuration: { githubRepository, documentationUrl }, - name, - categories = [], - } = sourceData; + const { serviceType, name, categories = [] } = sourceData; return ( <> @@ -99,77 +91,7 @@ export const SaveCustom: React.FC = () => { - - - {serviceType !== 'custom' && githubRepository ? ( - <> - - - - ), - }} - /> - - - - - ), - }} - /> - - ) : ( - - - - ), - }} - /> - )} - - - {API_KEY_LABEL} - - ), - }} - /> - - - - + {serviceType !== 'custom' && ( diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.test.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.test.tsx new file mode 100644 index 0000000000000..afacfd0ccbbf9 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.test.tsx @@ -0,0 +1,99 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { setMockValues } from '../../../../__mocks__/kea_logic'; + +import React from 'react'; + +import { ShallowWrapper, shallow } from 'enzyme'; + +import { EuiPanel, EuiText, EuiHorizontalRule } from '@elastic/eui'; + +import { staticCustomSourceData } from '../source_data'; + +import { CustomSourceDeployment } from './custom_source_deployment'; +import { SourceIdentifier } from './source_identifier'; + +const customSource = { + id: 'id', + accessToken: 'token', + name: 'name', +}; + +const preconfiguredSourceData = { + ...staticCustomSourceData, + serviceType: 'sharepoint-server', + configuration: { + ...staticCustomSourceData.configuration, + githubRepository: 'elastic/sharepoint-server-connector', + }, +}; +const mockValues = { + sourceData: staticCustomSourceData, +}; + +describe('CustomSourceDeployment', () => { + describe('default behavior', () => { + let wrapper: ShallowWrapper; + + beforeAll(() => { + jest.clearAllMocks(); + setMockValues(mockValues); + + wrapper = shallow( + + ); + }); + + it('contains a source identifier', () => { + expect(wrapper.find(SourceIdentifier)).toHaveLength(1); + }); + + it('includes a link to generic documentation', () => { + expect(wrapper.find('[data-test-subj="GenericDocumentationLink"]')).toHaveLength(1); + }); + }); + + describe('for pre-configured custom sources', () => { + let wrapper: ShallowWrapper; + + beforeAll(() => { + jest.clearAllMocks(); + setMockValues({ + ...mockValues, + sourceData: {}, + }); + + wrapper = shallow( + + ); + }); + + it('includes a to the github repository', () => { + expect(wrapper.find('[data-test-subj="GithubRepositoryLink"]')).toHaveLength(1); + }); + + it('includes a link to service-type specific documentation', () => { + expect(wrapper.find('[data-test-subj="PreconfiguredDocumentationLink"]')).toHaveLength(1); + }); + }); + + it('can render a small version', () => { + jest.clearAllMocks(); + setMockValues(mockValues); + + const wrapper = shallow( + + ); + + expect(wrapper.find(EuiPanel).prop('paddingSize')).toEqual('m'); + + expect(wrapper.find(EuiText).prop('size')).toEqual('s'); + + expect(wrapper.find(EuiHorizontalRule).prop('margin')).toEqual('s'); + }); +}); diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.tsx new file mode 100644 index 0000000000000..7d34783e998a7 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/custom_source_deployment.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import { EuiPanel, EuiText, EuiSpacer, EuiLink, EuiHorizontalRule } from '@elastic/eui'; +import { FormattedMessage } from '@kbn/i18n-react'; + +import { EuiLinkTo } from '../../../../shared/react_router_helpers'; +import { API_KEY_LABEL } from '../../../constants'; +import { API_KEYS_PATH } from '../../../routes'; + +import { ContentSource, CustomSource, SourceDataItem } from '../../../types'; + +import { SourceIdentifier } from './source_identifier'; + +interface Props { + source: ContentSource | CustomSource; + sourceData: SourceDataItem; + small?: boolean; +} +export const CustomSourceDeployment: React.FC = ({ source, sourceData, small = false }) => { + const { name, id } = source; + const { + configuration: { documentationUrl, githubRepository }, + } = sourceData; + return ( + + + {githubRepository ? ( + <> + + + + ), + }} + /> + + + + + ), + }} + /> + + ) : ( + + + + ), + }} + /> + )} + + + {API_KEY_LABEL} + + ), + }} + /> + + + + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.test.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.test.tsx index 21a71308a1832..9af4eae693d7c 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.test.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.test.tsx @@ -12,10 +12,14 @@ import React from 'react'; import { shallow } from 'enzyme'; -import { EuiCallOut, EuiConfirmModal, EuiEmptyPrompt, EuiPanel, EuiTable } from '@elastic/eui'; +import { EuiCallOut, EuiConfirmModal, EuiEmptyPrompt, EuiTable } from '@elastic/eui'; import { ComponentLoader } from '../../../components/shared/component_loader'; +import * as SourceData from '../source_data'; + +import { CustomSourceDeployment } from './custom_source_deployment'; + import { Overview } from './overview'; describe('Overview', () => { @@ -31,6 +35,7 @@ describe('Overview', () => { }; beforeEach(() => { + jest.clearAllMocks(); setMockValues({ ...mockValues }); setMockActions({ initializeSourceSynchronization }); }); @@ -83,14 +88,6 @@ describe('Overview', () => { expect(groupsSummary.find('[data-test-subj="SourceGroupLink"]')).toHaveLength(1); }); - it('renders DocumentationCallout', () => { - setMockValues({ ...mockValues, contentSource: fullContentSources[1] }); - const wrapper = shallow(); - const documentationCallout = wrapper.find('[data-test-subj="DocumentationCallout"]').dive(); - - expect(documentationCallout.find(EuiPanel)).toHaveLength(1); - }); - it('renders PermissionsStatus', () => { setMockValues({ ...mockValues, @@ -146,4 +143,44 @@ describe('Overview', () => { expect(initializeSourceSynchronization).toHaveBeenCalled(); }); + + it('uses a base service type if one is provided', () => { + jest.spyOn(SourceData, 'getSourceData'); + setMockValues({ + ...mockValues, + contentSource: { + ...fullContentSources[0], + baseServiceType: 'share_point_server', + }, + }); + + shallow(); + + expect(SourceData.getSourceData).toHaveBeenCalledWith('share_point_server'); + }); + + it('defaults to the regular service tye', () => { + jest.spyOn(SourceData, 'getSourceData'); + setMockValues({ + ...mockValues, + contentSource: fullContentSources[0], + }); + + shallow(); + + expect(SourceData.getSourceData).toHaveBeenCalledWith('custom'); + }); + + describe('custom sources', () => { + it('includes deployment instructions', () => { + setMockValues({ + ...mockValues, + contentSource: fullContentSources[1], + }); + + const wrapper = shallow(); + + expect(wrapper.find(CustomSourceDeployment)).toHaveLength(1); + }); + }); }); diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.tsx index 8f287537e4109..698dc7a60eea4 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/overview.tsx @@ -43,11 +43,7 @@ import { ComponentLoader } from '../../../components/shared/component_loader'; import { LicenseBadge } from '../../../components/shared/license_badge'; import { StatusItem } from '../../../components/shared/status_item'; import { ViewContentHeader } from '../../../components/shared/view_content_header'; -import { - RECENT_ACTIVITY_TITLE, - CREDENTIALS_TITLE, - DOCUMENTATION_LINK_TITLE, -} from '../../../constants'; +import { RECENT_ACTIVITY_TITLE } from '../../../constants'; import { SYNC_FREQUENCY_PATH, BLOCKED_TIME_WINDOWS_PATH, @@ -78,7 +74,6 @@ import { EXTERNAL_IDENTITIES_LINK, LEARN_CUSTOM_FEATURES_BUTTON, DOC_PERMISSIONS_DESCRIPTION, - CUSTOM_CALLOUT_TITLE, SOURCE_SYNCHRONIZATION_TITLE, SOURCE_SYNC_FREQUENCY_LINK_LABEL, SOURCE_BLOCKED_TIME_WINDOWS_LINK_LABEL, @@ -86,9 +81,10 @@ import { SOURCE_SYNC_CONFIRM_TITLE, SOURCE_SYNC_CONFIRM_MESSAGE, } from '../constants'; +import { getSourceData } from '../source_data'; import { SourceLogic } from '../source_logic'; -import { SourceIdentifier } from './source_identifier'; +import { CustomSourceDeployment } from './custom_source_deployment'; import { SourceLayout } from './source_layout'; export const Overview: React.FC = () => { @@ -109,10 +105,13 @@ export const Overview: React.FC = () => { hasPermissions, isFederatedSource, isIndexedSource, - serviceType, name, } = contentSource; + const serviceType = contentSource.baseServiceType || contentSource.serviceType; + + const sourceData = getSourceData(serviceType); + const [isSyncing, setIsSyncing] = useState(false); const [isModalVisible, setIsModalVisible] = useState(false); const closeModal = () => setIsModalVisible(false); @@ -363,27 +362,27 @@ export const Overview: React.FC = () => { ); const sourceStatus = ( - - -
- {STATUS_HEADER} -
-
+ <> + +
{STATUS_HEADER}
+
- - - - - - - {STATUS_HEADING} - - -

{STATUS_TEXT}

-
-
-
-
+ + + + + + + + {STATUS_HEADING} + + +

{STATUS_TEXT}

+
+
+
+
+ ); const permissionsStatus = ( @@ -422,56 +421,45 @@ export const Overview: React.FC = () => { ); - const credentials = ( - - -
- {CREDENTIALS_TITLE} -
-
- - -
- ); - - const DocumentationCallout = ({ - title, - children, - }: { - title: string; - children: React.ReactNode; - }) => ( - - + const customSourceDeployment = ( + <> +
- {DOCUMENTATION_LINK_TITLE} + {i18n.translate('xpack.enterpriseSearch.workplaceSearch.deployment.title', { + defaultMessage: 'Deployment', + })}
-
- - - {title} - {children} -
+ + + ); const documentPermssionsLicenseLocked = ( - - - - - {DOCUMENT_PERMISSIONS_TITLE} - - -

{DOC_PERMISSIONS_DESCRIPTION}

-
+ <> + + + + {DOCUMENT_PERMISSIONS_TITLE} + + + + + + - - - {LEARN_CUSTOM_FEATURES_BUTTON} - - -
+ + +

{DOC_PERMISSIONS_DESCRIPTION}

+
+ + + + {LEARN_CUSTOM_FEATURES_BUTTON} + + +
+ ); const syncTriggerCallout = ( @@ -557,27 +545,7 @@ export const Overview: React.FC = () => { {custom && ( <> {sourceStatus} - {credentials} - - -

- - {LEARN_MORE_LINK} - - ), - }} - /> -

-
-
+ {customSourceDeployment} {!licenseSupportsPermissions && ( {documentPermssionsLicenseLocked} )} diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/source_data.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/source_data.tsx index 5b1e4d97ef4cd..3cd8fb2bbcd33 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/source_data.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/source_data.tsx @@ -634,3 +634,10 @@ export const staticCustomSourceData: SourceDataItem = { accountContextOnly: false, customConnectorAvailable: true, }; + +export const getSourceData = (serviceType: string): SourceDataItem => { + return ( + staticSourceData.find((staticSource) => staticSource.serviceType === serviceType) || + staticCustomSourceData + ); +}; diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 1595abb458a25..c535d8c251abb 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -9659,7 +9659,6 @@ "xpack.enterpriseSearch.workplaceSearch.sources.learnCustom.features.button": "Découvrir les fonctionnalités de Platinum", "xpack.enterpriseSearch.workplaceSearch.sources.learnMore.link": "En savoir plus", "xpack.enterpriseSearch.workplaceSearch.sources.learnMore.text": "{learnMoreLink} sur les autorisations", - "xpack.enterpriseSearch.workplaceSearch.sources.learnMoreCustom.text": "{learnMoreLink} sur les sources personnalisées.", "xpack.enterpriseSearch.workplaceSearch.sources.licenseCallout.description": "Pour en savoir plus, contactez votre administrateur d'expérience de recherche.", "xpack.enterpriseSearch.workplaceSearch.sources.licenseCallout.title": "Les sources privées ne sont plus disponibles", "xpack.enterpriseSearch.workplaceSearch.sources.noContent.title": "Aucun contenu pour l'instant", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 0719666625dc7..67a4e9ee72fe7 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -11426,7 +11426,6 @@ "xpack.enterpriseSearch.workplaceSearch.sources.learnCustom.features.button": "プラチナ機能の詳細", "xpack.enterpriseSearch.workplaceSearch.sources.learnMore.link": "詳細", "xpack.enterpriseSearch.workplaceSearch.sources.learnMore.text": "アクセス権については、{learnMoreLink}", - "xpack.enterpriseSearch.workplaceSearch.sources.learnMoreCustom.text": "カスタムソースについては、{learnMoreLink}。", "xpack.enterpriseSearch.workplaceSearch.sources.licenseCallout.description": "詳細については、検索エクスペリエンス管理者に問い合わせてください。", "xpack.enterpriseSearch.workplaceSearch.sources.licenseCallout.title": "非公開ソースは使用できません", "xpack.enterpriseSearch.workplaceSearch.sources.nextSyncRunningMessage": "現在実行中のジョブが完了したらすぐに実行", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 55651c16b66e8..a865591987685 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -11447,7 +11447,6 @@ "xpack.enterpriseSearch.workplaceSearch.sources.learnCustom.features.button": "了解白金级功能", "xpack.enterpriseSearch.workplaceSearch.sources.learnMore.link": "了解详情", "xpack.enterpriseSearch.workplaceSearch.sources.learnMore.text": "{learnMoreLink}的权限", - "xpack.enterpriseSearch.workplaceSearch.sources.learnMoreCustom.text": "{learnMoreLink}的定制源。", "xpack.enterpriseSearch.workplaceSearch.sources.licenseCallout.description": "请与您的搜索体验管理员联系,以获取更多信息。", "xpack.enterpriseSearch.workplaceSearch.sources.licenseCallout.title": "专用源不再可用", "xpack.enterpriseSearch.workplaceSearch.sources.nextSyncRunningMessage": "一旦当前运行的作业完成", From fbebba5d9f6ba173b5092897e0ba2b3d56d43270 Mon Sep 17 00:00:00 2001 From: Faisal Kanout Date: Mon, 28 Mar 2022 15:37:23 +0300 Subject: [PATCH 008/160] [RAC][LOGS] - 126231 - Add "View in App URL" {{context.viewInAppUrl}} variable to the rule templating language (#127890) * Exposes required functions via the common folder * Revert "Exposes required functions via the common folder" This reverts commit db34cf9a6cc77850817080f1388f9fa57552d19d. * Expose only the getAlertLink as a common code * Add viewInApp URL to Logs rule type * Add kibanaBaseUrl to the infra plugin to build the full link * Clean up code and extract kibana path name * Fix URL * Fix tests * Fix lint * Fix lint * fix i18n * typo * Optimization - code review * Uptdate tests * Code review * Remove unsed functions * Fix checks * Update getLogsAppAlertUrl * Remove join * Optim - code review * Comment tests related to alertUpdater * Comments imports * Add issue link * Uncomment/update tests --- .../infra/common/formatters/alert_link.ts | 16 +++ .../log_threshold/rule_data_formatters.ts | 11 +- .../log_threshold_executor.test.ts | 45 +++---- .../log_threshold/log_threshold_executor.ts | 118 ++++++++---------- .../register_log_threshold_rule_type.ts | 12 ++ .../plugins/infra/server/lib/infra_types.ts | 2 + x-pack/plugins/infra/server/plugin.ts | 1 + 7 files changed, 102 insertions(+), 103 deletions(-) create mode 100644 x-pack/plugins/infra/common/formatters/alert_link.ts diff --git a/x-pack/plugins/infra/common/formatters/alert_link.ts b/x-pack/plugins/infra/common/formatters/alert_link.ts new file mode 100644 index 0000000000000..ce5ab8941aa5a --- /dev/null +++ b/x-pack/plugins/infra/common/formatters/alert_link.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { modifyUrl } from '@kbn/std'; +export const getLogsAppAlertUrl = (timestamp: number | null) => + modifyUrl('/app/logs/link-to/default/logs', ({ query, ...otherUrlParts }) => ({ + ...otherUrlParts, + query: { + ...query, + ...(timestamp != null ? { time: `${timestamp}` } : {}), + }, + })); diff --git a/x-pack/plugins/infra/public/alerting/log_threshold/rule_data_formatters.ts b/x-pack/plugins/infra/public/alerting/log_threshold/rule_data_formatters.ts index c64f9b07fa33e..888646856e119 100644 --- a/x-pack/plugins/infra/public/alerting/log_threshold/rule_data_formatters.ts +++ b/x-pack/plugins/infra/public/alerting/log_threshold/rule_data_formatters.ts @@ -6,23 +6,16 @@ */ import { ALERT_REASON, ALERT_START } from '@kbn/rule-data-utils'; -import { modifyUrl } from '@kbn/std'; import { ObservabilityRuleTypeFormatter } from '../../../../observability/public'; +import { getLogsAppAlertUrl } from '../../../common/formatters/alert_link'; export const formatRuleData: ObservabilityRuleTypeFormatter = ({ fields }) => { const reason = fields[ALERT_REASON] ?? ''; const alertStartDate = fields[ALERT_START]; const timestamp = alertStartDate != null ? new Date(alertStartDate).valueOf() : null; - const link = modifyUrl('/app/logs/link-to/default/logs', ({ query, ...otherUrlParts }) => ({ - ...otherUrlParts, - query: { - ...query, - ...(timestamp != null ? { time: `${timestamp}` } : {}), - }, - })); return { reason, - link, // TODO: refactor to URL generators + link: getLogsAppAlertUrl(timestamp), // TODO: refactor to URL generators }; }; diff --git a/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.test.ts b/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.test.ts index ba02fb96b0d68..d6b599336fac8 100644 --- a/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.test.ts +++ b/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.test.ts @@ -17,13 +17,11 @@ import { } from './log_threshold_executor'; import { Comparator, - AlertStates, RuleParams, Criterion, UngroupedSearchQueryResponse, GroupedSearchQueryResponse, } from '../../../../common/alerting/logs/log_threshold'; -import { alertsMock } from '../../../../../alerting/server/mocks'; import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; // Mocks // @@ -31,7 +29,6 @@ const numericField = { field: 'numericField', value: 10, }; - const keywordField = { field: 'keywordField', value: 'error', @@ -407,7 +404,7 @@ describe('Log threshold executor', () => { describe('Results processors', () => { describe('Can process ungrouped results', () => { test('It handles the ALERT state correctly', () => { - const alertUpdaterMock = jest.fn(); + const alertFactoryMock = jest.fn(); const ruleParams = { ...baseRuleParams, criteria: [positiveCriteria[0]], @@ -419,16 +416,11 @@ describe('Log threshold executor', () => { }, }, } as UngroupedSearchQueryResponse; - processUngroupedResults( - results, - ruleParams, - alertsMock.createAlertFactory.create, - alertUpdaterMock - ); - // First call, second argument - expect(alertUpdaterMock.mock.calls[0][1]).toBe(AlertStates.ALERT); - // First call, third argument - expect(alertUpdaterMock.mock.calls[0][2]).toEqual([ + + processUngroupedResults(results, ruleParams, alertFactoryMock); + + // first call, fifth argument + expect(alertFactoryMock.mock.calls[0][4]).toEqual([ { actionGroup: 'logs.threshold.fired', context: { @@ -445,7 +437,7 @@ describe('Log threshold executor', () => { describe('Can process grouped results', () => { test('It handles the ALERT state correctly', () => { - const alertUpdaterMock = jest.fn(); + const alertFactoryMock = jest.fn(); const ruleParams = { ...baseRuleParams, criteria: [positiveCriteria[0]], @@ -484,17 +476,12 @@ describe('Log threshold executor', () => { }, }, ] as GroupedSearchQueryResponse['aggregations']['groups']['buckets']; - processGroupByResults( - results, - ruleParams, - alertsMock.createAlertFactory.create, - alertUpdaterMock - ); - expect(alertUpdaterMock.mock.calls.length).toBe(2); - // First call, second argument - expect(alertUpdaterMock.mock.calls[0][1]).toBe(AlertStates.ALERT); - // First call, third argument - expect(alertUpdaterMock.mock.calls[0][2]).toEqual([ + + processGroupByResults(results, ruleParams, alertFactoryMock); + expect(alertFactoryMock.mock.calls.length).toBe(2); + + // First call, fifth argument + expect(alertFactoryMock.mock.calls[0][4]).toEqual([ { actionGroup: 'logs.threshold.fired', context: { @@ -508,10 +495,8 @@ describe('Log threshold executor', () => { }, ]); - // Second call, second argument - expect(alertUpdaterMock.mock.calls[1][1]).toBe(AlertStates.ALERT); - // Second call, third argument - expect(alertUpdaterMock.mock.calls[1][2]).toEqual([ + // Second call, fifth argument + expect(alertFactoryMock.mock.calls[1][4]).toEqual([ { actionGroup: 'logs.threshold.fired', context: { diff --git a/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.ts b/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.ts index 2ca97c6b8a35f..5bf1a914f49b1 100644 --- a/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.ts +++ b/x-pack/plugins/infra/server/lib/alerting/log_threshold/log_threshold_executor.ts @@ -21,6 +21,7 @@ import { AlertInstanceState as AlertState, AlertTypeState as RuleTypeState, } from '../../../../../alerting/server'; + import { RuleParams, ruleParamsRT, @@ -43,6 +44,7 @@ import { } from '../../../../common/alerting/logs/log_threshold'; import { resolveLogSourceConfiguration } from '../../../../common/log_sources'; import { decodeOrThrow } from '../../../../common/runtime_types'; +import { getLogsAppAlertUrl } from '../../../../common/formatters/alert_link'; import { getIntervalInSeconds } from '../../../utils/get_interval_in_seconds'; import { InfraBackendLibs } from '../../infra_types'; import { UNGROUPED_FACTORY_KEY } from '../common/utils'; @@ -68,7 +70,8 @@ type LogThresholdAlertFactory = ( id: string, reason: string, value: number, - threshold: number + threshold: number, + actions?: Array<{ actionGroup: LogThresholdActionGroups; context: AlertContext }> ) => LogThresholdAlert; const COMPOSITE_GROUP_SIZE = 2000; @@ -93,11 +96,13 @@ export const createLogThresholdExecutor = (libs: InfraBackendLibs) => LogThresholdAlertState, LogThresholdAlertContext, LogThresholdActionGroups - >(async ({ services, params }) => { - const { alertWithLifecycle, savedObjectsClient, scopedClusterClient } = services; - const { sources } = libs; - const alertFactory: LogThresholdAlertFactory = (id, reason, value, threshold) => - alertWithLifecycle({ + >(async ({ services, params, startedAt }) => { + const { alertWithLifecycle, savedObjectsClient, scopedClusterClient, getAlertStartedDate } = + services; + const { sources, basePath } = libs; + + const alertFactory: LogThresholdAlertFactory = (id, reason, value, threshold, actions) => { + const alert = alertWithLifecycle({ id, fields: { [ALERT_EVALUATION_THRESHOLD]: threshold, @@ -106,6 +111,28 @@ export const createLogThresholdExecutor = (libs: InfraBackendLibs) => }, }); + if (actions && actions.length > 0) { + const indexedStartedAt = getAlertStartedDate(id) ?? startedAt.toISOString(); + const relativeViewInAppUrl = getLogsAppAlertUrl(new Date(indexedStartedAt).getTime()); + const viewInAppUrl = basePath.publicBaseUrl + ? new URL(basePath.prepend(relativeViewInAppUrl), basePath.publicBaseUrl).toString() + : relativeViewInAppUrl; + + const sharedContext = { + timestamp: new Date().toISOString(), + viewInAppUrl, + }; + actions.forEach((actionSet) => { + const { actionGroup, context } = actionSet; + alert.scheduleActions(actionGroup, { ...sharedContext, ...context }); + }); + } + + alert.replaceState({ + alertState: AlertStates.ALERT, + }); + return alert; + }; const sourceConfiguration = await sources.getSourceConfiguration(savedObjectsClient, 'default'); const { indices, timestampField, runtimeMappings } = await resolveLogSourceConfiguration( sourceConfiguration.configuration, @@ -157,19 +184,9 @@ async function executeAlert( } if (hasGroupBy(ruleParams)) { - processGroupByResults( - await getGroupedResults(query, esClient), - ruleParams, - alertFactory, - updateAlert - ); + processGroupByResults(await getGroupedResults(query, esClient), ruleParams, alertFactory); } else { - processUngroupedResults( - await getUngroupedResults(query, esClient), - ruleParams, - alertFactory, - updateAlert - ); + processUngroupedResults(await getUngroupedResults(query, esClient), ruleParams, alertFactory); } } @@ -213,8 +230,7 @@ async function executeRatioAlert( numeratorGroupedResults, denominatorGroupedResults, ruleParams, - alertFactory, - updateAlert + alertFactory ); } else { const [numeratorUngroupedResults, denominatorUngroupedResults] = await Promise.all([ @@ -225,8 +241,7 @@ async function executeRatioAlert( numeratorUngroupedResults, denominatorUngroupedResults, ruleParams, - alertFactory, - updateAlert + alertFactory ); } } @@ -245,8 +260,7 @@ const getESQuery = ( export const processUngroupedResults = ( results: UngroupedSearchQueryResponse, params: CountRuleParams, - alertFactory: LogThresholdAlertFactory, - alertUpdater: AlertUpdater + alertFactory: LogThresholdAlertFactory ) => { const { count, criteria, timeSize, timeUnit } = params; const documentCount = results.hits.total.value; @@ -257,9 +271,9 @@ export const processUngroupedResults = ( timeSize, timeUnit ); + if (checkValueAgainstComparatorMap[count.comparator](documentCount, count.value)) { - const alert = alertFactory(UNGROUPED_FACTORY_KEY, reasonMessage, documentCount, count.value); - alertUpdater(alert, AlertStates.ALERT, [ + const actions = [ { actionGroup: FIRED_ACTIONS.id, context: { @@ -270,7 +284,8 @@ export const processUngroupedResults = ( reason: reasonMessage, }, }, - ]); + ]; + alertFactory(UNGROUPED_FACTORY_KEY, reasonMessage, documentCount, count.value, actions); } }; @@ -278,8 +293,7 @@ export const processUngroupedRatioResults = ( numeratorResults: UngroupedSearchQueryResponse, denominatorResults: UngroupedSearchQueryResponse, params: RatioRuleParams, - alertFactory: LogThresholdAlertFactory, - alertUpdater: AlertUpdater + alertFactory: LogThresholdAlertFactory ) => { const { count, criteria, timeSize, timeUnit } = params; @@ -295,8 +309,7 @@ export const processUngroupedRatioResults = ( timeSize, timeUnit ); - const alert = alertFactory(UNGROUPED_FACTORY_KEY, reasonMessage, ratio, count.value); - alertUpdater(alert, AlertStates.ALERT, [ + const actions = [ { actionGroup: FIRED_ACTIONS.id, context: { @@ -308,7 +321,8 @@ export const processUngroupedRatioResults = ( reason: reasonMessage, }, }, - ]); + ]; + alertFactory(UNGROUPED_FACTORY_KEY, reasonMessage, ratio, count.value, actions); } }; @@ -354,8 +368,7 @@ const getReducedGroupByResults = ( export const processGroupByResults = ( results: GroupedSearchQueryResponse['aggregations']['groups']['buckets'], params: CountRuleParams, - alertFactory: LogThresholdAlertFactory, - alertUpdater: AlertUpdater + alertFactory: LogThresholdAlertFactory ) => { const { count, criteria, timeSize, timeUnit } = params; @@ -373,8 +386,7 @@ export const processGroupByResults = ( timeSize, timeUnit ); - const alert = alertFactory(group.name, reasonMessage, documentCount, count.value); - alertUpdater(alert, AlertStates.ALERT, [ + const actions = [ { actionGroup: FIRED_ACTIONS.id, context: { @@ -385,7 +397,8 @@ export const processGroupByResults = ( reason: reasonMessage, }, }, - ]); + ]; + alertFactory(group.name, reasonMessage, documentCount, count.value, actions); } }); }; @@ -394,8 +407,7 @@ export const processGroupByRatioResults = ( numeratorResults: GroupedSearchQueryResponse['aggregations']['groups']['buckets'], denominatorResults: GroupedSearchQueryResponse['aggregations']['groups']['buckets'], params: RatioRuleParams, - alertFactory: LogThresholdAlertFactory, - alertUpdater: AlertUpdater + alertFactory: LogThresholdAlertFactory ) => { const { count, criteria, timeSize, timeUnit } = params; @@ -423,8 +435,7 @@ export const processGroupByRatioResults = ( timeSize, timeUnit ); - const alert = alertFactory(numeratorGroup.name, reasonMessage, ratio, count.value); - alertUpdater(alert, AlertStates.ALERT, [ + const actions = [ { actionGroup: FIRED_ACTIONS.id, context: { @@ -436,33 +447,12 @@ export const processGroupByRatioResults = ( reason: reasonMessage, }, }, - ]); + ]; + alertFactory(numeratorGroup.name, reasonMessage, ratio, count.value, actions); } }); }; -type AlertUpdater = ( - alert: Alert, - state: AlertStates, - actions?: Array<{ actionGroup: LogThresholdActionGroups; context: AlertContext }> -) => void; - -export const updateAlert: AlertUpdater = (alert, state, actions) => { - if (actions && actions.length > 0) { - const sharedContext = { - timestamp: new Date().toISOString(), - }; - actions.forEach((actionSet) => { - const { actionGroup, context } = actionSet; - alert.scheduleActions(actionGroup, { ...sharedContext, ...context }); - }); - } - - alert.replaceState({ - alertState: state, - }); -}; - export const buildFiltersFromCriteria = ( params: Pick & { criteria: CountCriteria }, timestampField: string diff --git a/x-pack/plugins/infra/server/lib/alerting/log_threshold/register_log_threshold_rule_type.ts b/x-pack/plugins/infra/server/lib/alerting/log_threshold/register_log_threshold_rule_type.ts index d5f2fd17cf3be..d7b73ce187396 100644 --- a/x-pack/plugins/infra/server/lib/alerting/log_threshold/register_log_threshold_rule_type.ts +++ b/x-pack/plugins/infra/server/lib/alerting/log_threshold/register_log_threshold_rule_type.ts @@ -78,6 +78,14 @@ const alertReasonMessageActionVariableDescription = i18n.translate( } ); +const viewInAppUrlActionVariableDescription = i18n.translate( + 'xpack.infra.logs.alerting.threshold.viewInAppUrlActionVariableDescription', + { + defaultMessage: + 'Link to the view or feature within Elastic that can be used to investigate the alert and its context further', + } +); + export async function registerLogThresholdRuleType( alertingPlugin: PluginSetupContract, libs: InfraBackendLibs @@ -118,6 +126,10 @@ export async function registerLogThresholdRuleType( name: 'denominatorConditions', description: denominatorConditionsActionVariableDescription, }, + { + name: 'viewInAppUrl', + description: viewInAppUrlActionVariableDescription, + }, ], }, producer: 'logs', diff --git a/x-pack/plugins/infra/server/lib/infra_types.ts b/x-pack/plugins/infra/server/lib/infra_types.ts index 7f3b730cf03e7..c400e4664dc0a 100644 --- a/x-pack/plugins/infra/server/lib/infra_types.ts +++ b/x-pack/plugins/infra/server/lib/infra_types.ts @@ -6,6 +6,7 @@ */ import { Logger } from '@kbn/logging'; +import type { IBasePath } from 'src/core/server'; import { handleEsError } from '../../../../../src/plugins/es_ui_shared/server'; import { InfraConfig } from '../types'; import { GetLogQueryFields } from '../services/log_queries/get_log_query_fields'; @@ -32,5 +33,6 @@ export interface InfraBackendLibs extends InfraDomainLibs { handleEsError: typeof handleEsError; logsRules: RulesServiceSetup; metricsRules: RulesServiceSetup; + basePath: IBasePath; logger: Logger; } diff --git a/x-pack/plugins/infra/server/plugin.ts b/x-pack/plugins/infra/server/plugin.ts index eb66e805b15f4..650f3447372b4 100644 --- a/x-pack/plugins/infra/server/plugin.ts +++ b/x-pack/plugins/infra/server/plugin.ts @@ -154,6 +154,7 @@ export class InfraServerPlugin implements Plugin { handleEsError, logsRules: this.logsRules.setup(core, plugins), metricsRules: this.metricsRules.setup(core, plugins), + basePath: core.http.basePath, logger: this.logger, }; From 940a839da1d7967cd08cc1b1bc04592cffe3d103 Mon Sep 17 00:00:00 2001 From: Pierre Gayvallet Date: Mon, 28 Mar 2022 14:39:55 +0200 Subject: [PATCH 009/160] Add ThemeProvider to the fatalError page (#128456) * Add ThemeProvider to the fatalError page * update generated doc Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- src/core/public/core_system.ts | 4 +++- .../fatal_errors_service.test.ts.snap | 16 ++++++++++++++-- .../fatal_errors/fatal_errors_service.test.ts | 4 +++- .../fatal_errors/fatal_errors_service.tsx | 19 +++++++++++-------- src/core/public/public.api.md | 2 +- 5 files changed, 32 insertions(+), 13 deletions(-) diff --git a/src/core/public/core_system.ts b/src/core/public/core_system.ts index 1aa01c13dd375..ee36ae4a728cd 100644 --- a/src/core/public/core_system.ts +++ b/src/core/public/core_system.ts @@ -134,8 +134,11 @@ export class CoreSystem { // Setup FatalErrorsService and it's dependencies first so that we're // able to render any errors. const injectedMetadata = this.injectedMetadata.setup(); + const theme = this.theme.setup({ injectedMetadata }); + this.fatalErrorsSetup = this.fatalErrors.setup({ injectedMetadata, + theme, i18n: this.i18n.getContext(), }); await this.integrations.setup(); @@ -149,7 +152,6 @@ export class CoreSystem { }); const uiSettings = this.uiSettings.setup({ http, injectedMetadata }); const notifications = this.notifications.setup({ uiSettings }); - const theme = this.theme.setup({ injectedMetadata }); const application = this.application.setup({ http }); this.coreApp.setup({ application, http, injectedMetadata, notifications }); diff --git a/src/core/public/fatal_errors/__snapshots__/fatal_errors_service.test.ts.snap b/src/core/public/fatal_errors/__snapshots__/fatal_errors_service.test.ts.snap index df60b228972fc..b00d8be49739c 100644 --- a/src/core/public/fatal_errors/__snapshots__/fatal_errors_service.test.ts.snap +++ b/src/core/public/fatal_errors/__snapshots__/fatal_errors_service.test.ts.snap @@ -3,12 +3,24 @@ exports[`#add() deletes all children of rootDomElement and renders into it: fatal error screen component 1`] = ` Array [ Array [ - + - , + ,
, ], ] diff --git a/src/core/public/fatal_errors/fatal_errors_service.test.ts b/src/core/public/fatal_errors/fatal_errors_service.test.ts index 140e7542e8e79..4b243979c8e4d 100644 --- a/src/core/public/fatal_errors/fatal_errors_service.test.ts +++ b/src/core/public/fatal_errors/fatal_errors_service.test.ts @@ -15,6 +15,7 @@ expect.addSnapshotSerializer({ import { mockRender } from './fatal_errors_service.test.mocks'; import { injectedMetadataServiceMock } from '../injected_metadata/injected_metadata_service.mock'; +import { themeServiceMock } from '../theme/theme_service.mock'; import { FatalErrorsService } from './fatal_errors_service'; @@ -22,6 +23,7 @@ function setupService() { const rootDomElement = document.createElement('div'); const injectedMetadata = injectedMetadataServiceMock.createSetupContract(); + const theme = themeServiceMock.createSetupContract(); const stopCoreSystem = jest.fn(); @@ -37,7 +39,7 @@ function setupService() { rootDomElement, injectedMetadata, stopCoreSystem, - fatalErrors: fatalErrorsService.setup({ injectedMetadata, i18n }), + fatalErrors: fatalErrorsService.setup({ injectedMetadata, i18n, theme }), }; } diff --git a/src/core/public/fatal_errors/fatal_errors_service.tsx b/src/core/public/fatal_errors/fatal_errors_service.tsx index 262ee9e702f40..0e72b99bc6b92 100644 --- a/src/core/public/fatal_errors/fatal_errors_service.tsx +++ b/src/core/public/fatal_errors/fatal_errors_service.tsx @@ -13,11 +13,14 @@ import { first, tap } from 'rxjs/operators'; import { I18nStart } from '../i18n'; import { InjectedMetadataSetup } from '../injected_metadata'; +import { ThemeServiceSetup } from '../theme'; +import { CoreContextProvider } from '../utils'; import { FatalErrorsScreen } from './fatal_errors_screen'; import { FatalErrorInfo, getErrorInfo } from './get_error_info'; export interface Deps { i18n: I18nStart; + theme: ThemeServiceSetup; injectedMetadata: InjectedMetadataSetup; } @@ -64,13 +67,13 @@ export class FatalErrorsService { */ constructor(private rootDomElement: HTMLElement, private onFirstErrorCb: () => void) {} - public setup({ i18n, injectedMetadata }: Deps) { + public setup(deps: Deps) { this.errorInfo$ .pipe( first(), tap(() => { this.onFirstErrorCb(); - this.renderError(injectedMetadata, i18n); + this.renderError(deps); }) ) .subscribe({ @@ -99,7 +102,7 @@ export class FatalErrorsService { }, }; - this.setupGlobalErrorHandlers(this.fatalErrors!); + this.setupGlobalErrorHandlers(); return this.fatalErrors!; } @@ -112,7 +115,7 @@ export class FatalErrorsService { return fatalErrors; } - private renderError(injectedMetadata: InjectedMetadataSetup, i18n: I18nStart) { + private renderError({ i18n, theme, injectedMetadata }: Deps) { // delete all content in the rootDomElement this.rootDomElement.textContent = ''; @@ -121,20 +124,20 @@ export class FatalErrorsService { this.rootDomElement.appendChild(container); render( - + - , + , container ); } - private setupGlobalErrorHandlers(fatalErrorsSetup: FatalErrorsSetup) { + private setupGlobalErrorHandlers() { if (window.addEventListener) { - window.addEventListener('unhandledrejection', function (e) { + window.addEventListener('unhandledrejection', (e) => { console.log(`Detected an unhandled Promise rejection.\n${e.reason}`); // eslint-disable-line no-console }); } diff --git a/src/core/public/public.api.md b/src/core/public/public.api.md index 4ce68770d7f18..b9a0ca45e4629 100644 --- a/src/core/public/public.api.md +++ b/src/core/public/public.api.md @@ -1534,6 +1534,6 @@ export interface UserProvidedValues { // Warnings were encountered during analysis: // -// src/core/public/core_system.ts:183:21 - (ae-forgotten-export) The symbol "InternalApplicationStart" needs to be exported by the entry point index.d.ts +// src/core/public/core_system.ts:185:21 - (ae-forgotten-export) The symbol "InternalApplicationStart" needs to be exported by the entry point index.d.ts ``` From dca47de2e01dffd75724989d09b7b1a9c69ea929 Mon Sep 17 00:00:00 2001 From: Nicolas Chaulet Date: Mon, 28 Mar 2022 08:40:57 -0400 Subject: [PATCH 010/160] [Fleet] Remove non relevant field when changing output type (#128541) --- .../full_agent_policy.test.ts.snap | 6 --- .../agent_policies/full_agent_policy.test.ts | 7 --- .../agent_policies/full_agent_policy.ts | 2 +- .../fleet/server/services/output.test.ts | 46 +++++++++++++++++++ .../plugins/fleet/server/services/output.ts | 18 +++++++- 5 files changed, 63 insertions(+), 16 deletions(-) diff --git a/x-pack/plugins/fleet/server/services/agent_policies/__snapshots__/full_agent_policy.test.ts.snap b/x-pack/plugins/fleet/server/services/agent_policies/__snapshots__/full_agent_policy.test.ts.snap index eccd218b42447..0ef9efb2fa7e5 100644 --- a/x-pack/plugins/fleet/server/services/agent_policies/__snapshots__/full_agent_policy.test.ts.snap +++ b/x-pack/plugins/fleet/server/services/agent_policies/__snapshots__/full_agent_policy.test.ts.snap @@ -46,14 +46,12 @@ Object { }, "outputs": Object { "data-output-id": Object { - "ca_sha256": undefined, "hosts": Array [ "http://es-data.co:9201", ], "type": "elasticsearch", }, "default": Object { - "ca_sha256": undefined, "hosts": Array [ "http://127.0.0.1:9201", ], @@ -110,14 +108,12 @@ Object { }, "outputs": Object { "default": Object { - "ca_sha256": undefined, "hosts": Array [ "http://127.0.0.1:9201", ], "type": "elasticsearch", }, "monitoring-output-id": Object { - "ca_sha256": undefined, "hosts": Array [ "http://es-monitoring.co:9201", ], @@ -174,14 +170,12 @@ Object { }, "outputs": Object { "data-output-id": Object { - "ca_sha256": undefined, "hosts": Array [ "http://es-data.co:9201", ], "type": "elasticsearch", }, "monitoring-output-id": Object { - "ca_sha256": undefined, "hosts": Array [ "http://es-monitoring.co:9201", ], diff --git a/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.test.ts b/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.test.ts index c17d67c593229..ba9252dd09a8f 100644 --- a/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.test.ts +++ b/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.test.ts @@ -144,7 +144,6 @@ describe('getFullAgentPolicy', () => { default: { type: 'elasticsearch', hosts: ['http://127.0.0.1:9201'], - ca_sha256: undefined, }, }, inputs: [], @@ -176,7 +175,6 @@ describe('getFullAgentPolicy', () => { default: { type: 'elasticsearch', hosts: ['http://127.0.0.1:9201'], - ca_sha256: undefined, }, }, inputs: [], @@ -210,7 +208,6 @@ describe('getFullAgentPolicy', () => { default: { type: 'elasticsearch', hosts: ['http://127.0.0.1:9201'], - ca_sha256: undefined, }, }, inputs: [], @@ -316,7 +313,6 @@ describe('transformOutputToFullPolicyOutput', () => { expect(policyOutput).toMatchInlineSnapshot(` Object { - "ca_sha256": undefined, "hosts": Array [ "http://host.fr", ], @@ -341,7 +337,6 @@ ssl.test: 123 expect(policyOutput).toMatchInlineSnapshot(` Object { - "ca_sha256": undefined, "hosts": Array [ "http://host.fr", ], @@ -368,7 +363,6 @@ ssl.test: 123 expect(policyOutput).toMatchInlineSnapshot(` Object { - "ca_sha256": undefined, "hosts": Array [ "http://host.fr", ], @@ -394,7 +388,6 @@ ssl.test: 123 expect(policyOutput).toMatchInlineSnapshot(` Object { - "ca_sha256": undefined, "hosts": Array [ "host.fr:3332", ], diff --git a/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.ts b/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.ts index 0bc5315f62ddf..3114ac3c0a8ed 100644 --- a/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.ts +++ b/x-pack/plugins/fleet/server/services/agent_policies/full_agent_policy.ts @@ -179,7 +179,7 @@ export function transformOutputToFullPolicyOutput( ...configJs, type, hosts, - ca_sha256, + ...(ca_sha256 ? { ca_sha256 } : {}), ...(ssl ? { ssl } : {}), ...(ca_trusted_fingerprint ? { 'ssl.ca_trusted_fingerprint': ca_trusted_fingerprint } : {}), }; diff --git a/x-pack/plugins/fleet/server/services/output.test.ts b/x-pack/plugins/fleet/server/services/output.test.ts index a08fd7a81759d..211abecbc4395 100644 --- a/x-pack/plugins/fleet/server/services/output.test.ts +++ b/x-pack/plugins/fleet/server/services/output.test.ts @@ -84,6 +84,13 @@ function getMockedSoClient( }); } + case outputIdToUuid('existing-es-output'): { + return mockOutputSO('existing-es-output', { + type: 'elasticsearch', + is_default: false, + }); + } + default: throw new Error('not found: ' + id); } @@ -445,6 +452,26 @@ describe('Output Service', () => { ); }); + // With ES output + it('Should delete Logstash specific fields if the output type change to ES', async () => { + const soClient = getMockedSoClient({}); + mockedAgentPolicyService.list.mockResolvedValue({ + items: [{}], + } as unknown as ReturnType); + mockedAgentPolicyService.hasAPMIntegration.mockReturnValue(false); + + await outputService.update(soClient, 'existing-logstash-output', { + type: 'elasticsearch', + hosts: ['http://test:4343'], + }); + + expect(soClient.update).toBeCalledWith(expect.anything(), expect.anything(), { + type: 'elasticsearch', + hosts: ['http://test:4343'], + ssl: null, + }); + }); + // With logstash output it('Should work if you try to make that output the default output and no policies using default output has APM integration', async () => { const soClient = getMockedSoClient({}); @@ -472,6 +499,25 @@ describe('Output Service', () => { }) ).rejects.toThrow(`Logstash output cannot be used with APM integration.`); }); + it('Should delete ES specific fields if the output type change to logstash', async () => { + const soClient = getMockedSoClient({}); + mockedAgentPolicyService.list.mockResolvedValue({ + items: [{}], + } as unknown as ReturnType); + mockedAgentPolicyService.hasAPMIntegration.mockReturnValue(false); + + await outputService.update(soClient, 'existing-es-output', { + type: 'logstash', + hosts: ['test:4343'], + }); + + expect(soClient.update).toBeCalledWith(expect.anything(), expect.anything(), { + type: 'logstash', + hosts: ['test:4343'], + ca_sha256: null, + ca_trusted_fingerprint: null, + }); + }); }); describe('delete', () => { diff --git a/x-pack/plugins/fleet/server/services/output.ts b/x-pack/plugins/fleet/server/services/output.ts index 9302c87af85c1..3d2f5de0339ca 100644 --- a/x-pack/plugins/fleet/server/services/output.ts +++ b/x-pack/plugins/fleet/server/services/output.ts @@ -21,6 +21,8 @@ import { OutputUnauthorizedError, OutputInvalidError } from '../errors'; import { agentPolicyService } from './agent_policy'; import { appContextService } from './app_context'; +type Nullable = { [P in keyof T]: T[P] | null }; + const SAVED_OBJECT_TYPE = OUTPUT_SAVED_OBJECT_TYPE; const DEFAULT_ES_HOSTS = ['http://localhost:9200']; @@ -309,7 +311,7 @@ class OutputService { ); } - const updateData = { ...data }; + const updateData: Nullable> = { ...data }; const mergedType = data.type ?? originalOutput.type; const mergedIsDefault = data.is_default ?? originalOutput.is_default; @@ -317,6 +319,18 @@ class OutputService { await validateLogstashOutputNotUsedInAPMPolicy(soClient, id, mergedIsDefault); } + // If the output type changed + if (data.type && data.type !== originalOutput.type) { + if (data.type === outputType.Logstash) { + // remove ES specific field + updateData.ca_trusted_fingerprint = null; + updateData.ca_sha256 = null; + } else { + // remove logstash specific field + updateData.ssl = null; + } + } + // ensure only default output exists if (data.is_default) { const defaultDataOuputId = await this.getDefaultDataOutputId(soClient); @@ -345,7 +359,7 @@ class OutputService { if (mergedType === outputType.Elasticsearch && updateData.hosts) { updateData.hosts = updateData.hosts.map(normalizeHostsForAgents); } - const outputSO = await soClient.update( + const outputSO = await soClient.update>( SAVED_OBJECT_TYPE, outputIdToUuid(id), updateData From 32eb83cfd2b06b6a1c15b91cf9d4815d57edd31a Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Mon, 28 Mar 2022 13:57:04 +0100 Subject: [PATCH 011/160] chore(NA): redesign integration between bazel node_modules management and yarn kbn commands (#114048) * chore(NA): redesign integration between bazel node_modules management and yarn kbn commands * fix(NA): remove .yarn-integrity on force install * fix(NA): include clean on force install Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- WORKSPACE.bazel | 1 - packages/kbn-pm/dist/index.js | 605 +++++++++--------- packages/kbn-pm/src/commands/bootstrap.ts | 21 +- packages/kbn-pm/src/commands/clean.ts | 15 +- packages/kbn-pm/src/commands/reset.ts | 3 +- packages/kbn-pm/src/utils/bazel/index.ts | 2 +- .../kbn-pm/src/utils/bazel/yarn_integrity.ts | 25 +- 7 files changed, 307 insertions(+), 365 deletions(-) diff --git a/WORKSPACE.bazel b/WORKSPACE.bazel index c00062734239e..4a2e6ddf76b17 100644 --- a/WORKSPACE.bazel +++ b/WORKSPACE.bazel @@ -58,7 +58,6 @@ yarn_install( data = [ "//:.yarnrc", "//:preinstall_check.js", - "//:node_modules/.yarn-integrity", ], exports_directories_only = True, symlink_node_modules = True, diff --git a/packages/kbn-pm/dist/index.js b/packages/kbn-pm/dist/index.js index 99ab81d2b539f..eb6ea050841f8 100644 --- a/packages/kbn-pm/dist/index.js +++ b/packages/kbn-pm/dist/index.js @@ -8921,15 +8921,10 @@ const BootstrapCommand = { ms: Date.now() - start }); } - }; // Force install is set in case a flag is passed or - // if the `.yarn-integrity` file is not found which - // will be indicated by the return of yarnIntegrityFileExists. + }; // Force install is set in case a flag `--force-install` is passed into kbn bootstrap - const forceInstall = !!options && options['force-install'] === true || !(await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["yarnIntegrityFileExists"])(Object(path__WEBPACK_IMPORTED_MODULE_0__["resolve"])(kibanaProjectPath, 'node_modules'))); // Ensure we have a `node_modules/.yarn-integrity` file as we depend on it - // for bazel to know it has to re-install the node_modules after a reset or a clean - - await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["ensureYarnIntegrityFileExists"])(Object(path__WEBPACK_IMPORTED_MODULE_0__["resolve"])(kibanaProjectPath, 'node_modules')); // Install bazel machinery tools if needed + const forceInstall = !!options && options['force-install'] === true; // Install bazel machinery tools if needed await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["installBazelTools"])(rootPath); // Setup remote cache settings in .bazelrc.cache if needed @@ -8945,6 +8940,8 @@ const BootstrapCommand = { if (forceInstall) { await time('force install dependencies', async () => { + await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["removeYarnIntegrityFileIfExists"])(Object(path__WEBPACK_IMPORTED_MODULE_0__["resolve"])(kibanaProjectPath, 'node_modules')); + await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["runBazel"])(['clean']); await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["runBazel"])(['run', '@nodejs//:yarn'], runOffline, { env: { SASS_BINARY_SITE: 'https://us-central1-elastic-kibana-184716.cloudfunctions.net/kibana-ci-proxy-cache/node-sass', @@ -52653,25 +52650,23 @@ function addProjectToTree(tree, pathParts, project) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony import */ var _yarn_integrity__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(423); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "yarnIntegrityFileExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_0__["yarnIntegrityFileExists"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ensureYarnIntegrityFileExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_0__["ensureYarnIntegrityFileExists"]; }); +/* harmony import */ var _get_cache_folders__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(423); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "getBazelDiskCacheFolder", function() { return _get_cache_folders__WEBPACK_IMPORTED_MODULE_0__["getBazelDiskCacheFolder"]; }); -/* harmony import */ var _get_cache_folders__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(424); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "getBazelDiskCacheFolder", function() { return _get_cache_folders__WEBPACK_IMPORTED_MODULE_1__["getBazelDiskCacheFolder"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "getBazelRepositoryCacheFolder", function() { return _get_cache_folders__WEBPACK_IMPORTED_MODULE_0__["getBazelRepositoryCacheFolder"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "getBazelRepositoryCacheFolder", function() { return _get_cache_folders__WEBPACK_IMPORTED_MODULE_1__["getBazelRepositoryCacheFolder"]; }); +/* harmony import */ var _install_tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(424); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isBazelBinAvailable", function() { return _install_tools__WEBPACK_IMPORTED_MODULE_1__["isBazelBinAvailable"]; }); -/* harmony import */ var _install_tools__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(425); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isBazelBinAvailable", function() { return _install_tools__WEBPACK_IMPORTED_MODULE_2__["isBazelBinAvailable"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "installBazelTools", function() { return _install_tools__WEBPACK_IMPORTED_MODULE_1__["installBazelTools"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "installBazelTools", function() { return _install_tools__WEBPACK_IMPORTED_MODULE_2__["installBazelTools"]; }); +/* harmony import */ var _run__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(425); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "runBazel", function() { return _run__WEBPACK_IMPORTED_MODULE_2__["runBazel"]; }); -/* harmony import */ var _run__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(426); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "runBazel", function() { return _run__WEBPACK_IMPORTED_MODULE_3__["runBazel"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "runIBazel", function() { return _run__WEBPACK_IMPORTED_MODULE_2__["runIBazel"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "runIBazel", function() { return _run__WEBPACK_IMPORTED_MODULE_3__["runIBazel"]; }); +/* harmony import */ var _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(527); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "removeYarnIntegrityFileIfExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__["removeYarnIntegrityFileIfExists"]; }); /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one @@ -52689,53 +52684,6 @@ __webpack_require__.r(__webpack_exports__); /* 423 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "yarnIntegrityFileExists", function() { return yarnIntegrityFileExists; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ensureYarnIntegrityFileExists", function() { return ensureYarnIntegrityFileExists; }); -/* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4); -/* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var _fs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(231); -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0 and the Server Side Public License, v 1; you may not use this file except - * in compliance with, at your election, the Elastic License 2.0 or the Server - * Side Public License, v 1. - */ - - -async function yarnIntegrityFileExists(nodeModulesPath) { - try { - const nodeModulesRealPath = await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["tryRealpath"])(nodeModulesPath); - const yarnIntegrityFilePath = Object(path__WEBPACK_IMPORTED_MODULE_0__["join"])(nodeModulesRealPath, '.yarn-integrity'); // check if the file already exists - - if (await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["isFile"])(yarnIntegrityFilePath)) { - return true; - } - } catch {// no-op - } - - return false; -} -async function ensureYarnIntegrityFileExists(nodeModulesPath) { - try { - const nodeModulesRealPath = await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["tryRealpath"])(nodeModulesPath); - const yarnIntegrityFilePath = Object(path__WEBPACK_IMPORTED_MODULE_0__["join"])(nodeModulesRealPath, '.yarn-integrity'); // ensure node_modules folder is created - - await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["mkdirp"])(nodeModulesRealPath); // write a blank file in case it doesn't exists - - await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["writeFile"])(yarnIntegrityFilePath, '', { - flag: 'wx' - }); - } catch {// no-op - } -} - -/***/ }), -/* 424 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getBazelDiskCacheFolder", function() { return getBazelDiskCacheFolder; }); @@ -52770,7 +52718,7 @@ async function getBazelRepositoryCacheFolder() { } /***/ }), -/* 425 */ +/* 424 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -52889,7 +52837,7 @@ async function installBazelTools(repoRootPath) { } /***/ }), -/* 426 */ +/* 425 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -52899,8 +52847,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony import */ var chalk__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(114); /* harmony import */ var chalk__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(chalk__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9); -/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(427); -/* harmony import */ var _kbn_dev_utils_stdio__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(525); +/* harmony import */ var rxjs_operators__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(426); +/* harmony import */ var _kbn_dev_utils_stdio__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(524); /* harmony import */ var _kbn_dev_utils_stdio__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_kbn_dev_utils_stdio__WEBPACK_IMPORTED_MODULE_3__); /* harmony import */ var _child_process__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(221); /* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(220); @@ -52966,141 +52914,141 @@ async function runIBazel(bazelArgs, offline = false, runOpts = {}) { } /***/ }), -/* 427 */ +/* 426 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); -/* harmony import */ var _internal_operators_audit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(428); +/* harmony import */ var _internal_operators_audit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(427); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "audit", function() { return _internal_operators_audit__WEBPACK_IMPORTED_MODULE_0__["audit"]; }); -/* harmony import */ var _internal_operators_auditTime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(429); +/* harmony import */ var _internal_operators_auditTime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(428); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "auditTime", function() { return _internal_operators_auditTime__WEBPACK_IMPORTED_MODULE_1__["auditTime"]; }); -/* harmony import */ var _internal_operators_buffer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(430); +/* harmony import */ var _internal_operators_buffer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(429); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "buffer", function() { return _internal_operators_buffer__WEBPACK_IMPORTED_MODULE_2__["buffer"]; }); -/* harmony import */ var _internal_operators_bufferCount__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(431); +/* harmony import */ var _internal_operators_bufferCount__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(430); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "bufferCount", function() { return _internal_operators_bufferCount__WEBPACK_IMPORTED_MODULE_3__["bufferCount"]; }); -/* harmony import */ var _internal_operators_bufferTime__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(432); +/* harmony import */ var _internal_operators_bufferTime__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(431); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "bufferTime", function() { return _internal_operators_bufferTime__WEBPACK_IMPORTED_MODULE_4__["bufferTime"]; }); -/* harmony import */ var _internal_operators_bufferToggle__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(433); +/* harmony import */ var _internal_operators_bufferToggle__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(432); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "bufferToggle", function() { return _internal_operators_bufferToggle__WEBPACK_IMPORTED_MODULE_5__["bufferToggle"]; }); -/* harmony import */ var _internal_operators_bufferWhen__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(434); +/* harmony import */ var _internal_operators_bufferWhen__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(433); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "bufferWhen", function() { return _internal_operators_bufferWhen__WEBPACK_IMPORTED_MODULE_6__["bufferWhen"]; }); -/* harmony import */ var _internal_operators_catchError__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(435); +/* harmony import */ var _internal_operators_catchError__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(434); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "catchError", function() { return _internal_operators_catchError__WEBPACK_IMPORTED_MODULE_7__["catchError"]; }); -/* harmony import */ var _internal_operators_combineAll__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(436); +/* harmony import */ var _internal_operators_combineAll__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(435); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "combineAll", function() { return _internal_operators_combineAll__WEBPACK_IMPORTED_MODULE_8__["combineAll"]; }); -/* harmony import */ var _internal_operators_combineLatest__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(437); +/* harmony import */ var _internal_operators_combineLatest__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(436); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "combineLatest", function() { return _internal_operators_combineLatest__WEBPACK_IMPORTED_MODULE_9__["combineLatest"]; }); -/* harmony import */ var _internal_operators_concat__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(438); +/* harmony import */ var _internal_operators_concat__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(437); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "concat", function() { return _internal_operators_concat__WEBPACK_IMPORTED_MODULE_10__["concat"]; }); /* harmony import */ var _internal_operators_concatAll__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(81); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "concatAll", function() { return _internal_operators_concatAll__WEBPACK_IMPORTED_MODULE_11__["concatAll"]; }); -/* harmony import */ var _internal_operators_concatMap__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(439); +/* harmony import */ var _internal_operators_concatMap__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(438); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "concatMap", function() { return _internal_operators_concatMap__WEBPACK_IMPORTED_MODULE_12__["concatMap"]; }); -/* harmony import */ var _internal_operators_concatMapTo__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(440); +/* harmony import */ var _internal_operators_concatMapTo__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(439); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "concatMapTo", function() { return _internal_operators_concatMapTo__WEBPACK_IMPORTED_MODULE_13__["concatMapTo"]; }); -/* harmony import */ var _internal_operators_count__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(441); +/* harmony import */ var _internal_operators_count__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(440); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "count", function() { return _internal_operators_count__WEBPACK_IMPORTED_MODULE_14__["count"]; }); -/* harmony import */ var _internal_operators_debounce__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(442); +/* harmony import */ var _internal_operators_debounce__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(441); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "debounce", function() { return _internal_operators_debounce__WEBPACK_IMPORTED_MODULE_15__["debounce"]; }); -/* harmony import */ var _internal_operators_debounceTime__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(443); +/* harmony import */ var _internal_operators_debounceTime__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(442); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "debounceTime", function() { return _internal_operators_debounceTime__WEBPACK_IMPORTED_MODULE_16__["debounceTime"]; }); -/* harmony import */ var _internal_operators_defaultIfEmpty__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(444); +/* harmony import */ var _internal_operators_defaultIfEmpty__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(443); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "defaultIfEmpty", function() { return _internal_operators_defaultIfEmpty__WEBPACK_IMPORTED_MODULE_17__["defaultIfEmpty"]; }); -/* harmony import */ var _internal_operators_delay__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(445); +/* harmony import */ var _internal_operators_delay__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(444); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "delay", function() { return _internal_operators_delay__WEBPACK_IMPORTED_MODULE_18__["delay"]; }); -/* harmony import */ var _internal_operators_delayWhen__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(447); +/* harmony import */ var _internal_operators_delayWhen__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(446); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "delayWhen", function() { return _internal_operators_delayWhen__WEBPACK_IMPORTED_MODULE_19__["delayWhen"]; }); -/* harmony import */ var _internal_operators_dematerialize__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(448); +/* harmony import */ var _internal_operators_dematerialize__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(447); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "dematerialize", function() { return _internal_operators_dematerialize__WEBPACK_IMPORTED_MODULE_20__["dematerialize"]; }); -/* harmony import */ var _internal_operators_distinct__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(449); +/* harmony import */ var _internal_operators_distinct__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(448); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "distinct", function() { return _internal_operators_distinct__WEBPACK_IMPORTED_MODULE_21__["distinct"]; }); -/* harmony import */ var _internal_operators_distinctUntilChanged__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(450); +/* harmony import */ var _internal_operators_distinctUntilChanged__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(449); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "distinctUntilChanged", function() { return _internal_operators_distinctUntilChanged__WEBPACK_IMPORTED_MODULE_22__["distinctUntilChanged"]; }); -/* harmony import */ var _internal_operators_distinctUntilKeyChanged__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(451); +/* harmony import */ var _internal_operators_distinctUntilKeyChanged__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(450); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "distinctUntilKeyChanged", function() { return _internal_operators_distinctUntilKeyChanged__WEBPACK_IMPORTED_MODULE_23__["distinctUntilKeyChanged"]; }); -/* harmony import */ var _internal_operators_elementAt__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(452); +/* harmony import */ var _internal_operators_elementAt__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(451); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "elementAt", function() { return _internal_operators_elementAt__WEBPACK_IMPORTED_MODULE_24__["elementAt"]; }); -/* harmony import */ var _internal_operators_endWith__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(455); +/* harmony import */ var _internal_operators_endWith__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(454); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "endWith", function() { return _internal_operators_endWith__WEBPACK_IMPORTED_MODULE_25__["endWith"]; }); -/* harmony import */ var _internal_operators_every__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(456); +/* harmony import */ var _internal_operators_every__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(455); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "every", function() { return _internal_operators_every__WEBPACK_IMPORTED_MODULE_26__["every"]; }); -/* harmony import */ var _internal_operators_exhaust__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(457); +/* harmony import */ var _internal_operators_exhaust__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(456); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "exhaust", function() { return _internal_operators_exhaust__WEBPACK_IMPORTED_MODULE_27__["exhaust"]; }); -/* harmony import */ var _internal_operators_exhaustMap__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(458); +/* harmony import */ var _internal_operators_exhaustMap__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(457); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "exhaustMap", function() { return _internal_operators_exhaustMap__WEBPACK_IMPORTED_MODULE_28__["exhaustMap"]; }); -/* harmony import */ var _internal_operators_expand__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(459); +/* harmony import */ var _internal_operators_expand__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(458); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "expand", function() { return _internal_operators_expand__WEBPACK_IMPORTED_MODULE_29__["expand"]; }); /* harmony import */ var _internal_operators_filter__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(106); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "filter", function() { return _internal_operators_filter__WEBPACK_IMPORTED_MODULE_30__["filter"]; }); -/* harmony import */ var _internal_operators_finalize__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(460); +/* harmony import */ var _internal_operators_finalize__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(459); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "finalize", function() { return _internal_operators_finalize__WEBPACK_IMPORTED_MODULE_31__["finalize"]; }); -/* harmony import */ var _internal_operators_find__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(461); +/* harmony import */ var _internal_operators_find__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(460); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "find", function() { return _internal_operators_find__WEBPACK_IMPORTED_MODULE_32__["find"]; }); -/* harmony import */ var _internal_operators_findIndex__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(462); +/* harmony import */ var _internal_operators_findIndex__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(461); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "findIndex", function() { return _internal_operators_findIndex__WEBPACK_IMPORTED_MODULE_33__["findIndex"]; }); -/* harmony import */ var _internal_operators_first__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(463); +/* harmony import */ var _internal_operators_first__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(462); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "first", function() { return _internal_operators_first__WEBPACK_IMPORTED_MODULE_34__["first"]; }); /* harmony import */ var _internal_operators_groupBy__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(32); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "groupBy", function() { return _internal_operators_groupBy__WEBPACK_IMPORTED_MODULE_35__["groupBy"]; }); -/* harmony import */ var _internal_operators_ignoreElements__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(464); +/* harmony import */ var _internal_operators_ignoreElements__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(463); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ignoreElements", function() { return _internal_operators_ignoreElements__WEBPACK_IMPORTED_MODULE_36__["ignoreElements"]; }); -/* harmony import */ var _internal_operators_isEmpty__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(465); +/* harmony import */ var _internal_operators_isEmpty__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(464); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isEmpty", function() { return _internal_operators_isEmpty__WEBPACK_IMPORTED_MODULE_37__["isEmpty"]; }); -/* harmony import */ var _internal_operators_last__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(466); +/* harmony import */ var _internal_operators_last__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(465); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "last", function() { return _internal_operators_last__WEBPACK_IMPORTED_MODULE_38__["last"]; }); /* harmony import */ var _internal_operators_map__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(67); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "map", function() { return _internal_operators_map__WEBPACK_IMPORTED_MODULE_39__["map"]; }); -/* harmony import */ var _internal_operators_mapTo__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(468); +/* harmony import */ var _internal_operators_mapTo__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(467); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "mapTo", function() { return _internal_operators_mapTo__WEBPACK_IMPORTED_MODULE_40__["mapTo"]; }); -/* harmony import */ var _internal_operators_materialize__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(469); +/* harmony import */ var _internal_operators_materialize__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(468); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "materialize", function() { return _internal_operators_materialize__WEBPACK_IMPORTED_MODULE_41__["materialize"]; }); -/* harmony import */ var _internal_operators_max__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(470); +/* harmony import */ var _internal_operators_max__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(469); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "max", function() { return _internal_operators_max__WEBPACK_IMPORTED_MODULE_42__["max"]; }); -/* harmony import */ var _internal_operators_merge__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(473); +/* harmony import */ var _internal_operators_merge__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(472); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "merge", function() { return _internal_operators_merge__WEBPACK_IMPORTED_MODULE_43__["merge"]; }); /* harmony import */ var _internal_operators_mergeAll__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(82); @@ -53111,175 +53059,175 @@ __webpack_require__.r(__webpack_exports__); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "flatMap", function() { return _internal_operators_mergeMap__WEBPACK_IMPORTED_MODULE_45__["flatMap"]; }); -/* harmony import */ var _internal_operators_mergeMapTo__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(474); +/* harmony import */ var _internal_operators_mergeMapTo__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(473); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "mergeMapTo", function() { return _internal_operators_mergeMapTo__WEBPACK_IMPORTED_MODULE_46__["mergeMapTo"]; }); -/* harmony import */ var _internal_operators_mergeScan__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(475); +/* harmony import */ var _internal_operators_mergeScan__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(474); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "mergeScan", function() { return _internal_operators_mergeScan__WEBPACK_IMPORTED_MODULE_47__["mergeScan"]; }); -/* harmony import */ var _internal_operators_min__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(476); +/* harmony import */ var _internal_operators_min__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(475); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "min", function() { return _internal_operators_min__WEBPACK_IMPORTED_MODULE_48__["min"]; }); -/* harmony import */ var _internal_operators_multicast__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(477); +/* harmony import */ var _internal_operators_multicast__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(476); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "multicast", function() { return _internal_operators_multicast__WEBPACK_IMPORTED_MODULE_49__["multicast"]; }); /* harmony import */ var _internal_operators_observeOn__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(42); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "observeOn", function() { return _internal_operators_observeOn__WEBPACK_IMPORTED_MODULE_50__["observeOn"]; }); -/* harmony import */ var _internal_operators_onErrorResumeNext__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(478); +/* harmony import */ var _internal_operators_onErrorResumeNext__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(477); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onErrorResumeNext", function() { return _internal_operators_onErrorResumeNext__WEBPACK_IMPORTED_MODULE_51__["onErrorResumeNext"]; }); -/* harmony import */ var _internal_operators_pairwise__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(479); +/* harmony import */ var _internal_operators_pairwise__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(478); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "pairwise", function() { return _internal_operators_pairwise__WEBPACK_IMPORTED_MODULE_52__["pairwise"]; }); -/* harmony import */ var _internal_operators_partition__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(480); +/* harmony import */ var _internal_operators_partition__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(479); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "partition", function() { return _internal_operators_partition__WEBPACK_IMPORTED_MODULE_53__["partition"]; }); -/* harmony import */ var _internal_operators_pluck__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(481); +/* harmony import */ var _internal_operators_pluck__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(480); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "pluck", function() { return _internal_operators_pluck__WEBPACK_IMPORTED_MODULE_54__["pluck"]; }); -/* harmony import */ var _internal_operators_publish__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(482); +/* harmony import */ var _internal_operators_publish__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(481); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "publish", function() { return _internal_operators_publish__WEBPACK_IMPORTED_MODULE_55__["publish"]; }); -/* harmony import */ var _internal_operators_publishBehavior__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(483); +/* harmony import */ var _internal_operators_publishBehavior__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(482); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "publishBehavior", function() { return _internal_operators_publishBehavior__WEBPACK_IMPORTED_MODULE_56__["publishBehavior"]; }); -/* harmony import */ var _internal_operators_publishLast__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(484); +/* harmony import */ var _internal_operators_publishLast__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(483); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "publishLast", function() { return _internal_operators_publishLast__WEBPACK_IMPORTED_MODULE_57__["publishLast"]; }); -/* harmony import */ var _internal_operators_publishReplay__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(485); +/* harmony import */ var _internal_operators_publishReplay__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(484); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "publishReplay", function() { return _internal_operators_publishReplay__WEBPACK_IMPORTED_MODULE_58__["publishReplay"]; }); -/* harmony import */ var _internal_operators_race__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(486); +/* harmony import */ var _internal_operators_race__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(485); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "race", function() { return _internal_operators_race__WEBPACK_IMPORTED_MODULE_59__["race"]; }); -/* harmony import */ var _internal_operators_reduce__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(471); +/* harmony import */ var _internal_operators_reduce__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(470); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "reduce", function() { return _internal_operators_reduce__WEBPACK_IMPORTED_MODULE_60__["reduce"]; }); -/* harmony import */ var _internal_operators_repeat__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(487); +/* harmony import */ var _internal_operators_repeat__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(486); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "repeat", function() { return _internal_operators_repeat__WEBPACK_IMPORTED_MODULE_61__["repeat"]; }); -/* harmony import */ var _internal_operators_repeatWhen__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(488); +/* harmony import */ var _internal_operators_repeatWhen__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(487); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "repeatWhen", function() { return _internal_operators_repeatWhen__WEBPACK_IMPORTED_MODULE_62__["repeatWhen"]; }); -/* harmony import */ var _internal_operators_retry__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(489); +/* harmony import */ var _internal_operators_retry__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(488); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "retry", function() { return _internal_operators_retry__WEBPACK_IMPORTED_MODULE_63__["retry"]; }); -/* harmony import */ var _internal_operators_retryWhen__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(490); +/* harmony import */ var _internal_operators_retryWhen__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(489); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "retryWhen", function() { return _internal_operators_retryWhen__WEBPACK_IMPORTED_MODULE_64__["retryWhen"]; }); /* harmony import */ var _internal_operators_refCount__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(31); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "refCount", function() { return _internal_operators_refCount__WEBPACK_IMPORTED_MODULE_65__["refCount"]; }); -/* harmony import */ var _internal_operators_sample__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(491); +/* harmony import */ var _internal_operators_sample__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(490); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "sample", function() { return _internal_operators_sample__WEBPACK_IMPORTED_MODULE_66__["sample"]; }); -/* harmony import */ var _internal_operators_sampleTime__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(492); +/* harmony import */ var _internal_operators_sampleTime__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(491); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "sampleTime", function() { return _internal_operators_sampleTime__WEBPACK_IMPORTED_MODULE_67__["sampleTime"]; }); -/* harmony import */ var _internal_operators_scan__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(472); +/* harmony import */ var _internal_operators_scan__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(471); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "scan", function() { return _internal_operators_scan__WEBPACK_IMPORTED_MODULE_68__["scan"]; }); -/* harmony import */ var _internal_operators_sequenceEqual__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(493); +/* harmony import */ var _internal_operators_sequenceEqual__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(492); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "sequenceEqual", function() { return _internal_operators_sequenceEqual__WEBPACK_IMPORTED_MODULE_69__["sequenceEqual"]; }); -/* harmony import */ var _internal_operators_share__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(494); +/* harmony import */ var _internal_operators_share__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(493); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "share", function() { return _internal_operators_share__WEBPACK_IMPORTED_MODULE_70__["share"]; }); -/* harmony import */ var _internal_operators_shareReplay__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(495); +/* harmony import */ var _internal_operators_shareReplay__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(494); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "shareReplay", function() { return _internal_operators_shareReplay__WEBPACK_IMPORTED_MODULE_71__["shareReplay"]; }); -/* harmony import */ var _internal_operators_single__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(496); +/* harmony import */ var _internal_operators_single__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(495); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "single", function() { return _internal_operators_single__WEBPACK_IMPORTED_MODULE_72__["single"]; }); -/* harmony import */ var _internal_operators_skip__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(497); +/* harmony import */ var _internal_operators_skip__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(496); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "skip", function() { return _internal_operators_skip__WEBPACK_IMPORTED_MODULE_73__["skip"]; }); -/* harmony import */ var _internal_operators_skipLast__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(498); +/* harmony import */ var _internal_operators_skipLast__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(497); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "skipLast", function() { return _internal_operators_skipLast__WEBPACK_IMPORTED_MODULE_74__["skipLast"]; }); -/* harmony import */ var _internal_operators_skipUntil__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(499); +/* harmony import */ var _internal_operators_skipUntil__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(498); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "skipUntil", function() { return _internal_operators_skipUntil__WEBPACK_IMPORTED_MODULE_75__["skipUntil"]; }); -/* harmony import */ var _internal_operators_skipWhile__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(500); +/* harmony import */ var _internal_operators_skipWhile__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(499); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "skipWhile", function() { return _internal_operators_skipWhile__WEBPACK_IMPORTED_MODULE_76__["skipWhile"]; }); -/* harmony import */ var _internal_operators_startWith__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(501); +/* harmony import */ var _internal_operators_startWith__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(500); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "startWith", function() { return _internal_operators_startWith__WEBPACK_IMPORTED_MODULE_77__["startWith"]; }); -/* harmony import */ var _internal_operators_subscribeOn__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(502); +/* harmony import */ var _internal_operators_subscribeOn__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(501); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "subscribeOn", function() { return _internal_operators_subscribeOn__WEBPACK_IMPORTED_MODULE_78__["subscribeOn"]; }); -/* harmony import */ var _internal_operators_switchAll__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(504); +/* harmony import */ var _internal_operators_switchAll__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(503); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "switchAll", function() { return _internal_operators_switchAll__WEBPACK_IMPORTED_MODULE_79__["switchAll"]; }); -/* harmony import */ var _internal_operators_switchMap__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(505); +/* harmony import */ var _internal_operators_switchMap__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(504); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "switchMap", function() { return _internal_operators_switchMap__WEBPACK_IMPORTED_MODULE_80__["switchMap"]; }); -/* harmony import */ var _internal_operators_switchMapTo__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(506); +/* harmony import */ var _internal_operators_switchMapTo__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(505); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "switchMapTo", function() { return _internal_operators_switchMapTo__WEBPACK_IMPORTED_MODULE_81__["switchMapTo"]; }); -/* harmony import */ var _internal_operators_take__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(454); +/* harmony import */ var _internal_operators_take__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(453); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "take", function() { return _internal_operators_take__WEBPACK_IMPORTED_MODULE_82__["take"]; }); -/* harmony import */ var _internal_operators_takeLast__WEBPACK_IMPORTED_MODULE_83__ = __webpack_require__(467); +/* harmony import */ var _internal_operators_takeLast__WEBPACK_IMPORTED_MODULE_83__ = __webpack_require__(466); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "takeLast", function() { return _internal_operators_takeLast__WEBPACK_IMPORTED_MODULE_83__["takeLast"]; }); -/* harmony import */ var _internal_operators_takeUntil__WEBPACK_IMPORTED_MODULE_84__ = __webpack_require__(507); +/* harmony import */ var _internal_operators_takeUntil__WEBPACK_IMPORTED_MODULE_84__ = __webpack_require__(506); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "takeUntil", function() { return _internal_operators_takeUntil__WEBPACK_IMPORTED_MODULE_84__["takeUntil"]; }); -/* harmony import */ var _internal_operators_takeWhile__WEBPACK_IMPORTED_MODULE_85__ = __webpack_require__(508); +/* harmony import */ var _internal_operators_takeWhile__WEBPACK_IMPORTED_MODULE_85__ = __webpack_require__(507); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "takeWhile", function() { return _internal_operators_takeWhile__WEBPACK_IMPORTED_MODULE_85__["takeWhile"]; }); -/* harmony import */ var _internal_operators_tap__WEBPACK_IMPORTED_MODULE_86__ = __webpack_require__(509); +/* harmony import */ var _internal_operators_tap__WEBPACK_IMPORTED_MODULE_86__ = __webpack_require__(508); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "tap", function() { return _internal_operators_tap__WEBPACK_IMPORTED_MODULE_86__["tap"]; }); -/* harmony import */ var _internal_operators_throttle__WEBPACK_IMPORTED_MODULE_87__ = __webpack_require__(510); +/* harmony import */ var _internal_operators_throttle__WEBPACK_IMPORTED_MODULE_87__ = __webpack_require__(509); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "throttle", function() { return _internal_operators_throttle__WEBPACK_IMPORTED_MODULE_87__["throttle"]; }); -/* harmony import */ var _internal_operators_throttleTime__WEBPACK_IMPORTED_MODULE_88__ = __webpack_require__(511); +/* harmony import */ var _internal_operators_throttleTime__WEBPACK_IMPORTED_MODULE_88__ = __webpack_require__(510); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "throttleTime", function() { return _internal_operators_throttleTime__WEBPACK_IMPORTED_MODULE_88__["throttleTime"]; }); -/* harmony import */ var _internal_operators_throwIfEmpty__WEBPACK_IMPORTED_MODULE_89__ = __webpack_require__(453); +/* harmony import */ var _internal_operators_throwIfEmpty__WEBPACK_IMPORTED_MODULE_89__ = __webpack_require__(452); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "throwIfEmpty", function() { return _internal_operators_throwIfEmpty__WEBPACK_IMPORTED_MODULE_89__["throwIfEmpty"]; }); -/* harmony import */ var _internal_operators_timeInterval__WEBPACK_IMPORTED_MODULE_90__ = __webpack_require__(512); +/* harmony import */ var _internal_operators_timeInterval__WEBPACK_IMPORTED_MODULE_90__ = __webpack_require__(511); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "timeInterval", function() { return _internal_operators_timeInterval__WEBPACK_IMPORTED_MODULE_90__["timeInterval"]; }); -/* harmony import */ var _internal_operators_timeout__WEBPACK_IMPORTED_MODULE_91__ = __webpack_require__(513); +/* harmony import */ var _internal_operators_timeout__WEBPACK_IMPORTED_MODULE_91__ = __webpack_require__(512); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "timeout", function() { return _internal_operators_timeout__WEBPACK_IMPORTED_MODULE_91__["timeout"]; }); -/* harmony import */ var _internal_operators_timeoutWith__WEBPACK_IMPORTED_MODULE_92__ = __webpack_require__(514); +/* harmony import */ var _internal_operators_timeoutWith__WEBPACK_IMPORTED_MODULE_92__ = __webpack_require__(513); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "timeoutWith", function() { return _internal_operators_timeoutWith__WEBPACK_IMPORTED_MODULE_92__["timeoutWith"]; }); -/* harmony import */ var _internal_operators_timestamp__WEBPACK_IMPORTED_MODULE_93__ = __webpack_require__(515); +/* harmony import */ var _internal_operators_timestamp__WEBPACK_IMPORTED_MODULE_93__ = __webpack_require__(514); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "timestamp", function() { return _internal_operators_timestamp__WEBPACK_IMPORTED_MODULE_93__["timestamp"]; }); -/* harmony import */ var _internal_operators_toArray__WEBPACK_IMPORTED_MODULE_94__ = __webpack_require__(516); +/* harmony import */ var _internal_operators_toArray__WEBPACK_IMPORTED_MODULE_94__ = __webpack_require__(515); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "toArray", function() { return _internal_operators_toArray__WEBPACK_IMPORTED_MODULE_94__["toArray"]; }); -/* harmony import */ var _internal_operators_window__WEBPACK_IMPORTED_MODULE_95__ = __webpack_require__(517); +/* harmony import */ var _internal_operators_window__WEBPACK_IMPORTED_MODULE_95__ = __webpack_require__(516); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "window", function() { return _internal_operators_window__WEBPACK_IMPORTED_MODULE_95__["window"]; }); -/* harmony import */ var _internal_operators_windowCount__WEBPACK_IMPORTED_MODULE_96__ = __webpack_require__(518); +/* harmony import */ var _internal_operators_windowCount__WEBPACK_IMPORTED_MODULE_96__ = __webpack_require__(517); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "windowCount", function() { return _internal_operators_windowCount__WEBPACK_IMPORTED_MODULE_96__["windowCount"]; }); -/* harmony import */ var _internal_operators_windowTime__WEBPACK_IMPORTED_MODULE_97__ = __webpack_require__(519); +/* harmony import */ var _internal_operators_windowTime__WEBPACK_IMPORTED_MODULE_97__ = __webpack_require__(518); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "windowTime", function() { return _internal_operators_windowTime__WEBPACK_IMPORTED_MODULE_97__["windowTime"]; }); -/* harmony import */ var _internal_operators_windowToggle__WEBPACK_IMPORTED_MODULE_98__ = __webpack_require__(520); +/* harmony import */ var _internal_operators_windowToggle__WEBPACK_IMPORTED_MODULE_98__ = __webpack_require__(519); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "windowToggle", function() { return _internal_operators_windowToggle__WEBPACK_IMPORTED_MODULE_98__["windowToggle"]; }); -/* harmony import */ var _internal_operators_windowWhen__WEBPACK_IMPORTED_MODULE_99__ = __webpack_require__(521); +/* harmony import */ var _internal_operators_windowWhen__WEBPACK_IMPORTED_MODULE_99__ = __webpack_require__(520); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "windowWhen", function() { return _internal_operators_windowWhen__WEBPACK_IMPORTED_MODULE_99__["windowWhen"]; }); -/* harmony import */ var _internal_operators_withLatestFrom__WEBPACK_IMPORTED_MODULE_100__ = __webpack_require__(522); +/* harmony import */ var _internal_operators_withLatestFrom__WEBPACK_IMPORTED_MODULE_100__ = __webpack_require__(521); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "withLatestFrom", function() { return _internal_operators_withLatestFrom__WEBPACK_IMPORTED_MODULE_100__["withLatestFrom"]; }); -/* harmony import */ var _internal_operators_zip__WEBPACK_IMPORTED_MODULE_101__ = __webpack_require__(523); +/* harmony import */ var _internal_operators_zip__WEBPACK_IMPORTED_MODULE_101__ = __webpack_require__(522); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "zip", function() { return _internal_operators_zip__WEBPACK_IMPORTED_MODULE_101__["zip"]; }); -/* harmony import */ var _internal_operators_zipAll__WEBPACK_IMPORTED_MODULE_102__ = __webpack_require__(524); +/* harmony import */ var _internal_operators_zipAll__WEBPACK_IMPORTED_MODULE_102__ = __webpack_require__(523); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "zipAll", function() { return _internal_operators_zipAll__WEBPACK_IMPORTED_MODULE_102__["zipAll"]; }); /** PURE_IMPORTS_START PURE_IMPORTS_END */ @@ -53390,7 +53338,7 @@ __webpack_require__.r(__webpack_exports__); /***/ }), -/* 428 */ +/* 427 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -53469,14 +53417,14 @@ var AuditSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 429 */ +/* 428 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "auditTime", function() { return auditTime; }); /* harmony import */ var _scheduler_async__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _audit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(428); +/* harmony import */ var _audit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(427); /* harmony import */ var _observable_timer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(109); /** PURE_IMPORTS_START _scheduler_async,_audit,_observable_timer PURE_IMPORTS_END */ @@ -53492,7 +53440,7 @@ function auditTime(duration, scheduler) { /***/ }), -/* 430 */ +/* 429 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -53539,7 +53487,7 @@ var BufferSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 431 */ +/* 430 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -53640,7 +53588,7 @@ var BufferSkipCountSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 432 */ +/* 431 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -53801,7 +53749,7 @@ function dispatchBufferClose(arg) { /***/ }), -/* 433 */ +/* 432 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -53920,7 +53868,7 @@ var BufferToggleSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 434 */ +/* 433 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54013,7 +53961,7 @@ var BufferWhenSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 435 */ +/* 434 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54073,7 +54021,7 @@ var CatchSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 436 */ +/* 435 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54089,7 +54037,7 @@ function combineAll(project) { /***/ }), -/* 437 */ +/* 436 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54121,7 +54069,7 @@ function combineLatest() { /***/ }), -/* 438 */ +/* 437 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54141,7 +54089,7 @@ function concat() { /***/ }), -/* 439 */ +/* 438 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54157,13 +54105,13 @@ function concatMap(project, resultSelector) { /***/ }), -/* 440 */ +/* 439 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "concatMapTo", function() { return concatMapTo; }); -/* harmony import */ var _concatMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(439); +/* harmony import */ var _concatMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(438); /** PURE_IMPORTS_START _concatMap PURE_IMPORTS_END */ function concatMapTo(innerObservable, resultSelector) { @@ -54173,7 +54121,7 @@ function concatMapTo(innerObservable, resultSelector) { /***/ }), -/* 441 */ +/* 440 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54238,7 +54186,7 @@ var CountSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 442 */ +/* 441 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54323,7 +54271,7 @@ var DebounceSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 443 */ +/* 442 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54399,7 +54347,7 @@ function dispatchNext(subscriber) { /***/ }), -/* 444 */ +/* 443 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54449,7 +54397,7 @@ var DefaultIfEmptySubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 445 */ +/* 444 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54457,7 +54405,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "delay", function() { return delay; }); /* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(13); /* harmony import */ var _scheduler_async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _util_isDate__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(446); +/* harmony import */ var _util_isDate__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(445); /* harmony import */ var _Subscriber__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12); /* harmony import */ var _Notification__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43); /** PURE_IMPORTS_START tslib,_scheduler_async,_util_isDate,_Subscriber,_Notification PURE_IMPORTS_END */ @@ -54556,7 +54504,7 @@ var DelayMessage = /*@__PURE__*/ (function () { /***/ }), -/* 446 */ +/* 445 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54570,7 +54518,7 @@ function isDate(value) { /***/ }), -/* 447 */ +/* 446 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54716,7 +54664,7 @@ var SubscriptionDelaySubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 448 */ +/* 447 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54754,7 +54702,7 @@ var DeMaterializeSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 449 */ +/* 448 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54830,7 +54778,7 @@ var DistinctSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 450 */ +/* 449 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54901,13 +54849,13 @@ var DistinctUntilChangedSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 451 */ +/* 450 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "distinctUntilKeyChanged", function() { return distinctUntilKeyChanged; }); -/* harmony import */ var _distinctUntilChanged__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(450); +/* harmony import */ var _distinctUntilChanged__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(449); /** PURE_IMPORTS_START _distinctUntilChanged PURE_IMPORTS_END */ function distinctUntilKeyChanged(key, compare) { @@ -54917,7 +54865,7 @@ function distinctUntilKeyChanged(key, compare) { /***/ }), -/* 452 */ +/* 451 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -54925,9 +54873,9 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "elementAt", function() { return elementAt; }); /* harmony import */ var _util_ArgumentOutOfRangeError__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(63); /* harmony import */ var _filter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(106); -/* harmony import */ var _throwIfEmpty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(453); -/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(444); -/* harmony import */ var _take__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(454); +/* harmony import */ var _throwIfEmpty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(452); +/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(443); +/* harmony import */ var _take__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(453); /** PURE_IMPORTS_START _util_ArgumentOutOfRangeError,_filter,_throwIfEmpty,_defaultIfEmpty,_take PURE_IMPORTS_END */ @@ -54949,7 +54897,7 @@ function elementAt(index, defaultValue) { /***/ }), -/* 453 */ +/* 452 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55015,7 +54963,7 @@ function defaultErrorFactory() { /***/ }), -/* 454 */ +/* 453 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55077,7 +55025,7 @@ var TakeSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 455 */ +/* 454 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55099,7 +55047,7 @@ function endWith() { /***/ }), -/* 456 */ +/* 455 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55161,7 +55109,7 @@ var EverySubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 457 */ +/* 456 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55215,7 +55163,7 @@ var SwitchFirstSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 458 */ +/* 457 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55309,7 +55257,7 @@ var ExhaustMapSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 459 */ +/* 458 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55421,7 +55369,7 @@ var ExpandSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 460 */ +/* 459 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55459,7 +55407,7 @@ var FinallySubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 461 */ +/* 460 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55531,13 +55479,13 @@ var FindValueSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 462 */ +/* 461 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findIndex", function() { return findIndex; }); -/* harmony import */ var _operators_find__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(461); +/* harmony import */ var _operators_find__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(460); /** PURE_IMPORTS_START _operators_find PURE_IMPORTS_END */ function findIndex(predicate, thisArg) { @@ -55547,7 +55495,7 @@ function findIndex(predicate, thisArg) { /***/ }), -/* 463 */ +/* 462 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55555,9 +55503,9 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "first", function() { return first; }); /* harmony import */ var _util_EmptyError__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(64); /* harmony import */ var _filter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(106); -/* harmony import */ var _take__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(454); -/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(444); -/* harmony import */ var _throwIfEmpty__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(453); +/* harmony import */ var _take__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(453); +/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(443); +/* harmony import */ var _throwIfEmpty__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(452); /* harmony import */ var _util_identity__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(26); /** PURE_IMPORTS_START _util_EmptyError,_filter,_take,_defaultIfEmpty,_throwIfEmpty,_util_identity PURE_IMPORTS_END */ @@ -55574,7 +55522,7 @@ function first(predicate, defaultValue) { /***/ }), -/* 464 */ +/* 463 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55611,7 +55559,7 @@ var IgnoreElementsSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 465 */ +/* 464 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55655,7 +55603,7 @@ var IsEmptySubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 466 */ +/* 465 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55663,9 +55611,9 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "last", function() { return last; }); /* harmony import */ var _util_EmptyError__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(64); /* harmony import */ var _filter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(106); -/* harmony import */ var _takeLast__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(467); -/* harmony import */ var _throwIfEmpty__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(453); -/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(444); +/* harmony import */ var _takeLast__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(466); +/* harmony import */ var _throwIfEmpty__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(452); +/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(443); /* harmony import */ var _util_identity__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(26); /** PURE_IMPORTS_START _util_EmptyError,_filter,_takeLast,_throwIfEmpty,_defaultIfEmpty,_util_identity PURE_IMPORTS_END */ @@ -55682,7 +55630,7 @@ function last(predicate, defaultValue) { /***/ }), -/* 467 */ +/* 466 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55759,7 +55707,7 @@ var TakeLastSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 468 */ +/* 467 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55798,7 +55746,7 @@ var MapToSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 469 */ +/* 468 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55848,13 +55796,13 @@ var MaterializeSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 470 */ +/* 469 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "max", function() { return max; }); -/* harmony import */ var _reduce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(471); +/* harmony import */ var _reduce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(470); /** PURE_IMPORTS_START _reduce PURE_IMPORTS_END */ function max(comparer) { @@ -55867,15 +55815,15 @@ function max(comparer) { /***/ }), -/* 471 */ +/* 470 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "reduce", function() { return reduce; }); -/* harmony import */ var _scan__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(472); -/* harmony import */ var _takeLast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(467); -/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(444); +/* harmony import */ var _scan__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(471); +/* harmony import */ var _takeLast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(466); +/* harmony import */ var _defaultIfEmpty__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(443); /* harmony import */ var _util_pipe__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25); /** PURE_IMPORTS_START _scan,_takeLast,_defaultIfEmpty,_util_pipe PURE_IMPORTS_END */ @@ -55896,7 +55844,7 @@ function reduce(accumulator, seed) { /***/ }), -/* 472 */ +/* 471 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55978,7 +55926,7 @@ var ScanSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 473 */ +/* 472 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -55998,7 +55946,7 @@ function merge() { /***/ }), -/* 474 */ +/* 473 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56023,7 +55971,7 @@ function mergeMapTo(innerObservable, resultSelector, concurrent) { /***/ }), -/* 475 */ +/* 474 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56132,13 +56080,13 @@ var MergeScanSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 476 */ +/* 475 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "min", function() { return min; }); -/* harmony import */ var _reduce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(471); +/* harmony import */ var _reduce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(470); /** PURE_IMPORTS_START _reduce PURE_IMPORTS_END */ function min(comparer) { @@ -56151,7 +56099,7 @@ function min(comparer) { /***/ }), -/* 477 */ +/* 476 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56200,7 +56148,7 @@ var MulticastOperator = /*@__PURE__*/ (function () { /***/ }), -/* 478 */ +/* 477 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56290,7 +56238,7 @@ var OnErrorResumeNextSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 479 */ +/* 478 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56338,7 +56286,7 @@ var PairwiseSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 480 */ +/* 479 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56361,7 +56309,7 @@ function partition(predicate, thisArg) { /***/ }), -/* 481 */ +/* 480 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56401,14 +56349,14 @@ function plucker(props, length) { /***/ }), -/* 482 */ +/* 481 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "publish", function() { return publish; }); /* harmony import */ var _Subject__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(28); -/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(477); +/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(476); /** PURE_IMPORTS_START _Subject,_multicast PURE_IMPORTS_END */ @@ -56421,14 +56369,14 @@ function publish(selector) { /***/ }), -/* 483 */ +/* 482 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "publishBehavior", function() { return publishBehavior; }); /* harmony import */ var _BehaviorSubject__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(33); -/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(477); +/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(476); /** PURE_IMPORTS_START _BehaviorSubject,_multicast PURE_IMPORTS_END */ @@ -56439,14 +56387,14 @@ function publishBehavior(value) { /***/ }), -/* 484 */ +/* 483 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "publishLast", function() { return publishLast; }); /* harmony import */ var _AsyncSubject__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(51); -/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(477); +/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(476); /** PURE_IMPORTS_START _AsyncSubject,_multicast PURE_IMPORTS_END */ @@ -56457,14 +56405,14 @@ function publishLast() { /***/ }), -/* 485 */ +/* 484 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "publishReplay", function() { return publishReplay; }); /* harmony import */ var _ReplaySubject__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34); -/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(477); +/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(476); /** PURE_IMPORTS_START _ReplaySubject,_multicast PURE_IMPORTS_END */ @@ -56480,7 +56428,7 @@ function publishReplay(bufferSize, windowTime, selectorOrScheduler, scheduler) { /***/ }), -/* 486 */ +/* 485 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56507,7 +56455,7 @@ function race() { /***/ }), -/* 487 */ +/* 486 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56572,7 +56520,7 @@ var RepeatSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 488 */ +/* 487 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56666,7 +56614,7 @@ var RepeatWhenSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 489 */ +/* 488 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56719,7 +56667,7 @@ var RetrySubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 490 */ +/* 489 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56805,7 +56753,7 @@ var RetryWhenSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 491 */ +/* 490 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56860,7 +56808,7 @@ var SampleSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 492 */ +/* 491 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -56920,7 +56868,7 @@ function dispatchNotification(state) { /***/ }), -/* 493 */ +/* 492 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57043,13 +56991,13 @@ var SequenceEqualCompareToSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 494 */ +/* 493 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "share", function() { return share; }); -/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(477); +/* harmony import */ var _multicast__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(476); /* harmony import */ var _refCount__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(31); /* harmony import */ var _Subject__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(28); /** PURE_IMPORTS_START _multicast,_refCount,_Subject PURE_IMPORTS_END */ @@ -57066,7 +57014,7 @@ function share() { /***/ }), -/* 495 */ +/* 494 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57135,7 +57083,7 @@ function shareReplayOperator(_a) { /***/ }), -/* 496 */ +/* 495 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57215,7 +57163,7 @@ var SingleSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 497 */ +/* 496 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57257,7 +57205,7 @@ var SkipSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 498 */ +/* 497 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57319,7 +57267,7 @@ var SkipLastSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 499 */ +/* 498 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57376,7 +57324,7 @@ var SkipUntilSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 500 */ +/* 499 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57432,7 +57380,7 @@ var SkipWhileSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 501 */ +/* 500 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57461,13 +57409,13 @@ function startWith() { /***/ }), -/* 502 */ +/* 501 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "subscribeOn", function() { return subscribeOn; }); -/* harmony import */ var _observable_SubscribeOnObservable__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(503); +/* harmony import */ var _observable_SubscribeOnObservable__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(502); /** PURE_IMPORTS_START _observable_SubscribeOnObservable PURE_IMPORTS_END */ function subscribeOn(scheduler, delay) { @@ -57492,7 +57440,7 @@ var SubscribeOnOperator = /*@__PURE__*/ (function () { /***/ }), -/* 503 */ +/* 502 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57556,13 +57504,13 @@ var SubscribeOnObservable = /*@__PURE__*/ (function (_super) { /***/ }), -/* 504 */ +/* 503 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "switchAll", function() { return switchAll; }); -/* harmony import */ var _switchMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(505); +/* harmony import */ var _switchMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(504); /* harmony import */ var _util_identity__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(26); /** PURE_IMPORTS_START _switchMap,_util_identity PURE_IMPORTS_END */ @@ -57574,7 +57522,7 @@ function switchAll() { /***/ }), -/* 505 */ +/* 504 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57662,13 +57610,13 @@ var SwitchMapSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 506 */ +/* 505 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "switchMapTo", function() { return switchMapTo; }); -/* harmony import */ var _switchMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(505); +/* harmony import */ var _switchMap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(504); /** PURE_IMPORTS_START _switchMap PURE_IMPORTS_END */ function switchMapTo(innerObservable, resultSelector) { @@ -57678,7 +57626,7 @@ function switchMapTo(innerObservable, resultSelector) { /***/ }), -/* 507 */ +/* 506 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57726,7 +57674,7 @@ var TakeUntilSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 508 */ +/* 507 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57794,7 +57742,7 @@ var TakeWhileSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 509 */ +/* 508 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57882,7 +57830,7 @@ var TapSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 510 */ +/* 509 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57984,7 +57932,7 @@ var ThrottleSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 511 */ +/* 510 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -57993,7 +57941,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(13); /* harmony import */ var _Subscriber__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12); /* harmony import */ var _scheduler_async__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56); -/* harmony import */ var _throttle__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(510); +/* harmony import */ var _throttle__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(509); /** PURE_IMPORTS_START tslib,_Subscriber,_scheduler_async,_throttle PURE_IMPORTS_END */ @@ -58082,7 +58030,7 @@ function dispatchNext(arg) { /***/ }), -/* 512 */ +/* 511 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58090,7 +58038,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "timeInterval", function() { return timeInterval; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TimeInterval", function() { return TimeInterval; }); /* harmony import */ var _scheduler_async__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); -/* harmony import */ var _scan__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(472); +/* harmony import */ var _scan__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(471); /* harmony import */ var _observable_defer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(92); /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(67); /** PURE_IMPORTS_START _scheduler_async,_scan,_observable_defer,_map PURE_IMPORTS_END */ @@ -58126,7 +58074,7 @@ var TimeInterval = /*@__PURE__*/ (function () { /***/ }), -/* 513 */ +/* 512 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58134,7 +58082,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "timeout", function() { return timeout; }); /* harmony import */ var _scheduler_async__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); /* harmony import */ var _util_TimeoutError__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65); -/* harmony import */ var _timeoutWith__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(514); +/* harmony import */ var _timeoutWith__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(513); /* harmony import */ var _observable_throwError__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(50); /** PURE_IMPORTS_START _scheduler_async,_util_TimeoutError,_timeoutWith,_observable_throwError PURE_IMPORTS_END */ @@ -58151,7 +58099,7 @@ function timeout(due, scheduler) { /***/ }), -/* 514 */ +/* 513 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58159,7 +58107,7 @@ __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "timeoutWith", function() { return timeoutWith; }); /* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(13); /* harmony import */ var _scheduler_async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56); -/* harmony import */ var _util_isDate__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(446); +/* harmony import */ var _util_isDate__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(445); /* harmony import */ var _innerSubscribe__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(91); /** PURE_IMPORTS_START tslib,_scheduler_async,_util_isDate,_innerSubscribe PURE_IMPORTS_END */ @@ -58230,7 +58178,7 @@ var TimeoutWithSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 515 */ +/* 514 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58260,13 +58208,13 @@ var Timestamp = /*@__PURE__*/ (function () { /***/ }), -/* 516 */ +/* 515 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toArray", function() { return toArray; }); -/* harmony import */ var _reduce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(471); +/* harmony import */ var _reduce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(470); /** PURE_IMPORTS_START _reduce PURE_IMPORTS_END */ function toArrayReducer(arr, item, index) { @@ -58283,7 +58231,7 @@ function toArray() { /***/ }), -/* 517 */ +/* 516 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58361,7 +58309,7 @@ var WindowSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 518 */ +/* 517 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58451,7 +58399,7 @@ var WindowCountSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 519 */ +/* 518 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58621,7 +58569,7 @@ function dispatchWindowClose(state) { /***/ }), -/* 520 */ +/* 519 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58764,7 +58712,7 @@ var WindowToggleSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 521 */ +/* 520 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58861,7 +58809,7 @@ var WindowSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 522 */ +/* 521 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58956,7 +58904,7 @@ var WithLatestFromSubscriber = /*@__PURE__*/ (function (_super) { /***/ }), -/* 523 */ +/* 522 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58978,7 +58926,7 @@ function zip() { /***/ }), -/* 524 */ +/* 523 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; @@ -58994,7 +58942,7 @@ function zipAll(project) { /***/ }), -/* 525 */ +/* 524 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -59004,7 +58952,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var _observe_lines = __webpack_require__(526); +var _observe_lines = __webpack_require__(525); Object.keys(_observe_lines).forEach(function (key) { if (key === "default" || key === "__esModule") return; @@ -59017,7 +58965,7 @@ Object.keys(_observe_lines).forEach(function (key) { }); }); -var _observe_readable = __webpack_require__(527); +var _observe_readable = __webpack_require__(526); Object.keys(_observe_readable).forEach(function (key) { if (key === "default" || key === "__esModule") return; @@ -59031,7 +58979,7 @@ Object.keys(_observe_readable).forEach(function (key) { }); /***/ }), -/* 526 */ +/* 525 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -59044,9 +58992,9 @@ exports.observeLines = observeLines; var Rx = _interopRequireWildcard(__webpack_require__(9)); -var _operators = __webpack_require__(427); +var _operators = __webpack_require__(426); -var _observe_readable = __webpack_require__(527); +var _observe_readable = __webpack_require__(526); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } @@ -59109,7 +59057,7 @@ function observeLines(readable) { } /***/ }), -/* 527 */ +/* 526 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; @@ -59122,7 +59070,7 @@ exports.observeReadable = observeReadable; var Rx = _interopRequireWildcard(__webpack_require__(9)); -var _operators = __webpack_require__(427); +var _operators = __webpack_require__(426); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } @@ -59145,6 +59093,37 @@ function observeReadable(readable) { return Rx.race(Rx.fromEvent(readable, 'end').pipe((0, _operators.first)(), (0, _operators.ignoreElements)()), Rx.fromEvent(readable, 'error').pipe((0, _operators.first)(), (0, _operators.mergeMap)(err => Rx.throwError(err)))); } +/***/ }), +/* 527 */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeYarnIntegrityFileIfExists", function() { return removeYarnIntegrityFileIfExists; }); +/* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4); +/* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _fs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(231); +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + + +async function removeYarnIntegrityFileIfExists(nodeModulesPath) { + try { + const nodeModulesRealPath = await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["tryRealpath"])(nodeModulesPath); + const yarnIntegrityFilePath = Object(path__WEBPACK_IMPORTED_MODULE_0__["join"])(nodeModulesRealPath, '.yarn-integrity'); // check if the file exists and delete it in that case + + if (await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["isFile"])(yarnIntegrityFilePath)) { + await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["unlink"])(yarnIntegrityFilePath); + } + } catch {// no-op + } +} + /***/ }), /* 528 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { @@ -59315,7 +59294,7 @@ __webpack_require__.r(__webpack_exports__); const CleanCommand = { - description: 'Deletes output directories, node_modules and resets internal caches.', + description: 'Deletes output directories and resets internal caches.', name: 'clean', reportTiming: { group: 'scripts/kbn clean', @@ -59324,20 +59303,15 @@ const CleanCommand = { async run(projects) { _utils_log__WEBPACK_IMPORTED_MODULE_6__["log"].warning(dedent__WEBPACK_IMPORTED_MODULE_0___default.a` - This command is only necessary for the rare circumstance where you need to recover a consistent + This command is only necessary for the circumstance where you need to recover a consistent state when problems arise. If you need to run this command often, please let us know by - filling out this form: https://ela.st/yarn-kbn-clean + filling out this form: https://ela.st/yarn-kbn-clean. + Please not it might not solve problems with node_modules. To solve problems around node_modules + you might need to run 'yarn kbn reset'. `); const toDelete = []; for (const project of projects.values()) { - if (await Object(_utils_fs__WEBPACK_IMPORTED_MODULE_5__["isDirectory"])(project.nodeModulesLocation)) { - toDelete.push({ - cwd: project.path, - pattern: Object(path__WEBPACK_IMPORTED_MODULE_3__["relative"])(project.path, project.nodeModulesLocation) - }); - } - if (await Object(_utils_fs__WEBPACK_IMPORTED_MODULE_5__["isDirectory"])(project.targetLocation)) { toDelete.push({ cwd: project.path, @@ -61599,7 +61573,8 @@ const ResetCommand = { async run(projects) { _utils_log__WEBPACK_IMPORTED_MODULE_6__["log"].warning(dedent__WEBPACK_IMPORTED_MODULE_0___default.a` In most cases, 'yarn kbn clean' is all that should be needed to recover a consistent state when - problems arise. If you need to use this command, please let us know, as it should not be necessary. + problems arise. However for the rare cases where something get corrupt on node_modules you might need this command. + If you think you need to use this command very often (which is not normal), please let us know. `); const toDelete = []; diff --git a/packages/kbn-pm/src/commands/bootstrap.ts b/packages/kbn-pm/src/commands/bootstrap.ts index 26ca93d26c052..84bee5ddeceac 100644 --- a/packages/kbn-pm/src/commands/bootstrap.ts +++ b/packages/kbn-pm/src/commands/bootstrap.ts @@ -17,12 +17,7 @@ import { ICommand } from './'; import { readYarnLock } from '../utils/yarn_lock'; import { sortPackageJson } from '../utils/sort_package_json'; import { validateDependencies } from '../utils/validate_dependencies'; -import { - ensureYarnIntegrityFileExists, - installBazelTools, - runBazel, - yarnIntegrityFileExists, -} from '../utils/bazel'; +import { installBazelTools, removeYarnIntegrityFileIfExists, runBazel } from '../utils/bazel'; import { setupRemoteCache } from '../utils/bazel/setup_remote_cache'; export const BootstrapCommand: ICommand = { @@ -54,16 +49,8 @@ export const BootstrapCommand: ICommand = { } }; - // Force install is set in case a flag is passed or - // if the `.yarn-integrity` file is not found which - // will be indicated by the return of yarnIntegrityFileExists. - const forceInstall = - (!!options && options['force-install'] === true) || - !(await yarnIntegrityFileExists(resolve(kibanaProjectPath, 'node_modules'))); - - // Ensure we have a `node_modules/.yarn-integrity` file as we depend on it - // for bazel to know it has to re-install the node_modules after a reset or a clean - await ensureYarnIntegrityFileExists(resolve(kibanaProjectPath, 'node_modules')); + // Force install is set in case a flag `--force-install` is passed into kbn bootstrap + const forceInstall = !!options && options['force-install'] === true; // Install bazel machinery tools if needed await installBazelTools(rootPath); @@ -83,6 +70,8 @@ export const BootstrapCommand: ICommand = { if (forceInstall) { await time('force install dependencies', async () => { + await removeYarnIntegrityFileIfExists(resolve(kibanaProjectPath, 'node_modules')); + await runBazel(['clean']); await runBazel(['run', '@nodejs//:yarn'], runOffline, { env: { SASS_BINARY_SITE: diff --git a/packages/kbn-pm/src/commands/clean.ts b/packages/kbn-pm/src/commands/clean.ts index 89552946faeea..12f6d674ca9e6 100644 --- a/packages/kbn-pm/src/commands/clean.ts +++ b/packages/kbn-pm/src/commands/clean.ts @@ -17,7 +17,7 @@ import { log } from '../utils/log'; import { ICommand } from './'; export const CleanCommand: ICommand = { - description: 'Deletes output directories, node_modules and resets internal caches.', + description: 'Deletes output directories and resets internal caches.', name: 'clean', reportTiming: { @@ -27,20 +27,15 @@ export const CleanCommand: ICommand = { async run(projects) { log.warning(dedent` - This command is only necessary for the rare circumstance where you need to recover a consistent + This command is only necessary for the circumstance where you need to recover a consistent state when problems arise. If you need to run this command often, please let us know by - filling out this form: https://ela.st/yarn-kbn-clean + filling out this form: https://ela.st/yarn-kbn-clean. + Please not it might not solve problems with node_modules. To solve problems around node_modules + you might need to run 'yarn kbn reset'. `); const toDelete = []; for (const project of projects.values()) { - if (await isDirectory(project.nodeModulesLocation)) { - toDelete.push({ - cwd: project.path, - pattern: relative(project.path, project.nodeModulesLocation), - }); - } - if (await isDirectory(project.targetLocation)) { toDelete.push({ cwd: project.path, diff --git a/packages/kbn-pm/src/commands/reset.ts b/packages/kbn-pm/src/commands/reset.ts index 0d5fd72427a9f..1a3f7c748f79e 100644 --- a/packages/kbn-pm/src/commands/reset.ts +++ b/packages/kbn-pm/src/commands/reset.ts @@ -34,7 +34,8 @@ export const ResetCommand: ICommand = { async run(projects) { log.warning(dedent` In most cases, 'yarn kbn clean' is all that should be needed to recover a consistent state when - problems arise. If you need to use this command, please let us know, as it should not be necessary. + problems arise. However for the rare cases where something get corrupt on node_modules you might need this command. + If you think you need to use this command very often (which is not normal), please let us know. `); const toDelete = []; diff --git a/packages/kbn-pm/src/utils/bazel/index.ts b/packages/kbn-pm/src/utils/bazel/index.ts index a3651039161b8..84e26a0b914e1 100644 --- a/packages/kbn-pm/src/utils/bazel/index.ts +++ b/packages/kbn-pm/src/utils/bazel/index.ts @@ -6,7 +6,7 @@ * Side Public License, v 1. */ -export * from './yarn_integrity'; export * from './get_cache_folders'; export * from './install_tools'; export * from './run'; +export * from './yarn_integrity'; diff --git a/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts b/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts index 3a72f5ca080b8..1ac9bfeba1e3b 100644 --- a/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts +++ b/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts @@ -7,35 +7,18 @@ */ import { join } from 'path'; -import { isFile, mkdirp, tryRealpath, writeFile } from '../fs'; +import { isFile, tryRealpath, unlink } from '../fs'; -export async function yarnIntegrityFileExists(nodeModulesPath: string) { +export async function removeYarnIntegrityFileIfExists(nodeModulesPath: string) { try { const nodeModulesRealPath = await tryRealpath(nodeModulesPath); const yarnIntegrityFilePath = join(nodeModulesRealPath, '.yarn-integrity'); - // check if the file already exists + // check if the file exists and delete it in that case if (await isFile(yarnIntegrityFilePath)) { - return true; + await unlink(yarnIntegrityFilePath); } } catch { // no-op } - - return false; -} - -export async function ensureYarnIntegrityFileExists(nodeModulesPath: string) { - try { - const nodeModulesRealPath = await tryRealpath(nodeModulesPath); - const yarnIntegrityFilePath = join(nodeModulesRealPath, '.yarn-integrity'); - - // ensure node_modules folder is created - await mkdirp(nodeModulesRealPath); - - // write a blank file in case it doesn't exists - await writeFile(yarnIntegrityFilePath, '', { flag: 'wx' }); - } catch { - // no-op - } } From e95fbcfde62a83af118d0eebb37d441a0605aba3 Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Mon, 28 Mar 2022 15:24:46 +0200 Subject: [PATCH 012/160] switch to extension.raw field for stable terms agg (#128591) --- .../apps/lens/show_underlying_data.ts | 26 ++++++++++++------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/x-pack/test/functional/apps/lens/show_underlying_data.ts b/x-pack/test/functional/apps/lens/show_underlying_data.ts index 85d0a238832a6..aa2bc03ec3069 100644 --- a/x-pack/test/functional/apps/lens/show_underlying_data.ts +++ b/x-pack/test/functional/apps/lens/show_underlying_data.ts @@ -16,8 +16,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { const find = getService('find'); const browser = getService('browser'); - // Failing: See https://github.com/elastic/kibana/issues/128564 - describe.skip('show underlying data', () => { + describe('show underlying data', () => { it('should show the open button for a compatible saved visualization', async () => { await PageObjects.visualize.gotoVisualizationLandingPage(); await listingTable.searchForItemWithName('lnsXYvis'); @@ -25,6 +24,15 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.goToTimeRange(); await PageObjects.lens.waitForVisualization(); + + await PageObjects.lens.configureDimension({ + dimension: 'lnsXY_splitDimensionPanel > lns-dimensionTrigger', + operation: 'terms', + field: 'extension.raw', + }); + + await PageObjects.lens.waitForVisualization(); + // expect the button is shown and enabled await testSubjects.clickWhenNotDisabled(`lnsApp_openInDiscover`); @@ -36,7 +44,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await testSubjects.existOrFail('discoverChart'); // check the table columns const columns = await PageObjects.discover.getColumnHeaders(); - expect(columns).to.eql(['ip', '@timestamp', 'bytes']); + expect(columns).to.eql(['extension.raw', '@timestamp', 'bytes']); await browser.closeCurrentWindow(); await browser.switchToWindow(lensWindowHandler); }); @@ -83,7 +91,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await testSubjects.click('indexPattern-filter-by-input > switchQueryLanguageButton'); // apparently setting a filter requires some time before and after typing to work properly await PageObjects.common.sleep(1000); - await PageObjects.lens.setFilterBy('memory:*'); + await PageObjects.lens.setFilterBy('machine.ram:*'); await PageObjects.common.sleep(1000); await PageObjects.lens.closeDimensionEditor(); @@ -98,7 +106,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await testSubjects.existOrFail('discoverChart'); // check the query expect(await queryBar.getQueryString()).be.eql( - '( ( ip: "86.252.46.140" ) OR ( ip: "155.34.86.215" ) OR ( ip: "133.198.170.210" ) )' + '( ( extension.raw: "png" ) OR ( extension.raw: "css" ) OR ( extension.raw: "jpg" ) )' ); const filterPills = await filterBar.getFiltersLabel(); expect(filterPills.length).to.be(1); @@ -118,7 +126,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { }); const input = await find.activeElement(); - await input.type(`bytes > 6000`); + await input.type(`bytes > 2000`); // the tooltip seems to be there as long as the focus is in the query string await input.pressKeys(browser.keys.RIGHT); @@ -134,10 +142,10 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await testSubjects.existOrFail('discoverChart'); // check the columns const columns = await PageObjects.discover.getColumnHeaders(); - expect(columns).to.eql(['ip', '@timestamp', 'memory']); + expect(columns).to.eql(['extension.raw', '@timestamp', 'memory']); // check the query expect(await queryBar.getQueryString()).be.eql( - '( ( bytes > 6000 ) AND ( ( ip: "0.53.251.53" ) OR ( ip: "0.108.3.2" ) OR ( ip: "0.209.80.244" ) ) )' + '( ( bytes > 2000 ) AND ( ( extension.raw: "css" ) OR ( extension.raw: "gif" ) OR ( extension.raw: "jpg" ) ) )' ); await browser.closeCurrentWindow(); await browser.switchToWindow(lensWindowHandler); @@ -170,7 +178,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { // check the query expect(await queryBar.getQueryString()).be.eql( - '( ( bytes > 4000 ) AND ( ( ip: "0.53.251.53" ) OR ( ip: "0.108.3.2" ) OR ( ip: "0.209.80.244" ) ) )' + '( ( bytes > 4000 ) AND ( ( extension.raw: "css" ) OR ( extension.raw: "gif" ) OR ( extension.raw: "jpg" ) ) )' ); await browser.closeCurrentWindow(); await browser.switchToWindow(lensWindowHandler); From c059ead78c3550057dc7d7f8ea1338b6dd88dca2 Mon Sep 17 00:00:00 2001 From: Giorgos Bamparopoulos Date: Mon, 28 Mar 2022 14:31:59 +0100 Subject: [PATCH 013/160] Remove comparisonStart and comparisonEnd from API endpoints (#127812) * Use offset instead of comparisonStart / comparisonEnd * Replace comparisonType url param with offset * Add redirect for comparisonType and comparisonEnabled --- x-pack/plugins/apm/common/offset_rt.ts | 10 ++ .../runtime_types/comparison_type_rt.ts | 21 ---- .../service_overview/service_overview.spec.ts | 2 +- .../service_overview/time_comparison.spec.ts | 12 +- .../backend_detail_dependencies_table.tsx | 16 +-- .../backend_error_rate_chart.tsx | 17 +-- .../backend_latency_chart.tsx | 17 +-- .../backend_throughput_chart.tsx | 17 +-- .../app/backend_detail_overview/index.tsx | 3 + .../index.tsx | 23 ++-- .../error_group_details/detail_view/index.tsx | 4 +- .../app/error_group_details/index.tsx | 10 +- .../app/error_group_overview/index.tsx | 12 +- .../app/service_inventory/index.tsx | 14 +-- .../service_inventory.stories.tsx | 3 +- .../service_list/service_list.test.tsx | 1 + .../service_map/popover/backend_contents.tsx | 14 +-- .../service_map/popover/service_contents.tsx | 28 +++-- .../index.tsx | 24 ++-- .../service_overview_errors_table/index.tsx | 25 +--- ...ice_overview_instances_chart_and_table.tsx | 20 +-- .../service_overview_throughput_chart.tsx | 20 +-- .../app/transaction_details/index.tsx | 4 +- .../maybe_view_trace_link.tsx | 4 +- .../waterfall/flyout_top_level_properties.tsx | 4 +- .../span_flyout/sticky_span_properties.tsx | 10 +- .../app/transaction_overview/index.tsx | 4 +- .../components/routing/apm_route_config.tsx | 6 +- .../public/components/routing/app_root.tsx | 39 +++--- .../public/components/routing/home/index.tsx | 16 +-- .../routing/service_detail/index.tsx | 10 +- .../shared/backend_link.stories.tsx | 1 + .../failed_transaction_rate_chart/index.tsx | 20 +-- .../shared/charts/latency_chart/index.tsx | 2 +- .../latency_chart/latency_chart.stories.tsx | 2 +- .../shared/charts/spark_plot/index.tsx | 2 +- .../charts/transaction_charts/index.tsx | 7 +- .../index.tsx | 23 +--- .../shared/is_route_with_time_range.ts | 32 +++++ .../links/apm/transaction_detail_link.tsx | 10 +- .../components/shared/links/url_helpers.ts | 2 +- .../index.tsx | 19 +-- .../shared/redirect_with_offset/index.tsx | 72 +++++++++++ .../shared/service_link.stories.tsx | 1 + .../shared/time_comparison/comparison.test.ts | 114 ++++-------------- .../get_comparison_chart_theme.ts | 26 ++++ .../time_comparison/get_comparison_options.ts | 93 +++++++------- .../get_time_range_comparison.test.ts | 44 ------- .../get_time_range_comparison.ts | 78 ------------ .../shared/time_comparison/index.test.tsx | 39 +++--- .../shared/time_comparison/index.tsx | 37 +----- .../shared/transactions_table/get_columns.tsx | 7 +- .../shared/transactions_table/index.tsx | 19 +-- .../apm_plugin/mock_apm_plugin_context.tsx | 2 + .../url_params_context/resolve_url_params.ts | 5 +- .../context/url_params_context/types.ts | 3 +- .../use_error_group_distribution_fetcher.tsx | 17 +-- .../use_transaction_latency_chart_fetcher.ts | 16 +-- .../transaction_groups/get_coldstart_rate.ts | 39 +++--- .../get_failed_transaction_rate.ts | 17 ++- .../apm/server/routes/backends/route.ts | 8 +- .../apm/server/routes/default_api_types.ts | 7 -- .../errors/distribution/get_distribution.ts | 39 +++--- .../get_error_group_detailed_statistics.ts | 43 ++++--- .../plugins/apm/server/routes/errors/route.ts | 39 ++---- .../apm/server/routes/service_map/route.ts | 3 +- .../detailed_statistics.ts | 23 ++-- ...vice_instances_system_metric_statistics.ts | 21 +++- ...ervice_instances_transaction_statistics.ts | 23 +++- .../get_service_instances/main_statistics.ts | 1 + ...e_transaction_group_detailed_statistics.ts | 40 +++--- .../server/routes/services/get_throughput.ts | 24 +++- .../apm/server/routes/services/route.ts | 51 +++----- .../get_failed_transaction_rate_periods.ts | 22 ++-- .../transactions/get_latency_charts/index.ts | 46 ++++--- .../apm/server/routes/transactions/route.ts | 56 +++------ .../tests/cold_start/cold_start.spec.ts | 3 +- .../cold_start_by_transaction_name.spec.ts | 3 +- .../tests/errors/distribution.spec.ts | 6 +- .../instances_detailed_statistics.spec.ts | 3 +- .../instances_main_statistics.spec.ts | 6 +- .../error_groups_detailed_statistics.spec.ts | 3 +- .../tests/services/throughput.spec.ts | 3 +- .../tests/transactions/error_rate.spec.ts | 6 +- .../tests/transactions/latency.spec.ts | 3 +- ...actions_groups_detailed_statistics.spec.ts | 6 +- 86 files changed, 701 insertions(+), 946 deletions(-) create mode 100644 x-pack/plugins/apm/common/offset_rt.ts delete mode 100644 x-pack/plugins/apm/common/runtime_types/comparison_type_rt.ts create mode 100644 x-pack/plugins/apm/public/components/shared/is_route_with_time_range.ts create mode 100644 x-pack/plugins/apm/public/components/shared/redirect_with_offset/index.tsx create mode 100644 x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_chart_theme.ts delete mode 100644 x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.test.ts delete mode 100644 x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.ts diff --git a/x-pack/plugins/apm/common/offset_rt.ts b/x-pack/plugins/apm/common/offset_rt.ts new file mode 100644 index 0000000000000..68ac7f25f66e3 --- /dev/null +++ b/x-pack/plugins/apm/common/offset_rt.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as t from 'io-ts'; + +export const offsetRt = t.partial({ offset: t.string }); diff --git a/x-pack/plugins/apm/common/runtime_types/comparison_type_rt.ts b/x-pack/plugins/apm/common/runtime_types/comparison_type_rt.ts deleted file mode 100644 index 93c0a31c40cde..0000000000000 --- a/x-pack/plugins/apm/common/runtime_types/comparison_type_rt.ts +++ /dev/null @@ -1,21 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import * as t from 'io-ts'; - -export enum TimeRangeComparisonEnum { - WeekBefore = 'week', - DayBefore = 'day', - PeriodBefore = 'period', -} - -export const comparisonTypeRt = t.union([ - t.literal('day'), - t.literal('week'), - t.literal('period'), -]); - -export type TimeRangeComparisonType = t.TypeOf; diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts index fcd9e472cc7eb..4dd66f6dd9311 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts @@ -265,7 +265,7 @@ describe('Service Overview', () => { ); cy.expectAPIsToHaveBeenCalledWith({ apisIntercepted: aliasNamesWithComparison, - value: 'comparisonStart', + value: 'offset', }); }); }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts index d513dcaef6842..955b429a567a7 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts @@ -70,7 +70,7 @@ describe('Service overview: Time Comparison', () => { it('enables by default the time comparison feature with Last 24 hours selected', () => { cy.visit(serviceOverviewPath); - cy.url().should('include', 'comparisonEnabled=true&comparisonType=day'); + cy.url().should('include', 'comparisonEnabled=true&offset=1d'); }); describe('when comparison is toggled off', () => { @@ -94,17 +94,13 @@ describe('Service overview: Time Comparison', () => { cy.contains('opbeans-java'); cy.get('[data-test-subj="comparisonSelect"]').should('be.enabled'); - const comparisonStartEnd = `comparisonStart=${encodeURIComponent( - moment(start).subtract(1, 'day').toISOString() - )}&comparisonEnd=${encodeURIComponent( - moment(end).subtract(1, 'day').toISOString() - )}`; + const offset = `offset=1d`; // When the page loads it fetches all APIs with comparison time range cy.wait(apisToIntercept.map(({ name }) => `@${name}`)).then( (interceptions) => { interceptions.map((interception) => { - expect(interception.request.url).include(comparisonStartEnd); + expect(interception.request.url).include(offset); }); } ); @@ -116,7 +112,7 @@ describe('Service overview: Time Comparison', () => { cy.wait(apisToIntercept.map(({ name }) => `@${name}`)).then( (interceptions) => { interceptions.map((interception) => { - expect(interception.request.url).not.include(comparisonStartEnd); + expect(interception.request.url).not.include(offset); }); } ); diff --git a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_detail_dependencies_table.tsx b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_detail_dependencies_table.tsx index ee71e4d8c8674..ee0353529e7b0 100644 --- a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_detail_dependencies_table.tsx +++ b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_detail_dependencies_table.tsx @@ -10,7 +10,6 @@ import React from 'react'; import { getNodeName, NodeType } from '../../../../common/connections'; import { useApmParams } from '../../../hooks/use_apm_params'; import { useFetcher } from '../../../hooks/use_fetcher'; -import { getTimeRangeComparison } from '../../shared/time_comparison/get_time_range_comparison'; import { DependenciesTable } from '../../shared/dependencies_table'; import { ServiceLink } from '../../shared/service_link'; import { useTimeRange } from '../../../hooks/use_time_range'; @@ -24,19 +23,12 @@ export function BackendDetailDependenciesTable() { kuery, environment, comparisonEnabled, - comparisonType, + offset, }, } = useApmParams('/backends/overview'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonEnabled, - comparisonType, - }); - const { data, status } = useFetcher( (callApmApi) => { if (!start || !end) { @@ -51,13 +43,13 @@ export function BackendDetailDependenciesTable() { end, environment, numBuckets: 20, - offset, + offset: comparisonEnabled ? offset : undefined, kuery, }, }, }); }, - [start, end, environment, offset, backendName, kuery] + [start, end, environment, offset, backendName, kuery, comparisonEnabled] ); const dependencies = @@ -79,7 +71,7 @@ export function BackendDetailDependenciesTable() { agentName={location.agentName} query={{ comparisonEnabled, - comparisonType, + offset, environment, kuery, rangeFrom, diff --git a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_error_rate_chart.tsx b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_error_rate_chart.tsx index 5ecb41829f06c..550d1a1792473 100644 --- a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_error_rate_chart.tsx +++ b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_error_rate_chart.tsx @@ -16,10 +16,7 @@ import { ChartType, getTimeSeriesColor, } from '../../shared/charts/helper/get_timeseries_color'; -import { - getComparisonChartTheme, - getTimeRangeComparison, -} from '../../shared/time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../shared/time_comparison/get_comparison_chart_theme'; function yLabelFormat(y?: number | null) { return asPercent(y || 0, 1); @@ -37,20 +34,14 @@ export function BackendFailedTransactionRateChart({ environment, rangeFrom, rangeTo, + offset, comparisonEnabled, - comparisonType, }, } = useApmParams('/backends/overview'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); const comparisonChartTheme = getComparisonChartTheme(); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { data, status } = useFetcher( (callApmApi) => { @@ -64,14 +55,14 @@ export function BackendFailedTransactionRateChart({ backendName, start, end, - offset, + offset: comparisonEnabled ? offset : undefined, kuery, environment, }, }, }); }, - [backendName, start, end, offset, kuery, environment] + [backendName, start, end, offset, kuery, environment, comparisonEnabled] ); const { currentPeriodColor, previousPeriodColor } = getTimeSeriesColor( diff --git a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_latency_chart.tsx b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_latency_chart.tsx index 8289ac01b7b27..f4ccce9f4e8ca 100644 --- a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_latency_chart.tsx +++ b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_latency_chart.tsx @@ -20,10 +20,7 @@ import { ChartType, getTimeSeriesColor, } from '../../shared/charts/helper/get_timeseries_color'; -import { - getComparisonChartTheme, - getTimeRangeComparison, -} from '../../shared/time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../shared/time_comparison/get_comparison_chart_theme'; export function BackendLatencyChart({ height }: { height: number }) { const { @@ -33,20 +30,14 @@ export function BackendLatencyChart({ height }: { height: number }) { rangeTo, kuery, environment, + offset, comparisonEnabled, - comparisonType, }, } = useApmParams('/backends/overview'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); const comparisonChartTheme = getComparisonChartTheme(); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { data, status } = useFetcher( (callApmApi) => { @@ -60,14 +51,14 @@ export function BackendLatencyChart({ height }: { height: number }) { backendName, start, end, - offset, + offset: comparisonEnabled ? offset : undefined, kuery, environment, }, }, }); }, - [backendName, start, end, offset, kuery, environment] + [backendName, start, end, offset, kuery, environment, comparisonEnabled] ); const { currentPeriodColor, previousPeriodColor } = getTimeSeriesColor( diff --git a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_throughput_chart.tsx b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_throughput_chart.tsx index c8a37146d60a4..8d7cb9b2903b1 100644 --- a/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_throughput_chart.tsx +++ b/x-pack/plugins/apm/public/components/app/backend_detail_overview/backend_throughput_chart.tsx @@ -16,10 +16,7 @@ import { ChartType, getTimeSeriesColor, } from '../../shared/charts/helper/get_timeseries_color'; -import { - getComparisonChartTheme, - getTimeRangeComparison, -} from '../../shared/time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../shared/time_comparison/get_comparison_chart_theme'; export function BackendThroughputChart({ height }: { height: number }) { const { @@ -29,20 +26,14 @@ export function BackendThroughputChart({ height }: { height: number }) { rangeTo, kuery, environment, + offset, comparisonEnabled, - comparisonType, }, } = useApmParams('/backends/overview'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); const comparisonChartTheme = getComparisonChartTheme(); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { data, status } = useFetcher( (callApmApi) => { @@ -56,14 +47,14 @@ export function BackendThroughputChart({ height }: { height: number }) { backendName, start, end, - offset, + offset: comparisonEnabled ? offset : undefined, kuery, environment, }, }, }); }, - [backendName, start, end, offset, kuery, environment] + [backendName, start, end, offset, kuery, environment, comparisonEnabled] ); const { currentPeriodColor, previousPeriodColor } = getTimeSeriesColor( diff --git a/x-pack/plugins/apm/public/components/app/backend_detail_overview/index.tsx b/x-pack/plugins/apm/public/components/app/backend_detail_overview/index.tsx index 6823b571e9597..811f8979c8c96 100644 --- a/x-pack/plugins/apm/public/components/app/backend_detail_overview/index.tsx +++ b/x-pack/plugins/apm/public/components/app/backend_detail_overview/index.tsx @@ -38,6 +38,7 @@ export function BackendDetailOverview() { refreshPaused, environment, kuery, + comparisonEnabled, }, } = useApmParams('/backends/overview'); @@ -54,6 +55,7 @@ export function BackendDetailOverview() { refreshPaused, environment, kuery, + comparisonEnabled, }, }), }, @@ -68,6 +70,7 @@ export function BackendDetailOverview() { refreshPaused, environment, kuery, + comparisonEnabled, }, }), }, diff --git a/x-pack/plugins/apm/public/components/app/backend_inventory/backend_inventory_dependencies_table/index.tsx b/x-pack/plugins/apm/public/components/app/backend_inventory/backend_inventory_dependencies_table/index.tsx index fa7cf4a3ba242..f471777d965ef 100644 --- a/x-pack/plugins/apm/public/components/app/backend_inventory/backend_inventory_dependencies_table/index.tsx +++ b/x-pack/plugins/apm/public/components/app/backend_inventory/backend_inventory_dependencies_table/index.tsx @@ -15,7 +15,6 @@ import { useFetcher } from '../../../../hooks/use_fetcher'; import { useTimeRange } from '../../../../hooks/use_time_range'; import { BackendLink } from '../../../shared/backend_link'; import { DependenciesTable } from '../../../shared/dependencies_table'; -import { getTimeRangeComparison } from '../../../shared/time_comparison/get_time_range_comparison'; export function BackendInventoryDependenciesTable() { const { @@ -25,7 +24,7 @@ export function BackendInventoryDependenciesTable() { environment, kuery, comparisonEnabled, - comparisonType, + offset, }, } = useApmParams('/backends'); @@ -33,13 +32,6 @@ export function BackendInventoryDependenciesTable() { const trackEvent = useUiTracker(); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonEnabled, - comparisonType, - }); - const { data, status } = useFetcher( (callApmApi) => { if (!start || !end) { @@ -48,11 +40,18 @@ export function BackendInventoryDependenciesTable() { return callApmApi('GET /internal/apm/backends/top_backends', { params: { - query: { start, end, environment, numBuckets: 20, offset, kuery }, + query: { + start, + end, + environment, + numBuckets: 20, + offset: comparisonEnabled ? offset : undefined, + kuery, + }, }, }); }, - [start, end, environment, offset, kuery] + [start, end, environment, offset, kuery, comparisonEnabled] ); const dependencies = @@ -70,7 +69,7 @@ export function BackendInventoryDependenciesTable() { query={{ backendName: location.backendName, comparisonEnabled, - comparisonType, + offset, environment, kuery, rangeFrom, diff --git a/x-pack/plugins/apm/public/components/app/error_group_details/detail_view/index.tsx b/x-pack/plugins/apm/public/components/app/error_group_details/detail_view/index.tsx index 0a6b134275121..a0dbbb552d8cd 100644 --- a/x-pack/plugins/apm/public/components/app/error_group_details/detail_view/index.tsx +++ b/x-pack/plugins/apm/public/components/app/error_group_details/detail_view/index.tsx @@ -71,7 +71,7 @@ export function DetailView({ errorGroup, urlParams, kuery }: Props) { const history = useHistory(); const { transaction, error, occurrencesCount } = errorGroup; - const { detailTab, comparisonType, comparisonEnabled } = urlParams; + const { detailTab, offset, comparisonEnabled } = urlParams; if (!error) { return null; @@ -138,7 +138,7 @@ export function DetailView({ errorGroup, urlParams, kuery }: Props) { transactionName={transaction.transaction.name} transactionType={transaction.transaction.type} serviceName={transaction.service.name} - comparisonType={comparisonType} + offset={offset} comparisonEnabled={comparisonEnabled} > diff --git a/x-pack/plugins/apm/public/components/app/error_group_details/index.tsx b/x-pack/plugins/apm/public/components/app/error_group_details/index.tsx index e0fc999c578ae..071ef02922c4b 100644 --- a/x-pack/plugins/apm/public/components/app/error_group_details/index.tsx +++ b/x-pack/plugins/apm/public/components/app/error_group_details/index.tsx @@ -112,7 +112,14 @@ export function ErrorGroupDetails() { const { path: { groupId }, - query: { rangeFrom, rangeTo, environment, kuery, serviceGroup }, + query: { + rangeFrom, + rangeTo, + environment, + kuery, + serviceGroup, + comparisonEnabled, + }, } = useApmParams('/services/{serviceName}/errors/{groupId}'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); @@ -130,6 +137,7 @@ export function ErrorGroupDetails() { environment, kuery, serviceGroup, + comparisonEnabled, }, }), }); diff --git a/x-pack/plugins/apm/public/components/app/error_group_overview/index.tsx b/x-pack/plugins/apm/public/components/app/error_group_overview/index.tsx index 1618d7959bd07..be36ffcc55222 100644 --- a/x-pack/plugins/apm/public/components/app/error_group_overview/index.tsx +++ b/x-pack/plugins/apm/public/components/app/error_group_overview/index.tsx @@ -23,7 +23,6 @@ import { useFetcher, FETCH_STATUS } from '../../../hooks/use_fetcher'; import { useTimeRange } from '../../../hooks/use_time_range'; import { APIReturnType } from '../../../services/rest/create_call_apm_api'; import { FailedTransactionRateChart } from '../../shared/charts/failed_transaction_rate_chart'; -import { getTimeRangeComparison } from '../../shared/time_comparison/get_time_range_comparison'; import { ErrorDistribution } from '../error_group_details/distribution'; import { ErrorGroupList } from './error_group_list'; @@ -56,18 +55,12 @@ export function ErrorGroupOverview() { sortDirection, rangeFrom, rangeTo, - comparisonType, + offset, comparisonEnabled, }, } = useApmParams('/services/{serviceName}/errors'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { errorDistributionData, status } = useErrorGroupDistributionFetcher({ serviceName, groupId: undefined, @@ -133,8 +126,7 @@ export function ErrorGroupOverview() { groupIds: JSON.stringify( errorGroupMainStatistics.map(({ groupId }) => groupId).sort() ), - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx b/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx index 807a848d649ea..2ed0052547ed6 100644 --- a/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx +++ b/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx @@ -18,7 +18,6 @@ import { SearchBar } from '../../shared/search_bar'; import { ServiceList } from './service_list'; import { MLCallout, shouldDisplayMlCallout } from '../../shared/ml_callout'; import { joinByKey } from '../../../../common/utils/join_by_key'; -import { getTimeRangeComparison } from '../../shared/time_comparison/get_time_range_comparison'; const initialData = { requestId: '', @@ -35,20 +34,13 @@ function useServicesFetcher() { environment, kuery, serviceGroup, + offset, comparisonEnabled, - comparisonType, }, } = useApmParams('/services'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonEnabled, - comparisonType, - }); - const sortedAndFilteredServicesFetch = useFetcher( (callApmApi) => { return callApmApi('GET /internal/apm/sorted_and_filtered_services', { @@ -108,7 +100,7 @@ function useServicesFetcher() { // Service name is sorted to guarantee the same order every time this API is called so the result can be cached. .sort() ), - offset, + offset: comparisonEnabled ? offset : undefined, }, }, }); @@ -116,7 +108,7 @@ function useServicesFetcher() { }, // only fetches detailed statistics when requestId is invalidated by main statistics api call or offset is changed // eslint-disable-next-line react-hooks/exhaustive-deps - [mainStatisticsData.requestId, offset], + [mainStatisticsData.requestId, offset, comparisonEnabled], { preservePreviousData: false } ); diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/service_inventory.stories.tsx b/x-pack/plugins/apm/public/components/app/service_inventory/service_inventory.stories.tsx index 01430c93b4b5a..61e4f2b3ae766 100644 --- a/x-pack/plugins/apm/public/components/app/service_inventory/service_inventory.stories.tsx +++ b/x-pack/plugins/apm/public/components/app/service_inventory/service_inventory.stories.tsx @@ -11,7 +11,6 @@ import { MemoryRouter } from 'react-router-dom'; import { CoreStart } from '../../../../../../../src/core/public'; import { createKibanaReactContext } from '../../../../../../../src/plugins/kibana_react/public'; import { AnomalyDetectionSetupState } from '../../../../common/anomaly_detection/get_anomaly_detection_setup_state'; -import { TimeRangeComparisonEnum } from '../../../../common/runtime_types/comparison_type_rt'; import { AnomalyDetectionJobsContext } from '../../../context/anomaly_detection_jobs/anomaly_detection_jobs_context'; import { ApmPluginContextValue } from '../../../context/apm_plugin/apm_plugin_context'; import { MockApmPluginContextWrapper } from '../../../context/apm_plugin/mock_apm_plugin_context'; @@ -61,7 +60,7 @@ const stories: Meta<{}> = { ; @@ -38,14 +37,7 @@ export function BackendContents({ '/services/{serviceName}/service-map' ); - const { comparisonEnabled, comparisonType } = query; - - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonEnabled, - comparisonType, - }); + const { offset, comparisonEnabled } = query; const apmRouter = useApmRouter(); @@ -61,13 +53,13 @@ export function BackendContents({ environment, start, end, - offset, + offset: comparisonEnabled ? offset : undefined, }, }, }); } }, - [environment, backendName, start, end, offset] + [environment, backendName, start, end, offset, comparisonEnabled] ); const isLoading = status === FETCH_STATUS.LOADING; diff --git a/x-pack/plugins/apm/public/components/app/service_map/popover/service_contents.tsx b/x-pack/plugins/apm/public/components/app/service_map/popover/service_contents.tsx index 1d2b36c840b0b..04cf514a53dba 100644 --- a/x-pack/plugins/apm/public/components/app/service_map/popover/service_contents.tsx +++ b/x-pack/plugins/apm/public/components/app/service_map/popover/service_contents.tsx @@ -22,7 +22,6 @@ import { FETCH_STATUS, useFetcher } from '../../../../hooks/use_fetcher'; import { AnomalyDetection } from './anomaly_detection'; import { StatsList } from './stats_list'; import { useTimeRange } from '../../../../hooks/use_time_range'; -import { getTimeRangeComparison } from '../../../shared/time_comparison/get_time_range_comparison'; import { APIReturnType } from '../../../../services/rest/create_call_apm_api'; type ServiceNodeReturn = @@ -51,17 +50,10 @@ export function ServiceContents({ throw new Error('Expected rangeFrom and rangeTo to be set'); } - const { rangeFrom, rangeTo, comparisonEnabled, comparisonType } = query; + const { rangeFrom, rangeTo, comparisonEnabled, offset } = query; const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonEnabled, - comparisonType, - }); - const serviceName = nodeData.id!; const serviceGroup = ('serviceGroup' in query && query.serviceGroup) || ''; @@ -73,13 +65,18 @@ export function ServiceContents({ { params: { path: { serviceName }, - query: { environment, start, end, offset }, + query: { + environment, + start, + end, + offset: comparisonEnabled ? offset : undefined, + }, }, } ); } }, - [environment, serviceName, start, end, offset] + [environment, serviceName, start, end, offset, comparisonEnabled] ); const isLoading = status === FETCH_STATUS.LOADING; @@ -98,7 +95,14 @@ export function ServiceContents({ const focusUrl = apmRouter.link('/services/{serviceName}/service-map', { path: { serviceName }, - query: { rangeFrom, rangeTo, environment, kuery, serviceGroup }, + query: { + rangeFrom, + rangeTo, + environment, + kuery, + serviceGroup, + comparisonEnabled, + }, }); const { serviceAnomalyStats } = nodeData; diff --git a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_dependencies_table/index.tsx b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_dependencies_table/index.tsx index ba5674e558e44..4e912d7a0a453 100644 --- a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_dependencies_table/index.tsx +++ b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_dependencies_table/index.tsx @@ -18,7 +18,6 @@ import { useTimeRange } from '../../../../hooks/use_time_range'; import { BackendLink } from '../../../shared/backend_link'; import { DependenciesTable } from '../../../shared/dependencies_table'; import { ServiceLink } from '../../../shared/service_link'; -import { getTimeRangeComparison } from '../../../shared/time_comparison/get_time_range_comparison'; interface ServiceOverviewDependenciesTableProps { fixedHeight?: boolean; @@ -41,20 +40,13 @@ export function ServiceOverviewDependenciesTable({ rangeTo, serviceGroup, comparisonEnabled, - comparisonType, + offset, latencyAggregationType, }, } = useApmParams('/services/{serviceName}/*'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { offset } = getTimeRangeComparison({ - start, - end, - comparisonEnabled, - comparisonType, - }); - const { serviceName, transactionType } = useApmServiceContext(); const trackEvent = useUiTracker(); @@ -70,12 +62,18 @@ export function ServiceOverviewDependenciesTable({ { params: { path: { serviceName }, - query: { start, end, environment, numBuckets: 20, offset }, + query: { + start, + end, + environment, + numBuckets: 20, + offset: comparisonEnabled ? offset : undefined, + }, }, } ); }, - [start, end, serviceName, environment, offset] + [start, end, serviceName, environment, offset, comparisonEnabled] ); const dependencies = @@ -90,7 +88,7 @@ export function ServiceOverviewDependenciesTable({ query={{ backendName: location.backendName, comparisonEnabled, - comparisonType, + offset, environment, kuery, rangeFrom, @@ -110,7 +108,7 @@ export function ServiceOverviewDependenciesTable({ agentName={location.agentName} query={{ comparisonEnabled, - comparisonType, + offset, environment, kuery, rangeFrom, diff --git a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_errors_table/index.tsx b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_errors_table/index.tsx index 127e4cdbd5866..2a891e8abf7e0 100644 --- a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_errors_table/index.tsx +++ b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_errors_table/index.tsx @@ -18,7 +18,6 @@ import uuid from 'uuid'; import { FETCH_STATUS, useFetcher } from '../../../../hooks/use_fetcher'; import { APIReturnType } from '../../../../services/rest/create_call_apm_api'; import { ErrorOverviewLink } from '../../../shared/links/apm/error_overview_link'; -import { getTimeRangeComparison } from '../../../shared/time_comparison/get_time_range_comparison'; import { OverviewTableContainer } from '../../../shared/overview_table_container'; import { getColumns } from './get_columns'; import { useApmParams } from '../../../../hooks/use_apm_params'; @@ -70,24 +69,11 @@ export function ServiceOverviewErrorsTable({ serviceName }: Props) { const { query } = useApmParams('/services/{serviceName}/overview'); - const { - environment, - kuery, - rangeFrom, - rangeTo, - comparisonType, - comparisonEnabled, - } = query; + const { environment, kuery, rangeFrom, rangeTo, offset, comparisonEnabled } = + query; const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); - const { pageIndex, sort } = tableOptions; const { direction, field } = sort; @@ -134,8 +120,8 @@ export function ServiceOverviewErrorsTable({ serviceName }: Props) { pageIndex, direction, field, - // not used, but needed to trigger an update when comparisonType is changed either manually by user or when time range is changed - comparisonType, + // not used, but needed to trigger an update when offset is changed either manually by user or when time range is changed + offset, // not used, but needed to trigger an update when comparison feature is disabled/enabled by user comparisonEnabled, ] @@ -163,8 +149,7 @@ export function ServiceOverviewErrorsTable({ serviceName }: Props) { groupIds: JSON.stringify( items.map(({ groupId: groupId }) => groupId).sort() ), - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } diff --git a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_instances_chart_and_table.tsx b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_instances_chart_and_table.tsx index bbe94f8e8aae8..6ec04173da968 100644 --- a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_instances_chart_and_table.tsx +++ b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_instances_chart_and_table.tsx @@ -15,7 +15,6 @@ import { FETCH_STATUS, useFetcher } from '../../../hooks/use_fetcher'; import { useTimeRange } from '../../../hooks/use_time_range'; import { APIReturnType } from '../../../services/rest/create_call_apm_api'; import { InstancesLatencyDistributionChart } from '../../shared/charts/instances_latency_distribution_chart'; -import { getTimeRangeComparison } from '../../shared/time_comparison/get_time_range_comparison'; import { ServiceOverviewInstancesTable, TableOptions, @@ -79,20 +78,13 @@ export function ServiceOverviewInstancesChartAndTable({ rangeFrom, rangeTo, comparisonEnabled, - comparisonType, + offset, latencyAggregationType, }, } = useApmParams('/services/{serviceName}/overview'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); - const { data: mainStatsData = INITIAL_STATE_MAIN_STATS, status: mainStatsStatus, @@ -117,8 +109,7 @@ export function ServiceOverviewInstancesChartAndTable({ start, end, transactionType, - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } @@ -144,8 +135,8 @@ export function ServiceOverviewInstancesChartAndTable({ pageIndex, field, direction, - // not used, but needed to trigger an update when comparisonType is changed either manually by user or when time range is changed - comparisonType, + // not used, but needed to trigger an update when offset is changed either manually by user or when time range is changed + offset, // not used, but needed to trigger an update when comparison feature is disabled/enabled by user comparisonEnabled, ] @@ -206,8 +197,7 @@ export function ServiceOverviewInstancesChartAndTable({ serviceNodeIds: JSON.stringify( currentPeriodOrderedItems.map((item) => item.serviceNodeName) ), - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } diff --git a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_throughput_chart.tsx b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_throughput_chart.tsx index f7d0e618025f5..ad18f6dde3f75 100644 --- a/x-pack/plugins/apm/public/components/app/service_overview/service_overview_throughput_chart.tsx +++ b/x-pack/plugins/apm/public/components/app/service_overview/service_overview_throughput_chart.tsx @@ -23,10 +23,7 @@ import { useFetcher } from '../../../hooks/use_fetcher'; import { usePreferredServiceAnomalyTimeseries } from '../../../hooks/use_preferred_service_anomaly_timeseries'; import { useTimeRange } from '../../../hooks/use_time_range'; import { TimeseriesChart } from '../../shared/charts/timeseries_chart'; -import { - getComparisonChartTheme, - getTimeRangeComparison, -} from '../../shared/time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../shared/time_comparison/get_comparison_chart_theme'; import { ChartType, getTimeSeriesColor, @@ -47,7 +44,7 @@ export function ServiceOverviewThroughputChart({ transactionName?: string; }) { const { - query: { rangeFrom, rangeTo, comparisonEnabled, comparisonType }, + query: { rangeFrom, rangeTo, comparisonEnabled, offset }, } = useApmParams('/services/{serviceName}'); const { environment } = useEnvironmentsContext(); @@ -61,12 +58,6 @@ export function ServiceOverviewThroughputChart({ const { transactionType, serviceName } = useApmServiceContext(); const comparisonChartTheme = getComparisonChartTheme(); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { data = INITIAL_STATE, status } = useFetcher( (callApmApi) => { @@ -84,8 +75,7 @@ export function ServiceOverviewThroughputChart({ start, end, transactionType, - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, transactionName, }, }, @@ -100,9 +90,9 @@ export function ServiceOverviewThroughputChart({ start, end, transactionType, - comparisonStart, - comparisonEnd, + offset, transactionName, + comparisonEnabled, ] ); diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/index.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/index.tsx index 327664925d5b1..d91ecf3cb9dab 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/index.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/index.tsx @@ -30,7 +30,7 @@ export function TransactionDetails() { rangeTo, transactionType: transactionTypeFromUrl, comparisonEnabled, - comparisonType, + offset, } = query; const { start, end } = useTimeRange({ rangeFrom, rangeTo }); const apmRouter = useApmRouter(); @@ -74,7 +74,7 @@ export function TransactionDetails() { transactionName={transactionName} isServerlessContext={isServerless} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} /> diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx index 855f5c037fdd1..90fdaddc71408 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx @@ -25,7 +25,7 @@ export function MaybeViewTraceLink({ environment: Environment; }) { const { - query: { latencyAggregationType, comparisonEnabled, comparisonType }, + query: { latencyAggregationType, comparisonEnabled, offset }, } = useApmParams('/services/{serviceName}/transactions/view'); const viewFullTraceButtonLabel = i18n.translate( @@ -95,7 +95,7 @@ export function MaybeViewTraceLink({ environment={nextEnvironment} latencyAggregationType={latencyAggregationType} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} > {viewFullTraceButtonLabel} diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/flyout_top_level_properties.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/flyout_top_level_properties.tsx index ead54b3e9d6d9..2a168904d4a2f 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/flyout_top_level_properties.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/flyout_top_level_properties.tsx @@ -25,7 +25,7 @@ interface Props { export function FlyoutTopLevelProperties({ transaction }: Props) { const { query } = useApmParams('/services/{serviceName}/transactions/view'); - const { latencyAggregationType, comparisonEnabled, comparisonType } = query; + const { latencyAggregationType, comparisonEnabled, offset } = query; if (!transaction) { return null; @@ -66,7 +66,7 @@ export function FlyoutTopLevelProperties({ transaction }: Props) { environment={nextEnvironment} latencyAggregationType={latencyAggregationType} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} > {transaction.transaction.name} diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/sticky_span_properties.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/sticky_span_properties.tsx index 1e8cf5d19e5e0..18ec931bb7302 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/sticky_span_properties.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/sticky_span_properties.tsx @@ -34,12 +34,8 @@ interface Props { export function StickySpanProperties({ span, transaction }: Props) { const { query } = useApmParams('/services/{serviceName}/transactions/view'); - const { - environment, - latencyAggregationType, - comparisonEnabled, - comparisonType, - } = query; + const { environment, latencyAggregationType, comparisonEnabled, offset } = + query; const trackEvent = useUiTracker(); @@ -88,7 +84,7 @@ export function StickySpanProperties({ span, transaction }: Props) { environment={nextEnvironment} latencyAggregationType={latencyAggregationType} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} > {transaction.transaction.name} diff --git a/x-pack/plugins/apm/public/components/app/transaction_overview/index.tsx b/x-pack/plugins/apm/public/components/app/transaction_overview/index.tsx index bfe73e4ab0869..adb89867d743e 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_overview/index.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_overview/index.tsx @@ -26,7 +26,7 @@ export function TransactionOverview() { rangeTo, transactionType: transactionTypeFromUrl, comparisonEnabled, - comparisonType, + offset, }, } = useApmParams('/services/{serviceName}/transactions'); @@ -69,7 +69,7 @@ export function TransactionOverview() { end={end} isServerlessContext={isServerless} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} /> diff --git a/x-pack/plugins/apm/public/components/routing/apm_route_config.tsx b/x-pack/plugins/apm/public/components/routing/apm_route_config.tsx index ab211b6ee3912..0ff0b18818301 100644 --- a/x-pack/plugins/apm/public/components/routing/apm_route_config.tsx +++ b/x-pack/plugins/apm/public/components/routing/apm_route_config.tsx @@ -19,7 +19,7 @@ import { settings } from './settings'; import { ApmMainTemplate } from './templates/apm_main_template'; import { ServiceGroupsList } from '../app/service_groups'; import { ServiceGroupsRedirect } from './service_groups_redirect'; -import { comparisonTypeRt } from '../../../common/runtime_types/comparison_type_rt'; +import { offsetRt } from '../../../common/offset_rt'; const ServiceGroupsBreadcrumnbLabel = i18n.translate( 'xpack.apm.views.serviceGroups.breadcrumbLabel', @@ -97,6 +97,7 @@ const apmRoutes = { t.type({ rangeFrom: t.string, rangeTo: t.string, + comparisonEnabled: toBooleanRt, }), t.partial({ serviceGroup: t.string, @@ -104,9 +105,8 @@ const apmRoutes = { t.partial({ refreshPaused: t.union([t.literal('true'), t.literal('false')]), refreshInterval: t.string, - comparisonEnabled: toBooleanRt, - comparisonType: comparisonTypeRt, }), + offsetRt, ]), }), }, diff --git a/x-pack/plugins/apm/public/components/routing/app_root.tsx b/x-pack/plugins/apm/public/components/routing/app_root.tsx index 0bab92c74f1bd..3c66f39e268ec 100644 --- a/x-pack/plugins/apm/public/components/routing/app_root.tsx +++ b/x-pack/plugins/apm/public/components/routing/app_root.tsx @@ -37,6 +37,7 @@ import { RedirectWithDefaultDateRange } from '../shared/redirect_with_default_da import { apmRouter } from './apm_route_config'; import { TrackPageview } from './track_pageview'; import { RedirectWithDefaultEnvironment } from '../shared/redirect_with_default_environment'; +import { RedirectWithOffset } from '../shared/redirect_with_offset'; export function ApmAppRoot({ apmPluginContextValue, @@ -63,24 +64,28 @@ export function ApmAppRoot({ - - - - - - - - + + + + + + + + + - - - - - - - - - + + + + + + + + + + diff --git a/x-pack/plugins/apm/public/components/routing/home/index.tsx b/x-pack/plugins/apm/public/components/routing/home/index.tsx index 6e89df2aea5d2..5955b5bb5d909 100644 --- a/x-pack/plugins/apm/public/components/routing/home/index.tsx +++ b/x-pack/plugins/apm/public/components/routing/home/index.tsx @@ -9,7 +9,6 @@ import { Outlet } from '@kbn/typed-react-router-config'; import * as t from 'io-ts'; import React, { ComponentProps } from 'react'; import { toBooleanRt } from '@kbn/io-ts-utils'; -import { comparisonTypeRt } from '../../../../common/runtime_types/comparison_type_rt'; import { ENVIRONMENT_ALL } from '../../../../common/environment_filter_values'; import { environmentRt } from '../../../../common/environment_rt'; import { BackendDetailOverview } from '../../app/backend_detail_overview'; @@ -23,6 +22,7 @@ import { RedirectToBackendOverviewRouteView } from './redirect_to_backend_overvi import { ServiceGroupTemplate } from '../templates/service_group_template'; import { ServiceGroupsRedirect } from '../service_groups_redirect'; import { RedirectTo } from '../redirect_to'; +import { offsetRt } from '../../../../common/offset_rt'; function page({ path, @@ -133,13 +133,13 @@ export const home = { rangeFrom: t.string, rangeTo: t.string, kuery: t.string, + comparisonEnabled: toBooleanRt, }), t.partial({ refreshPaused: t.union([t.literal('true'), t.literal('false')]), refreshInterval: t.string, - comparisonEnabled: toBooleanRt, - comparisonType: comparisonTypeRt, }), + offsetRt, ]), }), defaults: { @@ -171,10 +171,12 @@ export const home = { '/backends': { element: , params: t.partial({ - query: t.partial({ - comparisonEnabled: toBooleanRt, - comparisonType: comparisonTypeRt, - }), + query: t.intersection([ + t.type({ + comparisonEnabled: toBooleanRt, + }), + offsetRt, + ]), }), children: { '/backends/{backendName}/overview': { diff --git a/x-pack/plugins/apm/public/components/routing/service_detail/index.tsx b/x-pack/plugins/apm/public/components/routing/service_detail/index.tsx index acc231615d42f..20fd4284a53cd 100644 --- a/x-pack/plugins/apm/public/components/routing/service_detail/index.tsx +++ b/x-pack/plugins/apm/public/components/routing/service_detail/index.tsx @@ -9,7 +9,6 @@ import { i18n } from '@kbn/i18n'; import React from 'react'; import { Outlet } from '@kbn/typed-react-router-config'; import { toBooleanRt, toNumberRt } from '@kbn/io-ts-utils'; -import { comparisonTypeRt } from '../../../../common/runtime_types/comparison_type_rt'; import { ENVIRONMENT_ALL } from '../../../../common/environment_filter_values'; import { environmentRt } from '../../../../common/environment_rt'; import { ServiceOverview } from '../../app/service_overview'; @@ -29,6 +28,7 @@ import { ServiceDependencies } from '../../app/service_dependencies'; import { ServiceLogs } from '../../app/service_logs'; import { InfraOverview } from '../../app/infra_overview'; import { LatencyAggregationType } from '../../../../common/latency_aggregation_types'; +import { offsetRt } from '../../../../common/offset_rt'; function page({ title, @@ -78,15 +78,15 @@ export const serviceDetail = { rangeTo: t.string, kuery: t.string, serviceGroup: t.string, + comparisonEnabled: toBooleanRt, }), t.partial({ - comparisonEnabled: toBooleanRt, - comparisonType: comparisonTypeRt, latencyAggregationType: t.string, transactionType: t.string, refreshPaused: t.union([t.literal('true'), t.literal('false')]), refreshInterval: t.string, }), + offsetRt, ]), }), ]), @@ -147,13 +147,13 @@ export const serviceDetail = { query: t.intersection([ t.type({ transactionName: t.string, + comparisonEnabled: toBooleanRt, }), t.partial({ traceId: t.string, transactionId: t.string, - comparisonEnabled: toBooleanRt, - comparisonType: comparisonTypeRt, }), + offsetRt, ]), }), }, diff --git a/x-pack/plugins/apm/public/components/shared/backend_link.stories.tsx b/x-pack/plugins/apm/public/components/shared/backend_link.stories.tsx index d26269d85cc9c..1eca596a86c67 100644 --- a/x-pack/plugins/apm/public/components/shared/backend_link.stories.tsx +++ b/x-pack/plugins/apm/public/components/shared/backend_link.stories.tsx @@ -36,5 +36,6 @@ Example.args = { kuery: '', rangeFrom: 'now-15m', rangeTo: 'now', + comparisonEnabled: false, }, }; diff --git a/x-pack/plugins/apm/public/components/shared/charts/failed_transaction_rate_chart/index.tsx b/x-pack/plugins/apm/public/components/shared/charts/failed_transaction_rate_chart/index.tsx index 77e30c2c67731..8be0ff224ec30 100644 --- a/x-pack/plugins/apm/public/components/shared/charts/failed_transaction_rate_chart/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/charts/failed_transaction_rate_chart/index.tsx @@ -15,10 +15,7 @@ import { useFetcher } from '../../../../hooks/use_fetcher'; import { useLegacyUrlParams } from '../../../../context/url_params_context/use_url_params'; import { TimeseriesChart } from '../timeseries_chart'; import { useApmServiceContext } from '../../../../context/apm_service/use_apm_service_context'; -import { - getComparisonChartTheme, - getTimeRangeComparison, -} from '../../time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../time_comparison/get_comparison_chart_theme'; import { useApmParams } from '../../../../hooks/use_apm_params'; import { useTimeRange } from '../../../../hooks/use_time_range'; import { useEnvironmentsContext } from '../../../../context/environments_context/use_environments_context'; @@ -60,7 +57,7 @@ export function FailedTransactionRateChart({ } = useLegacyUrlParams(); const { - query: { rangeFrom, rangeTo, comparisonEnabled, comparisonType }, + query: { rangeFrom, rangeTo, comparisonEnabled, offset }, } = useApmParams('/services/{serviceName}'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); @@ -74,12 +71,6 @@ export function FailedTransactionRateChart({ const { serviceName, transactionType } = useApmServiceContext(); const comparisonChartTheme = getComparisonChartTheme(); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { data = INITIAL_STATE, status } = useFetcher( (callApmApi) => { @@ -98,8 +89,7 @@ export function FailedTransactionRateChart({ end, transactionType, transactionName, - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } @@ -114,8 +104,8 @@ export function FailedTransactionRateChart({ end, transactionType, transactionName, - comparisonStart, - comparisonEnd, + offset, + comparisonEnabled, ] ); diff --git a/x-pack/plugins/apm/public/components/shared/charts/latency_chart/index.tsx b/x-pack/plugins/apm/public/components/shared/charts/latency_chart/index.tsx index f13eecaa8ef96..dd8543bc88c9f 100644 --- a/x-pack/plugins/apm/public/components/shared/charts/latency_chart/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/charts/latency_chart/index.tsx @@ -20,7 +20,7 @@ import { } from '../../../shared/charts/transaction_charts/helper'; import { MLHeader } from '../../../shared/charts/transaction_charts/ml_header'; import * as urlHelpers from '../../../shared/links/url_helpers'; -import { getComparisonChartTheme } from '../../time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../time_comparison/get_comparison_chart_theme'; import { useEnvironmentsContext } from '../../../../context/environments_context/use_environments_context'; import { ApmMlDetectorType } from '../../../../../common/anomaly_detection/apm_ml_detectors'; import { usePreferredServiceAnomalyTimeseries } from '../../../../hooks/use_preferred_service_anomaly_timeseries'; diff --git a/x-pack/plugins/apm/public/components/shared/charts/latency_chart/latency_chart.stories.tsx b/x-pack/plugins/apm/public/components/shared/charts/latency_chart/latency_chart.stories.tsx index 021c681778763..34ca6a205dbc9 100644 --- a/x-pack/plugins/apm/public/components/shared/charts/latency_chart/latency_chart.stories.tsx +++ b/x-pack/plugins/apm/public/components/shared/charts/latency_chart/latency_chart.stories.tsx @@ -69,7 +69,7 @@ const stories: Meta = { return ( diff --git a/x-pack/plugins/apm/public/components/shared/charts/spark_plot/index.tsx b/x-pack/plugins/apm/public/components/shared/charts/spark_plot/index.tsx index c497d35ed2cf6..680cd70bb4d83 100644 --- a/x-pack/plugins/apm/public/components/shared/charts/spark_plot/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/charts/spark_plot/index.tsx @@ -25,7 +25,7 @@ import { useChartTheme } from '../../../../../../observability/public'; import { Coordinate } from '../../../../../typings/timeseries'; import { useTheme } from '../../../../hooks/use_theme'; import { unit } from '../../../../utils/style'; -import { getComparisonChartTheme } from '../../time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../time_comparison/get_comparison_chart_theme'; function hasValidTimeseries( series?: Coordinate[] | null diff --git a/x-pack/plugins/apm/public/components/shared/charts/transaction_charts/index.tsx b/x-pack/plugins/apm/public/components/shared/charts/transaction_charts/index.tsx index a2bfad0175a5f..c126249d65131 100644 --- a/x-pack/plugins/apm/public/components/shared/charts/transaction_charts/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/charts/transaction_charts/index.tsx @@ -14,7 +14,6 @@ import { LatencyChart } from '../latency_chart'; import { TransactionBreakdownChart } from '../transaction_breakdown_chart'; import { TransactionColdstartRateChart } from '../transaction_coldstart_rate_chart'; import { FailedTransactionRateChart } from '../failed_transaction_rate_chart'; -import { TimeRangeComparisonType } from '../../../../../common/runtime_types/comparison_type_rt'; export function TransactionCharts({ kuery, @@ -24,7 +23,7 @@ export function TransactionCharts({ transactionName, isServerlessContext, comparisonEnabled, - comparisonType, + offset, }: { kuery: string; environment: string; @@ -33,7 +32,7 @@ export function TransactionCharts({ transactionName?: string; isServerlessContext?: boolean; comparisonEnabled?: boolean; - comparisonType?: TimeRangeComparisonType; + offset?: string; }) { return ( <> @@ -71,7 +70,7 @@ export function TransactionCharts({ transactionName={transactionName} environment={environment} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} /> ) : ( diff --git a/x-pack/plugins/apm/public/components/shared/charts/transaction_coldstart_rate_chart/index.tsx b/x-pack/plugins/apm/public/components/shared/charts/transaction_coldstart_rate_chart/index.tsx index b6558bea79d3e..f524b940e04d9 100644 --- a/x-pack/plugins/apm/public/components/shared/charts/transaction_coldstart_rate_chart/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/charts/transaction_coldstart_rate_chart/index.tsx @@ -20,13 +20,9 @@ import { useFetcher } from '../../../../hooks/use_fetcher'; import { useTheme } from '../../../../hooks/use_theme'; import { TimeseriesChart } from '../timeseries_chart'; import { useApmServiceContext } from '../../../../context/apm_service/use_apm_service_context'; -import { - getComparisonChartTheme, - getTimeRangeComparison, -} from '../../time_comparison/get_time_range_comparison'; +import { getComparisonChartTheme } from '../../time_comparison/get_comparison_chart_theme'; import { useApmParams } from '../../../../hooks/use_apm_params'; import { useTimeRange } from '../../../../hooks/use_time_range'; -import { TimeRangeComparisonType } from '../../../../../common/runtime_types/comparison_type_rt'; function yLabelFormat(y?: number | null) { return asPercent(y || 0, 1); @@ -39,7 +35,7 @@ interface Props { environment: string; transactionName?: string; comparisonEnabled?: boolean; - comparisonType?: TimeRangeComparisonType; + offset?: string; } type ColdstartRate = @@ -63,7 +59,7 @@ export function TransactionColdstartRateChart({ kuery, transactionName, comparisonEnabled, - comparisonType, + offset, }: Props) { const theme = useTheme(); @@ -75,12 +71,6 @@ export function TransactionColdstartRateChart({ const { serviceName, transactionType } = useApmServiceContext(); const comparisonChartTheme = getComparisonChartTheme(); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const endpoint = transactionName ? ('GET /internal/apm/services/{serviceName}/transactions/charts/coldstart_rate_by_transaction_name' as const) @@ -100,8 +90,7 @@ export function TransactionColdstartRateChart({ start, end, transactionType, - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, ...(transactionName ? { transactionName } : {}), }, }, @@ -116,9 +105,9 @@ export function TransactionColdstartRateChart({ end, transactionType, transactionName, - comparisonStart, - comparisonEnd, + offset, endpoint, + comparisonEnabled, ] ); diff --git a/x-pack/plugins/apm/public/components/shared/is_route_with_time_range.ts b/x-pack/plugins/apm/public/components/shared/is_route_with_time_range.ts new file mode 100644 index 0000000000000..a2573c4f65837 --- /dev/null +++ b/x-pack/plugins/apm/public/components/shared/is_route_with_time_range.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { Location } from 'history'; +import type { ApmRouter } from '../routing/apm_route_config'; + +export function isRouteWithTimeRange({ + apmRouter, + location, +}: { + apmRouter: ApmRouter; + location: Location; +}) { + const matchingRoutes = apmRouter.getRoutesToMatch(location.pathname); + const matchesRoute = matchingRoutes.some((route) => { + return ( + route.path === '/services' || + route.path === '/traces' || + route.path === '/service-map' || + route.path === '/backends' || + route.path === '/services/{serviceName}' || + route.path === '/service-groups' || + location.pathname === '/' || + location.pathname === '' + ); + }); + + return matchesRoute; +} diff --git a/x-pack/plugins/apm/public/components/shared/links/apm/transaction_detail_link.tsx b/x-pack/plugins/apm/public/components/shared/links/apm/transaction_detail_link.tsx index af299c6095e59..b11ec23586caf 100644 --- a/x-pack/plugins/apm/public/components/shared/links/apm/transaction_detail_link.tsx +++ b/x-pack/plugins/apm/public/components/shared/links/apm/transaction_detail_link.tsx @@ -14,10 +14,6 @@ import { useLegacyUrlParams } from '../../../../context/url_params_context/use_u import { pickKeys } from '../../../../../common/utils/pick_keys'; import { APMQueryParams } from '../url_helpers'; import { useApmPluginContext } from '../../../../context/apm_plugin/use_apm_plugin_context'; -import { - TimeRangeComparisonEnum, - TimeRangeComparisonType, -} from '../../../../../common/runtime_types/comparison_type_rt'; import { getComparisonEnabled } from '../../time_comparison/get_comparison_enabled'; interface Props extends APMLinkExtendProps { @@ -29,7 +25,7 @@ interface Props extends APMLinkExtendProps { latencyAggregationType?: string; environment?: string; comparisonEnabled?: boolean; - comparisonType?: TimeRangeComparisonType; + offset?: string; } const persistedFilters: Array = [ @@ -46,7 +42,7 @@ export function TransactionDetailLink({ latencyAggregationType, environment, comparisonEnabled, - comparisonType = TimeRangeComparisonEnum.DayBefore, + offset = '1d', ...rest }: Props) { const { urlParams } = useLegacyUrlParams(); @@ -65,7 +61,7 @@ export function TransactionDetailLink({ transactionName, transactionType, comparisonEnabled: defaultComparisonEnabled, - comparisonType, + offset, ...pickKeys(urlParams as APMQueryParams, ...persistedFilters), ...pickBy({ latencyAggregationType, environment }, identity), }, diff --git a/x-pack/plugins/apm/public/components/shared/links/url_helpers.ts b/x-pack/plugins/apm/public/components/shared/links/url_helpers.ts index ae42abaf4ac7b..093a953dffe94 100644 --- a/x-pack/plugins/apm/public/components/shared/links/url_helpers.ts +++ b/x-pack/plugins/apm/public/components/shared/links/url_helpers.ts @@ -88,7 +88,7 @@ export interface APMQueryParams { percentile?: 50 | 75 | 90 | 95 | 99; latencyAggregationType?: string; comparisonEnabled?: boolean; - comparisonType?: string; + offset?: string; transactionResult?: string; host?: string; containerId?: string; diff --git a/x-pack/plugins/apm/public/components/shared/redirect_with_default_date_range/index.tsx b/x-pack/plugins/apm/public/components/shared/redirect_with_default_date_range/index.tsx index f0056ca6e42e1..dd8393934d561 100644 --- a/x-pack/plugins/apm/public/components/shared/redirect_with_default_date_range/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/redirect_with_default_date_range/index.tsx @@ -8,6 +8,7 @@ import { ReactElement } from 'react'; import { useLocation } from 'react-router-dom'; import { useApmRouter } from '../../../hooks/use_apm_router'; import { useDateRangeRedirect } from '../../../hooks/use_date_range_redirect'; +import { isRouteWithTimeRange } from '../is_route_with_time_range'; // This is a top-level component that blocks rendering of the routes // if there is no valid date range, and redirects to one if needed. @@ -27,23 +28,9 @@ export function RedirectWithDefaultDateRange({ const apmRouter = useApmRouter(); const location = useLocation(); - const matchingRoutes = apmRouter.getRoutesToMatch(location.pathname); + const matchesRoute = isRouteWithTimeRange({ apmRouter, location }); - if ( - !isDateRangeSet && - matchingRoutes.some((route) => { - return ( - route.path === '/services' || - route.path === '/traces' || - route.path === '/service-map' || - route.path === '/backends' || - route.path === '/services/{serviceName}' || - route.path === '/service-groups' || - location.pathname === '/' || - location.pathname === '' - ); - }) - ) { + if (!isDateRangeSet && matchesRoute) { redirect(); return null; } diff --git a/x-pack/plugins/apm/public/components/shared/redirect_with_offset/index.tsx b/x-pack/plugins/apm/public/components/shared/redirect_with_offset/index.tsx new file mode 100644 index 0000000000000..b8f505bf3e3c0 --- /dev/null +++ b/x-pack/plugins/apm/public/components/shared/redirect_with_offset/index.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { useLocation, Redirect } from 'react-router-dom'; +import qs from 'query-string'; +import React from 'react'; +import { useApmRouter } from '../../../hooks/use_apm_router'; +import { isRouteWithTimeRange } from '../is_route_with_time_range'; +import { + TimeRangeComparisonEnum, + dayAndWeekBeforeToOffset, +} from '../../../components/shared/time_comparison/get_comparison_options'; +import { useApmPluginContext } from '../../../context/apm_plugin/use_apm_plugin_context'; +import { getComparisonEnabled } from '../../../components/shared/time_comparison/get_comparison_enabled'; +import { toBoolean } from '../../../context/url_params_context/helpers'; + +export function RedirectWithOffset({ + children, +}: { + children: React.ReactElement; +}) { + const { core } = useApmPluginContext(); + const location = useLocation(); + const apmRouter = useApmRouter(); + const matchesRoute = isRouteWithTimeRange({ apmRouter, location }); + const query = qs.parse(location.search); + + // Redirect when 'comparisonType' is set as we now use offset instead + // or when 'comparisonEnabled' is not set as it's now required + if ( + matchesRoute && + ('comparisonType' in query || !('comparisonEnabled' in query)) + ) { + const { + comparisonType, + comparisonEnabled: urlComparisonEnabled, + ...queryRest + } = query; + + const comparisonEnabled = getComparisonEnabled({ + core, + urlComparisonEnabled: urlComparisonEnabled + ? toBoolean(urlComparisonEnabled as string) + : undefined, + }).toString(); + + const comparisonTypeEnumValue = comparisonType as + | TimeRangeComparisonEnum.DayBefore + | TimeRangeComparisonEnum.WeekBefore; + + const dayOrWeekOffset = dayAndWeekBeforeToOffset[comparisonTypeEnumValue]; + + return ( + + ); + } + + return children; +} diff --git a/x-pack/plugins/apm/public/components/shared/service_link.stories.tsx b/x-pack/plugins/apm/public/components/shared/service_link.stories.tsx index 55320bfd94bd3..ea21313b7c4cd 100644 --- a/x-pack/plugins/apm/public/components/shared/service_link.stories.tsx +++ b/x-pack/plugins/apm/public/components/shared/service_link.stories.tsx @@ -37,6 +37,7 @@ Example.args = { rangeFrom: 'now-15m', rangeTo: 'now', serviceGroup: '', + comparisonEnabled: false, }, serviceName: 'opbeans-java', }; diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/comparison.test.ts b/x-pack/plugins/apm/public/components/shared/time_comparison/comparison.test.ts index fdb812f57e490..f92bcc8a2d096 100644 --- a/x-pack/plugins/apm/public/components/shared/time_comparison/comparison.test.ts +++ b/x-pack/plugins/apm/public/components/shared/time_comparison/comparison.test.ts @@ -5,8 +5,6 @@ * 2.0. */ -import { TimeRangeComparisonEnum } from '../../../../common/runtime_types/comparison_type_rt'; -import { getTimeRangeComparison } from './get_time_range_comparison'; import { getDateRange } from '../../../context/url_params_context/helpers'; import { getComparisonOptions } from './get_comparison_options'; import moment from 'moment-timezone'; @@ -19,24 +17,7 @@ function getExpectedTimesAndComparisons({ rangeTo: string; }) { const { start, end } = getDateRange({ rangeFrom, rangeTo }); - const comparisonOptions = getComparisonOptions({ start, end }); - - const comparisons = comparisonOptions.map(({ value, text }) => { - const { comparisonStart, comparisonEnd, offset } = getTimeRangeComparison({ - comparisonEnabled: true, - comparisonType: value, - start, - end, - }); - - return { - value, - text, - comparisonStart, - comparisonEnd, - offset, - }; - }); + const comparisons = getComparisonOptions({ start, end }); return { start, @@ -79,18 +60,12 @@ describe('Comparison test suite', () => { it('should return comparison by day and week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.DayBefore, text: 'Day before', - comparisonStart: '2022-01-14T18:00:00.000Z', - comparisonEnd: '2022-01-15T18:30:00.000Z', - offset: '1d', + value: '1d', }, { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-08T18:00:00.000Z', - comparisonEnd: '2022-01-09T18:30:00.000Z', - offset: '1w', + value: '1w', }, ]); }); @@ -114,11 +89,8 @@ describe('Comparison test suite', () => { it('should only return comparison by week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-08T18:00:00.000Z', - comparisonEnd: '2022-01-09T19:00:00.000Z', - offset: '1w', + value: '1w', }, ]); }); @@ -142,11 +114,8 @@ describe('Comparison test suite', () => { it('should only return comparison by week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-08T18:00:00.000Z', - comparisonEnd: '2022-01-15T21:00:00.000Z', - offset: '1w', + value: '1w', }, ]); }); @@ -170,11 +139,8 @@ describe('Comparison test suite', () => { it('should only return comparison by period and format text as DD/MM HH:mm when range years are the same', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.PeriodBefore, text: '07/01 18:00 - 15/01 18:00', - comparisonStart: '2022-01-07T18:00:00.000Z', - comparisonEnd: '2022-01-15T18:00:00.000Z', - offset: '691200000ms', + value: '691200000ms', }, ]); }); @@ -182,7 +148,7 @@ describe('Comparison test suite', () => { it('should have the same offset for start / end and comparisonStart / comparisonEnd', () => { const { start, end, comparisons } = expectation; const diffInMs = moment(end).diff(moment(start)); - expect(`${diffInMs}ms`).toBe(comparisons[0].offset); + expect(`${diffInMs}ms`).toBe(comparisons[0].value); }); }); @@ -204,11 +170,8 @@ describe('Comparison test suite', () => { it('should only return comparison by period and format text as DD/MM HH:mm when range years are the same', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.PeriodBefore, text: '06/01 06:00 - 15/01 00:00', - comparisonStart: '2022-01-06T06:00:00.000Z', - comparisonEnd: '2022-01-15T00:00:00.000Z', - offset: '756000000ms', + value: '756000000ms', }, ]); }); @@ -216,7 +179,7 @@ describe('Comparison test suite', () => { it('should have the same offset for start / end and comparisonStart / comparisonEnd', () => { const { start, end, comparisons } = expectation; const diffInMs = moment(end).diff(moment(start)); - expect(`${diffInMs}ms`).toBe(comparisons[0].offset); + expect(`${diffInMs}ms`).toBe(comparisons[0].value); }); }); @@ -238,18 +201,12 @@ describe('Comparison test suite', () => { it('should return comparison by day and week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.DayBefore, text: 'Day before', - comparisonStart: '2022-01-13T00:00:00.000Z', - comparisonEnd: '2022-01-13T23:59:59.999Z', - offset: '1d', + value: '1d', }, { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-07T00:00:00.000Z', - comparisonEnd: '2022-01-07T23:59:59.999Z', - offset: '1w', + value: '1w', }, ]); }); @@ -273,11 +230,8 @@ describe('Comparison test suite', () => { it('should only return comparison by week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-02T00:00:00.000Z', - comparisonEnd: '2022-01-08T23:59:59.999Z', - offset: '1w', + value: '1w', }, ]); }); @@ -301,18 +255,12 @@ describe('Comparison test suite', () => { it('should return comparison by day and week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.DayBefore, text: 'Day before', - comparisonStart: '2022-01-12T18:30:15.500Z', - comparisonEnd: '2022-01-13T18:30:15.500Z', - offset: '1d', + value: '1d', }, { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-06T18:30:15.500Z', - comparisonEnd: '2022-01-07T18:30:15.500Z', - offset: '1w', + value: '1w', }, ]); }); @@ -336,18 +284,12 @@ describe('Comparison test suite', () => { it('should return comparison by day and week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.DayBefore, text: 'Day before', - comparisonStart: '2022-01-12T18:00:00.000Z', - comparisonEnd: '2022-01-13T18:30:15.500Z', - offset: '1d', + value: '1d', }, { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2022-01-06T18:00:00.000Z', - comparisonEnd: '2022-01-07T18:30:15.500Z', - offset: '1w', + value: '1w', }, ]); }); @@ -371,11 +313,8 @@ describe('Comparison test suite', () => { it('should only return comparison by week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2021-12-31T18:30:15.500Z', - comparisonEnd: '2022-01-07T18:30:15.500Z', - offset: '1w', + value: '1w', }, ]); }); @@ -399,11 +338,8 @@ describe('Comparison test suite', () => { it('should only return comparison by week', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.WeekBefore, text: 'Week before', - comparisonStart: '2021-12-31T00:00:00.000Z', - comparisonEnd: '2022-01-07T18:30:15.500Z', - offset: '1w', + value: '1w', }, ]); }); @@ -427,11 +363,8 @@ describe('Comparison test suite', () => { it('should only return comparison by period and format text as DD/MM/YY HH:mm when range years are different', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.PeriodBefore, text: '15/11/21 18:30 - 15/12/21 18:30', - comparisonStart: '2021-11-15T18:30:15.500Z', - comparisonEnd: '2021-12-15T18:30:15.500Z', - offset: '2592000000ms', + value: '2592000000ms', }, ]); }); @@ -439,7 +372,7 @@ describe('Comparison test suite', () => { it('should have the same offset for start / end and comparisonStart / comparisonEnd', () => { const { start, end, comparisons } = expectation; const diffInMs = moment(end).diff(moment(start)); - expect(`${diffInMs}ms`).toBe(comparisons[0].offset); + expect(`${diffInMs}ms`).toBe(comparisons[0].value); }); }); @@ -461,11 +394,8 @@ describe('Comparison test suite', () => { it('should only return comparison by period and format text as DD/MM/YY HH:mm when range years are different', () => { expect(expectation.comparisons).toEqual([ { - value: TimeRangeComparisonEnum.PeriodBefore, text: '14/11/21 05:29 - 15/12/21 00:00', - comparisonStart: '2021-11-14T05:29:44.500Z', - comparisonEnd: '2021-12-15T00:00:00.000Z', - offset: '2658615500ms', + value: '2658615500ms', }, ]); }); @@ -473,7 +403,7 @@ describe('Comparison test suite', () => { it('should have the same offset for start / end and comparisonStart / comparisonEnd', () => { const { start, end, comparisons } = expectation; const diffInMs = moment(end).diff(moment(start)); - expect(`${diffInMs}ms`).toBe(comparisons[0].offset); + expect(`${diffInMs}ms`).toBe(comparisons[0].value); }); }); }); diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_chart_theme.ts b/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_chart_theme.ts new file mode 100644 index 0000000000000..91e8461f6d39c --- /dev/null +++ b/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_chart_theme.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { PartialTheme } from '@elastic/charts'; + +export function getComparisonChartTheme(): PartialTheme { + return { + areaSeriesStyle: { + area: { + visible: true, + opacity: 0.5, + }, + line: { + strokeWidth: 1, + visible: true, + }, + point: { + visible: false, + }, + }, + }; +} diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_options.ts b/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_options.ts index 9400f668a18f0..741b955d16931 100644 --- a/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_options.ts +++ b/x-pack/plugins/apm/public/components/shared/time_comparison/get_comparison_options.ts @@ -7,54 +7,56 @@ import moment from 'moment'; import { i18n } from '@kbn/i18n'; -import { TimeRangeComparisonEnum } from '../../../../common/runtime_types/comparison_type_rt'; -import { getTimeRangeComparison } from './get_time_range_comparison'; +import { getOffsetInMs } from '../../../../common/utils/get_offset_in_ms'; -const eightDaysInHours = moment.duration(8, 'd').asHours(); - -function getDateFormat({ - previousPeriodStart, - currentPeriodEnd, -}: { - previousPeriodStart?: string; - currentPeriodEnd?: string; -}) { - const momentPreviousPeriodStart = moment(previousPeriodStart); - const momentCurrentPeriodEnd = moment(currentPeriodEnd); - const isDifferentYears = - momentPreviousPeriodStart.get('year') !== - momentCurrentPeriodEnd.get('year'); - return isDifferentYears ? 'DD/MM/YY HH:mm' : 'DD/MM HH:mm'; +export enum TimeRangeComparisonEnum { + WeekBefore = 'week', + DayBefore = 'day', + PeriodBefore = 'period', } +export const dayAndWeekBeforeToOffset = { + [TimeRangeComparisonEnum.DayBefore]: '1d', + [TimeRangeComparisonEnum.WeekBefore]: '1w', +} as const; + +const twentyFiveHoursInMs = moment.duration(25, 'h').asMilliseconds(); +const eightDaysInMs = moment.duration(8, 'd').asMilliseconds(); + function formatDate({ - dateFormat, + currentPeriodEnd, previousPeriodStart, previousPeriodEnd, }: { - dateFormat: string; - previousPeriodStart?: string; - previousPeriodEnd?: string; + currentPeriodEnd: moment.Moment; + previousPeriodStart: moment.Moment; + previousPeriodEnd: moment.Moment; }) { - const momentStart = moment(previousPeriodStart); - const momentEnd = moment(previousPeriodEnd); - return `${momentStart.format(dateFormat)} - ${momentEnd.format(dateFormat)}`; + const isDifferentYears = + previousPeriodStart.get('year') !== currentPeriodEnd.get('year'); + const dateFormat = isDifferentYears ? 'DD/MM/YY HH:mm' : 'DD/MM HH:mm'; + + return `${previousPeriodStart.format( + dateFormat + )} - ${previousPeriodEnd.format(dateFormat)}`; } function getSelectOptions({ comparisonTypes, start, end, + msDiff, }: { comparisonTypes: TimeRangeComparisonEnum[]; - start?: string; - end?: string; + start: moment.Moment; + end: moment.Moment; + msDiff: number; }) { return comparisonTypes.map((value) => { switch (value) { case TimeRangeComparisonEnum.DayBefore: { return { - value, + value: dayAndWeekBeforeToOffset[TimeRangeComparisonEnum.DayBefore], text: i18n.translate('xpack.apm.timeComparison.select.dayBefore', { defaultMessage: 'Day before', }), @@ -62,31 +64,27 @@ function getSelectOptions({ } case TimeRangeComparisonEnum.WeekBefore: { return { - value, + value: dayAndWeekBeforeToOffset[TimeRangeComparisonEnum.WeekBefore], text: i18n.translate('xpack.apm.timeComparison.select.weekBefore', { defaultMessage: 'Week before', }), }; } case TimeRangeComparisonEnum.PeriodBefore: { - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - comparisonType: TimeRangeComparisonEnum.PeriodBefore, - start, - end, - comparisonEnabled: true, - }); + const offset = `${msDiff}ms`; - const dateFormat = getDateFormat({ - previousPeriodStart: comparisonStart, - currentPeriodEnd: end, + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start: start.valueOf(), + end: end.valueOf(), + offset, }); return { - value, + value: offset, text: formatDate({ - dateFormat, - previousPeriodStart: comparisonStart, - previousPeriodEnd: comparisonEnd, + currentPeriodEnd: end, + previousPeriodStart: moment(startWithOffset), + previousPeriodEnd: moment(endWithOffset), }), }; } @@ -103,18 +101,18 @@ export function getComparisonOptions({ }) { const momentStart = moment(start); const momentEnd = moment(end); - const hourDiff = momentEnd.diff(momentStart, 'h', true); + const msDiff = momentEnd.diff(momentStart, 'ms', true); let comparisonTypes: TimeRangeComparisonEnum[]; - if (hourDiff < 25) { + if (msDiff < twentyFiveHoursInMs) { // Less than 25 hours. This is because relative times may be rounded when // asking for a day, which can result in a duration > 24h. (e.g. rangeFrom: 'now-24h/h, rangeTo: 'now') comparisonTypes = [ TimeRangeComparisonEnum.DayBefore, TimeRangeComparisonEnum.WeekBefore, ]; - } else if (hourDiff < eightDaysInHours) { + } else if (msDiff < eightDaysInMs) { // Less than 8 days. This is because relative times may be rounded when // asking for a week, which can result in a duration > 7d. (e.g. rangeFrom: 'now-7d/d, rangeTo: 'now') comparisonTypes = [TimeRangeComparisonEnum.WeekBefore]; @@ -122,5 +120,10 @@ export function getComparisonOptions({ comparisonTypes = [TimeRangeComparisonEnum.PeriodBefore]; } - return getSelectOptions({ comparisonTypes, start, end }); + return getSelectOptions({ + comparisonTypes, + start: momentStart, + end: momentEnd, + msDiff, + }); } diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.test.ts b/x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.test.ts deleted file mode 100644 index c6619ad6d35f3..0000000000000 --- a/x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.test.ts +++ /dev/null @@ -1,44 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import { TimeRangeComparisonEnum } from '../../../../common/runtime_types/comparison_type_rt'; -import { getTimeRangeComparison } from './get_time_range_comparison'; - -describe('getTimeRangeComparison', () => { - describe('return empty object', () => { - it('when comparison is disabled', () => { - const end = '2021-01-28T15:00:00.000Z'; - const result = getTimeRangeComparison({ - start: undefined, - end, - comparisonType: TimeRangeComparisonEnum.DayBefore, - comparisonEnabled: false, - }); - expect(result).toEqual({}); - }); - it('when start is not defined', () => { - const end = '2021-01-28T15:00:00.000Z'; - const result = getTimeRangeComparison({ - start: undefined, - end, - comparisonType: TimeRangeComparisonEnum.DayBefore, - comparisonEnabled: true, - }); - expect(result).toEqual({}); - }); - - it('when end is not defined', () => { - const start = '2021-01-28T14:45:00.000Z'; - const result = getTimeRangeComparison({ - start, - end: undefined, - comparisonType: TimeRangeComparisonEnum.DayBefore, - comparisonEnabled: true, - }); - expect(result).toEqual({}); - }); - }); -}); diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.ts b/x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.ts deleted file mode 100644 index 6a1f7b1978ca0..0000000000000 --- a/x-pack/plugins/apm/public/components/shared/time_comparison/get_time_range_comparison.ts +++ /dev/null @@ -1,78 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { PartialTheme } from '@elastic/charts'; -import moment from 'moment'; -import { - TimeRangeComparisonType, - TimeRangeComparisonEnum, -} from '../../../../common/runtime_types/comparison_type_rt'; - -export function getComparisonChartTheme(): PartialTheme { - return { - areaSeriesStyle: { - area: { - visible: true, - opacity: 0.5, - }, - line: { - strokeWidth: 1, - visible: true, - }, - point: { - visible: false, - }, - }, - }; -} - -const oneDayInMilliseconds = moment.duration(1, 'day').asMilliseconds(); -const oneWeekInMilliseconds = moment.duration(1, 'week').asMilliseconds(); - -export function getTimeRangeComparison({ - comparisonEnabled, - comparisonType, - start, - end, -}: { - comparisonEnabled?: boolean; - comparisonType?: TimeRangeComparisonType; - start?: string; - end?: string; -}) { - if (!comparisonEnabled || !comparisonType || !start || !end) { - return {}; - } - const startMoment = moment(start); - const endMoment = moment(end); - - let diff: number; - let offset: string; - - switch (comparisonType) { - case TimeRangeComparisonEnum.DayBefore: - diff = oneDayInMilliseconds; - offset = '1d'; - break; - case TimeRangeComparisonEnum.WeekBefore: - diff = oneWeekInMilliseconds; - offset = '1w'; - break; - case TimeRangeComparisonEnum.PeriodBefore: - diff = endMoment.diff(startMoment); - offset = `${diff}ms`; - break; - default: - throw new Error('Unknown comparisonType'); - } - - return { - comparisonStart: startMoment.subtract(diff, 'ms').toISOString(), - comparisonEnd: endMoment.subtract(diff, 'ms').toISOString(), - offset, - }; -} diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/index.test.tsx b/x-pack/plugins/apm/public/components/shared/time_comparison/index.test.tsx index 83d2962316aa2..93d24208a0681 100644 --- a/x-pack/plugins/apm/public/components/shared/time_comparison/index.test.tsx +++ b/x-pack/plugins/apm/public/components/shared/time_comparison/index.test.tsx @@ -18,22 +18,17 @@ import * as urlHelpers from '../../shared/links/url_helpers'; import moment from 'moment'; import { MockApmPluginContextWrapper } from '../../../context/apm_plugin/mock_apm_plugin_context'; import { ENVIRONMENT_ALL } from '../../../../common/environment_filter_values'; -import { - TimeRangeComparisonType, - TimeRangeComparisonEnum, -} from '../../../../common/runtime_types/comparison_type_rt'; -import { MockUrlParamsContextProvider } from '../../../context/url_params_context/mock_url_params_context_provider'; function getWrapper({ rangeFrom, rangeTo, - comparisonType, + offset, comparisonEnabled, environment = ENVIRONMENT_ALL.value, }: { rangeFrom: string; rangeTo: string; - comparisonType?: TimeRangeComparisonType; + offset?: string; comparisonEnabled?: boolean; environment?: string; }) { @@ -41,16 +36,12 @@ function getWrapper({ return ( - - - {children} - - + + {children} + ); }; @@ -76,8 +67,7 @@ describe('TimeComparison component', () => { render(, { wrapper: Wrapper }); expect(spy).toHaveBeenCalledWith(expect.anything(), { query: { - comparisonEnabled: 'true', - comparisonType: TimeRangeComparisonEnum.DayBefore, + offset: '1d', }, }); }); @@ -87,7 +77,7 @@ describe('TimeComparison component', () => { rangeFrom: '2021-06-04T16:17:02.335Z', rangeTo: '2021-06-04T16:32:02.335Z', comparisonEnabled: true, - comparisonType: TimeRangeComparisonEnum.DayBefore, + offset: '1d', }); const component = render(, { wrapper: Wrapper }); expectTextsInDocument(component, ['Day before', 'Week before']); @@ -102,7 +92,7 @@ describe('TimeComparison component', () => { rangeFrom: '2021-06-03T16:31:35.748Z', rangeTo: '2021-06-04T16:31:35.748Z', comparisonEnabled: true, - comparisonType: TimeRangeComparisonEnum.DayBefore, + offset: '1d', }); const component = render(, { wrapper: Wrapper }); expectTextsInDocument(component, ['Day before', 'Week before']); @@ -119,7 +109,7 @@ describe('TimeComparison component', () => { rangeFrom: '2021-06-02T12:32:00.000Z', rangeTo: '2021-06-03T13:32:09.079Z', comparisonEnabled: true, - comparisonType: TimeRangeComparisonEnum.WeekBefore, + offset: '1w', }); const component = render(, { wrapper: Wrapper, @@ -138,8 +128,7 @@ describe('TimeComparison component', () => { }); expect(spy).toHaveBeenCalledWith(expect.anything(), { query: { - comparisonEnabled: 'true', - comparisonType: TimeRangeComparisonEnum.WeekBefore, + offset: '1w', }, }); }); @@ -149,7 +138,7 @@ describe('TimeComparison component', () => { rangeFrom: '2021-06-02T12:32:00.000Z', rangeTo: '2021-06-03T13:32:09.079Z', comparisonEnabled: true, - comparisonType: TimeRangeComparisonEnum.WeekBefore, + offset: '1w', }); const component = render(, { wrapper: Wrapper, @@ -169,7 +158,7 @@ describe('TimeComparison component', () => { rangeFrom: '2021-05-27T16:32:46.747Z', rangeTo: '2021-06-04T16:32:46.747Z', comparisonEnabled: true, - comparisonType: TimeRangeComparisonEnum.PeriodBefore, + offset: '691200000ms', }); const component = render(, { wrapper: Wrapper, @@ -187,7 +176,7 @@ describe('TimeComparison component', () => { rangeFrom: '2020-05-27T16:32:46.747Z', rangeTo: '2021-06-04T16:32:46.747Z', comparisonEnabled: true, - comparisonType: TimeRangeComparisonEnum.PeriodBefore, + offset: '32227200000ms', }); const component = render(, { wrapper: Wrapper, diff --git a/x-pack/plugins/apm/public/components/shared/time_comparison/index.tsx b/x-pack/plugins/apm/public/components/shared/time_comparison/index.tsx index cb0bc870354c4..d587d363d921d 100644 --- a/x-pack/plugins/apm/public/components/shared/time_comparison/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/time_comparison/index.tsx @@ -11,13 +11,10 @@ import React from 'react'; import { useHistory } from 'react-router-dom'; import { euiStyled } from '../../../../../../../src/plugins/kibana_react/common'; import { useUiTracker } from '../../../../../observability/public'; -import { useLegacyUrlParams } from '../../../context/url_params_context/use_url_params'; -import { useApmPluginContext } from '../../../context/apm_plugin/use_apm_plugin_context'; import { useAnyOfApmParams } from '../../../hooks/use_apm_params'; import { useBreakpoints } from '../../../hooks/use_breakpoints'; import { useTimeRange } from '../../../hooks/use_time_range'; import * as urlHelpers from '../../shared/links/url_helpers'; -import { getComparisonEnabled } from './get_comparison_enabled'; import { getComparisonOptions } from './get_comparison_options'; const PrependContainer = euiStyled.div` @@ -30,49 +27,25 @@ const PrependContainer = euiStyled.div` `; export function TimeComparison() { - const { core } = useApmPluginContext(); const trackApmEvent = useUiTracker({ app: 'apm' }); const history = useHistory(); const { isSmall } = useBreakpoints(); const { - query: { rangeFrom, rangeTo }, + query: { rangeFrom, rangeTo, comparisonEnabled, offset }, } = useAnyOfApmParams('/services', '/backends/*', '/services/{serviceName}'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { - urlParams: { comparisonEnabled, comparisonType }, - } = useLegacyUrlParams(); - const comparisonOptions = getComparisonOptions({ start, end }); - // Sets default values - if (comparisonEnabled === undefined || comparisonType === undefined) { - urlHelpers.replace(history, { - query: { - comparisonEnabled: - getComparisonEnabled({ - core, - urlComparisonEnabled: comparisonEnabled, - }) === false - ? 'false' - : 'true', - comparisonType: comparisonType - ? comparisonType - : comparisonOptions[0].value, - }, - }); - return null; - } - const isSelectedComparisonTypeAvailable = comparisonOptions.some( - ({ value }) => value === comparisonType + ({ value }) => value === offset ); // Replaces type when current one is no longer available in the select options if (comparisonOptions.length !== 0 && !isSelectedComparisonTypeAvailable) { urlHelpers.replace(history, { - query: { comparisonType: comparisonOptions[0].value }, + query: { offset: comparisonOptions[0].value }, }); return null; } @@ -83,7 +56,7 @@ export function TimeComparison() { data-test-subj="comparisonSelect" disabled={!comparisonEnabled} options={comparisonOptions} - value={comparisonType} + value={offset} prepend={ > { return [ { @@ -79,7 +78,7 @@ export function getColumns({ transactionType={type} latencyAggregationType={latencyAggregationType} comparisonEnabled={comparisonEnabled} - comparisonType={comparisonType} + offset={offset} > {name} diff --git a/x-pack/plugins/apm/public/components/shared/transactions_table/index.tsx b/x-pack/plugins/apm/public/components/shared/transactions_table/index.tsx index 149e7350cc36c..5374439a32609 100644 --- a/x-pack/plugins/apm/public/components/shared/transactions_table/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/transactions_table/index.tsx @@ -23,7 +23,6 @@ import { APIReturnType } from '../../../services/rest/create_call_apm_api'; import { useApmServiceContext } from '../../../context/apm_service/use_apm_service_context'; import { FETCH_STATUS, useFetcher } from '../../../hooks/use_fetcher'; import { TransactionOverviewLink } from '../links/apm/transaction_overview_link'; -import { getTimeRangeComparison } from '../time_comparison/get_time_range_comparison'; import { OverviewTableContainer } from '../overview_table_container'; import { getColumns } from './get_columns'; import { ElasticDocsLink } from '../links/elastic_docs_link'; @@ -91,7 +90,7 @@ export function TransactionsTable({ const { query: { comparisonEnabled, - comparisonType, + offset, latencyAggregationType, page: urlPage = 0, pageSize: urlPageSize = numberOfTransactionsPerPage, @@ -124,13 +123,6 @@ export function TransactionsTable({ const { transactionType, serviceName } = useApmServiceContext(); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); - const { data = INITIAL_STATE, status } = useFetcher( (callApmApi) => { if (!start || !end || !latencyAggregationType || !transactionType) { @@ -183,8 +175,8 @@ export function TransactionsTable({ size, direction, field, - // not used, but needed to trigger an update when comparisonType is changed either manually by user or when time range is changed - comparisonType, + // not used, but needed to trigger an update when offset is changed either manually by user or when time range is changed + offset, // not used, but needed to trigger an update when comparison feature is disabled/enabled by user comparisonEnabled, ] @@ -229,8 +221,7 @@ export function TransactionsTable({ transactionNames: JSON.stringify( transactionGroups.map(({ name }) => name).sort() ), - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } @@ -252,7 +243,7 @@ export function TransactionsTable({ transactionGroupDetailedStatistics, comparisonEnabled, shouldShowSparkPlots, - comparisonType, + offset, }); const isLoading = status === FETCH_STATUS.LOADING; diff --git a/x-pack/plugins/apm/public/context/apm_plugin/mock_apm_plugin_context.tsx b/x-pack/plugins/apm/public/context/apm_plugin/mock_apm_plugin_context.tsx index fc3771dba499f..025338bb53517 100644 --- a/x-pack/plugins/apm/public/context/apm_plugin/mock_apm_plugin_context.tsx +++ b/x-pack/plugins/apm/public/context/apm_plugin/mock_apm_plugin_context.tsx @@ -19,6 +19,7 @@ import { UI_SETTINGS } from '../../../../../../src/plugins/data/common'; import { createCallApmApi } from '../../services/rest/create_call_apm_api'; import { apmRouter } from '../../components/routing/apm_route_config'; import { MlLocatorDefinition } from '../../../../ml/public'; +import { enableComparisonByDefault } from '../../../../observability/public'; const coreStart = coreMock.createStart({ basePath: '/basepath' }); @@ -52,6 +53,7 @@ const mockCore = merge({}, coreStart, { pause: false, value: 100000, }, + [enableComparisonByDefault]: true, }; return uiSettings[key]; }, diff --git a/x-pack/plugins/apm/public/context/url_params_context/resolve_url_params.ts b/x-pack/plugins/apm/public/context/url_params_context/resolve_url_params.ts index 5bb3a46c3aea4..3a2d1a709b376 100644 --- a/x-pack/plugins/apm/public/context/url_params_context/resolve_url_params.ts +++ b/x-pack/plugins/apm/public/context/url_params_context/resolve_url_params.ts @@ -6,7 +6,6 @@ */ import { Location } from 'history'; -import { TimeRangeComparisonType } from '../../../common/runtime_types/comparison_type_rt'; import { ENVIRONMENT_ALL } from '../../../common/environment_filter_values'; import { LatencyAggregationType } from '../../../common/latency_aggregation_types'; import { toQuery } from '../../components/shared/links/url_helpers'; @@ -49,7 +48,7 @@ export function resolveUrlParams(location: Location, state: TimeUrlParams) { percentile, latencyAggregationType = LatencyAggregationType.avg, comparisonEnabled, - comparisonType, + offset, } = query; return removeUndefinedProps({ @@ -83,6 +82,6 @@ export function resolveUrlParams(location: Location, state: TimeUrlParams) { comparisonEnabled: comparisonEnabled ? toBoolean(comparisonEnabled) : undefined, - comparisonType: comparisonType as TimeRangeComparisonType | undefined, + offset, }); } diff --git a/x-pack/plugins/apm/public/context/url_params_context/types.ts b/x-pack/plugins/apm/public/context/url_params_context/types.ts index 6c0f10f78e7c8..d5932ff73cafb 100644 --- a/x-pack/plugins/apm/public/context/url_params_context/types.ts +++ b/x-pack/plugins/apm/public/context/url_params_context/types.ts @@ -5,7 +5,6 @@ * 2.0. */ -import { TimeRangeComparisonType } from '../../../common/runtime_types/comparison_type_rt'; import { LatencyAggregationType } from '../../../common/latency_aggregation_types'; export interface UrlParams { @@ -34,7 +33,7 @@ export interface UrlParams { percentile?: number; latencyAggregationType?: LatencyAggregationType; comparisonEnabled?: boolean; - comparisonType?: TimeRangeComparisonType; + offset?: string; } export type UxUrlParams = UrlParams; diff --git a/x-pack/plugins/apm/public/hooks/use_error_group_distribution_fetcher.tsx b/x-pack/plugins/apm/public/hooks/use_error_group_distribution_fetcher.tsx index 62e2ab92c4fcc..3f983adf204dc 100644 --- a/x-pack/plugins/apm/public/hooks/use_error_group_distribution_fetcher.tsx +++ b/x-pack/plugins/apm/public/hooks/use_error_group_distribution_fetcher.tsx @@ -4,7 +4,6 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import { getTimeRangeComparison } from '../components/shared/time_comparison/get_time_range_comparison'; import { useApmParams } from './use_apm_params'; import { useFetcher } from './use_fetcher'; import { useTimeRange } from './use_time_range'; @@ -21,16 +20,11 @@ export function useErrorGroupDistributionFetcher({ environment: string; }) { const { - query: { rangeFrom, rangeTo, comparisonEnabled, comparisonType }, + query: { rangeFrom, rangeTo, offset, comparisonEnabled }, } = useApmParams('/services/{serviceName}/errors'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); + const { data, status } = useFetcher( (callApmApi) => { if (start && end) { @@ -44,8 +38,7 @@ export function useErrorGroupDistributionFetcher({ kuery, start, end, - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, groupId, }, }, @@ -59,9 +52,9 @@ export function useErrorGroupDistributionFetcher({ serviceName, start, end, - comparisonStart, - comparisonEnd, + offset, groupId, + comparisonEnabled, ] ); diff --git a/x-pack/plugins/apm/public/hooks/use_transaction_latency_chart_fetcher.ts b/x-pack/plugins/apm/public/hooks/use_transaction_latency_chart_fetcher.ts index 8dbc1f3a47505..62f21b77f4a15 100644 --- a/x-pack/plugins/apm/public/hooks/use_transaction_latency_chart_fetcher.ts +++ b/x-pack/plugins/apm/public/hooks/use_transaction_latency_chart_fetcher.ts @@ -10,7 +10,6 @@ import { useFetcher } from './use_fetcher'; import { useLegacyUrlParams } from '../context/url_params_context/use_url_params'; import { useApmServiceContext } from '../context/apm_service/use_apm_service_context'; import { getLatencyChartSelector } from '../selectors/latency_chart_selectors'; -import { getTimeRangeComparison } from '../components/shared/time_comparison/get_time_range_comparison'; import { useTimeRange } from './use_time_range'; import { useApmParams } from './use_apm_params'; @@ -27,17 +26,11 @@ export function useTransactionLatencyChartsFetcher({ } = useLegacyUrlParams(); const { - query: { rangeFrom, rangeTo, comparisonType, comparisonEnabled }, + query: { rangeFrom, rangeTo, offset, comparisonEnabled }, } = useApmParams('/services/{serviceName}'); const { start, end } = useTimeRange({ rangeFrom, rangeTo }); - const { comparisonStart, comparisonEnd } = getTimeRangeComparison({ - start, - end, - comparisonType, - comparisonEnabled, - }); const { data, error, status } = useFetcher( (callApmApi) => { if ( @@ -60,8 +53,7 @@ export function useTransactionLatencyChartsFetcher({ transactionType, transactionName, latencyAggregationType, - comparisonStart, - comparisonEnd, + offset: comparisonEnabled ? offset : undefined, }, }, } @@ -77,8 +69,8 @@ export function useTransactionLatencyChartsFetcher({ transactionName, transactionType, latencyAggregationType, - comparisonStart, - comparisonEnd, + offset, + comparisonEnabled, ] ); diff --git a/x-pack/plugins/apm/server/lib/transaction_groups/get_coldstart_rate.ts b/x-pack/plugins/apm/server/lib/transaction_groups/get_coldstart_rate.ts index e7c9e111be7a5..2a47c4e441dec 100644 --- a/x-pack/plugins/apm/server/lib/transaction_groups/get_coldstart_rate.ts +++ b/x-pack/plugins/apm/server/lib/transaction_groups/get_coldstart_rate.ts @@ -27,6 +27,7 @@ import { getTransactionColdstartRateTimeSeries, } from '../helpers/transaction_coldstart_rate'; import { termQuery } from '../../../../observability/server'; +import { getOffsetInMs } from '../../../common/utils/get_offset_in_ms'; export async function getColdstartRate({ environment, @@ -38,6 +39,7 @@ export async function getColdstartRate({ searchAggregatedTransactions, start, end, + offset, }: { environment: string; kuery: string; @@ -48,19 +50,26 @@ export async function getColdstartRate({ searchAggregatedTransactions: boolean; start: number; end: number; + offset?: string; }): Promise<{ transactionColdstartRate: Coordinate[]; average: number | null; }> { const { apmEventClient } = setup; + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + const filter = [ ...termQuery(SERVICE_NAME, serviceName), { exists: { field: FAAS_COLDSTART } }, ...(transactionName ? termQuery(TRANSACTION_NAME, transactionName) : []), ...termQuery(TRANSACTION_TYPE, transactionType), ...getDocumentTypeFilterForTransactions(searchAggregatedTransactions), - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ]; @@ -80,12 +89,12 @@ export async function getColdstartRate({ date_histogram: { field: '@timestamp', fixed_interval: getBucketSizeForAggregatedTransactions({ - start, - end, + start: startWithOffset, + end: endWithOffset, searchAggregatedTransactions, }).intervalString, min_doc_count: 0, - extended_bounds: { min: start, max: end }, + extended_bounds: { min: startWithOffset, max: endWithOffset }, }, aggs: { coldstartStates, @@ -123,10 +132,9 @@ export async function getColdstartRatePeriods({ transactionName = '', setup, searchAggregatedTransactions, - comparisonStart, - comparisonEnd, start, end, + offset, }: { environment: string; kuery: string; @@ -135,10 +143,9 @@ export async function getColdstartRatePeriods({ transactionName?: string; setup: Setup; searchAggregatedTransactions: boolean; - comparisonStart?: number; - comparisonEnd?: number; start: number; end: number; + offset?: string; }) { const commonProps = { environment, @@ -152,14 +159,14 @@ export async function getColdstartRatePeriods({ const currentPeriodPromise = getColdstartRate({ ...commonProps, start, end }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getColdstartRate({ - ...commonProps, - start: comparisonStart, - end: comparisonEnd, - }) - : { transactionColdstartRate: [], average: null }; + const previousPeriodPromise = offset + ? getColdstartRate({ + ...commonProps, + start, + end, + offset, + }) + : { transactionColdstartRate: [], average: null }; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, diff --git a/x-pack/plugins/apm/server/lib/transaction_groups/get_failed_transaction_rate.ts b/x-pack/plugins/apm/server/lib/transaction_groups/get_failed_transaction_rate.ts index e3b5c995d0563..06c0419f5999e 100644 --- a/x-pack/plugins/apm/server/lib/transaction_groups/get_failed_transaction_rate.ts +++ b/x-pack/plugins/apm/server/lib/transaction_groups/get_failed_transaction_rate.ts @@ -30,6 +30,7 @@ import { getOutcomeAggregation, getFailedTransactionRateTimeSeries, } from '../helpers/transaction_error_rate'; +import { getOffsetInMs } from '../../../common/utils/get_offset_in_ms'; export async function getFailedTransactionRate({ environment, @@ -42,6 +43,7 @@ export async function getFailedTransactionRate({ start, end, numBuckets, + offset, }: { environment: string; kuery: string; @@ -53,12 +55,19 @@ export async function getFailedTransactionRate({ start: number; end: number; numBuckets?: number; + offset?: string; }): Promise<{ timeseries: Coordinate[]; average: number | null; }> { const { apmEventClient } = setup; + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + const filter = [ { term: { [SERVICE_NAME]: serviceName } }, { @@ -69,7 +78,7 @@ export async function getFailedTransactionRate({ { terms: { [TRANSACTION_TYPE]: transactionTypes } }, ...termQuery(TRANSACTION_NAME, transactionName), ...getDocumentTypeFilterForTransactions(searchAggregatedTransactions), - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ]; @@ -89,13 +98,13 @@ export async function getFailedTransactionRate({ date_histogram: { field: '@timestamp', fixed_interval: getBucketSizeForAggregatedTransactions({ - start, - end, + start: startWithOffset, + end: endWithOffset, searchAggregatedTransactions, numBuckets, }).intervalString, min_doc_count: 0, - extended_bounds: { min: start, max: end }, + extended_bounds: { min: startWithOffset, max: endWithOffset }, }, aggs: { outcomes, diff --git a/x-pack/plugins/apm/server/routes/backends/route.ts b/x-pack/plugins/apm/server/routes/backends/route.ts index 730ad672a26b7..d8f619af58199 100644 --- a/x-pack/plugins/apm/server/routes/backends/route.ts +++ b/x-pack/plugins/apm/server/routes/backends/route.ts @@ -8,12 +8,7 @@ import * as t from 'io-ts'; import { toNumberRt } from '@kbn/io-ts-utils'; import { setupRequest } from '../../lib/helpers/setup_request'; -import { - environmentRt, - kueryRt, - offsetRt, - rangeRt, -} from '../default_api_types'; +import { environmentRt, kueryRt, rangeRt } from '../default_api_types'; import { createApmServerRoute } from '../apm_routes/create_apm_server_route'; import { getMetadataForBackend } from './get_metadata_for_backend'; import { getLatencyChartsForBackend } from './get_latency_charts_for_backend'; @@ -22,6 +17,7 @@ import { getUpstreamServicesForBackend } from './get_upstream_services_for_backe import { getThroughputChartsForBackend } from './get_throughput_charts_for_backend'; import { getErrorRateChartsForBackend } from './get_error_rate_charts_for_backend'; import { ConnectionStatsItemWithImpact } from './../../../common/connections'; +import { offsetRt } from '../../../common/offset_rt'; const topBackendsRoute = createApmServerRoute({ endpoint: 'GET /internal/apm/backends/top_backends', diff --git a/x-pack/plugins/apm/server/routes/default_api_types.ts b/x-pack/plugins/apm/server/routes/default_api_types.ts index 5622b12e1b099..e2b969f00edc5 100644 --- a/x-pack/plugins/apm/server/routes/default_api_types.ts +++ b/x-pack/plugins/apm/server/routes/default_api_types.ts @@ -15,11 +15,4 @@ export const rangeRt = t.type({ end: isoToEpochRt, }); -export const offsetRt = t.partial({ offset: t.string }); - -export const comparisonRangeRt = t.partial({ - comparisonStart: isoToEpochRt, - comparisonEnd: isoToEpochRt, -}); - export const kueryRt = t.type({ kuery: t.string }); diff --git a/x-pack/plugins/apm/server/routes/errors/distribution/get_distribution.ts b/x-pack/plugins/apm/server/routes/errors/distribution/get_distribution.ts index 9e7221b7cd939..b08113be712c2 100644 --- a/x-pack/plugins/apm/server/routes/errors/distribution/get_distribution.ts +++ b/x-pack/plugins/apm/server/routes/errors/distribution/get_distribution.ts @@ -9,6 +9,7 @@ import { offsetPreviousPeriodCoordinates } from '../../../../common/utils/offset import { Setup } from '../../../lib/helpers/setup_request'; import { BUCKET_TARGET_COUNT } from '../../transactions/constants'; import { getBuckets } from './get_buckets'; +import { getOffsetInMs } from '../../../../common/utils/get_offset_in_ms'; function getBucketSize({ start, end }: { start: number; end: number }) { return Math.floor((end - start) / BUCKET_TARGET_COUNT); @@ -22,8 +23,7 @@ export async function getErrorDistribution({ setup, start, end, - comparisonStart, - comparisonEnd, + offset, }: { environment: string; kuery: string; @@ -32,10 +32,19 @@ export async function getErrorDistribution({ setup: Setup; start: number; end: number; - comparisonStart?: number; - comparisonEnd?: number; + offset?: string; }) { - const bucketSize = getBucketSize({ start, end }); + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + + const bucketSize = getBucketSize({ + start: startWithOffset, + end: endWithOffset, + }); + const commonProps = { environment, kuery, @@ -46,17 +55,17 @@ export async function getErrorDistribution({ }; const currentPeriodPromise = getBuckets({ ...commonProps, - start, - end, + start: startWithOffset, + end: endWithOffset, }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getBuckets({ - ...commonProps, - start: comparisonStart, - end: comparisonEnd, - }) - : { buckets: [], bucketSize: null }; + + const previousPeriodPromise = offset + ? getBuckets({ + ...commonProps, + start: startWithOffset, + end: endWithOffset, + }) + : { buckets: [], bucketSize: null }; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, diff --git a/x-pack/plugins/apm/server/routes/errors/get_error_groups/get_error_group_detailed_statistics.ts b/x-pack/plugins/apm/server/routes/errors/get_error_groups/get_error_group_detailed_statistics.ts index 9eda5769e7fb8..3ffa084f63463 100644 --- a/x-pack/plugins/apm/server/routes/errors/get_error_groups/get_error_group_detailed_statistics.ts +++ b/x-pack/plugins/apm/server/routes/errors/get_error_groups/get_error_group_detailed_statistics.ts @@ -16,6 +16,7 @@ import { rangeQuery, kqlQuery } from '../../../../../observability/server'; import { environmentQuery } from '../../../../common/utils/environment_query'; import { getBucketSize } from '../../../lib/helpers/get_bucket_size'; import { Setup } from '../../../lib/helpers/setup_request'; +import { getOffsetInMs } from '../../../../common/utils/get_offset_in_ms'; export async function getErrorGroupDetailedStatistics({ kuery, @@ -26,6 +27,7 @@ export async function getErrorGroupDetailedStatistics({ environment, start, end, + offset, }: { kuery: string; serviceName: string; @@ -35,10 +37,21 @@ export async function getErrorGroupDetailedStatistics({ environment: string; start: number; end: number; + offset?: string; }): Promise> { const { apmEventClient } = setup; - const { intervalString } = getBucketSize({ start, end, numBuckets }); + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + + const { intervalString } = getBucketSize({ + start: startWithOffset, + end: endWithOffset, + numBuckets, + }); const timeseriesResponse = await apmEventClient.search( 'get_service_error_group_detailed_statistics', @@ -53,7 +66,7 @@ export async function getErrorGroupDetailedStatistics({ filter: [ { terms: { [ERROR_GROUP_ID]: groupIds } }, { term: { [SERVICE_NAME]: serviceName } }, - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ], @@ -72,8 +85,8 @@ export async function getErrorGroupDetailedStatistics({ fixed_interval: intervalString, min_doc_count: 0, extended_bounds: { - min: start, - max: end, + min: startWithOffset, + max: endWithOffset, }, }, }, @@ -109,10 +122,9 @@ export async function getErrorGroupPeriods({ numBuckets, groupIds, environment, - comparisonStart, - comparisonEnd, start, end, + offset, }: { kuery: string; serviceName: string; @@ -120,10 +132,9 @@ export async function getErrorGroupPeriods({ numBuckets: number; groupIds: string[]; environment: string; - comparisonStart?: number; - comparisonEnd?: number; start: number; end: number; + offset?: string; }) { const commonProps = { environment, @@ -140,14 +151,14 @@ export async function getErrorGroupPeriods({ end, }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getErrorGroupDetailedStatistics({ - ...commonProps, - start: comparisonStart, - end: comparisonEnd, - }) - : []; + const previousPeriodPromise = offset + ? getErrorGroupDetailedStatistics({ + ...commonProps, + start, + end, + offset, + }) + : []; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, diff --git a/x-pack/plugins/apm/server/routes/errors/route.ts b/x-pack/plugins/apm/server/routes/errors/route.ts index 52a72a70b7d67..73ad46adb3331 100644 --- a/x-pack/plugins/apm/server/routes/errors/route.ts +++ b/x-pack/plugins/apm/server/routes/errors/route.ts @@ -10,15 +10,11 @@ import * as t from 'io-ts'; import { createApmServerRoute } from '../apm_routes/create_apm_server_route'; import { getErrorDistribution } from './distribution/get_distribution'; import { setupRequest } from '../../lib/helpers/setup_request'; -import { - environmentRt, - kueryRt, - rangeRt, - comparisonRangeRt, -} from '../default_api_types'; +import { environmentRt, kueryRt, rangeRt } from '../default_api_types'; import { getErrorGroupMainStatistics } from './get_error_groups/get_error_group_main_statistics'; import { getErrorGroupPeriods } from './get_error_groups/get_error_group_detailed_statistics'; import { getErrorGroupSample } from './get_error_groups/get_error_group_sample'; +import { offsetRt } from '../../../common/offset_rt'; const errorsMainStatisticsRoute = createApmServerRoute({ endpoint: @@ -83,7 +79,7 @@ const errorsDetailedStatisticsRoute = createApmServerRoute({ environmentRt, kueryRt, rangeRt, - comparisonRangeRt, + offsetRt, t.type({ numBuckets: toNumberRt, groupIds: jsonRt.pipe(t.array(t.string)), @@ -111,16 +107,7 @@ const errorsDetailedStatisticsRoute = createApmServerRoute({ const { path: { serviceName }, - query: { - environment, - kuery, - numBuckets, - groupIds, - comparisonStart, - comparisonEnd, - start, - end, - }, + query: { environment, kuery, numBuckets, groupIds, start, end, offset }, } = params; return getErrorGroupPeriods({ @@ -130,10 +117,9 @@ const errorsDetailedStatisticsRoute = createApmServerRoute({ setup, numBuckets, groupIds, - comparisonStart, - comparisonEnd, start, end, + offset, }); }, }); @@ -187,7 +173,7 @@ const errorDistributionRoute = createApmServerRoute({ environmentRt, kueryRt, rangeRt, - comparisonRangeRt, + offsetRt, ]), }), options: { tags: ['access:apm'] }, @@ -204,15 +190,7 @@ const errorDistributionRoute = createApmServerRoute({ const setup = await setupRequest(resources); const { params } = resources; const { serviceName } = params.path; - const { - environment, - kuery, - groupId, - start, - end, - comparisonStart, - comparisonEnd, - } = params.query; + const { environment, kuery, groupId, start, end, offset } = params.query; return getErrorDistribution({ environment, kuery, @@ -221,8 +199,7 @@ const errorDistributionRoute = createApmServerRoute({ setup, start, end, - comparisonStart, - comparisonEnd, + offset, }); }, }); diff --git a/x-pack/plugins/apm/server/routes/service_map/route.ts b/x-pack/plugins/apm/server/routes/service_map/route.ts index b00a0da8e55bf..b357958d219a9 100644 --- a/x-pack/plugins/apm/server/routes/service_map/route.ts +++ b/x-pack/plugins/apm/server/routes/service_map/route.ts @@ -16,8 +16,9 @@ import { getServiceMap } from './get_service_map'; import { getServiceMapBackendNodeInfo } from './get_service_map_backend_node_info'; import { getServiceMapServiceNodeInfo } from './get_service_map_service_node_info'; import { createApmServerRoute } from '../apm_routes/create_apm_server_route'; -import { environmentRt, offsetRt, rangeRt } from '../default_api_types'; +import { environmentRt, rangeRt } from '../default_api_types'; import { getServiceGroup } from '../service_groups/get_service_group'; +import { offsetRt } from '../../../common/offset_rt'; const serviceMapRoute = createApmServerRoute({ endpoint: 'GET /internal/apm/service-map', diff --git a/x-pack/plugins/apm/server/routes/services/get_service_instances/detailed_statistics.ts b/x-pack/plugins/apm/server/routes/services/get_service_instances/detailed_statistics.ts index 10393e3434779..01e82c6d57c77 100644 --- a/x-pack/plugins/apm/server/routes/services/get_service_instances/detailed_statistics.ts +++ b/x-pack/plugins/apm/server/routes/services/get_service_instances/detailed_statistics.ts @@ -27,6 +27,7 @@ interface ServiceInstanceDetailedStatisticsParams { start: number; end: number; serviceNodeIds: string[]; + offset?: string; } async function getServiceInstancesDetailedStatistics( @@ -72,10 +73,9 @@ export async function getServiceInstancesDetailedStatisticsPeriods({ searchAggregatedTransactions, numBuckets, serviceNodeIds, - comparisonStart, - comparisonEnd, start, end, + offset, }: { environment: string; kuery: string; @@ -86,10 +86,9 @@ export async function getServiceInstancesDetailedStatisticsPeriods({ searchAggregatedTransactions: boolean; numBuckets: number; serviceNodeIds: string[]; - comparisonStart?: number; - comparisonEnd?: number; start: number; end: number; + offset?: string; }) { return withApmSpan( 'get_service_instances_detailed_statistics_periods', @@ -112,14 +111,14 @@ export async function getServiceInstancesDetailedStatisticsPeriods({ end, }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getServiceInstancesDetailedStatistics({ - ...commonParams, - start: comparisonStart, - end: comparisonEnd, - }) - : []; + const previousPeriodPromise = offset + ? getServiceInstancesDetailedStatistics({ + ...commonParams, + start, + end, + offset, + }) + : []; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, previousPeriodPromise, diff --git a/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_system_metric_statistics.ts b/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_system_metric_statistics.ts index 11fcbd8ce6561..c1cfbed24c91d 100644 --- a/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_system_metric_statistics.ts +++ b/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_system_metric_statistics.ts @@ -25,6 +25,7 @@ import { percentCgroupMemoryUsedScript, percentSystemMemoryUsedScript, } from '../../metrics/by_agent/shared/memory'; +import { getOffsetInMs } from '../../../../common/utils/get_offset_in_ms'; interface ServiceInstanceSystemMetricPrimaryStatistics { serviceNodeName: string; @@ -55,6 +56,7 @@ export async function getServiceInstancesSystemMetricStatistics< serviceNodeIds, numBuckets, isComparisonSearch, + offset, }: { setup: Setup; serviceName: string; @@ -66,10 +68,21 @@ export async function getServiceInstancesSystemMetricStatistics< kuery: string; size?: number; isComparisonSearch: T; + offset?: string; }): Promise>> { const { apmEventClient } = setup; - const { intervalString } = getBucketSize({ start, end, numBuckets }); + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + + const { intervalString } = getBucketSize({ + start: startWithOffset, + end: endWithOffset, + numBuckets, + }); const systemMemoryFilter = { bool: { @@ -99,8 +112,8 @@ export async function getServiceInstancesSystemMetricStatistics< fixed_interval: intervalString, min_doc_count: 0, extended_bounds: { - min: start, - max: end, + min: startWithOffset, + max: endWithOffset, }, }, aggs: { avg: { avg: agg } }, @@ -137,7 +150,7 @@ export async function getServiceInstancesSystemMetricStatistics< bool: { filter: [ { term: { [SERVICE_NAME]: serviceName } }, - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ...(isComparisonSearch && serviceNodeIds diff --git a/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_transaction_statistics.ts b/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_transaction_statistics.ts index ec081916f455d..7aa80322269b4 100644 --- a/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_transaction_statistics.ts +++ b/x-pack/plugins/apm/server/routes/services/get_service_instances/get_service_instances_transaction_statistics.ts @@ -28,6 +28,7 @@ import { getLatencyValue, } from '../../../lib/helpers/latency_aggregation_type'; import { Setup } from '../../../lib/helpers/setup_request'; +import { getOffsetInMs } from '../../../../common/utils/get_offset_in_ms'; interface ServiceInstanceTransactionPrimaryStatistics { serviceNodeName: string; @@ -63,6 +64,7 @@ export async function getServiceInstancesTransactionStatistics< serviceNodeIds, numBuckets, isComparisonSearch, + offset, }: { latencyAggregationType: LatencyAggregationType; setup: Setup; @@ -77,13 +79,20 @@ export async function getServiceInstancesTransactionStatistics< kuery: string; size?: number; numBuckets?: number; + offset?: string; }): Promise>> { const { apmEventClient } = setup; + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + const { intervalString, bucketSize } = getBucketSizeForAggregatedTransactions( { - start, - end, + start: startWithOffset, + end: endWithOffset, numBuckets, searchAggregatedTransactions, } @@ -108,7 +117,7 @@ export async function getServiceInstancesTransactionStatistics< { term: { [SERVICE_NAME]: serviceName } }, { term: { [TRANSACTION_TYPE]: transactionType } }, ...getDocumentTypeFilterForTransactions(searchAggregatedTransactions), - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ...getDocumentTypeFilterForTransactions(searchAggregatedTransactions), @@ -134,7 +143,7 @@ export async function getServiceInstancesTransactionStatistics< field: '@timestamp', fixed_interval: intervalString, min_doc_count: 0, - extended_bounds: { min: start, max: end }, + extended_bounds: { min: startWithOffset, max: endWithOffset }, }, aggs: subAggs, }, @@ -193,7 +202,11 @@ export async function getServiceInstancesTransactionStatistics< aggregation: latency, latencyAggregationType, }), - throughput: calculateThroughput({ start, end, value: count }), + throughput: calculateThroughput({ + start: startWithOffset, + end: endWithOffset, + value: count, + }), }; } } diff --git a/x-pack/plugins/apm/server/routes/services/get_service_instances/main_statistics.ts b/x-pack/plugins/apm/server/routes/services/get_service_instances/main_statistics.ts index a064c71496de9..a09b105cb5a79 100644 --- a/x-pack/plugins/apm/server/routes/services/get_service_instances/main_statistics.ts +++ b/x-pack/plugins/apm/server/routes/services/get_service_instances/main_statistics.ts @@ -23,6 +23,7 @@ interface ServiceInstanceMainStatisticsParams { size: number; start: number; end: number; + offset?: string; } export async function getServiceInstancesMainStatistics( diff --git a/x-pack/plugins/apm/server/routes/services/get_service_transaction_group_detailed_statistics.ts b/x-pack/plugins/apm/server/routes/services/get_service_transaction_group_detailed_statistics.ts index b14329985db90..2bc9ea328030d 100644 --- a/x-pack/plugins/apm/server/routes/services/get_service_transaction_group_detailed_statistics.ts +++ b/x-pack/plugins/apm/server/routes/services/get_service_transaction_group_detailed_statistics.ts @@ -30,6 +30,7 @@ import { } from '../../lib/helpers/latency_aggregation_type'; import { Setup } from '../../lib/helpers/setup_request'; import { calculateFailedTransactionRate } from '../../lib/helpers/transaction_error_rate'; +import { getOffsetInMs } from '../../../common/utils/get_offset_in_ms'; export async function getServiceTransactionGroupDetailedStatistics({ environment, @@ -43,6 +44,7 @@ export async function getServiceTransactionGroupDetailedStatistics({ latencyAggregationType, start, end, + offset, }: { environment: string; kuery: string; @@ -55,6 +57,7 @@ export async function getServiceTransactionGroupDetailedStatistics({ latencyAggregationType: LatencyAggregationType; start: number; end: number; + offset?: string; }): Promise< Array<{ transactionName: string; @@ -65,9 +68,16 @@ export async function getServiceTransactionGroupDetailedStatistics({ }> > { const { apmEventClient } = setup; - const { intervalString } = getBucketSizeForAggregatedTransactions({ + + const { startWithOffset, endWithOffset } = getOffsetInMs({ start, end, + offset, + }); + + const { intervalString } = getBucketSizeForAggregatedTransactions({ + start: startWithOffset, + end: endWithOffset, numBuckets, searchAggregatedTransactions, }); @@ -92,7 +102,7 @@ export async function getServiceTransactionGroupDetailedStatistics({ ...getDocumentTypeFilterForTransactions( searchAggregatedTransactions ), - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ], @@ -116,8 +126,8 @@ export async function getServiceTransactionGroupDetailedStatistics({ fixed_interval: intervalString, min_doc_count: 0, extended_bounds: { - min: start, - max: end, + min: startWithOffset, + max: endWithOffset, }, }, aggs: { @@ -179,12 +189,11 @@ export async function getServiceTransactionGroupDetailedStatisticsPeriods({ searchAggregatedTransactions, transactionType, latencyAggregationType, - comparisonStart, - comparisonEnd, environment, kuery, start, end, + offset, }: { serviceName: string; transactionNames: string[]; @@ -193,12 +202,11 @@ export async function getServiceTransactionGroupDetailedStatisticsPeriods({ searchAggregatedTransactions: boolean; transactionType: string; latencyAggregationType: LatencyAggregationType; - comparisonStart?: number; - comparisonEnd?: number; environment: string; kuery: string; start: number; end: number; + offset?: string; }) { const commonProps = { setup, @@ -218,14 +226,14 @@ export async function getServiceTransactionGroupDetailedStatisticsPeriods({ end, }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getServiceTransactionGroupDetailedStatistics({ - ...commonProps, - start: comparisonStart, - end: comparisonEnd, - }) - : []; + const previousPeriodPromise = offset + ? getServiceTransactionGroupDetailedStatistics({ + ...commonProps, + start, + end, + offset, + }) + : []; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, diff --git a/x-pack/plugins/apm/server/routes/services/get_throughput.ts b/x-pack/plugins/apm/server/routes/services/get_throughput.ts index ae730313ed808..fc266d8c8f8ee 100644 --- a/x-pack/plugins/apm/server/routes/services/get_throughput.ts +++ b/x-pack/plugins/apm/server/routes/services/get_throughput.ts @@ -21,6 +21,8 @@ import { getProcessorEventForTransactions, } from '../../lib/helpers/transactions'; import { Setup } from '../../lib/helpers/setup_request'; +import { getOffsetInMs } from '../../../common/utils/get_offset_in_ms'; +import { getBucketSizeForAggregatedTransactions } from '../../lib/helpers/get_bucket_size_for_aggregated_transactions'; interface Options { environment: string; @@ -32,8 +34,7 @@ interface Options { transactionName?: string; start: number; end: number; - intervalString: string; - bucketSize: number; + offset?: string; } export async function getThroughput({ @@ -46,11 +47,22 @@ export async function getThroughput({ transactionName, start, end, - intervalString, - bucketSize, + offset, }: Options) { const { apmEventClient } = setup; + const { startWithOffset, endWithOffset } = getOffsetInMs({ + start, + end, + offset, + }); + + const { intervalString } = getBucketSizeForAggregatedTransactions({ + start: startWithOffset, + end: endWithOffset, + searchAggregatedTransactions, + }); + const params = { apm: { events: [getProcessorEventForTransactions(searchAggregatedTransactions)], @@ -65,7 +77,7 @@ export async function getThroughput({ ...getDocumentTypeFilterForTransactions( searchAggregatedTransactions ), - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ...termQuery(TRANSACTION_NAME, transactionName), @@ -78,7 +90,7 @@ export async function getThroughput({ field: '@timestamp', fixed_interval: intervalString, min_doc_count: 0, - extended_bounds: { min: start, max: end }, + extended_bounds: { min: startWithOffset, max: endWithOffset }, }, aggs: { throughput: { diff --git a/x-pack/plugins/apm/server/routes/services/route.ts b/x-pack/plugins/apm/server/routes/services/route.ts index 8373e513c8325..fb5b7a56e72fb 100644 --- a/x-pack/plugins/apm/server/routes/services/route.ts +++ b/x-pack/plugins/apm/server/routes/services/route.ts @@ -29,17 +29,10 @@ import { getServiceProfilingTimeline } from './profiling/get_service_profiling_t import { getServiceInfrastructure } from './get_service_infrastructure'; import { withApmSpan } from '../../utils/with_apm_span'; import { createApmServerRoute } from '../apm_routes/create_apm_server_route'; -import { - comparisonRangeRt, - environmentRt, - kueryRt, - offsetRt, - rangeRt, -} from '../default_api_types'; +import { environmentRt, kueryRt, rangeRt } from '../default_api_types'; import { offsetPreviousPeriodCoordinates } from '../../../common/utils/offset_previous_period_coordinate'; import { getServicesDetailedStatistics } from './get_services_detailed_statistics'; import { getServiceDependenciesBreakdown } from './get_service_dependencies_breakdown'; -import { getBucketSizeForAggregatedTransactions } from '../../lib/helpers/get_bucket_size_for_aggregated_transactions'; import { getAnomalyTimeseries } from '../../lib/anomaly_detection/get_anomaly_timeseries'; import { UnknownMLCapabilitiesError, @@ -54,6 +47,7 @@ import { ConnectionStatsItemWithImpact } from './../../../common/connections'; import { getSortedAndFilteredServices } from './get_services/get_sorted_and_filtered_services'; import { ServiceHealthStatus } from './../../../common/service_health_status'; import { getServiceGroup } from '../service_groups/get_service_group'; +import { offsetRt } from '../../../common/offset_rt'; const servicesRoute = createApmServerRoute({ endpoint: 'GET /internal/apm/services', @@ -509,7 +503,7 @@ const serviceThroughputRoute = createApmServerRoute({ query: t.intersection([ t.type({ transactionType: t.string }), t.partial({ transactionName: t.string }), - t.intersection([environmentRt, kueryRt, rangeRt, comparisonRangeRt]), + t.intersection([environmentRt, kueryRt, rangeRt, offsetRt]), ]), }), options: { tags: ['access:apm'] }, @@ -530,8 +524,7 @@ const serviceThroughputRoute = createApmServerRoute({ kuery, transactionType, transactionName, - comparisonStart, - comparisonEnd, + offset, start, end, } = params.query; @@ -542,13 +535,6 @@ const serviceThroughputRoute = createApmServerRoute({ end, }); - const { bucketSize, intervalString } = - getBucketSizeForAggregatedTransactions({ - start, - end, - searchAggregatedTransactions, - }); - const commonProps = { environment, kuery, @@ -557,8 +543,6 @@ const serviceThroughputRoute = createApmServerRoute({ setup, transactionType, transactionName, - intervalString, - bucketSize, }; const [currentPeriod, previousPeriod] = await Promise.all([ @@ -567,11 +551,12 @@ const serviceThroughputRoute = createApmServerRoute({ start, end, }), - comparisonStart && comparisonEnd + offset ? getThroughput({ ...commonProps, - start: comparisonStart, - end: comparisonEnd, + start, + end, + offset, }) : [], ]); @@ -598,7 +583,7 @@ const serviceInstancesMainStatisticsRoute = createApmServerRoute({ latencyAggregationType: latencyAggregationTypeRt, transactionType: t.string, }), - comparisonRangeRt, + offsetRt, environmentRt, kueryRt, rangeRt, @@ -633,8 +618,7 @@ const serviceInstancesMainStatisticsRoute = createApmServerRoute({ kuery, transactionType, latencyAggregationType, - comparisonStart, - comparisonEnd, + offset, start, end, } = params.query; @@ -658,7 +642,7 @@ const serviceInstancesMainStatisticsRoute = createApmServerRoute({ start, end, }), - ...(comparisonStart && comparisonEnd + ...(offset ? [ getServiceInstancesMainStatistics({ environment, @@ -668,8 +652,9 @@ const serviceInstancesMainStatisticsRoute = createApmServerRoute({ setup, transactionType, searchAggregatedTransactions, - start: comparisonStart, - end: comparisonEnd, + start, + end, + offset, }), ] : []), @@ -696,7 +681,7 @@ const serviceInstancesDetailedStatisticsRoute = createApmServerRoute({ environmentRt, kueryRt, rangeRt, - comparisonRangeRt, + offsetRt, ]), }), options: { tags: ['access:apm'] }, @@ -752,8 +737,7 @@ const serviceInstancesDetailedStatisticsRoute = createApmServerRoute({ environment, kuery, transactionType, - comparisonStart, - comparisonEnd, + offset, serviceNodeIds, numBuckets, latencyAggregationType, @@ -778,8 +762,7 @@ const serviceInstancesDetailedStatisticsRoute = createApmServerRoute({ searchAggregatedTransactions, numBuckets, serviceNodeIds, - comparisonStart, - comparisonEnd, + offset, start, end, }); diff --git a/x-pack/plugins/apm/server/routes/transactions/get_failed_transaction_rate_periods.ts b/x-pack/plugins/apm/server/routes/transactions/get_failed_transaction_rate_periods.ts index 96913b9e197a7..0538832b6e84c 100644 --- a/x-pack/plugins/apm/server/routes/transactions/get_failed_transaction_rate_periods.ts +++ b/x-pack/plugins/apm/server/routes/transactions/get_failed_transaction_rate_periods.ts @@ -16,10 +16,9 @@ export async function getFailedTransactionRatePeriods({ transactionName, setup, searchAggregatedTransactions, - comparisonStart, - comparisonEnd, start, end, + offset, }: { environment: string; kuery: string; @@ -28,10 +27,9 @@ export async function getFailedTransactionRatePeriods({ transactionName?: string; setup: Setup; searchAggregatedTransactions: boolean; - comparisonStart?: number; - comparisonEnd?: number; start: number; end: number; + offset?: string; }) { const commonProps = { environment, @@ -49,14 +47,14 @@ export async function getFailedTransactionRatePeriods({ end, }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getFailedTransactionRate({ - ...commonProps, - start: comparisonStart, - end: comparisonEnd, - }) - : { timeseries: [], average: null }; + const previousPeriodPromise = offset + ? getFailedTransactionRate({ + ...commonProps, + start, + end, + offset, + }) + : { timeseries: [], average: null }; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, diff --git a/x-pack/plugins/apm/server/routes/transactions/get_latency_charts/index.ts b/x-pack/plugins/apm/server/routes/transactions/get_latency_charts/index.ts index 5ae16aab00c23..cb8289200959e 100644 --- a/x-pack/plugins/apm/server/routes/transactions/get_latency_charts/index.ts +++ b/x-pack/plugins/apm/server/routes/transactions/get_latency_charts/index.ts @@ -29,6 +29,8 @@ import { getLatencyAggregation, getLatencyValue, } from '../../../lib/helpers/latency_aggregation_type'; +import { getOffsetInMs } from '../../../../common/utils/get_offset_in_ms'; + export type LatencyChartsSearchResponse = Awaited< ReturnType >; @@ -44,6 +46,7 @@ function searchLatency({ latencyAggregationType, start, end, + offset, }: { environment: string; kuery: string; @@ -55,11 +58,19 @@ function searchLatency({ latencyAggregationType: LatencyAggregationType; start: number; end: number; + offset?: string; }) { const { apmEventClient } = setup; - const { intervalString } = getBucketSizeForAggregatedTransactions({ + + const { startWithOffset, endWithOffset } = getOffsetInMs({ start, end, + offset, + }); + + const { intervalString } = getBucketSizeForAggregatedTransactions({ + start: startWithOffset, + end: endWithOffset, searchAggregatedTransactions, }); @@ -80,7 +91,7 @@ function searchLatency({ ...getDocumentTypeFilterForTransactions( searchAggregatedTransactions ), - ...rangeQuery(start, end), + ...rangeQuery(startWithOffset, endWithOffset), ...environmentQuery(environment), ...kqlQuery(kuery), ...termQuery(TRANSACTION_NAME, transactionName), @@ -94,7 +105,7 @@ function searchLatency({ field: '@timestamp', fixed_interval: intervalString, min_doc_count: 0, - extended_bounds: { min: start, max: end }, + extended_bounds: { min: startWithOffset, max: endWithOffset }, }, aggs: getLatencyAggregation( latencyAggregationType, @@ -120,6 +131,7 @@ export async function getLatencyTimeseries({ latencyAggregationType, start, end, + offset, }: { environment: string; kuery: string; @@ -131,6 +143,7 @@ export async function getLatencyTimeseries({ latencyAggregationType: LatencyAggregationType; start: number; end: number; + offset?: string; }) { const response = await searchLatency({ environment, @@ -143,6 +156,7 @@ export async function getLatencyTimeseries({ latencyAggregationType, start, end, + offset, }); if (!response.aggregations) { @@ -173,12 +187,11 @@ export async function getLatencyPeriods({ setup, searchAggregatedTransactions, latencyAggregationType, - comparisonStart, - comparisonEnd, kuery, environment, start, end, + offset, }: { serviceName: string; transactionType: string | undefined; @@ -186,12 +199,11 @@ export async function getLatencyPeriods({ setup: Setup; searchAggregatedTransactions: boolean; latencyAggregationType: LatencyAggregationType; - comparisonStart?: number; - comparisonEnd?: number; kuery: string; environment: string; start: number; end: number; + offset?: string; }) { const options = { serviceName, @@ -210,16 +222,16 @@ export async function getLatencyPeriods({ latencyAggregationType: latencyAggregationType as LatencyAggregationType, }); - const previousPeriodPromise = - comparisonStart && comparisonEnd - ? getLatencyTimeseries({ - ...options, - start: comparisonStart, - end: comparisonEnd, - latencyAggregationType: - latencyAggregationType as LatencyAggregationType, - }) - : { latencyTimeseries: [], overallAvgDuration: null }; + const previousPeriodPromise = offset + ? getLatencyTimeseries({ + ...options, + start, + end, + offset, + latencyAggregationType: + latencyAggregationType as LatencyAggregationType, + }) + : { latencyTimeseries: [], overallAvgDuration: null }; const [currentPeriod, previousPeriod] = await Promise.all([ currentPeriodPromise, diff --git a/x-pack/plugins/apm/server/routes/transactions/route.ts b/x-pack/plugins/apm/server/routes/transactions/route.ts index 657387037855f..d5a380ffefa19 100644 --- a/x-pack/plugins/apm/server/routes/transactions/route.ts +++ b/x-pack/plugins/apm/server/routes/transactions/route.ts @@ -21,12 +21,8 @@ import { getLatencyPeriods } from './get_latency_charts'; import { getFailedTransactionRatePeriods } from './get_failed_transaction_rate_periods'; import { getColdstartRatePeriods } from '../../lib/transaction_groups/get_coldstart_rate'; import { createApmServerRoute } from '../apm_routes/create_apm_server_route'; -import { - comparisonRangeRt, - environmentRt, - kueryRt, - rangeRt, -} from '../default_api_types'; +import { environmentRt, kueryRt, rangeRt } from '../default_api_types'; +import { offsetRt } from '../../../common/offset_rt'; const transactionGroupsMainStatisticsRoute = createApmServerRoute({ endpoint: @@ -104,7 +100,7 @@ const transactionGroupsDetailedStatisticsRoute = createApmServerRoute({ environmentRt, kueryRt, rangeRt, - comparisonRangeRt, + offsetRt, t.type({ transactionNames: jsonRt.pipe(t.array(t.string)), numBuckets: toNumberRt, @@ -155,10 +151,9 @@ const transactionGroupsDetailedStatisticsRoute = createApmServerRoute({ latencyAggregationType, numBuckets, transactionType, - comparisonStart, - comparisonEnd, start, end, + offset, }, } = params; @@ -179,10 +174,9 @@ const transactionGroupsDetailedStatisticsRoute = createApmServerRoute({ transactionType, numBuckets, latencyAggregationType, - comparisonStart, - comparisonEnd, start, end, + offset, }); }, }); @@ -200,7 +194,7 @@ const transactionLatencyChartsRoute = createApmServerRoute({ latencyAggregationType: latencyAggregationTypeRt, }), t.partial({ transactionName: t.string }), - t.intersection([environmentRt, kueryRt, rangeRt, comparisonRangeRt]), + t.intersection([environmentRt, kueryRt, rangeRt, offsetRt]), ]), }), options: { tags: ['access:apm'] }, @@ -237,10 +231,9 @@ const transactionLatencyChartsRoute = createApmServerRoute({ transactionType, transactionName, latencyAggregationType, - comparisonStart, - comparisonEnd, start, end, + offset, } = params.query; const searchAggregatedTransactions = await getSearchAggregatedTransactions({ @@ -266,8 +259,7 @@ const transactionLatencyChartsRoute = createApmServerRoute({ const { currentPeriod, previousPeriod } = await getLatencyPeriods({ ...options, latencyAggregationType: latencyAggregationType as LatencyAggregationType, - comparisonStart, - comparisonEnd, + offset, }); return { @@ -397,7 +389,7 @@ const transactionChartsErrorRateRoute = createApmServerRoute({ query: t.intersection([ t.type({ transactionType: t.string }), t.partial({ transactionName: t.string }), - t.intersection([environmentRt, kueryRt, rangeRt, comparisonRangeRt]), + t.intersection([environmentRt, kueryRt, rangeRt, offsetRt]), ]), }), options: { tags: ['access:apm'] }, @@ -433,10 +425,9 @@ const transactionChartsErrorRateRoute = createApmServerRoute({ kuery, transactionType, transactionName, - comparisonStart, - comparisonEnd, start, end, + offset, } = params.query; const searchAggregatedTransactions = await getSearchAggregatedTransactions({ @@ -454,10 +445,9 @@ const transactionChartsErrorRateRoute = createApmServerRoute({ transactionName, setup, searchAggregatedTransactions, - comparisonStart, - comparisonEnd, start, end, + offset, }); }, }); @@ -471,7 +461,7 @@ const transactionChartsColdstartRateRoute = createApmServerRoute({ }), query: t.intersection([ t.type({ transactionType: t.string }), - t.intersection([environmentRt, kueryRt, rangeRt, comparisonRangeRt]), + t.intersection([environmentRt, kueryRt, rangeRt, offsetRt]), ]), }), options: { tags: ['access:apm'] }, @@ -504,15 +494,8 @@ const transactionChartsColdstartRateRoute = createApmServerRoute({ const { params } = resources; const { serviceName } = params.path; - const { - environment, - kuery, - transactionType, - comparisonStart, - comparisonEnd, - start, - end, - } = params.query; + const { environment, kuery, transactionType, start, end, offset } = + params.query; const searchAggregatedTransactions = await getSearchAggregatedTransactions({ ...setup, @@ -528,10 +511,9 @@ const transactionChartsColdstartRateRoute = createApmServerRoute({ transactionType, setup, searchAggregatedTransactions, - comparisonStart, - comparisonEnd, start, end, + offset, }); }, }); @@ -546,7 +528,7 @@ const transactionChartsColdstartRateByTransactionNameRoute = }), query: t.intersection([ t.type({ transactionType: t.string, transactionName: t.string }), - t.intersection([environmentRt, kueryRt, rangeRt, comparisonRangeRt]), + t.intersection([environmentRt, kueryRt, rangeRt, offsetRt]), ]), }), options: { tags: ['access:apm'] }, @@ -584,10 +566,9 @@ const transactionChartsColdstartRateByTransactionNameRoute = kuery, transactionType, transactionName, - comparisonStart, - comparisonEnd, start, end, + offset, } = params.query; const searchAggregatedTransactions = @@ -606,10 +587,9 @@ const transactionChartsColdstartRateByTransactionNameRoute = transactionName, setup, searchAggregatedTransactions, - comparisonStart, - comparisonEnd, start, end, + offset, }); }, }); diff --git a/x-pack/test/apm_api_integration/tests/cold_start/cold_start.spec.ts b/x-pack/test/apm_api_integration/tests/cold_start/cold_start.spec.ts index fedf44d477d2d..a942862891969 100644 --- a/x-pack/test/apm_api_integration/tests/cold_start/cold_start.spec.ts +++ b/x-pack/test/apm_api_integration/tests/cold_start/cold_start.spec.ts @@ -141,8 +141,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { query: { start: startDate.toISOString(), end: endDate.subtract(1, 'seconds').toISOString(), - comparisonStart: comparisonStartDate.toISOString(), - comparisonEnd: comparisonEndDate.subtract(1, 'seconds').toISOString(), + offset: '6m', }, }); body = response.body; diff --git a/x-pack/test/apm_api_integration/tests/cold_start/cold_start_by_transaction_name/cold_start_by_transaction_name.spec.ts b/x-pack/test/apm_api_integration/tests/cold_start/cold_start_by_transaction_name/cold_start_by_transaction_name.spec.ts index d577077490b88..4cd9026f6ac51 100644 --- a/x-pack/test/apm_api_integration/tests/cold_start/cold_start_by_transaction_name/cold_start_by_transaction_name.spec.ts +++ b/x-pack/test/apm_api_integration/tests/cold_start/cold_start_by_transaction_name/cold_start_by_transaction_name.spec.ts @@ -143,8 +143,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { query: { start: startDate.toISOString(), end: endDate.subtract(1, 'seconds').toISOString(), - comparisonStart: comparisonStartDate.toISOString(), - comparisonEnd: comparisonEndDate.subtract(1, 'seconds').toISOString(), + offset: '6m', }, }); body = response.body; diff --git a/x-pack/test/apm_api_integration/tests/errors/distribution.spec.ts b/x-pack/test/apm_api_integration/tests/errors/distribution.spec.ts index d237574d551f7..9511284aba455 100644 --- a/x-pack/test/apm_api_integration/tests/errors/distribution.spec.ts +++ b/x-pack/test/apm_api_integration/tests/errors/distribution.spec.ts @@ -112,8 +112,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { query: { start: new Date(end - fiveMinutes).toISOString(), end: new Date(end).toISOString(), - comparisonStart: new Date(start).toISOString(), - comparisonEnd: new Date(start + fiveMinutes).toISOString(), + offset: '5m', }, }); errorsDistribution = response.body; @@ -157,8 +156,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { query: { start: '2021-01-03T00:00:00.000Z', end: '2021-01-03T00:15:00.000Z', - comparisonStart: '2021-01-02T00:00:00.000Z', - comparisonEnd: '2021-01-02T00:15:00.000Z', + offset: '1d', }, }); errorsDistribution = response.body; diff --git a/x-pack/test/apm_api_integration/tests/service_overview/instances_detailed_statistics.spec.ts b/x-pack/test/apm_api_integration/tests/service_overview/instances_detailed_statistics.spec.ts index e8c4b73ac2970..653a96ad79b3b 100644 --- a/x-pack/test/apm_api_integration/tests/service_overview/instances_detailed_statistics.spec.ts +++ b/x-pack/test/apm_api_integration/tests/service_overview/instances_detailed_statistics.spec.ts @@ -150,8 +150,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { serviceNodeIds: JSON.stringify(serviceNodeIds), start: moment(end).subtract(15, 'minutes').toISOString(), end, - comparisonStart: start, - comparisonEnd: moment(start).add(15, 'minutes').toISOString(), + offset: '15m', environment: 'ENVIRONMENT_ALL', kuery: '', }, diff --git a/x-pack/test/apm_api_integration/tests/service_overview/instances_main_statistics.spec.ts b/x-pack/test/apm_api_integration/tests/service_overview/instances_main_statistics.spec.ts index 4f847011ad56e..37e0d65ff9411 100644 --- a/x-pack/test/apm_api_integration/tests/service_overview/instances_main_statistics.spec.ts +++ b/x-pack/test/apm_api_integration/tests/service_overview/instances_main_statistics.spec.ts @@ -41,8 +41,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { transactionType: 'request', start: moment(end).subtract(15, 'minutes').toISOString(), end, - comparisonStart: start, - comparisonEnd: moment(start).add(15, 'minutes').toISOString(), + offset: '15m', environment: 'ENVIRONMENT_ALL', kuery: '', }, @@ -214,8 +213,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { transactionType: 'request', start: moment(end).subtract(15, 'minutes').toISOString(), end, - comparisonStart: start, - comparisonEnd: moment(start).add(15, 'minutes').toISOString(), + offset: '15m', environment: 'ENVIRONMENT_ALL', kuery: '', }, diff --git a/x-pack/test/apm_api_integration/tests/services/error_groups/error_groups_detailed_statistics.spec.ts b/x-pack/test/apm_api_integration/tests/services/error_groups/error_groups_detailed_statistics.spec.ts index 9d09e7046519b..8867327ac418a 100644 --- a/x-pack/test/apm_api_integration/tests/services/error_groups/error_groups_detailed_statistics.spec.ts +++ b/x-pack/test/apm_api_integration/tests/services/error_groups/error_groups_detailed_statistics.spec.ts @@ -141,8 +141,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { groupIds: JSON.stringify(errorIds), start: moment(end).subtract(7, 'minutes').toISOString(), end: new Date(end).toISOString(), - comparisonStart: new Date(start).toISOString(), - comparisonEnd: moment(start).add(7, 'minutes').toISOString(), + offset: '7m', }, }); errorGroupsDetailedStatistics = response.body; diff --git a/x-pack/test/apm_api_integration/tests/services/throughput.spec.ts b/x-pack/test/apm_api_integration/tests/services/throughput.spec.ts index a2428d13ae253..f319f3566a551 100644 --- a/x-pack/test/apm_api_integration/tests/services/throughput.spec.ts +++ b/x-pack/test/apm_api_integration/tests/services/throughput.spec.ts @@ -216,8 +216,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { query: { start: moment(end).subtract(7, 'minutes').toISOString(), end: new Date(end).toISOString(), - comparisonStart: new Date(start).toISOString(), - comparisonEnd: moment(start).add(7, 'minutes').toISOString(), + offset: '7m', }, }); throughputResponse = response.body; diff --git a/x-pack/test/apm_api_integration/tests/transactions/error_rate.spec.ts b/x-pack/test/apm_api_integration/tests/transactions/error_rate.spec.ts index 858c7c9327176..8790e4325f820 100644 --- a/x-pack/test/apm_api_integration/tests/transactions/error_rate.spec.ts +++ b/x-pack/test/apm_api_integration/tests/transactions/error_rate.spec.ts @@ -51,8 +51,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { transactionType, start: moment(end).subtract(15, 'minutes').toISOString(), end, - comparisonStart: start, - comparisonEnd: moment(start).add(15, 'minutes').toISOString(), + offset: '15m', environment: 'ENVIRONMENT_ALL', kuery: '', }, @@ -137,8 +136,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { transactionType, start: moment(end).subtract(15, 'minutes').toISOString(), end, - comparisonStart: start, - comparisonEnd: moment(start).add(15, 'minutes').toISOString(), + offset: '15m', environment: 'ENVIRONMENT_ALL', kuery: '', }, diff --git a/x-pack/test/apm_api_integration/tests/transactions/latency.spec.ts b/x-pack/test/apm_api_integration/tests/transactions/latency.spec.ts index a221325e15771..7a78fe2742ef5 100644 --- a/x-pack/test/apm_api_integration/tests/transactions/latency.spec.ts +++ b/x-pack/test/apm_api_integration/tests/transactions/latency.spec.ts @@ -181,8 +181,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { transactionType: 'request', start: moment(end).subtract(15, 'minutes').toISOString(), end, - comparisonStart: start, - comparisonEnd: moment(start).add(15, 'minutes').toISOString(), + offset: '15m', environment: 'ENVIRONMENT_ALL', kuery: '', }, diff --git a/x-pack/test/apm_api_integration/tests/transactions/transactions_groups_detailed_statistics.spec.ts b/x-pack/test/apm_api_integration/tests/transactions/transactions_groups_detailed_statistics.spec.ts index 02103b456c826..587206cb46a64 100644 --- a/x-pack/test/apm_api_integration/tests/transactions/transactions_groups_detailed_statistics.spec.ts +++ b/x-pack/test/apm_api_integration/tests/transactions/transactions_groups_detailed_statistics.spec.ts @@ -37,8 +37,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { transactionType?: string; environment?: string; kuery?: string; - comparisonStart?: string; - comparisonEnd?: string; + offset?: string; transactionNames?: string; latencyAggregationType?: LatencyAggregationType; numBuckets?: number; @@ -190,8 +189,7 @@ export default function ApiTest({ getService }: FtrProviderContext) { query: { start: moment(end).subtract(7, 'minutes').toISOString(), end: new Date(end).toISOString(), - comparisonStart: new Date(start).toISOString(), - comparisonEnd: moment(start).add(7, 'minutes').toISOString(), + offset: '8m', }, }); }); From 2dfc0b9d19749d562d630d89a0d3190f0de17c49 Mon Sep 17 00:00:00 2001 From: mgiota Date: Mon, 28 Mar 2022 15:47:07 +0200 Subject: [PATCH 014/160] [Actionable Observability] filter by o11y rule types (#128370) * filter per o11y rule types * fix typescript errors --- .../public/application/application.test.tsx | 1 + .../public/application/index.tsx | 4 + .../components/app/section/apm/index.test.tsx | 1 + .../public/context/plugin_context.tsx | 2 + .../public/hooks/use_fetch_rules.ts | 11 ++- .../pages/overview/overview.stories.tsx | 1 + .../pages/rules/components/type_filter.tsx | 90 +++++++++++++++++++ .../public/pages/rules/index.tsx | 46 +++++++++- .../observability/public/pages/rules/types.ts | 1 + x-pack/plugins/observability/public/plugin.ts | 14 +++ .../public/utils/test_helper.tsx | 1 + 11 files changed, 167 insertions(+), 5 deletions(-) create mode 100644 x-pack/plugins/observability/public/pages/rules/components/type_filter.tsx diff --git a/x-pack/plugins/observability/public/application/application.test.tsx b/x-pack/plugins/observability/public/application/application.test.tsx index 20e67661bad06..cd96b1018cdca 100644 --- a/x-pack/plugins/observability/public/application/application.test.tsx +++ b/x-pack/plugins/observability/public/application/application.test.tsx @@ -83,6 +83,7 @@ describe('renderApp', () => { appMountParameters: params, observabilityRuleTypeRegistry: createObservabilityRuleTypeRegistryMock(), ObservabilityPageTemplate: KibanaPageTemplate, + kibanaFeatures: [], }); unmount(); }).not.toThrowError(); diff --git a/x-pack/plugins/observability/public/application/index.tsx b/x-pack/plugins/observability/public/application/index.tsx index bb2239abd68fb..6f8f99a6197ae 100644 --- a/x-pack/plugins/observability/public/application/index.tsx +++ b/x-pack/plugins/observability/public/application/index.tsx @@ -9,6 +9,7 @@ import { i18n } from '@kbn/i18n'; import React from 'react'; import ReactDOM from 'react-dom'; import { Route, Router, Switch } from 'react-router-dom'; +import { KibanaFeature } from '../../../features/common'; import { ConfigSchema } from '..'; import { AppMountParameters, APP_WRAPPER_CLASS, CoreStart } from '../../../../../src/core/public'; import { EuiThemeProvider } from '../../../../../src/plugins/kibana_react/common'; @@ -52,6 +53,7 @@ export const renderApp = ({ appMountParameters, observabilityRuleTypeRegistry, ObservabilityPageTemplate, + kibanaFeatures, }: { config: ConfigSchema; core: CoreStart; @@ -59,6 +61,7 @@ export const renderApp = ({ observabilityRuleTypeRegistry: ObservabilityRuleTypeRegistry; appMountParameters: AppMountParameters; ObservabilityPageTemplate: React.ComponentType; + kibanaFeatures: KibanaFeature[]; }) => { const { element, history, theme$ } = appMountParameters; const i18nCore = core.i18n; @@ -83,6 +86,7 @@ export const renderApp = ({ config, observabilityRuleTypeRegistry, ObservabilityPageTemplate, + kibanaFeatures, }} > diff --git a/x-pack/plugins/observability/public/components/app/section/apm/index.test.tsx b/x-pack/plugins/observability/public/components/app/section/apm/index.test.tsx index e590d53074f8a..24538cb4eb25c 100644 --- a/x-pack/plugins/observability/public/components/app/section/apm/index.test.tsx +++ b/x-pack/plugins/observability/public/components/app/section/apm/index.test.tsx @@ -54,6 +54,7 @@ describe('APMSection', () => { }, observabilityRuleTypeRegistry: createObservabilityRuleTypeRegistryMock(), ObservabilityPageTemplate: KibanaPageTemplate, + kibanaFeatures: [], })); }); diff --git a/x-pack/plugins/observability/public/context/plugin_context.tsx b/x-pack/plugins/observability/public/context/plugin_context.tsx index 50711d1a46553..e4e1ddb420340 100644 --- a/x-pack/plugins/observability/public/context/plugin_context.tsx +++ b/x-pack/plugins/observability/public/context/plugin_context.tsx @@ -7,6 +7,7 @@ import { AppMountParameters } from 'kibana/public'; import { createContext } from 'react'; +import { KibanaFeature } from '../../../features/common'; import { ConfigSchema } from '..'; import { ObservabilityRuleTypeRegistry } from '../rules/create_observability_rule_type_registry'; import type { LazyObservabilityPageTemplateProps } from '../components/shared/page_template/lazy_page_template'; @@ -16,6 +17,7 @@ export interface PluginContextValue { config: ConfigSchema; observabilityRuleTypeRegistry: ObservabilityRuleTypeRegistry; ObservabilityPageTemplate: React.ComponentType; + kibanaFeatures: KibanaFeature[]; } export const PluginContext = createContext({} as PluginContextValue); diff --git a/x-pack/plugins/observability/public/hooks/use_fetch_rules.ts b/x-pack/plugins/observability/public/hooks/use_fetch_rules.ts index 53b2f68821710..e3a1ab9c0137c 100644 --- a/x-pack/plugins/observability/public/hooks/use_fetch_rules.ts +++ b/x-pack/plugins/observability/public/hooks/use_fetch_rules.ts @@ -23,6 +23,7 @@ interface RuleState { export function useFetchRules({ searchText, ruleLastResponseFilter, + typesFilter, setPage, page, sort, @@ -47,7 +48,7 @@ export function useFetchRules({ http, page, searchText, - typesFilter: OBSERVABILITY_RULE_TYPES, + typesFilter: typesFilter.length > 0 ? typesFilter : OBSERVABILITY_RULE_TYPES, ruleStatusesFilter: ruleLastResponseFilter, sort, }); @@ -61,14 +62,18 @@ export function useFetchRules({ if (!response.data?.length && page.index > 0) { setPage({ ...page, index: 0 }); } - const isFilterApplied = !(isEmpty(searchText) && isEmpty(ruleLastResponseFilter)); + const isFilterApplied = !( + isEmpty(searchText) && + isEmpty(ruleLastResponseFilter) && + isEmpty(typesFilter) + ); setNoData(response.data.length === 0 && !isFilterApplied); } catch (_e) { setRulesState((oldState) => ({ ...oldState, isLoading: false, error: RULES_LOAD_ERROR })); } setInitialLoad(false); - }, [http, page, setPage, searchText, ruleLastResponseFilter, sort]); + }, [http, page, setPage, searchText, ruleLastResponseFilter, typesFilter, sort]); useEffect(() => { fetchRules(); }, [fetchRules]); diff --git a/x-pack/plugins/observability/public/pages/overview/overview.stories.tsx b/x-pack/plugins/observability/public/pages/overview/overview.stories.tsx index 7922bda9fddee..956dc76a8e2fe 100644 --- a/x-pack/plugins/observability/public/pages/overview/overview.stories.tsx +++ b/x-pack/plugins/observability/public/pages/overview/overview.stories.tsx @@ -94,6 +94,7 @@ const withCore = makeDecorator({ }, observabilityRuleTypeRegistry: createObservabilityRuleTypeRegistryMock(), ObservabilityPageTemplate: KibanaPageTemplate, + kibanaFeatures: [], }} > {storyFn(context)} diff --git a/x-pack/plugins/observability/public/pages/rules/components/type_filter.tsx b/x-pack/plugins/observability/public/pages/rules/components/type_filter.tsx new file mode 100644 index 0000000000000..5f4d4666002b5 --- /dev/null +++ b/x-pack/plugins/observability/public/pages/rules/components/type_filter.tsx @@ -0,0 +1,90 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { Fragment, useEffect, useState } from 'react'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { + EuiFilterGroup, + EuiPopover, + EuiFilterButton, + EuiFilterSelectItem, + EuiTitle, +} from '@elastic/eui'; + +interface TypeFilterProps { + options: Array<{ + groupName: string; + subOptions: Array<{ + value: string; + name: string; + }>; + }>; + onChange?: (selectedTags: string[]) => void; +} + +export function TypeFilter({ 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)} + data-test-subj="ruleTypeFilterButton" + > + + + } + > +
+ {options.map((groupItem, groupIndex) => ( + + +

{groupItem.groupName}

+
+ {groupItem.subOptions.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} + data-test-subj={`ruleType${item.value}FilterOption`} + > + {item.name} + + ))} +
+ ))} +
+
+
+ ); +} diff --git a/x-pack/plugins/observability/public/pages/rules/index.tsx b/x-pack/plugins/observability/public/pages/rules/index.tsx index a0b95441f4857..21cdc997419c0 100644 --- a/x-pack/plugins/observability/public/pages/rules/index.tsx +++ b/x-pack/plugins/observability/public/pages/rules/index.tsx @@ -6,6 +6,7 @@ */ import React, { useState, useMemo, useEffect } from 'react'; +import { capitalize, sortBy } from 'lodash'; import { EuiButton, EuiButtonIcon, @@ -28,6 +29,7 @@ import { useFetchRules } from '../../hooks/use_fetch_rules'; import { RulesTable } from './components/rules_table'; import { Name } from './components/name'; import { LastResponseFilter } from './components/last_response_filter'; +import { TypeFilter } from './components/type_filter'; import { StatusContext } from './components/status_context'; import { ExecutionStatus } from './components/execution_status'; import { LastRun } from './components/last_run'; @@ -70,11 +72,10 @@ import { SEARCH_PLACEHOLDER, } from './translations'; import { ExperimentalBadge } from '../../components/shared/experimental_badge'; - const ENTER_KEY = 13; export function RulesPage() { - const { ObservabilityPageTemplate } = usePluginContext(); + const { ObservabilityPageTemplate, kibanaFeatures } = usePluginContext(); const { http, docLinks, @@ -95,6 +96,7 @@ export function RulesPage() { const [refreshInterval, setRefreshInterval] = useState(60000); const [isPaused, setIsPaused] = useState(false); const [ruleLastResponseFilter, setRuleLastResponseFilter] = useState([]); + const [typesFilter, setTypesFilter] = useState([]); const [currentRuleToEdit, setCurrentRuleToEdit] = useState(null); const [rulesToDelete, setRulesToDelete] = useState([]); const [createRuleFlyoutVisibility, setCreateRuleFlyoutVisibility] = useState(false); @@ -117,6 +119,7 @@ export function RulesPage() { const { rulesState, setRulesState, reload, noData, initialLoad } = useFetchRules({ searchText, ruleLastResponseFilter, + typesFilter, page, setPage, sort, @@ -127,6 +130,32 @@ export function RulesPage() { }); const authorizedRuleTypes = [...ruleTypes.values()]; + const getProducerFeatureName = (producer: string) => { + return kibanaFeatures?.find((featureItem) => featureItem.id === producer)?.name; + }; + + const groupRuleTypesByProducer = () => { + return authorizedRuleTypes.reduce( + ( + result: Record< + string, + Array<{ + value: string; + name: string; + }> + >, + ruleType + ) => { + const producer = ruleType.producer; + (result[producer] = result[producer] || []).push({ + value: ruleType.id, + name: ruleType.name, + }); + return result; + }, + {} + ); + }; const authorizedToCreateAnyRules = authorizedRuleTypes.some( (ruleType) => ruleType.authorizedConsumers[ALERTS_FEATURE_ID]?.all ); @@ -291,6 +320,18 @@ export function RulesPage() { placeholder={SEARCH_PLACEHOLDER} /> + + setTypesFilter(types)} + options={sortBy(Object.entries(groupRuleTypesByProducer())).map( + ([groupName, ruleTypesOptions]) => ({ + groupName: getProducerFeatureName(groupName) ?? capitalize(groupName), + subOptions: ruleTypesOptions.sort((a, b) => a.name.localeCompare(b.name)), + }) + )} + /> + + {getRulesTable()} {error && toasts.addDanger({ diff --git a/x-pack/plugins/observability/public/pages/rules/types.ts b/x-pack/plugins/observability/public/pages/rules/types.ts index 1a15cf3d9cef2..0fba341d7f16d 100644 --- a/x-pack/plugins/observability/public/pages/rules/types.ts +++ b/x-pack/plugins/observability/public/pages/rules/types.ts @@ -69,6 +69,7 @@ export interface Pagination { export interface FetchRulesProps { searchText: string | undefined; ruleLastResponseFilter: string[]; + typesFilter: string[]; page: Pagination; setPage: Dispatch>; sort: EuiTableSortingType['sort']; diff --git a/x-pack/plugins/observability/public/plugin.ts b/x-pack/plugins/observability/public/plugin.ts index ed591d45a9820..2fe097cf8eb10 100644 --- a/x-pack/plugins/observability/public/plugin.ts +++ b/x-pack/plugins/observability/public/plugin.ts @@ -27,6 +27,7 @@ import type { import type { DataViewsPublicPluginStart } from '../../../../src/plugins/data_views/public'; import type { DiscoverStart } from '../../../../src/plugins/discover/public'; import type { EmbeddableStart } from '../../../../src/plugins/embeddable/public'; +import type { FeaturesPluginStart } from '../../features/public'; import type { HomePublicPluginSetup, HomePublicPluginStart, @@ -48,6 +49,7 @@ import { getExploratoryViewEmbeddable } from './components/shared/exploratory_vi import { createExploratoryViewUrl } from './components/shared/exploratory_view/configurations/utils'; import { createUseRulesLink } from './hooks/create_use_rules_link'; import getAppDataView from './utils/observability_data_views/get_app_data_view'; +import { KibanaFeature } from '../../features/common'; export type ObservabilityPublicSetup = ReturnType; @@ -66,6 +68,8 @@ export interface ObservabilityPublicPluginsStart { dataViews: DataViewsPublicPluginStart; lens: LensPublicStart; discover: DiscoverStart; + features: FeaturesPluginStart; + kibanaFeatures: KibanaFeature[]; } export type ObservabilityPublicStart = ReturnType; @@ -146,6 +150,15 @@ export class Plugin const { renderApp } = await import('./application'); // Get start services const [coreStart, pluginsStart, { navigation }] = await coreSetup.getStartServices(); + // The `/api/features` endpoint requires the "Global All" Kibana privilege. Users with a + // subset of this privilege are not authorized to access this endpoint and will receive a 404 + // error that causes the Alerting view to fail to load. + let kibanaFeatures: KibanaFeature[]; + try { + kibanaFeatures = await pluginsStart.features.getFeatures(); + } catch (err) { + kibanaFeatures = []; + } return renderApp({ config, @@ -154,6 +167,7 @@ export class Plugin appMountParameters: params, observabilityRuleTypeRegistry, ObservabilityPageTemplate: navigation.PageTemplate, + kibanaFeatures, }); }; diff --git a/x-pack/plugins/observability/public/utils/test_helper.tsx b/x-pack/plugins/observability/public/utils/test_helper.tsx index 4dd67ff290886..b8d16f481c499 100644 --- a/x-pack/plugins/observability/public/utils/test_helper.tsx +++ b/x-pack/plugins/observability/public/utils/test_helper.tsx @@ -46,6 +46,7 @@ export const render = (component: React.ReactNode) => { config, observabilityRuleTypeRegistry, ObservabilityPageTemplate: KibanaPageTemplate, + kibanaFeatures: [], }} > {component} From 94858d74493b447a965caef7aac6029d629770e3 Mon Sep 17 00:00:00 2001 From: Julia Bardi <90178898+juliaElastic@users.noreply.github.com> Date: Mon, 28 Mar 2022 15:55:42 +0200 Subject: [PATCH 015/160] fixed openapi enrollment_api_keys (#128610) --- .../plugins/fleet/common/openapi/bundled.json | 38 ++++++------------- .../plugins/fleet/common/openapi/bundled.yaml | 23 +++-------- .../get_enrollment_api_keys_response.yaml | 15 -------- .../paths/enrollment_api_keys@{key_id}.yaml | 7 +++- 4 files changed, 23 insertions(+), 60 deletions(-) delete mode 100644 x-pack/plugins/fleet/common/openapi/components/schemas/get_enrollment_api_keys_response.yaml diff --git a/x-pack/plugins/fleet/common/openapi/bundled.json b/x-pack/plugins/fleet/common/openapi/bundled.json index e9bb796626f58..dfc257b2bfe1e 100644 --- a/x-pack/plugins/fleet/common/openapi/bundled.json +++ b/x-pack/plugins/fleet/common/openapi/bundled.json @@ -1157,7 +1157,7 @@ "schema": { "type": "array" }, - "name": "agentsIds", + "name": "agentsId", "in": "query", "required": true } @@ -2302,7 +2302,15 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/get_enrollment_api_keys_response" + "type": "object", + "properties": { + "item": { + "$ref": "#/components/schemas/enrollment_api_key" + } + }, + "required": [ + "item" + ] } } } @@ -3586,7 +3594,7 @@ "lens", "ml-module", "security-rule", - "csp-rule-template" + "csp_rule_template" ] }, "elasticsearch_asset_type": { @@ -4152,30 +4160,6 @@ "created_at" ] }, - "get_enrollment_api_keys_response": { - "title": "Bulk install packages response", - "type": "object", - "properties": { - "list": { - "type": "array", - "deprecated": true, - "properties": { - "items": { - "$ref": "#/components/schemas/enrollment_api_key" - } - } - }, - "item": { - "type": "array", - "items": { - "$ref": "#/components/schemas/enrollment_api_key" - } - } - }, - "required": [ - "item" - ] - }, "upgrade_diff": { "title": "Package policy Upgrade dryrun", "type": "array", diff --git a/x-pack/plugins/fleet/common/openapi/bundled.yaml b/x-pack/plugins/fleet/common/openapi/bundled.yaml index f7941f863c120..d91ebd515600d 100644 --- a/x-pack/plugins/fleet/common/openapi/bundled.yaml +++ b/x-pack/plugins/fleet/common/openapi/bundled.yaml @@ -1412,7 +1412,12 @@ paths: content: application/json: schema: - $ref: '#/components/schemas/get_enrollment_api_keys_response' + type: object + properties: + item: + $ref: '#/components/schemas/enrollment_api_key' + required: + - item operationId: get-enrollment-api-key delete: summary: Enrollment API Key - Delete @@ -2613,22 +2618,6 @@ components: - api_key - active - created_at - get_enrollment_api_keys_response: - title: Bulk install packages response - type: object - properties: - list: - type: array - deprecated: true - properties: - items: - $ref: '#/components/schemas/enrollment_api_key' - item: - type: array - items: - $ref: '#/components/schemas/enrollment_api_key' - required: - - item upgrade_diff: title: Package policy Upgrade dryrun type: array diff --git a/x-pack/plugins/fleet/common/openapi/components/schemas/get_enrollment_api_keys_response.yaml b/x-pack/plugins/fleet/common/openapi/components/schemas/get_enrollment_api_keys_response.yaml deleted file mode 100644 index c8a121a6ffee3..0000000000000 --- a/x-pack/plugins/fleet/common/openapi/components/schemas/get_enrollment_api_keys_response.yaml +++ /dev/null @@ -1,15 +0,0 @@ -title: Bulk install packages response -type: object -properties: - list: - type: array - deprecated: true - properties: - items: - $ref: ./enrollment_api_key.yaml - item: - type: array - items: - $ref: ./enrollment_api_key.yaml -required: - - item diff --git a/x-pack/plugins/fleet/common/openapi/paths/enrollment_api_keys@{key_id}.yaml b/x-pack/plugins/fleet/common/openapi/paths/enrollment_api_keys@{key_id}.yaml index f5e0905464346..37c390897ef67 100644 --- a/x-pack/plugins/fleet/common/openapi/paths/enrollment_api_keys@{key_id}.yaml +++ b/x-pack/plugins/fleet/common/openapi/paths/enrollment_api_keys@{key_id}.yaml @@ -13,7 +13,12 @@ get: content: application/json: schema: - $ref: ../components/schemas/get_enrollment_api_keys_response.yaml + type: object + properties: + item: + $ref: ../components/schemas/enrollment_api_key.yaml + required: + - item operationId: get-enrollment-api-key delete: summary: Enrollment API Key - Delete From a0518b61ea1303e834c2ffaa661ff5ab3422114b Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Mon, 28 Mar 2022 15:57:17 +0200 Subject: [PATCH 016/160] [Lens] Add suffix formatter (#128246) --- .../format_column/format_column.test.ts | 46 +++++++++++++++++++ .../format_column/format_column_fn.ts | 20 ++++++-- .../common/expressions/format_column/index.ts | 5 ++ .../lens/common/suffix_formatter/index.ts | 2 +- .../dimension_panel/format_selector.test.tsx | 25 +++++++++- .../dimension_panel/format_selector.tsx | 44 +++++++++++++++++- .../operations/definitions/cardinality.tsx | 4 +- .../operations/definitions/column_types.ts | 5 +- .../operations/definitions/count.tsx | 4 +- .../operations/definitions/formula/math.tsx | 9 +--- .../operations/definitions/last_value.tsx | 9 +--- .../operations/definitions/metrics.tsx | 8 +++- .../operations/definitions/static_value.tsx | 13 +++--- .../operations/definitions/terms/types.ts | 9 +--- .../indexpattern_datasource/to_expression.ts | 4 ++ 15 files changed, 164 insertions(+), 43 deletions(-) diff --git a/x-pack/plugins/lens/common/expressions/format_column/format_column.test.ts b/x-pack/plugins/lens/common/expressions/format_column/format_column.test.ts index 17192103efaae..d3e074d4cdafc 100644 --- a/x-pack/plugins/lens/common/expressions/format_column/format_column.test.ts +++ b/x-pack/plugins/lens/common/expressions/format_column/format_column.test.ts @@ -63,6 +63,26 @@ describe('format_column', () => { }); }); + it('wraps in suffix formatter if provided', async () => { + datatable.columns[0].meta.params = { id: 'myformatter', params: {} }; + const result = await fn(datatable, { + columnId: 'test', + format: 'number', + decimals: 5, + suffix: 'ABC', + }); + expect(result.columns[0].meta.params).toEqual({ + id: 'suffix', + params: { + suffixString: 'ABC', + id: 'number', + params: { + pattern: '0,0.00000', + }, + }, + }); + }); + it('has special handling for 0 decimals', async () => { datatable.columns[0].meta.params = { id: 'myformatter', params: {} }; const result = await fn(datatable, { columnId: 'test', format: 'number', decimals: 0 }); @@ -140,6 +160,32 @@ describe('format_column', () => { }); }); + it('double-nests suffix formatters', async () => { + datatable.columns[0].meta.params = { + id: 'suffix', + params: { suffixString: 'ABC', id: 'myformatter', params: { innerParam: 456 } }, + }; + const result = await fn(datatable, { + columnId: 'test', + format: '', + parentFormat: JSON.stringify({ id: 'suffix', params: { suffixString: 'DEF' } }), + }); + expect(result.columns[0].meta.params).toEqual({ + id: 'suffix', + params: { + suffixString: 'DEF', + id: 'suffix', + params: { + suffixString: 'ABC', + id: 'myformatter', + params: { + innerParam: 456, + }, + }, + }, + }); + }); + it('overwrites format with well known pattern including decimals', async () => { datatable.columns[0].meta.params = { id: 'previousWrapper', diff --git a/x-pack/plugins/lens/common/expressions/format_column/format_column_fn.ts b/x-pack/plugins/lens/common/expressions/format_column/format_column_fn.ts index 93b54e777b645..183ec74ac301d 100644 --- a/x-pack/plugins/lens/common/expressions/format_column/format_column_fn.ts +++ b/x-pack/plugins/lens/common/expressions/format_column/format_column_fn.ts @@ -5,6 +5,7 @@ * 2.0. */ +import { SerializedFieldFormat } from 'src/plugins/field_formats/common'; import { supportedFormats } from './supported_formats'; import type { DatatableColumn } from '../../../../../../src/plugins/expressions'; import type { FormatColumnArgs } from './index'; @@ -12,7 +13,8 @@ import type { FormatColumnExpressionFunction } from './types'; function isNestedFormat(params: DatatableColumn['meta']['params']) { // if there is a nested params object with an id, it's a nested format - return !!params?.params?.id; + // suffix formatters do not count as nested + return !!params?.params?.id && params.id !== 'suffix'; } function withParams(col: DatatableColumn, params: Record) { @@ -21,17 +23,27 @@ function withParams(col: DatatableColumn, params: Record) { export const formatColumnFn: FormatColumnExpressionFunction['fn'] = ( input, - { format, columnId, decimals, parentFormat }: FormatColumnArgs + { format, columnId, decimals, suffix, parentFormat }: FormatColumnArgs ) => ({ ...input, columns: input.columns.map((col) => { if (col.id === columnId) { if (!parentFormat) { if (supportedFormats[format]) { - return withParams(col, { + let serializedFormat: SerializedFieldFormat = { id: format, params: { pattern: supportedFormats[format].decimalsToPattern(decimals) }, - }); + }; + if (suffix) { + serializedFormat = { + id: 'suffix', + params: { + ...serializedFormat, + suffixString: suffix, + }, + }; + } + return withParams(col, serializedFormat as Record); } else if (format) { return withParams(col, { id: format }); } else { diff --git a/x-pack/plugins/lens/common/expressions/format_column/index.ts b/x-pack/plugins/lens/common/expressions/format_column/index.ts index 0fc99ff8f7089..2a6721ad993b7 100644 --- a/x-pack/plugins/lens/common/expressions/format_column/index.ts +++ b/x-pack/plugins/lens/common/expressions/format_column/index.ts @@ -11,6 +11,7 @@ export interface FormatColumnArgs { format: string; columnId: string; decimals?: number; + suffix?: string; parentFormat?: string; } @@ -33,6 +34,10 @@ export const formatColumn: FormatColumnExpressionFunction = { types: ['number'], help: '', }, + suffix: { + types: ['string'], + help: '', + }, parentFormat: { types: ['string'], help: '', diff --git a/x-pack/plugins/lens/common/suffix_formatter/index.ts b/x-pack/plugins/lens/common/suffix_formatter/index.ts index 4fa6457f0125d..d2af0df25f132 100644 --- a/x-pack/plugins/lens/common/suffix_formatter/index.ts +++ b/x-pack/plugins/lens/common/suffix_formatter/index.ts @@ -49,7 +49,7 @@ export function getSuffixFormatter(getFormatFactory: () => FormatFactory): Field textConvert = (val: unknown) => { const unit = this.param('unit') as TimeScaleUnit | undefined; - const suffix = unit ? unitSuffixes[unit] : undefined; + const suffix = unit ? unitSuffixes[unit] : this.param('suffixString'); const nestedFormatter = this.param('id'); const nestedParams = this.param('params'); diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.test.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.test.tsx index 1321d765e119f..60fdb382322a6 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.test.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.test.tsx @@ -6,11 +6,20 @@ */ import React from 'react'; -import { shallow } from 'enzyme'; +import { mount, shallow } from 'enzyme'; import { FormatSelector } from './format_selector'; import { act } from 'react-dom/test-utils'; import { GenericIndexPatternColumn } from '../..'; +jest.mock('lodash', () => { + const original = jest.requireActual('lodash'); + + return { + ...original, + debounce: (fn: unknown) => fn, + }; +}); + const bytesColumn: GenericIndexPatternColumn = { label: 'Max of bytes', dataType: 'number', @@ -63,4 +72,18 @@ describe('FormatSelector', () => { }); expect(props.onChange).toBeCalledWith({ id: 'bytes', params: { decimals: 0 } }); }); + it('updates the suffix', async () => { + const props = getDefaultProps(); + const component = mount(); + await act(async () => { + component + .find('[data-test-subj="indexPattern-dimension-formatSuffix"]') + .last() + .prop('onChange')!({ + currentTarget: { value: 'GB' }, + } as React.ChangeEvent); + }); + component.update(); + expect(props.onChange).toBeCalledWith({ id: 'bytes', params: { suffix: 'GB' } }); + }); }); diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.tsx index efe7966870531..49231e64d53be 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/format_selector.tsx @@ -7,9 +7,10 @@ import React, { useCallback, useMemo, useState } from 'react'; import { i18n } from '@kbn/i18n'; -import { EuiFormRow, EuiComboBox, EuiSpacer, EuiRange } from '@elastic/eui'; +import { EuiFormRow, EuiComboBox, EuiSpacer, EuiRange, EuiFieldText } from '@elastic/eui'; import { GenericIndexPatternColumn } from '../indexpattern'; import { isColumnFormatted } from '../operations/definitions/helpers'; +import { useDebouncedValue } from '../../shared_components'; const supportedFormats: Record = { number: { @@ -46,6 +47,10 @@ const decimalsLabel = i18n.translate('xpack.lens.indexPattern.decimalPlacesLabel defaultMessage: 'Decimals', }); +const suffixLabel = i18n.translate('xpack.lens.indexPattern.suffixLabel', { + defaultMessage: 'Suffix', +}); + interface FormatSelectorProps { selectedColumn: GenericIndexPatternColumn; onChange: (newFormat?: { id: string; params?: Record }) => void; @@ -62,6 +67,30 @@ export function FormatSelector(props: FormatSelectorProps) { const [decimals, setDecimals] = useState(currentFormat?.params?.decimals ?? 2); + const onChangeSuffix = useCallback( + (suffix: string) => { + if (!currentFormat) { + return; + } + onChange({ + id: currentFormat.id, + params: { + ...currentFormat.params, + suffix, + }, + }); + }, + [currentFormat, onChange] + ); + + const { handleInputChange: setSuffix, inputValue: suffix } = useDebouncedValue( + { + onChange: onChangeSuffix, + value: currentFormat?.params?.suffix ?? '', + }, + { allowFalsyValue: true } + ); + const selectedFormat = currentFormat?.id ? supportedFormats[currentFormat.id] : undefined; const stableOptions = useMemo( () => [ @@ -135,6 +164,7 @@ export function FormatSelector(props: FormatSelectorProps) { onChange({ id: currentFormat.id, params: { + ...currentFormat.params, decimals: validatedValue, }, }); @@ -145,6 +175,18 @@ export function FormatSelector(props: FormatSelectorProps) { prepend={decimalsLabel} aria-label={decimalsLabel} /> + + { + setSuffix(e.currentTarget.value); + }} + data-test-subj="indexPattern-dimension-formatSuffix" + compressed + fullWidth + prepend={suffixLabel} + aria-label={suffixLabel} + /> ) : null}
diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/cardinality.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/cardinality.tsx index 8490b48ad320e..e65d89547d567 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/cardinality.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/cardinality.tsx @@ -12,7 +12,7 @@ import { euiThemeVars } from '@kbn/ui-theme'; import { AggFunctionsMapping } from '../../../../../../../src/plugins/data/public'; import { buildExpressionFunction } from '../../../../../../../src/plugins/expressions/public'; import { OperationDefinition, ParamEditorProps } from './index'; -import { FieldBasedIndexPatternColumn, FormatParams } from './column_types'; +import { FieldBasedIndexPatternColumn, ValueFormatConfig } from './column_types'; import { getFormatFromPreviousColumn, @@ -60,7 +60,7 @@ export interface CardinalityIndexPatternColumn extends FieldBasedIndexPatternCol operationType: typeof OPERATION_TYPE; params?: { emptyAsNull?: boolean; - format?: FormatParams; + format?: ValueFormatConfig; }; } diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/column_types.ts b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/column_types.ts index 333312116949f..029f2b7bed7de 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/column_types.ts +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/column_types.ts @@ -19,17 +19,18 @@ export interface BaseIndexPatternColumn extends Operation { timeShift?: string; } -export interface FormatParams { +export interface ValueFormatConfig { id: string; params?: { decimals: number; + suffix?: string; }; } // Formatting can optionally be added to any column export interface FormattedIndexPatternColumn extends BaseIndexPatternColumn { params?: { - format?: FormatParams; + format?: ValueFormatConfig; }; } diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/count.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/count.tsx index 7ecd5a4970c95..0643e6b2ca365 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/count.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/count.tsx @@ -12,7 +12,7 @@ import { EuiSwitch } from '@elastic/eui'; import { AggFunctionsMapping } from '../../../../../../../src/plugins/data/public'; import { buildExpressionFunction } from '../../../../../../../src/plugins/expressions/public'; import { OperationDefinition, ParamEditorProps } from './index'; -import { FieldBasedIndexPatternColumn, FormatParams } from './column_types'; +import { FieldBasedIndexPatternColumn, ValueFormatConfig } from './column_types'; import { IndexPatternField } from '../../types'; import { getInvalidFieldMessage, @@ -36,7 +36,7 @@ export type CountIndexPatternColumn = FieldBasedIndexPatternColumn & { operationType: 'count'; params?: { emptyAsNull?: boolean; - format?: FormatParams; + format?: ValueFormatConfig; }; }; diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/math.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/math.tsx index 7aae35f496923..4797ac348c71f 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/math.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/math.tsx @@ -7,7 +7,7 @@ import type { TinymathAST } from '@kbn/tinymath'; import { OperationDefinition } from '../index'; -import { ReferenceBasedIndexPatternColumn } from '../column_types'; +import { ValueFormatConfig, ReferenceBasedIndexPatternColumn } from '../column_types'; import { IndexPattern } from '../../../types'; export interface MathIndexPatternColumn extends ReferenceBasedIndexPatternColumn { @@ -15,12 +15,7 @@ export interface MathIndexPatternColumn extends ReferenceBasedIndexPatternColumn params: { tinymathAst: TinymathAST | string; // last value on numeric fields can be formatted - format?: { - id: string; - params?: { - decimals: number; - }; - }; + format?: ValueFormatConfig; }; } diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/last_value.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/last_value.tsx index 1ebbf6d87b92f..b8fe5a1584d35 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/last_value.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/last_value.tsx @@ -18,7 +18,7 @@ import { import { AggFunctionsMapping } from '../../../../../../../src/plugins/data/public'; import { buildExpressionFunction } from '../../../../../../../src/plugins/expressions/public'; import { OperationDefinition } from './index'; -import { FieldBasedIndexPatternColumn } from './column_types'; +import { FieldBasedIndexPatternColumn, ValueFormatConfig } from './column_types'; import { IndexPatternField, IndexPattern } from '../../types'; import { adjustColumnReferencesForChangedColumn, updateColumnParam } from '../layer_helpers'; import { DataType } from '../../../types'; @@ -108,12 +108,7 @@ export interface LastValueIndexPatternColumn extends FieldBasedIndexPatternColum sortField: string; showArrayValues: boolean; // last value on numeric fields can be formatted - format?: { - id: string; - params?: { - decimals: number; - }; - }; + format?: ValueFormatConfig; }; } diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx index 2b46e52defdba..438902962fbcf 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx @@ -19,7 +19,11 @@ import { combineErrorMessages, isColumnOfType, } from './helpers'; -import { FieldBasedIndexPatternColumn, BaseIndexPatternColumn, FormatParams } from './column_types'; +import { + FieldBasedIndexPatternColumn, + BaseIndexPatternColumn, + ValueFormatConfig, +} from './column_types'; import { adjustTimeScaleLabelSuffix, adjustTimeScaleOnOtherColumnChange, @@ -31,7 +35,7 @@ type MetricColumn = FieldBasedIndexPatternColumn & { operationType: T; params?: { emptyAsNull?: boolean; - format?: FormatParams; + format?: ValueFormatConfig; }; }; diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/static_value.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/static_value.tsx index d41ddaf26fb3f..39122808c9c0b 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/static_value.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/static_value.tsx @@ -8,7 +8,11 @@ import React, { useCallback } from 'react'; import { i18n } from '@kbn/i18n'; import { EuiFieldNumber, EuiFormLabel, EuiSpacer } from '@elastic/eui'; import { OperationDefinition } from './index'; -import { ReferenceBasedIndexPatternColumn, GenericIndexPatternColumn } from './column_types'; +import { + ReferenceBasedIndexPatternColumn, + GenericIndexPatternColumn, + ValueFormatConfig, +} from './column_types'; import type { IndexPattern } from '../../types'; import { useDebouncedValue } from '../../../shared_components'; import { getFormatFromPreviousColumn, isValidNumber } from './helpers'; @@ -37,12 +41,7 @@ export interface StaticValueIndexPatternColumn extends ReferenceBasedIndexPatter operationType: 'static_value'; params: { value?: string; - format?: { - id: string; - params?: { - decimals: number; - }; - }; + format?: ValueFormatConfig; }; } diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/terms/types.ts b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/terms/types.ts index 1284870327653..eb4425987cc31 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/terms/types.ts +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/terms/types.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { FieldBasedIndexPatternColumn } from '../column_types'; +import { FieldBasedIndexPatternColumn, ValueFormatConfig } from '../column_types'; export interface TermsIndexPatternColumn extends FieldBasedIndexPatternColumn { operationType: 'terms'; @@ -22,12 +22,7 @@ export interface TermsIndexPatternColumn extends FieldBasedIndexPatternColumn { missingBucket?: boolean; secondaryFields?: string[]; // Terms on numeric fields can be formatted - format?: { - id: string; - params?: { - decimals: number; - }; - }; + format?: ValueFormatConfig; parentFormat?: { id: string; }; diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/to_expression.ts b/x-pack/plugins/lens/public/indexpattern_datasource/to_expression.ts index f9fe8701949e1..f229407ce23ff 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/to_expression.ts +++ b/x-pack/plugins/lens/public/indexpattern_datasource/to_expression.ts @@ -194,6 +194,10 @@ function getExpressionForLayer( format: format ? [format.id] : [''], columnId: [id], decimals: typeof format?.params?.decimals === 'number' ? [format.params.decimals] : [], + suffix: + format?.params && 'suffix' in format.params && format.params.suffix + ? [format.params.suffix] + : [], parentFormat: parentFormat ? [JSON.stringify(parentFormat)] : [], }, }; From 61955d53f68d2a0c54dcb4ce5480d200356c5fc5 Mon Sep 17 00:00:00 2001 From: Pete Harverson Date: Mon, 28 Mar 2022 15:10:47 +0100 Subject: [PATCH 017/160] [ML][File upload] Migrate IndexPattern service usage to DataView service (#128600) * [ML][File upload] Migrate IndexPattern service usage to DataView service * [ML][File upload] Update translations * [ML][File upload] Fix API tests --- .../file_data_visualizer_view.js | 2 +- .../components/import_view/import_view.js | 2 +- .../plugins/file_upload/public/api/index.ts | 2 +- .../public/components/geo_upload_wizard.tsx | 28 +++++++++---------- .../components/import_complete_view.tsx | 8 +++--- .../file_upload/public/kibana_services.ts | 2 +- .../file_upload/public/validate_index_name.ts | 8 +++--- .../file_upload/server/capabilities.ts | 2 +- .../file_upload/server/check_privileges.ts | 6 ++-- x-pack/plugins/file_upload/server/routes.ts | 6 ++-- .../wizards/file_upload_wizard/config.tsx | 2 +- .../new_vector_layer_wizard/config.tsx | 2 +- .../new_vector_layer_wizard/wizard.tsx | 2 +- .../translations/translations/fr-FR.json | 2 -- .../translations/translations/ja-JP.json | 4 --- .../translations/translations/zh-CN.json | 4 --- .../apis/file_upload/has_import_permission.ts | 10 +++---- 17 files changed, 41 insertions(+), 51 deletions(-) diff --git a/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/file_data_visualizer_view/file_data_visualizer_view.js b/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/file_data_visualizer_view/file_data_visualizer_view.js index 5d5f07f2279c9..ae0a979008eff 100644 --- a/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/file_data_visualizer_view/file_data_visualizer_view.js +++ b/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/file_data_visualizer_view/file_data_visualizer_view.js @@ -74,7 +74,7 @@ export class FileDataVisualizerView extends Component { // note, calling hasImportPermission with no arguments just checks the // cluster privileges, the user will still need index privileges to create and ingest const hasPermissionToImport = await this.props.fileUpload.hasImportPermission({ - checkCreateIndexPattern: false, + checkCreateDataView: false, checkHasManagePipeline: true, }); this.setState({ hasPermissionToImport }); diff --git a/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/import_view/import_view.js b/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/import_view/import_view.js index b62e43c5fc2e2..c5021f930c942 100644 --- a/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/import_view/import_view.js +++ b/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/components/import_view/import_view.js @@ -116,7 +116,7 @@ export class ImportView extends Component { // check to see if the user has permission to create and ingest data into the specified index if ( (await fileUpload.hasImportPermission({ - checkCreateIndexPattern: createDataView, + checkCreateDataView: createDataView, checkHasManagePipeline: true, indexName: index, })) === false diff --git a/x-pack/plugins/file_upload/public/api/index.ts b/x-pack/plugins/file_upload/public/api/index.ts index 7224eacc08e42..4284102b26674 100644 --- a/x-pack/plugins/file_upload/public/api/index.ts +++ b/x-pack/plugins/file_upload/public/api/index.ts @@ -42,7 +42,7 @@ export async function importerFactory( } interface HasImportPermissionParams { - checkCreateIndexPattern: boolean; + checkCreateDataView: boolean; checkHasManagePipeline: boolean; indexName?: string; } diff --git a/x-pack/plugins/file_upload/public/components/geo_upload_wizard.tsx b/x-pack/plugins/file_upload/public/components/geo_upload_wizard.tsx index 8c876c84b3b77..24fcbdd7e1ed0 100644 --- a/x-pack/plugins/file_upload/public/components/geo_upload_wizard.tsx +++ b/x-pack/plugins/file_upload/public/components/geo_upload_wizard.tsx @@ -8,7 +8,7 @@ import React, { Component, Fragment } from 'react'; import { i18n } from '@kbn/i18n'; import { EuiProgress, EuiText } from '@elastic/eui'; -import { getIndexPatternService } from '../kibana_services'; +import { getDataViewsService } from '../kibana_services'; import { GeoUploadForm, OnFileSelectParameters } from './geo_upload_form'; import { ImportCompleteView } from './import_complete_view'; import { ES_FIELD_TYPES } from '../../../../../src/plugins/data/public'; @@ -38,7 +38,7 @@ interface State { importResults?: ImportResults; indexName: string; indexNameError?: string; - indexPatternResp?: object; + dataViewResp?: object; phase: PHASE; } @@ -81,7 +81,7 @@ export class GeoUploadWizard extends Component // check permissions // const canImport = await hasImportPermission({ - checkCreateIndexPattern: true, + checkCreateDataView: true, checkHasManagePipeline: false, indexName: this.state.indexName, }); @@ -179,24 +179,24 @@ export class GeoUploadWizard extends Component // this.setState({ importResults, - importStatus: i18n.translate('xpack.fileUpload.geoUploadWizard.creatingIndexPattern', { + importStatus: i18n.translate('xpack.fileUpload.geoUploadWizard.creatingDataView', { defaultMessage: 'Creating data view: {indexName}', values: { indexName: this.state.indexName }, }), }); - let indexPattern; + let dataView; let results: FileUploadGeoResults | undefined; try { - indexPattern = await getIndexPatternService().createAndSave( + dataView = await getDataViewsService().createAndSave( { title: this.state.indexName, }, true ); - if (!indexPattern.id) { + if (!dataView.id) { throw new Error('id not provided'); } - const geoField = indexPattern.fields.find((field) => + const geoField = dataView.fields.find((field) => [ES_FIELD_TYPES.GEO_POINT as string, ES_FIELD_TYPES.GEO_SHAPE as string].includes( field.type ) @@ -205,7 +205,7 @@ export class GeoUploadWizard extends Component throw new Error('geo field not created'); } results = { - indexPatternId: indexPattern.id, + indexPatternId: dataView.id, geoFieldName: geoField.name, geoFieldType: geoField.type as ES_FIELD_TYPES.GEO_POINT | ES_FIELD_TYPES.GEO_SHAPE, docCount: importResults.docCount !== undefined ? importResults.docCount : 0, @@ -213,7 +213,7 @@ export class GeoUploadWizard extends Component } catch (error) { if (this._isMounted) { this.setState({ - importStatus: i18n.translate('xpack.fileUpload.geoUploadWizard.indexPatternError', { + importStatus: i18n.translate('xpack.fileUpload.geoUploadWizard.dataViewError', { defaultMessage: 'Unable to create data view', }), phase: PHASE.COMPLETE, @@ -230,10 +230,10 @@ export class GeoUploadWizard extends Component // Successful import // this.setState({ - indexPatternResp: { + dataViewResp: { success: true, - id: indexPattern.id, - fields: indexPattern.fields, + id: dataView.id, + fields: dataView.fields, }, phase: PHASE.COMPLETE, importStatus: '', @@ -297,7 +297,7 @@ export class GeoUploadWizard extends Component return ( diff --git a/x-pack/plugins/file_upload/public/components/import_complete_view.tsx b/x-pack/plugins/file_upload/public/components/import_complete_view.tsx index 09f2ad96d11f4..5a7483328112e 100644 --- a/x-pack/plugins/file_upload/public/components/import_complete_view.tsx +++ b/x-pack/plugins/file_upload/public/components/import_complete_view.tsx @@ -30,7 +30,7 @@ const services = { interface Props { failedPermissionCheck: boolean; importResults?: ImportResults; - indexPatternResp?: object; + dataViewResp?: object; indexName: string; } @@ -213,11 +213,11 @@ export class ImportCompleteView extends Component { 'indexRespCopyButton' )} {this._renderCodeEditor( - this.props.indexPatternResp, - i18n.translate('xpack.fileUpload.importComplete.indexPatternResponse', { + this.props.dataViewResp, + i18n.translate('xpack.fileUpload.importComplete.dataViewResponse', { defaultMessage: 'Data view response', }), - 'indexPatternRespCopyButton' + 'dataViewRespCopyButton' )} {this._renderIndexManagementMsg()} diff --git a/x-pack/plugins/file_upload/public/kibana_services.ts b/x-pack/plugins/file_upload/public/kibana_services.ts index dfe2785e7a2bc..76dd6f660da51 100644 --- a/x-pack/plugins/file_upload/public/kibana_services.ts +++ b/x-pack/plugins/file_upload/public/kibana_services.ts @@ -16,7 +16,7 @@ export function setStartServices(core: CoreStart, plugins: FileUploadStartDepend } export const getDocLinks = () => coreStart.docLinks; -export const getIndexPatternService = () => pluginsStart.data.indexPatterns; +export const getDataViewsService = () => pluginsStart.data.dataViews; export const getHttp = () => coreStart.http; export const getSavedObjectsClient = () => coreStart.savedObjects.client; export const getUiSettings = () => coreStart.uiSettings; diff --git a/x-pack/plugins/file_upload/public/validate_index_name.ts b/x-pack/plugins/file_upload/public/validate_index_name.ts index 39cffdf63580e..4c3c7747c5fd9 100644 --- a/x-pack/plugins/file_upload/public/validate_index_name.ts +++ b/x-pack/plugins/file_upload/public/validate_index_name.ts @@ -6,7 +6,7 @@ */ import { i18n } from '@kbn/i18n'; -import { getIndexPatternService } from './kibana_services'; +import { getDataViewsService } from './kibana_services'; import { checkIndexExists } from './api'; export function checkIndexPatternValid(name: string) { @@ -35,9 +35,9 @@ export const validateIndexName = async (indexName: string) => { }); } - const indexPatternNames = await getIndexPatternService().getTitles(); - if (indexPatternNames.includes(indexName)) { - return i18n.translate('xpack.fileUpload.indexPatternAlreadyExistsErrorMessage', { + const dataViewNames = await getDataViewsService().getTitles(); + if (dataViewNames.includes(indexName)) { + return i18n.translate('xpack.fileUpload.dataViewAlreadyExistsErrorMessage', { defaultMessage: 'Data view already exists.', }); } diff --git a/x-pack/plugins/file_upload/server/capabilities.ts b/x-pack/plugins/file_upload/server/capabilities.ts index 17880b98150d6..585aca196c66e 100644 --- a/x-pack/plugins/file_upload/server/capabilities.ts +++ b/x-pack/plugins/file_upload/server/capabilities.ts @@ -30,7 +30,7 @@ export const setupCapabilities = ( const { hasImportPermission } = await checkFileUploadPrivileges({ authorization: security?.authz, request, - checkCreateIndexPattern: true, + checkCreateDataView: true, checkHasManagePipeline: false, }); diff --git a/x-pack/plugins/file_upload/server/check_privileges.ts b/x-pack/plugins/file_upload/server/check_privileges.ts index 42cc53f693fec..5f8b521506840 100644 --- a/x-pack/plugins/file_upload/server/check_privileges.ts +++ b/x-pack/plugins/file_upload/server/check_privileges.ts @@ -15,7 +15,7 @@ interface Deps { 'mode' | 'actions' | 'checkPrivilegesDynamicallyWithRequest' >; checkHasManagePipeline: boolean; - checkCreateIndexPattern: boolean; + checkCreateDataView: boolean; indexName?: string; } @@ -23,7 +23,7 @@ export const checkFileUploadPrivileges = async ({ request, authorization, checkHasManagePipeline, - checkCreateIndexPattern, + checkCreateDataView, indexName, }: Deps) => { const requiresAuthz = authorization?.mode.useRbacForRequest(request) ?? false; @@ -42,7 +42,7 @@ export const checkFileUploadPrivileges = async ({ index: indexName ? { [indexName]: ['create', 'create_index'] } : {}, }, }; - if (checkCreateIndexPattern) { + if (checkCreateDataView) { checkPrivilegesPayload.kibana = [ authorization.actions.savedObject.get('index-pattern', 'create'), ]; diff --git a/x-pack/plugins/file_upload/server/routes.ts b/x-pack/plugins/file_upload/server/routes.ts index eeb22faefb1ca..82c66d9c73313 100644 --- a/x-pack/plugins/file_upload/server/routes.ts +++ b/x-pack/plugins/file_upload/server/routes.ts @@ -50,7 +50,7 @@ export function fileUploadRoutes(coreSetup: CoreSetup, logge validate: { query: schema.object({ indexName: schema.maybe(schema.string()), - checkCreateIndexPattern: schema.boolean(), + checkCreateDataView: schema.boolean(), checkHasManagePipeline: schema.boolean(), }), }, @@ -58,13 +58,13 @@ export function fileUploadRoutes(coreSetup: CoreSetup, logge async (context, request, response) => { try { const [, pluginsStart] = await coreSetup.getStartServices(); - const { indexName, checkCreateIndexPattern, checkHasManagePipeline } = request.query; + const { indexName, checkCreateDataView, checkHasManagePipeline } = request.query; const { hasImportPermission } = await checkFileUploadPrivileges({ authorization: pluginsStart.security?.authz, request, indexName, - checkCreateIndexPattern, + checkCreateDataView, checkHasManagePipeline, }); diff --git a/x-pack/plugins/maps/public/classes/layers/wizards/file_upload_wizard/config.tsx b/x-pack/plugins/maps/public/classes/layers/wizards/file_upload_wizard/config.tsx index e0852b6f9300f..fa11f192c9a99 100644 --- a/x-pack/plugins/maps/public/classes/layers/wizards/file_upload_wizard/config.tsx +++ b/x-pack/plugins/maps/public/classes/layers/wizards/file_upload_wizard/config.tsx @@ -25,7 +25,7 @@ export const uploadLayerWizardConfig: LayerWizard = { }), getIsDisabled: async () => { const hasImportPermission = await getFileUpload().hasImportPermission({ - checkCreateIndexPattern: true, + checkCreateDataView: true, checkHasManagePipeline: false, }); return !hasImportPermission; diff --git a/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/config.tsx b/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/config.tsx index c5aa0fc7db1fd..18bb3cde2ca87 100644 --- a/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/config.tsx +++ b/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/config.tsx @@ -28,7 +28,7 @@ export const newVectorLayerWizardConfig: LayerWizard = { }), getIsDisabled: async () => { const hasImportPermission = await getFileUpload().hasImportPermission({ - checkCreateIndexPattern: true, + checkCreateDataView: true, checkHasManagePipeline: false, }); return !hasImportPermission; diff --git a/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/wizard.tsx b/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/wizard.tsx index 2fd783a657034..d098984faaa7a 100644 --- a/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/wizard.tsx +++ b/x-pack/plugins/maps/public/classes/layers/wizards/new_vector_layer_wizard/wizard.tsx @@ -74,7 +74,7 @@ export class NewVectorLayerEditor extends Component { const resp = await supertestWithoutAuth .get( `/internal/file_upload/has_import_permission\ -?checkCreateIndexPattern=true\ +?checkCreateDataView=true\ &checkHasManagePipeline=true\ &indexName=${INDEX_NAME}` ) @@ -63,7 +63,7 @@ export default ({ getService }: FtrProviderContext) => { } }); - it('should return false when user can not create index pattern when checkCreateIndexPattern=true', async () => { + it('should return false when user can not create data view when checkCreateDataView=true', async () => { try { await security.role.create(IMPORTER_ROLE_NAME, {}); @@ -75,7 +75,7 @@ export default ({ getService }: FtrProviderContext) => { const resp = await supertestWithoutAuth .get( `/internal/file_upload/has_import_permission\ -?checkCreateIndexPattern=true\ +?checkCreateDataView=true\ &checkHasManagePipeline=false` ) .auth(IMPORTER_USER_NAME, IMPORT_USER_PASSWORD) @@ -102,7 +102,7 @@ export default ({ getService }: FtrProviderContext) => { const resp = await supertestWithoutAuth .get( `/internal/file_upload/has_import_permission\ -?checkCreateIndexPattern=false\ +?checkCreateDataView=false\ &checkHasManagePipeline=true` ) .auth(IMPORTER_USER_NAME, IMPORT_USER_PASSWORD) @@ -128,7 +128,7 @@ export default ({ getService }: FtrProviderContext) => { const resp = await supertestWithoutAuth .get( `/internal/file_upload/has_import_permission\ -?checkCreateIndexPattern=false\ +?checkCreateDataView=false\ &checkHasManagePipeline=false\ &indexName=${INDEX_NAME}` ) From 74fc0fb0dd4836dedeb85e07f4607fb3a811741d Mon Sep 17 00:00:00 2001 From: Dzmitry Lemechko Date: Mon, 28 Mar 2022 16:21:44 +0200 Subject: [PATCH 018/160] [load testing] add vars to disable plugins/enable shards delay aggs (#128292) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/test/load/config.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/x-pack/test/load/config.ts b/x-pack/test/load/config.ts index a243635e5ea4c..2d20806f3e9e8 100644 --- a/x-pack/test/load/config.ts +++ b/x-pack/test/load/config.ts @@ -13,6 +13,8 @@ import { GatlingTestRunner } from './runner'; // These "secret" values are intentionally written in the source. const APM_SERVER_URL = 'https://142fea2d3047486e925eb8b223559cae.apm.europe-west1.gcp.cloud.es.io'; const APM_PUBLIC_TOKEN = 'pWFFEym07AKBBhUE2i'; +const AGGS_SHARD_DELAY = process.env.LOAD_TESTING_SHARD_DELAY; +const DISABLE_PLUGINS = process.env.LOAD_TESTING_DISABLE_PLUGINS; export default async function ({ readConfigFile }: FtrConfigProviderContext) { const kibanaCommonTestsConfig = await readConfigFile( @@ -43,6 +45,8 @@ export default async function ({ readConfigFile }: FtrConfigProviderContext) { ...xpackFunctionalTestsConfig.get('kbnTestServer.sourceArgs'), '--no-base-path', '--env.name=development', + ...(!!AGGS_SHARD_DELAY ? ['--data.search.aggs.shardDelay.enabled=true'] : []), + ...(!!DISABLE_PLUGINS ? ['--plugins.initialize=false'] : []), ], env: { ELASTIC_APM_ACTIVE: process.env.ELASTIC_APM_ACTIVE, From e60a95f34741ee2900314e43f601a02ccbbb4847 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Mon, 28 Mar 2022 15:37:44 +0100 Subject: [PATCH 019/160] chore(NA): run force-install automatically when .yarn-integrity file is missing (#128631) --- packages/kbn-pm/dist/index.js | 21 +++++++++++++++++-- packages/kbn-pm/src/commands/bootstrap.ts | 14 ++++++++++--- .../kbn-pm/src/utils/bazel/yarn_integrity.ts | 16 ++++++++++++++ 3 files changed, 46 insertions(+), 5 deletions(-) diff --git a/packages/kbn-pm/dist/index.js b/packages/kbn-pm/dist/index.js index eb6ea050841f8..b086f398faea4 100644 --- a/packages/kbn-pm/dist/index.js +++ b/packages/kbn-pm/dist/index.js @@ -8921,10 +8921,11 @@ const BootstrapCommand = { ms: Date.now() - start }); } - }; // Force install is set in case a flag `--force-install` is passed into kbn bootstrap + }; // Force install is set in case a flag is passed into yarn kbn bootstrap or if the `.yarn-integrity` + // file is not found which will be indicated by the return of yarnIntegrityFileExists. - const forceInstall = !!options && options['force-install'] === true; // Install bazel machinery tools if needed + const forceInstall = !!options && options['force-install'] === true || !(await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["yarnIntegrityFileExists"])(Object(path__WEBPACK_IMPORTED_MODULE_0__["resolve"])(kibanaProjectPath, 'node_modules'))); // Install bazel machinery tools if needed await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["installBazelTools"])(rootPath); // Setup remote cache settings in .bazelrc.cache if needed @@ -52668,6 +52669,8 @@ __webpack_require__.r(__webpack_exports__); /* harmony import */ var _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(527); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "removeYarnIntegrityFileIfExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__["removeYarnIntegrityFileIfExists"]; }); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "yarnIntegrityFileExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__["yarnIntegrityFileExists"]; }); + /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License @@ -59100,6 +59103,7 @@ function observeReadable(readable) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeYarnIntegrityFileIfExists", function() { return removeYarnIntegrityFileIfExists; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "yarnIntegrityFileExists", function() { return yarnIntegrityFileExists; }); /* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4); /* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _fs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(231); @@ -59123,6 +59127,19 @@ async function removeYarnIntegrityFileIfExists(nodeModulesPath) { } catch {// no-op } } +async function yarnIntegrityFileExists(nodeModulesPath) { + try { + const nodeModulesRealPath = await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["tryRealpath"])(nodeModulesPath); + const yarnIntegrityFilePath = Object(path__WEBPACK_IMPORTED_MODULE_0__["join"])(nodeModulesRealPath, '.yarn-integrity'); // check if the file already exists + + if (await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["isFile"])(yarnIntegrityFilePath)) { + return true; + } + } catch {// no-op + } + + return false; +} /***/ }), /* 528 */ diff --git a/packages/kbn-pm/src/commands/bootstrap.ts b/packages/kbn-pm/src/commands/bootstrap.ts index 84bee5ddeceac..7b5c8c2b6b37d 100644 --- a/packages/kbn-pm/src/commands/bootstrap.ts +++ b/packages/kbn-pm/src/commands/bootstrap.ts @@ -17,7 +17,12 @@ import { ICommand } from './'; import { readYarnLock } from '../utils/yarn_lock'; import { sortPackageJson } from '../utils/sort_package_json'; import { validateDependencies } from '../utils/validate_dependencies'; -import { installBazelTools, removeYarnIntegrityFileIfExists, runBazel } from '../utils/bazel'; +import { + installBazelTools, + removeYarnIntegrityFileIfExists, + runBazel, + yarnIntegrityFileExists, +} from '../utils/bazel'; import { setupRemoteCache } from '../utils/bazel/setup_remote_cache'; export const BootstrapCommand: ICommand = { @@ -49,8 +54,11 @@ export const BootstrapCommand: ICommand = { } }; - // Force install is set in case a flag `--force-install` is passed into kbn bootstrap - const forceInstall = !!options && options['force-install'] === true; + // Force install is set in case a flag is passed into yarn kbn bootstrap or if the `.yarn-integrity` + // file is not found which will be indicated by the return of yarnIntegrityFileExists. + const forceInstall = + (!!options && options['force-install'] === true) || + !(await yarnIntegrityFileExists(resolve(kibanaProjectPath, 'node_modules'))); // Install bazel machinery tools if needed await installBazelTools(rootPath); diff --git a/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts b/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts index 1ac9bfeba1e3b..76910786898aa 100644 --- a/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts +++ b/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts @@ -22,3 +22,19 @@ export async function removeYarnIntegrityFileIfExists(nodeModulesPath: string) { // no-op } } + +export async function yarnIntegrityFileExists(nodeModulesPath: string) { + try { + const nodeModulesRealPath = await tryRealpath(nodeModulesPath); + const yarnIntegrityFilePath = join(nodeModulesRealPath, '.yarn-integrity'); + + // check if the file already exists + if (await isFile(yarnIntegrityFilePath)) { + return true; + } + } catch { + // no-op + } + + return false; +} From ec0887a94564d28b55d21f8932e6cb39f069be11 Mon Sep 17 00:00:00 2001 From: Uladzislau Lasitsa Date: Mon, 28 Mar 2022 17:39:40 +0300 Subject: [PATCH 020/160] [Gauge] Add common label (#127886) * Add common label * Fix CI * Fix text * Fix snapshot Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../__snapshots__/gauge_function.test.ts.snap | 14 +++ .../expression_functions/gauge_function.ts | 6 ++ .../common/types/expression_functions.ts | 1 + .../public/components/gauge.scss | 12 +++ .../public/components/gauge_component.tsx | 91 ++++++++++--------- .../public/__snapshots__/to_ast.test.ts.snap | 2 +- src/plugins/vis_types/gauge/public/to_ast.ts | 3 +- 7 files changed, 84 insertions(+), 45 deletions(-) create mode 100644 src/plugins/chart_expressions/expression_gauge/public/components/gauge.scss diff --git a/src/plugins/chart_expressions/expression_gauge/common/expression_functions/__snapshots__/gauge_function.test.ts.snap b/src/plugins/chart_expressions/expression_gauge/common/expression_functions/__snapshots__/gauge_function.test.ts.snap index c640ed8884d98..5bb924a71a2a1 100644 --- a/src/plugins/chart_expressions/expression_gauge/common/expression_functions/__snapshots__/gauge_function.test.ts.snap +++ b/src/plugins/chart_expressions/expression_gauge/common/expression_functions/__snapshots__/gauge_function.test.ts.snap @@ -39,6 +39,7 @@ Object { "centralMajor": "Some label", "centralMajorMode": "custom", "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -89,6 +90,7 @@ Object { "centralMajor": undefined, "centralMajorMode": "auto", "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -137,6 +139,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "auto", @@ -185,6 +188,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -233,6 +237,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -283,6 +288,7 @@ Object { "centralMajor": "Some label", "centralMajorMode": "custom", "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -333,6 +339,7 @@ Object { "centralMajor": undefined, "centralMajorMode": "auto", "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -381,6 +388,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -429,6 +437,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -477,6 +486,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -525,6 +535,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -573,6 +584,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "none", @@ -621,6 +633,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "palette", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", @@ -669,6 +682,7 @@ Object { "args": Object { "ariaLabel": undefined, "colorMode": "none", + "commonLabel": undefined, "goal": undefined, "labelMajor": "title", "labelMajorMode": "custom", diff --git a/src/plugins/chart_expressions/expression_gauge/common/expression_functions/gauge_function.ts b/src/plugins/chart_expressions/expression_gauge/common/expression_functions/gauge_function.ts index 133c8114bdb50..ba40821948526 100644 --- a/src/plugins/chart_expressions/expression_gauge/common/expression_functions/gauge_function.ts +++ b/src/plugins/chart_expressions/expression_gauge/common/expression_functions/gauge_function.ts @@ -160,6 +160,12 @@ export const gaugeFunction = (): GaugeExpressionFunctionDefinition => ({ defaultMessage: 'Enables relative precentage mode', }), }, + commonLabel: { + types: ['string'], + help: i18n.translate('expressionGauge.functions.gauge.args.commonLabel.help', { + defaultMessage: 'Specifies the common label outside the chart', + }), + }, ariaLabel: { types: ['string'], help: i18n.translate('expressionGauge.functions.gaugeChart.config.ariaLabel.help', { diff --git a/src/plugins/chart_expressions/expression_gauge/common/types/expression_functions.ts b/src/plugins/chart_expressions/expression_gauge/common/types/expression_functions.ts index 3cd6d566d4870..b6add118a6747 100644 --- a/src/plugins/chart_expressions/expression_gauge/common/types/expression_functions.ts +++ b/src/plugins/chart_expressions/expression_gauge/common/types/expression_functions.ts @@ -47,6 +47,7 @@ export interface GaugeState { shape: GaugeShape; /** @deprecated This field is deprecated and going to be removed in the futher release versions. */ percentageMode?: boolean; + commonLabel?: string; } export type GaugeArguments = GaugeState & { diff --git a/src/plugins/chart_expressions/expression_gauge/public/components/gauge.scss b/src/plugins/chart_expressions/expression_gauge/public/components/gauge.scss new file mode 100644 index 0000000000000..cb7d6718d4dcd --- /dev/null +++ b/src/plugins/chart_expressions/expression_gauge/public/components/gauge.scss @@ -0,0 +1,12 @@ +.gauge__wrapper { + flex: 1 1 0; + display: flex; + flex-direction: column; + // it is used for rendering at `Canvas`. + height: 100%; +} + +.gauge__label { + width: 100%; + text-align: center; +} diff --git a/src/plugins/chart_expressions/expression_gauge/public/components/gauge_component.tsx b/src/plugins/chart_expressions/expression_gauge/public/components/gauge_component.tsx index 9db6b81acefce..8258063dfdd69 100644 --- a/src/plugins/chart_expressions/expression_gauge/public/components/gauge_component.tsx +++ b/src/plugins/chart_expressions/expression_gauge/public/components/gauge_component.tsx @@ -34,6 +34,8 @@ import './index.scss'; import { GaugeCentralMajorMode } from '../../common/types'; import { isBulletShape, isRoundShape } from '../../common/utils'; +import './gauge.scss'; + declare global { interface Window { /** @@ -211,6 +213,7 @@ export const GaugeComponent: FC = memo( centralMajor, centralMajorMode, ticksPosition, + commonLabel, } = args; const getColor = useCallback( @@ -377,50 +380,52 @@ export const GaugeComponent: FC = memo( : {}; return ( - - - = bands[0] && goal <= bands[bands.length - 1] ? goal : undefined} - actual={actualValue} - tickValueFormatter={({ value: tickValue }) => tickFormatter.convert(tickValue)} - tooltipValueFormatter={(tooltipValue) => tickFormatter.convert(tooltipValue)} - bands={bands} - ticks={ticks} - bandFillColor={ - colorMode === GaugeColorModes.PALETTE - ? (val) => { - const value = getPreviousSectionValue(val.value, bands); - - const overridedColor = overrideColor( - value, - args.percentageMode ? bands : args.palette?.params?.stops ?? [], - args.percentageMode ? tickFormatter : undefined - ); - - if (overridedColor) { - return overridedColor; +
+ + + = bands[0] && goal <= bands[bands.length - 1] ? goal : undefined} + actual={actualValue} + tickValueFormatter={({ value: tickValue }) => tickFormatter.convert(tickValue)} + tooltipValueFormatter={(tooltipValue) => tickFormatter.convert(tooltipValue)} + bands={bands} + ticks={ticks} + bandFillColor={ + colorMode === GaugeColorModes.PALETTE + ? (val) => { + const value = getPreviousSectionValue(val.value, bands); + + const overridedColor = overrideColor( + value, + args.percentageMode ? bands : args.palette?.params?.stops ?? [], + args.percentageMode ? tickFormatter : undefined + ); + + if (overridedColor) { + return overridedColor; + } + return args.palette + ? getColor(value, args.palette, bands, args.percentageMode) ?? TRANSPARENT + : TRANSPARENT; } - - return args.palette - ? getColor(value, args.palette, bands, args.percentageMode) ?? TRANSPARENT - : TRANSPARENT; - } - : () => TRANSPARENT - } - labelMajor={labelMajorTitle ? `${labelMajorTitle}${majorExtraSpaces}` : labelMajorTitle} - labelMinor={labelMinor ? `${labelMinor}${minorExtraSpaces}` : ''} - {...extraTitles} - {...goalConfig} - /> - + : () => TRANSPARENT + } + labelMajor={labelMajorTitle ? `${labelMajorTitle}${majorExtraSpaces}` : labelMajorTitle} + labelMinor={labelMinor ? `${labelMinor}${minorExtraSpaces}` : ''} + {...extraTitles} + {...goalConfig} + /> + + {commonLabel &&
{commonLabel}
} +
); } ); diff --git a/src/plugins/vis_types/gauge/public/__snapshots__/to_ast.test.ts.snap b/src/plugins/vis_types/gauge/public/__snapshots__/to_ast.test.ts.snap index dbc909f9ede22..cd9ce5427fd6f 100644 --- a/src/plugins/vis_types/gauge/public/__snapshots__/to_ast.test.ts.snap +++ b/src/plugins/vis_types/gauge/public/__snapshots__/to_ast.test.ts.snap @@ -41,7 +41,7 @@ Object { "palette", ], "labelMajorMode": Array [ - "auto", + "none", ], "labelMinor": Array [ "some custom sublabel", diff --git a/src/plugins/vis_types/gauge/public/to_ast.ts b/src/plugins/vis_types/gauge/public/to_ast.ts index dfb483d47fd21..1e9226aa10094 100644 --- a/src/plugins/vis_types/gauge/public/to_ast.ts +++ b/src/plugins/vis_types/gauge/public/to_ast.ts @@ -67,11 +67,12 @@ export const toExpressionAst: VisToExpressionAst = (vis, params) shape: gaugeTypeToShape(gaugeType), metric: schemas.metric.map(prepareDimension), ticksPosition: scale.show ? 'auto' : 'hidden', - labelMajorMode: 'auto', + labelMajorMode: 'none', colorMode: 'palette', centralMajorMode, ...(centralMajorMode === 'custom' ? { labelMinor: style.subText } : {}), percentageMode, + commonLabel: schemas.metric?.[0]?.label, }); if (colorsRange && colorsRange.length) { From 9cd8a84f2d96103dd228dcf8e163e78dd9f769b2 Mon Sep 17 00:00:00 2001 From: Faisal Kanout Date: Mon, 28 Mar 2022 17:46:59 +0300 Subject: [PATCH 021/160] [RAC][Metrics] Add "View in App URL" {{context.viewInAppUrl}} variable to the rule templating language (#128281) * Add viewInApp URL * Mock viewInAppUrl for the tests * Remove join * Fix inventory viewInAppUrl * Extract and create getInventoryViewInAppUrl * Expose only alert_link with getInventoryViewInAppUrl * Remove unused type * Fix import path * Fix double import * Fix double import --- .../common/alerting/metrics/alert_link.ts | 48 +++++++++++++++++++ .../infra/common/alerting/metrics/index.ts | 2 + .../inventory/rule_data_formatters.ts | 41 ++-------------- .../metric_threshold/rule_data_formatters.ts | 4 +- .../server/lib/alerting/common/messages.ts | 8 ++++ .../infra/server/lib/alerting/common/utils.ts | 34 ++++++++++++- .../inventory_metric_threshold_executor.ts | 24 ++++++++-- ...er_inventory_metric_threshold_rule_type.ts | 2 + .../metric_threshold_executor.ts | 6 ++- .../register_metric_threshold_rule_type.ts | 2 + .../alerting/metric_threshold/test_mocks.ts | 5 ++ .../plugins/infra/server/lib/infra_types.ts | 4 +- x-pack/plugins/infra/server/plugin.ts | 2 +- 13 files changed, 133 insertions(+), 49 deletions(-) create mode 100644 x-pack/plugins/infra/common/alerting/metrics/alert_link.ts diff --git a/x-pack/plugins/infra/common/alerting/metrics/alert_link.ts b/x-pack/plugins/infra/common/alerting/metrics/alert_link.ts new file mode 100644 index 0000000000000..b6d09e1004a70 --- /dev/null +++ b/x-pack/plugins/infra/common/alerting/metrics/alert_link.ts @@ -0,0 +1,48 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { ALERT_RULE_PARAMETERS, TIMESTAMP } from '@kbn/rule-data-utils'; +import { encode } from 'rison-node'; +import { stringify } from 'query-string'; +import { ParsedTechnicalFields } from '../../../../rule_registry/common/parse_technical_fields'; + +export const getInventoryViewInAppUrl = ( + fields: ParsedTechnicalFields & Record +): string => { + const nodeTypeField = `${ALERT_RULE_PARAMETERS}.nodeType`; + const nodeType = fields[nodeTypeField]; + let inventoryViewInAppUrl = '/app/metrics/link-to/inventory?'; + if (nodeType) { + const linkToParams: Record = { + nodeType: fields[nodeTypeField][0], + timestamp: Date.parse(fields[TIMESTAMP]), + customMetric: '', + }; + // We always pick the first criteria metric for the URL + const criteriaMetric = fields[`${ALERT_RULE_PARAMETERS}.criteria.metric`][0]; + const criteriaCustomMetricId = fields[`${ALERT_RULE_PARAMETERS}.criteria.customMetric.id`][0]; + if (criteriaCustomMetricId !== 'alert-custom-metric') { + const criteriaCustomMetricAggregation = + fields[`${ALERT_RULE_PARAMETERS}.criteria.customMetric.aggregation`][0]; + const criteriaCustomMetricField = + fields[`${ALERT_RULE_PARAMETERS}.criteria.customMetric.field`][0]; + + const customMetric = encode({ + id: criteriaCustomMetricId, + type: 'custom', + field: criteriaCustomMetricField, + aggregation: criteriaCustomMetricAggregation, + }); + linkToParams.customMetric = customMetric; + linkToParams.metric = customMetric; + } else { + linkToParams.metric = encode({ type: criteriaMetric }); + } + inventoryViewInAppUrl += stringify(linkToParams); + } + return inventoryViewInAppUrl; +}; diff --git a/x-pack/plugins/infra/common/alerting/metrics/index.ts b/x-pack/plugins/infra/common/alerting/metrics/index.ts index 2c66638711cd0..3ed41e70e2269 100644 --- a/x-pack/plugins/infra/common/alerting/metrics/index.ts +++ b/x-pack/plugins/infra/common/alerting/metrics/index.ts @@ -17,3 +17,5 @@ export const isTooManyBucketsPreviewException = ( value: any ): value is TooManyBucketsPreviewExceptionMetadata => Boolean(value && value.TOO_MANY_BUCKETS_PREVIEW_EXCEPTION); + +export const LINK_TO_METRICS_EXPLORER = '/app/metrics/explorer'; diff --git a/x-pack/plugins/infra/public/alerting/inventory/rule_data_formatters.ts b/x-pack/plugins/infra/public/alerting/inventory/rule_data_formatters.ts index b3455b8baa713..a419bef9f6c76 100644 --- a/x-pack/plugins/infra/public/alerting/inventory/rule_data_formatters.ts +++ b/x-pack/plugins/infra/public/alerting/inventory/rule_data_formatters.ts @@ -5,50 +5,15 @@ * 2.0. */ -import { ALERT_REASON, ALERT_RULE_PARAMETERS, TIMESTAMP } from '@kbn/rule-data-utils'; -import { encode } from 'rison-node'; -import { stringify } from 'query-string'; +import { ALERT_REASON } from '@kbn/rule-data-utils'; import { ObservabilityRuleTypeFormatter } from '../../../../observability/public'; +import { getInventoryViewInAppUrl } from '../../../common/alerting/metrics/alert_link'; export const formatReason: ObservabilityRuleTypeFormatter = ({ fields }) => { const reason = fields[ALERT_REASON] ?? '-'; - const nodeTypeField = `${ALERT_RULE_PARAMETERS}.nodeType`; - const nodeType = fields[nodeTypeField]; - let link = '/app/metrics/link-to/inventory?'; - - if (nodeType) { - const linkToParams: Record = { - nodeType: fields[nodeTypeField][0], - timestamp: Date.parse(fields[TIMESTAMP]), - customMetric: '', - }; - - // We always pick the first criteria metric for the URL - const criteriaMetric = fields[`${ALERT_RULE_PARAMETERS}.criteria.metric`][0]; - const criteriaCustomMetricId = fields[`${ALERT_RULE_PARAMETERS}.criteria.customMetric.id`][0]; - if (criteriaCustomMetricId !== 'alert-custom-metric') { - const criteriaCustomMetricAggregation = - fields[`${ALERT_RULE_PARAMETERS}.criteria.customMetric.aggregation`][0]; - const criteriaCustomMetricField = - fields[`${ALERT_RULE_PARAMETERS}.criteria.customMetric.field`][0]; - - const customMetric = encode({ - id: criteriaCustomMetricId, - type: 'custom', - field: criteriaCustomMetricField, - aggregation: criteriaCustomMetricAggregation, - }); - linkToParams.customMetric = customMetric; - linkToParams.metric = customMetric; - } else { - linkToParams.metric = encode({ type: criteriaMetric }); - } - - link += stringify(linkToParams); - } return { reason, - link, + link: getInventoryViewInAppUrl(fields), }; }; diff --git a/x-pack/plugins/infra/public/alerting/metric_threshold/rule_data_formatters.ts b/x-pack/plugins/infra/public/alerting/metric_threshold/rule_data_formatters.ts index 7a0140ab05652..268d0d2113381 100644 --- a/x-pack/plugins/infra/public/alerting/metric_threshold/rule_data_formatters.ts +++ b/x-pack/plugins/infra/public/alerting/metric_threshold/rule_data_formatters.ts @@ -7,10 +7,10 @@ import { ALERT_REASON } from '@kbn/rule-data-utils'; import { ObservabilityRuleTypeFormatter } from '../../../../observability/public'; - +import { LINK_TO_METRICS_EXPLORER } from '../../../common/alerting/metrics'; export const formatReason: ObservabilityRuleTypeFormatter = ({ fields }) => { const reason = fields[ALERT_REASON] ?? '-'; - const link = '/app/metrics/explorer'; // TODO https://github.com/elastic/kibana/issues/106497 & https://github.com/elastic/kibana/issues/106958 + const link = LINK_TO_METRICS_EXPLORER; // TODO https://github.com/elastic/kibana/issues/106497 & https://github.com/elastic/kibana/issues/106958 return { reason, diff --git a/x-pack/plugins/infra/server/lib/alerting/common/messages.ts b/x-pack/plugins/infra/server/lib/alerting/common/messages.ts index 193b5191bc98f..d61d4dd95b05e 100644 --- a/x-pack/plugins/infra/server/lib/alerting/common/messages.ts +++ b/x-pack/plugins/infra/server/lib/alerting/common/messages.ts @@ -206,3 +206,11 @@ export const thresholdActionVariableDescription = i18n.translate( 'The threshold value of the metric for the specified condition. Usage: (ctx.threshold.condition0, ctx.threshold.condition1, etc...).', } ); + +export const viewInAppUrlActionVariableDescription = i18n.translate( + 'xpack.infra.metrics.alerting.viewInAppUrlActionVariableDescription', + { + defaultMessage: + 'Link to the view or feature within Elastic that can be used to investigate the alert and its context further', + } +); diff --git a/x-pack/plugins/infra/server/lib/alerting/common/utils.ts b/x-pack/plugins/infra/server/lib/alerting/common/utils.ts index d1a7f9d643773..e5e93ae4aa360 100644 --- a/x-pack/plugins/infra/server/lib/alerting/common/utils.ts +++ b/x-pack/plugins/infra/server/lib/alerting/common/utils.ts @@ -8,7 +8,14 @@ import { isEmpty, isError } from 'lodash'; import { schema } from '@kbn/config-schema'; import { Logger, LogMeta } from '@kbn/logging'; -import { AlertExecutionDetails } from '../../../../common/alerting/metrics/types'; +import type { IBasePath } from 'kibana/server'; +import { ALERT_RULE_PARAMETERS, TIMESTAMP } from '@kbn/rule-data-utils'; +import { getInventoryViewInAppUrl } from '../../../../common/alerting/metrics/alert_link'; +import { parseTechnicalFields } from '../../../../../rule_registry/common/parse_technical_fields'; +import { + AlertExecutionDetails, + InventoryMetricConditions, +} from '../../../../common/alerting/metrics/types'; export const oneOfLiterals = (arrayOfLiterals: Readonly) => schema.string({ @@ -75,3 +82,28 @@ export const createScopedLogger = ( }, }; }; + +export const getViewInAppUrl = (basePath: IBasePath, relativeViewInAppUrl: string) => + basePath.publicBaseUrl + ? new URL(basePath.prepend(relativeViewInAppUrl), basePath.publicBaseUrl).toString() + : relativeViewInAppUrl; + +export const getViewInAppUrlInventory = ( + criteria: InventoryMetricConditions[], + nodeType: string, + timestamp: string, + basePath: IBasePath +) => { + const { metric, customMetric } = criteria[0]; + const fields = { + [`${ALERT_RULE_PARAMETERS}.criteria.metric`]: [metric], + [`${ALERT_RULE_PARAMETERS}.criteria.customMetric.id`]: [customMetric?.id], + [`${ALERT_RULE_PARAMETERS}.criteria.customMetric.aggregation`]: [customMetric?.aggregation], + [`${ALERT_RULE_PARAMETERS}.criteria.customMetric.field`]: [customMetric?.field], + [`${ALERT_RULE_PARAMETERS}.nodeType`]: [nodeType], + [TIMESTAMP]: timestamp, + }; + + const relativeViewInAppUrl = getInventoryViewInAppUrl(parseTechnicalFields(fields, true)); + return getViewInAppUrl(basePath, relativeViewInAppUrl); +}; diff --git a/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.ts b/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.ts index 7b6b23eff0a08..289b4bc6ee74e 100644 --- a/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.ts +++ b/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/inventory_metric_threshold_executor.ts @@ -32,7 +32,7 @@ import { // buildRecoveredAlertReason, stateToAlertMessage, } from '../common/messages'; -import { createScopedLogger } from '../common/utils'; +import { createScopedLogger, getViewInAppUrlInventory } from '../common/utils'; import { evaluateCondition } from './evaluate_condition'; type InventoryMetricThresholdAllowedActionGroups = ActionGroupIdsOf< @@ -62,12 +62,12 @@ export const createInventoryMetricThresholdExecutor = (libs: InfraBackendLibs) = InventoryMetricThresholdAlertState, InventoryMetricThresholdAlertContext, InventoryMetricThresholdAllowedActionGroups - >(async ({ services, params, alertId, executionId }) => { + >(async ({ services, params, alertId, executionId, startedAt }) => { const startTime = Date.now(); const { criteria, filterQuery, sourceId, nodeType, alertOnNoData } = params; if (criteria.length === 0) throw new Error('Cannot execute an alert with 0 conditions'); const logger = createScopedLogger(libs.logger, 'inventoryRule', { alertId, executionId }); - const { alertWithLifecycle, savedObjectsClient } = services; + const { alertWithLifecycle, savedObjectsClient, getAlertStartedDate } = services; const alertFactory: InventoryMetricThresholdAlertFactory = (id, reason) => alertWithLifecycle({ id, @@ -86,10 +86,18 @@ export const createInventoryMetricThresholdExecutor = (libs: InfraBackendLibs) = const actionGroupId = FIRED_ACTIONS.id; // Change this to an Error action group when able const reason = buildInvalidQueryAlertReason(params.filterQueryText); const alert = alertFactory('*', reason); + const indexedStartedDate = getAlertStartedDate('*') ?? startedAt.toISOString(); + const viewInAppUrl = getViewInAppUrlInventory( + criteria, + nodeType, + indexedStartedDate, + libs.basePath + ); alert.scheduleActions(actionGroupId, { group: '*', alertState: stateToAlertMessage[AlertStates.ERROR], reason, + viewInAppUrl, timestamp: moment().toISOString(), value: null, metric: mapToConditionsLookup(criteria, (c) => c.metric), @@ -192,7 +200,14 @@ export const createInventoryMetricThresholdExecutor = (libs: InfraBackendLibs) = ? WARNING_ACTIONS.id : FIRED_ACTIONS.id; - const alert = alertFactory(`${group}`, reason); + const alert = alertFactory(group, reason); + const indexedStartedDate = getAlertStartedDate(group) ?? startedAt.toISOString(); + const viewInAppUrl = getViewInAppUrlInventory( + criteria, + nodeType, + indexedStartedDate, + libs.basePath + ); scheduledActionsCount++; alert.scheduleActions( /** @@ -204,6 +219,7 @@ export const createInventoryMetricThresholdExecutor = (libs: InfraBackendLibs) = group, alertState: stateToAlertMessage[nextState], reason, + viewInAppUrl, timestamp: moment().toISOString(), value: mapToConditionsLookup(results, (result) => formatMetric(result[group].metric, result[group].currentValue) diff --git a/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/register_inventory_metric_threshold_rule_type.ts b/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/register_inventory_metric_threshold_rule_type.ts index 81d7758886644..f7d1e80346d71 100644 --- a/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/register_inventory_metric_threshold_rule_type.ts +++ b/x-pack/plugins/infra/server/lib/alerting/inventory_metric_threshold/register_inventory_metric_threshold_rule_type.ts @@ -30,6 +30,7 @@ import { thresholdActionVariableDescription, timestampActionVariableDescription, valueActionVariableDescription, + viewInAppUrlActionVariableDescription, } from '../common/messages'; import { oneOfLiterals, validateIsStringElasticsearchJSONFilter } from '../common/utils'; import { @@ -99,6 +100,7 @@ export async function registerMetricInventoryThresholdRuleType( { name: 'value', description: valueActionVariableDescription }, { name: 'metric', description: metricActionVariableDescription }, { name: 'threshold', description: thresholdActionVariableDescription }, + { name: 'viewInAppUrl', description: viewInAppUrlActionVariableDescription }, ], }, }); diff --git a/x-pack/plugins/infra/server/lib/alerting/metric_threshold/metric_threshold_executor.ts b/x-pack/plugins/infra/server/lib/alerting/metric_threshold/metric_threshold_executor.ts index 9fbbe26fba126..d8792e7cb9d34 100644 --- a/x-pack/plugins/infra/server/lib/alerting/metric_threshold/metric_threshold_executor.ts +++ b/x-pack/plugins/infra/server/lib/alerting/metric_threshold/metric_threshold_executor.ts @@ -27,7 +27,9 @@ import { // buildRecoveredAlertReason, stateToAlertMessage, } from '../common/messages'; -import { UNGROUPED_FACTORY_KEY } from '../common/utils'; +import { UNGROUPED_FACTORY_KEY, getViewInAppUrl } from '../common/utils'; +import { LINK_TO_METRICS_EXPLORER } from '../../../../common/alerting/metrics'; + import { EvaluatedRuleParams, evaluateRule } from './lib/evaluate_rule'; import { TimeUnitChar } from '../../../../../observability/common/utils/formatters/duration'; @@ -100,6 +102,7 @@ export const createMetricThresholdExecutor = (libs: InfraBackendLibs) => group: UNGROUPED_FACTORY_KEY, alertState: stateToAlertMessage[AlertStates.ERROR], reason, + viewInAppUrl: getViewInAppUrl(libs.basePath, LINK_TO_METRICS_EXPLORER), timestamp, value: null, metric: mapToConditionsLookup(criteria, (c) => c.metric), @@ -234,6 +237,7 @@ export const createMetricThresholdExecutor = (libs: InfraBackendLibs) => group, alertState: stateToAlertMessage[nextState], reason, + viewInAppUrl: getViewInAppUrl(libs.basePath, LINK_TO_METRICS_EXPLORER), timestamp, value: mapToConditionsLookup( alertResults, diff --git a/x-pack/plugins/infra/server/lib/alerting/metric_threshold/register_metric_threshold_rule_type.ts b/x-pack/plugins/infra/server/lib/alerting/metric_threshold/register_metric_threshold_rule_type.ts index d5d819ba7902e..a4ec6e4c4930e 100644 --- a/x-pack/plugins/infra/server/lib/alerting/metric_threshold/register_metric_threshold_rule_type.ts +++ b/x-pack/plugins/infra/server/lib/alerting/metric_threshold/register_metric_threshold_rule_type.ts @@ -20,6 +20,7 @@ import { thresholdActionVariableDescription, timestampActionVariableDescription, valueActionVariableDescription, + viewInAppUrlActionVariableDescription, } from '../common/messages'; import { oneOfLiterals, validateIsStringElasticsearchJSONFilter } from '../common/utils'; import { @@ -97,6 +98,7 @@ export async function registerMetricThresholdRuleType( { name: 'value', description: valueActionVariableDescription }, { name: 'metric', description: metricActionVariableDescription }, { name: 'threshold', description: thresholdActionVariableDescription }, + { name: 'viewInAppUrl', description: viewInAppUrlActionVariableDescription }, ], }, producer: 'infrastructure', diff --git a/x-pack/plugins/infra/server/lib/alerting/metric_threshold/test_mocks.ts b/x-pack/plugins/infra/server/lib/alerting/metric_threshold/test_mocks.ts index d023aa5e28a4e..ee9a34ef9233a 100644 --- a/x-pack/plugins/infra/server/lib/alerting/metric_threshold/test_mocks.ts +++ b/x-pack/plugins/infra/server/lib/alerting/metric_threshold/test_mocks.ts @@ -4,6 +4,11 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ +import * as utils from '../../alerting/common/utils'; +jest + .spyOn(utils, 'getViewInAppUrl') + .mockReturnValue('http://localhost:5601/eyg/app/metrics/explorer'); + const bucketsA = (from: number) => [ { doc_count: null, diff --git a/x-pack/plugins/infra/server/lib/infra_types.ts b/x-pack/plugins/infra/server/lib/infra_types.ts index c400e4664dc0a..bf2847491a901 100644 --- a/x-pack/plugins/infra/server/lib/infra_types.ts +++ b/x-pack/plugins/infra/server/lib/infra_types.ts @@ -6,7 +6,7 @@ */ import { Logger } from '@kbn/logging'; -import type { IBasePath } from 'src/core/server'; +import type { IBasePath } from 'kibana/server'; import { handleEsError } from '../../../../../src/plugins/es_ui_shared/server'; import { InfraConfig } from '../types'; import { GetLogQueryFields } from '../services/log_queries/get_log_query_fields'; @@ -33,6 +33,6 @@ export interface InfraBackendLibs extends InfraDomainLibs { handleEsError: typeof handleEsError; logsRules: RulesServiceSetup; metricsRules: RulesServiceSetup; - basePath: IBasePath; logger: Logger; + basePath: IBasePath; } diff --git a/x-pack/plugins/infra/server/plugin.ts b/x-pack/plugins/infra/server/plugin.ts index 650f3447372b4..6b0400a0c5e65 100644 --- a/x-pack/plugins/infra/server/plugin.ts +++ b/x-pack/plugins/infra/server/plugin.ts @@ -154,8 +154,8 @@ export class InfraServerPlugin implements Plugin { handleEsError, logsRules: this.logsRules.setup(core, plugins), metricsRules: this.metricsRules.setup(core, plugins), - basePath: core.http.basePath, logger: this.logger, + basePath: core.http.basePath, }; plugins.features.registerKibanaFeature(METRICS_FEATURE); From d8f0862fd7a2548dfe287b5b827a401af59260bf Mon Sep 17 00:00:00 2001 From: Oliver Gupte Date: Mon, 28 Mar 2022 10:58:33 -0400 Subject: [PATCH 022/160] [APM] Set APM agent policy id in the fleet migration to "elastic-cloud-apm" (#128494) (#128496) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/apm/common/fleet.ts | 2 ++ .../server/routes/fleet/get_apm_package_policy_definition.ts | 2 ++ 2 files changed, 4 insertions(+) diff --git a/x-pack/plugins/apm/common/fleet.ts b/x-pack/plugins/apm/common/fleet.ts index 183192e6bd1da..46ec9be784f43 100644 --- a/x-pack/plugins/apm/common/fleet.ts +++ b/x-pack/plugins/apm/common/fleet.ts @@ -13,3 +13,5 @@ export const SUPPORTED_APM_PACKAGE_VERSION = '8.1.0'; export function isPrereleaseVersion(version: string) { return semverParse(version)?.prerelease?.length ?? 0 > 0; } + +export const ELASTIC_CLOUD_APM_AGENT_POLICY_ID = 'elastic-cloud-apm'; diff --git a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts b/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts index 352ff8eb9cca5..6d4af4e33ad5b 100644 --- a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts +++ b/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts @@ -9,6 +9,7 @@ import { isPrereleaseVersion, POLICY_ELASTIC_AGENT_ON_CLOUD, SUPPORTED_APM_PACKAGE_VERSION, + ELASTIC_CLOUD_APM_AGENT_POLICY_ID, } from '../../../common/fleet'; import { APMPluginSetupDependencies, @@ -29,6 +30,7 @@ export async function getApmPackagePolicyDefinition( options; return { + id: ELASTIC_CLOUD_APM_AGENT_POLICY_ID, name: 'Elastic APM', namespace: 'default', enabled: true, From b398a962237abd5d9cd654c2d69379992c796eb5 Mon Sep 17 00:00:00 2001 From: Nicolas Chaulet Date: Mon, 28 Mar 2022 11:07:02 -0400 Subject: [PATCH 023/160] [Fleet] Mark logstash output as BETA (#128625) --- .../components/edit_output_flyout/index.tsx | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/settings/components/edit_output_flyout/index.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/settings/components/edit_output_flyout/index.tsx index f366f32a36b84..2517d5c9e6f5c 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/sections/settings/components/edit_output_flyout/index.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/settings/components/edit_output_flyout/index.tsx @@ -45,7 +45,7 @@ export interface EditOutputFlyoutProps { const OUTPUT_TYPE_OPTIONS = [ { value: 'elasticsearch', text: 'Elasticsearch' }, - { value: 'logstash', text: 'Logstash' }, + { value: 'logstash', text: 'Logstash (BETA)' }, ]; export const EditOutputFlyout: React.FunctionComponent = ({ @@ -130,6 +130,23 @@ export const EditOutputFlyout: React.FunctionComponent = defaultMessage="Type" /> } + helpText={ + isLogstashOutput && ( + + {i18n.translate('xpack.fleet.editOutputFlyout.learnMoreLink', { + defaultMessage: 'Learn more', + })} + + ), + }} + /> + ) + } > Date: Mon, 28 Mar 2022 16:10:55 +0100 Subject: [PATCH 024/160] update toast content (#128595) --- .../components/visualization_actions/translations.ts | 7 +++++++ .../use_add_to_existing_case.test.tsx | 1 + .../visualization_actions/use_add_to_existing_case.tsx | 2 ++ .../visualization_actions/use_add_to_new_case.test.tsx | 1 + .../visualization_actions/use_add_to_new_case.tsx | 2 ++ 5 files changed, 13 insertions(+) diff --git a/x-pack/plugins/security_solution/public/common/components/visualization_actions/translations.ts b/x-pack/plugins/security_solution/public/common/components/visualization_actions/translations.ts index 9707fd39d9322..c3850ab7ade8a 100644 --- a/x-pack/plugins/security_solution/public/common/components/visualization_actions/translations.ts +++ b/x-pack/plugins/security_solution/public/common/components/visualization_actions/translations.ts @@ -39,6 +39,13 @@ export const ADD_TO_EXISTING_CASE = i18n.translate( } ); +export const ADD_TO_CASE_SUCCESS = i18n.translate( + 'xpack.securitySolution.visualizationActions.addToCaseSuccessContent', + { + defaultMessage: 'Successfully added visualization to the case', + } +); + export const SOURCE_CHART_LABEL = i18n.translate( 'xpack.securitySolution.visualizationActions.uniqueIps.sourceChartLabel', { diff --git a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.test.tsx b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.test.tsx index a1831a7fccde7..af0b41ad87bca 100644 --- a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.test.tsx @@ -50,6 +50,7 @@ describe('', () => { }, ], onClose: mockOnAddToCaseClicked, + toastContent: 'Successfully added visualization to the case', }); expect(result.current.disabled).toEqual(false); }); diff --git a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.tsx b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.tsx index 5a4ac6dd934e9..fc2a1893e1ad0 100644 --- a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.tsx +++ b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_existing_case.tsx @@ -9,6 +9,7 @@ import { CommentType } from '../../../../../cases/common'; import { APP_ID } from '../../../../common/constants'; import { useKibana } from '../../lib/kibana/kibana_react'; +import { ADD_TO_CASE_SUCCESS } from './translations'; import { LensAttributes } from './types'; @@ -42,6 +43,7 @@ export const useAddToExistingCase = ({ const selectCaseModal = cases.hooks.getUseCasesAddToExistingCaseModal({ attachments, onClose: onAddToCaseClicked, + toastContent: ADD_TO_CASE_SUCCESS, }); const onAddToExistingCaseClicked = useCallback(() => { diff --git a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.test.tsx b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.test.tsx index 0627262eec438..758f7e664fb03 100644 --- a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.test.tsx @@ -47,6 +47,7 @@ describe('', () => { type, }, ], + toastContent: 'Successfully added visualization to the case', }); expect(result.current.disabled).toEqual(false); }); diff --git a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.tsx b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.tsx index 854894e81c48c..6958b2cb97892 100644 --- a/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.tsx +++ b/x-pack/plugins/security_solution/public/common/components/visualization_actions/use_add_to_new_case.tsx @@ -10,6 +10,7 @@ import { CommentType } from '../../../../../cases/common'; import { APP_ID } from '../../../../common/constants'; import { useKibana } from '../../lib/kibana/kibana_react'; +import { ADD_TO_CASE_SUCCESS } from './translations'; import { LensAttributes } from './types'; @@ -44,6 +45,7 @@ export const useAddToNewCase = ({ const createCaseFlyout = cases.hooks.getUseCasesAddToNewCaseFlyout({ attachments, + toastContent: ADD_TO_CASE_SUCCESS, }); const onAddToNewCaseClicked = useCallback(() => { From 96554163adfd52529198e2a401441da6806073bc Mon Sep 17 00:00:00 2001 From: Kevin Logan <56395104+kevinlog@users.noreply.github.com> Date: Mon, 28 Mar 2022 11:15:12 -0400 Subject: [PATCH 025/160] [Security Solution] Session Data eventing switch in Linux Endpoint policy (#128149) --- .../security_solution/to_v8_2_0.test.ts | 14 +- .../migrations/security_solution/to_v8_2_0.ts | 2 + .../common/endpoint/models/policy_config.ts | 1 + .../common/endpoint/types/index.ts | 1 + .../policy/models/advanced_policy_schema.ts | 11 ++ .../policy/store/policy_details/index.test.ts | 2 +- .../view/components/events_form/index.tsx | 145 +++++++++++++----- .../policy/view/policy_forms/events/linux.tsx | 33 +++- 8 files changed, 164 insertions(+), 45 deletions(-) diff --git a/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.test.ts b/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.test.ts index a1cd0f01ac225..dabd76dd48635 100644 --- a/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.test.ts +++ b/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.test.ts @@ -12,7 +12,12 @@ import type { PackagePolicy } from '../../../../common'; import { migratePackagePolicyToV820 as migration } from './to_v8_2_0'; describe('8.2.0 Endpoint Package Policy migration', () => { - const policyDoc = ({ windowsMalware = {}, macMalware = {}, linuxMalware = {} }) => { + const policyDoc = ({ + windowsMalware = {}, + macMalware = {}, + linuxMalware = {}, + linuxEvents = {}, + }) => { return { id: 'mock-saved-object-id', attributes: { @@ -48,6 +53,7 @@ describe('8.2.0 Endpoint Package Policy migration', () => { }, linux: { ...linuxMalware, + ...linuxEvents, }, }, }, @@ -64,12 +70,14 @@ describe('8.2.0 Endpoint Package Policy migration', () => { windowsMalware: { malware: { mode: 'off' } }, macMalware: { malware: { mode: 'off' } }, linuxMalware: { malware: { mode: 'off' } }, + linuxEvents: { events: { process: true, file: true, network: true } }, }); const migratedDoc = policyDoc({ windowsMalware: { malware: { mode: 'off', blocklist: false } }, macMalware: { malware: { mode: 'off', blocklist: false } }, linuxMalware: { malware: { mode: 'off', blocklist: false } }, + linuxEvents: { events: { process: true, file: true, network: true, session_data: false } }, }); expect(migration(initialDoc, {} as SavedObjectMigrationContext)).toEqual(migratedDoc); @@ -80,12 +88,14 @@ describe('8.2.0 Endpoint Package Policy migration', () => { windowsMalware: { malware: { mode: 'prevent' } }, macMalware: { malware: { mode: 'prevent' } }, linuxMalware: { malware: { mode: 'prevent' } }, + linuxEvents: { events: { process: true, file: true, network: true } }, }); const migratedDoc = policyDoc({ windowsMalware: { malware: { mode: 'prevent', blocklist: true } }, macMalware: { malware: { mode: 'prevent', blocklist: true } }, linuxMalware: { malware: { mode: 'prevent', blocklist: true } }, + linuxEvents: { events: { process: true, file: true, network: true, session_data: false } }, }); expect(migration(initialDoc, {} as SavedObjectMigrationContext)).toEqual(migratedDoc); @@ -96,12 +106,14 @@ describe('8.2.0 Endpoint Package Policy migration', () => { windowsMalware: { malware: { mode: 'detect' } }, macMalware: { malware: { mode: 'detect' } }, linuxMalware: { malware: { mode: 'detect' } }, + linuxEvents: { events: { process: true, file: true, network: true } }, }); const migratedDoc = policyDoc({ windowsMalware: { malware: { mode: 'detect', blocklist: true } }, macMalware: { malware: { mode: 'detect', blocklist: true } }, linuxMalware: { malware: { mode: 'detect', blocklist: true } }, + linuxEvents: { events: { process: true, file: true, network: true, session_data: false } }, }); expect(migration(initialDoc, {} as SavedObjectMigrationContext)).toEqual(migratedDoc); diff --git a/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.ts b/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.ts index dbc5c2f32a2a8..d6610915c0031 100644 --- a/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.ts +++ b/x-pack/plugins/fleet/server/saved_objects/migrations/security_solution/to_v8_2_0.ts @@ -28,6 +28,8 @@ export const migratePackagePolicyToV820: SavedObjectMigrationFn { process: true, file: true, network: true, + session_data: false, }, malware: { mode: ProtectionModes.prevent, diff --git a/x-pack/plugins/security_solution/common/endpoint/types/index.ts b/x-pack/plugins/security_solution/common/endpoint/types/index.ts index cbbf3010ef7b2..5aa38617f0331 100644 --- a/x-pack/plugins/security_solution/common/endpoint/types/index.ts +++ b/x-pack/plugins/security_solution/common/endpoint/types/index.ts @@ -984,6 +984,7 @@ export interface PolicyConfig { file: boolean; process: boolean; network: boolean; + session_data: boolean; }; malware: ProtectionFields & BlocklistFields; behavior_protection: ProtectionFields & SupportedFields; diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/models/advanced_policy_schema.ts b/x-pack/plugins/security_solution/public/management/pages/policy/models/advanced_policy_schema.ts index 128bca807381c..d5147f58d4f0b 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/models/advanced_policy_schema.ts +++ b/x-pack/plugins/security_solution/public/management/pages/policy/models/advanced_policy_schema.ts @@ -873,4 +873,15 @@ export const AdvancedPolicySchema: AdvancedPolicySchemaType[] = [ } ), }, + { + key: 'linux.advanced.kernel.capture_mode', + first_supported_version: '8.2', + documentation: i18n.translate( + 'xpack.securitySolution.endpoint.policy.advanced.linux.advanced.kernel.capture_mode', + { + defaultMessage: + 'Allows users to control whether kprobes or ebpf are used to gather data. Possible options are kprobes, ebpf, or auto. Default: auto', + } + ), + }, ]; diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/store/policy_details/index.test.ts b/x-pack/plugins/security_solution/public/management/pages/policy/store/policy_details/index.test.ts index b6720527a7935..1fe646c86bd6a 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/store/policy_details/index.test.ts +++ b/x-pack/plugins/security_solution/public/management/pages/policy/store/policy_details/index.test.ts @@ -332,7 +332,7 @@ describe('policy details: ', () => { logging: { file: 'info' }, }, linux: { - events: { process: true, file: true, network: true }, + events: { process: true, file: true, network: true, session_data: false }, logging: { file: 'info' }, malware: { mode: 'prevent', blocklist: true }, behavior_protection: { mode: 'off', supported: false }, diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/components/events_form/index.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/components/events_form/index.tsx index a3f4b2fdc7fb1..c079ae8a3a7da 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/components/events_form/index.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/components/events_form/index.tsx @@ -5,10 +5,21 @@ * 2.0. */ -import React from 'react'; +import React, { useContext, useCallback } from 'react'; import { i18n } from '@kbn/i18n'; -import { EuiCheckbox, EuiSpacer, EuiText, htmlIdGenerator } from '@elastic/eui'; +import { + EuiCheckbox, + EuiSpacer, + EuiText, + htmlIdGenerator, + EuiSwitch, + EuiIconTip, + EuiBetaBadge, + EuiFlexItem, + EuiFlexGroup, +} from '@elastic/eui'; import { OperatingSystem } from '@kbn/securitysolution-utils'; +import { ThemeContext } from 'styled-components'; import { PolicyOperatingSystem, UIPolicyConfig } from '../../../../../../../common/endpoint/types'; import { ConfigForm, ConfigFormHeading } from '../../components/config_form'; @@ -34,54 +45,110 @@ export interface EventFormOption { protectionField: ProtectionField; } +export interface SupplementalEventFormOption { + name: string; + protectionField: ProtectionField; + tooltipText?: string; + beta?: boolean; +} + export interface EventsFormProps { os: T; options: ReadonlyArray>; selection: EventFormSelection; onValueSelection: (value: ProtectionField, selected: boolean) => void; + supplementalOptions?: ReadonlyArray>; } -const countSelected = (selection: EventFormSelection) => { - return Object.values(selection).filter((value) => value).length; -}; - -export const EventsForm = ({ +const InnerEventsForm = ({ os, options, selection, onValueSelection, -}: EventsFormProps) => ( - - {i18n.translate('xpack.securitySolution.endpoint.policy.details.eventCollectionsEnabled', { - defaultMessage: '{selected} / {total} event collections enabled', - values: { selected: countSelected(selection), total: options.length }, + supplementalOptions, +}: EventsFormProps) => { + const theme = useContext(ThemeContext); + const countSelected = useCallback(() => { + const supplementalSelectionFields: string[] = supplementalOptions + ? supplementalOptions.map((value) => value.protectionField as string) + : []; + return Object.entries(selection).filter(([key, value]) => + !supplementalSelectionFields.includes(key) ? value : false + ).length; + }, [selection, supplementalOptions]); + + return ( + + {i18n.translate( + 'xpack.securitySolution.endpoint.policy.details.eventCollectionsEnabled', + { + defaultMessage: '{selected} / {total} event collections enabled', + values: { + selected: countSelected(), + total: options.length, + }, + } + )} + + } + > + + {i18n.translate('xpack.securitySolution.endpoint.policyDetailsConfig.eventingEvents', { + defaultMessage: 'Events', })} - - } - > - - {i18n.translate('xpack.securitySolution.endpoint.policyDetailsConfig.eventingEvents', { - defaultMessage: 'Events', + + + {options.map(({ name, protectionField }) => { + return ( + onValueSelection(protectionField, event.target.checked)} + /> + ); })} - - - {options.map(({ name, protectionField }) => ( - onValueSelection(protectionField, event.target.checked)} - /> - ))} - -); + {supplementalOptions && + supplementalOptions.map(({ name, protectionField, tooltipText, beta }) => { + return ( +
+ + + + onValueSelection(protectionField, event.target.checked)} + /> + + {tooltipText && ( + + + + )} + {beta && ( + + + + )} + +
+ ); + })} +
+ ); +}; + +InnerEventsForm.displayName = 'EventsForm'; -EventsForm.displayName = 'EventsForm'; +export const EventsForm = React.memo(InnerEventsForm) as typeof InnerEventsForm; diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_forms/events/linux.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_forms/events/linux.tsx index 1980877eea95d..71e7dba966484 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_forms/events/linux.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_forms/events/linux.tsx @@ -12,7 +12,11 @@ import { OperatingSystem } from '@kbn/securitysolution-utils'; import { policyConfig } from '../../../store/policy_details/selectors'; import { setIn } from '../../../models/policy_details_config'; import { usePolicyDetailsSelector } from '../../policy_hooks'; -import { EventFormOption, EventsForm } from '../../components/events_form'; +import { + EventFormOption, + EventsForm, + SupplementalEventFormOption, +} from '../../components/events_form'; const OPTIONS: ReadonlyArray> = [ { @@ -21,6 +25,15 @@ const OPTIONS: ReadonlyArray> = [ }), protectionField: 'file', }, + { + name: i18n.translate( + 'xpack.securitySolution.endpoint.policyDetailsConfig.linux.events.network', + { + defaultMessage: 'Network', + } + ), + protectionField: 'network', + }, { name: i18n.translate( 'xpack.securitySolution.endpoint.policyDetailsConfig.linux.events.process', @@ -30,14 +43,25 @@ const OPTIONS: ReadonlyArray> = [ ), protectionField: 'process', }, +]; + +const SUPPLEMENTAL_OPTIONS: ReadonlyArray> = [ { name: i18n.translate( - 'xpack.securitySolution.endpoint.policyDetailsConfig.linux.events.network', + 'xpack.securitySolution.endpoint.policyDetailsConfig.linux.events.session_data', { - defaultMessage: 'Network', + defaultMessage: 'Include session data', } ), - protectionField: 'network', + protectionField: 'session_data', + tooltipText: i18n.translate( + 'xpack.securitySolution.endpoint.policyDetailsConfig.linux.events.session_data.tooltip', + { + defaultMessage: + 'Capture the extended process event data required for Session View. Session View helps you investigate process, user, and service activity on your Linux infrastructure by displaying session and process execution data organized in a tree according to the Linux process model. NOTE: Capturing extended process events substantially increases data usage.', + } + ), + beta: true, }, ]; @@ -50,6 +74,7 @@ export const LinuxEvents = memo(() => { os={OperatingSystem.LINUX} selection={policyDetailsConfig.linux.events} options={OPTIONS} + supplementalOptions={SUPPLEMENTAL_OPTIONS} onValueSelection={(value, selected) => dispatch({ type: 'userChangedPolicyConfig', From 0ea741dcd5c1f8edce30f74f62177a4c7a001837 Mon Sep 17 00:00:00 2001 From: Andrew Tate Date: Mon, 28 Mar 2022 10:15:40 -0500 Subject: [PATCH 026/160] [Lens] "Open in Discover" from dashboard (#127355) --- test/accessibility/apps/dashboard_panel.ts | 2 +- x-pack/plugins/discover_enhanced/kibana.json | 2 +- .../abstract_explore_data_action.ts | 2 + .../plugins/discover_enhanced/tsconfig.json | 1 + .../app_plugin/show_underlying_data.test.ts | 171 +++++++++++++++-- .../public/app_plugin/show_underlying_data.ts | 97 +++++++--- .../public/editor_frame_service/service.tsx | 2 +- .../public/embeddable/embeddable.test.tsx | 103 ++++++++-- .../lens/public/embeddable/embeddable.tsx | 180 +++++++++++++++--- .../public/embeddable/embeddable_factory.ts | 7 +- x-pack/plugins/lens/public/plugin.ts | 17 +- .../open_in_discover_action.test.ts | 107 +++++++++++ .../open_in_discover_action.ts | 41 ++++ x-pack/test/functional/apps/lens/dashboard.ts | 11 +- x-pack/test/functional/apps/lens/index.ts | 1 + .../lens/show_underlying_data_dashboard.ts | 113 +++++++++++ 16 files changed, 760 insertions(+), 97 deletions(-) create mode 100644 x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.test.ts create mode 100644 x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.ts create mode 100644 x-pack/test/functional/apps/lens/show_underlying_data_dashboard.ts diff --git a/test/accessibility/apps/dashboard_panel.ts b/test/accessibility/apps/dashboard_panel.ts index 83c7776049d16..b7975738104ce 100644 --- a/test/accessibility/apps/dashboard_panel.ts +++ b/test/accessibility/apps/dashboard_panel.ts @@ -57,7 +57,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('dashboard panel full screen', async () => { const header = await dashboardPanelActions.getPanelHeading('[Flights] Flight count'); - await dashboardPanelActions.toggleContextMenu(header); + await dashboardPanelActions.openContextMenuMorePanel(header); await testSubjects.click('embeddablePanelAction-togglePanel'); await a11y.testAppSnapshot(); diff --git a/x-pack/plugins/discover_enhanced/kibana.json b/x-pack/plugins/discover_enhanced/kibana.json index 426da33ae64f1..d1c8242987424 100644 --- a/x-pack/plugins/discover_enhanced/kibana.json +++ b/x-pack/plugins/discover_enhanced/kibana.json @@ -7,7 +7,7 @@ "requiredPlugins": ["uiActions", "embeddable", "discover"], "optionalPlugins": ["share", "usageCollection"], "configPath": ["xpack", "discoverEnhanced"], - "requiredBundles": ["kibanaUtils", "data"], + "requiredBundles": ["kibanaUtils", "data", "lens"], "owner": { "name": "Data Discovery", "githubTeam": "kibana-data-discovery" diff --git a/x-pack/plugins/discover_enhanced/public/actions/explore_data/abstract_explore_data_action.ts b/x-pack/plugins/discover_enhanced/public/actions/explore_data/abstract_explore_data_action.ts index c1c84c040f51e..52b60012f62f2 100644 --- a/x-pack/plugins/discover_enhanced/public/actions/explore_data/abstract_explore_data_action.ts +++ b/x-pack/plugins/discover_enhanced/public/actions/explore_data/abstract_explore_data_action.ts @@ -11,6 +11,7 @@ import { ViewMode, IEmbeddable } from '../../../../../../src/plugins/embeddable/ import { StartServicesGetter } from '../../../../../../src/plugins/kibana_utils/public'; import { CoreStart } from '../../../../../../src/core/public'; import { KibanaLocation } from '../../../../../../src/plugins/share/public'; +import { DOC_TYPE as LENS_DOC_TYPE } from '../../../../lens/common/constants'; import * as shared from './shared'; export const ACTION_EXPLORE_DATA = 'ACTION_EXPLORE_DATA'; @@ -41,6 +42,7 @@ export abstract class AbstractExploreDataAction { if (!embeddable) return false; + if (embeddable.type === LENS_DOC_TYPE) return false; const { core, plugins } = this.params.start(); const { capabilities } = core.application; diff --git a/x-pack/plugins/discover_enhanced/tsconfig.json b/x-pack/plugins/discover_enhanced/tsconfig.json index 8ce3e5bf9f63a..631ca8a577cdf 100644 --- a/x-pack/plugins/discover_enhanced/tsconfig.json +++ b/x-pack/plugins/discover_enhanced/tsconfig.json @@ -13,6 +13,7 @@ { "path": "../../../src/plugins/discover/tsconfig.json" }, { "path": "../../../src/plugins/share/tsconfig.json" }, { "path": "../../../src/plugins/kibana_utils/tsconfig.json" }, + { "path": "../lens/tsconfig.json" }, { "path": "../../../src/plugins/url_forwarding/tsconfig.json" }, { "path": "../../../src/plugins/usage_collection/tsconfig.json" }, { "path": "../../../src/plugins/embeddable/tsconfig.json" }, diff --git a/x-pack/plugins/lens/public/app_plugin/show_underlying_data.test.ts b/x-pack/plugins/lens/public/app_plugin/show_underlying_data.test.ts index f7ae043eba1d7..367349f17a5b2 100644 --- a/x-pack/plugins/lens/public/app_plugin/show_underlying_data.test.ts +++ b/x-pack/plugins/lens/public/app_plugin/show_underlying_data.test.ts @@ -9,14 +9,12 @@ import { createMockDatasource } from '../mocks'; import { combineQueryAndFilters, getLayerMetaInfo } from './show_underlying_data'; import { Filter } from '@kbn/es-query'; import { DatasourcePublicAPI } from '../types'; -import { RecursiveReadonly } from '@kbn/utility-types'; -import { Capabilities } from 'kibana/public'; describe('getLayerMetaInfo', () => { const capabilities = { navLinks: { discover: true }, discover: { show: true }, - } as unknown as RecursiveReadonly; + }; it('should return error in case of no data', () => { expect( getLayerMetaInfo(createMockDatasource('testDatasource'), {}, undefined, capabilities).error @@ -85,7 +83,7 @@ describe('getLayerMetaInfo', () => { { navLinks: { discover: false }, discover: { show: true }, - } as unknown as RecursiveReadonly + } ).isVisible ).toBeFalsy(); expect( @@ -98,7 +96,7 @@ describe('getLayerMetaInfo', () => { { navLinks: { discover: true }, discover: { show: false }, - } as unknown as RecursiveReadonly + } ).isVisible ).toBeFalsy(); }); @@ -178,7 +176,7 @@ describe('combineQueryAndFilters', () => { undefined ) ).toEqual({ - query: { language: 'kuery', query: '( myfield: * ) AND ( otherField: * )' }, + query: { language: 'kuery', query: '( ( myfield: * ) AND ( otherField: * ) )' }, filters: [], }); }); @@ -198,7 +196,7 @@ describe('combineQueryAndFilters', () => { }, undefined ) - ).toEqual({ query: { language: 'kuery', query: '( otherField: * )' }, filters: [] }); + ).toEqual({ query: { language: 'kuery', query: 'otherField: *' }, filters: [] }); }); it('should build single kuery expression from meta filters and join using OR and AND at the right level', () => { @@ -238,6 +236,7 @@ describe('combineQueryAndFilters', () => { filters: [], }); }); + it('should assign kuery meta filters to app filters if existing query is using lucene language', () => { expect( combineQueryAndFilters( @@ -293,6 +292,7 @@ describe('combineQueryAndFilters', () => { ], }); }); + it('should append lucene meta filters to app filters even if existing filters are using kuery', () => { expect( combineQueryAndFilters( @@ -385,7 +385,7 @@ describe('combineQueryAndFilters', () => { must: [ { query_string: { - query: '( anotherField )', + query: 'anotherField', }, }, ], @@ -407,6 +407,7 @@ describe('combineQueryAndFilters', () => { }, }); }); + it('should append lucene meta filters to an existing lucene query', () => { expect( combineQueryAndFilters( @@ -461,10 +462,158 @@ describe('combineQueryAndFilters', () => { ], query: { language: 'lucene', - query: '( myField ) AND ( anotherField )', + query: '( ( myField ) AND ( anotherField ) )', + }, + }); + }); + + it('should accept multiple queries (and play nice with meta filters)', () => { + const { query, filters } = combineQueryAndFilters( + [ + { language: 'lucene', query: 'myFirstField' }, + { language: 'lucene', query: 'mySecondField' }, + { language: 'kuery', query: 'myThirdField : *' }, + ], + [], + { + id: 'testDatasource', + columns: [], + filters: { + enabled: { + kuery: [[{ language: 'kuery', query: 'myFourthField : *' }]], + lucene: [[{ language: 'lucene', query: 'myFifthField' }]], + }, + disabled: { kuery: [], lucene: [] }, + }, }, + undefined + ); + + expect(query).toEqual({ + language: 'lucene', + query: '( ( myFirstField ) AND ( mySecondField ) AND ( myFifthField ) )', }); + + expect(filters).toEqual([ + { + $state: { + store: 'appState', + }, + bool: { + filter: [ + { + bool: { + filter: [ + { + bool: { + minimum_should_match: 1, + should: [ + { + exists: { + field: 'myThirdField', + }, + }, + ], + }, + }, + { + bool: { + minimum_should_match: 1, + should: [ + { + exists: { + field: 'myFourthField', + }, + }, + ], + }, + }, + ], + }, + }, + ], + must: [], + must_not: [], + should: [], + }, + meta: { + alias: 'Lens context (kuery)', + disabled: false, + index: 'testDatasource', + negate: false, + type: 'custom', + }, + }, + ]); }); + + it('should ignore all empty queries', () => { + const emptyQueryAndFilters = { + filters: [], + query: { + language: 'kuery', + query: '', + }, + }; + + expect( + combineQueryAndFilters( + [{ language: 'lucene', query: '' }], + [], + { + id: 'testDatasource', + columns: [], + filters: { + enabled: { + kuery: [[{ language: 'kuery', query: '' }]], + lucene: [], + }, + disabled: { kuery: [], lucene: [] }, + }, + }, + undefined + ) + ).toEqual(emptyQueryAndFilters); + + expect( + combineQueryAndFilters( + { language: 'lucene', query: '' }, + [], + { + id: 'testDatasource', + columns: [], + filters: { + enabled: { + kuery: [[{ language: 'kuery', query: '' }]], + lucene: [], + }, + disabled: { kuery: [], lucene: [] }, + }, + }, + undefined + ) + ).toEqual(emptyQueryAndFilters); + + expect( + combineQueryAndFilters( + undefined, + [], + { + id: 'testDatasource', + columns: [], + filters: { + enabled: { + kuery: [[{ language: 'kuery', query: '' }]], + lucene: [], + }, + disabled: { kuery: [], lucene: [] }, + }, + }, + undefined + ) + ).toEqual(emptyQueryAndFilters); + }); + it('should work for complex cases of nested meta filters', () => { // scenario overview: // A kuery query @@ -596,7 +745,7 @@ describe('combineQueryAndFilters', () => { query: { language: 'kuery', query: - '( myField: * ) AND ( ( bytes > 4000 ) AND ( ( memory > 5000 ) OR ( memory >= 15000 ) ) AND ( myField: * ) AND ( otherField >= 15 ) )', + '( ( myField: * ) AND ( bytes > 4000 ) AND ( ( memory > 5000 ) OR ( memory >= 15000 ) ) AND ( myField: * ) AND ( otherField >= 15 ) )', }, }); }); @@ -796,7 +945,7 @@ describe('combineQueryAndFilters', () => { ], query: { language: 'lucene', - query: '( myField ) AND ( anotherField )', + query: '( ( myField ) AND ( anotherField ) )', }, }); }); diff --git a/x-pack/plugins/lens/public/app_plugin/show_underlying_data.ts b/x-pack/plugins/lens/public/app_plugin/show_underlying_data.ts index 7329159cc1d3b..12cd5aac25552 100644 --- a/x-pack/plugins/lens/public/app_plugin/show_underlying_data.ts +++ b/x-pack/plugins/lens/public/app_plugin/show_underlying_data.ts @@ -16,6 +16,7 @@ import { import { i18n } from '@kbn/i18n'; import { RecursiveReadonly } from '@kbn/utility-types'; import { Capabilities } from 'kibana/public'; +import { partition } from 'lodash'; import { TableInspectorAdapter } from '../editor_frame_service/types'; import { Datasource } from '../types'; @@ -24,10 +25,17 @@ export const getShowUnderlyingDataLabel = () => defaultMessage: 'Open in Discover', }); -function joinQueries(queries: Query[][] | undefined) { - if (!queries) { - return ''; +/** + * Joins a series of queries. + * + * Uses "AND" along dimension 1 and "OR" along dimension 2 + */ +function joinQueries(queries: Query[][]) { + // leave a single query alone + if (queries.length === 1 && queries[0].length === 1) { + return queries[0][0].query; } + const expression = queries .filter((subQueries) => subQueries.length) .map((subQueries) => @@ -56,7 +64,10 @@ export function getLayerMetaInfo( currentDatasource: Datasource | undefined, datasourceState: unknown, activeData: TableInspectorAdapter | undefined, - capabilities: RecursiveReadonly + capabilities: RecursiveReadonly<{ + navLinks: Capabilities['navLinks']; + discover?: Capabilities['discover']; + }> ): { meta: LayerMetaInfo | undefined; isVisible: boolean; error: string | undefined } { const isVisible = Boolean(capabilities.navLinks?.discover && capabilities.discover?.show); // If Multiple tables, return @@ -123,40 +134,65 @@ export function getLayerMetaInfo( } // This enforces on assignment time that the two props are not the same -type LanguageAssignments = - | { queryLanguage: 'lucene'; filtersLanguage: 'kuery' } - | { queryLanguage: 'kuery'; filtersLanguage: 'lucene' }; +type QueryLanguage = 'lucene' | 'kuery'; +/** + * Translates an arbitrarily-large set of @type {Query}s (including those supplied in @type {LayerMetaInfo}) + * and existing Kibana @type {Filter}s into a single query and a new set of @type {Filter}s. This allows them to + * function as an equivalent context in Discover. + * + * If some of the queries are in KQL and some in Lucene, all the queries in one language will be merged into + * a large query to be shown in the query bar, while the queries in the other language will be encoded as an + * extra filter pill. + */ export function combineQueryAndFilters( - query: Query | undefined, + query: Query | Query[] | undefined, filters: Filter[], meta: LayerMetaInfo, dataViews: DataViewBase[] | undefined ) { - // Unless a lucene query is already defined, kuery is assigned to it - const { queryLanguage, filtersLanguage }: LanguageAssignments = - query?.language === 'lucene' - ? { queryLanguage: 'lucene', filtersLanguage: 'kuery' } - : { queryLanguage: 'kuery', filtersLanguage: 'lucene' }; - - let newQuery = query; - const enabledFilters = meta.filters.enabled; - if (enabledFilters[queryLanguage]?.length) { - const filtersQuery = joinQueries(enabledFilters[queryLanguage]); - newQuery = { - language: queryLanguage, - query: query?.query.trim() - ? `( ${query.query} ) ${filtersQuery ? `AND ${filtersQuery}` : ''}` - : filtersQuery, - }; - } + const queries: { + kuery: Query[]; + lucene: Query[]; + } = { + kuery: [], + lucene: [], + }; + + const allQueries = Array.isArray(query) ? query : query ? [query] : []; + const nonEmptyQueries = allQueries.filter((q) => Boolean(q.query.trim())); + + [queries.lucene, queries.kuery] = partition(nonEmptyQueries, (q) => q.language === 'lucene'); + + const queryLanguage: QueryLanguage = + (nonEmptyQueries[0]?.language as QueryLanguage | undefined) || 'kuery'; + + const newQuery = { + language: queryLanguage, + query: joinQueries([ + ...queries[queryLanguage].map((q) => [q]), + ...(meta.filters.enabled[queryLanguage] || []), + ]), + }; + + const filtersLanguage = queryLanguage === 'lucene' ? 'kuery' : 'lucene'; // make a copy as the original filters are readonly const newFilters = [...filters]; + const dataView = dataViews?.find(({ id }) => id === meta.id); - if (enabledFilters[filtersLanguage]?.length) { - const queryExpression = joinQueries(enabledFilters[filtersLanguage]); - // Append the new filter based on the queryExpression to the existing ones + + const hasQueriesInFiltersLanguage = Boolean( + meta.filters.enabled[filtersLanguage]?.length || queries[filtersLanguage].length + ); + + if (hasQueriesInFiltersLanguage) { + const queryExpression = joinQueries([ + ...queries[filtersLanguage].map((q) => [q]), + ...(meta.filters.enabled[filtersLanguage] || []), + ]); + + // Create new filter to encode the rest of the query information newFilters.push( buildCustomFilter( meta.id!, @@ -171,11 +207,11 @@ export function combineQueryAndFilters( ) ); } + // for each disabled filter create a new custom filter and disable it // note that both languages go into the filter bar - const disabledFilters = meta.filters.disabled; for (const language of ['lucene', 'kuery'] as const) { - const [disabledQueries] = disabledFilters[language] || []; + const [disabledQueries] = meta.filters.disabled[language] || []; for (const disabledQuery of disabledQueries || []) { let label = disabledQuery.query as string; if (language === 'lucene') { @@ -193,5 +229,6 @@ export function combineQueryAndFilters( ); } } + return { filters: newFilters, query: newQuery }; } diff --git a/x-pack/plugins/lens/public/editor_frame_service/service.tsx b/x-pack/plugins/lens/public/editor_frame_service/service.tsx index b585d03e12f8f..ff05f7e5f0bb9 100644 --- a/x-pack/plugins/lens/public/editor_frame_service/service.tsx +++ b/x-pack/plugins/lens/public/editor_frame_service/service.tsx @@ -61,7 +61,7 @@ export class EditorFrameService { private readonly datasources: Array Promise)> = []; private readonly visualizations: Array Promise)> = []; - private loadDatasources = () => collectAsyncDefinitions(this.datasources); + public loadDatasources = () => collectAsyncDefinitions(this.datasources); public loadVisualizations = () => collectAsyncDefinitions(this.visualizations); /** diff --git a/x-pack/plugins/lens/public/embeddable/embeddable.test.tsx b/x-pack/plugins/lens/public/embeddable/embeddable.test.tsx index 2ac0742ebfdc2..f37b0dfe4ad1e 100644 --- a/x-pack/plugins/lens/public/embeddable/embeddable.test.tsx +++ b/x-pack/plugins/lens/public/embeddable/embeddable.test.tsx @@ -145,11 +145,14 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, inspector: inspectorPluginMock.createStartContract(), getTrigger, theme: themeServiceMock.createStartContract(), visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), documentToExpression: () => Promise.resolve({ @@ -189,9 +192,15 @@ describe('embeddable', () => { basePath, indexPatternService: {} as DataViewsContract, inspector: inspectorPluginMock.createStartContract(), - capabilities: { canSaveDashboards: true, canSaveVisualizations: true }, + capabilities: { + canSaveDashboards: true, + canSaveVisualizations: true, + discover: {}, + navLinks: {}, + }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -236,9 +245,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -294,9 +306,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -341,9 +356,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -387,9 +405,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -429,9 +450,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -474,9 +498,15 @@ describe('embeddable', () => { basePath, inspector: inspectorPluginMock.createStartContract(), indexPatternService: {} as DataViewsContract, - capabilities: { canSaveDashboards: true, canSaveVisualizations: true }, + capabilities: { + canSaveDashboards: true, + canSaveVisualizations: true, + discover: {}, + navLinks: {}, + }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -526,9 +556,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -576,9 +609,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -633,9 +669,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -659,7 +698,7 @@ describe('embeddable', () => { expect.objectContaining({ timeRange, query: [query, savedVis.state.query], - filters: mockInjectFilterReferences(filters, []), + filters, }) ); @@ -691,9 +730,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -723,8 +765,10 @@ describe('embeddable', () => { it('should merge external context with query and filters of the saved object', async () => { const timeRange: TimeRange = { from: 'now-15d', to: 'now' }; - const query: Query = { language: 'kquery', query: 'external filter' }; - const filters: Filter[] = [{ meta: { alias: 'test', negate: false, disabled: false } }]; + const query: Query = { language: 'kquery', query: 'external query' }; + const filters: Filter[] = [ + { meta: { alias: 'external filter', negate: false, disabled: false } }, + ]; const newSavedVis = { ...savedVis, @@ -750,9 +794,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -772,18 +819,16 @@ describe('embeddable', () => { await embeddable.initializeSavedVis(input); embeddable.render(mountpoint); - expect(expressionRenderer.mock.calls[0][0].searchContext).toEqual({ - timeRange, - query: [query, { language: 'kquery', query: 'saved filter' }], - // actual index pattern id gets injected - filters: mockInjectFilterReferences( - [ - filters[0], - { meta: { alias: 'test', negate: false, disabled: false, index: 'injected!' } }, - ], - [] - ), - }); + const expectedFilters = [ + ...input.filters!, + ...mockInjectFilterReferences(newSavedVis.state.filters, []), + ]; + expect(expressionRenderer.mock.calls[0][0].searchContext?.timeRange).toEqual(timeRange); + expect(expressionRenderer.mock.calls[0][0].searchContext?.filters).toEqual(expectedFilters); + expect(expressionRenderer.mock.calls[0][0].searchContext?.query).toEqual([ + query, + { language: 'kquery', query: 'saved filter' }, + ]); }); it('should execute trigger on event from expression renderer', async () => { @@ -798,9 +843,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -846,9 +894,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -891,9 +942,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -951,9 +1005,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -1030,9 +1087,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -1084,9 +1144,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -1135,9 +1198,12 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, visualizationMap: {}, + datasourceMap: {}, injectFilterReferences: jest.fn(mockInjectFilterReferences), theme: themeServiceMock.createStartContract(), documentToExpression: () => @@ -1207,6 +1273,8 @@ describe('embeddable', () => { capabilities: { canSaveDashboards: true, canSaveVisualizations: true, + discover: {}, + navLinks: {}, }, getTrigger, theme: themeServiceMock.createStartContract(), @@ -1216,6 +1284,7 @@ describe('embeddable', () => { onEditAction: onEditActionMock, } as unknown as Visualization, }, + datasourceMap: {}, documentToExpression: documentToExpressionMock, }, { id: '123' } as unknown as LensEmbeddableInput diff --git a/x-pack/plugins/lens/public/embeddable/embeddable.tsx b/x-pack/plugins/lens/public/embeddable/embeddable.tsx index a0d5c91777364..cf126721a7c91 100644 --- a/x-pack/plugins/lens/public/embeddable/embeddable.tsx +++ b/x-pack/plugins/lens/public/embeddable/embeddable.tsx @@ -9,7 +9,7 @@ import { isEqual, uniqBy } from 'lodash'; import React from 'react'; import { i18n } from '@kbn/i18n'; import { render, unmountComponentAtNode } from 'react-dom'; -import { Filter } from '@kbn/es-query'; +import { DataViewBase, Filter } from '@kbn/es-query'; import { ExecutionContextSearch, Query, @@ -55,21 +55,25 @@ import { LensTableRowContextMenuEvent, VisualizationMap, Visualization, + DatasourceMap, + Datasource, } from '../types'; import type { DataViewsContract, DataView } from '../../../../../src/plugins/data_views/public'; import { getEditPath, DOC_TYPE, PLUGIN_ID } from '../../common'; import type { + Capabilities, IBasePath, KibanaExecutionContext, ThemeServiceStart, } from '../../../../../src/core/public'; import { LensAttributeService } from '../lens_attribute_service'; -import type { ErrorMessage } from '../editor_frame_service/types'; +import type { ErrorMessage, TableInspectorAdapter } from '../editor_frame_service/types'; import { getLensInspectorService, LensInspector } from '../lens_inspector_service'; import { SharingSavedObjectProps } from '../types'; import type { SpacesPluginStart } from '../../../spaces/public'; -import { inferTimeField } from '../utils'; +import { getActiveDatasourceIdFromDoc, getIndexPatternsObjects, inferTimeField } from '../utils'; +import { getLayerMetaInfo, combineQueryAndFilters } from '../app_plugin/show_underlying_data'; export type LensSavedObjectAttributes = Omit; @@ -114,6 +118,7 @@ export interface LensEmbeddableDeps { ) => Promise<{ ast: Ast | null; errors: ErrorMessage[] | undefined }>; injectFilterReferences: FilterManager['inject']; visualizationMap: VisualizationMap; + datasourceMap: DatasourceMap; indexPatternService: DataViewsContract; expressionRenderer: ReactExpressionRendererType; timefilter: TimefilterContract; @@ -121,12 +126,25 @@ export interface LensEmbeddableDeps { inspector: InspectorStart; getTrigger?: UiActionsStart['getTrigger'] | undefined; getTriggerCompatibleActions?: UiActionsStart['getTriggerCompatibleActions']; - capabilities: { canSaveVisualizations: boolean; canSaveDashboards: boolean }; + capabilities: { + canSaveVisualizations: boolean; + canSaveDashboards: boolean; + navLinks: Capabilities['navLinks']; + discover: Capabilities['discover']; + }; usageCollection?: UsageCollectionSetup; spaces?: SpacesPluginStart; theme: ThemeServiceStart; } +export interface ViewUnderlyingDataArgs { + indexPatternId: string; + timeRange: TimeRange; + filters: Filter[]; + query: Query | undefined; + columns: string[]; +} + const getExpressionFromDocument = async ( document: Document, documentToExpression: LensEmbeddableDeps['documentToExpression'] @@ -138,6 +156,52 @@ const getExpressionFromDocument = async ( }; }; +function getViewUnderlyingDataArgs({ + activeDatasource, + activeDatasourceState, + activeData, + dataViews, + capabilities, + query, + filters, + timeRange, +}: { + activeDatasource: Datasource; + activeDatasourceState: unknown; + activeData: TableInspectorAdapter | undefined; + dataViews: DataViewBase[] | undefined; + capabilities: LensEmbeddableDeps['capabilities']; + query: ExecutionContextSearch['query']; + filters: Filter[]; + timeRange: TimeRange; +}) { + const { error, meta } = getLayerMetaInfo( + activeDatasource, + activeDatasourceState, + activeData, + capabilities + ); + + if (error || !meta) { + return; + } + + const { filters: newFilters, query: newQuery } = combineQueryAndFilters( + query, + filters, + meta, + dataViews + ); + + return { + indexPatternId: meta.id, + timeRange, + filters: newFilters, + query: newQuery, + columns: meta.columns, + }; +} + export class Embeddable extends AbstractEmbeddable implements ReferenceOrValueEmbeddable @@ -173,6 +237,16 @@ export class Embeddable searchSessionId?: string; } = {}; + private activeDataInfo: { + activeData?: TableInspectorAdapter; + activeDatasource?: Datasource; + activeDatasourceState?: unknown; + } = {}; + + private indexPatterns: DataView[] = []; + + private viewUnderlyingDataArgs?: ViewUnderlyingDataArgs; + constructor( private deps: LensEmbeddableDeps, initialInput: LensEmbeddableInput, @@ -387,7 +461,8 @@ export class Embeddable return isDirty; } - private updateActiveData: ExpressionWrapperProps['onData$'] = () => { + private updateActiveData: ExpressionWrapperProps['onData$'] = (_, adapters) => { + this.activeDataInfo.activeData = adapters?.tables?.tables; if (this.input.onLoad) { // once onData$ is get's called from expression renderer, loading becomes false this.input.onLoad(false); @@ -495,22 +570,25 @@ export class Embeddable if (!this.savedVis) { throw new Error('savedVis is required for getMergedSearchContext'); } - const output: ExecutionContextSearch = { + + const context: ExecutionContextSearch = { timeRange: this.externalSearchContext.timeRange, + query: [this.savedVis.state.query], + filters: this.deps.injectFilterReferences( + this.savedVis.state.filters, + this.savedVis.references + ), }; + if (this.externalSearchContext.query) { - output.query = [this.externalSearchContext.query, this.savedVis.state.query]; - } else { - output.query = [this.savedVis.state.query]; + context.query = [this.externalSearchContext.query, ...(context.query as Query[])]; } + if (this.externalSearchContext.filters?.length) { - output.filters = [...this.externalSearchContext.filters, ...this.savedVis.state.filters]; - } else { - output.filters = [...this.savedVis.state.filters]; + context.filters = [...this.externalSearchContext.filters, ...(context.filters as Filter[])]; } - output.filters = this.deps.injectFilterReferences(output.filters, this.savedVis.references); - return output; + return context; } private get onEditAction(): Visualization['onEditAction'] { @@ -597,28 +675,78 @@ export class Embeddable } } + private async loadViewUnderlyingDataArgs(): Promise { + const mergedSearchContext = this.getMergedSearchContext(); + + if (!this.activeDataInfo.activeData || !mergedSearchContext.timeRange) { + return false; + } + + const activeDatasourceId = getActiveDatasourceIdFromDoc(this.savedVis); + if (!activeDatasourceId) { + return false; + } + + this.activeDataInfo.activeDatasource = this.deps.datasourceMap[activeDatasourceId]; + const docDatasourceState = this.savedVis?.state.datasourceStates[activeDatasourceId]; + + if (!this.activeDataInfo.activeDatasourceState) { + this.activeDataInfo.activeDatasourceState = + await this.activeDataInfo.activeDatasource.initialize( + docDatasourceState, + this.savedVis?.references + ); + } + + const viewUnderlyingDataArgs = getViewUnderlyingDataArgs({ + activeDatasource: this.activeDataInfo.activeDatasource, + activeDatasourceState: this.activeDataInfo.activeDatasourceState, + activeData: this.activeDataInfo.activeData, + dataViews: this.indexPatterns, + capabilities: this.deps.capabilities, + query: mergedSearchContext.query, + filters: mergedSearchContext.filters || [], + timeRange: mergedSearchContext.timeRange, + }); + + const loaded = typeof viewUnderlyingDataArgs !== 'undefined'; + if (loaded) { + this.viewUnderlyingDataArgs = viewUnderlyingDataArgs; + } + return loaded; + } + + /** + * Returns the necessary arguments to view the underlying data in discover. + * + * Only makes sense to call this after canViewUnderlyingData has been checked + */ + public getViewUnderlyingDataArgs() { + return this.viewUnderlyingDataArgs; + } + + public canViewUnderlyingData() { + return this.loadViewUnderlyingDataArgs(); + } + async initializeOutput() { if (!this.savedVis) { return; } - const responses = await Promise.allSettled( - uniqBy( - this.savedVis.references.filter(({ type }) => type === 'index-pattern'), - 'id' - ).map(({ id }) => this.deps.indexPatternService.get(id)) + + const { indexPatterns } = await getIndexPatternsObjects( + this.savedVis?.references.map(({ id }) => id) || [], + this.deps.indexPatternService ); - const indexPatterns = responses - .filter( - (response): response is PromiseFulfilledResult => response.status === 'fulfilled' - ) - .map(({ value }) => value); + + this.indexPatterns = uniqBy(indexPatterns, 'id'); // passing edit url and index patterns to the output of this embeddable for // the container to pick them up and use them to configure filter bar and // config dropdown correctly. const input = this.getInput(); - this.errors = this.maybeAddTimeRangeError(this.errors, input, indexPatterns); + this.errors = this.maybeAddTimeRangeError(this.errors, input, this.indexPatterns); if (this.errors) { this.logError('validation'); @@ -633,7 +761,7 @@ export class Embeddable title, editPath: getEditPath(savedObjectId), editUrl: this.deps.basePath.prepend(`/app/lens${getEditPath(savedObjectId)}`), - indexPatterns, + indexPatterns: this.indexPatterns, }); // deferred loading of this embeddable is complete diff --git a/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts b/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts index af76fd83b2b97..77a4acfa7d433 100644 --- a/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts +++ b/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts @@ -26,7 +26,7 @@ import { DOC_TYPE } from '../../common/constants'; import { ErrorMessage } from '../editor_frame_service/types'; import { extract, inject } from '../../common/embeddable_factory'; import type { SpacesPluginStart } from '../../../spaces/public'; -import { VisualizationMap } from '../types'; +import { DatasourceMap, VisualizationMap } from '../types'; export interface LensEmbeddableStartServices { timefilter: TimefilterContract; @@ -43,6 +43,7 @@ export interface LensEmbeddableStartServices { ) => Promise<{ ast: Ast | null; errors: ErrorMessage[] | undefined }>; injectFilterReferences: FilterManager['inject']; visualizationMap: VisualizationMap; + datasourceMap: DatasourceMap; spaces?: SpacesPluginStart; theme: ThemeServiceStart; } @@ -92,6 +93,7 @@ export class EmbeddableFactory implements EmbeddableFactoryDefinition { documentToExpression, injectFilterReferences, visualizationMap, + datasourceMap, uiActions, coreHttp, attributeService, @@ -118,9 +120,12 @@ export class EmbeddableFactory implements EmbeddableFactoryDefinition { documentToExpression, injectFilterReferences, visualizationMap, + datasourceMap, capabilities: { canSaveDashboards: Boolean(capabilities.dashboard?.showWriteControls), canSaveVisualizations: Boolean(capabilities.visualize.save), + navLinks: capabilities.navLinks, + discover: capabilities.discover, }, usageCollection, theme, diff --git a/x-pack/plugins/lens/public/plugin.ts b/x-pack/plugins/lens/public/plugin.ts index d2bb7cdbb4344..dbecf1e7d779f 100644 --- a/x-pack/plugins/lens/public/plugin.ts +++ b/x-pack/plugins/lens/public/plugin.ts @@ -16,8 +16,12 @@ import type { DataPublicPluginSetup, DataPublicPluginStart, } from '../../../../src/plugins/data/public'; +import { + CONTEXT_MENU_TRIGGER, + EmbeddableSetup, + EmbeddableStart, +} from '../../../../src/plugins/embeddable/public'; import type { DataViewsPublicPluginStart } from '../../../../src/plugins/data_views/public'; -import type { EmbeddableSetup, EmbeddableStart } from '../../../../src/plugins/embeddable/public'; import type { DashboardStart } from '../../../../src/plugins/dashboard/public'; import type { SpacesPluginStart } from '../../spaces/public'; import type { @@ -80,6 +84,7 @@ import type { LensTopNavMenuEntryGenerator, } from './types'; import { getLensAliasConfig } from './vis_type_alias'; +import { createOpenInDiscoverAction } from './trigger_actions/open_in_discover_action'; import { visualizeFieldAction } from './trigger_actions/visualize_field_actions'; import { visualizeTSVBAction } from './trigger_actions/visualize_tsvb_actions'; @@ -259,6 +264,7 @@ export class LensPlugin { eventAnnotation ); const visualizationMap = await this.editorFrameService!.loadVisualizations(); + const datasourceMap = await this.editorFrameService!.loadDatasources(); return { attributeService: getLensAttributeService(coreStart, plugins), @@ -269,6 +275,7 @@ export class LensPlugin { documentToExpression: this.editorFrameService!.documentToExpression, injectFilterReferences: data.query.filterManager.inject.bind(data.query.filterManager), visualizationMap, + datasourceMap, indexPatternService: plugins.dataViews, uiActions: plugins.uiActions, usageCollection, @@ -440,6 +447,14 @@ export class LensPlugin { visualizeTSVBAction(core.application) ); + startDependencies.uiActions.addTriggerAction( + CONTEXT_MENU_TRIGGER, + createOpenInDiscoverAction( + startDependencies.discover!, + core.application.capabilities.discover.show as boolean + ) + ); + return { EmbeddableComponent: getEmbeddableComponent(core, startDependencies), SaveModalComponent: getSaveModalComponent(core, startDependencies), diff --git a/x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.test.ts b/x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.test.ts new file mode 100644 index 0000000000000..321f87d42fc39 --- /dev/null +++ b/x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { DiscoverStart } from '../../../../../src/plugins/discover/public'; +import type { IEmbeddable } from '../../../../../src/plugins/embeddable/public'; +import { ActionExecutionContext } from '../../../../../src/plugins/ui_actions/public'; +import { DOC_TYPE } from '../../common'; +import { Embeddable } from '../embeddable'; +import { createOpenInDiscoverAction } from './open_in_discover_action'; + +describe('open in discover action', () => { + describe('compatibility check', () => { + it('is incompatible with non-lens embeddables', async () => { + const embeddable = { type: 'NOT_LENS' } as IEmbeddable; + + const isCompatible = await createOpenInDiscoverAction({} as DiscoverStart, true).isCompatible( + { + embeddable, + } as ActionExecutionContext<{ embeddable: IEmbeddable }> + ); + + expect(isCompatible).toBeFalsy(); + }); + it('is incompatible if user cant access Discover app', async () => { + // setup + const embeddable = { type: DOC_TYPE } as Embeddable; + embeddable.canViewUnderlyingData = () => Promise.resolve(true); + + let hasDiscoverAccess = true; + // make sure it would work if we had access to Discover + expect( + await createOpenInDiscoverAction({} as DiscoverStart, hasDiscoverAccess).isCompatible({ + embeddable, + } as unknown as ActionExecutionContext<{ embeddable: IEmbeddable }>) + ).toBeTruthy(); + + // make sure no Discover access makes the action incompatible + hasDiscoverAccess = false; + expect( + await createOpenInDiscoverAction({} as DiscoverStart, hasDiscoverAccess).isCompatible({ + embeddable, + } as unknown as ActionExecutionContext<{ embeddable: IEmbeddable }>) + ).toBeFalsy(); + }); + it('checks for ability to view underlying data if lens embeddable', async () => { + // setup + const embeddable = { type: DOC_TYPE } as Embeddable; + + // test false + embeddable.canViewUnderlyingData = jest.fn(() => Promise.resolve(false)); + expect( + await createOpenInDiscoverAction({} as DiscoverStart, true).isCompatible({ + embeddable, + } as unknown as ActionExecutionContext<{ embeddable: IEmbeddable }>) + ).toBeFalsy(); + + expect(embeddable.canViewUnderlyingData).toHaveBeenCalledTimes(1); + + // test true + embeddable.canViewUnderlyingData = jest.fn(() => Promise.resolve(true)); + expect( + await createOpenInDiscoverAction({} as DiscoverStart, true).isCompatible({ + embeddable, + } as unknown as ActionExecutionContext<{ embeddable: IEmbeddable }>) + ).toBeTruthy(); + + expect(embeddable.canViewUnderlyingData).toHaveBeenCalledTimes(1); + }); + }); + + it('navigates to discover when executed', async () => { + const viewUnderlyingDataArgs = { + indexPatternId: 'index-pattern-id', + timeRange: {}, + filters: [], + query: undefined, + columns: [], + }; + + const embeddable = { + getViewUnderlyingDataArgs: jest.fn(() => viewUnderlyingDataArgs), + }; + + const discoverUrl = 'https://discover-redirect-url'; + const discover = { + locator: { + getRedirectUrl: jest.fn(() => discoverUrl), + }, + } as unknown as DiscoverStart; + + globalThis.open = jest.fn(); + + await createOpenInDiscoverAction(discover, true).execute({ + embeddable, + } as unknown as ActionExecutionContext<{ + embeddable: IEmbeddable; + }>); + + expect(embeddable.getViewUnderlyingDataArgs).toHaveBeenCalled(); + expect(discover.locator!.getRedirectUrl).toHaveBeenCalledWith(viewUnderlyingDataArgs); + expect(globalThis.open).toHaveBeenCalledWith(discoverUrl, '_blank'); + }); +}); diff --git a/x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.ts b/x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.ts new file mode 100644 index 0000000000000..947e01fd15bc9 --- /dev/null +++ b/x-pack/plugins/lens/public/trigger_actions/open_in_discover_action.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { i18n } from '@kbn/i18n'; +import type { IEmbeddable } from 'src/plugins/embeddable/public'; +import { createAction } from '../../../../../src/plugins/ui_actions/public'; +import type { Embeddable } from '../embeddable'; +import type { DiscoverStart } from '../../../../../src/plugins/discover/public'; +import { DOC_TYPE } from '../../common'; + +const ACTION_OPEN_IN_DISCOVER = 'ACTION_OPEN_IN_DISCOVER'; + +export const createOpenInDiscoverAction = (discover: DiscoverStart, hasDiscoverAccess: boolean) => + createAction<{ embeddable: IEmbeddable }>({ + type: ACTION_OPEN_IN_DISCOVER, + id: ACTION_OPEN_IN_DISCOVER, + order: 19, // right after Inspect which is 20 + getIconType: () => 'popout', + getDisplayName: () => + i18n.translate('xpack.lens.actions.openInDiscover', { + defaultMessage: 'Open in Discover', + }), + isCompatible: async (context: { embeddable: IEmbeddable }) => { + if (!hasDiscoverAccess) return false; + return ( + context.embeddable.type === DOC_TYPE && + (await (context.embeddable as Embeddable).canViewUnderlyingData()) + ); + }, + execute: async (context: { embeddable: Embeddable }) => { + const args = context.embeddable.getViewUnderlyingDataArgs()!; + const discoverUrl = discover.locator?.getRedirectUrl({ + ...args, + }); + window.open(discoverUrl, '_blank'); + }, + }); diff --git a/x-pack/test/functional/apps/lens/dashboard.ts b/x-pack/test/functional/apps/lens/dashboard.ts index e60e3ca76030c..97dc29280761f 100644 --- a/x-pack/test/functional/apps/lens/dashboard.ts +++ b/x-pack/test/functional/apps/lens/dashboard.ts @@ -91,8 +91,8 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { }); // Requires xpack.discoverEnhanced.actions.exploreDataInContextMenu.enabled - // setting set in kibana.yml to work (not enabled by default) - it('should be able to drill down to discover', async () => { + // setting set in kibana.yml to test (not enabled by default) + it('should hide old "explore underlying data" action', async () => { await PageObjects.common.navigateToApp('dashboard'); await PageObjects.dashboard.clickNewDashboard(); await dashboardAddPanel.clickOpenAddPanel(); @@ -102,13 +102,8 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.goToTimeRange(); await PageObjects.dashboard.saveDashboard('lnsDrilldown'); await panelActions.openContextMenu(); - await testSubjects.clickWhenNotDisabled('embeddablePanelAction-ACTION_EXPLORE_DATA'); - await PageObjects.discover.waitForDiscoverAppOnScreen(); - const el = await testSubjects.find('indexPattern-switch-link'); - const text = await el.getVisibleText(); - - expect(text).to.be('logstash-*'); + expect(await testSubjects.exists('embeddablePanelAction-ACTION_EXPLORE_DATA')).not.to.be.ok(); }); it('should be able to add filters by clicking in pie chart', async () => { diff --git a/x-pack/test/functional/apps/lens/index.ts b/x-pack/test/functional/apps/lens/index.ts index 20da3e48fc8ae..f66f6cf2f30e5 100644 --- a/x-pack/test/functional/apps/lens/index.ts +++ b/x-pack/test/functional/apps/lens/index.ts @@ -58,6 +58,7 @@ export default function ({ getService, loadTestFile, getPageObjects }: FtrProvid loadTestFile(require.resolve('./multi_terms')); loadTestFile(require.resolve('./epoch_millis')); loadTestFile(require.resolve('./show_underlying_data')); + loadTestFile(require.resolve('./show_underlying_data_dashboard')); }); describe('', function () { diff --git a/x-pack/test/functional/apps/lens/show_underlying_data_dashboard.ts b/x-pack/test/functional/apps/lens/show_underlying_data_dashboard.ts new file mode 100644 index 0000000000000..dc25e5f77f412 --- /dev/null +++ b/x-pack/test/functional/apps/lens/show_underlying_data_dashboard.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import expect from '@kbn/expect'; +import uuid from 'uuid'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +export default function ({ getService, getPageObjects }: FtrProviderContext) { + const PageObjects = getPageObjects([ + 'visualize', + 'lens', + 'dashboard', + 'header', + 'discover', + 'common', + ]); + + const listingTable = getService('listingTable'); + const testSubjects = getService('testSubjects'); + const dashboardPanelActions = getService('dashboardPanelActions'); + const filterBarService = getService('filterBar'); + const queryBar = getService('queryBar'); + const browser = getService('browser'); + const retry = getService('retry'); + + describe('lens show underlying data from dashboard', () => { + it('should show the open button for a compatible saved visualization', async () => { + await PageObjects.visualize.gotoVisualizationLandingPage(); + await listingTable.searchForItemWithName('lnsXYvis'); + await PageObjects.lens.clickVisualizeListItemTitle('lnsXYvis'); + await PageObjects.lens.goToTimeRange(); + await PageObjects.lens.save('Embedded Visualization', true, false, false, 'new'); + + await PageObjects.dashboard.saveDashboard(`Open in Discover Testing ${uuid()}`, { + exitFromEditMode: true, + }); + + await dashboardPanelActions.openContextMenu(); + + await testSubjects.click('embeddablePanelAction-ACTION_OPEN_IN_DISCOVER'); + + const [dashboardWindowHandle, discoverWindowHandle] = await browser.getAllWindowHandles(); + await browser.switchToWindow(discoverWindowHandle); + + await PageObjects.header.waitUntilLoadingHasFinished(); + await testSubjects.existOrFail('discoverChart'); + // check the table columns + const columns = await PageObjects.discover.getColumnHeaders(); + expect(columns).to.eql(['ip', '@timestamp', 'bytes']); + + await browser.closeCurrentWindow(); + await browser.switchToWindow(dashboardWindowHandle); + }); + + it('should bring both dashboard context and visualization context to discover', async () => { + await PageObjects.dashboard.switchToEditMode(); + await dashboardPanelActions.clickEdit(); + + await queryBar.switchQueryLanguage('lucene'); + await queryBar.setQuery('host.keyword www.elastic.co'); + await queryBar.submitQuery(); + await filterBarService.addFilter('geo.src', 'is', 'AF'); + // the filter bar seems to need a moment to settle before saving and returning + await PageObjects.common.sleep(1000); + + await PageObjects.lens.saveAndReturn(); + + await queryBar.switchQueryLanguage('kql'); + await queryBar.setQuery('request.keyword : "/apm"'); + await queryBar.submitQuery(); + await filterBarService.addFilter( + 'host.raw', + 'is', + 'cdn.theacademyofperformingartsandscience.org' + ); + + await PageObjects.dashboard.clickQuickSave(); + + // make sure Open in Discover is also available in edit mode + await dashboardPanelActions.openContextMenuMorePanel(); + await testSubjects.existOrFail('embeddablePanelAction-ACTION_OPEN_IN_DISCOVER'); + + await PageObjects.dashboard.clickCancelOutOfEditMode(); + + await dashboardPanelActions.openContextMenu(); + + await testSubjects.click('embeddablePanelAction-ACTION_OPEN_IN_DISCOVER'); + + const [dashboardWindowHandle, discoverWindowHandle] = await browser.getAllWindowHandles(); + await browser.switchToWindow(discoverWindowHandle); + + await PageObjects.header.waitUntilLoadingHasFinished(); + + await retry.waitFor('filter count to be correct', async () => { + const filterCount = await filterBarService.getFilterCount(); + return filterCount === 3; + }); + + expect( + await filterBarService.hasFilter('host.raw', 'cdn.theacademyofperformingartsandscience.org') + ).to.be.ok(); + expect(await filterBarService.hasFilter('geo.src', 'AF')).to.be.ok(); + expect(await filterBarService.getFiltersLabel()).to.contain('Lens context (lucene)'); + expect(await queryBar.getQueryString()).to.be('request.keyword : "/apm"'); + + await browser.closeCurrentWindow(); + await browser.switchToWindow(dashboardWindowHandle); + }); + }); +} From 072fe63c0b326f6dfd0215cda648c982f4b6bee8 Mon Sep 17 00:00:00 2001 From: Yaroslav Kuznietsov Date: Mon, 28 Mar 2022 18:17:36 +0300 Subject: [PATCH 027/160] [XY] Expression chart. (#127150) * added xy plugin. * Added expressionXY limits. * Added xy expression functions to the expression_xy plugin. * Moved xy to a separate plugin. * Fixed bugs, caused by the refactoring process. * Fixed lens snapshots. * Removed new line. * Fixed xy_chart tests. * Added lazy loading for xy chart. * Fixed xy chart test. * Fixed broken chart selectors. * Fixed dashboard tests. * dashboard test fixed. * Fixed heatmap vis. * Smokescreen test fixed. * more fixes. * async dashboard tests fixed. * Fixed xy smokescreen tests selectors. * fixed show_underlying_data tests. * Updated snapshots. * updated limits. * Fixed more selectors * Fixed persistent context test. * Fixed some more test at ml. * Fixed types and imports * Fixed handlers.inspectorAdapters.tables.logDatatable * Fixed logDatatable * Translations fixed. * Fixed "Visualize App ... cleans filters and query" test. * Fixed "lens disable auto-apply tests" test. * Updated dashboard tests. * Fixed translations. * Expression tests fixed. * Cleaned up expression_xy. * cleaned up lens xy_visualization. * Moved XY state types to lens. * Update src/plugins/chart_expressions/expression_xy/README.md Co-authored-by: Marta Bondyra * [CI] Auto-commit changed files from 'node scripts/build_plugin_list_docs' * Removed yConfig from *Layers types * Removed not used utils and styles. Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> Co-authored-by: Marta Bondyra --- .github/CODEOWNERS | 1 + .i18nrc.json | 1 + docs/developer/plugin-list.asciidoc | 4 + packages/kbn-optimizer/limits.yml | 1 + .../chart_expressions/expression_xy/README.md | 9 + .../expression_xy/common/__mocks__/index.ts | 128 + .../expression_xy/common/constants.ts | 111 + .../annotation_layer_config.ts | 49 + .../axis_extent_config.ts | 54 + .../axis_titles_visibility_config.ts | 53 + .../data_layer_config.test.ts | 33 + .../expression_functions/data_layer_config.ts | 123 + .../grid_lines_config.test.ts | 20 + .../grid_lines_config.ts | 32 +- .../common/expression_functions/index.ts | 19 + .../labels_orientation_config.test.ts | 20 + .../labels_orientation_config.ts | 40 +- .../legend_config.test.ts | 21 + .../expression_functions/legend_config.ts | 102 + .../reference_line_layer_config.ts | 62 + .../tick_labels_config.test.ts | 20 + .../tick_labels_config.ts | 32 +- .../expression_functions/xy_vis.test.ts | 21 + .../common/expression_functions/xy_vis.ts | 154 +- .../expression_functions/y_axis_config.ts | 93 + .../expression_xy/common/index.ts | 66 + .../common/types/expression_functions.ts | 239 ++ .../common/types/expression_renderers.ts | 21 + .../expression_xy/common/types/index.ts | 10 + .../expression_xy/jest.config.js | 19 + .../expression_xy/kibana.json | 15 + .../expression_xy/public/__mocks__/index.tsx | 224 ++ .../__snapshots__/xy_chart.test.tsx.snap | 22 +- .../public/components/annotations.scss | 18 + .../public/components/annotations.tsx | 157 +- .../expression_xy/public/components/index.ts | 13 + .../public/components/legend_action.test.tsx | 17 +- .../public/components/legend_action.tsx | 17 +- .../components/legend_action_popover.tsx | 108 + .../public/components/reference_lines.scss | 4 +- .../components/reference_lines.test.tsx | 30 +- .../public/components/reference_lines.tsx | 366 ++ .../public/components}/x_domain.tsx | 12 +- .../public/components/xy_chart.scss | 7 + .../public/components/xy_chart.test.tsx | 2703 ++++++++++++++ .../public/components/xy_chart.tsx | 229 +- .../expression_xy/public/definitions/index.ts | 9 + .../public/definitions/visualizations.ts | 34 + .../public/expression_renderers/index.ts | 10 + .../xy_chart_renderer.tsx | 90 + .../public/helpers/annotations.tsx | 137 +- .../public/helpers/annotations_icon_set.tsx | 101 + .../public/helpers/axes_configuration.test.ts | 334 ++ .../public/helpers/axes_configuration.ts | 146 + .../public/helpers/color_assignment.test.ts | 239 ++ .../public/helpers/color_assignment.ts | 93 + .../public/helpers}/fitting_functions.ts | 7 +- .../expression_xy/public/helpers/icon.ts | 11 + .../expression_xy/public/helpers/index.ts | 19 + .../public/helpers/interval.test.ts | 80 + .../expression_xy/public/helpers/interval.ts | 36 + .../expression_xy/public/helpers/layers.ts | 30 + .../public/helpers/reference_lines.ts | 76 + .../expression_xy/public/helpers/state.ts | 36 + .../public/helpers/visualization.ts | 43 + .../expression_xy/public/icons/area.tsx | 32 + .../public/icons/area_percentage.tsx | 32 + .../public/icons/area_stacked.tsx | 32 + .../expression_xy/public/icons/bar.tsx | 32 + .../public/icons/bar_horizontal.tsx | 32 + .../icons/bar_horizontal_percentage.tsx | 36 + .../public/icons/bar_horizontal_stacked.tsx | 36 + .../public/icons/bar_percentage.tsx | 32 + .../public/icons/bar_reference_line.tsx | 37 + .../public/icons/bar_stacked.tsx | 32 + .../expression_xy/public/icons/circle.tsx | 32 + .../expression_xy/public/icons/index.ts | 22 + .../expression_xy/public/icons/line.tsx | 32 + .../expression_xy/public/icons/mixed_xy.tsx | 36 + .../expression_xy/public/icons/triangle.tsx | 31 + .../expression_xy/public/index.ts | 17 + .../expression_xy/public/plugin.ts | 99 + .../expression_xy/public/types.ts | 116 + .../expression_xy/server/index.ts | 15 + .../expression_xy/server/plugin.ts | 47 + .../expression_xy/server/types.ts | 20 + .../expression_xy/tsconfig.json | 26 + .../static/components/empty_placeholder.tsx | 5 +- test/functional/apps/home/_sample_data.ts | 2 +- .../plugins/lens/common/expressions/index.ts | 1 - .../expressions/xy_chart/axis_config.ts | 207 -- .../lens/common/expressions/xy_chart/index.ts | 18 - .../layer_config/annotation_layer_config.ts | 67 - .../layer_config/data_layer_config.ts | 122 - .../xy_chart/layer_config/index.ts | 17 - .../reference_line_layer_config.ts | 64 - .../expressions/xy_chart/legend_config.ts | 142 - .../expressions/xy_chart/series_type.ts | 18 - .../common/expressions/xy_chart/xy_args.ts | 45 - x-pack/plugins/lens/kibana.json | 1 + x-pack/plugins/lens/public/expressions.ts | 29 - x-pack/plugins/lens/public/index.ts | 53 +- .../shared_components/axis_title_settings.tsx | 3 +- .../__snapshots__/to_expression.test.ts.snap | 21 +- .../annotations/config_panel/index.tsx | 3 +- .../annotations/expression.scss | 37 - .../xy_visualization/annotations/helpers.tsx | 7 +- .../axes_configuration.test.ts | 12 +- .../xy_visualization/axes_configuration.ts | 3 +- .../xy_visualization/color_assignment.test.ts | 10 +- .../xy_visualization/color_assignment.ts | 39 +- .../public/xy_visualization/expression.scss | 15 - .../xy_visualization/expression.test.tsx | 3167 ----------------- .../expression_reference_lines.tsx | 213 -- .../expression_thresholds.scss | 18 - .../lens/public/xy_visualization/index.ts | 17 +- .../reference_line_helpers.test.ts | 12 +- .../reference_line_helpers.tsx | 23 +- .../public/xy_visualization/state_helpers.ts | 8 +- .../xy_visualization/to_expression.test.ts | 2 +- .../public/xy_visualization/to_expression.ts | 42 +- .../lens/public/xy_visualization/types.ts | 38 +- .../xy_visualization/visualization.test.ts | 20 +- .../public/xy_visualization/visualization.tsx | 51 +- .../visualization_helpers.tsx | 25 +- .../xy_config_panel/axis_settings_popover.tsx | 7 +- .../xy_config_panel/color_picker.tsx | 7 +- .../xy_config_panel/dimension_editor.tsx | 31 +- .../xy_config_panel/index.tsx | 5 +- .../xy_config_panel/layer_header.tsx | 9 +- .../xy_config_panel/reference_line_panel.tsx | 8 +- .../shared/line_style_settings.tsx | 3 +- .../shared/marker_decoration_settings.tsx | 5 +- .../end_value_definitions.ts} | 7 +- .../fitting_function_definitions.ts} | 7 +- .../visual_options_popover/index.tsx | 2 +- .../line_curve_option.tsx | 2 +- .../missing_values_option.tsx | 8 +- .../visual_options_popover.test.tsx | 29 +- .../xy_config_panel/xy_config_panel.test.tsx | 3 +- .../xy_visualization/xy_suggestions.test.ts | 9 +- .../public/xy_visualization/xy_suggestions.ts | 24 +- .../xy_visualization/xy_visualization.ts | 1 - .../lens/server/expressions/expressions.ts | 20 - .../saved_object_migrations.test.ts | 8 +- x-pack/plugins/lens/tsconfig.json | 109 +- .../translations/translations/fr-FR.json | 86 +- .../translations/translations/ja-JP.json | 84 +- .../translations/translations/zh-CN.json | 86 +- .../embedded_lens/embedded_example.ts | 6 +- .../apps/dashboard/_async_dashboard.ts | 8 +- .../apps/dashboard/dashboard_lens_by_value.ts | 2 +- .../time_to_visualize_security.ts | 2 +- .../functional/apps/lens/add_to_dashboard.ts | 4 +- .../test/functional/apps/lens/chart_data.ts | 14 +- .../apps/lens/disable_auto_apply.ts | 2 +- .../functional/apps/lens/drag_and_drop.ts | 29 +- .../test/functional/apps/lens/epoch_millis.ts | 4 +- x-pack/test/functional/apps/lens/formula.ts | 4 +- x-pack/test/functional/apps/lens/gauge.ts | 2 +- x-pack/test/functional/apps/lens/heatmap.ts | 14 +- x-pack/test/functional/apps/lens/inspector.ts | 2 +- .../apps/lens/persistent_context.ts | 4 +- x-pack/test/functional/apps/lens/rollup.ts | 4 +- .../apps/lens/show_underlying_data.ts | 12 +- .../test/functional/apps/lens/smokescreen.ts | 20 +- .../functional/apps/lens/tsvb_open_in_lens.ts | 10 +- .../apps/maps/lens/choropleth_chart.ts | 2 +- .../data_visualizer/index_data_visualizer.ts | 10 +- .../test/functional/page_objects/lens_page.ts | 4 +- .../services/ml/data_visualizer_table.ts | 4 +- .../save_search_session_relative_time.ts | 8 +- 172 files changed, 7945 insertions(+), 5220 deletions(-) create mode 100755 src/plugins/chart_expressions/expression_xy/README.md create mode 100644 src/plugins/chart_expressions/expression_xy/common/__mocks__/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/constants.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/annotation_layer_config.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_extent_config.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_titles_visibility_config.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.test.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.test.ts rename {x-pack/plugins/lens/common/expressions/xy_chart => src/plugins/chart_expressions/expression_xy/common/expression_functions}/grid_lines_config.ts (51%) create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.test.ts rename {x-pack/plugins/lens/common/expressions/xy_chart => src/plugins/chart_expressions/expression_xy/common/expression_functions}/labels_orientation_config.ts (50%) create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.test.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/reference_line_layer_config.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.test.ts rename {x-pack/plugins/lens/common/expressions/xy_chart => src/plugins/chart_expressions/expression_xy/common/expression_functions}/tick_labels_config.ts (51%) create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.test.ts rename x-pack/plugins/lens/common/expressions/xy_chart/xy_chart.ts => src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.ts (53%) create mode 100644 src/plugins/chart_expressions/expression_xy/common/expression_functions/y_axis_config.ts create mode 100755 src/plugins/chart_expressions/expression_xy/common/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/types/expression_functions.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/types/expression_renderers.ts create mode 100644 src/plugins/chart_expressions/expression_xy/common/types/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/jest.config.js create mode 100755 src/plugins/chart_expressions/expression_xy/kibana.json create mode 100644 src/plugins/chart_expressions/expression_xy/public/__mocks__/index.tsx rename x-pack/plugins/lens/public/xy_visualization/__snapshots__/expression.test.tsx.snap => src/plugins/chart_expressions/expression_xy/public/components/__snapshots__/xy_chart.test.tsx.snap (97%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/components/annotations.scss rename x-pack/plugins/lens/public/xy_visualization/annotations/expression.tsx => src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx (66%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/components/index.ts rename x-pack/plugins/lens/public/xy_visualization/get_legend_action.test.tsx => src/plugins/chart_expressions/expression_xy/public/components/legend_action.test.tsx (92%) rename x-pack/plugins/lens/public/xy_visualization/get_legend_action.tsx => src/plugins/chart_expressions/expression_xy/public/components/legend_action.tsx (79%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/components/legend_action_popover.tsx rename x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.scss => src/plugins/chart_expressions/expression_xy/public/components/reference_lines.scss (79%) rename x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.test.tsx => src/plugins/chart_expressions/expression_xy/public/components/reference_lines.test.tsx (93%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx rename {x-pack/plugins/lens/public/xy_visualization => src/plugins/chart_expressions/expression_xy/public/components}/x_domain.tsx (89%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/components/xy_chart.scss create mode 100644 src/plugins/chart_expressions/expression_xy/public/components/xy_chart.test.tsx rename x-pack/plugins/lens/public/xy_visualization/expression.tsx => src/plugins/chart_expressions/expression_xy/public/components/xy_chart.tsx (81%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/definitions/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/definitions/visualizations.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/expression_renderers/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx rename x-pack/plugins/lens/public/xy_visualization/annotations_helpers.tsx => src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx (57%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/annotations_icon_set.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.test.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.test.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.ts rename {x-pack/plugins/lens/public/xy_visualization => src/plugins/chart_expressions/expression_xy/public/helpers}/fitting_functions.ts (74%) create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/icon.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/interval.test.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/interval.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/layers.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/reference_lines.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/state.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/helpers/visualization.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/area.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/area_percentage.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/area_stacked.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_percentage.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_stacked.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar_percentage.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar_reference_line.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/bar_stacked.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/circle.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/index.ts create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/line.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/mixed_xy.tsx create mode 100644 src/plugins/chart_expressions/expression_xy/public/icons/triangle.tsx create mode 100755 src/plugins/chart_expressions/expression_xy/public/index.ts create mode 100755 src/plugins/chart_expressions/expression_xy/public/plugin.ts create mode 100755 src/plugins/chart_expressions/expression_xy/public/types.ts create mode 100755 src/plugins/chart_expressions/expression_xy/server/index.ts create mode 100755 src/plugins/chart_expressions/expression_xy/server/plugin.ts create mode 100755 src/plugins/chart_expressions/expression_xy/server/types.ts create mode 100644 src/plugins/chart_expressions/expression_xy/tsconfig.json delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/axis_config.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/index.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/layer_config/annotation_layer_config.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/layer_config/data_layer_config.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/layer_config/index.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/layer_config/reference_line_layer_config.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/legend_config.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/series_type.ts delete mode 100644 x-pack/plugins/lens/common/expressions/xy_chart/xy_args.ts delete mode 100644 x-pack/plugins/lens/public/xy_visualization/annotations/expression.scss delete mode 100644 x-pack/plugins/lens/public/xy_visualization/expression.scss delete mode 100644 x-pack/plugins/lens/public/xy_visualization/expression.test.tsx delete mode 100644 x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.tsx delete mode 100644 x-pack/plugins/lens/public/xy_visualization/expression_thresholds.scss rename x-pack/plugins/lens/{common/expressions/xy_chart/end_value.ts => public/xy_visualization/xy_config_panel/visual_options_popover/end_value_definitions.ts} (85%) rename x-pack/plugins/lens/{common/expressions/xy_chart/fitting_function.ts => public/xy_visualization/xy_config_panel/visual_options_popover/fitting_function_definitions.ts} (88%) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 1ccad2a3ac36d..1d4eb2ba39cd5 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -41,6 +41,7 @@ /src/plugins/chart_expressions/expression_heatmap/ @elastic/kibana-vis-editors /src/plugins/chart_expressions/expression_gauge/ @elastic/kibana-vis-editors /src/plugins/chart_expressions/expression_partition_vis/ @elastic/kibana-vis-editors +/src/plugins/chart_expressions/expression_xy/ @elastic/kibana-vis-editors /src/plugins/url_forwarding/ @elastic/kibana-vis-editors /packages/kbn-tinymath/ @elastic/kibana-vis-editors /x-pack/test/functional/apps/lens @elastic/kibana-vis-editors diff --git a/.i18nrc.json b/.i18nrc.json index 71b68d2c51d85..908963ca4d991 100644 --- a/.i18nrc.json +++ b/.i18nrc.json @@ -26,6 +26,7 @@ "expressionMetric": "src/plugins/expression_metric", "expressionMetricVis": "src/plugins/chart_expressions/expression_metric", "expressionPartitionVis": "src/plugins/chart_expressions/expression_partition_vis", + "expressionXY": "src/plugins/chart_expressions/expression_xy", "expressionRepeatImage": "src/plugins/expression_repeat_image", "expressionRevealImage": "src/plugins/expression_reveal_image", "expressions": "src/plugins/expressions", diff --git a/docs/developer/plugin-list.asciidoc b/docs/developer/plugin-list.asciidoc index b6cac30c1bc88..0b9e48020c680 100644 --- a/docs/developer/plugin-list.asciidoc +++ b/docs/developer/plugin-list.asciidoc @@ -164,6 +164,10 @@ for use in their own application. |Expression Tagcloud plugin adds a tagcloud renderer and function to the expression plugin. The renderer will display the Wordcloud chart. +|{kib-repo}blob/{branch}/src/plugins/chart_expressions/expression_xy/README.md[expressionXY] +|Expression XY plugin adds a xy renderer and function to the expression plugin. The renderer will display the xy chart. + + |{kib-repo}blob/{branch}/src/plugins/field_formats/README.md[fieldFormats] |Index pattern fields formatters diff --git a/packages/kbn-optimizer/limits.yml b/packages/kbn-optimizer/limits.yml index 526c1ff5dad82..34c2285016086 100644 --- a/packages/kbn-optimizer/limits.yml +++ b/packages/kbn-optimizer/limits.yml @@ -124,4 +124,5 @@ pageLoadAssetSize: sessionView: 77750 cloudSecurityPosture: 19109 visTypeGauge: 24113 + expressionXY: 41392 eventAnnotation: 19334 diff --git a/src/plugins/chart_expressions/expression_xy/README.md b/src/plugins/chart_expressions/expression_xy/README.md new file mode 100755 index 0000000000000..5ad68bebd40fb --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/README.md @@ -0,0 +1,9 @@ +# expressionXY + +Expression XY plugin adds a `xy` renderer and function to the expression plugin. The renderer will display the `xy` chart. + +--- + +## Development + +See the [kibana contributing guide](https://github.com/elastic/kibana/blob/main/CONTRIBUTING.md) for instructions setting up your development environment. diff --git a/src/plugins/chart_expressions/expression_xy/common/__mocks__/index.ts b/src/plugins/chart_expressions/expression_xy/common/__mocks__/index.ts new file mode 100644 index 0000000000000..4bafffc065835 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/__mocks__/index.ts @@ -0,0 +1,128 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { Position } from '@elastic/charts'; +import { PaletteOutput } from 'src/plugins/charts/common'; +import { Datatable, DatatableRow } from 'src/plugins/expressions'; +import { LayerTypes } from '../constants'; +import { DataLayerConfigResult, LensMultiTable, XYArgs } from '../types'; + +export const mockPaletteOutput: PaletteOutput = { + type: 'palette', + name: 'mock', + params: {}, +}; + +export const createSampleDatatableWithRows = (rows: DatatableRow[]): Datatable => ({ + type: 'datatable', + columns: [ + { + id: 'a', + name: 'a', + meta: { type: 'number', params: { id: 'number', params: { pattern: '0,0.000' } } }, + }, + { + id: 'b', + name: 'b', + meta: { type: 'number', params: { id: 'number', params: { pattern: '000,0' } } }, + }, + { + id: 'c', + name: 'c', + meta: { + type: 'date', + field: 'order_date', + sourceParams: { type: 'date-histogram', params: { interval: 'auto' } }, + params: { id: 'string' }, + }, + }, + { id: 'd', name: 'ColD', meta: { type: 'string' } }, + ], + rows, +}); + +export const sampleLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'c', + accessors: ['a', 'b'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, +}; + +export const createArgsWithLayers = (layers: DataLayerConfigResult[] = [sampleLayer]): XYArgs => ({ + xTitle: '', + yTitle: '', + yRightTitle: '', + legend: { + type: 'legendConfig', + isVisible: false, + position: Position.Top, + }, + valueLabels: 'hide', + valuesInLegend: false, + axisTitlesVisibilitySettings: { + type: 'axisTitlesVisibilityConfig', + x: true, + yLeft: true, + yRight: true, + }, + tickLabelsVisibilitySettings: { + type: 'tickLabelsConfig', + x: true, + yLeft: false, + yRight: false, + }, + labelsOrientation: { + type: 'labelsOrientationConfig', + x: 0, + yLeft: -90, + yRight: -45, + }, + gridlinesVisibilitySettings: { + type: 'gridlinesConfig', + x: true, + yLeft: false, + yRight: false, + }, + yLeftExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + yRightExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + layers, +}); + +export function sampleArgs() { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: createSampleDatatableWithRows([ + { a: 1, b: 2, c: 'I', d: 'Foo' }, + { a: 1, b: 5, c: 'J', d: 'Bar' }, + ]), + }, + dateRange: { + fromDate: new Date('2019-01-02T05:00:00.000Z'), + toDate: new Date('2019-01-03T05:00:00.000Z'), + }, + }; + + const args: XYArgs = createArgsWithLayers(); + + return { data, args }; +} diff --git a/src/plugins/chart_expressions/expression_xy/common/constants.ts b/src/plugins/chart_expressions/expression_xy/common/constants.ts new file mode 100644 index 0000000000000..bf1e43b205843 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/constants.ts @@ -0,0 +1,111 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export const XY_VIS = 'xyVis'; +export const Y_CONFIG = 'yConfig'; +export const MULTITABLE = 'lens_multitable'; +export const DATA_LAYER = 'dataLayer'; +export const LEGEND_CONFIG = 'legendConfig'; +export const XY_VIS_RENDERER = 'xyVis'; +export const GRID_LINES_CONFIG = 'gridlinesConfig'; +export const ANNOTATION_LAYER = 'annotationLayer'; +export const TICK_LABELS_CONFIG = 'tickLabelsConfig'; +export const AXIS_EXTENT_CONFIG = 'axisExtentConfig'; +export const REFERENCE_LINE_LAYER = 'referenceLineLayer'; +export const LABELS_ORIENTATION_CONFIG = 'labelsOrientationConfig'; +export const AXIS_TITLES_VISIBILITY_CONFIG = 'axisTitlesVisibilityConfig'; + +export const LayerTypes = { + DATA: 'data', + REFERENCELINE: 'referenceLine', + ANNOTATIONS: 'annotations', +} as const; + +export const FittingFunctions = { + NONE: 'None', + ZERO: 'Zero', + LINEAR: 'Linear', + CARRY: 'Carry', + LOOKAHEAD: 'Lookahead', +} as const; + +export const EndValues = { + NONE: 'None', + ZERO: 'Zero', + NEAREST: 'Nearest', +} as const; + +export const YAxisModes = { + AUTO: 'auto', + LEFT: 'left', + RIGHT: 'right', + BOTTOM: 'bottom', +} as const; + +export const AxisExtentModes = { + FULL: 'full', + CUSTOM: 'custom', + DATA_BOUNDS: 'dataBounds', +} as const; + +export const LineStyles = { + SOLID: 'solid', + DASHED: 'dashed', + DOTTED: 'dotted', +} as const; + +export const FillStyles = { + NONE: 'none', + ABOVE: 'above', + BELOW: 'below', +} as const; + +export const IconPositions = { + AUTO: 'auto', + LEFT: 'left', + RIGHT: 'right', + ABOVE: 'above', + BELOW: 'below', +} as const; + +export const SeriesTypes = { + BAR: 'bar', + LINE: 'line', + AREA: 'area', + BAR_STACKED: 'bar_stacked', + AREA_STACKED: 'area_stacked', + BAR_HORIZONTAL: 'bar_horizontal', + BAR_PERCENTAGE_STACKED: 'bar_percentage_stacked', + BAR_HORIZONTAL_STACKED: 'bar_horizontal_stacked', + AREA_PERCENTAGE_STACKED: 'area_percentage_stacked', + BAR_HORIZONTAL_PERCENTAGE_STACKED: 'bar_horizontal_percentage_stacked', +} as const; + +export const YScaleTypes = { + TIME: 'time', + LINEAR: 'linear', + LOG: 'log', + SQRT: 'sqrt', +} as const; + +export const XScaleTypes = { + TIME: 'time', + LINEAR: 'linear', + ORDINAL: 'ordinal', +} as const; + +export const XYCurveTypes = { + LINEAR: 'LINEAR', + CURVE_MONOTONE_X: 'CURVE_MONOTONE_X', +} as const; + +export const ValueLabelModes = { + HIDE: 'hide', + INSIDE: 'inside', + OUTSIDE: 'outside', +} as const; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/annotation_layer_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/annotation_layer_config.ts new file mode 100644 index 0000000000000..0862b69ca44f2 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/annotation_layer_config.ts @@ -0,0 +1,49 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import type { ExpressionFunctionDefinition } from '../../../../expressions/common'; +import { LayerTypes, ANNOTATION_LAYER } from '../constants'; +import { AnnotationLayerArgs, AnnotationLayerConfigResult } from '../types'; + +export function annotationLayerConfigFunction(): ExpressionFunctionDefinition< + typeof ANNOTATION_LAYER, + null, + AnnotationLayerArgs, + AnnotationLayerConfigResult +> { + return { + name: ANNOTATION_LAYER, + aliases: [], + type: ANNOTATION_LAYER, + inputTypes: ['null'], + help: 'Annotation layer in lens', + args: { + layerId: { + types: ['string'], + help: '', + }, + hide: { + types: ['boolean'], + default: false, + help: 'Show details', + }, + annotations: { + types: ['manual_event_annotation'], + help: '', + multi: true, + }, + }, + fn: (input, args) => { + return { + type: ANNOTATION_LAYER, + ...args, + layerType: LayerTypes.ANNOTATIONS, + }; + }, + }; +} diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_extent_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_extent_config.ts new file mode 100644 index 0000000000000..c5cf89a4663c9 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_extent_config.ts @@ -0,0 +1,54 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import type { ExpressionFunctionDefinition } from '../../../../expressions/common'; +import { AxisExtentConfig, AxisExtentConfigResult } from '../types'; +import { AxisExtentModes, AXIS_EXTENT_CONFIG } from '../constants'; + +export const axisExtentConfigFunction: ExpressionFunctionDefinition< + typeof AXIS_EXTENT_CONFIG, + null, + AxisExtentConfig, + AxisExtentConfigResult +> = { + name: AXIS_EXTENT_CONFIG, + aliases: [], + type: AXIS_EXTENT_CONFIG, + help: i18n.translate('expressionXY.axisExtentConfig.help', { + defaultMessage: `Configure the xy chart's axis extents`, + }), + inputTypes: ['null'], + args: { + mode: { + types: ['string'], + options: [...Object.values(AxisExtentModes)], + help: i18n.translate('expressionXY.axisExtentConfig.extentMode.help', { + defaultMessage: 'The extent mode', + }), + }, + lowerBound: { + types: ['number'], + help: i18n.translate('expressionXY.axisExtentConfig.lowerBound.help', { + defaultMessage: 'Lower bound', + }), + }, + upperBound: { + types: ['number'], + help: i18n.translate('expressionXY.axisExtentConfig.upperBound.help', { + defaultMessage: 'Upper bound', + }), + }, + }, + fn(input, args) { + return { + type: AXIS_EXTENT_CONFIG, + ...args, + }; + }, +}; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_titles_visibility_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_titles_visibility_config.ts new file mode 100644 index 0000000000000..50302214fc37c --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/axis_titles_visibility_config.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import type { ExpressionFunctionDefinition } from '../../../../expressions/common'; +import { AXIS_TITLES_VISIBILITY_CONFIG } from '../constants'; +import { AxesSettingsConfig, AxisTitlesVisibilityConfigResult } from '../types'; + +export const axisTitlesVisibilityConfigFunction: ExpressionFunctionDefinition< + typeof AXIS_TITLES_VISIBILITY_CONFIG, + null, + AxesSettingsConfig, + AxisTitlesVisibilityConfigResult +> = { + name: AXIS_TITLES_VISIBILITY_CONFIG, + aliases: [], + type: AXIS_TITLES_VISIBILITY_CONFIG, + help: i18n.translate('expressionXY.axisTitlesVisibilityConfig.help', { + defaultMessage: `Configure the xy chart's axis titles appearance`, + }), + inputTypes: ['null'], + args: { + x: { + types: ['boolean'], + help: i18n.translate('expressionXY.axisTitlesVisibilityConfig.x.help', { + defaultMessage: 'Specifies whether or not the title of the x-axis are visible.', + }), + }, + yLeft: { + types: ['boolean'], + help: i18n.translate('expressionXY.axisTitlesVisibilityConfig.yLeft.help', { + defaultMessage: 'Specifies whether or not the title of the left y-axis are visible.', + }), + }, + yRight: { + types: ['boolean'], + help: i18n.translate('expressionXY.axisTitlesVisibilityConfig.yRight.help', { + defaultMessage: 'Specifies whether or not the title of the right y-axis are visible.', + }), + }, + }, + fn(inputn, args) { + return { + type: AXIS_TITLES_VISIBILITY_CONFIG, + ...args, + }; + }, +}; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.test.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.test.ts new file mode 100644 index 0000000000000..ba7fafd3b3685 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { DataLayerArgs } from '../types'; +import { dataLayerConfigFunction } from '../expression_functions'; +import { createMockExecutionContext } from '../../../../expressions/common/mocks'; +import { mockPaletteOutput } from '../__mocks__'; +import { LayerTypes } from '../constants'; + +describe('dataLayerConfig', () => { + test('produces the correct arguments', () => { + const args: DataLayerArgs = { + layerId: 'first', + seriesType: 'line', + xAccessor: 'c', + accessors: ['a', 'b'], + splitAccessor: 'd', + xScaleType: 'linear', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }; + + const result = dataLayerConfigFunction.fn(null, args, createMockExecutionContext()); + + expect(result).toEqual({ type: 'dataLayer', layerType: LayerTypes.DATA, ...args }); + }); +}); diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts new file mode 100644 index 0000000000000..3aac992d674d9 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts @@ -0,0 +1,123 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import type { ExpressionFunctionDefinition } from '../../../../expressions/common'; +import { DataLayerArgs, DataLayerConfigResult } from '../types'; +import { + DATA_LAYER, + LayerTypes, + SeriesTypes, + XScaleTypes, + YScaleTypes, + Y_CONFIG, +} from '../constants'; + +export const dataLayerConfigFunction: ExpressionFunctionDefinition< + typeof DATA_LAYER, + null, + DataLayerArgs, + DataLayerConfigResult +> = { + name: DATA_LAYER, + aliases: [], + type: DATA_LAYER, + help: i18n.translate('expressionXY.dataLayer.help', { + defaultMessage: `Configure a layer in the xy chart`, + }), + inputTypes: ['null'], + args: { + hide: { + types: ['boolean'], + default: false, + help: i18n.translate('expressionXY.dataLayer.hide.help', { + defaultMessage: 'Show / hide axis', + }), + }, + layerId: { + types: ['string'], + help: i18n.translate('expressionXY.dataLayer.layerId.help', { + defaultMessage: 'Layer ID', + }), + }, + xAccessor: { + types: ['string'], + help: i18n.translate('expressionXY.dataLayer.xAccessor.help', { + defaultMessage: 'X-axis', + }), + }, + seriesType: { + types: ['string'], + options: [...Object.values(SeriesTypes)], + help: i18n.translate('expressionXY.dataLayer.seriesType.help', { + defaultMessage: 'The type of chart to display.', + }), + }, + xScaleType: { + options: [...Object.values(XScaleTypes)], + help: i18n.translate('expressionXY.dataLayer.xScaleType.help', { + defaultMessage: 'The scale type of the x axis', + }), + default: XScaleTypes.ORDINAL, + }, + isHistogram: { + types: ['boolean'], + default: false, + help: i18n.translate('expressionXY.dataLayer.isHistogram.help', { + defaultMessage: 'Whether to layout the chart as a histogram', + }), + }, + yScaleType: { + options: [...Object.values(YScaleTypes)], + help: i18n.translate('expressionXY.dataLayer.yScaleType.help', { + defaultMessage: 'The scale type of the y axes', + }), + default: YScaleTypes.LINEAR, + }, + splitAccessor: { + types: ['string'], + help: i18n.translate('expressionXY.dataLayer.splitAccessor.help', { + defaultMessage: 'The column to split by', + }), + }, + accessors: { + types: ['string'], + help: i18n.translate('expressionXY.dataLayer.accessors.help', { + defaultMessage: 'The columns to display on the y axis.', + }), + multi: true, + }, + yConfig: { + types: [Y_CONFIG], + help: i18n.translate('expressionXY.dataLayer.yConfig.help', { + defaultMessage: 'Additional configuration for y axes', + }), + multi: true, + }, + columnToLabel: { + types: ['string'], + help: i18n.translate('expressionXY.dataLayer.columnToLabel.help', { + defaultMessage: 'JSON key-value pairs of column ID to label', + }), + }, + palette: { + default: `{theme "palette" default={system_palette name="default"} }`, + help: i18n.translate('expressionXY.dataLayer.palette.help', { + defaultMessage: 'Palette', + }), + types: ['palette'], + }, + }, + fn(input, args) { + return { + type: DATA_LAYER, + ...args, + layerType: LayerTypes.DATA, + }; + }, +}; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.test.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.test.ts new file mode 100644 index 0000000000000..91bfbc8fbe6f0 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.test.ts @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { AxesSettingsConfig } from '../types'; +import { gridlinesConfigFunction } from '../expression_functions'; +import { createMockExecutionContext } from '../../../../../plugins/expressions/common/mocks'; + +describe('gridlinesConfig', () => { + test('produces the correct arguments', () => { + const args: AxesSettingsConfig = { x: true, yLeft: false, yRight: false }; + const result = gridlinesConfigFunction.fn(null, args, createMockExecutionContext()); + + expect(result).toEqual({ type: 'gridlinesConfig', ...args }); + }); +}); diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/grid_lines_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.ts similarity index 51% rename from x-pack/plugins/lens/common/expressions/xy_chart/grid_lines_config.ts rename to src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.ts index 6338e9f039937..b94b8b5709c03 100644 --- a/x-pack/plugins/lens/common/expressions/xy_chart/grid_lines_config.ts +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/grid_lines_config.ts @@ -1,50 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import { i18n } from '@kbn/i18n'; import type { ExpressionFunctionDefinition } from '../../../../../../src/plugins/expressions/common'; -import type { AxesSettingsConfig } from './axis_config'; +import { GRID_LINES_CONFIG } from '../constants'; +import { AxesSettingsConfig, GridlinesConfigResult } from '../types'; -export type GridlinesConfigResult = AxesSettingsConfig & { type: 'lens_xy_gridlinesConfig' }; - -export const gridlinesConfig: ExpressionFunctionDefinition< - 'lens_xy_gridlinesConfig', +export const gridlinesConfigFunction: ExpressionFunctionDefinition< + typeof GRID_LINES_CONFIG, null, AxesSettingsConfig, GridlinesConfigResult > = { - name: 'lens_xy_gridlinesConfig', + name: GRID_LINES_CONFIG, aliases: [], - type: 'lens_xy_gridlinesConfig', - help: `Configure the xy chart's gridlines appearance`, + type: GRID_LINES_CONFIG, + help: i18n.translate('expressionXY.gridlinesConfig.help', { + defaultMessage: `Configure the xy chart's gridlines appearance`, + }), inputTypes: ['null'], args: { x: { types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.xAxisGridlines.help', { + help: i18n.translate('expressionXY.gridlinesConfig.x.help', { defaultMessage: 'Specifies whether or not the gridlines of the x-axis are visible.', }), }, yLeft: { types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.yLeftAxisgridlines.help', { + help: i18n.translate('expressionXY.gridlinesConfig.yLeft.help', { defaultMessage: 'Specifies whether or not the gridlines of the left y-axis are visible.', }), }, yRight: { types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.yRightAxisgridlines.help', { + help: i18n.translate('expressionXY.gridlinesConfig.yRight.help', { defaultMessage: 'Specifies whether or not the gridlines of the right y-axis are visible.', }), }, }, - fn: function fn(input: unknown, args: AxesSettingsConfig) { + fn(input, args) { return { - type: 'lens_xy_gridlinesConfig', + type: GRID_LINES_CONFIG, ...args, }; }, diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/index.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/index.ts new file mode 100644 index 0000000000000..5c7e013a91332 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/index.ts @@ -0,0 +1,19 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export * from './xy_vis'; +export * from './legend_config'; +export * from './annotation_layer_config'; +export * from './y_axis_config'; +export * from './data_layer_config'; +export * from './grid_lines_config'; +export * from './axis_extent_config'; +export * from './tick_labels_config'; +export * from './labels_orientation_config'; +export * from './reference_line_layer_config'; +export * from './axis_titles_visibility_config'; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.test.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.test.ts new file mode 100644 index 0000000000000..2d54a729d3e5a --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.test.ts @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { LabelsOrientationConfig } from '../types'; +import { labelsOrientationConfigFunction } from '../expression_functions'; +import { createMockExecutionContext } from '../../../../../plugins/expressions/common/mocks'; + +describe('labelsOrientationConfig', () => { + test('produces the correct arguments', () => { + const args: LabelsOrientationConfig = { x: 0, yLeft: -90, yRight: -45 }; + const result = labelsOrientationConfigFunction.fn(null, args, createMockExecutionContext()); + + expect(result).toEqual({ type: 'labelsOrientationConfig', ...args }); + }); +}); diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/labels_orientation_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.ts similarity index 50% rename from x-pack/plugins/lens/common/expressions/xy_chart/labels_orientation_config.ts rename to src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.ts index 773ce61a102f9..94d726c56f3b2 100644 --- a/x-pack/plugins/lens/common/expressions/xy_chart/labels_orientation_config.ts +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/labels_orientation_config.ts @@ -1,59 +1,55 @@ /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ + import { i18n } from '@kbn/i18n'; import type { ExpressionFunctionDefinition } from '../../../../../../src/plugins/expressions/common'; +import { LABELS_ORIENTATION_CONFIG } from '../constants'; +import { LabelsOrientationConfig, LabelsOrientationConfigResult } from '../types'; -export interface LabelsOrientationConfig { - x: number; - yLeft: number; - yRight: number; -} - -export type LabelsOrientationConfigResult = LabelsOrientationConfig & { - type: 'lens_xy_labelsOrientationConfig'; -}; - -export const labelsOrientationConfig: ExpressionFunctionDefinition< - 'lens_xy_labelsOrientationConfig', +export const labelsOrientationConfigFunction: ExpressionFunctionDefinition< + typeof LABELS_ORIENTATION_CONFIG, null, LabelsOrientationConfig, LabelsOrientationConfigResult > = { - name: 'lens_xy_labelsOrientationConfig', + name: LABELS_ORIENTATION_CONFIG, aliases: [], - type: 'lens_xy_labelsOrientationConfig', - help: `Configure the xy chart's tick labels orientation`, + type: LABELS_ORIENTATION_CONFIG, + help: i18n.translate('expressionXY.labelsOrientationConfig.help', { + defaultMessage: `Configure the xy chart's tick labels orientation`, + }), inputTypes: ['null'], args: { x: { types: ['number'], options: [0, -90, -45], - help: i18n.translate('xpack.lens.xyChart.xAxisLabelsOrientation.help', { + help: i18n.translate('expressionXY.labelsOrientationConfig.x.help', { defaultMessage: 'Specifies the labels orientation of the x-axis.', }), }, yLeft: { types: ['number'], options: [0, -90, -45], - help: i18n.translate('xpack.lens.xyChart.yLeftAxisLabelsOrientation.help', { + help: i18n.translate('expressionXY.labelsOrientationConfig.yLeft.help', { defaultMessage: 'Specifies the labels orientation of the left y-axis.', }), }, yRight: { types: ['number'], options: [0, -90, -45], - help: i18n.translate('xpack.lens.xyChart.yRightAxisLabelsOrientation.help', { + help: i18n.translate('expressionXY.labelsOrientationConfig.yRight.help', { defaultMessage: 'Specifies the labels orientation of the right y-axis.', }), }, }, - fn: function fn(input: unknown, args: LabelsOrientationConfig) { + fn(input, args) { return { - type: 'lens_xy_labelsOrientationConfig', + type: LABELS_ORIENTATION_CONFIG, ...args, }; }, diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.test.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.test.ts new file mode 100644 index 0000000000000..2c673ab990ded --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.test.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { Position } from '@elastic/charts'; +import { createMockExecutionContext } from '../../../../expressions/common/mocks'; +import { LegendConfig } from '../types'; +import { legendConfigFunction } from './legend_config'; + +describe('legendConfigFunction', () => { + test('produces the correct arguments', () => { + const args: LegendConfig = { isVisible: true, position: Position.Left }; + const result = legendConfigFunction.fn(null, args, createMockExecutionContext()); + + expect(result).toEqual({ type: 'legendConfig', ...args }); + }); +}); diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.ts new file mode 100644 index 0000000000000..384f23aee811a --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/legend_config.ts @@ -0,0 +1,102 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { HorizontalAlignment, Position, VerticalAlignment } from '@elastic/charts'; +import { i18n } from '@kbn/i18n'; +import type { ExpressionFunctionDefinition } from '../../../../../../src/plugins/expressions/common'; +import { LEGEND_CONFIG } from '../constants'; +import { LegendConfig, LegendConfigResult } from '../types'; + +export const legendConfigFunction: ExpressionFunctionDefinition< + typeof LEGEND_CONFIG, + null, + LegendConfig, + LegendConfigResult +> = { + name: LEGEND_CONFIG, + aliases: [], + type: LEGEND_CONFIG, + help: i18n.translate('expressionXY.legendConfig.help', { + defaultMessage: `Configure the xy chart's legend`, + }), + inputTypes: ['null'], + args: { + isVisible: { + types: ['boolean'], + help: i18n.translate('expressionXY.legendConfig.isVisible.help', { + defaultMessage: 'Specifies whether or not the legend is visible.', + }), + }, + position: { + types: ['string'], + options: [Position.Top, Position.Right, Position.Bottom, Position.Left], + help: i18n.translate('expressionXY.legendConfig.position.help', { + defaultMessage: 'Specifies the legend position.', + }), + }, + showSingleSeries: { + types: ['boolean'], + help: i18n.translate('expressionXY.legendConfig.showSingleSeries.help', { + defaultMessage: 'Specifies whether a legend with just a single entry should be shown', + }), + }, + isInside: { + types: ['boolean'], + help: i18n.translate('expressionXY.legendConfig.isInside.help', { + defaultMessage: 'Specifies whether a legend is inside the chart', + }), + }, + horizontalAlignment: { + types: ['string'], + options: [HorizontalAlignment.Right, HorizontalAlignment.Left], + help: i18n.translate('expressionXY.legendConfig.horizontalAlignment.help', { + defaultMessage: + 'Specifies the horizontal alignment of the legend when it is displayed inside chart.', + }), + }, + verticalAlignment: { + types: ['string'], + options: [VerticalAlignment.Top, VerticalAlignment.Bottom], + help: i18n.translate('expressionXY.legendConfig.verticalAlignment.help', { + defaultMessage: + 'Specifies the vertical alignment of the legend when it is displayed inside chart.', + }), + }, + floatingColumns: { + types: ['number'], + help: i18n.translate('expressionXY.legendConfig.floatingColumns.help', { + defaultMessage: 'Specifies the number of columns when legend is displayed inside chart.', + }), + }, + maxLines: { + types: ['number'], + help: i18n.translate('expressionXY.legendConfig.maxLines.help', { + defaultMessage: 'Specifies the number of lines per legend item.', + }), + }, + shouldTruncate: { + types: ['boolean'], + default: true, + help: i18n.translate('expressionXY.legendConfig.shouldTruncate.help', { + defaultMessage: 'Specifies whether the legend items will be truncated or not', + }), + }, + legendSize: { + types: ['number'], + help: i18n.translate('expressionXY.legendConfig.legendSize.help', { + defaultMessage: 'Specifies the legend size in pixels.', + }), + }, + }, + fn(input, args) { + return { + type: LEGEND_CONFIG, + ...args, + }; + }, +}; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/reference_line_layer_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/reference_line_layer_config.ts new file mode 100644 index 0000000000000..c5d0f17ff138d --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/reference_line_layer_config.ts @@ -0,0 +1,62 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import type { ExpressionFunctionDefinition } from '../../../../expressions/common'; +import { LayerTypes, REFERENCE_LINE_LAYER, Y_CONFIG } from '../constants'; +import { ReferenceLineLayerArgs, ReferenceLineLayerConfigResult } from '../types'; + +export const referenceLineLayerConfigFunction: ExpressionFunctionDefinition< + typeof REFERENCE_LINE_LAYER, + null, + ReferenceLineLayerArgs, + ReferenceLineLayerConfigResult +> = { + name: REFERENCE_LINE_LAYER, + aliases: [], + type: REFERENCE_LINE_LAYER, + help: i18n.translate('expressionXY.referenceLineLayer.help', { + defaultMessage: `Configure a reference line in the xy chart`, + }), + inputTypes: ['null'], + args: { + layerId: { + types: ['string'], + help: i18n.translate('expressionXY.referenceLineLayer.layerId.help', { + defaultMessage: `Layer ID`, + }), + }, + accessors: { + types: ['string'], + help: i18n.translate('expressionXY.referenceLineLayer.accessors.help', { + defaultMessage: 'The columns to display on the y axis.', + }), + multi: true, + }, + yConfig: { + types: [Y_CONFIG], + help: i18n.translate('expressionXY.referenceLineLayer.yConfig.help', { + defaultMessage: 'Additional configuration for y axes', + }), + multi: true, + }, + columnToLabel: { + types: ['string'], + help: i18n.translate('expressionXY.referenceLineLayer.columnToLabel.help', { + defaultMessage: 'JSON key-value pairs of column ID to label', + }), + }, + }, + fn(input, args) { + return { + type: REFERENCE_LINE_LAYER, + ...args, + layerType: LayerTypes.REFERENCELINE, + }; + }, +}; diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.test.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.test.ts new file mode 100644 index 0000000000000..8b31258377dd9 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.test.ts @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { AxesSettingsConfig } from '../types'; +import { tickLabelsConfigFunction } from '../expression_functions'; +import { createMockExecutionContext } from '../../../../../plugins/expressions/common/mocks'; + +describe('tickLabelsConfig', () => { + test('produces the correct arguments', () => { + const args: AxesSettingsConfig = { x: true, yLeft: false, yRight: false }; + const result = tickLabelsConfigFunction.fn(null, args, createMockExecutionContext()); + + expect(result).toEqual({ type: 'tickLabelsConfig', ...args }); + }); +}); diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/tick_labels_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.ts similarity index 51% rename from x-pack/plugins/lens/common/expressions/xy_chart/tick_labels_config.ts rename to src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.ts index 4af78d8355786..6a882094a56d2 100644 --- a/x-pack/plugins/lens/common/expressions/xy_chart/tick_labels_config.ts +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/tick_labels_config.ts @@ -1,50 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import { i18n } from '@kbn/i18n'; import type { ExpressionFunctionDefinition } from '../../../../../../src/plugins/expressions/common'; -import type { AxesSettingsConfig } from './axis_config'; +import { TICK_LABELS_CONFIG } from '../constants'; +import { AxesSettingsConfig, TickLabelsConfigResult } from '../types'; -export type TickLabelsConfigResult = AxesSettingsConfig & { type: 'lens_xy_tickLabelsConfig' }; - -export const tickLabelsConfig: ExpressionFunctionDefinition< - 'lens_xy_tickLabelsConfig', +export const tickLabelsConfigFunction: ExpressionFunctionDefinition< + typeof TICK_LABELS_CONFIG, null, AxesSettingsConfig, TickLabelsConfigResult > = { - name: 'lens_xy_tickLabelsConfig', + name: TICK_LABELS_CONFIG, aliases: [], - type: 'lens_xy_tickLabelsConfig', - help: `Configure the xy chart's tick labels appearance`, + type: TICK_LABELS_CONFIG, + help: i18n.translate('expressionXY.tickLabelsConfig.help', { + defaultMessage: `Configure the xy chart's tick labels appearance`, + }), inputTypes: ['null'], args: { x: { types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.xAxisTickLabels.help', { + help: i18n.translate('expressionXY.tickLabelsConfig.x.help', { defaultMessage: 'Specifies whether or not the tick labels of the x-axis are visible.', }), }, yLeft: { types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.yLeftAxisTickLabels.help', { + help: i18n.translate('expressionXY.tickLabelsConfig.yLeft.help', { defaultMessage: 'Specifies whether or not the tick labels of the left y-axis are visible.', }), }, yRight: { types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.yRightAxisTickLabels.help', { + help: i18n.translate('expressionXY.tickLabelsConfig.yRight.help', { defaultMessage: 'Specifies whether or not the tick labels of the right y-axis are visible.', }), }, }, - fn: function fn(input: unknown, args: AxesSettingsConfig) { + fn(input, args) { return { - type: 'lens_xy_tickLabelsConfig', + type: TICK_LABELS_CONFIG, ...args, }; }, diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.test.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.test.ts new file mode 100644 index 0000000000000..69d0bf51b3d64 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.test.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { xyVisFunction } from '../expression_functions'; +import { createMockExecutionContext } from '../../../../../plugins/expressions/common/mocks'; +import { sampleArgs } from '../__mocks__'; +import { XY_VIS } from '../constants'; + +describe('xyVis', () => { + test('it renders with the specified data and args', () => { + const { data, args } = sampleArgs(); + const result = xyVisFunction.fn(data, args, createMockExecutionContext()); + + expect(result).toEqual({ type: 'render', as: XY_VIS, value: { data, args } }); + }); +}); diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/xy_chart.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.ts similarity index 53% rename from x-pack/plugins/lens/common/expressions/xy_chart/xy_chart.ts rename to src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.ts index 3c68837defdd9..0f83aeecc7a20 100644 --- a/x-pack/plugins/lens/common/expressions/xy_chart/xy_chart.ts +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/xy_vis.ts @@ -1,58 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ + import { i18n } from '@kbn/i18n'; -import type { ExpressionFunctionDefinition } from '../../../../../../src/plugins/expressions/common'; -import type { ExpressionValueSearchContext } from '../../../../../../src/plugins/data/common'; -import type { LensMultiTable } from '../../types'; -import type { XYArgs } from './xy_args'; -import { fittingFunctionDefinitions } from './fitting_function'; +import type { ExpressionFunctionDefinition } from '../../../../expressions'; +import { LensMultiTable, XYArgs, XYRender } from '../types'; import { prepareLogTable } from '../../../../../../src/plugins/visualizations/common/utils'; -import { endValueDefinitions } from './end_value'; - -export interface XYChartProps { - data: LensMultiTable; - args: XYArgs; -} +import { + XY_VIS, + DATA_LAYER, + MULTITABLE, + XYCurveTypes, + LEGEND_CONFIG, + ValueLabelModes, + FittingFunctions, + GRID_LINES_CONFIG, + XY_VIS_RENDERER, + AXIS_EXTENT_CONFIG, + TICK_LABELS_CONFIG, + REFERENCE_LINE_LAYER, + LABELS_ORIENTATION_CONFIG, + AXIS_TITLES_VISIBILITY_CONFIG, + EndValues, + ANNOTATION_LAYER, + LayerTypes, +} from '../constants'; const strings = { getMetricHelp: () => - i18n.translate('xpack.lens.xy.logDatatable.metric', { + i18n.translate('expressionXY.xyVis.logDatatable.metric', { defaultMessage: 'Vertical axis', }), getXAxisHelp: () => - i18n.translate('xpack.lens.xy.logDatatable.x', { + i18n.translate('expressionXY.xyVis.logDatatable.x', { defaultMessage: 'Horizontal axis', }), getBreakdownHelp: () => - i18n.translate('xpack.lens.xy.logDatatable.breakDown', { + i18n.translate('expressionXY.xyVis.logDatatable.breakDown', { defaultMessage: 'Break down by', }), getReferenceLineHelp: () => - i18n.translate('xpack.lens.xy.logDatatable.breakDown', { + i18n.translate('expressionXY.xyVis.logDatatable.breakDown', { defaultMessage: 'Break down by', }), }; -export interface XYRender { - type: 'render'; - as: 'lens_xy_chart_renderer'; - value: XYChartProps; -} - -export const xyChart: ExpressionFunctionDefinition< - 'lens_xy_chart', - LensMultiTable | ExpressionValueSearchContext | null, +export const xyVisFunction: ExpressionFunctionDefinition< + typeof XY_VIS, + LensMultiTable, XYArgs, XYRender > = { - name: 'lens_xy_chart', + name: XY_VIS, type: 'render', - inputTypes: ['lens_multitable', 'kibana_context', 'null'], - help: i18n.translate('xpack.lens.xyChart.help', { + inputTypes: [MULTITABLE], + help: i18n.translate('expressionXY.xyVis.help', { defaultMessage: 'An X/Y chart', }), args: { @@ -66,51 +72,53 @@ export const xyChart: ExpressionFunctionDefinition< }, xTitle: { types: ['string'], - help: i18n.translate('xpack.lens.xyChart.xTitle.help', { + help: i18n.translate('expressionXY.xyVis.xTitle.help', { defaultMessage: 'X axis title', }), }, yTitle: { types: ['string'], - help: i18n.translate('xpack.lens.xyChart.yLeftTitle.help', { + help: i18n.translate('expressionXY.xyVis.yLeftTitle.help', { defaultMessage: 'Y left axis title', }), }, yRightTitle: { types: ['string'], - help: i18n.translate('xpack.lens.xyChart.yRightTitle.help', { + help: i18n.translate('expressionXY.xyVis.yRightTitle.help', { defaultMessage: 'Y right axis title', }), }, yLeftExtent: { - types: ['lens_xy_axisExtentConfig'], - help: i18n.translate('xpack.lens.xyChart.yLeftExtent.help', { + types: [AXIS_EXTENT_CONFIG], + help: i18n.translate('expressionXY.xyVis.yLeftExtent.help', { defaultMessage: 'Y left axis extents', }), }, yRightExtent: { - types: ['lens_xy_axisExtentConfig'], - help: i18n.translate('xpack.lens.xyChart.yRightExtent.help', { + types: [AXIS_EXTENT_CONFIG], + help: i18n.translate('expressionXY.xyVis.yRightExtent.help', { defaultMessage: 'Y right axis extents', }), }, legend: { - types: ['lens_xy_legendConfig'], - help: i18n.translate('xpack.lens.xyChart.legend.help', { + types: [LEGEND_CONFIG], + help: i18n.translate('expressionXY.xyVis.legend.help', { defaultMessage: 'Configure the chart legend.', }), }, fittingFunction: { types: ['string'], - options: [...fittingFunctionDefinitions.map(({ id }) => id)], - help: i18n.translate('xpack.lens.xyChart.fittingFunction.help', { + options: [...Object.values(FittingFunctions)], + help: i18n.translate('expressionXY.xyVis.fittingFunction.help', { defaultMessage: 'Define how missing values are treated', }), }, endValue: { types: ['string'], - options: [...endValueDefinitions.map(({ id }) => id)], - help: '', + options: [...Object.values(EndValues)], + help: i18n.translate('expressionXY.xyVis.endValue.help', { + defaultMessage: 'End value', + }), }, emphasizeFitting: { types: ['boolean'], @@ -119,85 +127,92 @@ export const xyChart: ExpressionFunctionDefinition< }, valueLabels: { types: ['string'], - options: ['hide', 'inside'], - help: '', + options: [...Object.values(ValueLabelModes)], + help: i18n.translate('expressionXY.xyVis.valueLabels.help', { + defaultMessage: 'Value labels mode', + }), }, tickLabelsVisibilitySettings: { - types: ['lens_xy_tickLabelsConfig'], - help: i18n.translate('xpack.lens.xyChart.tickLabelsSettings.help', { + types: [TICK_LABELS_CONFIG], + help: i18n.translate('expressionXY.xyVis.tickLabelsVisibilitySettings.help', { defaultMessage: 'Show x and y axes tick labels', }), }, labelsOrientation: { - types: ['lens_xy_labelsOrientationConfig'], - help: i18n.translate('xpack.lens.xyChart.labelsOrientation.help', { + types: [LABELS_ORIENTATION_CONFIG], + help: i18n.translate('expressionXY.xyVis.labelsOrientation.help', { defaultMessage: 'Defines the rotation of the axis labels', }), }, gridlinesVisibilitySettings: { - types: ['lens_xy_gridlinesConfig'], - help: i18n.translate('xpack.lens.xyChart.gridlinesSettings.help', { + types: [GRID_LINES_CONFIG], + help: i18n.translate('expressionXY.xyVis.gridlinesVisibilitySettings.help', { defaultMessage: 'Show x and y axes gridlines', }), }, axisTitlesVisibilitySettings: { - types: ['lens_xy_axisTitlesVisibilityConfig'], - help: i18n.translate('xpack.lens.xyChart.axisTitlesSettings.help', { + types: [AXIS_TITLES_VISIBILITY_CONFIG], + help: i18n.translate('expressionXY.xyVis.axisTitlesVisibilitySettings.help', { defaultMessage: 'Show x and y axes titles', }), }, layers: { - types: [ - 'lens_xy_data_layer', - 'lens_xy_referenceLine_layer', - 'lens_xy_annotation_layer', - // eslint-disable-next-line @typescript-eslint/no-explicit-any - ] as any, - help: 'Layers of visual series', + types: [DATA_LAYER, REFERENCE_LINE_LAYER, ANNOTATION_LAYER], + help: i18n.translate('expressionXY.xyVis.layers.help', { + defaultMessage: 'Layers of visual series', + }), multi: true, }, curveType: { types: ['string'], - options: ['LINEAR', 'CURVE_MONOTONE_X'], - help: i18n.translate('xpack.lens.xyChart.curveType.help', { + options: [...Object.values(XYCurveTypes)], + help: i18n.translate('expressionXY.xyVis.curveType.help', { defaultMessage: 'Define how curve type is rendered for a line chart', }), }, fillOpacity: { types: ['number'], - help: i18n.translate('xpack.lens.xyChart.fillOpacity.help', { + help: i18n.translate('expressionXY.xyVis.fillOpacity.help', { defaultMessage: 'Define the area chart fill opacity', }), }, hideEndzones: { types: ['boolean'], default: false, - help: i18n.translate('xpack.lens.xyChart.hideEndzones.help', { + help: i18n.translate('expressionXY.xyVis.hideEndzones.help', { defaultMessage: 'Hide endzone markers for partial data', }), }, valuesInLegend: { types: ['boolean'], default: false, - help: i18n.translate('xpack.lens.xyChart.valuesInLegend.help', { + help: i18n.translate('expressionXY.xyVis.valuesInLegend.help', { defaultMessage: 'Show values in legend', }), }, ariaLabel: { types: ['string'], - help: i18n.translate('xpack.lens.xyChart.ariaLabel.help', { + help: i18n.translate('expressionXY.xyVis.ariaLabel.help', { defaultMessage: 'Specifies the aria label of the xy chart', }), required: false, }, }, - fn(data: LensMultiTable, args: XYArgs, handlers) { + fn(data, args, handlers) { if (handlers?.inspectorAdapters?.tables) { args.layers.forEach((layer) => { - if (layer.layerType === 'annotations') { + if (layer.layerType === LayerTypes.ANNOTATIONS) { return; } - const { layerId, accessors, xAccessor, splitAccessor, layerType } = layer; + + let xAccessor; + let splitAccessor; + if (layer.layerType === LayerTypes.DATA) { + xAccessor = layer.xAccessor; + splitAccessor = layer.splitAccessor; + } + + const { layerId, accessors, layerType } = layer; const logTable = prepareLogTable( data.tables[layerId], [ @@ -214,9 +229,10 @@ export const xyChart: ExpressionFunctionDefinition< handlers.inspectorAdapters.tables.logDatatable(layerId, logTable); }); } + return { type: 'render', - as: 'lens_xy_chart_renderer', + as: XY_VIS_RENDERER, value: { data, args: { diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/y_axis_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/y_axis_config.ts new file mode 100644 index 0000000000000..e665fc2b8cea0 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/y_axis_config.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import type { ExpressionFunctionDefinition } from '../../../../expressions/common'; +import { FillStyles, IconPositions, LineStyles, YAxisModes, Y_CONFIG } from '../constants'; +import { YConfig, YConfigResult } from '../types'; + +export const yAxisConfigFunction: ExpressionFunctionDefinition< + typeof Y_CONFIG, + null, + YConfig, + YConfigResult +> = { + name: Y_CONFIG, + aliases: [], + type: Y_CONFIG, + help: i18n.translate('expressionXY.yConfig.help', { + defaultMessage: `Configure the behavior of a xy chart's y axis metric`, + }), + inputTypes: ['null'], + args: { + forAccessor: { + types: ['string'], + help: i18n.translate('expressionXY.yConfig.forAccessor.help', { + defaultMessage: 'The accessor this configuration is for', + }), + }, + axisMode: { + types: ['string'], + options: [...Object.values(YAxisModes)], + help: i18n.translate('expressionXY.yConfig.axisMode.help', { + defaultMessage: 'The axis mode of the metric', + }), + }, + color: { + types: ['string'], + help: i18n.translate('expressionXY.yConfig.color.help', { + defaultMessage: 'The color of the series', + }), + }, + lineStyle: { + types: ['string'], + options: [...Object.values(LineStyles)], + help: i18n.translate('expressionXY.yConfig.lineStyle.help', { + defaultMessage: 'The style of the reference line', + }), + }, + lineWidth: { + types: ['number'], + help: i18n.translate('expressionXY.yConfig.lineWidth.help', { + defaultMessage: 'The width of the reference line', + }), + }, + icon: { + types: ['string'], + help: i18n.translate('expressionXY.yConfig.icon.help', { + defaultMessage: 'An optional icon used for reference lines', + }), + }, + iconPosition: { + types: ['string'], + options: [...Object.values(IconPositions)], + help: i18n.translate('expressionXY.yConfig.iconPosition.help', { + defaultMessage: 'The placement of the icon for the reference line', + }), + }, + textVisibility: { + types: ['boolean'], + help: i18n.translate('expressionXY.yConfig.textVisibility.help', { + defaultMessage: 'Visibility of the label on the reference line', + }), + }, + fill: { + types: ['string'], + options: [...Object.values(FillStyles)], + help: i18n.translate('expressionXY.yConfig.fill.help', { + defaultMessage: 'Fill', + }), + }, + }, + fn(input, args) { + return { + type: Y_CONFIG, + ...args, + }; + }, +}; diff --git a/src/plugins/chart_expressions/expression_xy/common/index.ts b/src/plugins/chart_expressions/expression_xy/common/index.ts new file mode 100755 index 0000000000000..68f9f946baeb0 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/index.ts @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export const PLUGIN_ID = 'expressionXy'; +export const PLUGIN_NAME = 'expressionXy'; + +export { + xyVisFunction, + yAxisConfigFunction, + legendConfigFunction, + gridlinesConfigFunction, + dataLayerConfigFunction, + axisExtentConfigFunction, + tickLabelsConfigFunction, + annotationLayerConfigFunction, + labelsOrientationConfigFunction, + referenceLineLayerConfigFunction, + axisTitlesVisibilityConfigFunction, +} from './expression_functions'; + +export type { + XYArgs, + YConfig, + EndValue, + XYRender, + LayerType, + YAxisMode, + LineStyle, + FillStyle, + SeriesType, + YScaleType, + XScaleType, + AxisConfig, + ValidLayer, + XYLayerArgs, + XYCurveType, + XYChartProps, + LegendConfig, + IconPosition, + YConfigResult, + DataLayerArgs, + LensMultiTable, + ValueLabelMode, + AxisExtentMode, + FittingFunction, + AxisExtentConfig, + LegendConfigResult, + AxesSettingsConfig, + AnnotationLayerArgs, + XYLayerConfigResult, + GridlinesConfigResult, + DataLayerConfigResult, + TickLabelsConfigResult, + AxisExtentConfigResult, + ReferenceLineLayerArgs, + LabelsOrientationConfig, + AnnotationLayerConfigResult, + LabelsOrientationConfigResult, + ReferenceLineLayerConfigResult, + AxisTitlesVisibilityConfigResult, +} from './types'; diff --git a/src/plugins/chart_expressions/expression_xy/common/types/expression_functions.ts b/src/plugins/chart_expressions/expression_xy/common/types/expression_functions.ts new file mode 100644 index 0000000000000..98889da771c04 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/types/expression_functions.ts @@ -0,0 +1,239 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { HorizontalAlignment, Position, VerticalAlignment } from '@elastic/charts'; +import { $Values } from '@kbn/utility-types'; +import { Datatable } from '../../../../expressions'; +import { PaletteOutput } from '../../../../charts/common'; +import { EventAnnotationOutput } from '../../../../event_annotation/common'; +import { + AxisExtentModes, + FillStyles, + FittingFunctions, + IconPositions, + LayerTypes, + MULTITABLE, + LineStyles, + SeriesTypes, + ValueLabelModes, + XScaleTypes, + XYCurveTypes, + YAxisModes, + YScaleTypes, + REFERENCE_LINE_LAYER, + Y_CONFIG, + AXIS_TITLES_VISIBILITY_CONFIG, + LABELS_ORIENTATION_CONFIG, + TICK_LABELS_CONFIG, + GRID_LINES_CONFIG, + LEGEND_CONFIG, + DATA_LAYER, + AXIS_EXTENT_CONFIG, + ANNOTATION_LAYER, + EndValues, +} from '../constants'; + +export type EndValue = $Values; +export type LayerType = $Values; +export type YAxisMode = $Values; +export type LineStyle = $Values; +export type FillStyle = $Values; +export type SeriesType = $Values; +export type YScaleType = $Values; +export type XScaleType = $Values; +export type XYCurveType = $Values; +export type IconPosition = $Values; +export type ValueLabelMode = $Values; +export type AxisExtentMode = $Values; +export type FittingFunction = $Values; + +export interface AxesSettingsConfig { + x: boolean; + yLeft: boolean; + yRight: boolean; +} + +export interface AxisExtentConfig { + mode: AxisExtentMode; + lowerBound?: number; + upperBound?: number; +} + +export interface AxisConfig { + title: string; + hide?: boolean; +} + +export interface YConfig { + forAccessor: string; + axisMode?: YAxisMode; + color?: string; + icon?: string; + lineWidth?: number; + lineStyle?: LineStyle; + fill?: FillStyle; + iconPosition?: IconPosition; + textVisibility?: boolean; +} + +export interface ValidLayer extends DataLayerConfigResult { + xAccessor: NonNullable; +} + +export interface DataLayerArgs { + layerId: string; + accessors: string[]; + seriesType: SeriesType; + xAccessor?: string; + hide?: boolean; + splitAccessor?: string; + columnToLabel?: string; // Actually a JSON key-value pair + yScaleType: YScaleType; + xScaleType: XScaleType; + isHistogram: boolean; + // palette will always be set on the expression + palette: PaletteOutput; + yConfig?: YConfigResult[]; +} + +export interface LegendConfig { + /** + * Flag whether the legend should be shown. If there is just a single series, it will be hidden + */ + isVisible: boolean; + /** + * Position of the legend relative to the chart + */ + position: Position; + /** + * Flag whether the legend should be shown even with just a single series + */ + showSingleSeries?: boolean; + /** + * Flag whether the legend is inside the chart + */ + isInside?: boolean; + /** + * Horizontal Alignment of the legend when it is set inside chart + */ + horizontalAlignment?: HorizontalAlignment; + /** + * Vertical Alignment of the legend when it is set inside chart + */ + verticalAlignment?: VerticalAlignment; + /** + * Number of columns when legend is set inside chart + */ + floatingColumns?: number; + /** + * Maximum number of lines per legend item + */ + maxLines?: number; + + /** + * Flag whether the legend items are truncated or not + */ + shouldTruncate?: boolean; + + /** + * Exact legend width (vertical) or height (horizontal) + * Limited to max of 70% of the chart container dimension Vertical legends limited to min of 30% of computed width + */ + legendSize?: number; +} + +export interface LabelsOrientationConfig { + x: number; + yLeft: number; + yRight: number; +} + +// Arguments to XY chart expression, with computed properties +export interface XYArgs { + title?: string; + description?: string; + xTitle: string; + yTitle: string; + yRightTitle: string; + yLeftExtent: AxisExtentConfigResult; + yRightExtent: AxisExtentConfigResult; + legend: LegendConfigResult; + valueLabels: ValueLabelMode; + layers: XYLayerConfigResult[]; + endValue?: EndValue; + emphasizeFitting?: boolean; + fittingFunction?: FittingFunction; + axisTitlesVisibilitySettings?: AxisTitlesVisibilityConfigResult; + tickLabelsVisibilitySettings?: TickLabelsConfigResult; + gridlinesVisibilitySettings?: GridlinesConfigResult; + labelsOrientation?: LabelsOrientationConfigResult; + curveType?: XYCurveType; + fillOpacity?: number; + hideEndzones?: boolean; + valuesInLegend?: boolean; + ariaLabel?: string; +} + +export interface AnnotationLayerArgs { + annotations: EventAnnotationOutput[]; + layerId: string; + hide?: boolean; +} + +export type AnnotationLayerConfigResult = AnnotationLayerArgs & { + type: typeof ANNOTATION_LAYER; + layerType: typeof LayerTypes.ANNOTATIONS; +}; + +export interface ReferenceLineLayerArgs { + layerId: string; + accessors: string[]; + columnToLabel?: string; + yConfig?: YConfigResult[]; +} + +export type XYLayerArgs = DataLayerArgs | ReferenceLineLayerArgs | AnnotationLayerArgs; + +export type XYLayerConfigResult = + | DataLayerConfigResult + | ReferenceLineLayerConfigResult + | AnnotationLayerConfigResult; + +export interface LensMultiTable { + type: typeof MULTITABLE; + tables: Record; + dateRange?: { + fromDate: Date; + toDate: Date; + }; +} + +export type ReferenceLineLayerConfigResult = ReferenceLineLayerArgs & { + type: typeof REFERENCE_LINE_LAYER; + layerType: typeof LayerTypes.REFERENCELINE; +}; + +export type DataLayerConfigResult = DataLayerArgs & { + type: typeof DATA_LAYER; + layerType: typeof LayerTypes.DATA; +}; + +export type YConfigResult = YConfig & { type: typeof Y_CONFIG }; + +export type AxisTitlesVisibilityConfigResult = AxesSettingsConfig & { + type: typeof AXIS_TITLES_VISIBILITY_CONFIG; +}; + +export type LabelsOrientationConfigResult = LabelsOrientationConfig & { + type: typeof LABELS_ORIENTATION_CONFIG; +}; + +export type LegendConfigResult = LegendConfig & { type: typeof LEGEND_CONFIG }; +export type AxisExtentConfigResult = AxisExtentConfig & { type: typeof AXIS_EXTENT_CONFIG }; +export type GridlinesConfigResult = AxesSettingsConfig & { type: typeof GRID_LINES_CONFIG }; +export type TickLabelsConfigResult = AxesSettingsConfig & { type: typeof TICK_LABELS_CONFIG }; diff --git a/src/plugins/chart_expressions/expression_xy/common/types/expression_renderers.ts b/src/plugins/chart_expressions/expression_xy/common/types/expression_renderers.ts new file mode 100644 index 0000000000000..1acb98903d06b --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/types/expression_renderers.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { XY_VIS_RENDERER } from '../constants'; +import { LensMultiTable, XYArgs } from './expression_functions'; + +export interface XYChartProps { + data: LensMultiTable; + args: XYArgs; +} + +export interface XYRender { + type: 'render'; + as: typeof XY_VIS_RENDERER; + value: XYChartProps; +} diff --git a/src/plugins/chart_expressions/expression_xy/common/types/index.ts b/src/plugins/chart_expressions/expression_xy/common/types/index.ts new file mode 100644 index 0000000000000..9c50bfab1305d --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/common/types/index.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export * from './expression_functions'; +export * from './expression_renderers'; diff --git a/src/plugins/chart_expressions/expression_xy/jest.config.js b/src/plugins/chart_expressions/expression_xy/jest.config.js new file mode 100644 index 0000000000000..6d742af9a6f3d --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/jest.config.js @@ -0,0 +1,19 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +module.exports = { + preset: '@kbn/test', + rootDir: '../../../../', + roots: ['/src/plugins/chart_expressions/expression_xy'], + coverageDirectory: + '/target/kibana-coverage/jest/src/plugins/chart_expressions/expression_xy', + coverageReporters: ['text', 'html'], + collectCoverageFrom: [ + '/src/plugins/chart_expressions/expression_xy/{common,public,server}/**/*.{ts,tsx}', + ], +}; diff --git a/src/plugins/chart_expressions/expression_xy/kibana.json b/src/plugins/chart_expressions/expression_xy/kibana.json new file mode 100755 index 0000000000000..e9680d9b85163 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/kibana.json @@ -0,0 +1,15 @@ +{ + "id": "expressionXY", + "version": "1.0.0", + "kibanaVersion": "kibana", + "owner": { + "name": "Vis Editors", + "githubTeam": "kibana-vis-editors" + }, + "description": "Expression XY plugin adds a `xy` renderer and function to the expression plugin. The renderer will display the `xy` chart.", + "server": true, + "ui": true, + "requiredPlugins": ["expressions", "charts", "data", "fieldFormats", "uiActions", "eventAnnotation", "visualizations"], + "requiredBundles": ["kibanaReact"], + "optionalPlugins": [] +} diff --git a/src/plugins/chart_expressions/expression_xy/public/__mocks__/index.tsx b/src/plugins/chart_expressions/expression_xy/public/__mocks__/index.tsx new file mode 100644 index 0000000000000..cc73950438f38 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/__mocks__/index.tsx @@ -0,0 +1,224 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { chartPluginMock } from '../../../../../plugins/charts/public/mocks'; +import { DataLayerConfigResult, LensMultiTable, XYArgs } from '../../common'; +import { LayerTypes } from '../../common/constants'; +import { mockPaletteOutput, sampleArgs } from '../../common/__mocks__'; + +const chartSetupContract = chartPluginMock.createSetupContract(); +const chartStartContract = chartPluginMock.createStartContract(); + +export const chartsThemeService = chartSetupContract.theme; +export const chartsActiveCursorService = chartStartContract.activeCursor; + +export const paletteService = chartPluginMock.createPaletteRegistry(); + +export const dateHistogramData: LensMultiTable = { + type: 'lens_multitable', + tables: { + timeLayer: { + type: 'datatable', + rows: [ + { + xAccessorId: 1585758120000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + }, + { + xAccessorId: 1585758360000, + splitAccessorId: "Women's Accessories", + yAccessorId: 1, + }, + { + xAccessorId: 1585758360000, + splitAccessorId: "Women's Clothing", + yAccessorId: 1, + }, + { + xAccessorId: 1585759380000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + }, + { + xAccessorId: 1585759380000, + splitAccessorId: "Men's Shoes", + yAccessorId: 1, + }, + { + xAccessorId: 1585759380000, + splitAccessorId: "Women's Clothing", + yAccessorId: 1, + }, + { + xAccessorId: 1585760700000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + }, + { + xAccessorId: 1585760760000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + }, + { + xAccessorId: 1585760760000, + splitAccessorId: "Men's Shoes", + yAccessorId: 1, + }, + { + xAccessorId: 1585761120000, + splitAccessorId: "Men's Shoes", + yAccessorId: 1, + }, + ], + columns: [ + { + id: 'xAccessorId', + name: 'order_date per minute', + meta: { + type: 'date', + field: 'order_date', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'date_histogram', + appliedTimeRange: { + from: '2020-04-01T16:14:16.246Z', + to: '2020-04-01T17:15:41.263Z', + }, + params: { + field: 'order_date', + timeRange: { from: '2020-04-01T16:14:16.246Z', to: '2020-04-01T17:15:41.263Z' }, + useNormalizedEsInterval: true, + scaleMetricValues: false, + interval: '1m', + drop_partials: false, + min_doc_count: 0, + extended_bounds: {}, + }, + }, + params: { id: 'date', params: { pattern: 'HH:mm' } }, + }, + }, + { + id: 'splitAccessorId', + name: 'Top values of category.keyword', + meta: { + type: 'string', + field: 'category.keyword', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'terms', + params: { + field: 'category.keyword', + orderBy: 'yAccessorId', + order: 'desc', + size: 3, + otherBucket: false, + otherBucketLabel: 'Other', + missingBucket: false, + missingBucketLabel: 'Missing', + }, + }, + params: { + id: 'terms', + params: { + id: 'string', + otherBucketLabel: 'Other', + missingBucketLabel: 'Missing', + parsedUrl: { + origin: 'http://localhost:5601', + pathname: '/jiy/app/kibana', + basePath: '/jiy', + }, + }, + }, + }, + }, + { + id: 'yAccessorId', + name: 'Count of records', + meta: { + type: 'number', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + params: {}, + }, + params: { id: 'number' }, + }, + }, + ], + }, + }, + dateRange: { + fromDate: new Date('2020-04-01T16:14:16.246Z'), + toDate: new Date('2020-04-01T17:15:41.263Z'), + }, +}; + +export const dateHistogramLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'timeLayer', + layerType: LayerTypes.DATA, + hide: false, + xAccessor: 'xAccessorId', + yScaleType: 'linear', + xScaleType: 'time', + isHistogram: true, + splitAccessor: 'splitAccessorId', + seriesType: 'bar_stacked', + accessors: ['yAccessorId'], + palette: mockPaletteOutput, +}; + +export function sampleArgsWithReferenceLine(value: number = 150) { + const { data, args } = sampleArgs(); + + return { + data: { + ...data, + tables: { + ...data.tables, + referenceLine: { + type: 'datatable', + columns: [ + { + id: 'referenceLine-a', + meta: { params: { id: 'number' }, type: 'number' }, + name: 'Static value', + }, + ], + rows: [{ 'referenceLine-a': value }], + }, + }, + } as LensMultiTable, + args: { + ...args, + layers: [ + ...args.layers, + { + layerType: LayerTypes.REFERENCELINE, + accessors: ['referenceLine-a'], + layerId: 'referenceLine', + seriesType: 'line', + xScaleType: 'linear', + yScaleType: 'linear', + palette: mockPaletteOutput, + isHistogram: false, + hide: true, + yConfig: [{ axisMode: 'left', forAccessor: 'referenceLine-a', type: 'yConfig' }], + }, + ], + } as XYArgs, + }; +} diff --git a/x-pack/plugins/lens/public/xy_visualization/__snapshots__/expression.test.tsx.snap b/src/plugins/chart_expressions/expression_xy/public/components/__snapshots__/xy_chart.test.tsx.snap similarity index 97% rename from x-pack/plugins/lens/public/xy_visualization/__snapshots__/expression.test.tsx.snap rename to src/plugins/chart_expressions/expression_xy/public/components/__snapshots__/xy_chart.test.tsx.snap index fdde8eb6ad3f2..828a62c85cce3 100644 --- a/x-pack/plugins/lens/public/xy_visualization/__snapshots__/expression.test.tsx.snap +++ b/src/plugins/chart_expressions/expression_xy/public/components/__snapshots__/xy_chart.test.tsx.snap @@ -1,6 +1,6 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`xy_expression XYChart component annotations should render basic annotation 1`] = ` +exports[`XYChart component annotations should render basic annotation 1`] = ` `; -exports[`xy_expression XYChart component annotations should render grouped annotations preserving the shared styles 1`] = ` +exports[`XYChart component annotations should render grouped annotations preserving the shared styles 1`] = ` `; -exports[`xy_expression XYChart component annotations should render grouped annotations with default styles 1`] = ` +exports[`XYChart component annotations should render grouped annotations with default styles 1`] = ` `; -exports[`xy_expression XYChart component annotations should render simplified annotation when hide is true 1`] = ` +exports[`XYChart component annotations should render simplified annotation when hide is true 1`] = ` `; -exports[`xy_expression XYChart component it renders area 1`] = ` +exports[`XYChart component it renders area 1`] = ` @@ -447,7 +447,7 @@ exports[`xy_expression XYChart component it renders area 1`] = ` `; -exports[`xy_expression XYChart component it renders bar 1`] = ` +exports[`XYChart component it renders bar 1`] = ` @@ -693,7 +693,7 @@ exports[`xy_expression XYChart component it renders bar 1`] = ` `; -exports[`xy_expression XYChart component it renders horizontal bar 1`] = ` +exports[`XYChart component it renders horizontal bar 1`] = ` @@ -939,7 +939,7 @@ exports[`xy_expression XYChart component it renders horizontal bar 1`] = ` `; -exports[`xy_expression XYChart component it renders line 1`] = ` +exports[`XYChart component it renders line 1`] = ` @@ -1173,7 +1173,7 @@ exports[`xy_expression XYChart component it renders line 1`] = ` `; -exports[`xy_expression XYChart component it renders stacked area 1`] = ` +exports[`XYChart component it renders stacked area 1`] = ` @@ -1415,7 +1415,7 @@ exports[`xy_expression XYChart component it renders stacked area 1`] = ` `; -exports[`xy_expression XYChart component it renders stacked bar 1`] = ` +exports[`XYChart component it renders stacked bar 1`] = ` @@ -1669,7 +1669,7 @@ exports[`xy_expression XYChart component it renders stacked bar 1`] = ` `; -exports[`xy_expression XYChart component it renders stacked horizontal bar 1`] = ` +exports[`XYChart component it renders stacked horizontal bar 1`] = ` diff --git a/src/plugins/chart_expressions/expression_xy/public/components/annotations.scss b/src/plugins/chart_expressions/expression_xy/public/components/annotations.scss new file mode 100644 index 0000000000000..88881ae718925 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/components/annotations.scss @@ -0,0 +1,18 @@ +.xyAnnotationNumberIcon { + border-radius: $euiSize; + min-width: $euiSize; + height: $euiSize; + background-color: currentColor; +} + +.xyAnnotationNumberIcon__text { + font-weight: 500; + font-size: 9px; + letter-spacing: -.5px; + line-height: 11px; +} + +.xyAnnotationIcon_rotate90 { + transform: rotate(45deg); + transform-origin: center; +} diff --git a/x-pack/plugins/lens/public/xy_visualization/annotations/expression.tsx b/src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx similarity index 66% rename from x-pack/plugins/lens/public/xy_visualization/annotations/expression.tsx rename to src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx index fa41a752cc09b..4e8fa1b95775f 100644 --- a/x-pack/plugins/lens/public/xy_visualization/annotations/expression.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx @@ -1,11 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ -import './expression.scss'; +import './annotations.scss'; +import './reference_lines.scss'; + import React from 'react'; import { snakeCase } from 'lodash'; import { @@ -14,20 +17,20 @@ import { LineAnnotation, Position, } from '@elastic/charts'; -import type { FieldFormat } from 'src/plugins/field_formats/common'; -import type { EventAnnotationArgs } from 'src/plugins/event_annotation/common'; import moment from 'moment'; -import { EuiFlexGroup, EuiFlexItem } from '@elastic/eui'; +import { EuiFlexGroup, EuiFlexItem, EuiIcon, EuiIconProps, EuiText } from '@elastic/eui'; +import classnames from 'classnames'; +import type { EventAnnotationArgs } from '../../../../event_annotation/common'; +import type { FieldFormat } from '../../../../field_formats/common'; import { defaultAnnotationColor } from '../../../../../../src/plugins/event_annotation/public'; -import type { AnnotationLayerArgs } from '../../../common/expressions'; -import { hasIcon } from '../xy_config_panel/shared/icon_select'; -import { - mapVerticalToHorizontalPlacement, - LINES_MARKER_SIZE, - MarkerBody, - Marker, - AnnotationIcon, -} from '../annotations_helpers'; +import type { + AnnotationLayerArgs, + AnnotationLayerConfigResult, + IconPosition, + YAxisMode, +} from '../../common/types'; +import { annotationsIconSet, hasIcon, isNumericalString } from '../helpers'; +import { mapVerticalToHorizontalPlacement, LINES_MARKER_SIZE } from '../helpers'; const getRoundedTimestamp = (timestamp: number, firstTimestamp?: number, minInterval?: number) => { if (!firstTimestamp || !minInterval) { @@ -124,7 +127,7 @@ const getCommonStyles = (configArr: EventAnnotationArgs[]) => { }; export const getAnnotationsGroupedByInterval = ( - layers: AnnotationLayerArgs[], + layers: AnnotationLayerConfigResult[], minInterval?: number, firstTimestamp?: number, formatter?: FieldFormat @@ -187,7 +190,7 @@ export const Annotations = ({ isHorizontal: !isHorizontal, hasReducedPadding, label: annotation.label, - rotateClassName: isHorizontal ? 'lnsXyAnnotationIcon_rotate90' : undefined, + rotateClassName: isHorizontal ? 'xyAnnotationIcon_rotate90' : undefined, }} /> ) : undefined @@ -232,3 +235,123 @@ export const Annotations = ({ ); }; + +export function MarkerBody({ + label, + isHorizontal, +}: { + label: string | undefined; + isHorizontal: boolean; +}) { + if (!label) { + return null; + } + if (isHorizontal) { + return ( +
+ {label} +
+ ); + } + return ( +
+
+ {label} +
+
+ ); +} + +function NumberIcon({ number }: { number: number }) { + return ( + + + {number < 10 ? number : `9+`} + + + ); +} + +export const AnnotationIcon = ({ + type, + rotateClassName = '', + isHorizontal, + renderedInChart, + ...rest +}: { + type: string; + rotateClassName?: string; + isHorizontal?: boolean; + renderedInChart?: boolean; +} & EuiIconProps) => { + if (isNumericalString(type)) { + return ; + } + const iconConfig = annotationsIconSet.find((i) => i.value === type); + if (!iconConfig) { + return null; + } + return ( + + ); +}; + +interface MarkerConfig { + axisMode?: YAxisMode; + icon?: string; + textVisibility?: boolean; + iconPosition?: IconPosition; +} + +export function Marker({ + config, + isHorizontal, + hasReducedPadding, + label, + rotateClassName, +}: { + config: MarkerConfig; + isHorizontal: boolean; + hasReducedPadding: boolean; + label?: string; + rotateClassName?: string; +}) { + if (hasIcon(config.icon)) { + return ( + + ); + } + + // if there's some text, check whether to show it as marker, or just show some padding for the icon + if (config.textVisibility) { + if (hasReducedPadding) { + return ; + } + return ; + } + return null; +} diff --git a/src/plugins/chart_expressions/expression_xy/public/components/index.ts b/src/plugins/chart_expressions/expression_xy/public/components/index.ts new file mode 100644 index 0000000000000..be06610fa8922 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/components/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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export * from './legend_action_popover'; +export * from './reference_lines'; +export * from './legend_action'; +export * from './x_domain'; +export * from './xy_chart'; diff --git a/x-pack/plugins/lens/public/xy_visualization/get_legend_action.test.tsx b/src/plugins/chart_expressions/expression_xy/public/components/legend_action.test.tsx similarity index 92% rename from x-pack/plugins/lens/public/xy_visualization/get_legend_action.test.tsx rename to src/plugins/chart_expressions/expression_xy/public/components/legend_action.test.tsx index faa3ecc976d9b..0f1cdebc5bf59 100644 --- a/x-pack/plugins/lens/public/xy_visualization/get_legend_action.test.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/legend_action.test.tsx @@ -1,8 +1,9 @@ /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import React from 'react'; @@ -11,14 +12,15 @@ import { EuiPopover } from '@elastic/eui'; import { mountWithIntl } from '@kbn/test-jest-helpers'; import { ComponentType, ReactWrapper } from 'enzyme'; import type { LensMultiTable } from '../../common'; -import { layerTypes } from '../../common'; -import type { DataLayerArgs } from '../../common/expressions'; -import { getLegendAction } from './get_legend_action'; -import { LegendActionPopover } from '../shared_components'; +import { LayerTypes } from '../../common/constants'; +import type { DataLayerArgs } from '../../common'; +import { getLegendAction } from './legend_action'; +import { LegendActionPopover } from './legend_action_popover'; +import { mockPaletteOutput } from '../../common/__mocks__'; const sampleLayer = { layerId: 'first', - layerType: layerTypes.DATA, + layerType: LayerTypes.DATA, seriesType: 'line', xAccessor: 'c', accessors: ['a', 'b'], @@ -27,6 +29,7 @@ const sampleLayer = { xScaleType: 'ordinal', yScaleType: 'linear', isHistogram: false, + palette: mockPaletteOutput, } as DataLayerArgs; const tables = { diff --git a/x-pack/plugins/lens/public/xy_visualization/get_legend_action.tsx b/src/plugins/chart_expressions/expression_xy/public/components/legend_action.tsx similarity index 79% rename from x-pack/plugins/lens/public/xy_visualization/get_legend_action.tsx rename to src/plugins/chart_expressions/expression_xy/public/components/legend_action.tsx index 00532314e045b..9bbdec3635fa8 100644 --- a/x-pack/plugins/lens/public/xy_visualization/get_legend_action.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/legend_action.tsx @@ -1,21 +1,22 @@ /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import React from 'react'; import type { LegendAction, XYChartSeriesIdentifier } from '@elastic/charts'; -import type { LensFilterEvent } from '../types'; -import type { LensMultiTable, FormatFactory } from '../../common'; -import type { DataLayerArgs } from '../../common/expressions'; -import { LegendActionPopover } from '../shared_components'; +import type { FilterEvent } from '../types'; +import type { LensMultiTable, DataLayerArgs } from '../../common'; +import type { FormatFactory } from '../types'; +import { LegendActionPopover } from './legend_action_popover'; export const getLegendAction = ( filteredLayers: DataLayerArgs[], tables: LensMultiTable['tables'], - onFilter: (data: LensFilterEvent['data']) => void, + onFilter: (data: FilterEvent['data']) => void, formatFactory: FormatFactory, layersAlreadyFormatted: Record ): LegendAction => @@ -55,7 +56,7 @@ export const getLegendAction = ( }, ]; - const context: LensFilterEvent['data'] = { + const context: FilterEvent['data'] = { data, }; diff --git a/src/plugins/chart_expressions/expression_xy/public/components/legend_action_popover.tsx b/src/plugins/chart_expressions/expression_xy/public/components/legend_action_popover.tsx new file mode 100644 index 0000000000000..a1ab31a993edf --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/components/legend_action_popover.tsx @@ -0,0 +1,108 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React, { useState } from 'react'; +import { i18n } from '@kbn/i18n'; +import { EuiContextMenuPanelDescriptor, EuiIcon, EuiPopover, EuiContextMenu } from '@elastic/eui'; +import { useLegendAction } from '@elastic/charts'; +import type { FilterEvent } from '../types'; + +export interface LegendActionPopoverProps { + /** + * Determines the panels label + */ + label: string; + /** + * Callback on filter value + */ + onFilter: (data: FilterEvent['data']) => void; + /** + * Determines the filter event data + */ + context: FilterEvent['data']; +} + +export const LegendActionPopover: React.FunctionComponent = ({ + label, + onFilter, + context, +}) => { + const [popoverOpen, setPopoverOpen] = useState(false); + const [ref, onClose] = useLegendAction(); + const panels: EuiContextMenuPanelDescriptor[] = [ + { + id: 'main', + title: label, + items: [ + { + name: i18n.translate('expressionXY.legend.filterForValueButtonAriaLabel', { + defaultMessage: 'Filter for value', + }), + 'data-test-subj': `legend-${label}-filterIn`, + icon: , + onClick: () => { + setPopoverOpen(false); + onFilter(context); + }, + }, + { + name: i18n.translate('expressionXY.legend.filterOutValueButtonAriaLabel', { + defaultMessage: 'Filter out value', + }), + 'data-test-subj': `legend-${label}-filterOut`, + icon: , + onClick: () => { + setPopoverOpen(false); + onFilter({ ...context, negate: true }); + }, + }, + ], + }, + ]; + + const Button = ( +
setPopoverOpen(!popoverOpen)} + onClick={() => setPopoverOpen(!popoverOpen)} + > + +
+ ); + return ( + { + setPopoverOpen(false); + onClose(); + }} + panelPaddingSize="none" + anchorPosition="upLeft" + title={i18n.translate('expressionXY.legend.filterOptionsLegend', { + defaultMessage: '{legendDataLabel}, filter options', + values: { legendDataLabel: label }, + })} + > + + + ); +}; diff --git a/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.scss b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.scss similarity index 79% rename from x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.scss rename to src/plugins/chart_expressions/expression_xy/public/components/reference_lines.scss index 07946b52b0000..2cd7fb9c26915 100644 --- a/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.scss +++ b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.scss @@ -1,9 +1,9 @@ -.lnsXyDecorationRotatedWrapper { +.xyDecorationRotatedWrapper { display: inline-block; overflow: hidden; line-height: 1.5; - .lnsXyDecorationRotatedWrapper__label { + .xyDecorationRotatedWrapper__label { display: inline-block; white-space: nowrap; transform: translate(0, 100%) rotate(-90deg); diff --git a/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.test.tsx b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.test.tsx similarity index 93% rename from x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.test.tsx rename to src/plugins/chart_expressions/expression_xy/public/components/reference_lines.test.tsx index 4ec38f31b85af..a0d6351dad7f9 100644 --- a/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.test.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.test.tsx @@ -1,23 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import { LineAnnotation, RectAnnotation } from '@elastic/charts'; import { shallow } from 'enzyme'; import React from 'react'; -import { chartPluginMock } from 'src/plugins/charts/public/mocks'; -import { FieldFormat } from 'src/plugins/field_formats/common'; +import { FieldFormat } from '../../../../field_formats/common'; import { LensMultiTable } from '../../common'; -import { ReferenceLineLayerArgs, YConfig } from '../../common/expressions'; -import { - ReferenceLineAnnotations, - ReferenceLineAnnotationsProps, -} from './expression_reference_lines'; - -const paletteService = chartPluginMock.createPaletteRegistry(); +import { ReferenceLineLayerArgs, YConfig } from '../../common/types'; +import { ReferenceLineAnnotations, ReferenceLineAnnotationsProps } from './reference_lines'; const row: Record = { xAccessorFirstId: 1, @@ -54,7 +49,6 @@ function createLayers(yConfigs: ReferenceLineLayerArgs['yConfig']): ReferenceLin return [ { layerId: 'firstLayer', - layerType: 'referenceLine', accessors: (yConfigs || []).map(({ forAccessor }) => forAccessor), yConfig: yConfigs, }, @@ -90,8 +84,6 @@ describe('ReferenceLineAnnotations', () => { defaultProps = { formatters, - paletteService, - syncColors: false, isHorizontal: false, axesMap: { left: true, right: false }, paddingMap: {}, @@ -117,6 +109,7 @@ describe('ReferenceLineAnnotations', () => { axisMode, lineStyle: 'solid', fill, + type: 'yConfig', }, ])} /> @@ -154,6 +147,7 @@ describe('ReferenceLineAnnotations', () => { forAccessor: `${layerPrefix}FirstId`, axisMode: 'bottom', lineStyle: 'solid', + type: 'yConfig', fill, }, ])} @@ -195,12 +189,14 @@ describe('ReferenceLineAnnotations', () => { forAccessor: `${layerPrefix}FirstId`, axisMode, lineStyle: 'solid', + type: 'yConfig', fill, }, { forAccessor: `${layerPrefix}SecondId`, axisMode, lineStyle: 'solid', + type: 'yConfig', fill, }, ])} @@ -243,12 +239,14 @@ describe('ReferenceLineAnnotations', () => { forAccessor: `${layerPrefix}FirstId`, axisMode: 'bottom', lineStyle: 'solid', + type: 'yConfig', fill, }, { forAccessor: `${layerPrefix}SecondId`, axisMode: 'bottom', lineStyle: 'solid', + type: 'yConfig', fill, }, ])} @@ -291,12 +289,14 @@ describe('ReferenceLineAnnotations', () => { axisMode, lineStyle: 'solid', fill: 'above', + type: 'yConfig', }, { forAccessor: `${layerPrefix}SecondId`, axisMode, lineStyle: 'solid', fill: 'below', + type: 'yConfig', }, ])} /> @@ -339,12 +339,14 @@ describe('ReferenceLineAnnotations', () => { axisMode: 'left', lineStyle: 'solid', fill, + type: 'yConfig', }, { forAccessor: `yAccessorRightSecondId`, axisMode: 'right', lineStyle: 'solid', fill, + type: 'yConfig', }, ])} /> diff --git a/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx new file mode 100644 index 0000000000000..65bc91c06efe5 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx @@ -0,0 +1,366 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import './reference_lines.scss'; + +import React from 'react'; +import { groupBy } from 'lodash'; +import { EuiIcon } from '@elastic/eui'; +import { RectAnnotation, AnnotationDomainType, LineAnnotation, Position } from '@elastic/charts'; +import { euiLightVars } from '@kbn/ui-theme'; +import type { FieldFormat } from '../../../../field_formats/common'; +import type { IconPosition, ReferenceLineLayerArgs, YAxisMode } from '../../common/types'; +import type { LensMultiTable } from '../../common/types'; +import { hasIcon } from '../helpers'; + +export const REFERENCE_LINE_MARKER_SIZE = 20; + +export const computeChartMargins = ( + referenceLinePaddings: Partial>, + labelVisibility: Partial>, + titleVisibility: Partial>, + axesMap: Record<'left' | 'right', unknown>, + isHorizontal: boolean +) => { + const result: Partial> = {}; + if (!labelVisibility?.x && !titleVisibility?.x && referenceLinePaddings.bottom) { + const placement = isHorizontal ? mapVerticalToHorizontalPlacement('bottom') : 'bottom'; + result[placement] = referenceLinePaddings.bottom; + } + if ( + referenceLinePaddings.left && + (isHorizontal || (!labelVisibility?.yLeft && !titleVisibility?.yLeft)) + ) { + const placement = isHorizontal ? mapVerticalToHorizontalPlacement('left') : 'left'; + result[placement] = referenceLinePaddings.left; + } + if ( + referenceLinePaddings.right && + (isHorizontal || !axesMap.right || (!labelVisibility?.yRight && !titleVisibility?.yRight)) + ) { + const placement = isHorizontal ? mapVerticalToHorizontalPlacement('right') : 'right'; + result[placement] = referenceLinePaddings.right; + } + // there's no top axis, so just check if a margin has been computed + if (referenceLinePaddings.top) { + const placement = isHorizontal ? mapVerticalToHorizontalPlacement('top') : 'top'; + result[placement] = referenceLinePaddings.top; + } + return result; +}; + +// Note: it does not take into consideration whether the reference line is in view or not +export const getReferenceLineRequiredPaddings = ( + referenceLineLayers: ReferenceLineLayerArgs[], + axesMap: Record<'left' | 'right', unknown> +) => { + // collect all paddings for the 4 axis: if any text is detected double it. + const paddings: Partial> = {}; + const icons: Partial> = {}; + referenceLineLayers.forEach((layer) => { + layer.yConfig?.forEach(({ axisMode, icon, iconPosition, textVisibility }) => { + if (axisMode && (hasIcon(icon) || textVisibility)) { + const placement = getBaseIconPlacement(iconPosition, axisMode, axesMap); + paddings[placement] = Math.max( + paddings[placement] || 0, + REFERENCE_LINE_MARKER_SIZE * (textVisibility ? 2 : 1) // double the padding size if there's text + ); + icons[placement] = (icons[placement] || 0) + (hasIcon(icon) ? 1 : 0); + } + }); + }); + // post-process the padding based on the icon presence: + // if no icon is present for the placement, just reduce the padding + (Object.keys(paddings) as Position[]).forEach((placement) => { + if (!icons[placement]) { + paddings[placement] = REFERENCE_LINE_MARKER_SIZE; + } + }); + + return paddings; +}; + +function mapVerticalToHorizontalPlacement(placement: Position) { + switch (placement) { + case Position.Top: + return Position.Right; + case Position.Bottom: + return Position.Left; + case Position.Left: + return Position.Bottom; + case Position.Right: + return Position.Top; + } +} + +// if there's just one axis, put it on the other one +// otherwise use the same axis +// this function assume the chart is vertical +function getBaseIconPlacement( + iconPosition: IconPosition | undefined, + axisMode: YAxisMode | undefined, + axesMap: Record +) { + if (iconPosition === 'auto') { + if (axisMode === 'bottom') { + return Position.Top; + } + if (axisMode === 'left') { + return axesMap.right ? Position.Left : Position.Right; + } + return axesMap.left ? Position.Right : Position.Left; + } + + if (iconPosition === 'left') { + return Position.Left; + } + if (iconPosition === 'right') { + return Position.Right; + } + if (iconPosition === 'below') { + return Position.Bottom; + } + return Position.Top; +} + +function getMarkerBody(label: string | undefined, isHorizontal: boolean) { + if (!label) { + return; + } + if (isHorizontal) { + return ( +
+ {label} +
+ ); + } + return ( +
+
+ {label} +
+
+ ); +} + +interface MarkerConfig { + axisMode?: YAxisMode; + icon?: string; + textVisibility?: boolean; +} + +function getMarkerToShow( + markerConfig: MarkerConfig, + label: string | undefined, + isHorizontal: boolean, + hasReducedPadding: boolean +) { + // show an icon if present + if (hasIcon(markerConfig.icon)) { + return ; + } + // if there's some text, check whether to show it as marker, or just show some padding for the icon + if (markerConfig.textVisibility) { + if (hasReducedPadding) { + return getMarkerBody( + label, + (!isHorizontal && markerConfig.axisMode === 'bottom') || + (isHorizontal && markerConfig.axisMode !== 'bottom') + ); + } + return ; + } +} + +export interface ReferenceLineAnnotationsProps { + layers: ReferenceLineLayerArgs[]; + data: LensMultiTable; + formatters: Record<'left' | 'right' | 'bottom', FieldFormat | undefined>; + axesMap: Record<'left' | 'right', boolean>; + isHorizontal: boolean; + paddingMap: Partial>; +} + +export const ReferenceLineAnnotations = ({ + layers, + data, + formatters, + axesMap, + isHorizontal, + paddingMap, +}: ReferenceLineAnnotationsProps) => { + return ( + <> + {layers.flatMap((layer) => { + if (!layer.yConfig) { + return []; + } + const { columnToLabel, yConfig: yConfigs, layerId } = layer; + const columnToLabelMap: Record = columnToLabel + ? JSON.parse(columnToLabel) + : {}; + const table = data.tables[layerId]; + + const row = table.rows[0]; + + const yConfigByValue = yConfigs.sort( + ({ forAccessor: idA }, { forAccessor: idB }) => row[idA] - row[idB] + ); + + const groupedByDirection = groupBy(yConfigByValue, 'fill'); + if (groupedByDirection.below) { + groupedByDirection.below.reverse(); + } + + return yConfigByValue.flatMap((yConfig, i) => { + // Find the formatter for the given axis + const groupId = + yConfig.axisMode === 'bottom' + ? undefined + : yConfig.axisMode === 'right' + ? 'right' + : 'left'; + + const formatter = formatters[groupId || 'bottom']; + + const defaultColor = euiLightVars.euiColorDarkShade; + + // get the position for vertical chart + const markerPositionVertical = getBaseIconPlacement( + yConfig.iconPosition, + yConfig.axisMode, + axesMap + ); + // the padding map is built for vertical chart + const hasReducedPadding = + paddingMap[markerPositionVertical] === REFERENCE_LINE_MARKER_SIZE; + + const props = { + groupId, + marker: getMarkerToShow( + yConfig, + columnToLabelMap[yConfig.forAccessor], + isHorizontal, + hasReducedPadding + ), + markerBody: getMarkerBody( + yConfig.textVisibility && !hasReducedPadding + ? columnToLabelMap[yConfig.forAccessor] + : undefined, + (!isHorizontal && yConfig.axisMode === 'bottom') || + (isHorizontal && yConfig.axisMode !== 'bottom') + ), + // rotate the position if required + markerPosition: isHorizontal + ? mapVerticalToHorizontalPlacement(markerPositionVertical) + : markerPositionVertical, + }; + const annotations = []; + + const dashStyle = + yConfig.lineStyle === 'dashed' + ? [(yConfig.lineWidth || 1) * 3, yConfig.lineWidth || 1] + : yConfig.lineStyle === 'dotted' + ? [yConfig.lineWidth || 1, yConfig.lineWidth || 1] + : undefined; + + const sharedStyle = { + strokeWidth: yConfig.lineWidth || 1, + stroke: yConfig.color || defaultColor, + dash: dashStyle, + }; + + annotations.push( + ({ + dataValue: row[yConfig.forAccessor], + header: columnToLabelMap[yConfig.forAccessor], + details: formatter?.convert(row[yConfig.forAccessor]) || row[yConfig.forAccessor], + }))} + domainType={ + yConfig.axisMode === 'bottom' + ? AnnotationDomainType.XDomain + : AnnotationDomainType.YDomain + } + style={{ + line: { + ...sharedStyle, + opacity: 1, + }, + }} + /> + ); + + if (yConfig.fill && yConfig.fill !== 'none') { + const isFillAbove = yConfig.fill === 'above'; + const indexFromSameType = groupedByDirection[yConfig.fill].findIndex( + ({ forAccessor }) => forAccessor === yConfig.forAccessor + ); + const shouldCheckNextReferenceLine = + indexFromSameType < groupedByDirection[yConfig.fill].length - 1; + annotations.push( + { + const nextValue = shouldCheckNextReferenceLine + ? row[groupedByDirection[yConfig.fill!][indexFromSameType + 1].forAccessor] + : undefined; + if (yConfig.axisMode === 'bottom') { + return { + coordinates: { + x0: isFillAbove ? row[yConfig.forAccessor] : nextValue, + y0: undefined, + x1: isFillAbove ? nextValue : row[yConfig.forAccessor], + y1: undefined, + }, + header: columnToLabelMap[yConfig.forAccessor], + details: + formatter?.convert(row[yConfig.forAccessor]) || row[yConfig.forAccessor], + }; + } + return { + coordinates: { + x0: undefined, + y0: isFillAbove ? row[yConfig.forAccessor] : nextValue, + x1: undefined, + y1: isFillAbove ? nextValue : row[yConfig.forAccessor], + }, + header: columnToLabelMap[yConfig.forAccessor], + details: + formatter?.convert(row[yConfig.forAccessor]) || row[yConfig.forAccessor], + }; + })} + style={{ + ...sharedStyle, + fill: yConfig.color || defaultColor, + opacity: 0.1, + }} + /> + ); + } + return annotations; + }); + })} + + ); +}; diff --git a/x-pack/plugins/lens/public/xy_visualization/x_domain.tsx b/src/plugins/chart_expressions/expression_xy/public/components/x_domain.tsx similarity index 89% rename from x-pack/plugins/lens/public/xy_visualization/x_domain.tsx rename to src/plugins/chart_expressions/expression_xy/public/components/x_domain.tsx index eb9de9a2993b4..dbc4c348cb891 100644 --- a/x-pack/plugins/lens/public/xy_visualization/x_domain.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/x_domain.tsx @@ -1,17 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import { uniq } from 'lodash'; import React from 'react'; import moment from 'moment'; -import { Endzones } from '../../../../../src/plugins/charts/public'; -import type { LensMultiTable } from '../../common'; -import type { DataLayerArgs } from '../../common/expressions'; -import { search } from '../../../../../src/plugins/data/public'; +import { Endzones } from '../../../../../plugins/charts/public'; +import type { LensMultiTable, DataLayerArgs } from '../../common'; +import { search } from '../../../../../plugins/data/public'; export interface XDomain { min?: number; diff --git a/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.scss b/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.scss new file mode 100644 index 0000000000000..ba998c863b6ac --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.scss @@ -0,0 +1,7 @@ +.xyChart__empty { + height: 100%; + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; +} diff --git a/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.test.tsx b/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.test.tsx new file mode 100644 index 0000000000000..1a8a16c165e9e --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.test.tsx @@ -0,0 +1,2703 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { mount, shallow } from 'enzyme'; +import { mountWithIntl } from '@kbn/test-jest-helpers'; +import { + AnnotationLayerConfigResult, + DataLayerConfigResult, + LensMultiTable, + XYArgs, +} from '../../common'; +import { LayerTypes } from '../../common/constants'; +import { + AreaSeries, + Axis, + BarSeries, + Fit, + GeometryValue, + HorizontalAlignment, + LayoutDirection, + LineAnnotation, + LineSeries, + Position, + ScaleType, + SeriesNameFn, + Settings, + VerticalAlignment, + XYChartSeriesIdentifier, +} from '@elastic/charts'; +import { EmptyPlaceholder } from '../../../../../plugins/charts/public'; +import { XyEndzones } from './x_domain'; +import { + chartsActiveCursorService, + chartsThemeService, + dateHistogramData, + dateHistogramLayer, + paletteService, + sampleArgsWithReferenceLine, +} from '../__mocks__'; +import { + mockPaletteOutput, + sampleArgs, + createArgsWithLayers, + createSampleDatatableWithRows, + sampleLayer, +} from '../../common/__mocks__'; +import { XYChart, XYChartRenderProps } from './xy_chart'; +import { eventAnnotationServiceMock } from '../../../../event_annotation/public/mocks'; +import { EventAnnotationOutput } from '../../../../event_annotation/common'; + +const onClickValue = jest.fn(); +const onSelectRange = jest.fn(); + +describe('XYChart component', () => { + let getFormatSpy: jest.Mock; + let convertSpy: jest.Mock; + let defaultProps: Omit; + + const dataWithoutFormats: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + type: 'datatable', + columns: [ + { id: 'a', name: 'a', meta: { type: 'number' } }, + { id: 'b', name: 'b', meta: { type: 'number' } }, + { id: 'c', name: 'c', meta: { type: 'string' } }, + { id: 'd', name: 'd', meta: { type: 'string' } }, + ], + rows: [ + { a: 1, b: 2, c: 'I', d: 'Row 1' }, + { a: 1, b: 5, c: 'J', d: 'Row 2' }, + ], + }, + }, + }; + const dataWithFormats: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + type: 'datatable', + columns: [ + { id: 'a', name: 'a', meta: { type: 'number' } }, + { id: 'b', name: 'b', meta: { type: 'number' } }, + { id: 'c', name: 'c', meta: { type: 'string' } }, + { id: 'd', name: 'd', meta: { type: 'string', params: { id: 'custom' } } }, + ], + rows: [ + { a: 1, b: 2, c: 'I', d: 'Row 1' }, + { a: 1, b: 5, c: 'J', d: 'Row 2' }, + ], + }, + }, + }; + + const getRenderedComponent = (data: LensMultiTable, args: XYArgs) => { + return shallow(); + }; + + beforeEach(() => { + convertSpy = jest.fn((x) => x); + getFormatSpy = jest.fn(); + getFormatSpy.mockReturnValue({ convert: convertSpy }); + + defaultProps = { + formatFactory: getFormatSpy, + timeZone: 'UTC', + renderMode: 'view', + chartsThemeService, + chartsActiveCursorService, + paletteService, + minInterval: 50, + onClickValue, + onSelectRange, + syncColors: false, + useLegacyTimeAxis: false, + eventAnnotationService: eventAnnotationServiceMock, + }; + }); + + test('it renders line', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(LineSeries)).toHaveLength(2); + expect(component.find(LineSeries).at(0).prop('yAccessors')).toEqual(['a']); + expect(component.find(LineSeries).at(1).prop('yAccessors')).toEqual(['b']); + }); + + describe('date range', () => { + const timeSampleLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'c', + accessors: ['a', 'b'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', + xScaleType: 'time', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }; + const multiLayerArgs = createArgsWithLayers([ + timeSampleLayer, + { + ...timeSampleLayer, + layerId: 'second', + seriesType: 'bar', + xScaleType: 'time', + }, + ]); + test('it uses the full date range', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + c.id !== 'c' + ? c + : { + ...c, + meta: { + type: 'date', + source: 'esaggs', + sourceParams: { + type: 'date_histogram', + params: {}, + appliedTimeRange: { + from: '2019-01-02T05:00:00.000Z', + to: '2019-01-03T05:00:00.000Z', + }, + }, + }, + } + ), + }, + }, + }} + args={{ + ...args, + layers: [ + { + ...(args.layers[0] as DataLayerConfigResult), + seriesType: 'line', + xScaleType: 'time', + }, + ], + }} + minInterval={undefined} + /> + ); + expect(component.find(Settings).prop('xDomain')).toMatchInlineSnapshot(` + Object { + "max": 1546491600000, + "min": 1546405200000, + "minInterval": undefined, + } + `); + }); + + test('it uses passed in minInterval', () => { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: createSampleDatatableWithRows([{ a: 1, b: 2, c: 'I', d: 'Foo' }]), + second: createSampleDatatableWithRows([]), + }, + }; + + const component = shallow(); + + // real auto interval is 30mins = 1800000 + expect(component.find(Settings).prop('xDomain')).toMatchInlineSnapshot(` + Object { + "max": NaN, + "min": NaN, + "minInterval": 50, + } + `); + }); + + describe('axis time', () => { + const defaultTimeLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'c', + accessors: ['a', 'b'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', + xScaleType: 'time', + yScaleType: 'linear', + isHistogram: true, + palette: mockPaletteOutput, + }; + test('it should disable the new time axis for a line time layer when isHistogram is set to false', () => { + const { data } = sampleArgs(); + + const instance = shallow( + + ); + + const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); + + expect(axisStyle).toBe(0); + }); + test('it should enable the new time axis for a line time layer when isHistogram is set to true', () => { + const { data } = sampleArgs(); + const timeLayerArgs = createArgsWithLayers([defaultTimeLayer]); + + const instance = shallow( + + ); + + const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); + + expect(axisStyle).toBe(3); + }); + test('it should disable the new time axis for a vertical bar with break down dimension', () => { + const { data } = sampleArgs(); + const timeLayer: DataLayerConfigResult = { + ...defaultTimeLayer, + seriesType: 'bar', + }; + const timeLayerArgs = createArgsWithLayers([timeLayer]); + + const instance = shallow( + + ); + + const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); + + expect(axisStyle).toBe(0); + }); + + test('it should enable the new time axis for a stacked vertical bar with break down dimension', () => { + const { data } = sampleArgs(); + const timeLayer: DataLayerConfigResult = { + ...defaultTimeLayer, + seriesType: 'bar_stacked', + }; + const timeLayerArgs = createArgsWithLayers([timeLayer]); + + const instance = shallow( + + ); + + const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); + + expect(axisStyle).toBe(3); + }); + }); + describe('endzones', () => { + const { args } = sampleArgs(); + const table = createSampleDatatableWithRows([ + { a: 1, b: 2, c: new Date('2021-04-22').valueOf(), d: 'Foo' }, + { a: 1, b: 2, c: new Date('2021-04-23').valueOf(), d: 'Foo' }, + { a: 1, b: 2, c: new Date('2021-04-24').valueOf(), d: 'Foo' }, + ]); + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + ...table, + columns: table.columns.map((c) => + c.id !== 'c' + ? c + : { + ...c, + meta: { + type: 'date', + source: 'esaggs', + sourceParams: { + type: 'date_histogram', + params: {}, + appliedTimeRange: { + from: '2021-04-22T12:00:00.000Z', + to: '2021-04-24T12:00:00.000Z', + }, + }, + }, + } + ), + }, + }, + dateRange: { + // first and last bucket are partial + fromDate: new Date('2021-04-22T12:00:00.000Z'), + toDate: new Date('2021-04-24T12:00:00.000Z'), + }, + }; + const timeArgs: XYArgs = { + ...args, + layers: [ + { + ...(args.layers[0] as DataLayerConfigResult), + seriesType: 'line', + xScaleType: 'time', + isHistogram: true, + splitAccessor: undefined, + }, + ], + }; + + test('it extends interval if data is exceeding it', () => { + const component = shallow( + + ); + + expect(component.find(Settings).prop('xDomain')).toEqual({ + // shortened to 24th midnight (elastic-charts automatically adds one min interval) + max: new Date('2021-04-24').valueOf(), + // extended to 22nd midnight because of first bucket + min: new Date('2021-04-22').valueOf(), + minInterval: 24 * 60 * 60 * 1000, + }); + }); + + test('it renders endzone component bridging gap between domain and extended domain', () => { + const component = shallow( + + ); + + expect(component.find(XyEndzones).dive().find('Endzones').props()).toEqual( + expect.objectContaining({ + domainStart: new Date('2021-04-22T12:00:00.000Z').valueOf(), + domainEnd: new Date('2021-04-24T12:00:00.000Z').valueOf(), + domainMin: new Date('2021-04-22').valueOf(), + domainMax: new Date('2021-04-24').valueOf(), + }) + ); + }); + + test('should pass enabled histogram mode and min interval to endzones component', () => { + const component = shallow( + + ); + + expect(component.find(XyEndzones).dive().find('Endzones').props()).toEqual( + expect.objectContaining({ + interval: 24 * 60 * 60 * 1000, + isFullBin: false, + }) + ); + }); + + test('should pass disabled histogram mode and min interval to endzones component', () => { + const component = shallow( + + ); + + expect(component.find(XyEndzones).dive().find('Endzones').props()).toEqual( + expect.objectContaining({ + interval: 24 * 60 * 60 * 1000, + isFullBin: true, + }) + ); + }); + + test('it does not render endzones if disabled via settings', () => { + const component = shallow( + + ); + + expect(component.find(XyEndzones).length).toEqual(0); + }); + }); + }); + + describe('y axis extents', () => { + test('it passes custom y axis extents to elastic-charts axis spec', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: false, + min: 123, + max: 456, + }); + }); + + test('it passes fit to bounds y axis extents to elastic-charts axis spec', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: true, + min: NaN, + max: NaN, + }); + }); + + test('it does not allow fit for area chart', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: false, + min: NaN, + max: NaN, + }); + }); + + test('it does not allow positive lower bound for bar', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: false, + min: NaN, + max: NaN, + }); + }); + + test('it does include referenceLine values when in full extent mode', () => { + const { data, args } = sampleArgsWithReferenceLine(); + + const component = shallow(); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: false, + min: 0, + max: 150, + }); + }); + + test('it should ignore referenceLine values when set to custom extents', () => { + const { data, args } = sampleArgsWithReferenceLine(); + + const component = shallow( + + ); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: false, + min: 123, + max: 456, + }); + }); + + test('it should work for negative values in referenceLines', () => { + const { data, args } = sampleArgsWithReferenceLine(-150); + + const component = shallow(); + expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ + fit: false, + min: -150, + max: 5, + }); + }); + }); + + test('it has xDomain undefined if the x is not a time scale or a histogram', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + const xDomain = component.find(Settings).prop('xDomain'); + expect(xDomain).toEqual(undefined); + }); + + test('it uses min interval if interval is passed in and visualization is histogram', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(Settings).prop('xDomain')).toEqual({ + minInterval: 101, + min: NaN, + max: NaN, + }); + }); + + test('disabled legend extra by default', () => { + const { data, args } = sampleArgs(); + const component = shallow(); + expect(component.find(Settings).at(0).prop('showLegendExtra')).toEqual(false); + }); + + test('ignores legend extra for ordinal chart', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component.find(Settings).at(0).prop('showLegendExtra')).toEqual(false); + }); + + test('shows legend extra for histogram chart', () => { + const { args } = sampleArgs(); + const component = shallow( + + ); + expect(component.find(Settings).at(0).prop('showLegendExtra')).toEqual(true); + }); + + test('it renders bar', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(BarSeries)).toHaveLength(2); + expect(component.find(BarSeries).at(0).prop('yAccessors')).toEqual(['a']); + expect(component.find(BarSeries).at(1).prop('yAccessors')).toEqual(['b']); + }); + + test('it renders area', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(AreaSeries)).toHaveLength(2); + expect(component.find(AreaSeries).at(0).prop('yAccessors')).toEqual(['a']); + expect(component.find(AreaSeries).at(1).prop('yAccessors')).toEqual(['b']); + }); + + test('it renders horizontal bar', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(BarSeries)).toHaveLength(2); + expect(component.find(BarSeries).at(0).prop('yAccessors')).toEqual(['a']); + expect(component.find(BarSeries).at(1).prop('yAccessors')).toEqual(['b']); + expect(component.find(Settings).prop('rotation')).toEqual(90); + }); + + test('it renders regular bar empty placeholder for no results', () => { + const { data, args } = sampleArgs(); + + // send empty data to the chart + data.tables.first.rows = []; + + const component = shallow(); + + expect(component.find(BarSeries)).toHaveLength(0); + expect(component.find(EmptyPlaceholder).prop('icon')).toBeDefined(); + }); + + test('onBrushEnd returns correct context data for date histogram data', () => { + const { args } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + wrapper.find(Settings).first().prop('onBrushEnd')!({ x: [1585757732783, 1585758880838] }); + + expect(onSelectRange).toHaveBeenCalledWith({ + column: 0, + table: dateHistogramData.tables.timeLayer, + range: [1585757732783, 1585758880838], + }); + }); + + test('onBrushEnd returns correct context data for number histogram data', () => { + const { args } = sampleArgs(); + + const numberLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'numberLayer', + layerType: LayerTypes.DATA, + hide: false, + xAccessor: 'xAccessorId', + yScaleType: 'linear', + xScaleType: 'linear', + isHistogram: true, + seriesType: 'bar_stacked', + accessors: ['yAccessorId'], + palette: mockPaletteOutput, + }; + + const numberHistogramData: LensMultiTable = { + type: 'lens_multitable', + tables: { + numberLayer: { + type: 'datatable', + rows: [ + { + xAccessorId: 5, + yAccessorId: 1, + }, + { + xAccessorId: 7, + yAccessorId: 1, + }, + { + xAccessorId: 8, + yAccessorId: 1, + }, + { + xAccessorId: 10, + yAccessorId: 1, + }, + ], + columns: [ + { + id: 'xAccessorId', + name: 'bytes', + meta: { type: 'number' }, + }, + { + id: 'yAccessorId', + name: 'Count of records', + meta: { type: 'number' }, + }, + ], + }, + }, + dateRange: { + fromDate: new Date('2020-04-01T16:14:16.246Z'), + toDate: new Date('2020-04-01T17:15:41.263Z'), + }, + }; + + const wrapper = mountWithIntl( + + ); + + wrapper.find(Settings).first().prop('onBrushEnd')!({ x: [5, 8] }); + + expect(onSelectRange).toHaveBeenCalledWith({ + column: 0, + table: numberHistogramData.tables.numberLayer, + range: [5, 8], + }); + }); + + test('onBrushEnd is not set on non-interactive mode', () => { + const { args, data } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + + expect(wrapper.find(Settings).first().prop('onBrushEnd')).toBeUndefined(); + }); + + test('allowBrushingLastHistogramBin is true for date histogram data', () => { + const { args } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + expect(wrapper.find(Settings).at(0).prop('allowBrushingLastHistogramBin')).toEqual(true); + }); + + test('onElementClick returns correct context data', () => { + const geometry: GeometryValue = { x: 5, y: 1, accessor: 'y1', mark: null, datum: {} }; + const series = { + key: 'spec{d}yAccessor{d}splitAccessors{b-2}', + specId: 'd', + yAccessor: 'd', + splitAccessors: {}, + seriesKeys: [2, 'd'], + }; + + const { args, data } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + + wrapper.find(Settings).first().prop('onElementClick')!([ + [geometry, series as XYChartSeriesIdentifier], + ]); + + expect(onClickValue).toHaveBeenCalledWith({ + data: [ + { + column: 1, + row: 1, + table: data.tables.first, + value: 5, + }, + { + column: 1, + row: 0, + table: data.tables.first, + value: 2, + }, + ], + }); + }); + + test('onElementClick returns correct context data for date histogram', () => { + const geometry: GeometryValue = { + x: 1585758120000, + y: 1, + accessor: 'y1', + mark: null, + datum: {}, + }; + const series = { + key: 'spec{d}yAccessor{d}splitAccessors{b-2}', + specId: 'd', + yAccessor: 'yAccessorId', + splitAccessors: {}, + seriesKeys: ['yAccessorId'], + }; + + const { args } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + + wrapper.find(Settings).first().prop('onElementClick')!([ + [geometry, series as XYChartSeriesIdentifier], + ]); + + expect(onClickValue).toHaveBeenCalledWith({ + data: [ + { + column: 0, + row: 0, + table: dateHistogramData.tables.timeLayer, + value: 1585758120000, + }, + ], + }); + }); + + test('onElementClick returns correct context data for numeric histogram', () => { + const { args } = sampleArgs(); + + const numberLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'numberLayer', + layerType: LayerTypes.DATA, + hide: false, + xAccessor: 'xAccessorId', + yScaleType: 'linear', + xScaleType: 'linear', + isHistogram: true, + seriesType: 'bar_stacked', + accessors: ['yAccessorId'], + palette: mockPaletteOutput, + }; + + const numberHistogramData: LensMultiTable = { + type: 'lens_multitable', + tables: { + numberLayer: { + type: 'datatable', + rows: [ + { + xAccessorId: 5, + yAccessorId: 1, + }, + { + xAccessorId: 7, + yAccessorId: 1, + }, + { + xAccessorId: 8, + yAccessorId: 1, + }, + { + xAccessorId: 10, + yAccessorId: 1, + }, + ], + columns: [ + { + id: 'xAccessorId', + name: 'bytes', + meta: { type: 'number' }, + }, + { + id: 'yAccessorId', + name: 'Count of records', + meta: { type: 'number' }, + }, + ], + }, + }, + dateRange: { + fromDate: new Date('2020-04-01T16:14:16.246Z'), + toDate: new Date('2020-04-01T17:15:41.263Z'), + }, + }; + const geometry: GeometryValue = { + x: 5, + y: 1, + accessor: 'y1', + mark: null, + datum: {}, + }; + const series = { + key: 'spec{d}yAccessor{d}splitAccessors{b-2}', + specId: 'd', + yAccessor: 'yAccessorId', + splitAccessors: {}, + seriesKeys: ['yAccessorId'], + }; + + const wrapper = mountWithIntl( + + ); + + wrapper.find(Settings).first().prop('onElementClick')!([ + [geometry, series as XYChartSeriesIdentifier], + ]); + + expect(onClickValue).toHaveBeenCalledWith({ + data: [ + { + column: 0, + row: 0, + table: numberHistogramData.tables.numberLayer, + value: 5, + }, + ], + timeFieldName: undefined, + }); + }); + + test('returns correct original data for ordinal x axis with special formatter', () => { + const geometry: GeometryValue = { x: 'BAR', y: 1, accessor: 'y1', mark: null, datum: {} }; + const series = { + key: 'spec{d}yAccessor{d}splitAccessors{b-2}', + specId: 'd', + yAccessor: 'a', + splitAccessors: {}, + seriesKeys: ['a'], + }; + + const { args, data } = sampleArgs(); + + convertSpy.mockImplementation((x) => (typeof x === 'string' ? x.toUpperCase() : x)); + + const wrapper = mountWithIntl( + + ); + + wrapper.find(Settings).first().prop('onElementClick')!([ + [geometry, series as XYChartSeriesIdentifier], + ]); + + expect(onClickValue).toHaveBeenCalledWith({ + data: [ + { + column: 3, + row: 1, + table: data.tables.first, + value: 'Bar', + }, + ], + }); + }); + + test('sets up correct yScaleType equal to binary_linear for bytes formatting', () => { + const { args, data } = sampleArgs(); + data.tables.first.columns[0].meta = { + type: 'number', + params: { id: 'bytes', params: { pattern: '0,0.00b' } }, + }; + + const wrapper = mountWithIntl( + + ); + + expect(wrapper.find(LineSeries).at(0).prop('yScaleType')).toEqual('linear_binary'); + }); + + test('allowBrushingLastHistogramBin should be fakse for ordinal data', () => { + const { args, data } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + + expect(wrapper.find(Settings).at(0).prop('allowBrushingLastHistogramBin')).toEqual(false); + }); + + test('onElementClick is not triggering event on non-interactive mode', () => { + const { args, data } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + + expect(wrapper.find(Settings).first().prop('onElementClick')).toBeUndefined(); + }); + + test('legendAction is not triggering event on non-interactive mode', () => { + const { args, data } = sampleArgs(); + + const wrapper = mountWithIntl( + + ); + + expect(wrapper.find(Settings).first().prop('legendAction')).toBeUndefined(); + }); + + test('it renders stacked bar', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(BarSeries)).toHaveLength(2); + expect(component.find(BarSeries).at(0).prop('stackAccessors')).toHaveLength(1); + expect(component.find(BarSeries).at(1).prop('stackAccessors')).toHaveLength(1); + }); + + test('it renders stacked area', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(AreaSeries)).toHaveLength(2); + expect(component.find(AreaSeries).at(0).prop('stackAccessors')).toHaveLength(1); + expect(component.find(AreaSeries).at(1).prop('stackAccessors')).toHaveLength(1); + }); + + test('it renders stacked horizontal bar', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component).toMatchSnapshot(); + expect(component.find(BarSeries)).toHaveLength(2); + expect(component.find(BarSeries).at(0).prop('stackAccessors')).toHaveLength(1); + expect(component.find(BarSeries).at(1).prop('stackAccessors')).toHaveLength(1); + expect(component.find(Settings).prop('rotation')).toEqual(90); + }); + + test('it renders stacked bar empty placeholder for no results', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + + expect(component.find(BarSeries)).toHaveLength(0); + expect(component.find(EmptyPlaceholder).prop('icon')).toBeDefined(); + }); + + test('it passes time zone to the series', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component.find(LineSeries).at(0).prop('timeZone')).toEqual('CEST'); + expect(component.find(LineSeries).at(1).prop('timeZone')).toEqual('CEST'); + }); + + test('it applies histogram mode to the series for single series', () => { + const { data, args } = sampleArgs(); + const firstLayer: DataLayerConfigResult = { + ...args.layers[0], + accessors: ['b'], + seriesType: 'bar', + isHistogram: true, + } as DataLayerConfigResult; + delete firstLayer.splitAccessor; + const component = shallow( + + ); + expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(true); + }); + + test('it does not apply histogram mode to more than one bar series for unstacked bar chart', () => { + const { data, args } = sampleArgs(); + const firstLayer: DataLayerConfigResult = { + ...args.layers[0], + seriesType: 'bar', + isHistogram: true, + } as DataLayerConfigResult; + delete firstLayer.splitAccessor; + const component = shallow( + + ); + expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(false); + expect(component.find(BarSeries).at(1).prop('enableHistogramMode')).toEqual(false); + }); + + test('it applies histogram mode to more than one the series for unstacked line/area chart', () => { + const { data, args } = sampleArgs(); + const firstLayer: DataLayerConfigResult = { + ...args.layers[0], + seriesType: 'line', + isHistogram: true, + } as DataLayerConfigResult; + delete firstLayer.splitAccessor; + const secondLayer: DataLayerConfigResult = { + ...args.layers[0], + seriesType: 'line', + isHistogram: true, + } as DataLayerConfigResult; + delete secondLayer.splitAccessor; + const component = shallow( + + ); + expect(component.find(LineSeries).at(0).prop('enableHistogramMode')).toEqual(true); + expect(component.find(LineSeries).at(1).prop('enableHistogramMode')).toEqual(true); + }); + + test('it applies histogram mode to the series for stacked series', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(true); + expect(component.find(BarSeries).at(1).prop('enableHistogramMode')).toEqual(true); + }); + + test('it does not apply histogram mode for splitted series', () => { + const { data, args } = sampleArgs(); + const component = shallow( + + ); + expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(false); + expect(component.find(BarSeries).at(1).prop('enableHistogramMode')).toEqual(false); + }); + + describe('y axes', () => { + test('single axis if possible', () => { + const args = createArgsWithLayers(); + + const component = getRenderedComponent(dataWithoutFormats, args); + const axes = component.find(Axis); + expect(axes).toHaveLength(2); + }); + + test('multiple axes because of config', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a', 'b'], + yConfig: [ + { + forAccessor: 'a', + axisMode: 'left', + }, + { + forAccessor: 'b', + axisMode: 'right', + }, + ], + }, + ], + } as XYArgs; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const axes = component.find(Axis); + expect(axes).toHaveLength(3); + expect(component.find(LineSeries).at(0).prop('groupId')).toEqual(axes.at(1).prop('groupId')); + expect(component.find(LineSeries).at(1).prop('groupId')).toEqual(axes.at(2).prop('groupId')); + }); + + test('multiple axes because of incompatible formatters', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['c', 'd'], + }, + ], + } as XYArgs; + + const component = getRenderedComponent(dataWithFormats, newArgs); + const axes = component.find(Axis); + expect(axes).toHaveLength(3); + expect(component.find(LineSeries).at(0).prop('groupId')).toEqual(axes.at(1).prop('groupId')); + expect(component.find(LineSeries).at(1).prop('groupId')).toEqual(axes.at(2).prop('groupId')); + }); + + test('single axis despite different formatters if enforced', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['c', 'd'], + yConfig: [ + { + forAccessor: 'c', + axisMode: 'left', + }, + { + forAccessor: 'd', + axisMode: 'left', + }, + ], + }, + ], + } as XYArgs; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const axes = component.find(Axis); + expect(axes).toHaveLength(2); + }); + }); + + describe('y series coloring', () => { + test('color is applied to chart for multiple series', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + splitAccessor: undefined, + accessors: ['a', 'b'], + yConfig: [ + { + forAccessor: 'a', + color: '#550000', + }, + { + forAccessor: 'b', + color: '#FFFF00', + }, + ], + }, + { + ...args.layers[0], + splitAccessor: undefined, + accessors: ['c'], + yConfig: [ + { + forAccessor: 'c', + color: '#FEECDF', + }, + ], + }, + ], + } as XYArgs; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + expect( + (component.find(LineSeries).at(0).prop('color') as Function)!({ + yAccessor: 'a', + seriesKeys: ['a'], + }) + ).toEqual('#550000'); + expect( + (component.find(LineSeries).at(1).prop('color') as Function)!({ + yAccessor: 'b', + seriesKeys: ['b'], + }) + ).toEqual('#FFFF00'); + expect( + (component.find(LineSeries).at(2).prop('color') as Function)!({ + yAccessor: 'c', + seriesKeys: ['c'], + }) + ).toEqual('#FEECDF'); + }); + test('color is not applied to chart when splitAccessor is defined or when yConfig is not configured', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a'], + yConfig: [ + { + forAccessor: 'a', + color: '#550000', + }, + ], + }, + { + ...args.layers[0], + splitAccessor: undefined, + accessors: ['c'], + }, + ], + } as XYArgs; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + expect( + (component.find(LineSeries).at(0).prop('color') as Function)!({ + yAccessor: 'a', + seriesKeys: ['a'], + }) + ).toEqual('blue'); + expect( + (component.find(LineSeries).at(1).prop('color') as Function)!({ + yAccessor: 'c', + seriesKeys: ['c'], + }) + ).toEqual('blue'); + }); + }); + + describe('provides correct series naming', () => { + const nameFnArgs = { + seriesKeys: [], + key: '', + specId: 'a', + yAccessor: '', + splitAccessors: new Map(), + }; + + test('simplest xy chart without human-readable name', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a'], + splitAccessor: undefined, + columnToLabel: '', + }, + ], + }; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; + + // In this case, the ID is used as the name. This shouldn't happen in practice + expect(nameFn({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual(''); + expect(nameFn({ ...nameFnArgs, seriesKeys: ['nonsense'] }, false)).toEqual(''); + }); + + test('simplest xy chart with empty name', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a'], + splitAccessor: undefined, + columnToLabel: '{"a":""}', + }, + ], + }; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; + + // In this case, the ID is used as the name. This shouldn't happen in practice + expect(nameFn({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual(''); + expect(nameFn({ ...nameFnArgs, seriesKeys: ['nonsense'] }, false)).toEqual(''); + }); + + test('simplest xy chart with human-readable name', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a'], + splitAccessor: undefined, + columnToLabel: '{"a":"Column A"}', + }, + ], + }; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; + + expect(nameFn({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual('Column A'); + }); + + test('multiple y accessors', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a', 'b'], + splitAccessor: undefined, + columnToLabel: '{"a": "Label A"}', + }, + ], + }; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const nameFn1 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; + const nameFn2 = component.find(LineSeries).at(1).prop('name') as SeriesNameFn; + + // This accessor has a human-readable name + expect(nameFn1({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual('Label A'); + // This accessor does not + expect(nameFn2({ ...nameFnArgs, seriesKeys: ['b'] }, false)).toEqual(''); + expect(nameFn1({ ...nameFnArgs, seriesKeys: ['nonsense'] }, false)).toEqual(''); + }); + + test('split series without formatting and single y accessor', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A"}', + }, + ], + }; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; + + expect(nameFn({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual('split1'); + }); + + test('split series with formatting and single y accessor', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A"}', + }, + ], + }; + + const component = getRenderedComponent(dataWithFormats, newArgs); + const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; + + convertSpy.mockReturnValueOnce('formatted'); + expect(nameFn({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual('formatted'); + expect(getFormatSpy).toHaveBeenCalledWith({ id: 'custom' }); + }); + + test('split series without formatting with multiple y accessors', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a', 'b'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A","b": "Label B"}', + }, + ], + }; + + const component = getRenderedComponent(dataWithoutFormats, newArgs); + const nameFn1 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; + const nameFn2 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; + + expect(nameFn1({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual( + 'split1 - Label A' + ); + expect(nameFn2({ ...nameFnArgs, seriesKeys: ['split1', 'b'] }, false)).toEqual( + 'split1 - Label B' + ); + }); + + test('split series with formatting with multiple y accessors', () => { + const args = createArgsWithLayers(); + const newArgs = { + ...args, + layers: [ + { + ...args.layers[0], + accessors: ['a', 'b'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A","b": "Label B"}', + }, + ], + }; + + const component = getRenderedComponent(dataWithFormats, newArgs); + const nameFn1 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; + const nameFn2 = component.find(LineSeries).at(1).prop('name') as SeriesNameFn; + + convertSpy.mockReturnValueOnce('formatted1').mockReturnValueOnce('formatted2'); + expect(nameFn1({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual( + 'formatted1 - Label A' + ); + expect(nameFn2({ ...nameFnArgs, seriesKeys: ['split1', 'b'] }, false)).toEqual( + 'formatted2 - Label B' + ); + }); + }); + + test('it set the scale of the x axis according to the args prop', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(LineSeries).at(0).prop('xScaleType')).toEqual(ScaleType.Ordinal); + expect(component.find(LineSeries).at(1).prop('xScaleType')).toEqual(ScaleType.Ordinal); + }); + + test('it set the scale of the y axis according to the args prop', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + expect(component.find(LineSeries).at(0).prop('yScaleType')).toEqual(ScaleType.Sqrt); + expect(component.find(LineSeries).at(1).prop('yScaleType')).toEqual(ScaleType.Sqrt); + }); + + test('it gets the formatter for the x axis', () => { + const { data, args } = sampleArgs(); + + shallow(); + + expect(getFormatSpy).toHaveBeenCalledWith({ id: 'string' }); + }); + + test('it gets the formatter for the y axis if there is only one accessor', () => { + const { data, args } = sampleArgs(); + + shallow( + + ); + expect(getFormatSpy).toHaveBeenCalledWith({ + id: 'number', + params: { pattern: '0,0.000' }, + }); + }); + + test('it should pass the formatter function to the axis', () => { + const { data, args } = sampleArgs(); + + const instance = shallow(); + + const tickFormatter = instance.find(Axis).first().prop('tickFormat'); + + if (!tickFormatter) { + throw new Error('tickFormatter prop not found'); + } + + tickFormatter('I'); + + expect(convertSpy).toHaveBeenCalledWith('I'); + }); + + test('it should set the tickLabel visibility on the x axis if the tick labels is hidden', () => { + const { data, args } = sampleArgs(); + + args.tickLabelsVisibilitySettings = { + x: false, + yLeft: true, + yRight: true, + type: 'tickLabelsConfig', + }; + + const instance = shallow(); + + const axisStyle = instance.find(Axis).first().prop('style'); + + expect(axisStyle).toMatchObject({ + tickLabel: { + visible: false, + }, + }); + }); + + test('it should set the tickLabel visibility on the y axis if the tick labels is hidden', () => { + const { data, args } = sampleArgs(); + + args.tickLabelsVisibilitySettings = { + x: true, + yLeft: false, + yRight: false, + type: 'tickLabelsConfig', + }; + + const instance = shallow(); + + const axisStyle = instance.find(Axis).at(1).prop('style'); + + expect(axisStyle).toMatchObject({ + tickLabel: { + visible: false, + }, + }); + }); + + test('it should set the tickLabel visibility on the x axis if the tick labels is shown', () => { + const { data, args } = sampleArgs(); + + args.tickLabelsVisibilitySettings = { + x: true, + yLeft: true, + yRight: true, + type: 'tickLabelsConfig', + }; + + const instance = shallow(); + + const axisStyle = instance.find(Axis).first().prop('style'); + + expect(axisStyle).toMatchObject({ + tickLabel: { + visible: true, + }, + }); + }); + + test('it should set the tickLabel orientation on the x axis', () => { + const { data, args } = sampleArgs(); + + args.labelsOrientation = { + x: -45, + yLeft: 0, + yRight: -90, + type: 'labelsOrientationConfig', + }; + + const instance = shallow(); + + const axisStyle = instance.find(Axis).first().prop('style'); + + expect(axisStyle).toMatchObject({ + tickLabel: { + rotation: -45, + }, + }); + }); + + test('it should set the tickLabel visibility on the y axis if the tick labels is shown', () => { + const { data, args } = sampleArgs(); + + args.tickLabelsVisibilitySettings = { + x: false, + yLeft: true, + yRight: true, + type: 'tickLabelsConfig', + }; + + const instance = shallow(); + + const axisStyle = instance.find(Axis).at(1).prop('style'); + + expect(axisStyle).toMatchObject({ + tickLabel: { + visible: true, + }, + }); + }); + + test('it should set the tickLabel orientation on the y axis', () => { + const { data, args } = sampleArgs(); + + args.labelsOrientation = { + x: -45, + yLeft: -90, + yRight: -90, + type: 'labelsOrientationConfig', + }; + + const instance = shallow(); + + const axisStyle = instance.find(Axis).at(1).prop('style'); + + expect(axisStyle).toMatchObject({ + tickLabel: { + rotation: -90, + }, + }); + }); + + test('it should remove invalid rows', () => { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + type: 'datatable', + columns: [ + { id: 'a', name: 'a', meta: { type: 'number' } }, + { id: 'b', name: 'b', meta: { type: 'number' } }, + { id: 'c', name: 'c', meta: { type: 'string' } }, + ], + rows: [ + { a: undefined, b: 2, c: 'I', d: 'Row 1' }, + { a: 1, b: 5, c: 'J', d: 'Row 2' }, + ], + }, + second: { + type: 'datatable', + columns: [ + { id: 'a', name: 'a', meta: { type: 'number' } }, + { id: 'b', name: 'b', meta: { type: 'number' } }, + { id: 'c', name: 'c', meta: { type: 'string' } }, + ], + rows: [ + { a: undefined, b: undefined, c: undefined }, + { a: undefined, b: undefined, c: undefined }, + ], + }, + }, + }; + + const args: XYArgs = { + xTitle: '', + yTitle: '', + yRightTitle: '', + legend: { type: 'legendConfig', isVisible: false, position: Position.Top }, + valueLabels: 'hide', + tickLabelsVisibilitySettings: { + type: 'tickLabelsConfig', + x: true, + yLeft: true, + yRight: true, + }, + gridlinesVisibilitySettings: { + type: 'gridlinesConfig', + x: true, + yLeft: false, + yRight: false, + }, + labelsOrientation: { + type: 'labelsOrientationConfig', + x: 0, + yLeft: 0, + yRight: 0, + }, + yLeftExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + yRightExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + layers: [ + { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'a', + accessors: ['c'], + splitAccessor: 'b', + columnToLabel: '', + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }, + { + type: 'dataLayer', + layerId: 'second', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'a', + accessors: ['c'], + splitAccessor: 'b', + columnToLabel: '', + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }, + ], + }; + + const component = shallow(); + + const series = component.find(LineSeries); + + // Only one series should be rendered, even though 2 are configured + // This one series should only have one row, even though 2 are sent + expect(series.prop('data')).toEqual([{ a: 1, b: 5, c: 'J', d: 'Row 2' }]); + }); + + test('it should not remove rows with falsy but non-undefined values', () => { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + type: 'datatable', + columns: [ + { id: 'a', name: 'a', meta: { type: 'number' } }, + { id: 'b', name: 'b', meta: { type: 'number' } }, + { id: 'c', name: 'c', meta: { type: 'number' } }, + ], + rows: [ + { a: 0, b: 2, c: 5 }, + { a: 1, b: 0, c: 7 }, + ], + }, + }, + }; + + const args: XYArgs = { + xTitle: '', + yTitle: '', + yRightTitle: '', + legend: { type: 'legendConfig', isVisible: false, position: Position.Top }, + valueLabels: 'hide', + tickLabelsVisibilitySettings: { + type: 'tickLabelsConfig', + x: true, + yLeft: false, + yRight: false, + }, + gridlinesVisibilitySettings: { + type: 'gridlinesConfig', + x: true, + yLeft: false, + yRight: false, + }, + labelsOrientation: { + type: 'labelsOrientationConfig', + x: 0, + yLeft: 0, + yRight: 0, + }, + yLeftExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + yRightExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + layers: [ + { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'a', + accessors: ['c'], + splitAccessor: 'b', + columnToLabel: '', + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }, + ], + }; + + const component = shallow(); + + const series = component.find(LineSeries); + + expect(series.prop('data')).toEqual([ + { a: 0, b: 2, c: 5 }, + { a: 1, b: 0, c: 7 }, + ]); + }); + + test('it should show legend for split series, even with one row', () => { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + type: 'datatable', + columns: [ + { id: 'a', name: 'a', meta: { type: 'number' } }, + { id: 'b', name: 'b', meta: { type: 'number' } }, + { id: 'c', name: 'c', meta: { type: 'string' } }, + ], + rows: [{ a: 1, b: 5, c: 'J' }], + }, + }, + }; + + const args: XYArgs = { + xTitle: '', + yTitle: '', + yRightTitle: '', + legend: { type: 'legendConfig', isVisible: true, position: Position.Top }, + valueLabels: 'hide', + tickLabelsVisibilitySettings: { + type: 'tickLabelsConfig', + x: true, + yLeft: false, + yRight: false, + }, + gridlinesVisibilitySettings: { + type: 'gridlinesConfig', + x: true, + yLeft: false, + yRight: false, + }, + labelsOrientation: { + type: 'labelsOrientationConfig', + x: 0, + yLeft: 0, + yRight: 0, + }, + yLeftExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + yRightExtent: { + mode: 'full', + type: 'axisExtentConfig', + }, + layers: [ + { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'a', + accessors: ['c'], + splitAccessor: 'b', + columnToLabel: '', + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }, + ], + }; + + const component = shallow(); + + expect(component.find(Settings).prop('showLegend')).toEqual(true); + }); + + test('it should always show legend if showSingleSeries is set', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + + expect(component.find(Settings).prop('showLegend')).toEqual(true); + }); + + test('it should populate the correct legendPosition if isInside is set', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + + expect(component.find(Settings).prop('legendPosition')).toEqual({ + vAlign: VerticalAlignment.Top, + hAlign: HorizontalAlignment.Right, + direction: LayoutDirection.Vertical, + floating: true, + floatingColumns: 1, + }); + }); + + test('it not show legend if isVisible is set to false', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + + expect(component.find(Settings).prop('showLegend')).toEqual(false); + }); + + test('it should show legend on right side', () => { + const { data, args } = sampleArgs(); + + const component = shallow( + + ); + + expect(component.find(Settings).prop('legendPosition')).toEqual('top'); + }); + + test('it should apply the fitting function to all non-bar series', () => { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: createSampleDatatableWithRows([ + { a: 1, b: 2, c: 'I', d: 'Foo' }, + { a: 1, b: 5, c: 'J', d: 'Bar' }, + ]), + }, + }; + + const args: XYArgs = createArgsWithLayers([ + { ...sampleLayer, accessors: ['a'] }, + { ...sampleLayer, seriesType: 'bar', accessors: ['a'] }, + { ...sampleLayer, seriesType: 'area', accessors: ['a'] }, + { ...sampleLayer, seriesType: 'area_stacked', accessors: ['a'] }, + ]); + + const component = shallow( + + ); + + expect(component.find(LineSeries).prop('fit')).toEqual({ type: Fit.Carry }); + expect(component.find(BarSeries).prop('fit')).toEqual(undefined); + expect(component.find(AreaSeries).at(0).prop('fit')).toEqual({ type: Fit.Carry }); + expect(component.find(AreaSeries).at(0).prop('stackAccessors')).toEqual([]); + expect(component.find(AreaSeries).at(1).prop('fit')).toEqual({ type: Fit.Carry }); + expect(component.find(AreaSeries).at(1).prop('stackAccessors')).toEqual(['c']); + }); + + test('it should apply None fitting function if not specified', () => { + const { data, args } = sampleArgs(); + + (args.layers[0] as DataLayerConfigResult).accessors = ['a']; + + const component = shallow(); + + expect(component.find(LineSeries).prop('fit')).toEqual({ type: Fit.None }); + }); + + test('it should apply the xTitle if is specified', () => { + const { data, args } = sampleArgs(); + + args.xTitle = 'My custom x-axis title'; + + const component = shallow(); + + expect(component.find(Axis).at(0).prop('title')).toEqual('My custom x-axis title'); + }); + + test('it should hide the X axis title if the corresponding switch is off', () => { + const { data, args } = sampleArgs(); + + args.axisTitlesVisibilitySettings = { + x: false, + yLeft: true, + yRight: true, + type: 'axisTitlesVisibilityConfig', + }; + + const component = shallow(); + + const axisStyle = component.find(Axis).first().prop('style'); + + expect(axisStyle).toMatchObject({ + axisTitle: { + visible: false, + }, + }); + }); + + test('it should show the X axis gridlines if the setting is on', () => { + const { data, args } = sampleArgs(); + + args.gridlinesVisibilitySettings = { + x: true, + yLeft: false, + yRight: false, + type: 'gridlinesConfig', + }; + + const component = shallow(); + + expect(component.find(Axis).at(0).prop('gridLine')).toMatchObject({ + visible: true, + }); + }); + + test('it should format the boolean values correctly', () => { + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + first: { + type: 'datatable', + columns: [ + { + id: 'a', + name: 'a', + meta: { type: 'number', params: { id: 'number', params: { pattern: '0,0.000' } } }, + }, + { + id: 'b', + name: 'b', + meta: { type: 'number', params: { id: 'number', params: { pattern: '000,0' } } }, + }, + { + id: 'c', + name: 'c', + meta: { + type: 'boolean', + params: { id: 'boolean' }, + }, + }, + ], + rows: [ + { a: 5, b: 2, c: 0 }, + { a: 19, b: 5, c: 1 }, + ], + }, + }, + dateRange: { + fromDate: new Date('2019-01-02T05:00:00.000Z'), + toDate: new Date('2019-01-03T05:00:00.000Z'), + }, + }; + const timeSampleLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'c', + accessors: ['a', 'b'], + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: mockPaletteOutput, + }; + const args = createArgsWithLayers([timeSampleLayer]); + + const getCustomFormatSpy = jest.fn(); + getCustomFormatSpy.mockReturnValue({ convert: jest.fn((x) => Boolean(x)) }); + + const component = shallow( + + ); + + expect(component.find(LineSeries).at(1).prop('data')).toEqual([ + { + a: 5, + b: 2, + c: false, + }, + { + a: 19, + b: 5, + c: true, + }, + ]); + }); + + describe('annotations', () => { + const sampleStyledAnnotation: EventAnnotationOutput = { + time: '2022-03-18T08:25:00.000Z', + label: 'Event 1', + icon: 'triangle', + type: 'manual_event_annotation', + color: 'red', + lineStyle: 'dashed', + lineWidth: 3, + }; + const sampleAnnotationLayers: AnnotationLayerConfigResult[] = [ + { + type: 'annotationLayer', + layerType: LayerTypes.ANNOTATIONS, + layerId: 'annotation', + annotations: [ + { + time: '2022-03-18T08:25:17.140Z', + label: 'Annotation', + type: 'manual_event_annotation', + }, + ], + }, + ]; + function sampleArgsWithAnnotation(annotationLayers = sampleAnnotationLayers) { + const { args } = sampleArgs(); + return { + data: dateHistogramData, + args: { + ...args, + layers: [dateHistogramLayer, ...annotationLayers], + } as XYArgs, + }; + } + test('should render basic annotation', () => { + const { data, args } = sampleArgsWithAnnotation(); + const component = mount(); + expect(component.find('LineAnnotation')).toMatchSnapshot(); + }); + test('should render simplified annotation when hide is true', () => { + const { data, args } = sampleArgsWithAnnotation(); + (args.layers[0] as AnnotationLayerConfigResult).hide = true; + const component = mount(); + expect(component.find('LineAnnotation')).toMatchSnapshot(); + }); + + test('should render grouped annotations preserving the shared styles', () => { + const { data, args } = sampleArgsWithAnnotation([ + { + type: 'annotationLayer', + layerType: LayerTypes.ANNOTATIONS, + layerId: 'annotation', + annotations: [ + sampleStyledAnnotation, + { ...sampleStyledAnnotation, time: '2022-03-18T08:25:00.020Z', label: 'Event 2' }, + { + ...sampleStyledAnnotation, + time: '2022-03-18T08:25:00.001Z', + label: 'Event 3', + }, + ], + }, + ]); + const component = mount(); + const groupedAnnotation = component.find(LineAnnotation); + + expect(groupedAnnotation.length).toEqual(1); + // styles are passed because they are shared, dataValues & header is rounded to the interval + expect(groupedAnnotation).toMatchSnapshot(); + // renders numeric icon for grouped annotations + const marker = mount(
{groupedAnnotation.prop('marker')}
); + const numberIcon = marker.find('NumberIcon'); + expect(numberIcon.length).toEqual(1); + expect(numberIcon.text()).toEqual('3'); + + // checking tooltip + const renderLinks = mount(
{groupedAnnotation.prop('customTooltipDetails')!()}
); + expect(renderLinks.text()).toEqual( + ' Event 1 2022-03-18T08:25:00.000Z Event 3 2022-03-18T08:25:00.001Z Event 2 2022-03-18T08:25:00.020Z' + ); + }); + test('should render grouped annotations with default styles', () => { + const { data, args } = sampleArgsWithAnnotation([ + { + type: 'annotationLayer', + layerType: LayerTypes.ANNOTATIONS, + layerId: 'annotation', + annotations: [sampleStyledAnnotation], + }, + { + type: 'annotationLayer', + layerType: LayerTypes.ANNOTATIONS, + layerId: 'annotation', + annotations: [ + { + ...sampleStyledAnnotation, + icon: 'square', + color: 'blue', + lineStyle: 'dotted', + lineWidth: 10, + time: '2022-03-18T08:25:00.001Z', + label: 'Event 2', + }, + ], + }, + ]); + const component = mount(); + const groupedAnnotation = component.find(LineAnnotation); + + expect(groupedAnnotation.length).toEqual(1); + // styles are default because they are different for both annotations + expect(groupedAnnotation).toMatchSnapshot(); + }); + test('should not render hidden annotations', () => { + const { data, args } = sampleArgsWithAnnotation([ + { + type: 'annotationLayer', + layerType: LayerTypes.ANNOTATIONS, + layerId: 'annotation', + annotations: [ + sampleStyledAnnotation, + { ...sampleStyledAnnotation, time: '2022-03-18T08:30:00.020Z', label: 'Event 2' }, + { + ...sampleStyledAnnotation, + time: '2022-03-18T08:35:00.001Z', + label: 'Event 3', + isHidden: true, + }, + ], + }, + ]); + const component = mount(); + const annotations = component.find(LineAnnotation); + + expect(annotations.length).toEqual(2); + }); + }); +}); diff --git a/x-pack/plugins/lens/public/xy_visualization/expression.tsx b/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.tsx similarity index 81% rename from x-pack/plugins/lens/public/xy_visualization/expression.tsx rename to src/plugins/chart_expressions/expression_xy/public/components/xy_chart.tsx index 105b9d24bb09b..d69e8e8b645fa 100644 --- a/x-pack/plugins/lens/public/xy_visualization/expression.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/xy_chart.tsx @@ -1,14 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ -import './expression.scss'; - import React, { useRef } from 'react'; -import ReactDOM from 'react-dom'; import { Chart, Settings, @@ -38,57 +36,44 @@ import { LineSeriesProps, ColorVariant, } from '@elastic/charts'; -import { I18nProvider } from '@kbn/i18n-react'; -import type { - ExpressionRenderDefinition, - Datatable, - DatatableRow, - DatatableColumn, -} from 'src/plugins/expressions/public'; import { IconType } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; -import { RenderMode } from 'src/plugins/expressions'; -import { ThemeServiceStart } from 'kibana/public'; -import { FieldFormat } from 'src/plugins/field_formats/common'; -import { EventAnnotationServiceType } from '../../../../../src/plugins/event_annotation/public'; -import { EmptyPlaceholder } from '../../../../../src/plugins/charts/public'; -import { KibanaThemeProvider } from '../../../../../src/plugins/kibana_react/public'; -import type { ILensInterpreterRenderHandlers, LensFilterEvent, LensBrushEvent } from '../types'; -import type { LensMultiTable, FormatFactory } from '../../common'; -import type { - DataLayerArgs, - SeriesType, - XYChartProps, - XYLayerArgs, -} from '../../common/expressions'; -import { visualizationTypes } from './types'; -import { VisualizationContainer } from '../visualization_container'; -import { isHorizontalChart, getSeriesColor } from './state_helpers'; -import { search } from '../../../../../src/plugins/data/public'; +import type { Datatable, DatatableRow, DatatableColumn } from '../../../../expressions/public'; +import { RenderMode } from '../../../../expressions/common'; +import { FieldFormat } from '../../../../field_formats/common'; +import { EmptyPlaceholder } from '../../../../../plugins/charts/public'; +import type { FilterEvent, BrushEvent, FormatFactory } from '../types'; +import type { SeriesType, XYChartProps } from '../../common/types'; +import { isHorizontalChart, getSeriesColor, getAnnotationsLayers, getDataLayers } from '../helpers'; +import { EventAnnotationServiceType } from '../../../../event_annotation/public'; import { ChartsPluginSetup, ChartsPluginStart, PaletteRegistry, SeriesLayer, useActiveCursor, -} from '../../../../../src/plugins/charts/public'; -import { MULTILAYER_TIME_AXIS_STYLE } from '../../../../../src/plugins/charts/common'; -import { getFitOptions } from './fitting_functions'; -import { getAxesConfiguration, GroupsConfiguration, validateExtent } from './axes_configuration'; -import { getColorAssignments } from './color_assignment'; -import { getXDomain, XyEndzones } from './x_domain'; -import { getLegendAction } from './get_legend_action'; -import { ReferenceLineAnnotations } from './expression_reference_lines'; - -import { computeChartMargins, getLinesCausedPaddings } from './annotations_helpers'; - -import { Annotations, getAnnotationsGroupedByInterval } from './annotations/expression'; -import { computeOverallDataDomain } from './reference_line_helpers'; +} from '../../../../../plugins/charts/public'; +import { MULTILAYER_TIME_AXIS_STYLE } from '../../../../../plugins/charts/common'; import { + getFilteredLayers, getReferenceLayers, - getDataLayersArgs, - getAnnotationsLayersArgs, -} from './visualization_helpers'; + isDataLayer, + getFitOptions, + getAxesConfiguration, + GroupsConfiguration, + validateExtent, + computeOverallDataDomain, + getColorAssignments, + getLinesCausedPaddings, +} from '../helpers'; +import { getXDomain, XyEndzones } from './x_domain'; +import { getLegendAction } from './legend_action'; +import { ReferenceLineAnnotations, computeChartMargins } from './reference_lines'; +import { visualizationDefinitions } from '../definitions'; +import { XYLayerConfigResult } from '../../common/types'; +import { Annotations, getAnnotationsGroupedByInterval } from './annotations'; + +import './xy_chart.scss'; declare global { interface Window { @@ -110,96 +95,15 @@ export type XYChartRenderProps = XYChartProps & { useLegacyTimeAxis: boolean; minInterval: number | undefined; interactive?: boolean; - onClickValue: (data: LensFilterEvent['data']) => void; - onSelectRange: (data: LensBrushEvent['data']) => void; + onClickValue: (data: FilterEvent['data']) => void; + onSelectRange: (data: BrushEvent['data']) => void; renderMode: RenderMode; syncColors: boolean; eventAnnotationService: EventAnnotationServiceType; }; -export function calculateMinInterval({ args: { layers }, data }: XYChartProps) { - const filteredLayers = getFilteredLayers(layers, data); - if (filteredLayers.length === 0) return; - const isTimeViz = filteredLayers.every((l) => l.xScaleType === 'time'); - const xColumn = data.tables[filteredLayers[0].layerId].columns.find( - (column) => column.id === filteredLayers[0].xAccessor - ); - - if (!xColumn) return; - if (!isTimeViz) { - const histogramInterval = search.aggs.getNumberHistogramIntervalByDatatableColumn(xColumn); - if (typeof histogramInterval === 'number') { - return histogramInterval; - } else { - return undefined; - } - } - const dateInterval = search.aggs.getDateHistogramMetaDataByDatatableColumn(xColumn)?.interval; - if (!dateInterval) return; - const intervalDuration = search.aggs.parseInterval(dateInterval); - if (!intervalDuration) return; - return intervalDuration.as('milliseconds'); -} - const isPrimitive = (value: unknown): boolean => value != null && typeof value !== 'object'; -export const getXyChartRenderer = (dependencies: { - formatFactory: FormatFactory; - chartsThemeService: ChartsPluginStart['theme']; - chartsActiveCursorService: ChartsPluginStart['activeCursor']; - paletteService: PaletteRegistry; - timeZone: string; - useLegacyTimeAxis: boolean; - kibanaTheme: ThemeServiceStart; - eventAnnotationService: EventAnnotationServiceType; -}): ExpressionRenderDefinition => ({ - name: 'lens_xy_chart_renderer', - displayName: 'XY chart', - help: i18n.translate('xpack.lens.xyChart.renderer.help', { - defaultMessage: 'X/Y chart renderer', - }), - validate: () => undefined, - reuseDomNode: true, - render: async ( - domNode: Element, - config: XYChartProps, - handlers: ILensInterpreterRenderHandlers - ) => { - handlers.onDestroy(() => ReactDOM.unmountComponentAtNode(domNode)); - const onClickValue = (data: LensFilterEvent['data']) => { - handlers.event({ name: 'filter', data }); - }; - const onSelectRange = (data: LensBrushEvent['data']) => { - handlers.event({ name: 'brush', data }); - }; - - ReactDOM.render( - - - - - , - domNode, - () => handlers.done() - ); - }, -}); - function getValueLabelsStyling(isHorizontal: boolean): { displayValue: RecursivePartial; } { @@ -222,18 +126,10 @@ function getValueLabelsStyling(isHorizontal: boolean): { } function getIconForSeriesType(seriesType: SeriesType): IconType { - return visualizationTypes.find((c) => c.id === seriesType)!.icon || 'empty'; + return visualizationDefinitions.find((c) => c.id === seriesType)!.icon || 'empty'; } -const MemoizedChart = React.memo(XYChart); - -export function XYChartReportable(props: XYChartRenderProps) { - return ( - - - - ); -} +export const XYChartReportable = React.memo(XYChart); export function XYChart({ data, @@ -268,26 +164,28 @@ export function XYChart({ const chartBaseTheme = chartsThemeService.useChartsBaseTheme(); const darkMode = chartsThemeService.useDarkMode(); const filteredLayers = getFilteredLayers(layers, data); - const layersById = filteredLayers.reduce((memo, layer) => { - memo[layer.layerId] = layer; - return memo; - }, {} as Record); + const layersById = filteredLayers.reduce>( + (hashMap, layer) => { + hashMap[layer.layerId] = layer; + return hashMap; + }, + {} + ); const handleCursorUpdate = useActiveCursor(chartsActiveCursorService, chartRef, { datatables: Object.values(data.tables), }); if (filteredLayers.length === 0) { - const icon: IconType = getIconForSeriesType( - getDataLayersArgs(layers)?.[0]?.seriesType || 'bar' - ); - return ; + const icon: IconType = getIconForSeriesType(getDataLayers(layers)?.[0]?.seriesType || 'bar'); + return ; } // use formatting hint of first x axis column to format ticks const xAxisColumn = data.tables[filteredLayers[0].layerId].columns.find( ({ id }) => id === filteredLayers[0].xAccessor ); + const xAxisFormatter = formatFactory(xAxisColumn && xAxisColumn.meta?.params); const layersAlreadyFormatted: Record = {}; @@ -368,7 +266,7 @@ export function XYChart({ }; const referenceLineLayers = getReferenceLayers(layers); - const annotationsLayers = getAnnotationsLayersArgs(layers); + const annotationsLayers = getAnnotationsLayers(layers); const firstTable = data.tables[filteredLayers[0].layerId]; const xColumnId = firstTable.columns.find((col) => col.id === filteredLayers[0].xAccessor)?.id; @@ -427,8 +325,12 @@ export function XYChart({ const extent = axis.groupId === 'left' ? yLeftExtent : yRightExtent; const hasBarOrArea = Boolean( axis.series.some((series) => { - const seriesType = layersById[series.layer]?.seriesType; - return seriesType?.includes('bar') || seriesType?.includes('area'); + const layer = layersById[series.layer]; + if (!(layer && isDataLayer(layer))) { + return false; + } + + return layer.seriesType.includes('bar') || layer.seriesType.includes('area'); }) ); const fit = !hasBarOrArea && extent.mode === 'dataBounds'; @@ -489,7 +391,7 @@ export function XYChart({ const valueLabelsStyling = shouldShowValueLabels && valueLabels !== 'hide' && getValueLabelsStyling(shouldRotate); - const colorAssignments = getColorAssignments(getDataLayersArgs(args.layers), data, formatFactory); + const colorAssignments = getColorAssignments(getDataLayers(args.layers), data, formatFactory); const clickHandler: ElementClickListener = ([[geometry, series]]) => { // for xyChart series is always XYChartSeriesIdentifier and geometry is always type of GeometryValue @@ -548,7 +450,7 @@ export function XYChart({ value: pointValue, }); } - const context: LensFilterEvent['data'] = { + const context: FilterEvent['data'] = { data: points.map((point) => ({ row: point.row, column: point.column, @@ -572,7 +474,7 @@ export function XYChart({ const xAxisColumnIndex = table.columns.findIndex((el) => el.id === filteredLayers[0].xAccessor); - const context: LensBrushEvent['data'] = { + const context: BrushEvent['data'] = { range: [min, max], table, column: xAxisColumnIndex, @@ -827,7 +729,7 @@ export function XYChart({ if (!xAccessor) { rows.forEach((row) => { - row.unifiedX = i18n.translate('xpack.lens.xyChart.emptyXLabel', { + row.unifiedX = i18n.translate('expressionXY.xyChart.emptyXLabel', { defaultMessage: '(empty)', }); }); @@ -1021,8 +923,6 @@ export function XYChart({ { - const { layerId, xAccessor, accessors, splitAccessor } = layer; - return !( - !accessors.length || - !data.tables[layerId] || - data.tables[layerId].rows.length === 0 || - (xAccessor && - data.tables[layerId].rows.every((row) => typeof row[xAccessor] === 'undefined')) || - // stacked percentage bars have no xAccessors but splitAccessor with undefined values in them when empty - (!xAccessor && - splitAccessor && - data.tables[layerId].rows.every((row) => typeof row[splitAccessor] === 'undefined')) - ); - }); -} - function assertNever(x: never): never { throw new Error('Unexpected series type: ' + x); } diff --git a/src/plugins/chart_expressions/expression_xy/public/definitions/index.ts b/src/plugins/chart_expressions/expression_xy/public/definitions/index.ts new file mode 100644 index 0000000000000..53af8ec397dcb --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/definitions/index.ts @@ -0,0 +1,9 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export { visualizationDefinitions } from './visualizations'; diff --git a/src/plugins/chart_expressions/expression_xy/public/definitions/visualizations.ts b/src/plugins/chart_expressions/expression_xy/public/definitions/visualizations.ts new file mode 100644 index 0000000000000..9cd1540c7bbeb --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/definitions/visualizations.ts @@ -0,0 +1,34 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { SeriesTypes } from '../../common/constants'; +import { + BarIcon, + LineIcon, + AreaIcon, + BarStackedIcon, + AreaStackedIcon, + BarHorizontalIcon, + BarPercentageIcon, + AreaPercentageIcon, + BarHorizontalStackedIcon, + BarHorizontalPercentageIcon, +} from '../icons'; + +export const visualizationDefinitions = [ + { id: SeriesTypes.BAR, icon: BarIcon }, + { id: SeriesTypes.BAR_STACKED, icon: BarStackedIcon }, + { id: SeriesTypes.BAR_HORIZONTAL, icon: BarHorizontalIcon }, + { id: SeriesTypes.BAR_PERCENTAGE_STACKED, icon: BarPercentageIcon }, + { id: SeriesTypes.BAR_HORIZONTAL_STACKED, icon: BarHorizontalStackedIcon }, + { id: SeriesTypes.BAR_HORIZONTAL_PERCENTAGE_STACKED, icon: BarHorizontalPercentageIcon }, + { id: SeriesTypes.LINE, icon: LineIcon }, + { id: SeriesTypes.AREA, icon: AreaIcon }, + { id: SeriesTypes.AREA_STACKED, icon: AreaStackedIcon }, + { id: SeriesTypes.AREA_PERCENTAGE_STACKED, icon: AreaPercentageIcon }, +]; diff --git a/src/plugins/chart_expressions/expression_xy/public/expression_renderers/index.ts b/src/plugins/chart_expressions/expression_xy/public/expression_renderers/index.ts new file mode 100644 index 0000000000000..863dbb960512d --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/expression_renderers/index.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export { getXyChartRenderer } from './xy_chart_renderer'; +export type { GetStartDepsFn } from './xy_chart_renderer'; diff --git a/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx b/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx new file mode 100644 index 0000000000000..70acc25330b87 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx @@ -0,0 +1,90 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import { I18nProvider } from '@kbn/i18n-react'; +import { ThemeServiceStart } from 'kibana/public'; +import React from 'react'; +import ReactDOM from 'react-dom'; +import { ChartsPluginStart, PaletteRegistry } from '../../../../charts/public'; +import { EventAnnotationServiceType } from '../../../../event_annotation/public'; +import { ExpressionRenderDefinition } from '../../../../expressions'; +import { FormatFactory } from '../../../../field_formats/common'; +import { KibanaThemeProvider } from '../../../../kibana_react/public'; +import { XYChartProps } from '../../common'; +import { calculateMinInterval } from '../helpers'; +import { BrushEvent, FilterEvent } from '../types'; + +export type GetStartDepsFn = () => Promise<{ + formatFactory: FormatFactory; + theme: ChartsPluginStart['theme']; + activeCursor: ChartsPluginStart['activeCursor']; + paletteService: PaletteRegistry; + timeZone: string; + useLegacyTimeAxis: boolean; + kibanaTheme: ThemeServiceStart; + eventAnnotationService: EventAnnotationServiceType; +}>; + +interface XyChartRendererDeps { + getStartDeps: GetStartDepsFn; +} + +export const getXyChartRenderer = ({ + getStartDeps, +}: XyChartRendererDeps): ExpressionRenderDefinition => ({ + name: 'xyVis', + displayName: 'XY chart', + help: i18n.translate('expressionXY.xyVis.renderer.help', { + defaultMessage: 'X/Y chart renderer', + }), + validate: () => undefined, + reuseDomNode: true, + render: async (domNode: Element, config: XYChartProps, handlers) => { + handlers.onDestroy(() => ReactDOM.unmountComponentAtNode(domNode)); + const onClickValue = (data: FilterEvent['data']) => { + handlers.event({ name: 'filter', data }); + }; + const onSelectRange = (data: BrushEvent['data']) => { + handlers.event({ name: 'brush', data }); + }; + const deps = await getStartDeps(); + + const { XYChartReportable } = await import('../components/xy_chart'); + + ReactDOM.render( + + +
+ +
{' '} +
+
, + domNode, + () => handlers.done() + ); + }, +}); diff --git a/x-pack/plugins/lens/public/xy_visualization/annotations_helpers.tsx b/src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx similarity index 57% rename from x-pack/plugins/lens/public/xy_visualization/annotations_helpers.tsx rename to src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx index ddbdfc91f4a3e..8da38af10f5d9 100644 --- a/x-pack/plugins/lens/public/xy_visualization/annotations_helpers.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx @@ -1,18 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ - -import './expression_reference_lines.scss'; -import React from 'react'; -import { EuiFlexGroup, EuiIcon, EuiIconProps, EuiText } from '@elastic/eui'; import { Position } from '@elastic/charts'; -import classnames from 'classnames'; -import type { IconPosition, YAxisMode, YConfig } from '../../common/expressions'; -import { hasIcon } from './xy_config_panel/shared/icon_select'; -import { annotationsIconSet } from './annotations/config_panel/icon_set'; +import type { IconPosition, YAxisMode, YConfig } from '../../common/types'; +import { hasIcon } from './icon'; export const LINES_MARKER_SIZE = 20; @@ -130,124 +125,4 @@ export function getBaseIconPlacement( return Position.Top; } -export function MarkerBody({ - label, - isHorizontal, -}: { - label: string | undefined; - isHorizontal: boolean; -}) { - if (!label) { - return null; - } - if (isHorizontal) { - return ( -
- {label} -
- ); - } - return ( -
-
- {label} -
-
- ); -} - -const isNumericalString = (value: string) => !isNaN(Number(value)); - -function NumberIcon({ number }: { number: number }) { - return ( - - - {number < 10 ? number : `9+`} - - - ); -} - -interface MarkerConfig { - axisMode?: YAxisMode; - icon?: string; - textVisibility?: boolean; - iconPosition?: IconPosition; -} - -export const AnnotationIcon = ({ - type, - rotateClassName = '', - isHorizontal, - renderedInChart, - ...rest -}: { - type: string; - rotateClassName?: string; - isHorizontal?: boolean; - renderedInChart?: boolean; -} & EuiIconProps) => { - if (isNumericalString(type)) { - return ; - } - const iconConfig = annotationsIconSet.find((i) => i.value === type); - if (!iconConfig) { - return null; - } - return ( - - ); -}; - -export function Marker({ - config, - isHorizontal, - hasReducedPadding, - label, - rotateClassName, -}: { - config: MarkerConfig; - isHorizontal: boolean; - hasReducedPadding: boolean; - label?: string; - rotateClassName?: string; -}) { - if (hasIcon(config.icon)) { - return ( - - ); - } - - // if there's some text, check whether to show it as marker, or just show some padding for the icon - if (config.textVisibility) { - if (hasReducedPadding) { - return ; - } - return ; - } - return null; -} +export const isNumericalString = (value: string) => !isNaN(Number(value)); diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/annotations_icon_set.tsx b/src/plugins/chart_expressions/expression_xy/public/helpers/annotations_icon_set.tsx new file mode 100644 index 0000000000000..99b4648e4d556 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/annotations_icon_set.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; +import { TriangleIcon, CircleIcon } from '../icons'; + +export const annotationsIconSet = [ + { + value: 'asterisk', + label: i18n.translate('expressionXY.xyChart.iconSelect.asteriskIconLabel', { + defaultMessage: 'Asterisk', + }), + }, + { + value: 'alert', + label: i18n.translate('expressionXY.xyChart.iconSelect.alertIconLabel', { + defaultMessage: 'Alert', + }), + }, + { + value: 'bell', + label: i18n.translate('expressionXY.xyChart.iconSelect.bellIconLabel', { + defaultMessage: 'Bell', + }), + }, + { + value: 'bolt', + label: i18n.translate('expressionXY.xyChart.iconSelect.boltIconLabel', { + defaultMessage: 'Bolt', + }), + }, + { + value: 'bug', + label: i18n.translate('expressionXY.xyChart.iconSelect.bugIconLabel', { + defaultMessage: 'Bug', + }), + }, + { + value: 'circle', + label: i18n.translate('expressionXY.xyChart.iconSelect.circleIconLabel', { + defaultMessage: 'Circle', + }), + icon: CircleIcon, + canFill: true, + }, + + { + value: 'editorComment', + label: i18n.translate('expressionXY.xyChart.iconSelect.commentIconLabel', { + defaultMessage: 'Comment', + }), + }, + { + value: 'flag', + label: i18n.translate('expressionXY.xyChart.iconSelect.flagIconLabel', { + defaultMessage: 'Flag', + }), + }, + { + value: 'heart', + label: i18n.translate('expressionXY.xyChart.iconSelect.heartLabel', { + defaultMessage: 'Heart', + }), + }, + { + value: 'mapMarker', + label: i18n.translate('expressionXY.xyChart.iconSelect.mapMarkerLabel', { + defaultMessage: 'Map Marker', + }), + }, + { + value: 'pinFilled', + label: i18n.translate('expressionXY.xyChart.iconSelect.mapPinLabel', { + defaultMessage: 'Map Pin', + }), + }, + { + value: 'starEmpty', + label: i18n.translate('expressionXY.xyChart.iconSelect.starLabel', { defaultMessage: 'Star' }), + }, + { + value: 'tag', + label: i18n.translate('expressionXY.xyChart.iconSelect.tagIconLabel', { + defaultMessage: 'Tag', + }), + }, + { + value: 'triangle', + label: i18n.translate('expressionXY.xyChart.iconSelect.triangleIconLabel', { + defaultMessage: 'Triangle', + }), + icon: TriangleIcon, + shouldRotate: true, + canFill: true, + }, +]; diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.test.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.test.ts new file mode 100644 index 0000000000000..201b0198087da --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.test.ts @@ -0,0 +1,334 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { DataLayerConfigResult } from '../../common'; +import { LayerTypes } from '../../common/constants'; +import { Datatable } from '../../../../../plugins/expressions/public'; +import { getAxesConfiguration } from './axes_configuration'; + +describe('axes_configuration', () => { + const tables: Record = { + first: { + type: 'datatable', + rows: [ + { + xAccessorId: 1585758120000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585758360000, + splitAccessorId: "Women's Accessories", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585758360000, + splitAccessorId: "Women's Clothing", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585759380000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585759380000, + splitAccessorId: "Men's Shoes", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585759380000, + splitAccessorId: "Women's Clothing", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585760700000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585760760000, + splitAccessorId: "Men's Clothing", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585760760000, + splitAccessorId: "Men's Shoes", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + { + xAccessorId: 1585761120000, + splitAccessorId: "Men's Shoes", + yAccessorId: 1, + yAccessorId2: 1, + yAccessorId3: 1, + yAccessorId4: 4, + }, + ], + columns: [ + { + id: 'xAccessorId', + name: 'order_date per minute', + meta: { + type: 'date', + field: 'order_date', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'date_histogram', + params: { + field: 'order_date', + timeRange: { from: '2020-04-01T16:14:16.246Z', to: '2020-04-01T17:15:41.263Z' }, + useNormalizedEsInterval: true, + scaleMetricValues: false, + interval: '1m', + drop_partials: false, + min_doc_count: 0, + extended_bounds: {}, + }, + }, + params: { params: { id: 'date', params: { pattern: 'HH:mm' } } }, + }, + }, + { + id: 'splitAccessorId', + name: 'Top values of category.keyword', + meta: { + type: 'string', + field: 'category.keyword', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'terms', + params: { + field: 'category.keyword', + orderBy: 'yAccessorId', + order: 'desc', + size: 3, + otherBucket: false, + otherBucketLabel: 'Other', + missingBucket: false, + missingBucketLabel: 'Missing', + }, + }, + params: { + id: 'terms', + params: { + id: 'string', + otherBucketLabel: 'Other', + missingBucketLabel: 'Missing', + parsedUrl: { + origin: 'http://localhost:5601', + pathname: '/jiy/app/kibana', + basePath: '/jiy', + }, + }, + }, + }, + }, + { + id: 'yAccessorId', + name: 'Count of records', + meta: { + type: 'number', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'count', + }, + params: { id: 'number' }, + }, + }, + { + id: 'yAccessorId2', + name: 'Other column', + meta: { + type: 'number', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'average', + }, + params: { id: 'bytes' }, + }, + }, + { + id: 'yAccessorId3', + name: 'Other column', + meta: { + type: 'number', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'average', + }, + params: { id: 'currency' }, + }, + }, + { + id: 'yAccessorId4', + name: 'Other column', + meta: { + type: 'number', + source: 'esaggs', + index: 'indexPatternId', + sourceParams: { + indexPatternId: 'indexPatternId', + type: 'average', + }, + params: { id: 'currency' }, + }, + }, + ], + }, + }; + + const sampleLayer: DataLayerConfigResult = { + type: 'dataLayer', + layerId: 'first', + layerType: LayerTypes.DATA, + seriesType: 'line', + xAccessor: 'c', + accessors: ['yAccessorId'], + splitAccessor: 'd', + columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', + xScaleType: 'ordinal', + yScaleType: 'linear', + isHistogram: false, + palette: { type: 'palette', name: 'default' }, + }; + + it('should map auto series to left axis', () => { + const formatFactory = jest.fn(); + const groups = getAxesConfiguration([sampleLayer], false, tables, formatFactory); + expect(groups.length).toEqual(1); + expect(groups[0].position).toEqual('left'); + expect(groups[0].series[0].accessor).toEqual('yAccessorId'); + expect(groups[0].series[0].layer).toEqual('first'); + }); + + it('should map auto series to right axis if formatters do not match', () => { + const formatFactory = jest.fn(); + const twoSeriesLayer = { ...sampleLayer, accessors: ['yAccessorId', 'yAccessorId2'] }; + const groups = getAxesConfiguration([twoSeriesLayer], false, tables, formatFactory); + expect(groups.length).toEqual(2); + expect(groups[0].position).toEqual('left'); + expect(groups[1].position).toEqual('right'); + expect(groups[0].series[0].accessor).toEqual('yAccessorId'); + expect(groups[1].series[0].accessor).toEqual('yAccessorId2'); + }); + + it('should map auto series to left if left and right are already filled with non-matching series', () => { + const formatFactory = jest.fn(); + const threeSeriesLayer = { + ...sampleLayer, + accessors: ['yAccessorId', 'yAccessorId2', 'yAccessorId3'], + }; + const groups = getAxesConfiguration([threeSeriesLayer], false, tables, formatFactory); + expect(groups.length).toEqual(2); + expect(groups[0].position).toEqual('left'); + expect(groups[1].position).toEqual('right'); + expect(groups[0].series[0].accessor).toEqual('yAccessorId'); + expect(groups[0].series[1].accessor).toEqual('yAccessorId3'); + expect(groups[1].series[0].accessor).toEqual('yAccessorId2'); + }); + + it('should map right series to right axis', () => { + const formatFactory = jest.fn(); + const groups = getAxesConfiguration( + [ + { + ...sampleLayer, + yConfig: [{ type: 'yConfig', forAccessor: 'yAccessorId', axisMode: 'right' }], + }, + ], + false, + tables, + formatFactory + ); + expect(groups.length).toEqual(1); + expect(groups[0].position).toEqual('right'); + expect(groups[0].series[0].accessor).toEqual('yAccessorId'); + expect(groups[0].series[0].layer).toEqual('first'); + }); + + it('should map series with matching formatters to same axis', () => { + const formatFactory = jest.fn(); + const groups = getAxesConfiguration( + [ + { + ...sampleLayer, + accessors: ['yAccessorId', 'yAccessorId3', 'yAccessorId4'], + yConfig: [{ type: 'yConfig', forAccessor: 'yAccessorId', axisMode: 'right' }], + }, + ], + false, + tables, + formatFactory + ); + expect(groups.length).toEqual(2); + expect(groups[0].position).toEqual('left'); + expect(groups[0].series[0].accessor).toEqual('yAccessorId3'); + expect(groups[0].series[1].accessor).toEqual('yAccessorId4'); + expect(groups[1].position).toEqual('right'); + expect(groups[1].series[0].accessor).toEqual('yAccessorId'); + expect(formatFactory).toHaveBeenCalledWith({ id: 'number' }); + expect(formatFactory).toHaveBeenCalledWith({ id: 'currency' }); + }); + + it('should create one formatter per series group', () => { + const formatFactory = jest.fn(); + getAxesConfiguration( + [ + { + ...sampleLayer, + accessors: ['yAccessorId', 'yAccessorId3', 'yAccessorId4'], + yConfig: [{ type: 'yConfig', forAccessor: 'yAccessorId', axisMode: 'right' }], + }, + ], + false, + tables, + formatFactory + ); + expect(formatFactory).toHaveBeenCalledTimes(2); + expect(formatFactory).toHaveBeenCalledWith({ id: 'number' }); + expect(formatFactory).toHaveBeenCalledWith({ id: 'currency' }); + }); +}); diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.ts new file mode 100644 index 0000000000000..16529ecd40e90 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/axes_configuration.ts @@ -0,0 +1,146 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { FormatFactory } from '../types'; +import { AxisExtentConfig, DataLayerConfigResult } from '../../common'; +import { Datatable } from '../../../../../plugins/expressions/public'; +import type { + IFieldFormat, + SerializedFieldFormat, +} from '../../../../../plugins/field_formats/common'; + +interface FormattedMetric { + layer: string; + accessor: string; + fieldFormat: SerializedFieldFormat; +} + +export type GroupsConfiguration = Array<{ + groupId: string; + position: 'left' | 'right' | 'bottom' | 'top'; + formatter?: IFieldFormat; + series: Array<{ layer: string; accessor: string }>; +}>; + +export function isFormatterCompatible( + formatter1: SerializedFieldFormat, + formatter2: SerializedFieldFormat +) { + return formatter1.id === formatter2.id; +} + +export function groupAxesByType( + layers: DataLayerConfigResult[], + tables?: Record +) { + const series: { + auto: FormattedMetric[]; + left: FormattedMetric[]; + right: FormattedMetric[]; + bottom: FormattedMetric[]; + } = { + auto: [], + left: [], + right: [], + bottom: [], + }; + + layers?.forEach((layer) => { + const table = tables?.[layer.layerId]; + layer.accessors.forEach((accessor) => { + const mode = + layer.yConfig?.find((yAxisConfig) => yAxisConfig.forAccessor === accessor)?.axisMode || + 'auto'; + let formatter: SerializedFieldFormat = table?.columns.find((column) => column.id === accessor) + ?.meta?.params || { id: 'number' }; + if (layer.seriesType.includes('percentage') && formatter.id !== 'percent') { + formatter = { + id: 'percent', + params: { + pattern: '0.[00]%', + }, + }; + } + series[mode].push({ + layer: layer.layerId, + accessor, + fieldFormat: formatter, + }); + }); + }); + + series.auto.forEach((currentSeries) => { + if ( + series.left.length === 0 || + (tables && + series.left.every((leftSeries) => + isFormatterCompatible(leftSeries.fieldFormat, currentSeries.fieldFormat) + )) + ) { + series.left.push(currentSeries); + } else if ( + series.right.length === 0 || + (tables && + series.left.every((leftSeries) => + isFormatterCompatible(leftSeries.fieldFormat, currentSeries.fieldFormat) + )) + ) { + series.right.push(currentSeries); + } else if (series.right.length >= series.left.length) { + series.left.push(currentSeries); + } else { + series.right.push(currentSeries); + } + }); + return series; +} + +export function getAxesConfiguration( + layers: DataLayerConfigResult[], + shouldRotate: boolean, + tables?: Record, + formatFactory?: FormatFactory +): GroupsConfiguration { + const series = groupAxesByType(layers, tables); + + const axisGroups: GroupsConfiguration = []; + + if (series.left.length > 0) { + axisGroups.push({ + groupId: 'left', + position: shouldRotate ? 'bottom' : 'left', + formatter: formatFactory?.(series.left[0].fieldFormat), + series: series.left.map(({ fieldFormat, ...currentSeries }) => currentSeries), + }); + } + + if (series.right.length > 0) { + axisGroups.push({ + groupId: 'right', + position: shouldRotate ? 'top' : 'right', + formatter: formatFactory?.(series.right[0].fieldFormat), + series: series.right.map(({ fieldFormat, ...currentSeries }) => currentSeries), + }); + } + + return axisGroups; +} + +export function validateExtent(hasBarOrArea: boolean, extent?: AxisExtentConfig) { + const inclusiveZeroError = + extent && + hasBarOrArea && + ((extent.lowerBound !== undefined && extent.lowerBound > 0) || + (extent.upperBound !== undefined && extent.upperBound) < 0); + const boundaryError = + extent && + extent.lowerBound !== undefined && + extent.upperBound !== undefined && + extent.upperBound <= extent.lowerBound; + return { inclusiveZeroError, boundaryError }; +} diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.test.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.test.ts new file mode 100644 index 0000000000000..bd13e3217c2af --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.test.ts @@ -0,0 +1,239 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { getColorAssignments } from './color_assignment'; +import type { DataLayerConfigResult, LensMultiTable } from '../../common'; +import type { FormatFactory } from '../types'; +import { LayerTypes } from '../../common/constants'; + +describe('color_assignment', () => { + const layers: DataLayerConfigResult[] = [ + { + type: 'dataLayer', + yScaleType: 'linear', + xScaleType: 'linear', + isHistogram: true, + seriesType: 'bar', + palette: { type: 'palette', name: 'palette1' }, + layerId: '1', + layerType: LayerTypes.DATA, + splitAccessor: 'split1', + accessors: ['y1', 'y2'], + }, + { + type: 'dataLayer', + yScaleType: 'linear', + xScaleType: 'linear', + isHistogram: true, + seriesType: 'bar', + palette: { type: 'palette', name: 'palette2' }, + layerId: '2', + layerType: LayerTypes.DATA, + splitAccessor: 'split2', + accessors: ['y3', 'y4'], + }, + ]; + + const data: LensMultiTable = { + type: 'lens_multitable', + tables: { + '1': { + type: 'datatable', + columns: [ + { id: 'split1', name: '', meta: { type: 'number' } }, + { id: 'y1', name: '', meta: { type: 'number' } }, + { id: 'y2', name: '', meta: { type: 'number' } }, + ], + rows: [ + { split1: 1 }, + { split1: 2 }, + { split1: 3 }, + { split1: 1 }, + { split1: 2 }, + { split1: 3 }, + ], + }, + '2': { + type: 'datatable', + columns: [ + { id: 'split2', name: '', meta: { type: 'number' } }, + { id: 'y1', name: '', meta: { type: 'number' } }, + { id: 'y2', name: '', meta: { type: 'number' } }, + ], + rows: [ + { split2: 1 }, + { split2: 2 }, + { split2: 3 }, + { split2: 1 }, + { split2: 2 }, + { split2: 3 }, + ], + }, + }, + }; + + const formatFactory = (() => + ({ + convert(x: unknown) { + return x; + }, + } as unknown)) as FormatFactory; + + describe('totalSeriesCount', () => { + it('should calculate total number of series per palette', () => { + const assignments = getColorAssignments(layers, data, formatFactory); + // two y accessors, with 3 splitted series + expect(assignments.palette1.totalSeriesCount).toEqual(2 * 3); + expect(assignments.palette2.totalSeriesCount).toEqual(2 * 3); + }); + + it('should calculate total number of series spanning multible layers', () => { + const assignments = getColorAssignments( + [layers[0], { ...layers[1], palette: layers[0].palette }], + data, + formatFactory + ); + // two y accessors, with 3 splitted series, two times + expect(assignments.palette1.totalSeriesCount).toEqual(2 * 3 + 2 * 3); + expect(assignments.palette2).toBeUndefined(); + }); + + it('should calculate total number of series for non split series', () => { + const assignments = getColorAssignments( + [layers[0], { ...layers[1], palette: layers[0].palette, splitAccessor: undefined }], + data, + formatFactory + ); + // two y accessors, with 3 splitted series for the first layer, 2 non splitted y accessors for the second layer + expect(assignments.palette1.totalSeriesCount).toEqual(2 * 3 + 2); + expect(assignments.palette2).toBeUndefined(); + }); + + it('should format non-primitive values and count them correctly', () => { + const complexObject = { aProp: 123 }; + const formatMock = jest.fn((x) => 'formatted'); + const assignments = getColorAssignments( + layers, + { + ...data, + tables: { + ...data.tables, + '1': { ...data.tables['1'], rows: [{ split1: complexObject }, { split1: 'abc' }] }, + }, + }, + (() => + ({ + convert: formatMock, + } as unknown)) as FormatFactory + ); + expect(assignments.palette1.totalSeriesCount).toEqual(2 * 2); + expect(assignments.palette2.totalSeriesCount).toEqual(2 * 3); + expect(formatMock).toHaveBeenCalledWith(complexObject); + }); + + it('should handle missing tables', () => { + const assignments = getColorAssignments(layers, { ...data, tables: {} }, formatFactory); + // if there is no data, just assume a single split + expect(assignments.palette1.totalSeriesCount).toEqual(2); + }); + + it('should handle missing columns', () => { + const assignments = getColorAssignments( + layers, + { + ...data, + tables: { + ...data.tables, + '1': { + ...data.tables['1'], + columns: [], + }, + }, + }, + formatFactory + ); + // if the split column is missing, just assume a single split + expect(assignments.palette1.totalSeriesCount).toEqual(2); + }); + }); + + describe('getRank', () => { + it('should return the correct rank for a series key', () => { + const assignments = getColorAssignments(layers, data, formatFactory); + // 3 series in front of 2/y2 - 1/y1, 1/y2 and 2/y1 + expect(assignments.palette1.getRank(layers[0], '2', 'y2')).toEqual(3); + // 1 series in front of 1/y4 - 1/y3 + expect(assignments.palette2.getRank(layers[1], '1', 'y4')).toEqual(1); + }); + + it('should return the correct rank for a series key spanning multiple layers', () => { + const newLayers = [layers[0], { ...layers[1], palette: layers[0].palette }]; + const assignments = getColorAssignments(newLayers, data, formatFactory); + // 3 series in front of 2/y2 - 1/y1, 1/y2 and 2/y1 + expect(assignments.palette1.getRank(newLayers[0], '2', 'y2')).toEqual(3); + // 2 series in front for the current layer (1/y3, 1/y4), plus all 6 series from the first layer + expect(assignments.palette1.getRank(newLayers[1], '2', 'y3')).toEqual(8); + }); + + it('should return the correct rank for a series without a split', () => { + const newLayers = [ + layers[0], + { ...layers[1], palette: layers[0].palette, splitAccessor: undefined }, + ]; + const assignments = getColorAssignments(newLayers, data, formatFactory); + // 3 series in front of 2/y2 - 1/y1, 1/y2 and 2/y1 + expect(assignments.palette1.getRank(newLayers[0], '2', 'y2')).toEqual(3); + // 1 series in front for the current layer (y3), plus all 6 series from the first layer + expect(assignments.palette1.getRank(newLayers[1], 'Metric y4', 'y4')).toEqual(7); + }); + + it('should return the correct rank for a series with a non-primitive value', () => { + const assignments = getColorAssignments( + layers, + { + ...data, + tables: { + ...data.tables, + '1': { ...data.tables['1'], rows: [{ split1: 'abc' }, { split1: { aProp: 123 } }] }, + }, + }, + (() => + ({ + convert: () => 'formatted', + } as unknown)) as FormatFactory + ); + // 3 series in front of (complex object)/y1 - abc/y1, abc/y2 + expect(assignments.palette1.getRank(layers[0], 'formatted', 'y1')).toEqual(2); + }); + + it('should handle missing tables', () => { + const assignments = getColorAssignments(layers, { ...data, tables: {} }, formatFactory); + // if there is no data, assume it is the first splitted series. One series in front - 0/y1 + expect(assignments.palette1.getRank(layers[0], '2', 'y2')).toEqual(1); + }); + + it('should handle missing columns', () => { + const assignments = getColorAssignments( + layers, + { + ...data, + tables: { + ...data.tables, + '1': { + ...data.tables['1'], + columns: [], + }, + }, + }, + formatFactory + ); + // if the split column is missing, assume it is the first splitted series. One series in front - 0/y1 + expect(assignments.palette1.getRank(layers[0], '2', 'y2')).toEqual(1); + }); + }); +}); diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.ts new file mode 100644 index 0000000000000..ef0cd36e3598e --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/color_assignment.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { uniq, mapValues } from 'lodash'; +import { euiLightVars } from '@kbn/ui-theme'; +import type { Datatable } from '../../../../expressions'; +import { FormatFactory } from '../types'; +import { isDataLayer } from './visualization'; +import { DataLayerConfigResult, XYLayerConfigResult } from '../../common'; + +const isPrimitive = (value: unknown): boolean => value != null && typeof value !== 'object'; + +export const defaultReferenceLineColor = euiLightVars.euiColorDarkShade; + +export type ColorAssignments = Record< + string, + { + totalSeriesCount: number; + getRank(sortedLayer: DataLayerConfigResult, seriesKey: string, yAccessor: string): number; + } +>; + +export function getColorAssignments( + layers: XYLayerConfigResult[], + data: { tables: Record }, + formatFactory: FormatFactory +): ColorAssignments { + const layersPerPalette: Record = {}; + + layers + .filter((layer): layer is DataLayerConfigResult => isDataLayer(layer)) + .forEach((layer) => { + const palette = layer.palette?.name || 'default'; + if (!layersPerPalette[palette]) { + layersPerPalette[palette] = []; + } + layersPerPalette[palette].push(layer); + }); + + return mapValues(layersPerPalette, (paletteLayers) => { + const seriesPerLayer = paletteLayers.map((layer, layerIndex) => { + if (!layer.splitAccessor) { + return { numberOfSeries: layer.accessors.length, splits: [] }; + } + const splitAccessor = layer.splitAccessor; + const column = data.tables[layer.layerId]?.columns.find(({ id }) => id === splitAccessor); + const columnFormatter = column && formatFactory(column.meta.params); + const splits = + !column || !data.tables[layer.layerId] + ? [] + : uniq( + data.tables[layer.layerId].rows.map((row) => { + let value = row[splitAccessor]; + if (value && !isPrimitive(value)) { + value = columnFormatter?.convert(value) ?? value; + } else { + value = String(value); + } + return value; + }) + ); + return { numberOfSeries: (splits.length || 1) * layer.accessors.length, splits }; + }); + const totalSeriesCount = seriesPerLayer.reduce( + (sum, perLayer) => sum + perLayer.numberOfSeries, + 0 + ); + return { + totalSeriesCount, + getRank(sortedLayer: DataLayerConfigResult, seriesKey: string, yAccessor: string) { + const layerIndex = paletteLayers.findIndex((l) => sortedLayer.layerId === l.layerId); + const currentSeriesPerLayer = seriesPerLayer[layerIndex]; + const splitRank = currentSeriesPerLayer.splits.indexOf(seriesKey); + return ( + (layerIndex === 0 + ? 0 + : seriesPerLayer + .slice(0, layerIndex) + .reduce((sum, perLayer) => sum + perLayer.numberOfSeries, 0)) + + (sortedLayer.splitAccessor && splitRank !== -1 + ? splitRank * sortedLayer.accessors.length + : 0) + + sortedLayer.accessors.indexOf(yAccessor) + ); + }, + }; + }); +} diff --git a/x-pack/plugins/lens/public/xy_visualization/fitting_functions.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/fitting_functions.ts similarity index 74% rename from x-pack/plugins/lens/public/xy_visualization/fitting_functions.ts rename to src/plugins/chart_expressions/expression_xy/public/helpers/fitting_functions.ts index 63a3b308d8ae8..43d5ad9b4c19f 100644 --- a/x-pack/plugins/lens/public/xy_visualization/fitting_functions.ts +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/fitting_functions.ts @@ -1,12 +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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. */ import { Fit } from '@elastic/charts'; -import { EndValue, FittingFunction } from '../../common/expressions'; +import { EndValue, FittingFunction } from '../../common'; export function getFitEnum(fittingFunction?: FittingFunction | EndValue) { if (fittingFunction) { diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/icon.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/icon.ts new file mode 100644 index 0000000000000..57e285a07232f --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/icon.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export function hasIcon(icon: string | undefined): icon is string { + return icon != null && icon !== 'empty'; +} diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/index.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/index.ts new file mode 100644 index 0000000000000..cb0300e47ae70 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/index.ts @@ -0,0 +1,19 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export * from './interval'; +export * from './layers'; +export * from './state'; +export * from './visualization'; +export * from './fitting_functions'; +export * from './axes_configuration'; +export * from './reference_lines'; +export * from './icon'; +export * from './color_assignment'; +export * from './annotations_icon_set'; +export * from './annotations'; diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/interval.test.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/interval.test.ts new file mode 100644 index 0000000000000..0fe979b8c3fc1 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/interval.test.ts @@ -0,0 +1,80 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { DataLayerConfigResult, XYChartProps } from '../../common'; +import { sampleArgs } from '../../common/__mocks__'; +import { calculateMinInterval } from './interval'; + +describe('calculateMinInterval', () => { + let xyProps: XYChartProps; + + beforeEach(() => { + xyProps = sampleArgs(); + (xyProps.args.layers[0] as DataLayerConfigResult).xScaleType = 'time'; + }); + it('should use first valid layer and determine interval', async () => { + xyProps.data.tables.first.columns[2].meta.source = 'esaggs'; + xyProps.data.tables.first.columns[2].meta.sourceParams = { + type: 'date_histogram', + params: { + used_interval: '5m', + }, + }; + const result = await calculateMinInterval(xyProps); + expect(result).toEqual(5 * 60 * 1000); + }); + + it('should return interval of number histogram if available on first x axis columns', async () => { + (xyProps.args.layers[0] as DataLayerConfigResult).xScaleType = 'linear'; + xyProps.data.tables.first.columns[2].meta = { + source: 'esaggs', + type: 'number', + field: 'someField', + sourceParams: { + type: 'histogram', + params: { + interval: 'auto', + used_interval: 5, + }, + }, + }; + const result = await calculateMinInterval(xyProps); + expect(result).toEqual(5); + }); + + it('should return undefined if data table is empty', async () => { + xyProps.data.tables.first.rows = []; + xyProps.data.tables.first.columns[2].meta.source = 'esaggs'; + xyProps.data.tables.first.columns[2].meta.sourceParams = { + type: 'date_histogram', + params: { + used_interval: '5m', + }, + }; + const result = await calculateMinInterval(xyProps); + expect(result).toEqual(undefined); + }); + + it('should return undefined if interval can not be checked', async () => { + const result = await calculateMinInterval(xyProps); + expect(result).toEqual(undefined); + }); + + it('should return undefined if date column is not found', async () => { + xyProps.data.tables.first.columns.splice(2, 1); + const result = await calculateMinInterval(xyProps); + expect(result).toEqual(undefined); + }); + + it('should return undefined if x axis is not a date', async () => { + (xyProps.args.layers[0] as DataLayerConfigResult).xScaleType = 'ordinal'; + xyProps.data.tables.first.columns.splice(2, 1); + const result = await calculateMinInterval(xyProps); + expect(result).toEqual(undefined); + }); +}); diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/interval.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/interval.ts new file mode 100644 index 0000000000000..7e15b49c311d4 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/interval.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { search } from '../../../../data/public'; +import { XYChartProps } from '../../common'; +import { getFilteredLayers } from './layers'; +import { isDataLayer } from './visualization'; + +export function calculateMinInterval({ args: { layers }, data }: XYChartProps) { + const filteredLayers = getFilteredLayers(layers, data); + if (filteredLayers.length === 0) return; + const isTimeViz = filteredLayers.every((l) => isDataLayer(l) && l.xScaleType === 'time'); + const xColumn = data.tables[filteredLayers[0].layerId].columns.find( + (column) => isDataLayer(filteredLayers[0]) && column.id === filteredLayers[0].xAccessor + ); + + if (!xColumn) return; + if (!isTimeViz) { + const histogramInterval = search.aggs.getNumberHistogramIntervalByDatatableColumn(xColumn); + if (typeof histogramInterval === 'number') { + return histogramInterval; + } else { + return undefined; + } + } + const dateInterval = search.aggs.getDateHistogramMetaDataByDatatableColumn(xColumn)?.interval; + if (!dateInterval) return; + const intervalDuration = search.aggs.parseInterval(dateInterval); + if (!intervalDuration) return; + return intervalDuration.as('milliseconds'); +} diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/layers.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/layers.ts new file mode 100644 index 0000000000000..be1701e6b6e4b --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/layers.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { LensMultiTable } from '../../common'; +import { DataLayerConfigResult, XYLayerConfigResult } from '../../common/types'; +import { getDataLayers } from './visualization'; + +export function getFilteredLayers(layers: XYLayerConfigResult[], data: LensMultiTable) { + return getDataLayers(layers).filter( + (layer): layer is DataLayerConfigResult => { + const { layerId, xAccessor, accessors, splitAccessor } = layer; + return !( + !accessors.length || + !data.tables[layerId] || + data.tables[layerId].rows.length === 0 || + (xAccessor && + data.tables[layerId].rows.every((row) => typeof row[xAccessor] === 'undefined')) || + // stacked percentage bars have no xAccessors but splitAccessor with undefined values in them when empty + (!xAccessor && + splitAccessor && + data.tables[layerId].rows.every((row) => typeof row[splitAccessor] === 'undefined')) + ); + } + ); +} diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/reference_lines.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/reference_lines.ts new file mode 100644 index 0000000000000..35419c3a40558 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/reference_lines.ts @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { partition } from 'lodash'; +import { Datatable } from '../../../../expressions'; +import type { DataLayerConfigResult } from '../../common'; +import { isStackedChart } from './state'; + +export function computeOverallDataDomain( + dataLayers: DataLayerConfigResult[], + accessorIds: string[], + activeData: Record, + allowStacking: boolean = true +) { + const accessorMap = new Set(accessorIds); + let min: number | undefined; + let max: number | undefined; + const [stacked, unstacked] = partition( + dataLayers, + ({ seriesType }) => isStackedChart(seriesType) && allowStacking + ); + for (const { layerId, accessors } of unstacked) { + const table = activeData[layerId]; + if (table) { + for (const accessor of accessors) { + if (accessorMap.has(accessor)) { + for (const row of table.rows) { + const value = row[accessor]; + if (typeof value === 'number') { + // when not stacked, do not keep the 0 + max = max != null ? Math.max(value, max) : value; + min = min != null ? Math.min(value, min) : value; + } + } + } + } + } + } + // stacked can span multiple layers, so compute an overall max/min by bucket + const stackedResults: Record = {}; + for (const { layerId, accessors, xAccessor } of stacked) { + const table = activeData[layerId]; + if (table) { + for (const accessor of accessors) { + if (accessorMap.has(accessor)) { + for (const row of table.rows) { + const value = row[accessor]; + // start with a shared bucket + let bucket = 'shared'; + // but if there's an xAccessor use it as new bucket system + if (xAccessor) { + bucket = row[xAccessor]; + } + if (typeof value === 'number') { + stackedResults[bucket] = stackedResults[bucket] ?? 0; + stackedResults[bucket] += value; + } + } + } + } + } + } + + for (const value of Object.values(stackedResults)) { + // for stacked extents keep 0 in view + max = Math.max(value, max || 0, 0); + min = Math.min(value, min || 0, 0); + } + + return { min, max }; +} diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/state.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/state.ts new file mode 100644 index 0000000000000..a5cd66f178b63 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/state.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import type { SeriesType, XYLayerConfigResult, YConfig } from '../../common'; +import { getDataLayers, isAnnotationsLayer, isDataLayer } from './visualization'; + +export function isHorizontalSeries(seriesType: SeriesType) { + return ( + seriesType === 'bar_horizontal' || + seriesType === 'bar_horizontal_stacked' || + seriesType === 'bar_horizontal_percentage_stacked' + ); +} + +export function isStackedChart(seriesType: SeriesType) { + return seriesType.includes('stacked'); +} + +export function isHorizontalChart(layers: XYLayerConfigResult[]) { + return getDataLayers(layers).every((l) => isHorizontalSeries(l.seriesType)); +} + +export const getSeriesColor = (layer: XYLayerConfigResult, accessor: string) => { + if ((isDataLayer(layer) && layer.splitAccessor) || isAnnotationsLayer(layer)) { + return null; + } + + return ( + layer?.yConfig?.find((yConfig: YConfig) => yConfig.forAccessor === accessor)?.color || null + ); +}; diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/visualization.ts b/src/plugins/chart_expressions/expression_xy/public/helpers/visualization.ts new file mode 100644 index 0000000000000..af2e80948ffdf --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/visualization.ts @@ -0,0 +1,43 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { + DataLayerConfigResult, + ReferenceLineLayerConfigResult, + XYLayerConfigResult, + AnnotationLayerConfigResult, +} from '../../common/types'; +import { LayerTypes } from '../../common/constants'; + +export const isDataLayer = (layer: XYLayerConfigResult): layer is DataLayerConfigResult => + layer.layerType === LayerTypes.DATA || !layer.layerType; + +export const getDataLayers = (layers: XYLayerConfigResult[]) => + (layers || []).filter((layer): layer is DataLayerConfigResult => isDataLayer(layer)); + +export const isReferenceLayer = ( + layer: XYLayerConfigResult +): layer is ReferenceLineLayerConfigResult => layer.layerType === LayerTypes.REFERENCELINE; + +export const getReferenceLayers = (layers: XYLayerConfigResult[]) => + (layers || []).filter((layer): layer is ReferenceLineLayerConfigResult => + isReferenceLayer(layer) + ); + +const isAnnotationLayerCommon = ( + layer: XYLayerConfigResult +): layer is AnnotationLayerConfigResult => layer.layerType === LayerTypes.ANNOTATIONS; + +export const isAnnotationsLayer = ( + layer: XYLayerConfigResult +): layer is AnnotationLayerConfigResult => isAnnotationLayerCommon(layer); + +export const getAnnotationsLayers = ( + layers: XYLayerConfigResult[] +): AnnotationLayerConfigResult[] => + (layers || []).filter((layer): layer is AnnotationLayerConfigResult => isAnnotationsLayer(layer)); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/area.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/area.tsx new file mode 100644 index 0000000000000..010ffaf1fb7ec --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/area.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const AreaIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/area_percentage.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/area_percentage.tsx new file mode 100644 index 0000000000000..a51e66b68ba93 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/area_percentage.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const AreaPercentageIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/area_stacked.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/area_stacked.tsx new file mode 100644 index 0000000000000..c2b9fbe926328 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/area_stacked.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const AreaStackedIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar.tsx new file mode 100644 index 0000000000000..f134d7871bfde --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal.tsx new file mode 100644 index 0000000000000..a2fb843cb095d --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarHorizontalIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_percentage.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_percentage.tsx new file mode 100644 index 0000000000000..6b2bb61a246e1 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_percentage.tsx @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarHorizontalPercentageIcon = ({ + title, + titleId, + ...props +}: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_stacked.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_stacked.tsx new file mode 100644 index 0000000000000..b399c47d3fc7d --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar_horizontal_stacked.tsx @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarHorizontalStackedIcon = ({ + title, + titleId, + ...props +}: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar_percentage.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar_percentage.tsx new file mode 100644 index 0000000000000..64514cea6c012 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar_percentage.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarPercentageIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar_reference_line.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar_reference_line.tsx new file mode 100644 index 0000000000000..95bd8e2a8d0a2 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar_reference_line.tsx @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarReferenceLineIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/bar_stacked.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/bar_stacked.tsx new file mode 100644 index 0000000000000..833f3d0e816e6 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/bar_stacked.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const BarStackedIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/circle.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/circle.tsx new file mode 100644 index 0000000000000..39bbe5cde74de --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/circle.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; +import classnames from 'classnames'; + +export const CircleIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/index.ts b/src/plugins/chart_expressions/expression_xy/public/icons/index.ts new file mode 100644 index 0000000000000..4ca0b640a3d89 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/index.ts @@ -0,0 +1,22 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export { BarHorizontalPercentageIcon } from './bar_horizontal_percentage'; +export { BarHorizontalStackedIcon } from './bar_horizontal_stacked'; +export { BarReferenceLineIcon } from './bar_reference_line'; +export { AreaPercentageIcon } from './area_percentage'; +export { BarHorizontalIcon } from './bar_horizontal'; +export { BarPercentageIcon } from './bar_percentage'; +export { AreaStackedIcon } from './area_stacked'; +export { BarStackedIcon } from './bar_stacked'; +export { TriangleIcon } from './triangle'; +export { MixedXyIcon } from './mixed_xy'; +export { CircleIcon } from './circle'; +export { AreaIcon } from './area'; +export { LineIcon } from './line'; +export { BarIcon } from './bar'; diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/line.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/line.tsx new file mode 100644 index 0000000000000..6735f58b734ec --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/line.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const LineIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/mixed_xy.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/mixed_xy.tsx new file mode 100644 index 0000000000000..e16b7f6bed76f --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/mixed_xy.tsx @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; + +export const MixedXyIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/icons/triangle.tsx b/src/plugins/chart_expressions/expression_xy/public/icons/triangle.tsx new file mode 100644 index 0000000000000..8ffb8c490d9a4 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/icons/triangle.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React from 'react'; +import { EuiIconProps } from '@elastic/eui'; +import classnames from 'classnames'; + +export const TriangleIcon = ({ title, titleId, ...props }: Omit) => ( + + {title ? {title} : null} + + +); diff --git a/src/plugins/chart_expressions/expression_xy/public/index.ts b/src/plugins/chart_expressions/expression_xy/public/index.ts new file mode 100755 index 0000000000000..d9447400aa266 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { ExpressionXyPlugin } from './plugin'; + +// This exports static code and TypeScript types, +// as well as, Kibana Platform `plugin()` initializer. +export function plugin() { + return new ExpressionXyPlugin(); +} + +export type { ExpressionXyPluginSetup, ExpressionXyPluginStart } from './types'; diff --git a/src/plugins/chart_expressions/expression_xy/public/plugin.ts b/src/plugins/chart_expressions/expression_xy/public/plugin.ts new file mode 100755 index 0000000000000..c43e3aae11de7 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/plugin.ts @@ -0,0 +1,99 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import moment from 'moment'; +import { LEGACY_TIME_AXIS } from '../../../charts/common'; +import { DataPublicPluginStart } from '../../../data/public'; +import { FieldFormatsStart } from '../../../field_formats/public'; +import { ChartsPluginStart } from '../../../charts/public'; +import { CoreSetup, CoreStart, IUiSettingsClient } from '../../../../core/public'; +import { ExpressionXyPluginSetup, ExpressionXyPluginStart, SetupDeps } from './types'; +import { + xyVisFunction, + yAxisConfigFunction, + legendConfigFunction, + gridlinesConfigFunction, + dataLayerConfigFunction, + axisExtentConfigFunction, + tickLabelsConfigFunction, + annotationLayerConfigFunction, + labelsOrientationConfigFunction, + referenceLineLayerConfigFunction, + axisTitlesVisibilityConfigFunction, +} from '../common'; +import { GetStartDepsFn, getXyChartRenderer } from './expression_renderers'; +import { EventAnnotationPluginSetup } from '../../../event_annotation/public'; + +export interface XYPluginStartDependencies { + data: DataPublicPluginStart; + fieldFormats: FieldFormatsStart; + charts: ChartsPluginStart; + eventAnnotation: EventAnnotationPluginSetup; +} + +export function getTimeZone(uiSettings: IUiSettingsClient) { + const configuredTimeZone = uiSettings.get('dateFormat:tz'); + if (configuredTimeZone === 'Browser') { + return moment.tz.guess(); + } + + return configuredTimeZone; +} + +export class ExpressionXyPlugin { + public setup( + core: CoreSetup, + { expressions, charts }: SetupDeps + ): ExpressionXyPluginSetup { + expressions.registerFunction(yAxisConfigFunction); + expressions.registerFunction(legendConfigFunction); + expressions.registerFunction(gridlinesConfigFunction); + expressions.registerFunction(dataLayerConfigFunction); + expressions.registerFunction(axisExtentConfigFunction); + expressions.registerFunction(tickLabelsConfigFunction); + expressions.registerFunction(annotationLayerConfigFunction); + expressions.registerFunction(labelsOrientationConfigFunction); + expressions.registerFunction(referenceLineLayerConfigFunction); + expressions.registerFunction(axisTitlesVisibilityConfigFunction); + expressions.registerFunction(xyVisFunction); + + const getStartDeps: GetStartDepsFn = async () => { + const [coreStart, deps] = await core.getStartServices(); + const { + data, + fieldFormats, + eventAnnotation, + charts: { activeCursor, theme, palettes }, + } = deps; + + const paletteService = await palettes.getPalettes(); + + const { theme: kibanaTheme } = coreStart; + const eventAnnotationService = await eventAnnotation.getService(); + const useLegacyTimeAxis = core.uiSettings.get(LEGACY_TIME_AXIS); + + return { + data, + formatFactory: fieldFormats.deserialize, + kibanaTheme, + theme, + activeCursor, + paletteService, + useLegacyTimeAxis, + eventAnnotationService, + timeZone: getTimeZone(core.uiSettings), + }; + }; + + expressions.registerRenderer(getXyChartRenderer({ getStartDeps })); + } + + public start(core: CoreStart): ExpressionXyPluginStart {} + + public stop() {} +} diff --git a/src/plugins/chart_expressions/expression_xy/public/types.ts b/src/plugins/chart_expressions/expression_xy/public/types.ts new file mode 100755 index 0000000000000..36b8f4c13a776 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/public/types.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { IconType } from '@elastic/eui'; +import { DataPublicPluginSetup } from '../../../data/public'; +import { FieldFormatsSetup } from '../../../field_formats/public'; +import { ChartsPluginSetup } from '../../../charts/public'; +import { IFieldFormat, SerializedFieldFormat } from '../../../../plugins/field_formats/common'; +import type { RangeSelectContext, ValueClickContext } from '../../../../plugins/embeddable/public'; +import { ExpressionsServiceStart, ExpressionsSetup } from '../../../expressions/public'; + +export interface SetupDeps { + expressions: ExpressionsSetup; + data: DataPublicPluginSetup; + fieldFormats: FieldFormatsSetup; + charts: ChartsPluginSetup; +} + +export interface StartDeps { + expression: ExpressionsServiceStart; +} + +export type ExpressionXyPluginSetup = void; +export type ExpressionXyPluginStart = void; + +export interface FilterEvent { + name: 'filter'; + data: ValueClickContext['data']; +} + +export interface BrushEvent { + name: 'brush'; + data: RangeSelectContext['data']; +} + +export type FormatFactory = (mapping?: SerializedFieldFormat) => IFieldFormat; + +export interface OperationDescriptor extends Operation { + hasTimeShift: boolean; +} + +export type SortingHint = 'version'; +export type FieldOnlyDataType = 'document' | 'ip' | 'histogram' | 'geo_point' | 'geo_shape'; +export type DataType = 'string' | 'number' | 'date' | 'boolean' | FieldOnlyDataType; + +export interface OperationMetadata { + // The output of this operation will have this data type + dataType: DataType; + // A bucketed operation is grouped by duplicate values, otherwise each row is + // treated as unique + isBucketed: boolean; + /** + * ordinal: Each name is a unique value, but the names are in sorted order, like "Top values" + * interval: Histogram data, like date or number histograms + * ratio: Most number data is rendered as a ratio that includes 0 + */ + scale?: 'ordinal' | 'interval' | 'ratio'; + // Extra meta-information like cardinality, color + // TODO currently it's not possible to differentiate between a field from a raw + // document and an aggregated metric which might be handy in some cases. Once we + // introduce a raw document datasource, this should be considered here. + isStaticValue?: boolean; +} + +export interface Operation extends OperationMetadata { + // User-facing label for the operation + label: string; + sortingHint?: SortingHint; +} + +/** + * A visualization type advertised to the user in the chart switcher + */ +export interface VisualizationType { + /** + * Unique id of the visualization type within the visualization defining it + */ + id: string; + /** + * Icon used in the chart switcher + */ + icon: IconType; + /** + * Visible label used in the chart switcher and above the workspace panel in collapsed state + */ + label: string; + /** + * Optional label used in visualization type search if chart switcher is expanded and for tooltips + */ + fullLabel?: string; + /** + * The group the visualization belongs to + */ + groupLabel: string; + /** + * The priority of the visualization in the list (global priority) + * Higher number means higher priority. When omitted defaults to 0 + */ + sortPriority?: number; + /** + * Indicates if visualization is in the experimental stage. + */ + showExperimentalBadge?: boolean; +} + +export interface AccessorConfig { + columnId: string; + triggerIcon?: 'color' | 'disabled' | 'colorBy' | 'none' | 'invisible'; + color?: string; + palette?: string[] | Array<{ color: string; stop: number }>; +} diff --git a/src/plugins/chart_expressions/expression_xy/server/index.ts b/src/plugins/chart_expressions/expression_xy/server/index.ts new file mode 100755 index 0000000000000..e529b2a15fe34 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/server/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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { ExpressionXyPlugin } from './plugin'; + +export function plugin() { + return new ExpressionXyPlugin(); +} + +export type { ExpressionXyPluginSetup, ExpressionXyPluginStart } from './types'; diff --git a/src/plugins/chart_expressions/expression_xy/server/plugin.ts b/src/plugins/chart_expressions/expression_xy/server/plugin.ts new file mode 100755 index 0000000000000..ff979fd38e1c6 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/server/plugin.ts @@ -0,0 +1,47 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { CoreSetup, CoreStart, Plugin } from '../../../../core/server'; + +import { ExpressionXyPluginSetup, ExpressionXyPluginStart } from './types'; +import { + xyVisFunction, + yAxisConfigFunction, + legendConfigFunction, + gridlinesConfigFunction, + dataLayerConfigFunction, + axisExtentConfigFunction, + tickLabelsConfigFunction, + annotationLayerConfigFunction, + labelsOrientationConfigFunction, + referenceLineLayerConfigFunction, + axisTitlesVisibilityConfigFunction, +} from '../common'; +import { SetupDeps } from './types'; + +export class ExpressionXyPlugin + implements Plugin +{ + public setup(core: CoreSetup, { expressions }: SetupDeps) { + expressions.registerFunction(yAxisConfigFunction); + expressions.registerFunction(legendConfigFunction); + expressions.registerFunction(gridlinesConfigFunction); + expressions.registerFunction(dataLayerConfigFunction); + expressions.registerFunction(axisExtentConfigFunction); + expressions.registerFunction(tickLabelsConfigFunction); + expressions.registerFunction(annotationLayerConfigFunction); + expressions.registerFunction(labelsOrientationConfigFunction); + expressions.registerFunction(referenceLineLayerConfigFunction); + expressions.registerFunction(axisTitlesVisibilityConfigFunction); + expressions.registerFunction(xyVisFunction); + } + + public start(core: CoreStart) {} + + public stop() {} +} diff --git a/src/plugins/chart_expressions/expression_xy/server/types.ts b/src/plugins/chart_expressions/expression_xy/server/types.ts new file mode 100755 index 0000000000000..738f52b739229 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/server/types.ts @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { ExpressionsServerStart, ExpressionsServerSetup } from '../../../expressions/server'; + +export type ExpressionXyPluginSetup = void; +export type ExpressionXyPluginStart = void; + +export interface SetupDeps { + expressions: ExpressionsServerSetup; +} + +export interface StartDeps { + expression: ExpressionsServerStart; +} diff --git a/src/plugins/chart_expressions/expression_xy/tsconfig.json b/src/plugins/chart_expressions/expression_xy/tsconfig.json new file mode 100644 index 0000000000000..5733914869317 --- /dev/null +++ b/src/plugins/chart_expressions/expression_xy/tsconfig.json @@ -0,0 +1,26 @@ +{ + "extends": "../../../../tsconfig.base.json", + "compilerOptions": { + "outDir": "./target/types", + "emitDeclarationOnly": true, + "declaration": true, + "declarationMap": true, + "isolatedModules": true + }, + "include": [ + "common/**/*", + "public/**/*", + "server/**/*", + ], + "references": [ + { "path": "../../charts/tsconfig.json" }, + { "path": "../../../core/tsconfig.json" }, + { "path": "../../expressions/tsconfig.json" }, + { "path": "../../data/tsconfig.json"}, + { "path": "../../ui_actions/tsconfig.json" }, + { "path": "../../field_formats/tsconfig.json"}, + { "path": "../../kibana_utils/tsconfig.json" }, + { "path": "../../event_annotation/tsconfig.json" }, + { "path": "../../visualizations/tsconfig.json" }, + ] +} diff --git a/src/plugins/charts/public/static/components/empty_placeholder.tsx b/src/plugins/charts/public/static/components/empty_placeholder.tsx index 6989ea7a7a63b..e4559a0890ff2 100644 --- a/src/plugins/charts/public/static/components/empty_placeholder.tsx +++ b/src/plugins/charts/public/static/components/empty_placeholder.tsx @@ -10,22 +10,25 @@ import React from 'react'; import { EuiIcon, EuiText, IconType, EuiSpacer } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n-react'; import './empty_placeholder.scss'; +import classnames from 'classnames'; export const EmptyPlaceholder = ({ icon, iconColor = 'subdued', message = , dataTestSubj = 'emptyPlaceholder', + className, }: { icon: IconType; iconColor?: string; message?: JSX.Element; dataTestSubj?: string; + className?: string; }) => ( <> = { - name: 'lens_xy_axisTitlesVisibilityConfig', - aliases: [], - type: 'lens_xy_axisTitlesVisibilityConfig', - help: `Configure the xy chart's axis titles appearance`, - inputTypes: ['null'], - args: { - x: { - types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.xAxisTitle.help', { - defaultMessage: 'Specifies whether or not the title of the x-axis are visible.', - }), - }, - yLeft: { - types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.yLeftAxisTitle.help', { - defaultMessage: 'Specifies whether or not the title of the left y-axis are visible.', - }), - }, - yRight: { - types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.yRightAxisTitle.help', { - defaultMessage: 'Specifies whether or not the title of the right y-axis are visible.', - }), - }, - }, - fn: function fn(input: unknown, args: AxesSettingsConfig) { - return { - type: 'lens_xy_axisTitlesVisibilityConfig', - ...args, - }; - }, -}; - -export type AxisExtentConfigResult = AxisExtentConfig & { type: 'lens_xy_axisExtentConfig' }; - -export const axisExtentConfig: ExpressionFunctionDefinition< - 'lens_xy_axisExtentConfig', - null, - AxisExtentConfig, - AxisExtentConfigResult -> = { - name: 'lens_xy_axisExtentConfig', - aliases: [], - type: 'lens_xy_axisExtentConfig', - help: `Configure the xy chart's axis extents`, - inputTypes: ['null'], - args: { - mode: { - types: ['string'], - options: ['full', 'dataBounds', 'custom'], - help: i18n.translate('xpack.lens.xyChart.extentMode.help', { - defaultMessage: 'The extent mode', - }), - }, - lowerBound: { - types: ['number'], - help: i18n.translate('xpack.lens.xyChart.extentMode.help', { - defaultMessage: 'The extent mode', - }), - }, - upperBound: { - types: ['number'], - help: i18n.translate('xpack.lens.xyChart.extentMode.help', { - defaultMessage: 'The extent mode', - }), - }, - }, - fn: function fn(input: unknown, args: AxisExtentConfig) { - return { - type: 'lens_xy_axisExtentConfig', - ...args, - }; - }, -}; - -export const axisConfig: { [key in keyof AxisConfig]: ArgumentType } = { - title: { - types: ['string'], - help: i18n.translate('xpack.lens.xyChart.title.help', { - defaultMessage: 'The axis title', - }), - }, - hide: { - types: ['boolean'], - default: false, - help: 'Show / hide axis', - }, -}; - -export type YConfigResult = YConfig & { type: 'lens_xy_yConfig' }; - -export const yAxisConfig: ExpressionFunctionDefinition< - 'lens_xy_yConfig', - null, - YConfig, - YConfigResult -> = { - name: 'lens_xy_yConfig', - aliases: [], - type: 'lens_xy_yConfig', - help: `Configure the behavior of a xy chart's y axis metric`, - inputTypes: ['null'], - args: { - forAccessor: { - types: ['string'], - help: 'The accessor this configuration is for', - }, - axisMode: { - types: ['string'], - options: ['auto', 'left', 'right'], - help: 'The axis mode of the metric', - }, - color: { - types: ['string'], - help: 'The color of the series', - }, - lineStyle: { - types: ['string'], - options: ['solid', 'dotted', 'dashed'], - help: 'The style of the reference line', - }, - lineWidth: { - types: ['number'], - help: 'The width of the reference line', - }, - icon: { - types: ['string'], - help: 'An optional icon used for reference lines', - }, - iconPosition: { - types: ['string'], - options: ['auto', 'above', 'below', 'left', 'right'], - help: 'The placement of the icon for the reference line', - }, - textVisibility: { - types: ['boolean'], - help: 'Visibility of the label on the reference line', - }, - fill: { - types: ['string'], - options: ['none', 'above', 'below'], - help: '', - }, - }, - fn: function fn(input: unknown, args: YConfig) { - return { - type: 'lens_xy_yConfig', - ...args, - }; - }, -}; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/index.ts b/x-pack/plugins/lens/common/expressions/xy_chart/index.ts deleted file mode 100644 index 2f66c2c61a9f1..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/index.ts +++ /dev/null @@ -1,18 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -export * from './axis_config'; -export * from './fitting_function'; -export * from './end_value'; -export * from './grid_lines_config'; -export * from './layer_config'; -export * from './legend_config'; -export * from './series_type'; -export * from './tick_labels_config'; -export * from './xy_args'; -export * from './xy_chart'; -export * from './labels_orientation_config'; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/annotation_layer_config.ts b/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/annotation_layer_config.ts deleted file mode 100644 index 45b4bf31c0cdc..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/annotation_layer_config.ts +++ /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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { - EventAnnotationConfig, - EventAnnotationOutput, -} from '../../../../../../../src/plugins/event_annotation/common'; -import type { ExpressionFunctionDefinition } from '../../../../../../../src/plugins/expressions/common'; -import { layerTypes } from '../../../constants'; - -export interface XYAnnotationLayerConfig { - layerId: string; - layerType: typeof layerTypes.ANNOTATIONS; - annotations: EventAnnotationConfig[]; - hide?: boolean; -} - -export interface AnnotationLayerArgs { - annotations: EventAnnotationOutput[]; - layerId: string; - layerType: typeof layerTypes.ANNOTATIONS; - hide?: boolean; -} -export type XYAnnotationLayerArgsResult = AnnotationLayerArgs & { - type: 'lens_xy_annotation_layer'; -}; -export function annotationLayerConfig(): ExpressionFunctionDefinition< - 'lens_xy_annotation_layer', - null, - AnnotationLayerArgs, - XYAnnotationLayerArgsResult -> { - return { - name: 'lens_xy_annotation_layer', - aliases: [], - type: 'lens_xy_annotation_layer', - inputTypes: ['null'], - help: 'Annotation layer in lens', - args: { - layerId: { - types: ['string'], - help: '', - }, - layerType: { types: ['string'], options: [layerTypes.ANNOTATIONS], help: '' }, - hide: { - types: ['boolean'], - default: false, - help: 'Show details', - }, - annotations: { - types: ['manual_event_annotation'], - help: '', - multi: true, - }, - }, - fn: (input, args) => { - return { - type: 'lens_xy_annotation_layer', - ...args, - }; - }, - }; -} diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/data_layer_config.ts b/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/data_layer_config.ts deleted file mode 100644 index 322edccba19e3..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/data_layer_config.ts +++ /dev/null @@ -1,122 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { layerTypes } from '../../../constants'; -import type { PaletteOutput } from '../../../../../../../src/plugins/charts/common'; -import type { ExpressionFunctionDefinition } from '../../../../../../../src/plugins/expressions/common'; -import { axisConfig, YConfig } from '../axis_config'; -import type { SeriesType } from '../series_type'; - -export interface XYDataLayerConfig { - layerId: string; - layerType: typeof layerTypes.DATA; - accessors: string[]; - seriesType: SeriesType; - xAccessor?: string; - hide?: boolean; - yConfig?: YConfig[]; - splitAccessor?: string; - palette?: PaletteOutput; -} -export interface ValidLayer extends XYDataLayerConfig { - xAccessor: NonNullable; -} - -export type DataLayerArgs = XYDataLayerConfig & { - columnToLabel?: string; // Actually a JSON key-value pair - yScaleType: 'time' | 'linear' | 'log' | 'sqrt'; - xScaleType: 'time' | 'linear' | 'ordinal'; - isHistogram: boolean; - // palette will always be set on the expression - palette: PaletteOutput; -}; - -export type DataLayerConfigResult = DataLayerArgs & { type: 'lens_xy_data_layer' }; - -export const dataLayerConfig: ExpressionFunctionDefinition< - 'lens_xy_data_layer', - null, - DataLayerArgs, - DataLayerConfigResult -> = { - name: 'lens_xy_data_layer', - aliases: [], - type: 'lens_xy_data_layer', - help: `Configure a layer in the xy chart`, - inputTypes: ['null'], - args: { - ...axisConfig, - layerId: { - types: ['string'], - help: '', - }, - xAccessor: { - types: ['string'], - help: '', - }, - layerType: { types: ['string'], options: [layerTypes.DATA], help: '' }, - seriesType: { - types: ['string'], - options: [ - 'bar', - 'line', - 'area', - 'bar_stacked', - 'area_stacked', - 'bar_percentage_stacked', - 'area_percentage_stacked', - ], - help: 'The type of chart to display.', - }, - xScaleType: { - options: ['ordinal', 'linear', 'time'], - help: 'The scale type of the x axis', - default: 'ordinal', - }, - isHistogram: { - types: ['boolean'], - default: false, - help: 'Whether to layout the chart as a histogram', - }, - yScaleType: { - options: ['log', 'sqrt', 'linear', 'time'], - help: 'The scale type of the y axes', - default: 'linear', - }, - splitAccessor: { - types: ['string'], - help: 'The column to split by', - multi: false, - }, - accessors: { - types: ['string'], - help: 'The columns to display on the y axis.', - multi: true, - }, - yConfig: { - // eslint-disable-next-line @typescript-eslint/no-explicit-any - types: ['lens_xy_yConfig' as any], - help: 'Additional configuration for y axes', - multi: true, - }, - columnToLabel: { - types: ['string'], - help: 'JSON key-value pairs of column ID to label', - }, - palette: { - default: `{theme "palette" default={system_palette name="default"} }`, - help: '', - types: ['palette'], - }, - }, - fn: function fn(input: unknown, args: DataLayerArgs) { - return { - type: 'lens_xy_data_layer', - ...args, - }; - }, -}; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/index.ts b/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/index.ts deleted file mode 100644 index df27229bdb81f..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/index.ts +++ /dev/null @@ -1,17 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import { XYDataLayerConfig } from './data_layer_config'; -import { XYReferenceLineLayerConfig } from './reference_line_layer_config'; -import { XYAnnotationLayerConfig } from './annotation_layer_config'; -export * from './data_layer_config'; -export * from './reference_line_layer_config'; -export * from './annotation_layer_config'; - -export type XYLayerConfig = - | XYDataLayerConfig - | XYReferenceLineLayerConfig - | XYAnnotationLayerConfig; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/reference_line_layer_config.ts b/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/reference_line_layer_config.ts deleted file mode 100644 index 6e241f8b8db65..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/layer_config/reference_line_layer_config.ts +++ /dev/null @@ -1,64 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import type { ExpressionFunctionDefinition } from '../../../../../../../src/plugins/expressions/common'; -import { layerTypes } from '../../../constants'; -import { YConfig } from '../axis_config'; - -export interface XYReferenceLineLayerConfig { - layerId: string; - layerType: typeof layerTypes.REFERENCELINE; - accessors: string[]; - yConfig?: YConfig[]; -} -export type ReferenceLineLayerArgs = XYReferenceLineLayerConfig & { - columnToLabel?: string; -}; -export type ReferenceLineLayerConfigResult = ReferenceLineLayerArgs & { - type: 'lens_xy_referenceLine_layer'; -}; - -export const referenceLineLayerConfig: ExpressionFunctionDefinition< - 'lens_xy_referenceLine_layer', - null, - ReferenceLineLayerArgs, - ReferenceLineLayerConfigResult -> = { - name: 'lens_xy_referenceLine_layer', - aliases: [], - type: 'lens_xy_referenceLine_layer', - help: `Configure a layer in the xy chart`, - inputTypes: ['null'], - args: { - layerId: { - types: ['string'], - help: '', - }, - layerType: { types: ['string'], options: [layerTypes.REFERENCELINE], help: '' }, - accessors: { - types: ['string'], - help: 'The columns to display on the y axis.', - multi: true, - }, - yConfig: { - // eslint-disable-next-line @typescript-eslint/no-explicit-any - types: ['lens_xy_yConfig' as any], - help: 'Additional configuration for y axes', - multi: true, - }, - columnToLabel: { - types: ['string'], - help: 'JSON key-value pairs of column ID to label', - }, - }, - fn: function fn(input: unknown, args: ReferenceLineLayerArgs) { - return { - type: 'lens_xy_referenceLine_layer', - ...args, - }; - }, -}; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/legend_config.ts b/x-pack/plugins/lens/common/expressions/xy_chart/legend_config.ts deleted file mode 100644 index bced4e284aa3c..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/legend_config.ts +++ /dev/null @@ -1,142 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import { HorizontalAlignment, Position, VerticalAlignment } from '@elastic/charts'; -import { i18n } from '@kbn/i18n'; -import type { ExpressionFunctionDefinition } from '../../../../../../src/plugins/expressions/common'; - -export interface LegendConfig { - /** - * Flag whether the legend should be shown. If there is just a single series, it will be hidden - */ - isVisible: boolean; - /** - * Position of the legend relative to the chart - */ - position: Position; - /** - * Flag whether the legend should be shown even with just a single series - */ - showSingleSeries?: boolean; - /** - * Flag whether the legend is inside the chart - */ - isInside?: boolean; - /** - * Horizontal Alignment of the legend when it is set inside chart - */ - horizontalAlignment?: HorizontalAlignment; - /** - * Vertical Alignment of the legend when it is set inside chart - */ - verticalAlignment?: VerticalAlignment; - /** - * Number of columns when legend is set inside chart - */ - floatingColumns?: number; - /** - * Maximum number of lines per legend item - */ - maxLines?: number; - /** - * Flag whether the legend items are truncated or not - */ - shouldTruncate?: boolean; - /** - * Exact legend width (vertical) or height (horizontal) - * Limited to max of 70% of the chart container dimension Vertical legends limited to min of 30% of computed width - */ - legendSize?: number; -} - -export type LegendConfigResult = LegendConfig & { type: 'lens_xy_legendConfig' }; - -export const legendConfig: ExpressionFunctionDefinition< - 'lens_xy_legendConfig', - null, - LegendConfig, - LegendConfigResult -> = { - name: 'lens_xy_legendConfig', - aliases: [], - type: 'lens_xy_legendConfig', - help: `Configure the xy chart's legend`, - inputTypes: ['null'], - args: { - isVisible: { - types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.isVisible.help', { - defaultMessage: 'Specifies whether or not the legend is visible.', - }), - }, - position: { - types: ['string'], - options: [Position.Top, Position.Right, Position.Bottom, Position.Left], - help: i18n.translate('xpack.lens.xyChart.position.help', { - defaultMessage: 'Specifies the legend position.', - }), - }, - showSingleSeries: { - types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.showSingleSeries.help', { - defaultMessage: 'Specifies whether a legend with just a single entry should be shown', - }), - }, - isInside: { - types: ['boolean'], - help: i18n.translate('xpack.lens.xyChart.isInside.help', { - defaultMessage: 'Specifies whether a legend is inside the chart', - }), - }, - horizontalAlignment: { - types: ['string'], - options: [HorizontalAlignment.Right, HorizontalAlignment.Left], - help: i18n.translate('xpack.lens.xyChart.horizontalAlignment.help', { - defaultMessage: - 'Specifies the horizontal alignment of the legend when it is displayed inside chart.', - }), - }, - verticalAlignment: { - types: ['string'], - options: [VerticalAlignment.Top, VerticalAlignment.Bottom], - help: i18n.translate('xpack.lens.xyChart.verticalAlignment.help', { - defaultMessage: - 'Specifies the vertical alignment of the legend when it is displayed inside chart.', - }), - }, - floatingColumns: { - types: ['number'], - help: i18n.translate('xpack.lens.xyChart.floatingColumns.help', { - defaultMessage: 'Specifies the number of columns when legend is displayed inside chart.', - }), - }, - maxLines: { - types: ['number'], - help: i18n.translate('xpack.lens.xyChart.maxLines.help', { - defaultMessage: 'Specifies the number of lines per legend item.', - }), - }, - shouldTruncate: { - types: ['boolean'], - default: true, - help: i18n.translate('xpack.lens.xyChart.shouldTruncate.help', { - defaultMessage: 'Specifies whether the legend items will be truncated or not', - }), - }, - legendSize: { - types: ['number'], - help: i18n.translate('xpack.lens.xyChart.legendSize.help', { - defaultMessage: 'Specifies the legend size in pixels.', - }), - }, - }, - fn: function fn(input: unknown, args: LegendConfig) { - return { - type: 'lens_xy_legendConfig', - ...args, - }; - }, -}; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/series_type.ts b/x-pack/plugins/lens/common/expressions/xy_chart/series_type.ts deleted file mode 100644 index f9a375b8b47a1..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/series_type.ts +++ /dev/null @@ -1,18 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -export type SeriesType = - | 'bar' - | 'bar_horizontal' - | 'line' - | 'area' - | 'bar_stacked' - | 'bar_percentage_stacked' - | 'bar_horizontal_stacked' - | 'bar_horizontal_percentage_stacked' - | 'area_stacked' - | 'area_percentage_stacked'; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/xy_args.ts b/x-pack/plugins/lens/common/expressions/xy_chart/xy_args.ts deleted file mode 100644 index 4520f0c99c3e9..0000000000000 --- a/x-pack/plugins/lens/common/expressions/xy_chart/xy_args.ts +++ /dev/null @@ -1,45 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import type { AxisExtentConfigResult, AxisTitlesVisibilityConfigResult } from './axis_config'; -import type { FittingFunction } from './fitting_function'; -import type { EndValue } from './end_value'; -import type { GridlinesConfigResult } from './grid_lines_config'; -import type { AnnotationLayerArgs, DataLayerArgs } from './layer_config'; -import type { LegendConfigResult } from './legend_config'; -import type { TickLabelsConfigResult } from './tick_labels_config'; -import type { LabelsOrientationConfigResult } from './labels_orientation_config'; -import type { ValueLabelConfig } from '../../types'; - -export type XYCurveType = 'LINEAR' | 'CURVE_MONOTONE_X'; -export type XYLayerArgs = DataLayerArgs | AnnotationLayerArgs; - -// Arguments to XY chart expression, with computed properties -export interface XYArgs { - title?: string; - description?: string; - xTitle: string; - yTitle: string; - yRightTitle: string; - yLeftExtent: AxisExtentConfigResult; - yRightExtent: AxisExtentConfigResult; - legend: LegendConfigResult; - valueLabels: ValueLabelConfig; - layers: XYLayerArgs[]; - fittingFunction?: FittingFunction; - endValue?: EndValue; - emphasizeFitting?: boolean; - axisTitlesVisibilitySettings?: AxisTitlesVisibilityConfigResult; - tickLabelsVisibilitySettings?: TickLabelsConfigResult; - gridlinesVisibilitySettings?: GridlinesConfigResult; - labelsOrientation?: LabelsOrientationConfigResult; - curveType?: XYCurveType; - fillOpacity?: number; - hideEndzones?: boolean; - valuesInLegend?: boolean; - ariaLabel?: string; -} diff --git a/x-pack/plugins/lens/kibana.json b/x-pack/plugins/lens/kibana.json index 18f33adf40840..a2093e78f18f0 100644 --- a/x-pack/plugins/lens/kibana.json +++ b/x-pack/plugins/lens/kibana.json @@ -25,6 +25,7 @@ "eventAnnotation" ], "optionalPlugins": [ + "expressionXY", "usageCollection", "taskManager", "globalSearch", diff --git a/x-pack/plugins/lens/public/expressions.ts b/x-pack/plugins/lens/public/expressions.ts index 2bf1f49ae37c8..40fee07f5d95a 100644 --- a/x-pack/plugins/lens/public/expressions.ts +++ b/x-pack/plugins/lens/public/expressions.ts @@ -6,26 +6,8 @@ */ import type { ExpressionsSetup } from 'src/plugins/expressions/public'; - -import { - axisExtentConfig, - yAxisConfig, - axisTitlesVisibilityConfig, -} from '../common/expressions/xy_chart/axis_config'; -import { gridlinesConfig } from '../common/expressions/xy_chart/grid_lines_config'; -import { labelsOrientationConfig } from '../common/expressions/xy_chart/labels_orientation_config'; -import { - dataLayerConfig, - referenceLineLayerConfig, - annotationLayerConfig, -} from '../common/expressions/xy_chart/layer_config'; -import { legendConfig } from '../common/expressions/xy_chart/legend_config'; -import { tickLabelsConfig } from '../common/expressions/xy_chart/tick_labels_config'; -import { xyChart } from '../common/expressions/xy_chart/xy_chart'; - import { getDatatable } from '../common/expressions/datatable/datatable'; import { datatableColumn } from '../common/expressions/datatable/datatable_column'; - import { mergeTables } from '../common/expressions/merge_tables'; import { renameColumns } from '../common/expressions/rename_columns/rename_columns'; import { formatColumn } from '../common/expressions/format_column'; @@ -41,22 +23,11 @@ export const setupExpressions = ( [lensMultitable].forEach((expressionType) => expressions.registerType(expressionType)); [ - xyChart, mergeTables, counterRate, - yAxisConfig, - dataLayerConfig, - referenceLineLayerConfig, - annotationLayerConfig, formatColumn, - legendConfig, renameColumns, - gridlinesConfig, datatableColumn, - tickLabelsConfig, - axisTitlesVisibilityConfig, - axisExtentConfig, - labelsOrientationConfig, getDatatable(formatFactory), getTimeScale(getTimeZone), ].forEach((expressionFn) => expressions.registerFunction(expressionFn)); diff --git a/x-pack/plugins/lens/public/index.ts b/x-pack/plugins/lens/public/index.ts index a86ba194bf4db..5b1501410df26 100644 --- a/x-pack/plugins/lens/public/index.ts +++ b/x-pack/plugins/lens/public/index.ts @@ -11,7 +11,13 @@ export type { EmbeddableComponentProps, TypedLensByValueInput, } from './embeddable/embeddable_component'; -export type { XYState } from './xy_visualization/types'; +export type { + XYState, + XYReferenceLineLayerConfig, + XYLayerConfig, + XYDataLayerConfig, + XYAnnotationLayerConfig, +} from './xy_visualization/types'; export type { DatasourcePublicAPI, DataType, @@ -21,15 +27,6 @@ export type { Visualization, VisualizationSuggestion, } from './types'; -export type { - AxesSettingsConfig, - XYLayerConfig, - LegendConfig, - SeriesType, - YAxisMode, - XYCurveType, - YConfig, -} from '../common/expressions'; export type { ValueLabelConfig, PieVisualizationState, @@ -70,6 +67,42 @@ export type { FormulaPublicApi, StaticValueIndexPatternColumn, } from './indexpattern_datasource/types'; +export type { + XYArgs, + YConfig, + XYRender, + LayerType, + YAxisMode, + LineStyle, + FillStyle, + SeriesType, + YScaleType, + XScaleType, + AxisConfig, + ValidLayer, + XYCurveType, + XYChartProps, + LegendConfig, + IconPosition, + YConfigResult, + DataLayerArgs, + LensMultiTable, + ValueLabelMode, + AxisExtentMode, + FittingFunction, + AxisExtentConfig, + LegendConfigResult, + AxesSettingsConfig, + GridlinesConfigResult, + DataLayerConfigResult, + TickLabelsConfigResult, + AxisExtentConfigResult, + ReferenceLineLayerArgs, + LabelsOrientationConfig, + LabelsOrientationConfigResult, + ReferenceLineLayerConfigResult, + AxisTitlesVisibilityConfigResult, +} from '../../../../src/plugins/chart_expressions/expression_xy/common'; export type { LensEmbeddableInput } from './embeddable'; export { layerTypes } from '../common'; diff --git a/x-pack/plugins/lens/public/shared_components/axis_title_settings.tsx b/x-pack/plugins/lens/public/shared_components/axis_title_settings.tsx index 00cba7db4d17a..ff7b058873bbc 100644 --- a/x-pack/plugins/lens/public/shared_components/axis_title_settings.tsx +++ b/x-pack/plugins/lens/public/shared_components/axis_title_settings.tsx @@ -8,8 +8,9 @@ import React, { useCallback, useState } from 'react'; import { EuiSpacer, EuiFormRow } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; -import { AxesSettingsConfig } from '../../common/expressions'; +import { AxesSettingsConfig } from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { LabelMode, useDebouncedValue, VisLabel } from './'; + type AxesSettingsConfigKeys = keyof AxesSettingsConfig; export interface AxisTitleSettingsProps { diff --git a/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap b/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap index a1b0431f67138..27cc383834049 100644 --- a/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap +++ b/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap @@ -20,7 +20,7 @@ Object { true, ], }, - "function": "lens_xy_axisTitlesVisibilityConfig", + "function": "axisTitlesVisibilityConfig", "type": "function", }, ], @@ -60,7 +60,7 @@ Object { true, ], }, - "function": "lens_xy_gridlinesConfig", + "function": "gridlinesConfig", "type": "function", }, ], @@ -85,7 +85,7 @@ Object { -45, ], }, - "function": "lens_xy_labelsOrientationConfig", + "function": "labelsOrientationConfig", "type": "function", }, ], @@ -113,9 +113,6 @@ Object { "layerId": Array [ "first", ], - "layerType": Array [ - "data", - ], "seriesType": Array [ "area", ], @@ -133,7 +130,7 @@ Object { "linear", ], }, - "function": "lens_xy_data_layer", + "function": "dataLayer", "type": "function", }, ], @@ -162,7 +159,7 @@ Object { "showSingleSeries": Array [], "verticalAlignment": Array [], }, - "function": "lens_xy_legendConfig", + "function": "legendConfig", "type": "function", }, ], @@ -184,7 +181,7 @@ Object { true, ], }, - "function": "lens_xy_tickLabelsConfig", + "function": "tickLabelsConfig", "type": "function", }, ], @@ -214,7 +211,7 @@ Object { ], "upperBound": Array [], }, - "function": "lens_xy_axisExtentConfig", + "function": "axisExtentConfig", "type": "function", }, ], @@ -236,7 +233,7 @@ Object { 456, ], }, - "function": "lens_xy_axisExtentConfig", + "function": "axisExtentConfig", "type": "function", }, ], @@ -250,7 +247,7 @@ Object { "", ], }, - "function": "lens_xy_chart", + "function": "xyVis", "type": "function", }, ], diff --git a/x-pack/plugins/lens/public/xy_visualization/annotations/config_panel/index.tsx b/x-pack/plugins/lens/public/xy_visualization/annotations/config_panel/index.tsx index 4cdb2d6c7e0b9..c27165accb81d 100644 --- a/x-pack/plugins/lens/public/xy_visualization/annotations/config_panel/index.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/annotations/config_panel/index.tsx @@ -13,9 +13,8 @@ import type { PaletteRegistry } from 'src/plugins/charts/public'; import moment from 'moment'; import { EventAnnotationConfig } from 'src/plugins/event_annotation/common/types'; import type { VisualizationDimensionEditorProps } from '../../../types'; -import { State, XYState } from '../../types'; +import { State, XYState, XYAnnotationLayerConfig } from '../../types'; import { FormatFactory } from '../../../../common'; -import { XYAnnotationLayerConfig } from '../../../../common/expressions'; import { ColorPicker } from '../../xy_config_panel/color_picker'; import { DimensionEditorSection, NameInput, useDebouncedValue } from '../../../shared_components'; import { isHorizontalChart } from '../../state_helpers'; diff --git a/x-pack/plugins/lens/public/xy_visualization/annotations/expression.scss b/x-pack/plugins/lens/public/xy_visualization/annotations/expression.scss deleted file mode 100644 index fc2b1204bb1d0..0000000000000 --- a/x-pack/plugins/lens/public/xy_visualization/annotations/expression.scss +++ /dev/null @@ -1,37 +0,0 @@ -.lnsXyDecorationRotatedWrapper { - display: inline-block; - overflow: hidden; - line-height: 1.5; - - .lnsXyDecorationRotatedWrapper__label { - display: inline-block; - white-space: nowrap; - transform: translate(0, 100%) rotate(-90deg); - transform-origin: 0 0; - - &::after { - content: ''; - float: left; - margin-top: 100%; - } - } -} - -.lnsXyAnnotationNumberIcon { - border-radius: $euiSize; - min-width: $euiSize; - height: $euiSize; - background-color: currentColor; -} - -.lnsXyAnnotationNumberIcon__text { - font-weight: 500; - font-size: 9px; - letter-spacing: -.5px; - line-height: 11px; -} - -.lnsXyAnnotationIcon_rotate90 { - transform: rotate(45deg); - transform-origin: center; -} diff --git a/x-pack/plugins/lens/public/xy_visualization/annotations/helpers.tsx b/x-pack/plugins/lens/public/xy_visualization/annotations/helpers.tsx index c82228f088e47..8f18450ba5a21 100644 --- a/x-pack/plugins/lens/public/xy_visualization/annotations/helpers.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/annotations/helpers.tsx @@ -8,14 +8,9 @@ import { i18n } from '@kbn/i18n'; import moment from 'moment'; import { layerTypes } from '../../../common'; -import type { - XYDataLayerConfig, - XYAnnotationLayerConfig, - XYLayerConfig, -} from '../../../common/expressions'; import type { FramePublicAPI, Visualization } from '../../types'; import { isHorizontalChart } from '../state_helpers'; -import type { XYState } from '../types'; +import type { XYState, XYDataLayerConfig, XYAnnotationLayerConfig, XYLayerConfig } from '../types'; import { checkScaleOperation, getAnnotationsLayers, diff --git a/x-pack/plugins/lens/public/xy_visualization/axes_configuration.test.ts b/x-pack/plugins/lens/public/xy_visualization/axes_configuration.test.ts index ac3e224663ce4..a733f83b46338 100644 --- a/x-pack/plugins/lens/public/xy_visualization/axes_configuration.test.ts +++ b/x-pack/plugins/lens/public/xy_visualization/axes_configuration.test.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { DataLayerArgs } from '../../common/expressions'; +import { DataLayerConfigResult } from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { layerTypes } from '../../common'; import { Datatable } from '../../../../../src/plugins/expressions/public'; import { getAxesConfiguration } from './axes_configuration'; @@ -219,7 +219,8 @@ describe('axes_configuration', () => { }, }; - const sampleLayer: DataLayerArgs = { + const sampleLayer: DataLayerConfigResult = { + type: 'dataLayer', layerId: 'first', layerType: layerTypes.DATA, seriesType: 'line', @@ -271,7 +272,12 @@ describe('axes_configuration', () => { it('should map right series to right axis', () => { const formatFactory = jest.fn(); const groups = getAxesConfiguration( - [{ ...sampleLayer, yConfig: [{ forAccessor: 'yAccessorId', axisMode: 'right' }] }], + [ + { + ...sampleLayer, + yConfig: [{ forAccessor: 'yAccessorId', axisMode: 'right' }], + }, + ], false, tables, formatFactory diff --git a/x-pack/plugins/lens/public/xy_visualization/axes_configuration.ts b/x-pack/plugins/lens/public/xy_visualization/axes_configuration.ts index 7adc803f31e9f..b9b2c2ae86e42 100644 --- a/x-pack/plugins/lens/public/xy_visualization/axes_configuration.ts +++ b/x-pack/plugins/lens/public/xy_visualization/axes_configuration.ts @@ -6,12 +6,13 @@ */ import { FormatFactory } from '../../common'; -import { AxisExtentConfig, XYDataLayerConfig } from '../../common/expressions'; +import { AxisExtentConfig } from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { Datatable } from '../../../../../src/plugins/expressions/public'; import type { IFieldFormat, SerializedFieldFormat, } from '../../../../../src/plugins/field_formats/common'; +import { XYDataLayerConfig } from './types'; interface FormattedMetric { layer: string; diff --git a/x-pack/plugins/lens/public/xy_visualization/color_assignment.test.ts b/x-pack/plugins/lens/public/xy_visualization/color_assignment.test.ts index 9b29401d72a95..a329c12b083a5 100644 --- a/x-pack/plugins/lens/public/xy_visualization/color_assignment.test.ts +++ b/x-pack/plugins/lens/public/xy_visualization/color_assignment.test.ts @@ -7,15 +7,12 @@ import { getColorAssignments } from './color_assignment'; import type { FormatFactory, LensMultiTable } from '../../common'; -import type { DataLayerArgs } from '../../common/expressions'; import { layerTypes } from '../../common'; +import { XYDataLayerConfig } from './types'; describe('color_assignment', () => { - const layers: DataLayerArgs[] = [ + const layers: XYDataLayerConfig[] = [ { - yScaleType: 'linear', - xScaleType: 'linear', - isHistogram: true, seriesType: 'bar', palette: { type: 'palette', name: 'palette1' }, layerId: '1', @@ -24,9 +21,6 @@ describe('color_assignment', () => { accessors: ['y1', 'y2'], }, { - yScaleType: 'linear', - xScaleType: 'linear', - isHistogram: true, seriesType: 'bar', palette: { type: 'palette', name: 'palette2' }, layerId: '2', diff --git a/x-pack/plugins/lens/public/xy_visualization/color_assignment.ts b/x-pack/plugins/lens/public/xy_visualization/color_assignment.ts index f8d5805279a2e..ed1b7f0244c89 100644 --- a/x-pack/plugins/lens/public/xy_visualization/color_assignment.ts +++ b/x-pack/plugins/lens/public/xy_visualization/color_assignment.ts @@ -11,46 +11,40 @@ import type { Datatable } from 'src/plugins/expressions'; import { euiLightVars } from '@kbn/ui-theme'; import type { AccessorConfig, FramePublicAPI } from '../types'; import { getColumnToLabelMap } from './state_helpers'; -import { FormatFactory, LayerType } from '../../common'; -import type { XYLayerConfig } from '../../common/expressions'; -import { isReferenceLayer, isAnnotationsLayer } from './visualization_helpers'; +import { FormatFactory } from '../../common'; +import { isDataLayer, isReferenceLayer, isAnnotationsLayer } from './visualization_helpers'; import { getAnnotationsAccessorColorConfig } from './annotations/helpers'; import { getReferenceLineAccessorColorConfig } from './reference_line_helpers'; +import { XYDataLayerConfig, XYLayerConfig } from './types'; const isPrimitive = (value: unknown): boolean => value != null && typeof value !== 'object'; -interface LayerColorConfig { - palette?: PaletteOutput; - splitAccessor?: string; - accessors: string[]; - layerId: string; - layerType: LayerType; -} - export const defaultReferenceLineColor = euiLightVars.euiColorDarkShade; export type ColorAssignments = Record< string, { totalSeriesCount: number; - getRank(sortedLayer: LayerColorConfig, seriesKey: string, yAccessor: string): number; + getRank(sortedLayer: XYDataLayerConfig, seriesKey: string, yAccessor: string): number; } >; export function getColorAssignments( - layers: LayerColorConfig[], + layers: XYLayerConfig[], data: { tables: Record }, formatFactory: FormatFactory ): ColorAssignments { - const layersPerPalette: Record = {}; + const layersPerPalette: Record = {}; - layers.forEach((layer) => { - const palette = layer.palette?.name || 'default'; - if (!layersPerPalette[palette]) { - layersPerPalette[palette] = []; - } - layersPerPalette[palette].push(layer); - }); + layers + .filter((layer): layer is XYDataLayerConfig => isDataLayer(layer)) + .forEach((layer) => { + const palette = layer.palette?.name || 'default'; + if (!layersPerPalette[palette]) { + layersPerPalette[palette] = []; + } + layersPerPalette[palette].push(layer); + }); return mapValues(layersPerPalette, (paletteLayers) => { const seriesPerLayer = paletteLayers.map((layer, layerIndex) => { @@ -82,7 +76,7 @@ export function getColorAssignments( ); return { totalSeriesCount, - getRank(sortedLayer: LayerColorConfig, seriesKey: string, yAccessor: string) { + getRank(sortedLayer: XYDataLayerConfig, seriesKey: string, yAccessor: string) { const layerIndex = paletteLayers.findIndex((l) => sortedLayer.layerId === l.layerId); const currentSeriesPerLayer = seriesPerLayer[layerIndex]; const splitRank = currentSeriesPerLayer.splits.indexOf(seriesKey); @@ -125,6 +119,7 @@ export function getAccessorColorConfig( triggerIcon: 'disabled', }; } + const columnToLabel = getColumnToLabelMap(layer, frame.datasourceLayers[layer.layerId]); const rank = colorAssignments[currentPalette.name].getRank( layer, diff --git a/x-pack/plugins/lens/public/xy_visualization/expression.scss b/x-pack/plugins/lens/public/xy_visualization/expression.scss deleted file mode 100644 index 68f5e9863d2bb..0000000000000 --- a/x-pack/plugins/lens/public/xy_visualization/expression.scss +++ /dev/null @@ -1,15 +0,0 @@ -.lnsXyExpression__container { - height: 100%; - width: 100%; - // the FocusTrap is adding extra divs which are making the visualization redraw twice - // with a visible glitch. This make the chart library resilient to this extra reflow - overflow-x: hidden; -} - -.lnsChart__empty { - height: 100%; - display: flex; - flex-direction: column; - align-items: center; - justify-content: center; -} diff --git a/x-pack/plugins/lens/public/xy_visualization/expression.test.tsx b/x-pack/plugins/lens/public/xy_visualization/expression.test.tsx deleted file mode 100644 index 36e1155750ef0..0000000000000 --- a/x-pack/plugins/lens/public/xy_visualization/expression.test.tsx +++ /dev/null @@ -1,3167 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { - AreaSeries, - Axis, - BarSeries, - Position, - LineSeries, - Settings, - ScaleType, - GeometryValue, - XYChartSeriesIdentifier, - SeriesNameFn, - Fit, - HorizontalAlignment, - VerticalAlignment, - LayoutDirection, - LineAnnotation, -} from '@elastic/charts'; -import { PaletteOutput } from 'src/plugins/charts/public'; -import { calculateMinInterval, XYChart, XYChartRenderProps } from './expression'; -import type { LensMultiTable } from '../../common'; -import { layerTypes } from '../../common'; -import { AnnotationLayerArgs, xyChart } from '../../common/expressions'; -import { - dataLayerConfig, - legendConfig, - tickLabelsConfig, - gridlinesConfig, - XYArgs, - LegendConfig, - DataLayerArgs, - AxesSettingsConfig, - XYChartProps, - labelsOrientationConfig, - LabelsOrientationConfig, -} from '../../common/expressions'; -import { Datatable, DatatableRow } from '../../../../../src/plugins/expressions/public'; -import React from 'react'; -import { mount, shallow } from 'enzyme'; -import { createMockExecutionContext } from '../../../../../src/plugins/expressions/common/mocks'; -import { mountWithIntl } from '@kbn/test-jest-helpers'; -import { chartPluginMock } from '../../../../../src/plugins/charts/public/mocks'; -import { EmptyPlaceholder } from '../../../../../src/plugins/charts/public'; -import { XyEndzones } from './x_domain'; -import { eventAnnotationServiceMock } from '../../../../../src/plugins/event_annotation/public/mocks'; -import { EventAnnotationOutput } from 'src/plugins/event_annotation/common'; - -const onClickValue = jest.fn(); -const onSelectRange = jest.fn(); - -const chartSetupContract = chartPluginMock.createSetupContract(); -const chartStartContract = chartPluginMock.createStartContract(); - -const chartsThemeService = chartSetupContract.theme; -const chartsActiveCursorService = chartStartContract.activeCursor; - -const paletteService = chartPluginMock.createPaletteRegistry(); - -const mockPaletteOutput: PaletteOutput = { - type: 'palette', - name: 'mock', - params: {}, -}; - -const dateHistogramData: LensMultiTable = { - type: 'lens_multitable', - tables: { - timeLayer: { - type: 'datatable', - rows: [ - { - xAccessorId: 1585758120000, - splitAccessorId: "Men's Clothing", - yAccessorId: 1, - }, - { - xAccessorId: 1585758360000, - splitAccessorId: "Women's Accessories", - yAccessorId: 1, - }, - { - xAccessorId: 1585758360000, - splitAccessorId: "Women's Clothing", - yAccessorId: 1, - }, - { - xAccessorId: 1585759380000, - splitAccessorId: "Men's Clothing", - yAccessorId: 1, - }, - { - xAccessorId: 1585759380000, - splitAccessorId: "Men's Shoes", - yAccessorId: 1, - }, - { - xAccessorId: 1585759380000, - splitAccessorId: "Women's Clothing", - yAccessorId: 1, - }, - { - xAccessorId: 1585760700000, - splitAccessorId: "Men's Clothing", - yAccessorId: 1, - }, - { - xAccessorId: 1585760760000, - splitAccessorId: "Men's Clothing", - yAccessorId: 1, - }, - { - xAccessorId: 1585760760000, - splitAccessorId: "Men's Shoes", - yAccessorId: 1, - }, - { - xAccessorId: 1585761120000, - splitAccessorId: "Men's Shoes", - yAccessorId: 1, - }, - ], - columns: [ - { - id: 'xAccessorId', - name: 'order_date per minute', - meta: { - type: 'date', - field: 'order_date', - source: 'esaggs', - index: 'indexPatternId', - sourceParams: { - indexPatternId: 'indexPatternId', - type: 'date_histogram', - appliedTimeRange: { - from: '2020-04-01T16:14:16.246Z', - to: '2020-04-01T17:15:41.263Z', - }, - params: { - field: 'order_date', - timeRange: { from: '2020-04-01T16:14:16.246Z', to: '2020-04-01T17:15:41.263Z' }, - useNormalizedEsInterval: true, - scaleMetricValues: false, - interval: '1m', - drop_partials: false, - min_doc_count: 0, - extended_bounds: {}, - }, - }, - params: { id: 'date', params: { pattern: 'HH:mm' } }, - }, - }, - { - id: 'splitAccessorId', - name: 'Top values of category.keyword', - meta: { - type: 'string', - field: 'category.keyword', - source: 'esaggs', - index: 'indexPatternId', - sourceParams: { - indexPatternId: 'indexPatternId', - type: 'terms', - params: { - field: 'category.keyword', - orderBy: 'yAccessorId', - order: 'desc', - size: 3, - otherBucket: false, - otherBucketLabel: 'Other', - missingBucket: false, - missingBucketLabel: 'Missing', - }, - }, - params: { - id: 'terms', - params: { - id: 'string', - otherBucketLabel: 'Other', - missingBucketLabel: 'Missing', - parsedUrl: { - origin: 'http://localhost:5601', - pathname: '/jiy/app/kibana', - basePath: '/jiy', - }, - }, - }, - }, - }, - { - id: 'yAccessorId', - name: 'Count of records', - meta: { - type: 'number', - source: 'esaggs', - index: 'indexPatternId', - sourceParams: { - indexPatternId: 'indexPatternId', - params: {}, - }, - params: { id: 'number' }, - }, - }, - ], - }, - }, - dateRange: { - fromDate: new Date('2020-04-01T16:14:16.246Z'), - toDate: new Date('2020-04-01T17:15:41.263Z'), - }, -}; - -const dateHistogramLayer: DataLayerArgs = { - layerId: 'timeLayer', - layerType: layerTypes.DATA, - hide: false, - xAccessor: 'xAccessorId', - yScaleType: 'linear', - xScaleType: 'time', - isHistogram: true, - splitAccessor: 'splitAccessorId', - seriesType: 'bar_stacked', - accessors: ['yAccessorId'], - palette: mockPaletteOutput, -}; - -const createSampleDatatableWithRows = (rows: DatatableRow[]): Datatable => ({ - type: 'datatable', - columns: [ - { - id: 'a', - name: 'a', - meta: { type: 'number', params: { id: 'number', params: { pattern: '0,0.000' } } }, - }, - { - id: 'b', - name: 'b', - meta: { type: 'number', params: { id: 'number', params: { pattern: '000,0' } } }, - }, - { - id: 'c', - name: 'c', - meta: { - type: 'date', - field: 'order_date', - sourceParams: { type: 'date-histogram', params: { interval: 'auto' } }, - params: { id: 'string' }, - }, - }, - { id: 'd', name: 'ColD', meta: { type: 'string' } }, - ], - rows, -}); - -const sampleLayer: DataLayerArgs = { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'c', - accessors: ['a', 'b'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', - xScaleType: 'ordinal', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, -}; - -const createArgsWithLayers = (layers: DataLayerArgs[] = [sampleLayer]): XYArgs => ({ - xTitle: '', - yTitle: '', - yRightTitle: '', - legend: { - type: 'lens_xy_legendConfig', - isVisible: false, - position: Position.Top, - }, - valueLabels: 'hide', - valuesInLegend: false, - axisTitlesVisibilitySettings: { - type: 'lens_xy_axisTitlesVisibilityConfig', - x: true, - yLeft: true, - yRight: true, - }, - tickLabelsVisibilitySettings: { - type: 'lens_xy_tickLabelsConfig', - x: true, - yLeft: false, - yRight: false, - }, - labelsOrientation: { - type: 'lens_xy_labelsOrientationConfig', - x: 0, - yLeft: -90, - yRight: -45, - }, - gridlinesVisibilitySettings: { - type: 'lens_xy_gridlinesConfig', - x: true, - yLeft: false, - yRight: false, - }, - yLeftExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - yRightExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - layers, -}); - -function sampleArgs() { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: createSampleDatatableWithRows([ - { a: 1, b: 2, c: 'I', d: 'Foo' }, - { a: 1, b: 5, c: 'J', d: 'Bar' }, - ]), - }, - dateRange: { - fromDate: new Date('2019-01-02T05:00:00.000Z'), - toDate: new Date('2019-01-03T05:00:00.000Z'), - }, - }; - - const args: XYArgs = createArgsWithLayers(); - - return { data, args }; -} - -function sampleArgsWithReferenceLine(value: number = 150) { - const { data, args } = sampleArgs(); - - return { - data: { - ...data, - tables: { - ...data.tables, - referenceLine: { - type: 'datatable', - columns: [ - { - id: 'referenceLine-a', - meta: { params: { id: 'number' }, type: 'number' }, - name: 'Static value', - }, - ], - rows: [{ 'referenceLine-a': value }], - }, - }, - } as LensMultiTable, - args: { - ...args, - layers: [ - ...args.layers, - { - layerType: layerTypes.REFERENCELINE, - accessors: ['referenceLine-a'], - layerId: 'referenceLine', - seriesType: 'line', - xScaleType: 'linear', - yScaleType: 'linear', - palette: mockPaletteOutput, - isHistogram: false, - hide: true, - yConfig: [{ axisMode: 'left', forAccessor: 'referenceLine-a', type: 'lens_xy_yConfig' }], - }, - ], - } as XYArgs, - }; -} - -describe('xy_expression', () => { - describe('configs', () => { - test('legendConfig produces the correct arguments', () => { - const args: LegendConfig = { - isVisible: true, - position: Position.Left, - }; - - const result = legendConfig.fn(null, args, createMockExecutionContext()); - - expect(result).toEqual({ - type: 'lens_xy_legendConfig', - ...args, - }); - }); - - test('dataLayerConfig produces the correct arguments', () => { - const args: DataLayerArgs = { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'c', - accessors: ['a', 'b'], - splitAccessor: 'd', - xScaleType: 'linear', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }; - - const result = dataLayerConfig.fn(null, args, createMockExecutionContext()); - - expect(result).toEqual({ - type: 'lens_xy_data_layer', - ...args, - }); - }); - }); - - test('tickLabelsConfig produces the correct arguments', () => { - const args: AxesSettingsConfig = { - x: true, - yLeft: false, - yRight: false, - }; - - const result = tickLabelsConfig.fn(null, args, createMockExecutionContext()); - - expect(result).toEqual({ - type: 'lens_xy_tickLabelsConfig', - ...args, - }); - }); - - test('gridlinesConfig produces the correct arguments', () => { - const args: AxesSettingsConfig = { - x: true, - yLeft: false, - yRight: false, - }; - - const result = gridlinesConfig.fn(null, args, createMockExecutionContext()); - - expect(result).toEqual({ - type: 'lens_xy_gridlinesConfig', - ...args, - }); - }); - - test('labelsOrientationConfig produces the correct arguments', () => { - const args: LabelsOrientationConfig = { - x: 0, - yLeft: -90, - yRight: -45, - }; - - const result = labelsOrientationConfig.fn(null, args, createMockExecutionContext()); - - expect(result).toEqual({ - type: 'lens_xy_labelsOrientationConfig', - ...args, - }); - }); - - describe('xyChart', () => { - test('it renders with the specified data and args', () => { - const { data, args } = sampleArgs(); - const result = xyChart.fn(data, args, createMockExecutionContext()); - - expect(result).toEqual({ - type: 'render', - as: 'lens_xy_chart_renderer', - value: { data, args }, - }); - }); - }); - - describe('XYChart component', () => { - let getFormatSpy: jest.Mock; - let convertSpy: jest.Mock; - let defaultProps: Omit; - - const dataWithoutFormats: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - type: 'datatable', - columns: [ - { id: 'a', name: 'a', meta: { type: 'number' } }, - { id: 'b', name: 'b', meta: { type: 'number' } }, - { id: 'c', name: 'c', meta: { type: 'string' } }, - { id: 'd', name: 'd', meta: { type: 'string' } }, - ], - rows: [ - { a: 1, b: 2, c: 'I', d: 'Row 1' }, - { a: 1, b: 5, c: 'J', d: 'Row 2' }, - ], - }, - }, - }; - const dataWithFormats: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - type: 'datatable', - columns: [ - { id: 'a', name: 'a', meta: { type: 'number' } }, - { id: 'b', name: 'b', meta: { type: 'number' } }, - { id: 'c', name: 'c', meta: { type: 'string' } }, - { id: 'd', name: 'd', meta: { type: 'string', params: { id: 'custom' } } }, - ], - rows: [ - { a: 1, b: 2, c: 'I', d: 'Row 1' }, - { a: 1, b: 5, c: 'J', d: 'Row 2' }, - ], - }, - }, - }; - - const getRenderedComponent = (data: LensMultiTable, args: XYArgs) => { - return shallow(); - }; - - beforeEach(() => { - convertSpy = jest.fn((x) => x); - getFormatSpy = jest.fn(); - getFormatSpy.mockReturnValue({ convert: convertSpy }); - - defaultProps = { - formatFactory: getFormatSpy, - timeZone: 'UTC', - renderMode: 'view', - chartsThemeService, - chartsActiveCursorService, - paletteService, - minInterval: 50, - onClickValue, - onSelectRange, - syncColors: false, - useLegacyTimeAxis: false, - eventAnnotationService: eventAnnotationServiceMock, - }; - }); - - test('it renders line', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(LineSeries)).toHaveLength(2); - expect(component.find(LineSeries).at(0).prop('yAccessors')).toEqual(['a']); - expect(component.find(LineSeries).at(1).prop('yAccessors')).toEqual(['b']); - }); - - describe('date range', () => { - const timeSampleLayer: DataLayerArgs = { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'c', - accessors: ['a', 'b'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', - xScaleType: 'time', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }; - const multiLayerArgs = createArgsWithLayers([ - timeSampleLayer, - { - ...timeSampleLayer, - layerId: 'second', - seriesType: 'bar', - xScaleType: 'time', - }, - ]); - test('it uses the full date range', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - c.id !== 'c' - ? c - : { - ...c, - meta: { - type: 'date', - source: 'esaggs', - sourceParams: { - type: 'date_histogram', - params: {}, - appliedTimeRange: { - from: '2019-01-02T05:00:00.000Z', - to: '2019-01-03T05:00:00.000Z', - }, - }, - }, - } - ), - }, - }, - }} - args={{ - ...args, - layers: [ - { ...(args.layers[0] as DataLayerArgs), seriesType: 'line', xScaleType: 'time' }, - ], - }} - minInterval={undefined} - /> - ); - expect(component.find(Settings).prop('xDomain')).toMatchInlineSnapshot(` - Object { - "max": 1546491600000, - "min": 1546405200000, - "minInterval": undefined, - } - `); - }); - - test('it uses passed in minInterval', () => { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: createSampleDatatableWithRows([{ a: 1, b: 2, c: 'I', d: 'Foo' }]), - second: createSampleDatatableWithRows([]), - }, - }; - - const component = shallow(); - - // real auto interval is 30mins = 1800000 - expect(component.find(Settings).prop('xDomain')).toMatchInlineSnapshot(` - Object { - "max": NaN, - "min": NaN, - "minInterval": 50, - } - `); - }); - - describe('axis time', () => { - const defaultTimeLayer: DataLayerArgs = { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'c', - accessors: ['a', 'b'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A", "b": "Label B", "d": "Label D"}', - xScaleType: 'time', - yScaleType: 'linear', - isHistogram: true, - palette: mockPaletteOutput, - }; - test('it should disable the new time axis for a line time layer when isHistogram is set to false', () => { - const { data } = sampleArgs(); - - const instance = shallow( - - ); - - const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); - - expect(axisStyle).toBe(0); - }); - test('it should enable the new time axis for a line time layer when isHistogram is set to true', () => { - const { data } = sampleArgs(); - const timeLayerArgs = createArgsWithLayers([defaultTimeLayer]); - - const instance = shallow( - - ); - - const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); - - expect(axisStyle).toBe(3); - }); - test('it should disable the new time axis for a vertical bar with break down dimension', () => { - const { data } = sampleArgs(); - const timeLayer: DataLayerArgs = { - ...defaultTimeLayer, - seriesType: 'bar', - }; - const timeLayerArgs = createArgsWithLayers([timeLayer]); - - const instance = shallow( - - ); - - const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); - - expect(axisStyle).toBe(0); - }); - - test('it should enable the new time axis for a stacked vertical bar with break down dimension', () => { - const { data } = sampleArgs(); - const timeLayer: DataLayerArgs = { - ...defaultTimeLayer, - seriesType: 'bar_stacked', - }; - const timeLayerArgs = createArgsWithLayers([timeLayer]); - - const instance = shallow( - - ); - - const axisStyle = instance.find(Axis).first().prop('timeAxisLayerCount'); - - expect(axisStyle).toBe(3); - }); - }); - describe('endzones', () => { - const { args } = sampleArgs(); - const table = createSampleDatatableWithRows([ - { a: 1, b: 2, c: new Date('2021-04-22').valueOf(), d: 'Foo' }, - { a: 1, b: 2, c: new Date('2021-04-23').valueOf(), d: 'Foo' }, - { a: 1, b: 2, c: new Date('2021-04-24').valueOf(), d: 'Foo' }, - ]); - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - ...table, - columns: table.columns.map((c) => - c.id !== 'c' - ? c - : { - ...c, - meta: { - type: 'date', - source: 'esaggs', - sourceParams: { - type: 'date_histogram', - params: {}, - appliedTimeRange: { - from: '2021-04-22T12:00:00.000Z', - to: '2021-04-24T12:00:00.000Z', - }, - }, - }, - } - ), - }, - }, - dateRange: { - // first and last bucket are partial - fromDate: new Date('2021-04-22T12:00:00.000Z'), - toDate: new Date('2021-04-24T12:00:00.000Z'), - }, - }; - const timeArgs: XYArgs = { - ...args, - layers: [ - { - ...(args.layers[0] as DataLayerArgs), - seriesType: 'line', - xScaleType: 'time', - isHistogram: true, - splitAccessor: undefined, - }, - ], - }; - - test('it extends interval if data is exceeding it', () => { - const component = shallow( - - ); - - expect(component.find(Settings).prop('xDomain')).toEqual({ - // shortened to 24th midnight (elastic-charts automatically adds one min interval) - max: new Date('2021-04-24').valueOf(), - // extended to 22nd midnight because of first bucket - min: new Date('2021-04-22').valueOf(), - minInterval: 24 * 60 * 60 * 1000, - }); - }); - - test('it renders endzone component bridging gap between domain and extended domain', () => { - const component = shallow( - - ); - - expect(component.find(XyEndzones).dive().find('Endzones').props()).toEqual( - expect.objectContaining({ - domainStart: new Date('2021-04-22T12:00:00.000Z').valueOf(), - domainEnd: new Date('2021-04-24T12:00:00.000Z').valueOf(), - domainMin: new Date('2021-04-22').valueOf(), - domainMax: new Date('2021-04-24').valueOf(), - }) - ); - }); - - test('should pass enabled histogram mode and min interval to endzones component', () => { - const component = shallow( - - ); - - expect(component.find(XyEndzones).dive().find('Endzones').props()).toEqual( - expect.objectContaining({ - interval: 24 * 60 * 60 * 1000, - isFullBin: false, - }) - ); - }); - - test('should pass disabled histogram mode and min interval to endzones component', () => { - const component = shallow( - - ); - - expect(component.find(XyEndzones).dive().find('Endzones').props()).toEqual( - expect.objectContaining({ - interval: 24 * 60 * 60 * 1000, - isFullBin: true, - }) - ); - }); - - test('it does not render endzones if disabled via settings', () => { - const component = shallow( - - ); - - expect(component.find(XyEndzones).length).toEqual(0); - }); - }); - }); - - describe('y axis extents', () => { - test('it passes custom y axis extents to elastic-charts axis spec', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: false, - min: 123, - max: 456, - }); - }); - - test('it passes fit to bounds y axis extents to elastic-charts axis spec', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: true, - min: NaN, - max: NaN, - }); - }); - - test('it does not allow fit for area chart', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: false, - min: NaN, - max: NaN, - }); - }); - - test('it does not allow positive lower bound for bar', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: false, - min: NaN, - max: NaN, - }); - }); - - test('it does include referenceLine values when in full extent mode', () => { - const { data, args } = sampleArgsWithReferenceLine(); - - const component = shallow(); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: false, - min: 0, - max: 150, - }); - }); - - test('it should ignore referenceLine values when set to custom extents', () => { - const { data, args } = sampleArgsWithReferenceLine(); - - const component = shallow( - - ); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: false, - min: 123, - max: 456, - }); - }); - - test('it should work for negative values in referenceLines', () => { - const { data, args } = sampleArgsWithReferenceLine(-150); - - const component = shallow(); - expect(component.find(Axis).find('[id="left"]').prop('domain')).toEqual({ - fit: false, - min: -150, - max: 5, - }); - }); - }); - - test('it has xDomain undefined if the x is not a time scale or a histogram', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - const xDomain = component.find(Settings).prop('xDomain'); - expect(xDomain).toEqual(undefined); - }); - - test('it uses min interval if interval is passed in and visualization is histogram', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(Settings).prop('xDomain')).toEqual({ - minInterval: 101, - min: NaN, - max: NaN, - }); - }); - - test('disabled legend extra by default', () => { - const { data, args } = sampleArgs(); - const component = shallow(); - expect(component.find(Settings).at(0).prop('showLegendExtra')).toEqual(false); - }); - - test('ignores legend extra for ordinal chart', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component.find(Settings).at(0).prop('showLegendExtra')).toEqual(false); - }); - - test('shows legend extra for histogram chart', () => { - const { args } = sampleArgs(); - const component = shallow( - - ); - expect(component.find(Settings).at(0).prop('showLegendExtra')).toEqual(true); - }); - - test('it renders bar', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(BarSeries)).toHaveLength(2); - expect(component.find(BarSeries).at(0).prop('yAccessors')).toEqual(['a']); - expect(component.find(BarSeries).at(1).prop('yAccessors')).toEqual(['b']); - }); - - test('it renders area', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(AreaSeries)).toHaveLength(2); - expect(component.find(AreaSeries).at(0).prop('yAccessors')).toEqual(['a']); - expect(component.find(AreaSeries).at(1).prop('yAccessors')).toEqual(['b']); - }); - - test('it renders horizontal bar', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(BarSeries)).toHaveLength(2); - expect(component.find(BarSeries).at(0).prop('yAccessors')).toEqual(['a']); - expect(component.find(BarSeries).at(1).prop('yAccessors')).toEqual(['b']); - expect(component.find(Settings).prop('rotation')).toEqual(90); - }); - - test('it renders regular bar empty placeholder for no results', () => { - const { data, args } = sampleArgs(); - - // send empty data to the chart - data.tables.first.rows = []; - - const component = shallow(); - - expect(component.find(BarSeries)).toHaveLength(0); - expect(component.find(EmptyPlaceholder).prop('icon')).toBeDefined(); - }); - - test('onBrushEnd returns correct context data for date histogram data', () => { - const { args } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - wrapper.find(Settings).first().prop('onBrushEnd')!({ x: [1585757732783, 1585758880838] }); - - expect(onSelectRange).toHaveBeenCalledWith({ - column: 0, - table: dateHistogramData.tables.timeLayer, - range: [1585757732783, 1585758880838], - }); - }); - - test('onBrushEnd returns correct context data for number histogram data', () => { - const { args } = sampleArgs(); - - const numberLayer: DataLayerArgs = { - layerId: 'numberLayer', - layerType: layerTypes.DATA, - hide: false, - xAccessor: 'xAccessorId', - yScaleType: 'linear', - xScaleType: 'linear', - isHistogram: true, - seriesType: 'bar_stacked', - accessors: ['yAccessorId'], - palette: mockPaletteOutput, - }; - - const numberHistogramData: LensMultiTable = { - type: 'lens_multitable', - tables: { - numberLayer: { - type: 'datatable', - rows: [ - { - xAccessorId: 5, - yAccessorId: 1, - }, - { - xAccessorId: 7, - yAccessorId: 1, - }, - { - xAccessorId: 8, - yAccessorId: 1, - }, - { - xAccessorId: 10, - yAccessorId: 1, - }, - ], - columns: [ - { - id: 'xAccessorId', - name: 'bytes', - meta: { type: 'number' }, - }, - { - id: 'yAccessorId', - name: 'Count of records', - meta: { type: 'number' }, - }, - ], - }, - }, - dateRange: { - fromDate: new Date('2020-04-01T16:14:16.246Z'), - toDate: new Date('2020-04-01T17:15:41.263Z'), - }, - }; - - const wrapper = mountWithIntl( - - ); - - wrapper.find(Settings).first().prop('onBrushEnd')!({ x: [5, 8] }); - - expect(onSelectRange).toHaveBeenCalledWith({ - column: 0, - table: numberHistogramData.tables.numberLayer, - range: [5, 8], - }); - }); - - test('onBrushEnd is not set on non-interactive mode', () => { - const { args, data } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - - expect(wrapper.find(Settings).first().prop('onBrushEnd')).toBeUndefined(); - }); - - test('allowBrushingLastHistogramBin is true for date histogram data', () => { - const { args } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - expect(wrapper.find(Settings).at(0).prop('allowBrushingLastHistogramBin')).toEqual(true); - }); - - test('onElementClick returns correct context data', () => { - const geometry: GeometryValue = { x: 5, y: 1, accessor: 'y1', mark: null, datum: {} }; - const series = { - key: 'spec{d}yAccessor{d}splitAccessors{b-2}', - specId: 'd', - yAccessor: 'd', - splitAccessors: {}, - seriesKeys: [2, 'd'], - }; - - const { args, data } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - - wrapper.find(Settings).first().prop('onElementClick')!([ - [geometry, series as XYChartSeriesIdentifier], - ]); - - expect(onClickValue).toHaveBeenCalledWith({ - data: [ - { - column: 1, - row: 1, - table: data.tables.first, - value: 5, - }, - { - column: 1, - row: 0, - table: data.tables.first, - value: 2, - }, - ], - }); - }); - - test('onElementClick returns correct context data for date histogram', () => { - const geometry: GeometryValue = { - x: 1585758120000, - y: 1, - accessor: 'y1', - mark: null, - datum: {}, - }; - const series = { - key: 'spec{d}yAccessor{d}splitAccessors{b-2}', - specId: 'd', - yAccessor: 'yAccessorId', - splitAccessors: {}, - seriesKeys: ['yAccessorId'], - }; - - const { args } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - - wrapper.find(Settings).first().prop('onElementClick')!([ - [geometry, series as XYChartSeriesIdentifier], - ]); - - expect(onClickValue).toHaveBeenCalledWith({ - data: [ - { - column: 0, - row: 0, - table: dateHistogramData.tables.timeLayer, - value: 1585758120000, - }, - ], - }); - }); - - test('onElementClick returns correct context data for numeric histogram', () => { - const { args } = sampleArgs(); - - const numberLayer: DataLayerArgs = { - layerId: 'numberLayer', - layerType: layerTypes.DATA, - hide: false, - xAccessor: 'xAccessorId', - yScaleType: 'linear', - xScaleType: 'linear', - isHistogram: true, - seriesType: 'bar_stacked', - accessors: ['yAccessorId'], - palette: mockPaletteOutput, - }; - - const numberHistogramData: LensMultiTable = { - type: 'lens_multitable', - tables: { - numberLayer: { - type: 'datatable', - rows: [ - { - xAccessorId: 5, - yAccessorId: 1, - }, - { - xAccessorId: 7, - yAccessorId: 1, - }, - { - xAccessorId: 8, - yAccessorId: 1, - }, - { - xAccessorId: 10, - yAccessorId: 1, - }, - ], - columns: [ - { - id: 'xAccessorId', - name: 'bytes', - meta: { type: 'number' }, - }, - { - id: 'yAccessorId', - name: 'Count of records', - meta: { type: 'number' }, - }, - ], - }, - }, - dateRange: { - fromDate: new Date('2020-04-01T16:14:16.246Z'), - toDate: new Date('2020-04-01T17:15:41.263Z'), - }, - }; - const geometry: GeometryValue = { - x: 5, - y: 1, - accessor: 'y1', - mark: null, - datum: {}, - }; - const series = { - key: 'spec{d}yAccessor{d}splitAccessors{b-2}', - specId: 'd', - yAccessor: 'yAccessorId', - splitAccessors: {}, - seriesKeys: ['yAccessorId'], - }; - - const wrapper = mountWithIntl( - - ); - - wrapper.find(Settings).first().prop('onElementClick')!([ - [geometry, series as XYChartSeriesIdentifier], - ]); - - expect(onClickValue).toHaveBeenCalledWith({ - data: [ - { - column: 0, - row: 0, - table: numberHistogramData.tables.numberLayer, - value: 5, - }, - ], - timeFieldName: undefined, - }); - }); - - test('returns correct original data for ordinal x axis with special formatter', () => { - const geometry: GeometryValue = { x: 'BAR', y: 1, accessor: 'y1', mark: null, datum: {} }; - const series = { - key: 'spec{d}yAccessor{d}splitAccessors{b-2}', - specId: 'd', - yAccessor: 'a', - splitAccessors: {}, - seriesKeys: ['a'], - }; - - const { args, data } = sampleArgs(); - - convertSpy.mockImplementation((x) => (typeof x === 'string' ? x.toUpperCase() : x)); - - const wrapper = mountWithIntl( - - ); - - wrapper.find(Settings).first().prop('onElementClick')!([ - [geometry, series as XYChartSeriesIdentifier], - ]); - - expect(onClickValue).toHaveBeenCalledWith({ - data: [ - { - column: 3, - row: 1, - table: data.tables.first, - value: 'Bar', - }, - ], - }); - }); - - test('sets up correct yScaleType equal to binary_linear for bytes formatting', () => { - const { args, data } = sampleArgs(); - data.tables.first.columns[0].meta = { - type: 'number', - params: { id: 'bytes', params: { pattern: '0,0.00b' } }, - }; - - const wrapper = mountWithIntl( - - ); - - expect(wrapper.find(LineSeries).at(0).prop('yScaleType')).toEqual('linear_binary'); - }); - - test('allowBrushingLastHistogramBin should be fakse for ordinal data', () => { - const { args, data } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - - expect(wrapper.find(Settings).at(0).prop('allowBrushingLastHistogramBin')).toEqual(false); - }); - - test('onElementClick is not triggering event on non-interactive mode', () => { - const { args, data } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - - expect(wrapper.find(Settings).first().prop('onElementClick')).toBeUndefined(); - }); - - test('legendAction is not triggering event on non-interactive mode', () => { - const { args, data } = sampleArgs(); - - const wrapper = mountWithIntl( - - ); - - expect(wrapper.find(Settings).first().prop('legendAction')).toBeUndefined(); - }); - - test('it renders stacked bar', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(BarSeries)).toHaveLength(2); - expect(component.find(BarSeries).at(0).prop('stackAccessors')).toHaveLength(1); - expect(component.find(BarSeries).at(1).prop('stackAccessors')).toHaveLength(1); - }); - - test('it renders stacked area', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(AreaSeries)).toHaveLength(2); - expect(component.find(AreaSeries).at(0).prop('stackAccessors')).toHaveLength(1); - expect(component.find(AreaSeries).at(1).prop('stackAccessors')).toHaveLength(1); - }); - - test('it renders stacked horizontal bar', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component).toMatchSnapshot(); - expect(component.find(BarSeries)).toHaveLength(2); - expect(component.find(BarSeries).at(0).prop('stackAccessors')).toHaveLength(1); - expect(component.find(BarSeries).at(1).prop('stackAccessors')).toHaveLength(1); - expect(component.find(Settings).prop('rotation')).toEqual(90); - }); - - test('it renders stacked bar empty placeholder for no results', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - - expect(component.find(BarSeries)).toHaveLength(0); - expect(component.find(EmptyPlaceholder).prop('icon')).toBeDefined(); - }); - - test('it passes time zone to the series', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component.find(LineSeries).at(0).prop('timeZone')).toEqual('CEST'); - expect(component.find(LineSeries).at(1).prop('timeZone')).toEqual('CEST'); - }); - - test('it applies histogram mode to the series for single series', () => { - const { data, args } = sampleArgs(); - const firstLayer: DataLayerArgs = { - ...args.layers[0], - accessors: ['b'], - seriesType: 'bar', - isHistogram: true, - } as DataLayerArgs; - delete firstLayer.splitAccessor; - const component = shallow( - - ); - expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(true); - }); - - test('it does not apply histogram mode to more than one bar series for unstacked bar chart', () => { - const { data, args } = sampleArgs(); - const firstLayer: DataLayerArgs = { - ...args.layers[0], - seriesType: 'bar', - isHistogram: true, - } as DataLayerArgs; - delete firstLayer.splitAccessor; - const component = shallow( - - ); - expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(false); - expect(component.find(BarSeries).at(1).prop('enableHistogramMode')).toEqual(false); - }); - - test('it applies histogram mode to more than one the series for unstacked line/area chart', () => { - const { data, args } = sampleArgs(); - const firstLayer: DataLayerArgs = { - ...args.layers[0], - seriesType: 'line', - isHistogram: true, - } as DataLayerArgs; - delete firstLayer.splitAccessor; - const secondLayer: DataLayerArgs = { - ...args.layers[0], - seriesType: 'line', - isHistogram: true, - } as DataLayerArgs; - delete secondLayer.splitAccessor; - const component = shallow( - - ); - expect(component.find(LineSeries).at(0).prop('enableHistogramMode')).toEqual(true); - expect(component.find(LineSeries).at(1).prop('enableHistogramMode')).toEqual(true); - }); - - test('it applies histogram mode to the series for stacked series', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(true); - expect(component.find(BarSeries).at(1).prop('enableHistogramMode')).toEqual(true); - }); - - test('it does not apply histogram mode for splitted series', () => { - const { data, args } = sampleArgs(); - const component = shallow( - - ); - expect(component.find(BarSeries).at(0).prop('enableHistogramMode')).toEqual(false); - expect(component.find(BarSeries).at(1).prop('enableHistogramMode')).toEqual(false); - }); - - describe('y axes', () => { - test('single axis if possible', () => { - const args = createArgsWithLayers(); - - const component = getRenderedComponent(dataWithoutFormats, args); - const axes = component.find(Axis); - expect(axes).toHaveLength(2); - }); - - test('multiple axes because of config', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a', 'b'], - yConfig: [ - { - forAccessor: 'a', - axisMode: 'left', - }, - { - forAccessor: 'b', - axisMode: 'right', - }, - ], - }, - ], - } as XYArgs; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const axes = component.find(Axis); - expect(axes).toHaveLength(3); - expect(component.find(LineSeries).at(0).prop('groupId')).toEqual( - axes.at(1).prop('groupId') - ); - expect(component.find(LineSeries).at(1).prop('groupId')).toEqual( - axes.at(2).prop('groupId') - ); - }); - - test('multiple axes because of incompatible formatters', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['c', 'd'], - }, - ], - } as XYArgs; - - const component = getRenderedComponent(dataWithFormats, newArgs); - const axes = component.find(Axis); - expect(axes).toHaveLength(3); - expect(component.find(LineSeries).at(0).prop('groupId')).toEqual( - axes.at(1).prop('groupId') - ); - expect(component.find(LineSeries).at(1).prop('groupId')).toEqual( - axes.at(2).prop('groupId') - ); - }); - - test('single axis despite different formatters if enforced', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['c', 'd'], - yConfig: [ - { - forAccessor: 'c', - axisMode: 'left', - }, - { - forAccessor: 'd', - axisMode: 'left', - }, - ], - }, - ], - } as XYArgs; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const axes = component.find(Axis); - expect(axes).toHaveLength(2); - }); - }); - - describe('y series coloring', () => { - test('color is applied to chart for multiple series', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - splitAccessor: undefined, - accessors: ['a', 'b'], - yConfig: [ - { - forAccessor: 'a', - color: '#550000', - }, - { - forAccessor: 'b', - color: '#FFFF00', - }, - ], - }, - { - ...args.layers[0], - splitAccessor: undefined, - accessors: ['c'], - yConfig: [ - { - forAccessor: 'c', - color: '#FEECDF', - }, - ], - }, - ], - } as XYArgs; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - expect( - (component.find(LineSeries).at(0).prop('color') as Function)!({ - yAccessor: 'a', - seriesKeys: ['a'], - }) - ).toEqual('#550000'); - expect( - (component.find(LineSeries).at(1).prop('color') as Function)!({ - yAccessor: 'b', - seriesKeys: ['b'], - }) - ).toEqual('#FFFF00'); - expect( - (component.find(LineSeries).at(2).prop('color') as Function)!({ - yAccessor: 'c', - seriesKeys: ['c'], - }) - ).toEqual('#FEECDF'); - }); - test('color is not applied to chart when splitAccessor is defined or when yConfig is not configured', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a'], - yConfig: [ - { - forAccessor: 'a', - color: '#550000', - }, - ], - }, - { - ...args.layers[0], - splitAccessor: undefined, - accessors: ['c'], - }, - ], - } as XYArgs; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - expect( - (component.find(LineSeries).at(0).prop('color') as Function)!({ - yAccessor: 'a', - seriesKeys: ['a'], - }) - ).toEqual('blue'); - expect( - (component.find(LineSeries).at(1).prop('color') as Function)!({ - yAccessor: 'c', - seriesKeys: ['c'], - }) - ).toEqual('blue'); - }); - }); - - describe('provides correct series naming', () => { - const nameFnArgs = { - seriesKeys: [], - key: '', - specId: 'a', - yAccessor: '', - splitAccessors: new Map(), - }; - - test('simplest xy chart without human-readable name', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a'], - splitAccessor: undefined, - columnToLabel: '', - }, - ], - }; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; - - // In this case, the ID is used as the name. This shouldn't happen in practice - expect(nameFn({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual(''); - expect(nameFn({ ...nameFnArgs, seriesKeys: ['nonsense'] }, false)).toEqual(''); - }); - - test('simplest xy chart with empty name', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a'], - splitAccessor: undefined, - columnToLabel: '{"a":""}', - }, - ], - }; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; - - // In this case, the ID is used as the name. This shouldn't happen in practice - expect(nameFn({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual(''); - expect(nameFn({ ...nameFnArgs, seriesKeys: ['nonsense'] }, false)).toEqual(''); - }); - - test('simplest xy chart with human-readable name', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a'], - splitAccessor: undefined, - columnToLabel: '{"a":"Column A"}', - }, - ], - }; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; - - expect(nameFn({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual('Column A'); - }); - - test('multiple y accessors', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a', 'b'], - splitAccessor: undefined, - columnToLabel: '{"a": "Label A"}', - }, - ], - }; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const nameFn1 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; - const nameFn2 = component.find(LineSeries).at(1).prop('name') as SeriesNameFn; - - // This accessor has a human-readable name - expect(nameFn1({ ...nameFnArgs, seriesKeys: ['a'] }, false)).toEqual('Label A'); - // This accessor does not - expect(nameFn2({ ...nameFnArgs, seriesKeys: ['b'] }, false)).toEqual(''); - expect(nameFn1({ ...nameFnArgs, seriesKeys: ['nonsense'] }, false)).toEqual(''); - }); - - test('split series without formatting and single y accessor', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A"}', - }, - ], - }; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; - - expect(nameFn({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual('split1'); - }); - - test('split series with formatting and single y accessor', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A"}', - }, - ], - }; - - const component = getRenderedComponent(dataWithFormats, newArgs); - const nameFn = component.find(LineSeries).prop('name') as SeriesNameFn; - - convertSpy.mockReturnValueOnce('formatted'); - expect(nameFn({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual('formatted'); - expect(getFormatSpy).toHaveBeenCalledWith({ id: 'custom' }); - }); - - test('split series without formatting with multiple y accessors', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a', 'b'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A","b": "Label B"}', - }, - ], - }; - - const component = getRenderedComponent(dataWithoutFormats, newArgs); - const nameFn1 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; - const nameFn2 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; - - expect(nameFn1({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual( - 'split1 - Label A' - ); - expect(nameFn2({ ...nameFnArgs, seriesKeys: ['split1', 'b'] }, false)).toEqual( - 'split1 - Label B' - ); - }); - - test('split series with formatting with multiple y accessors', () => { - const args = createArgsWithLayers(); - const newArgs = { - ...args, - layers: [ - { - ...args.layers[0], - accessors: ['a', 'b'], - splitAccessor: 'd', - columnToLabel: '{"a": "Label A","b": "Label B"}', - }, - ], - }; - - const component = getRenderedComponent(dataWithFormats, newArgs); - const nameFn1 = component.find(LineSeries).at(0).prop('name') as SeriesNameFn; - const nameFn2 = component.find(LineSeries).at(1).prop('name') as SeriesNameFn; - - convertSpy.mockReturnValueOnce('formatted1').mockReturnValueOnce('formatted2'); - expect(nameFn1({ ...nameFnArgs, seriesKeys: ['split1', 'a'] }, false)).toEqual( - 'formatted1 - Label A' - ); - expect(nameFn2({ ...nameFnArgs, seriesKeys: ['split1', 'b'] }, false)).toEqual( - 'formatted2 - Label B' - ); - }); - }); - - test('it set the scale of the x axis according to the args prop', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(LineSeries).at(0).prop('xScaleType')).toEqual(ScaleType.Ordinal); - expect(component.find(LineSeries).at(1).prop('xScaleType')).toEqual(ScaleType.Ordinal); - }); - - test('it set the scale of the y axis according to the args prop', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - expect(component.find(LineSeries).at(0).prop('yScaleType')).toEqual(ScaleType.Sqrt); - expect(component.find(LineSeries).at(1).prop('yScaleType')).toEqual(ScaleType.Sqrt); - }); - - test('it gets the formatter for the x axis', () => { - const { data, args } = sampleArgs(); - - shallow(); - - expect(getFormatSpy).toHaveBeenCalledWith({ id: 'string' }); - }); - - test('it gets the formatter for the y axis if there is only one accessor', () => { - const { data, args } = sampleArgs(); - - shallow( - - ); - expect(getFormatSpy).toHaveBeenCalledWith({ - id: 'number', - params: { pattern: '0,0.000' }, - }); - }); - - test('it should pass the formatter function to the axis', () => { - const { data, args } = sampleArgs(); - - const instance = shallow(); - - const tickFormatter = instance.find(Axis).first().prop('tickFormat'); - - if (!tickFormatter) { - throw new Error('tickFormatter prop not found'); - } - - tickFormatter('I'); - - expect(convertSpy).toHaveBeenCalledWith('I'); - }); - - test('it should set the tickLabel visibility on the x axis if the tick labels is hidden', () => { - const { data, args } = sampleArgs(); - - args.tickLabelsVisibilitySettings = { - x: false, - yLeft: true, - yRight: true, - type: 'lens_xy_tickLabelsConfig', - }; - - const instance = shallow(); - - const axisStyle = instance.find(Axis).first().prop('style'); - - expect(axisStyle).toMatchObject({ - tickLabel: { - visible: false, - }, - }); - }); - - test('it should set the tickLabel visibility on the y axis if the tick labels is hidden', () => { - const { data, args } = sampleArgs(); - - args.tickLabelsVisibilitySettings = { - x: true, - yLeft: false, - yRight: false, - type: 'lens_xy_tickLabelsConfig', - }; - - const instance = shallow(); - - const axisStyle = instance.find(Axis).at(1).prop('style'); - - expect(axisStyle).toMatchObject({ - tickLabel: { - visible: false, - }, - }); - }); - - test('it should set the tickLabel visibility on the x axis if the tick labels is shown', () => { - const { data, args } = sampleArgs(); - - args.tickLabelsVisibilitySettings = { - x: true, - yLeft: true, - yRight: true, - type: 'lens_xy_tickLabelsConfig', - }; - - const instance = shallow(); - - const axisStyle = instance.find(Axis).first().prop('style'); - - expect(axisStyle).toMatchObject({ - tickLabel: { - visible: true, - }, - }); - }); - - test('it should set the tickLabel orientation on the x axis', () => { - const { data, args } = sampleArgs(); - - args.labelsOrientation = { - x: -45, - yLeft: 0, - yRight: -90, - type: 'lens_xy_labelsOrientationConfig', - }; - - const instance = shallow(); - - const axisStyle = instance.find(Axis).first().prop('style'); - - expect(axisStyle).toMatchObject({ - tickLabel: { - rotation: -45, - }, - }); - }); - - test('it should set the tickLabel visibility on the y axis if the tick labels is shown', () => { - const { data, args } = sampleArgs(); - - args.tickLabelsVisibilitySettings = { - x: false, - yLeft: true, - yRight: true, - type: 'lens_xy_tickLabelsConfig', - }; - - const instance = shallow(); - - const axisStyle = instance.find(Axis).at(1).prop('style'); - - expect(axisStyle).toMatchObject({ - tickLabel: { - visible: true, - }, - }); - }); - - test('it should set the tickLabel orientation on the y axis', () => { - const { data, args } = sampleArgs(); - - args.labelsOrientation = { - x: -45, - yLeft: -90, - yRight: -90, - type: 'lens_xy_labelsOrientationConfig', - }; - - const instance = shallow(); - - const axisStyle = instance.find(Axis).at(1).prop('style'); - - expect(axisStyle).toMatchObject({ - tickLabel: { - rotation: -90, - }, - }); - }); - - test('it should remove invalid rows', () => { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - type: 'datatable', - columns: [ - { id: 'a', name: 'a', meta: { type: 'number' } }, - { id: 'b', name: 'b', meta: { type: 'number' } }, - { id: 'c', name: 'c', meta: { type: 'string' } }, - ], - rows: [ - { a: undefined, b: 2, c: 'I', d: 'Row 1' }, - { a: 1, b: 5, c: 'J', d: 'Row 2' }, - ], - }, - second: { - type: 'datatable', - columns: [ - { id: 'a', name: 'a', meta: { type: 'number' } }, - { id: 'b', name: 'b', meta: { type: 'number' } }, - { id: 'c', name: 'c', meta: { type: 'string' } }, - ], - rows: [ - { a: undefined, b: undefined, c: undefined }, - { a: undefined, b: undefined, c: undefined }, - ], - }, - }, - }; - - const args: XYArgs = { - xTitle: '', - yTitle: '', - yRightTitle: '', - legend: { type: 'lens_xy_legendConfig', isVisible: false, position: Position.Top }, - valueLabels: 'hide', - tickLabelsVisibilitySettings: { - type: 'lens_xy_tickLabelsConfig', - x: true, - yLeft: true, - yRight: true, - }, - gridlinesVisibilitySettings: { - type: 'lens_xy_gridlinesConfig', - x: true, - yLeft: false, - yRight: false, - }, - labelsOrientation: { - type: 'lens_xy_labelsOrientationConfig', - x: 0, - yLeft: 0, - yRight: 0, - }, - yLeftExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - yRightExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - layers: [ - { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'a', - accessors: ['c'], - splitAccessor: 'b', - columnToLabel: '', - xScaleType: 'ordinal', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }, - { - layerId: 'second', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'a', - accessors: ['c'], - splitAccessor: 'b', - columnToLabel: '', - xScaleType: 'ordinal', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }, - ], - }; - - const component = shallow(); - - const series = component.find(LineSeries); - - // Only one series should be rendered, even though 2 are configured - // This one series should only have one row, even though 2 are sent - expect(series.prop('data')).toEqual([{ a: 1, b: 5, c: 'J', d: 'Row 2' }]); - }); - - test('it should not remove rows with falsy but non-undefined values', () => { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - type: 'datatable', - columns: [ - { id: 'a', name: 'a', meta: { type: 'number' } }, - { id: 'b', name: 'b', meta: { type: 'number' } }, - { id: 'c', name: 'c', meta: { type: 'number' } }, - ], - rows: [ - { a: 0, b: 2, c: 5 }, - { a: 1, b: 0, c: 7 }, - ], - }, - }, - }; - - const args: XYArgs = { - xTitle: '', - yTitle: '', - yRightTitle: '', - legend: { type: 'lens_xy_legendConfig', isVisible: false, position: Position.Top }, - valueLabels: 'hide', - tickLabelsVisibilitySettings: { - type: 'lens_xy_tickLabelsConfig', - x: true, - yLeft: false, - yRight: false, - }, - gridlinesVisibilitySettings: { - type: 'lens_xy_gridlinesConfig', - x: true, - yLeft: false, - yRight: false, - }, - labelsOrientation: { - type: 'lens_xy_labelsOrientationConfig', - x: 0, - yLeft: 0, - yRight: 0, - }, - yLeftExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - yRightExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - layers: [ - { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'a', - accessors: ['c'], - splitAccessor: 'b', - columnToLabel: '', - xScaleType: 'ordinal', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }, - ], - }; - - const component = shallow(); - - const series = component.find(LineSeries); - - expect(series.prop('data')).toEqual([ - { a: 0, b: 2, c: 5 }, - { a: 1, b: 0, c: 7 }, - ]); - }); - - test('it should show legend for split series, even with one row', () => { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - type: 'datatable', - columns: [ - { id: 'a', name: 'a', meta: { type: 'number' } }, - { id: 'b', name: 'b', meta: { type: 'number' } }, - { id: 'c', name: 'c', meta: { type: 'string' } }, - ], - rows: [{ a: 1, b: 5, c: 'J' }], - }, - }, - }; - - const args: XYArgs = { - xTitle: '', - yTitle: '', - yRightTitle: '', - legend: { type: 'lens_xy_legendConfig', isVisible: true, position: Position.Top }, - valueLabels: 'hide', - tickLabelsVisibilitySettings: { - type: 'lens_xy_tickLabelsConfig', - x: true, - yLeft: false, - yRight: false, - }, - gridlinesVisibilitySettings: { - type: 'lens_xy_gridlinesConfig', - x: true, - yLeft: false, - yRight: false, - }, - labelsOrientation: { - type: 'lens_xy_labelsOrientationConfig', - x: 0, - yLeft: 0, - yRight: 0, - }, - yLeftExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - yRightExtent: { - mode: 'full', - type: 'lens_xy_axisExtentConfig', - }, - layers: [ - { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'a', - accessors: ['c'], - splitAccessor: 'b', - columnToLabel: '', - xScaleType: 'ordinal', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }, - ], - }; - - const component = shallow(); - - expect(component.find(Settings).prop('showLegend')).toEqual(true); - }); - - test('it should always show legend if showSingleSeries is set', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - - expect(component.find(Settings).prop('showLegend')).toEqual(true); - }); - - test('it should populate the correct legendPosition if isInside is set', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - - expect(component.find(Settings).prop('legendPosition')).toEqual({ - vAlign: VerticalAlignment.Top, - hAlign: HorizontalAlignment.Right, - direction: LayoutDirection.Vertical, - floating: true, - floatingColumns: 1, - }); - }); - - test('it not show legend if isVisible is set to false', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - - expect(component.find(Settings).prop('showLegend')).toEqual(false); - }); - - test('it should show legend on right side', () => { - const { data, args } = sampleArgs(); - - const component = shallow( - - ); - - expect(component.find(Settings).prop('legendPosition')).toEqual('top'); - }); - - test('it should apply the fitting function to all non-bar series', () => { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: createSampleDatatableWithRows([ - { a: 1, b: 2, c: 'I', d: 'Foo' }, - { a: 1, b: 5, c: 'J', d: 'Bar' }, - ]), - }, - }; - - const args: XYArgs = createArgsWithLayers([ - { ...sampleLayer, accessors: ['a'] }, - { ...sampleLayer, seriesType: 'bar', accessors: ['a'] }, - { ...sampleLayer, seriesType: 'area', accessors: ['a'] }, - { ...sampleLayer, seriesType: 'area_stacked', accessors: ['a'] }, - ]); - - const component = shallow( - - ); - - expect(component.find(LineSeries).prop('fit')).toEqual({ type: Fit.Carry }); - expect(component.find(BarSeries).prop('fit')).toEqual(undefined); - expect(component.find(AreaSeries).at(0).prop('fit')).toEqual({ type: Fit.Carry }); - expect(component.find(AreaSeries).at(0).prop('stackAccessors')).toEqual([]); - expect(component.find(AreaSeries).at(1).prop('fit')).toEqual({ type: Fit.Carry }); - expect(component.find(AreaSeries).at(1).prop('stackAccessors')).toEqual(['c']); - }); - - test('it should apply None fitting function if not specified', () => { - const { data, args } = sampleArgs(); - - (args.layers[0] as DataLayerArgs).accessors = ['a']; - - const component = shallow( - - ); - - expect(component.find(LineSeries).prop('fit')).toEqual({ type: Fit.None }); - }); - - test('it should apply the xTitle if is specified', () => { - const { data, args } = sampleArgs(); - - args.xTitle = 'My custom x-axis title'; - - const component = shallow( - - ); - - expect(component.find(Axis).at(0).prop('title')).toEqual('My custom x-axis title'); - }); - - test('it should hide the X axis title if the corresponding switch is off', () => { - const { data, args } = sampleArgs(); - - args.axisTitlesVisibilitySettings = { - x: false, - yLeft: true, - yRight: true, - type: 'lens_xy_axisTitlesVisibilityConfig', - }; - - const component = shallow( - - ); - - const axisStyle = component.find(Axis).first().prop('style'); - - expect(axisStyle).toMatchObject({ - axisTitle: { - visible: false, - }, - }); - }); - - test('it should show the X axis gridlines if the setting is on', () => { - const { data, args } = sampleArgs(); - - args.gridlinesVisibilitySettings = { - x: true, - yLeft: false, - yRight: false, - type: 'lens_xy_gridlinesConfig', - }; - - const component = shallow( - - ); - - expect(component.find(Axis).at(0).prop('gridLine')).toMatchObject({ - visible: true, - }); - }); - - test('it should format the boolean values correctly', () => { - const data: LensMultiTable = { - type: 'lens_multitable', - tables: { - first: { - type: 'datatable', - columns: [ - { - id: 'a', - name: 'a', - meta: { type: 'number', params: { id: 'number', params: { pattern: '0,0.000' } } }, - }, - { - id: 'b', - name: 'b', - meta: { type: 'number', params: { id: 'number', params: { pattern: '000,0' } } }, - }, - { - id: 'c', - name: 'c', - meta: { - type: 'boolean', - params: { id: 'boolean' }, - }, - }, - ], - rows: [ - { a: 5, b: 2, c: 0 }, - { a: 19, b: 5, c: 1 }, - ], - }, - }, - dateRange: { - fromDate: new Date('2019-01-02T05:00:00.000Z'), - toDate: new Date('2019-01-03T05:00:00.000Z'), - }, - }; - const timeSampleLayer: DataLayerArgs = { - layerId: 'first', - layerType: layerTypes.DATA, - seriesType: 'line', - xAccessor: 'c', - accessors: ['a', 'b'], - xScaleType: 'ordinal', - yScaleType: 'linear', - isHistogram: false, - palette: mockPaletteOutput, - }; - const args = createArgsWithLayers([timeSampleLayer]); - - const getCustomFormatSpy = jest.fn(); - getCustomFormatSpy.mockReturnValue({ convert: jest.fn((x) => Boolean(x)) }); - - const component = shallow( - - ); - - expect(component.find(LineSeries).at(1).prop('data')).toEqual([ - { - a: 5, - b: 2, - c: false, - }, - { - a: 19, - b: 5, - c: true, - }, - ]); - }); - - describe('annotations', () => { - const sampleStyledAnnotation: EventAnnotationOutput = { - time: '2022-03-18T08:25:00.000Z', - label: 'Event 1', - icon: 'triangle', - type: 'manual_event_annotation', - color: 'red', - lineStyle: 'dashed', - lineWidth: 3, - }; - const sampleAnnotationLayers: AnnotationLayerArgs[] = [ - { - layerType: layerTypes.ANNOTATIONS, - layerId: 'annotation', - annotations: [ - { - time: '2022-03-18T08:25:17.140Z', - label: 'Annotation', - type: 'manual_event_annotation', - }, - ], - }, - ]; - function sampleArgsWithAnnotation(annotationLayers = sampleAnnotationLayers) { - const { args } = sampleArgs(); - return { - data: dateHistogramData, - args: { - ...args, - layers: [dateHistogramLayer, ...annotationLayers], - } as XYArgs, - }; - } - test('should render basic annotation', () => { - const { data, args } = sampleArgsWithAnnotation(); - const component = mount(); - expect(component.find('LineAnnotation')).toMatchSnapshot(); - }); - test('should render simplified annotation when hide is true', () => { - const { data, args } = sampleArgsWithAnnotation(); - args.layers[0].hide = true; - const component = mount(); - expect(component.find('LineAnnotation')).toMatchSnapshot(); - }); - - test('should render grouped annotations preserving the shared styles', () => { - const { data, args } = sampleArgsWithAnnotation([ - { - layerType: layerTypes.ANNOTATIONS, - layerId: 'annotation', - annotations: [ - sampleStyledAnnotation, - { ...sampleStyledAnnotation, time: '2022-03-18T08:25:00.020Z', label: 'Event 2' }, - { - ...sampleStyledAnnotation, - time: '2022-03-18T08:25:00.001Z', - label: 'Event 3', - }, - ], - }, - ]); - const component = mount(); - const groupedAnnotation = component.find(LineAnnotation); - - expect(groupedAnnotation.length).toEqual(1); - // styles are passed because they are shared, dataValues & header is rounded to the interval - expect(groupedAnnotation).toMatchSnapshot(); - // renders numeric icon for grouped annotations - const marker = mount(
{groupedAnnotation.prop('marker')}
); - const numberIcon = marker.find('NumberIcon'); - expect(numberIcon.length).toEqual(1); - expect(numberIcon.text()).toEqual('3'); - - // checking tooltip - const renderLinks = mount(
{groupedAnnotation.prop('customTooltipDetails')!()}
); - expect(renderLinks.text()).toEqual( - ' Event 1 2022-03-18T08:25:00.000Z Event 3 2022-03-18T08:25:00.001Z Event 2 2022-03-18T08:25:00.020Z' - ); - }); - test('should render grouped annotations with default styles', () => { - const { data, args } = sampleArgsWithAnnotation([ - { - layerType: layerTypes.ANNOTATIONS, - layerId: 'annotation', - annotations: [sampleStyledAnnotation], - }, - { - layerType: layerTypes.ANNOTATIONS, - layerId: 'annotation', - annotations: [ - { - ...sampleStyledAnnotation, - icon: 'square', - color: 'blue', - lineStyle: 'dotted', - lineWidth: 10, - time: '2022-03-18T08:25:00.001Z', - label: 'Event 2', - }, - ], - }, - ]); - const component = mount(); - const groupedAnnotation = component.find(LineAnnotation); - - expect(groupedAnnotation.length).toEqual(1); - // styles are default because they are different for both annotations - expect(groupedAnnotation).toMatchSnapshot(); - }); - test('should not render hidden annotations', () => { - const { data, args } = sampleArgsWithAnnotation([ - { - layerType: layerTypes.ANNOTATIONS, - layerId: 'annotation', - annotations: [ - sampleStyledAnnotation, - { ...sampleStyledAnnotation, time: '2022-03-18T08:30:00.020Z', label: 'Event 2' }, - { - ...sampleStyledAnnotation, - time: '2022-03-18T08:35:00.001Z', - label: 'Event 3', - isHidden: true, - }, - ], - }, - ]); - const component = mount(); - const annotations = component.find(LineAnnotation); - - expect(annotations.length).toEqual(2); - }); - }); - }); - - describe('calculateMinInterval', () => { - let xyProps: XYChartProps; - - beforeEach(() => { - xyProps = sampleArgs(); - (xyProps.args.layers[0] as DataLayerArgs).xScaleType = 'time'; - }); - it('should use first valid layer and determine interval', async () => { - xyProps.data.tables.first.columns[2].meta.source = 'esaggs'; - xyProps.data.tables.first.columns[2].meta.sourceParams = { - type: 'date_histogram', - params: { - used_interval: '5m', - }, - }; - const result = await calculateMinInterval(xyProps); - expect(result).toEqual(5 * 60 * 1000); - }); - - it('should return interval of number histogram if available on first x axis columns', async () => { - (xyProps.args.layers[0] as DataLayerArgs).xScaleType = 'linear'; - xyProps.data.tables.first.columns[2].meta = { - source: 'esaggs', - type: 'number', - field: 'someField', - sourceParams: { - type: 'histogram', - params: { - interval: 'auto', - used_interval: 5, - }, - }, - }; - const result = await calculateMinInterval(xyProps); - expect(result).toEqual(5); - }); - - it('should return undefined if data table is empty', async () => { - xyProps.data.tables.first.rows = []; - xyProps.data.tables.first.columns[2].meta.source = 'esaggs'; - xyProps.data.tables.first.columns[2].meta.sourceParams = { - type: 'date_histogram', - params: { - used_interval: '5m', - }, - }; - const result = await calculateMinInterval(xyProps); - expect(result).toEqual(undefined); - }); - - it('should return undefined if interval can not be checked', async () => { - const result = await calculateMinInterval(xyProps); - expect(result).toEqual(undefined); - }); - - it('should return undefined if date column is not found', async () => { - xyProps.data.tables.first.columns.splice(2, 1); - const result = await calculateMinInterval(xyProps); - expect(result).toEqual(undefined); - }); - - it('should return undefined if x axis is not a date', async () => { - (xyProps.args.layers[0] as DataLayerArgs).xScaleType = 'ordinal'; - xyProps.data.tables.first.columns.splice(2, 1); - const result = await calculateMinInterval(xyProps); - expect(result).toEqual(undefined); - }); - }); -}); diff --git a/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.tsx b/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.tsx deleted file mode 100644 index 7817db573e419..0000000000000 --- a/x-pack/plugins/lens/public/xy_visualization/expression_reference_lines.tsx +++ /dev/null @@ -1,213 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import './expression_reference_lines.scss'; -import React from 'react'; -import { groupBy } from 'lodash'; -import { RectAnnotation, AnnotationDomainType, LineAnnotation, Position } from '@elastic/charts'; -import type { PaletteRegistry } from 'src/plugins/charts/public'; -import type { FieldFormat } from 'src/plugins/field_formats/common'; -import type { ReferenceLineLayerArgs } from '../../common/expressions'; -import type { LensMultiTable } from '../../common/types'; -import { defaultReferenceLineColor } from './color_assignment'; -import { - MarkerBody, - Marker, - LINES_MARKER_SIZE, - mapVerticalToHorizontalPlacement, - getBaseIconPlacement, -} from './annotations_helpers'; - -export interface ReferenceLineAnnotationsProps { - layers: ReferenceLineLayerArgs[]; - data: LensMultiTable; - formatters: Record<'left' | 'right' | 'bottom', FieldFormat | undefined>; - paletteService: PaletteRegistry; - syncColors: boolean; - axesMap: Record<'left' | 'right', boolean>; - isHorizontal: boolean; - paddingMap: Partial>; -} - -export const ReferenceLineAnnotations = ({ - layers, - data, - formatters, - paletteService, - syncColors, - axesMap, - isHorizontal, - paddingMap, -}: ReferenceLineAnnotationsProps) => { - return ( - <> - {layers.flatMap((layer) => { - if (!layer.yConfig) { - return []; - } - const { columnToLabel, yConfig: yConfigs, layerId } = layer; - const columnToLabelMap: Record = columnToLabel - ? JSON.parse(columnToLabel) - : {}; - const table = data.tables[layerId]; - - const row = table.rows[0]; - - const yConfigByValue = yConfigs.sort( - ({ forAccessor: idA }, { forAccessor: idB }) => row[idA] - row[idB] - ); - - const groupedByDirection = groupBy(yConfigByValue, 'fill'); - if (groupedByDirection.below) { - groupedByDirection.below.reverse(); - } - - return yConfigByValue.flatMap((yConfig, i) => { - // Find the formatter for the given axis - const groupId = - yConfig.axisMode === 'bottom' - ? undefined - : yConfig.axisMode === 'right' - ? 'right' - : 'left'; - - const formatter = formatters[groupId || 'bottom']; - - // get the position for vertical chart - const markerPositionVertical = getBaseIconPlacement( - yConfig.iconPosition, - axesMap, - yConfig.axisMode - ); - // the padding map is built for vertical chart - const hasReducedPadding = paddingMap[markerPositionVertical] === LINES_MARKER_SIZE; - - const props = { - groupId, - marker: ( - - ), - markerBody: ( - - ), - // rotate the position if required - markerPosition: isHorizontal - ? mapVerticalToHorizontalPlacement(markerPositionVertical) - : markerPositionVertical, - }; - const annotations = []; - - const dashStyle = - yConfig.lineStyle === 'dashed' - ? [(yConfig.lineWidth || 1) * 3, yConfig.lineWidth || 1] - : yConfig.lineStyle === 'dotted' - ? [yConfig.lineWidth || 1, yConfig.lineWidth || 1] - : undefined; - - const sharedStyle = { - strokeWidth: yConfig.lineWidth || 1, - stroke: yConfig.color || defaultReferenceLineColor, - dash: dashStyle, - }; - - annotations.push( - ({ - dataValue: row[yConfig.forAccessor], - header: columnToLabelMap[yConfig.forAccessor], - details: formatter?.convert(row[yConfig.forAccessor]) || row[yConfig.forAccessor], - }))} - domainType={ - yConfig.axisMode === 'bottom' - ? AnnotationDomainType.XDomain - : AnnotationDomainType.YDomain - } - style={{ - line: { - ...sharedStyle, - opacity: 1, - }, - }} - /> - ); - - if (yConfig.fill && yConfig.fill !== 'none') { - const isFillAbove = yConfig.fill === 'above'; - const indexFromSameType = groupedByDirection[yConfig.fill].findIndex( - ({ forAccessor }) => forAccessor === yConfig.forAccessor - ); - const shouldCheckNextReferenceLine = - indexFromSameType < groupedByDirection[yConfig.fill].length - 1; - annotations.push( - { - const nextValue = shouldCheckNextReferenceLine - ? row[groupedByDirection[yConfig.fill!][indexFromSameType + 1].forAccessor] - : undefined; - if (yConfig.axisMode === 'bottom') { - return { - coordinates: { - x0: isFillAbove ? row[yConfig.forAccessor] : nextValue, - y0: undefined, - x1: isFillAbove ? nextValue : row[yConfig.forAccessor], - y1: undefined, - }, - header: columnToLabelMap[yConfig.forAccessor], - details: - formatter?.convert(row[yConfig.forAccessor]) || row[yConfig.forAccessor], - }; - } - return { - coordinates: { - x0: undefined, - y0: isFillAbove ? row[yConfig.forAccessor] : nextValue, - x1: undefined, - y1: isFillAbove ? nextValue : row[yConfig.forAccessor], - }, - header: columnToLabelMap[yConfig.forAccessor], - details: - formatter?.convert(row[yConfig.forAccessor]) || row[yConfig.forAccessor], - }; - })} - style={{ - ...sharedStyle, - fill: yConfig.color || defaultReferenceLineColor, - opacity: 0.1, - }} - /> - ); - } - return annotations; - }); - })} - - ); -}; diff --git a/x-pack/plugins/lens/public/xy_visualization/expression_thresholds.scss b/x-pack/plugins/lens/public/xy_visualization/expression_thresholds.scss deleted file mode 100644 index 41b30ce40676b..0000000000000 --- a/x-pack/plugins/lens/public/xy_visualization/expression_thresholds.scss +++ /dev/null @@ -1,18 +0,0 @@ -.lnsXyDecorationRotatedWrapper { - display: inline-block; - overflow: hidden; - line-height: $euiLineHeight; - - .lnsXyDecorationRotatedWrapper__label { - display: inline-block; - white-space: nowrap; - transform: translate(0, 100%) rotate(-90deg); - transform-origin: 0 0; - - &::after { - content: ''; - float: left; - margin-top: 100%; - } - } -} \ No newline at end of file diff --git a/x-pack/plugins/lens/public/xy_visualization/index.ts b/x-pack/plugins/lens/public/xy_visualization/index.ts index cfeb1387f689c..daae9a5ef56ff 100644 --- a/x-pack/plugins/lens/public/xy_visualization/index.ts +++ b/x-pack/plugins/lens/public/xy_visualization/index.ts @@ -11,7 +11,6 @@ import type { ExpressionsSetup } from '../../../../../src/plugins/expressions/pu import type { EditorFrameSetup } from '../types'; import type { ChartsPluginSetup } from '../../../../../src/plugins/charts/public'; import type { LensPluginStartDependencies } from '../plugin'; -import { getTimeZone } from '../utils'; import type { FormatFactory } from '../../common'; import { LEGACY_TIME_AXIS } from '../../../../../src/plugins/charts/common'; @@ -26,26 +25,14 @@ export interface XyVisualizationPluginSetupPlugins { export class XyVisualization { setup( core: CoreSetup, - { expressions, formatFactory, editorFrame }: XyVisualizationPluginSetupPlugins + { editorFrame }: XyVisualizationPluginSetupPlugins ) { editorFrame.registerVisualization(async () => { - const { getXyChartRenderer, getXyVisualization } = await import('../async_services'); + const { getXyVisualization } = await import('../async_services'); const [, { charts, fieldFormats, eventAnnotation }] = await core.getStartServices(); const palettes = await charts.palettes.getPalettes(); const eventAnnotationService = await eventAnnotation.getService(); const useLegacyTimeAxis = core.uiSettings.get(LEGACY_TIME_AXIS); - expressions.registerRenderer( - getXyChartRenderer({ - formatFactory, - chartsThemeService: charts.theme, - chartsActiveCursorService: charts.activeCursor, - paletteService: palettes, - eventAnnotationService, - timeZone: getTimeZone(core.uiSettings), - useLegacyTimeAxis, - kibanaTheme: core.theme, - }) - ); return getXyVisualization({ paletteService: palettes, eventAnnotationService, diff --git a/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.test.ts b/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.test.ts index 9def75615e6c8..368b213428ed7 100644 --- a/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.test.ts +++ b/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.test.ts @@ -5,9 +5,9 @@ * 2.0. */ -import { XYDataLayerConfig } from '../../common/expressions'; import { FramePublicAPI } from '../types'; import { computeOverallDataDomain, getStaticValue } from './reference_line_helpers'; +import { XYDataLayerConfig } from './types'; function getActiveData(json: Array<{ id: string; rows: Array> }>) { return json.reduce((memo, { id, rows }) => { @@ -277,6 +277,11 @@ describe('reference_line helpers', () => { layerType: 'data', xAccessor: 'a', accessors: [], + type: 'dataLayer', + yScaleType: 'linear', + xScaleType: 'linear', + isHistogram: false, + palette: { type: 'palette', name: 'palette1' }, } as XYDataLayerConfig, ], 'x', // this is influenced by the callback @@ -300,6 +305,11 @@ describe('reference_line helpers', () => { layerType: 'data', xAccessor: 'a', accessors: [], + type: 'dataLayer', + yScaleType: 'linear', + xScaleType: 'linear', + isHistogram: false, + palette: { type: 'palette', name: 'palette1' }, } as XYDataLayerConfig, ], 'x', diff --git a/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.tsx b/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.tsx index 8b6a96ce24d44..af679d1354792 100644 --- a/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/reference_line_helpers.tsx @@ -9,15 +9,14 @@ import { groupBy, partition } from 'lodash'; import { i18n } from '@kbn/i18n'; import { layerTypes } from '../../common'; import type { - XYDataLayerConfig, - XYReferenceLineLayerConfig, + YAxisMode, YConfig, -} from '../../common/expressions'; +} from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { Datatable } from '../../../../../src/plugins/expressions/public'; import type { DatasourcePublicAPI, FramePublicAPI, Visualization } from '../types'; import { groupAxesByType } from './axes_configuration'; import { isHorizontalChart, isPercentageSeries, isStackedChart } from './state_helpers'; -import type { XYState } from './types'; +import type { XYState, XYDataLayerConfig, XYReferenceLineLayerConfig } from './types'; import { checkScaleOperation, getAxisName, @@ -49,6 +48,7 @@ export function getGroupsToShow groupsAvailable[label] || config?.length) .map((layer) => ({ ...layer, valid: groupsAvailable[layer.label] })); @@ -339,6 +339,13 @@ export const setReferenceDimension: Visualization['setDimension'] = ({ ? newLayer.yConfig?.find(({ forAccessor }) => forAccessor === previousColumn) : false; if (!hasYConfig) { + const axisMode: YAxisMode = + groupId === 'xReferenceLine' + ? 'bottom' + : groupId === 'yReferenceLineRight' + ? 'right' + : 'left'; + newLayer.yConfig = [ ...(newLayer.yConfig || []), { @@ -346,15 +353,11 @@ export const setReferenceDimension: Visualization['setDimension'] = ({ ...previousYConfig, // but keep the new group & id config forAccessor: columnId, - axisMode: - groupId === 'xReferenceLine' - ? 'bottom' - : groupId === 'yReferenceLineRight' - ? 'right' - : 'left', + axisMode, }, ]; } + return { ...prevState, layers: prevState.layers.map((l) => (l.layerId === layerId ? newLayer : l)), diff --git a/x-pack/plugins/lens/public/xy_visualization/state_helpers.ts b/x-pack/plugins/lens/public/xy_visualization/state_helpers.ts index e0984e62cb9cc..d3c8efae33836 100644 --- a/x-pack/plugins/lens/public/xy_visualization/state_helpers.ts +++ b/x-pack/plugins/lens/public/xy_visualization/state_helpers.ts @@ -9,13 +9,15 @@ import { EuiIconType } from '@elastic/eui/src/components/icon/icon'; import type { FramePublicAPI, DatasourcePublicAPI } from '../types'; import type { SeriesType, - XYLayerConfig, YConfig, ValidLayer, +} from '../../../../../src/plugins/chart_expressions/expression_xy/common'; +import { + visualizationTypes, + XYLayerConfig, XYDataLayerConfig, XYReferenceLineLayerConfig, -} from '../../common/expressions'; -import { visualizationTypes } from './types'; +} from './types'; import { getDataLayers, isAnnotationsLayer, isDataLayer } from './visualization_helpers'; export function isHorizontalSeries(seriesType: SeriesType) { diff --git a/x-pack/plugins/lens/public/xy_visualization/to_expression.test.ts b/x-pack/plugins/lens/public/xy_visualization/to_expression.test.ts index 2e3db8f2f6f93..c04781198c78f 100644 --- a/x-pack/plugins/lens/public/xy_visualization/to_expression.test.ts +++ b/x-pack/plugins/lens/public/xy_visualization/to_expression.test.ts @@ -13,9 +13,9 @@ import { OperationDescriptor } from '../types'; import { createMockDatasource, createMockFramePublicAPI } from '../mocks'; import { layerTypes } from '../../common'; import { fieldFormatsServiceMock } from '../../../../../src/plugins/field_formats/public/mocks'; +import { eventAnnotationServiceMock } from '../../../../../src/plugins/event_annotation/public/mocks'; import { defaultReferenceLineColor } from './color_assignment'; import { themeServiceMock } from '../../../../../src/core/public/mocks'; -import { eventAnnotationServiceMock } from 'src/plugins/event_annotation/public/mocks'; describe('#toExpression', () => { const xyVisualization = getXyVisualization({ diff --git a/x-pack/plugins/lens/public/xy_visualization/to_expression.ts b/x-pack/plugins/lens/public/xy_visualization/to_expression.ts index ade90ff98e553..ec9093a999c84 100644 --- a/x-pack/plugins/lens/public/xy_visualization/to_expression.ts +++ b/x-pack/plugins/lens/public/xy_visualization/to_expression.ts @@ -8,18 +8,20 @@ import { Ast } from '@kbn/interpreter'; import { ScaleType } from '@elastic/charts'; import { PaletteRegistry } from 'src/plugins/charts/public'; + import { EventAnnotationServiceType } from 'src/plugins/event_annotation/public'; -import { State } from './types'; +import { + State, + XYDataLayerConfig, + XYReferenceLineLayerConfig, + XYAnnotationLayerConfig, +} from './types'; import { OperationMetadata, DatasourcePublicAPI } from '../types'; import { getColumnToLabelMap } from './state_helpers'; import type { ValidLayer, - XYAnnotationLayerConfig, - XYReferenceLineLayerConfig, YConfig, - XYDataLayerConfig, -} from '../../common/expressions'; -import { layerTypes } from '../../common'; +} from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { hasIcon } from './xy_config_panel/shared/icon_select'; import { defaultReferenceLineColor } from './color_assignment'; import { getDefaultVisualValuesForLayer } from '../shared_components/datasource_default_values'; @@ -31,6 +33,7 @@ import { } from './visualization_helpers'; import { defaultAnnotationLabel } from './annotations/config_panel'; import { getUniqueLabels } from './annotations/helpers'; +import { layerTypes } from '../../common'; export const getSortedAccessors = ( datasource: DatasourcePublicAPI, @@ -195,7 +198,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_chart', + function: 'xyVis', arguments: { title: [attributes?.title || ''], description: [attributes?.description || ''], @@ -208,7 +211,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_legendConfig', + function: 'legendConfig', arguments: { isVisible: [state.legend.isVisible], showSingleSeries: state.legend.showSingleSeries @@ -249,7 +252,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_axisExtentConfig', + function: 'axisExtentConfig', arguments: { mode: [state?.yLeftExtent?.mode || 'full'], lowerBound: @@ -271,7 +274,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_axisExtentConfig', + function: 'axisExtentConfig', arguments: { mode: [state?.yRightExtent?.mode || 'full'], lowerBound: @@ -293,7 +296,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_axisTitlesVisibilityConfig', + function: 'axisTitlesVisibilityConfig', arguments: { x: [state?.axisTitlesVisibilitySettings?.x ?? true], yLeft: [state?.axisTitlesVisibilitySettings?.yLeft ?? true], @@ -309,7 +312,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_tickLabelsConfig', + function: 'tickLabelsConfig', arguments: { x: [state?.tickLabelsVisibilitySettings?.x ?? true], yLeft: [state?.tickLabelsVisibilitySettings?.yLeft ?? true], @@ -325,7 +328,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_gridlinesConfig', + function: 'gridlinesConfig', arguments: { x: [state?.gridlinesVisibilitySettings?.x ?? true], yLeft: [state?.gridlinesVisibilitySettings?.yLeft ?? true], @@ -341,7 +344,7 @@ export const buildExpression = ( chain: [ { type: 'function', - function: 'lens_xy_labelsOrientationConfig', + function: 'labelsOrientationConfig', arguments: { x: [state?.labelsOrientation?.x ?? 0], yLeft: [state?.labelsOrientation?.yLeft ?? 0], @@ -388,7 +391,7 @@ const referenceLineLayerToExpression = ( chain: [ { type: 'function', - function: 'lens_xy_referenceLine_layer', + function: 'referenceLineLayer', arguments: { layerId: [layer.layerId], yConfig: layer.yConfig @@ -396,7 +399,6 @@ const referenceLineLayerToExpression = ( yConfigToExpression(yConfig, defaultReferenceLineColor) ) : [], - layerType: [layerTypes.REFERENCELINE], accessors: layer.accessors, columnToLabel: [JSON.stringify(getColumnToLabelMap(layer, datasourceLayer))], }, @@ -414,11 +416,10 @@ const annotationLayerToExpression = ( chain: [ { type: 'function', - function: 'lens_xy_annotation_layer', + function: 'annotationLayer', arguments: { hide: [Boolean(layer.hide)], layerId: [layer.layerId], - layerType: [layerTypes.ANNOTATIONS], annotations: layer.annotations ? layer.annotations.map( (ann): Ast => @@ -462,7 +463,7 @@ const dataLayerToExpression = ( chain: [ { type: 'function', - function: 'lens_xy_data_layer', + function: 'dataLayer', arguments: { layerId: [layer.layerId], hide: [Boolean(layer.hide)], @@ -477,7 +478,6 @@ const dataLayerToExpression = ( ? layer.yConfig.map((yConfig) => yConfigToExpression(yConfig)) : [], seriesType: [layer.seriesType], - layerType: [layerTypes.DATA], accessors: layer.accessors, columnToLabel: [JSON.stringify(columnToLabel)], ...(layer.palette @@ -515,7 +515,7 @@ const yConfigToExpression = (yConfig: YConfig, defaultColor?: string): Ast => { chain: [ { type: 'function', - function: 'lens_xy_yConfig', + function: 'yConfig', arguments: { forAccessor: [yConfig.forAccessor], axisMode: yConfig.axisMode ? [yConfig.axisMode] : [], diff --git a/x-pack/plugins/lens/public/xy_visualization/types.ts b/x-pack/plugins/lens/public/xy_visualization/types.ts index 2b9d5687979be..9fcb1951d5ac2 100644 --- a/x-pack/plugins/lens/public/xy_visualization/types.ts +++ b/x-pack/plugins/lens/public/xy_visualization/types.ts @@ -18,19 +18,52 @@ import { LensIconChartBarHorizontalPercentage } from '../assets/chart_bar_horizo import { LensIconChartLine } from '../assets/chart_line'; import type { VisualizationType, Suggestion } from '../types'; +import { PaletteOutput } from '../../../../../src/plugins/charts/common'; import type { SeriesType, LegendConfig, AxisExtentConfig, - XYLayerConfig, XYCurveType, AxesSettingsConfig, FittingFunction, LabelsOrientationConfig, EndValue, -} from '../../common/expressions'; + YConfig, +} from '../../../../../src/plugins/chart_expressions/expression_xy/common'; +import { EventAnnotationConfig } from '../../../../../src/plugins/event_annotation/common'; import type { ValueLabelConfig } from '../../common/types'; +export interface XYDataLayerConfig { + layerId: string; + accessors: string[]; + layerType: 'data'; + seriesType: SeriesType; + xAccessor?: string; + hide?: boolean; + yConfig?: YConfig[]; + splitAccessor?: string; + palette?: PaletteOutput; +} + +export interface XYReferenceLineLayerConfig { + layerId: string; + accessors: string[]; + yConfig?: YConfig[]; + layerType: 'referenceLine'; +} + +export interface XYAnnotationLayerConfig { + layerId: string; + layerType: 'annotations'; + annotations: EventAnnotationConfig[]; + hide?: boolean; +} + +export type XYLayerConfig = + | XYDataLayerConfig + | XYReferenceLineLayerConfig + | XYAnnotationLayerConfig; + // Persisted parts of the state export interface XYState { preferredSeriesType: SeriesType; @@ -56,6 +89,7 @@ export interface XYState { } export type State = XYState; + const groupLabelForBar = i18n.translate('xpack.lens.xyVisualization.barGroupLabel', { defaultMessage: 'Bar', }); diff --git a/x-pack/plugins/lens/public/xy_visualization/visualization.test.ts b/x-pack/plugins/lens/public/xy_visualization/visualization.test.ts index b5b17c4536288..18cd16c17b365 100644 --- a/x-pack/plugins/lens/public/xy_visualization/visualization.test.ts +++ b/x-pack/plugins/lens/public/xy_visualization/visualization.test.ts @@ -8,13 +8,15 @@ import { getXyVisualization } from './visualization'; import { Position } from '@elastic/charts'; import { Operation, VisualizeEditorContext, Suggestion, OperationDescriptor } from '../types'; -import type { State, XYState, XYSuggestion } from './types'; import type { - SeriesType, - XYDataLayerConfig, + State, + XYState, + XYSuggestion, XYLayerConfig, + XYDataLayerConfig, XYReferenceLineLayerConfig, -} from '../../common/expressions'; +} from './types'; +import type { SeriesType } from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { layerTypes } from '../../common'; import { createMockDatasource, createMockFramePublicAPI } from '../mocks'; import { LensIconChartBar } from '../assets/chart_bar'; @@ -45,7 +47,7 @@ const exampleAnnotation2: EventAnnotationConfig = { label: 'Annotation2', }; -function exampleState(): State { +function exampleState(): XYState { return { legend: { position: Position.Bottom, isVisible: true }, valueLabels: 'hide', @@ -58,7 +60,7 @@ function exampleState(): State { splitAccessor: 'd', xAccessor: 'a', accessors: ['b', 'c'], - } as XYDataLayerConfig, + }, ], }; } @@ -127,7 +129,7 @@ describe('xy_visualization', () => { }); describe('#getVisualizationTypeId', () => { - function mixedState(...types: SeriesType[]) { + function mixedState(...types: SeriesType[]): XYState { const state = exampleState(); return { ...state, @@ -1039,7 +1041,7 @@ describe('xy_visualization', () => { ...baseState.layers[0], accessors: ['a'], seriesType: 'bar_percentage_stacked', - } as XYDataLayerConfig, + } as XYLayerConfig, ], }, frame, @@ -1648,7 +1650,7 @@ describe('xy_visualization', () => { ...baseState.layers[0], splitAccessor: undefined, ...layerConfigOverride, - } as XYDataLayerConfig, + } as XYLayerConfig, ], }, frame, diff --git a/x-pack/plugins/lens/public/xy_visualization/visualization.tsx b/x-pack/plugins/lens/public/xy_visualization/visualization.tsx index 78fd50f7cfece..1a6af0dc36475 100644 --- a/x-pack/plugins/lens/public/xy_visualization/visualization.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/visualization.tsx @@ -16,14 +16,18 @@ import { ThemeServiceStart } from 'kibana/public'; import { EventAnnotationServiceType } from '../../../../../src/plugins/event_annotation/public'; import { KibanaThemeProvider } from '../../../../../src/plugins/kibana_react/public'; import { VIS_EVENT_TO_TRIGGER } from '../../../../../src/plugins/visualizations/public'; -import type { FillStyle, XYLayerConfig } from '../../common/expressions/xy_chart'; import { getSuggestions } from './xy_suggestions'; import { XyToolbar } from './xy_config_panel'; import { DimensionEditor } from './xy_config_panel/dimension_editor'; import { LayerHeader } from './xy_config_panel/layer_header'; import type { Visualization, AccessorConfig, FramePublicAPI } from '../types'; -import { State, visualizationTypes, XYSuggestion } from './types'; -import { SeriesType, XYDataLayerConfig, YAxisMode } from '../../common/expressions'; +import { + FillStyle, + SeriesType, + YAxisMode, + YConfig, +} from '../../../../../src/plugins/chart_expressions/expression_xy/common'; +import { State, visualizationTypes, XYSuggestion, XYLayerConfig, XYDataLayerConfig } from './types'; import { layerTypes } from '../../common'; import { isHorizontalChart } from './state_helpers'; import { toExpression, toPreviewExpression, getSortedAccessors } from './to_expression'; @@ -61,7 +65,7 @@ import { validateLayersForDimension, } from './visualization_helpers'; import { groupAxesByType } from './axes_configuration'; -import { XYState } from '..'; +import { XYState } from './types'; import { ReferenceLinePanel } from './xy_config_panel/reference_line_panel'; import { DimensionTrigger } from '../shared_components/dimension_trigger'; import { AnnotationsPanel, defaultAnnotationLabel } from './annotations/config_panel'; @@ -202,12 +206,18 @@ export const getXyVisualization = ({ accessors: sortedAccessors, }); + if (isReferenceLayer(layer)) { + return getReferenceConfiguration({ state, frame, layer, sortedAccessors }); + } + + const dataLayer: XYDataLayerConfig = layer; + const dataLayers = getDataLayers(state.layers); const isHorizontal = isHorizontalChart(state.layers); const { left, right } = groupAxesByType([layer], frame.activeData); // Check locally if it has one accessor OR one accessor per axis const layerHasOnlyOneAccessor = Boolean( - layer.accessors.length < 2 || + dataLayer.accessors.length < 2 || (left.length && left.length < 2) || (right.length && right.length < 2) ); @@ -219,9 +229,10 @@ export const getXyVisualization = ({ // check that the other layers are compatible with this one (l) => { if ( - l.seriesType === layer.seriesType && - Boolean(l.xAccessor) === Boolean(layer.xAccessor) && - Boolean(l.splitAccessor) === Boolean(layer.splitAccessor) + isDataLayer(l) && + l.seriesType === dataLayer.seriesType && + Boolean(l.xAccessor) === Boolean(dataLayer.xAccessor) && + Boolean(l.splitAccessor) === Boolean(dataLayer.splitAccessor) ) { const { left: localLeft, right: localRight } = groupAxesByType([l], frame.activeData); // return true only if matching axis are found @@ -240,9 +251,9 @@ export const getXyVisualization = ({ { groupId: 'x', groupLabel: getAxisName('x', { isHorizontal }), - accessors: layer.xAccessor ? [{ columnId: layer.xAccessor }] : [], + accessors: dataLayer.xAccessor ? [{ columnId: dataLayer.xAccessor }] : [], filterOperations: isBucketed, - supportsMoreColumns: !layer.xAccessor, + supportsMoreColumns: !dataLayer.xAccessor, dataTestSubj: 'lnsXY_xDimensionPanel', }, { @@ -260,21 +271,21 @@ export const getXyVisualization = ({ groupLabel: i18n.translate('xpack.lens.xyChart.splitSeries', { defaultMessage: 'Break down by', }), - accessors: layer.splitAccessor + accessors: dataLayer.splitAccessor ? [ { - columnId: layer.splitAccessor, + columnId: dataLayer.splitAccessor, triggerIcon: 'colorBy' as const, palette: paletteService - .get(layer.palette?.name || 'default') - .getCategoricalColors(10, layer.palette?.params), + .get(dataLayer.palette?.name || 'default') + .getCategoricalColors(10, dataLayer.palette?.params), }, ] : [], filterOperations: isBucketed, - supportsMoreColumns: !layer.splitAccessor, + supportsMoreColumns: !dataLayer.splitAccessor, dataTestSubj: 'lnsXY_splitDimensionPanel', - required: layer.seriesType.includes('percentage') && hasOnlyOneAccessor, + required: dataLayer.seriesType.includes('percentage') && hasOnlyOneAccessor, enableDimensionEditor: true, }, ], @@ -288,7 +299,9 @@ export const getXyVisualization = ({ setDimension(props) { const { prevState, layerId, columnId, groupId } = props; - const foundLayer = prevState.layers.find((l) => l.layerId === layerId); + const foundLayer: XYLayerConfig | undefined = prevState.layers.find( + (l) => l.layerId === layerId + ); if (!foundLayer) { return prevState; } @@ -300,7 +313,7 @@ export const getXyVisualization = ({ return setAnnotationsDimension(props); } - const newLayer = { ...foundLayer }; + const newLayer: XYDataLayerConfig = Object.assign({}, foundLayer); if (groupId === 'x') { newLayer.xAccessor = columnId; } @@ -324,7 +337,7 @@ export const getXyVisualization = ({ } const isReferenceLine = metrics.some((metric) => metric.agg === 'static_value'); const axisMode = axisPosition as YAxisMode; - const yConfig = metrics.map((metric, idx) => { + const yConfig = metrics.map((metric, idx) => { return { color: metric.color, forAccessor: metric.accessor ?? foundLayer.accessors[idx], diff --git a/x-pack/plugins/lens/public/xy_visualization/visualization_helpers.tsx b/x-pack/plugins/lens/public/xy_visualization/visualization_helpers.tsx index 23c2446ca2363..d680494ef8315 100644 --- a/x-pack/plugins/lens/public/xy_visualization/visualization_helpers.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/visualization_helpers.tsx @@ -8,18 +8,17 @@ import { i18n } from '@kbn/i18n'; import { uniq } from 'lodash'; import { DatasourcePublicAPI, OperationMetadata, VisualizationType } from '../types'; -import { State, visualizationTypes, XYState } from './types'; -import { isHorizontalChart } from './state_helpers'; import { - AnnotationLayerArgs, - DataLayerArgs, - SeriesType, + State, + visualizationTypes, + XYState, XYAnnotationLayerConfig, - XYDataLayerConfig, - XYLayerArgs, XYLayerConfig, + XYDataLayerConfig, XYReferenceLineLayerConfig, -} from '../../common/expressions'; +} from './types'; +import { isHorizontalChart } from './state_helpers'; +import { SeriesType } from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { layerTypes } from '..'; import { LensIconChartBarHorizontal } from '../assets/chart_bar_horizontal'; import { LensIconChartMixedXy } from '../assets/chart_mixed_xy'; @@ -131,15 +130,12 @@ export function checkScaleOperation( }; } -export const isDataLayer = (layer: Pick): layer is XYDataLayerConfig => +export const isDataLayer = (layer: XYLayerConfig): layer is XYDataLayerConfig => layer.layerType === layerTypes.DATA || !layer.layerType; -export const getDataLayers = (layers: Array>) => +export const getDataLayers = (layers: XYLayerConfig[]) => (layers || []).filter((layer): layer is XYDataLayerConfig => isDataLayer(layer)); -export const getDataLayersArgs = (layers: XYLayerArgs[]) => - (layers || []).filter((layer): layer is DataLayerArgs => isDataLayer(layer)); - export const getFirstDataLayer = (layers: XYLayerConfig[]) => (layers || []).find((layer): layer is XYDataLayerConfig => isDataLayer(layer)); @@ -157,9 +153,6 @@ export const isAnnotationsLayer = ( export const getAnnotationsLayers = (layers: Array>) => (layers || []).filter((layer): layer is XYAnnotationLayerConfig => isAnnotationsLayer(layer)); -export const getAnnotationsLayersArgs = (layers: XYLayerArgs[]) => - (layers || []).filter((layer): layer is AnnotationLayerArgs => isAnnotationsLayer(layer)); - export interface LayerTypeToLayer { [layerTypes.DATA]: (layer: XYDataLayerConfig) => XYDataLayerConfig; [layerTypes.REFERENCELINE]: (layer: XYReferenceLineLayerConfig) => XYReferenceLineLayerConfig; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/axis_settings_popover.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/axis_settings_popover.tsx index ef692b59a7eb7..340a9211fcdee 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/axis_settings_popover.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/axis_settings_popover.tsx @@ -17,7 +17,11 @@ import { } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { isEqual } from 'lodash'; -import { XYLayerConfig, AxesSettingsConfig, AxisExtentConfig } from '../../../common/expressions'; +import { + AxesSettingsConfig, + AxisExtentConfig, +} from '../../../../../../src/plugins/chart_expressions/expression_xy/common'; +import { XYLayerConfig } from '../types'; import { ToolbarPopover, useDebouncedValue, @@ -31,6 +35,7 @@ import { EuiIconAxisRight } from '../../assets/axis_right'; import { EuiIconAxisTop } from '../../assets/axis_top'; import { ToolbarButtonProps } from '../../../../../../src/plugins/kibana_react/public'; import { validateExtent } from '../axes_configuration'; + import './axis_settings_popover.scss'; type AxesSettingsConfigKeys = keyof AxesSettingsConfig; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/color_picker.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/color_picker.tsx index b448ebfbd455e..3f801fb92876d 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/color_picker.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/color_picker.tsx @@ -11,7 +11,7 @@ import { EuiFormRow, EuiColorPicker, EuiColorPickerProps, EuiToolTip, EuiIcon } import type { PaletteRegistry } from 'src/plugins/charts/public'; import { defaultAnnotationColor } from '../../../../../../src/plugins/event_annotation/public'; import type { VisualizationDimensionEditorProps } from '../../types'; -import { State } from '../types'; +import { State, XYDataLayerConfig } from '../types'; import { FormatFactory } from '../../../common'; import { getSeriesColor } from '../state_helpers'; import { @@ -67,6 +67,7 @@ export const ColorPicker = ({ return defaultAnnotationColor; } + const dataLayer: XYDataLayerConfig = layer; const sortedAccessors: string[] = getSortedAccessors( frame.datasourceLayers[layer.layerId] ?? layer.accessors, layer @@ -81,8 +82,8 @@ export const ColorPicker = ({ colorAssignments, frame, { - ...layer, - accessors: sortedAccessors.filter((sorted) => layer.accessors.includes(sorted)), + ...dataLayer, + accessors: sortedAccessors.filter((sorted) => dataLayer.accessors.includes(sorted)), }, paletteService ); diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/dimension_editor.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/dimension_editor.tsx index 1618bd4d0e540..b3e13ece50434 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/dimension_editor.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/dimension_editor.tsx @@ -10,12 +10,18 @@ import { i18n } from '@kbn/i18n'; import { EuiButtonGroup, EuiFormRow, htmlIdGenerator } from '@elastic/eui'; import type { PaletteRegistry } from 'src/plugins/charts/public'; import type { VisualizationDimensionEditorProps } from '../../types'; -import { State, XYState } from '../types'; +import { State, XYState, XYDataLayerConfig } from '../types'; import { FormatFactory } from '../../../common'; -import { XYDataLayerConfig, YAxisMode, YConfig } from '../../../common/expressions'; +import { + YAxisMode, + YConfig, +} from '../../../../../../src/plugins/chart_expressions/expression_xy/common'; import { isHorizontalChart } from '../state_helpers'; import { ColorPicker } from './color_picker'; import { PalettePicker, useDebouncedValue } from '../../shared_components'; +import { isAnnotationsLayer, isReferenceLayer } from '../visualization_helpers'; +import { ReferenceLinePanel } from './reference_line_panel'; +import { AnnotationsPanel } from '../annotations/config_panel'; type UnwrapArray = T extends Array ? P : T; @@ -43,16 +49,14 @@ export function DimensionEditor( ) { const { state, setState, layerId, accessor } = props; const index = state.layers.findIndex((l) => l.layerId === layerId); + const layer = state.layers[index] as XYDataLayerConfig; const { inputValue: localState, handleInputChange: setLocalState } = useDebouncedValue({ value: props.state, onChange: props.setState, }); - const localLayer = localState.layers.find((l) => l.layerId === layerId) as XYDataLayerConfig; - const localYConfig = localLayer?.yConfig?.find( - (yAxisConfig) => yAxisConfig.forAccessor === accessor - ); + const localYConfig = layer?.yConfig?.find((yAxisConfig) => yAxisConfig.forAccessor === accessor); const axisMode = localYConfig?.axisMode || 'auto'; const setConfig = useCallback( @@ -60,7 +64,7 @@ export function DimensionEditor( if (yConfig == null) { return; } - const newYConfigs = [...(localLayer.yConfig || [])]; + const newYConfigs = [...(layer.yConfig || [])]; const existingIndex = newYConfigs.findIndex( (yAxisConfig) => yAxisConfig.forAccessor === accessor ); @@ -72,11 +76,20 @@ export function DimensionEditor( ...yConfig, }); } - setLocalState(updateLayer(localState, { ...localLayer, yConfig: newYConfigs }, index)); + setLocalState(updateLayer(localState, { ...layer, yConfig: newYConfigs }, index)); }, - [accessor, index, localState, localLayer, setLocalState] + [accessor, index, localState, layer, setLocalState] ); + if (isAnnotationsLayer(layer)) { + return ; + } + + if (isReferenceLayer(layer)) { + return ; + } + + const localLayer: XYDataLayerConfig = layer; if (props.groupId === 'breakdown') { return ( <> diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/index.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/index.tsx index 1684d822b5576..42cf49c04fbd8 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/index.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/index.tsx @@ -11,7 +11,10 @@ import { Position, ScaleType, VerticalAlignment, HorizontalAlignment } from '@el import { EuiFlexGroup, EuiFlexItem } from '@elastic/eui'; import type { VisualizationToolbarProps, FramePublicAPI } from '../../types'; import { State, XYState } from '../types'; -import { AxesSettingsConfig, AxisExtentConfig } from '../../../common/expressions'; +import { + AxesSettingsConfig, + AxisExtentConfig, +} from '../../../../../../src/plugins/chart_expressions/expression_xy/common'; import { isHorizontalChart } from '../state_helpers'; import { LegendSettingsPopover } from '../../shared_components'; import { AxisSettingsPopover } from './axis_settings_popover'; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/layer_header.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/layer_header.tsx index c4e5268cfb8af..2aabf255c5993 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/layer_header.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/layer_header.tsx @@ -9,8 +9,8 @@ import React, { useState } from 'react'; import { i18n } from '@kbn/i18n'; import { EuiIcon, EuiPopover, EuiSelectable, EuiText, EuiPopoverTitle } from '@elastic/eui'; import type { VisualizationLayerWidgetProps, VisualizationType } from '../../types'; -import { State, visualizationTypes } from '../types'; -import { SeriesType, XYDataLayerConfig } from '../../../common/expressions'; +import { State, visualizationTypes, XYDataLayerConfig } from '../types'; +import { SeriesType } from '../../../../../../src/plugins/chart_expressions/expression_xy/common'; import { isHorizontalChart, isHorizontalSeries } from '../state_helpers'; import { trackUiEvent } from '../../lens_ui_telemetry'; import { StaticHeader } from '../../shared_components'; @@ -58,8 +58,9 @@ function AnnotationsLayerHeader() { function DataLayerHeader(props: VisualizationLayerWidgetProps) { const [isPopoverOpen, setPopoverIsOpen] = useState(false); const { state, layerId } = props; - const index = state.layers.findIndex((l) => l.layerId === layerId); - const layer = state.layers[index] as XYDataLayerConfig; + const layers = state.layers as XYDataLayerConfig[]; + const index = layers.findIndex((l) => l.layerId === layerId); + const layer = layers[index]; const currentVisType = visualizationTypes.find(({ id }) => id === layer.seriesType)!; const horizontalOnly = isHorizontalChart(state.layers); diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/reference_line_panel.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/reference_line_panel.tsx index 78020034c3d43..ffca2c0531b7c 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/reference_line_panel.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/reference_line_panel.tsx @@ -10,10 +10,12 @@ import { i18n } from '@kbn/i18n'; import { EuiButtonGroup, EuiFormRow } from '@elastic/eui'; import type { PaletteRegistry } from 'src/plugins/charts/public'; import type { VisualizationDimensionEditorProps } from '../../types'; -import { State, XYState } from '../types'; +import { State, XYState, XYReferenceLineLayerConfig } from '../types'; import { FormatFactory } from '../../../common'; -import { YConfig } from '../../../common/expressions'; -import { FillStyle, XYReferenceLineLayerConfig } from '../../../common/expressions/xy_chart'; +import { + FillStyle, + YConfig, +} from '../../../../../../src/plugins/chart_expressions/expression_xy/common'; import { ColorPicker } from './color_picker'; import { updateLayer } from '.'; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/line_style_settings.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/line_style_settings.tsx index 766d5462db787..8ae86c2fd5b46 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/line_style_settings.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/line_style_settings.tsx @@ -14,7 +14,8 @@ import { EuiFlexItem, EuiFormRow, } from '@elastic/eui'; -import { LineStyle } from '../../../../common/expressions/xy_chart'; +import { LineStyle } from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; + import { idPrefix } from '../dimension_editor'; interface LineStyleConfig { diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/marker_decoration_settings.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/marker_decoration_settings.tsx index 134d72b7de64b..b3736cdbf3dfe 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/marker_decoration_settings.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/shared/marker_decoration_settings.tsx @@ -8,7 +8,10 @@ import React from 'react'; import { i18n } from '@kbn/i18n'; import { EuiButtonGroup, EuiFormRow } from '@elastic/eui'; -import { IconPosition, YAxisMode } from '../../../../common/expressions/xy_chart'; +import { + IconPosition, + YAxisMode, +} from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; import { TooltipWrapper } from '../../../shared_components'; import { hasIcon, IconSelect, IconSet } from './icon_select'; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/end_value.ts b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/end_value_definitions.ts similarity index 85% rename from x-pack/plugins/lens/common/expressions/xy_chart/end_value.ts rename to x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/end_value_definitions.ts index 1ef664cb2e2ba..1ecd260b04a30 100644 --- a/x-pack/plugins/lens/common/expressions/xy_chart/end_value.ts +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/end_value_definitions.ts @@ -6,10 +6,9 @@ */ import { i18n } from '@kbn/i18n'; +import type { EndValue } from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; -export type EndValue = typeof endValueDefinitions[number]['id']; - -export const endValueDefinitions = [ +export const endValueDefinitions: Array<{ id: EndValue } & Record> = [ { id: 'None', title: i18n.translate('xpack.lens.endValue.none', { @@ -37,4 +36,4 @@ export const endValueDefinitions = [ defaultMessage: 'Extend series with the first/last value to the edge of the chart', }), }, -] as const; +]; diff --git a/x-pack/plugins/lens/common/expressions/xy_chart/fitting_function.ts b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/fitting_function_definitions.ts similarity index 88% rename from x-pack/plugins/lens/common/expressions/xy_chart/fitting_function.ts rename to x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/fitting_function_definitions.ts index 0cfea62d578d7..a357f7c2f92ca 100644 --- a/x-pack/plugins/lens/common/expressions/xy_chart/fitting_function.ts +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/fitting_function_definitions.ts @@ -6,10 +6,9 @@ */ import { i18n } from '@kbn/i18n'; +import type { FittingFunction } from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; -export type FittingFunction = typeof fittingFunctionDefinitions[number]['id']; - -export const fittingFunctionDefinitions = [ +export const fittingFunctionDefinitions: Array<{ id: FittingFunction } & Record> = [ { id: 'None', title: i18n.translate('xpack.lens.fittingFunctionsTitle.none', { @@ -55,4 +54,4 @@ export const fittingFunctionDefinitions = [ defaultMessage: 'Fill gaps with the next value', }), }, -] as const; +]; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/index.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/index.tsx index 0bdd513c1f881..00903e1107c91 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/index.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/index.tsx @@ -13,7 +13,7 @@ import { LineCurveOption } from './line_curve_option'; import { FillOpacityOption } from './fill_opacity_option'; import { XYState } from '../../types'; import { hasHistogramSeries } from '../../state_helpers'; -import { ValidLayer } from '../../../../common/expressions'; +import { ValidLayer } from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; import type { FramePublicAPI } from '../../../types'; import { getDataLayers } from '../../visualization_helpers'; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/line_curve_option.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/line_curve_option.tsx index 96926412afb8a..9e69c427d99fe 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/line_curve_option.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/line_curve_option.tsx @@ -8,7 +8,7 @@ import React from 'react'; import { i18n } from '@kbn/i18n'; import { EuiFormRow, EuiSwitch } from '@elastic/eui'; -import type { XYCurveType } from '../../../../common/expressions'; +import type { XYCurveType } from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; export interface LineCurveOptionProps { /** diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/missing_values_option.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/missing_values_option.tsx index 9bd59cb5c4a08..645b740fc9dad 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/missing_values_option.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/missing_values_option.tsx @@ -8,8 +8,12 @@ import React from 'react'; import { i18n } from '@kbn/i18n'; import { EuiFormRow, EuiIconTip, EuiSuperSelect, EuiSwitch, EuiText } from '@elastic/eui'; -import { fittingFunctionDefinitions, endValueDefinitions } from '../../../../common/expressions'; -import type { FittingFunction, EndValue } from '../../../../common/expressions'; +import { fittingFunctionDefinitions } from './fitting_function_definitions'; +import { endValueDefinitions } from './end_value_definitions'; +import type { + FittingFunction, + EndValue, +} from '../../../../../../../src/plugins/chart_expressions/expression_xy/common'; export interface MissingValuesOptionProps { fittingFunction?: FittingFunction; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/visual_options_popover.test.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/visual_options_popover.test.tsx index 4e2be2f0e4749..5b91ee70c6945 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/visual_options_popover.test.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/visual_options_popover/visual_options_popover.test.tsx @@ -10,13 +10,12 @@ import { shallowWithIntl as shallow } from '@kbn/test-jest-helpers'; import { Position } from '@elastic/charts'; import type { FramePublicAPI } from '../../../types'; import { createMockDatasource, createMockFramePublicAPI } from '../../../mocks'; -import { State } from '../../types'; +import { State, XYLayerConfig } from '../../types'; import { VisualOptionsPopover } from '.'; import { ToolbarPopover, ValueLabelsSettings } from '../../../shared_components'; import { MissingValuesOptions } from './missing_values_option'; import { FillOpacityOption } from './fill_opacity_option'; import { layerTypes } from '../../../../common'; -import { XYDataLayerConfig } from '../../../../common/expressions'; describe('Visual options popover', () => { let frame: FramePublicAPI; @@ -53,7 +52,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [{ ...state.layers[0], seriesType: 'bar_stacked' } as XYDataLayerConfig], + layers: [{ ...state.layers[0], seriesType: 'bar_stacked' } as XYLayerConfig], }} /> ); @@ -69,9 +68,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [ - { ...state.layers[0], seriesType: 'area_percentage_stacked' } as XYDataLayerConfig, - ], + layers: [{ ...state.layers[0], seriesType: 'area_percentage_stacked' } as XYLayerConfig], }} /> ); @@ -88,9 +85,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [ - { ...state.layers[0], seriesType: 'area_percentage_stacked' } as XYDataLayerConfig, - ], + layers: [{ ...state.layers[0], seriesType: 'area_percentage_stacked' } as XYLayerConfig], }} /> ); @@ -106,9 +101,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [ - { ...state.layers[0], seriesType: 'area_percentage_stacked' } as XYDataLayerConfig, - ], + layers: [{ ...state.layers[0], seriesType: 'area_percentage_stacked' } as XYLayerConfig], }} /> ); @@ -145,7 +138,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [{ ...state.layers[0], seriesType: 'bar_horizontal' } as XYDataLayerConfig], + layers: [{ ...state.layers[0], seriesType: 'bar_horizontal' } as XYLayerConfig], fittingFunction: 'Carry', }} /> @@ -162,7 +155,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [{ ...state.layers[0], seriesType: 'bar_horizontal' } as XYDataLayerConfig], + layers: [{ ...state.layers[0], seriesType: 'bar_horizontal' } as XYLayerConfig], fittingFunction: 'Carry', }} /> @@ -179,7 +172,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [{ ...state.layers[0], seriesType: 'line' } as XYDataLayerConfig], + layers: [{ ...state.layers[0], seriesType: 'line' } as XYLayerConfig], fittingFunction: 'Carry', }} /> @@ -197,7 +190,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [{ ...state.layers[0], seriesType: 'bar_horizontal' } as XYDataLayerConfig], + layers: [{ ...state.layers[0], seriesType: 'bar_horizontal' } as XYLayerConfig], fittingFunction: 'Carry', }} /> @@ -214,7 +207,7 @@ describe('Visual options popover', () => { setState={jest.fn()} state={{ ...state, - layers: [{ ...state.layers[0], seriesType: 'area' } as XYDataLayerConfig], + layers: [{ ...state.layers[0], seriesType: 'area' } as XYLayerConfig], fittingFunction: 'Carry', }} /> @@ -237,7 +230,7 @@ describe('Visual options popover', () => { state={{ ...state, layers: [ - { ...state.layers[0], seriesType: 'bar' } as XYDataLayerConfig, + { ...state.layers[0], seriesType: 'bar' } as XYLayerConfig, { seriesType: 'bar', layerType: layerTypes.DATA, diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/xy_config_panel.test.tsx b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/xy_config_panel.test.tsx index a73d14ad15573..953828db48a72 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/xy_config_panel.test.tsx +++ b/x-pack/plugins/lens/public/xy_visualization/xy_config_panel/xy_config_panel.test.tsx @@ -12,13 +12,12 @@ import { XyToolbar } from '.'; import { DimensionEditor } from './dimension_editor'; import { AxisSettingsPopover } from './axis_settings_popover'; import { FramePublicAPI } from '../../types'; -import { State, XYState } from '../types'; +import { State, XYState, XYDataLayerConfig } from '../types'; import { Position } from '@elastic/charts'; import { createMockFramePublicAPI, createMockDatasource } from '../../mocks'; import { chartPluginMock } from 'src/plugins/charts/public/mocks'; import { EuiColorPicker } from '@elastic/eui'; import { layerTypes } from '../../../common'; -import { XYDataLayerConfig } from '../../../common/expressions'; describe('XY Config panels', () => { let frame: FramePublicAPI; diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.test.ts b/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.test.ts index 2c3483e40b955..941e50d6e5285 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.test.ts +++ b/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.test.ts @@ -7,7 +7,13 @@ import { getSuggestions } from './xy_suggestions'; import type { TableSuggestionColumn, VisualizationSuggestion, TableSuggestion } from '../types'; -import { State, XYState, visualizationTypes } from './types'; +import { + State, + XYState, + visualizationTypes, + XYAnnotationLayerConfig, + XYDataLayerConfig, +} from './types'; import { generateId } from '../id_generator'; import { getXyVisualization } from './xy_visualization'; import { chartPluginMock } from '../../../../../src/plugins/charts/public/mocks'; @@ -16,7 +22,6 @@ import { PaletteOutput } from 'src/plugins/charts/public'; import { layerTypes } from '../../common'; import { fieldFormatsServiceMock } from '../../../../../src/plugins/field_formats/public/mocks'; import { themeServiceMock } from '../../../../../src/core/public/mocks'; -import { XYAnnotationLayerConfig, XYDataLayerConfig } from '../../common/expressions'; jest.mock('../id_generator'); diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.ts b/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.ts index bd5a37c206c6c..610e21c1fe138 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.ts +++ b/x-pack/plugins/lens/public/xy_visualization/xy_suggestions.ts @@ -16,8 +16,8 @@ import { TableSuggestion, TableChangeType, } from '../types'; -import { State, XYState, visualizationTypes } from './types'; -import type { SeriesType, XYDataLayerConfig } from '../../common/expressions'; +import { State, XYState, visualizationTypes, XYLayerConfig, XYDataLayerConfig } from './types'; +import type { SeriesType } from '../../../../../src/plugins/chart_expressions/expression_xy/common'; import { layerTypes } from '../../common'; import { getIconForSeries } from './state_helpers'; import { getDataLayers, isDataLayer } from './visualization_helpers'; @@ -499,26 +499,29 @@ function buildSuggestion({ splitBy = xValue; xValue = undefined; } - const existingLayer: XYDataLayerConfig | {} = - getExistingLayer(currentState, layerId) || ({} as XYDataLayerConfig); + const existingLayer = getExistingLayer(currentState, layerId) || null; const accessors = yValues.map((col) => col.columnId); - const newLayer = { - ...existingLayer, - palette: mainPalette || ('palette' in existingLayer ? existingLayer.palette : undefined), + const newLayer: XYDataLayerConfig = { + ...(existingLayer || {}), + palette: + mainPalette || + (existingLayer && 'palette' in existingLayer + ? (existingLayer as XYDataLayerConfig).palette + : undefined), layerId, seriesType, xAccessor: xValue?.columnId, splitAccessor: splitBy?.columnId, accessors, yConfig: - 'yConfig' in existingLayer && existingLayer.yConfig + existingLayer && 'yConfig' in existingLayer && existingLayer.yConfig ? existingLayer.yConfig.filter(({ forAccessor }) => accessors.indexOf(forAccessor) !== -1) : undefined, layerType: layerTypes.DATA, }; // Maintain consistent order for any layers that were saved - const keptLayers = currentState + const keptLayers: XYLayerConfig[] = currentState ? currentState.layers // Remove layers that aren't being suggested .filter( @@ -568,7 +571,8 @@ function buildSuggestion({ yRight: true, }, preferredSeriesType: seriesType, - layers: Object.keys(existingLayer).length ? keptLayers : [...keptLayers, newLayer], + layers: + existingLayer && Object.keys(existingLayer).length ? keptLayers : [...keptLayers, newLayer], }; return { diff --git a/x-pack/plugins/lens/public/xy_visualization/xy_visualization.ts b/x-pack/plugins/lens/public/xy_visualization/xy_visualization.ts index 894b003b4b371..7b9fa15413a57 100644 --- a/x-pack/plugins/lens/public/xy_visualization/xy_visualization.ts +++ b/x-pack/plugins/lens/public/xy_visualization/xy_visualization.ts @@ -5,6 +5,5 @@ * 2.0. */ -export * from './expression'; export * from './types'; export * from './visualization'; diff --git a/x-pack/plugins/lens/server/expressions/expressions.ts b/x-pack/plugins/lens/server/expressions/expressions.ts index c68fed23a7fdb..9b23c1741556a 100644 --- a/x-pack/plugins/lens/server/expressions/expressions.ts +++ b/x-pack/plugins/lens/server/expressions/expressions.ts @@ -7,19 +7,9 @@ import type { CoreSetup } from 'kibana/server'; import { - xyChart, counterRate, - yAxisConfig, - dataLayerConfig, - referenceLineLayerConfig, - annotationLayerConfig, formatColumn, - legendConfig, renameColumns, - gridlinesConfig, - datatableColumn, - tickLabelsConfig, - axisTitlesVisibilityConfig, getTimeScale, getDatatable, lensMultitable, @@ -36,19 +26,9 @@ export const setupExpressions = ( [lensMultitable].forEach((expressionType) => expressions.registerType(expressionType)); [ - xyChart, counterRate, - yAxisConfig, - dataLayerConfig, - referenceLineLayerConfig, - annotationLayerConfig, formatColumn, - legendConfig, renameColumns, - gridlinesConfig, - datatableColumn, - tickLabelsConfig, - axisTitlesVisibilityConfig, getDatatable(getFormatFactory(core)), getTimeScale(getTimeZoneFactory(core)), ].forEach((expressionFn) => expressions.registerFunction(expressionFn)); diff --git a/x-pack/plugins/lens/server/migrations/saved_object_migrations.test.ts b/x-pack/plugins/lens/server/migrations/saved_object_migrations.test.ts index 61342af5033dd..6760dfd084b94 100644 --- a/x-pack/plugins/lens/server/migrations/saved_object_migrations.test.ts +++ b/x-pack/plugins/lens/server/migrations/saved_object_migrations.test.ts @@ -200,10 +200,10 @@ describe('Lens migrations', () => { } | lens_rename_columns idMap="{\\"col-0-1d9cc16c-1460-41de-88f8-471932ecbc97\\":{\\"label\\":\\"products.created_on\\",\\"dataType\\":\\"date\\",\\"operationType\\":\\"date_histogram\\",\\"sourceField\\":\\"products.created_on\\",\\"isBucketed\\":true,\\"scale\\":\\"interval\\",\\"params\\":{\\"interval\\":\\"auto\\"},\\"id\\":\\"1d9cc16c-1460-41de-88f8-471932ecbc97\\"},\\"col-1-66115819-8481-4917-a6dc-8ffb10dd02df\\":{\\"label\\":\\"Count of records\\",\\"dataType\\":\\"number\\",\\"operationType\\":\\"count\\",\\"suggestedPriority\\":0,\\"isBucketed\\":false,\\"scale\\":\\"ratio\\",\\"sourceField\\":\\"Records\\",\\"id\\":\\"66115819-8481-4917-a6dc-8ffb10dd02df\\"}}" } - | lens_xy_chart + | xyVis xTitle="products.created_on" yTitle="Count of records" - legend={lens_xy_legendConfig isVisible=true position="right"} + legend={legendConfig isVisible=true position="right"} layers={lens_xy_layer layerId="bd09dc71-a7e2-42d0-83bd-85df8291f03c" hide=false @@ -293,7 +293,7 @@ describe('Lens migrations', () => { | kibana_context query="{\\"query\\":\\"\\",\\"language\\":\\"kuery\\"}" filters="[]" | lens_merge_tables layerIds="bd09dc71-a7e2-42d0-83bd-85df8291f03c" tables={esaggs index="ff959d40-b880-11e8-a6d9-e546fe2bba5f" metricsAtAllLevels=false partialRows=false includeFormatHints=true aggConfigs="[{\\"id\\":\\"1d9cc16c-1460-41de-88f8-471932ecbc97\\",\\"enabled\\":true,\\"type\\":\\"date_histogram\\",\\"schema\\":\\"segment\\",\\"params\\":{\\"field\\":\\"products.created_on\\",\\"useNormalizedEsInterval\\":true,\\"interval\\":\\"auto\\",\\"drop_partials\\":false,\\"min_doc_count\\":0,\\"extended_bounds\\":{}}},{\\"id\\":\\"66115819-8481-4917-a6dc-8ffb10dd02df\\",\\"enabled\\":true,\\"type\\":\\"count\\",\\"schema\\":\\"metric\\",\\"params\\":{}}]" timeFields=\"products.created_on\"} -| lens_xy_chart xTitle="products.created_on" yTitle="Count of records" legend={lens_xy_legendConfig isVisible=true position="right"} layers={}`, +| xyVis xTitle="products.created_on" yTitle="Count of records" legend={legendConfig isVisible=true position="right"} layers={}`, }, }; const result = migrations['7.8.0'](input, context); @@ -309,7 +309,7 @@ describe('Lens migrations', () => { attributes: { description: '', expression: - 'kibana\n| kibana_context query="{\\"query\\":\\"NOT bytes > 5000\\",\\"language\\":\\"kuery\\"}" \n filters="[{\\"meta\\":{\\"index\\":\\"90943e30-9a47-11e8-b64d-95841ca0b247\\",\\"alias\\":null,\\"negate\\":true,\\"disabled\\":false,\\"type\\":\\"phrase\\",\\"key\\":\\"geo.src\\",\\"params\\":{\\"query\\":\\"CN\\"}},\\"query\\":{\\"match_phrase\\":{\\"geo.src\\":\\"CN\\"}},\\"$state\\":{\\"store\\":\\"appState\\"}},{\\"meta\\":{\\"index\\":\\"ff959d40-b880-11e8-a6d9-e546fe2bba5f\\",\\"alias\\":null,\\"negate\\":true,\\"disabled\\":false,\\"type\\":\\"phrase\\",\\"key\\":\\"geoip.country_iso_code\\",\\"params\\":{\\"query\\":\\"US\\"}},\\"query\\":{\\"match_phrase\\":{\\"geoip.country_iso_code\\":\\"US\\"}},\\"$state\\":{\\"store\\":\\"appState\\"}}]"\n| lens_merge_tables layerIds="9a27f85d-35a9-4246-81b2-48e7ee9b0707"\n layerIds="3b7791e9-326e-40d5-a787-b7594e48d906" \n tables={esaggs index="90943e30-9a47-11e8-b64d-95841ca0b247" metricsAtAllLevels=true partialRows=true includeFormatHints=true aggConfigs="[{\\"id\\":\\"96352896-c508-4fca-90d8-66e9ebfce621\\",\\"enabled\\":true,\\"type\\":\\"terms\\",\\"schema\\":\\"segment\\",\\"params\\":{\\"field\\":\\"geo.src\\",\\"orderBy\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\",\\"order\\":\\"desc\\",\\"size\\":5,\\"otherBucket\\":false,\\"otherBucketLabel\\":\\"Other\\",\\"missingBucket\\":false,\\"missingBucketLabel\\":\\"Missing\\"}},{\\"id\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\",\\"enabled\\":true,\\"type\\":\\"count\\",\\"schema\\":\\"metric\\",\\"params\\":{}}]" | lens_rename_columns idMap="{\\"col-0-96352896-c508-4fca-90d8-66e9ebfce621\\":{\\"label\\":\\"Top values of geo.src\\",\\"dataType\\":\\"string\\",\\"operationType\\":\\"terms\\",\\"scale\\":\\"ordinal\\",\\"sourceField\\":\\"geo.src\\",\\"isBucketed\\":true,\\"params\\":{\\"size\\":5,\\"orderBy\\":{\\"type\\":\\"column\\",\\"columnId\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\"},\\"orderDirection\\":\\"desc\\"},\\"id\\":\\"96352896-c508-4fca-90d8-66e9ebfce621\\"},\\"col-1-4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\":{\\"label\\":\\"Count of records\\",\\"dataType\\":\\"number\\",\\"operationType\\":\\"count\\",\\"isBucketed\\":false,\\"scale\\":\\"ratio\\",\\"sourceField\\":\\"Records\\",\\"id\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\"}}"}\n tables={esaggs index="ff959d40-b880-11e8-a6d9-e546fe2bba5f" metricsAtAllLevels=true partialRows=true includeFormatHints=true aggConfigs="[{\\"id\\":\\"77d8383e-f66e-471e-ae50-c427feedb5ba\\",\\"enabled\\":true,\\"type\\":\\"terms\\",\\"schema\\":\\"segment\\",\\"params\\":{\\"field\\":\\"geoip.country_iso_code\\",\\"orderBy\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\",\\"order\\":\\"desc\\",\\"size\\":5,\\"otherBucket\\":false,\\"otherBucketLabel\\":\\"Other\\",\\"missingBucket\\":false,\\"missingBucketLabel\\":\\"Missing\\"}},{\\"id\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\",\\"enabled\\":true,\\"type\\":\\"count\\",\\"schema\\":\\"metric\\",\\"params\\":{}}]" | lens_rename_columns idMap="{\\"col-0-77d8383e-f66e-471e-ae50-c427feedb5ba\\":{\\"label\\":\\"Top values of geoip.country_iso_code\\",\\"dataType\\":\\"string\\",\\"operationType\\":\\"terms\\",\\"scale\\":\\"ordinal\\",\\"sourceField\\":\\"geoip.country_iso_code\\",\\"isBucketed\\":true,\\"params\\":{\\"size\\":5,\\"orderBy\\":{\\"type\\":\\"column\\",\\"columnId\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\"},\\"orderDirection\\":\\"desc\\"},\\"id\\":\\"77d8383e-f66e-471e-ae50-c427feedb5ba\\"},\\"col-1-a5c1b82d-51de-4448-a99d-6391432c3a03\\":{\\"label\\":\\"Count of records\\",\\"dataType\\":\\"number\\",\\"operationType\\":\\"count\\",\\"isBucketed\\":false,\\"scale\\":\\"ratio\\",\\"sourceField\\":\\"Records\\",\\"id\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\"}}"}\n| lens_xy_chart xTitle="Top values of geo.src" yTitle="Count of records" legend={lens_xy_legendConfig isVisible=true position="right"} fittingFunction="None" \n layers={lens_xy_layer layerId="9a27f85d-35a9-4246-81b2-48e7ee9b0707" hide=false xAccessor="96352896-c508-4fca-90d8-66e9ebfce621" yScaleType="linear" xScaleType="ordinal" isHistogram=false seriesType="bar" accessors="4ce9b4c7-2ebf-4d48-8669-0ea69d973353" columnToLabel="{\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\":\\"Count of records\\"}"}\n layers={lens_xy_layer layerId="3b7791e9-326e-40d5-a787-b7594e48d906" hide=false xAccessor="77d8383e-f66e-471e-ae50-c427feedb5ba" yScaleType="linear" xScaleType="ordinal" isHistogram=false seriesType="bar" accessors="a5c1b82d-51de-4448-a99d-6391432c3a03" columnToLabel="{\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\":\\"Count of records [1]\\"}"}', + 'kibana\n| kibana_context query="{\\"query\\":\\"NOT bytes > 5000\\",\\"language\\":\\"kuery\\"}" \n filters="[{\\"meta\\":{\\"index\\":\\"90943e30-9a47-11e8-b64d-95841ca0b247\\",\\"alias\\":null,\\"negate\\":true,\\"disabled\\":false,\\"type\\":\\"phrase\\",\\"key\\":\\"geo.src\\",\\"params\\":{\\"query\\":\\"CN\\"}},\\"query\\":{\\"match_phrase\\":{\\"geo.src\\":\\"CN\\"}},\\"$state\\":{\\"store\\":\\"appState\\"}},{\\"meta\\":{\\"index\\":\\"ff959d40-b880-11e8-a6d9-e546fe2bba5f\\",\\"alias\\":null,\\"negate\\":true,\\"disabled\\":false,\\"type\\":\\"phrase\\",\\"key\\":\\"geoip.country_iso_code\\",\\"params\\":{\\"query\\":\\"US\\"}},\\"query\\":{\\"match_phrase\\":{\\"geoip.country_iso_code\\":\\"US\\"}},\\"$state\\":{\\"store\\":\\"appState\\"}}]"\n| lens_merge_tables layerIds="9a27f85d-35a9-4246-81b2-48e7ee9b0707"\n layerIds="3b7791e9-326e-40d5-a787-b7594e48d906" \n tables={esaggs index="90943e30-9a47-11e8-b64d-95841ca0b247" metricsAtAllLevels=true partialRows=true includeFormatHints=true aggConfigs="[{\\"id\\":\\"96352896-c508-4fca-90d8-66e9ebfce621\\",\\"enabled\\":true,\\"type\\":\\"terms\\",\\"schema\\":\\"segment\\",\\"params\\":{\\"field\\":\\"geo.src\\",\\"orderBy\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\",\\"order\\":\\"desc\\",\\"size\\":5,\\"otherBucket\\":false,\\"otherBucketLabel\\":\\"Other\\",\\"missingBucket\\":false,\\"missingBucketLabel\\":\\"Missing\\"}},{\\"id\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\",\\"enabled\\":true,\\"type\\":\\"count\\",\\"schema\\":\\"metric\\",\\"params\\":{}}]" | lens_rename_columns idMap="{\\"col-0-96352896-c508-4fca-90d8-66e9ebfce621\\":{\\"label\\":\\"Top values of geo.src\\",\\"dataType\\":\\"string\\",\\"operationType\\":\\"terms\\",\\"scale\\":\\"ordinal\\",\\"sourceField\\":\\"geo.src\\",\\"isBucketed\\":true,\\"params\\":{\\"size\\":5,\\"orderBy\\":{\\"type\\":\\"column\\",\\"columnId\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\"},\\"orderDirection\\":\\"desc\\"},\\"id\\":\\"96352896-c508-4fca-90d8-66e9ebfce621\\"},\\"col-1-4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\":{\\"label\\":\\"Count of records\\",\\"dataType\\":\\"number\\",\\"operationType\\":\\"count\\",\\"isBucketed\\":false,\\"scale\\":\\"ratio\\",\\"sourceField\\":\\"Records\\",\\"id\\":\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\"}}"}\n tables={esaggs index="ff959d40-b880-11e8-a6d9-e546fe2bba5f" metricsAtAllLevels=true partialRows=true includeFormatHints=true aggConfigs="[{\\"id\\":\\"77d8383e-f66e-471e-ae50-c427feedb5ba\\",\\"enabled\\":true,\\"type\\":\\"terms\\",\\"schema\\":\\"segment\\",\\"params\\":{\\"field\\":\\"geoip.country_iso_code\\",\\"orderBy\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\",\\"order\\":\\"desc\\",\\"size\\":5,\\"otherBucket\\":false,\\"otherBucketLabel\\":\\"Other\\",\\"missingBucket\\":false,\\"missingBucketLabel\\":\\"Missing\\"}},{\\"id\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\",\\"enabled\\":true,\\"type\\":\\"count\\",\\"schema\\":\\"metric\\",\\"params\\":{}}]" | lens_rename_columns idMap="{\\"col-0-77d8383e-f66e-471e-ae50-c427feedb5ba\\":{\\"label\\":\\"Top values of geoip.country_iso_code\\",\\"dataType\\":\\"string\\",\\"operationType\\":\\"terms\\",\\"scale\\":\\"ordinal\\",\\"sourceField\\":\\"geoip.country_iso_code\\",\\"isBucketed\\":true,\\"params\\":{\\"size\\":5,\\"orderBy\\":{\\"type\\":\\"column\\",\\"columnId\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\"},\\"orderDirection\\":\\"desc\\"},\\"id\\":\\"77d8383e-f66e-471e-ae50-c427feedb5ba\\"},\\"col-1-a5c1b82d-51de-4448-a99d-6391432c3a03\\":{\\"label\\":\\"Count of records\\",\\"dataType\\":\\"number\\",\\"operationType\\":\\"count\\",\\"isBucketed\\":false,\\"scale\\":\\"ratio\\",\\"sourceField\\":\\"Records\\",\\"id\\":\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\"}}"}\n| xyVis xTitle="Top values of geo.src" yTitle="Count of records" legend={legendConfig isVisible=true position="right"} fittingFunction="None" \n layers={lens_xy_layer layerId="9a27f85d-35a9-4246-81b2-48e7ee9b0707" hide=false xAccessor="96352896-c508-4fca-90d8-66e9ebfce621" yScaleType="linear" xScaleType="ordinal" isHistogram=false seriesType="bar" accessors="4ce9b4c7-2ebf-4d48-8669-0ea69d973353" columnToLabel="{\\"4ce9b4c7-2ebf-4d48-8669-0ea69d973353\\":\\"Count of records\\"}"}\n layers={lens_xy_layer layerId="3b7791e9-326e-40d5-a787-b7594e48d906" hide=false xAccessor="77d8383e-f66e-471e-ae50-c427feedb5ba" yScaleType="linear" xScaleType="ordinal" isHistogram=false seriesType="bar" accessors="a5c1b82d-51de-4448-a99d-6391432c3a03" columnToLabel="{\\"a5c1b82d-51de-4448-a99d-6391432c3a03\\":\\"Count of records [1]\\"}"}', state: { datasourceMetaData: { filterableIndexPatterns: [ diff --git a/x-pack/plugins/lens/tsconfig.json b/x-pack/plugins/lens/tsconfig.json index 76e25f8b08639..eae5536012314 100644 --- a/x-pack/plugins/lens/tsconfig.json +++ b/x-pack/plugins/lens/tsconfig.json @@ -14,86 +14,33 @@ "../../../typings/**/*" ], "references": [ - { - "path": "../spaces/tsconfig.json" - }, - { - "path": "../../../src/core/tsconfig.json" - }, - { - "path": "../task_manager/tsconfig.json" - }, - { - "path": "../global_search/tsconfig.json" - }, - { - "path": "../saved_objects_tagging/tsconfig.json" - }, - { - "path": "../../../src/plugins/data/tsconfig.json" - }, - { - "path": "../../../src/plugins/data_views/tsconfig.json" - }, - { - "path": "../../../src/plugins/data_view_field_editor/tsconfig.json" - }, - { - "path": "../../../src/plugins/charts/tsconfig.json" - }, - { - "path": "../../../src/plugins/expressions/tsconfig.json" - }, - { - "path": "../../../src/plugins/navigation/tsconfig.json" - }, - { - "path": "../../../src/plugins/url_forwarding/tsconfig.json" - }, - { - "path": "../../../src/plugins/visualizations/tsconfig.json" - }, - { - "path": "../../../src/plugins/dashboard/tsconfig.json" - }, - { - "path": "../../../src/plugins/ui_actions/tsconfig.json" - }, - { - "path": "../../../src/plugins/embeddable/tsconfig.json" - }, - { - "path": "../../../src/plugins/share/tsconfig.json" - }, - { - "path": "../../../src/plugins/usage_collection/tsconfig.json" - }, - { - "path": "../../../src/plugins/saved_objects/tsconfig.json" - }, - { - "path": "../../../src/plugins/kibana_utils/tsconfig.json" - }, - { - "path": "../../../src/plugins/kibana_react/tsconfig.json" - }, - { - "path": "../../../src/plugins/embeddable/tsconfig.json" - }, - { - "path": "../../../src/plugins/presentation_util/tsconfig.json" - }, - { - "path": "../../../src/plugins/field_formats/tsconfig.json" - }, - { - "path": "../../../src/plugins/chart_expressions/expression_heatmap/tsconfig.json" - }, - { - "path": "../../../src/plugins/chart_expressions/expression_gauge/tsconfig.json" - }, - { - "path": "../../../src/plugins/event_annotation/tsconfig.json" - } + { "path": "../spaces/tsconfig.json" }, + { "path": "../../../src/core/tsconfig.json" }, + { "path": "../task_manager/tsconfig.json" }, + { "path": "../global_search/tsconfig.json"}, + { "path": "../saved_objects_tagging/tsconfig.json"}, + { "path": "../../../src/plugins/data/tsconfig.json"}, + { "path": "../../../src/plugins/data_views/tsconfig.json"}, + { "path": "../../../src/plugins/data_view_field_editor/tsconfig.json"}, + { "path": "../../../src/plugins/charts/tsconfig.json"}, + { "path": "../../../src/plugins/expressions/tsconfig.json"}, + { "path": "../../../src/plugins/navigation/tsconfig.json" }, + { "path": "../../../src/plugins/url_forwarding/tsconfig.json" }, + { "path": "../../../src/plugins/visualizations/tsconfig.json" }, + { "path": "../../../src/plugins/dashboard/tsconfig.json" }, + { "path": "../../../src/plugins/ui_actions/tsconfig.json" }, + { "path": "../../../src/plugins/embeddable/tsconfig.json" }, + { "path": "../../../src/plugins/share/tsconfig.json" }, + { "path": "../../../src/plugins/usage_collection/tsconfig.json" }, + { "path": "../../../src/plugins/saved_objects/tsconfig.json"}, + { "path": "../../../src/plugins/kibana_utils/tsconfig.json" }, + { "path": "../../../src/plugins/kibana_react/tsconfig.json" }, + { "path": "../../../src/plugins/embeddable/tsconfig.json"}, + { "path": "../../../src/plugins/presentation_util/tsconfig.json"}, + { "path": "../../../src/plugins/field_formats/tsconfig.json"}, + { "path": "../../../src/plugins/chart_expressions/expression_xy/tsconfig.json"}, + { "path": "../../../src/plugins/chart_expressions/expression_heatmap/tsconfig.json"}, + { "path": "../../../src/plugins/chart_expressions/expression_gauge/tsconfig.json"}, + { "path": "../../../src/plugins/event_annotation/tsconfig.json" } ] } \ No newline at end of file diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 6c186cecef8ad..9056d2e6053b3 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -642,9 +642,10 @@ "xpack.lens.section.workspaceLabel": "Espace de travail de visualisation", "xpack.lens.shared.chartValueLabelVisibilityLabel": "Étiquettes", "xpack.lens.shared.curveLabel": "Options visuelles", - "xpack.lens.shared.legend.filterForValueButtonAriaLabel": "Filtre pour la valeur", + "expressionXY.legend.filterForValueButtonAriaLabel": "Filtre pour la valeur", "xpack.lens.shared.legend.filterOptionsLegend": "{legendDataLabel}, options de filtre", - "xpack.lens.shared.legend.filterOutValueButtonAriaLabel": "Filtrer la valeur", + "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}, options de filtre", + "expressionXY.legend.filterOutValueButtonAriaLabel": "Filtrer la valeur", "xpack.lens.shared.legendAlignmentLabel": "Alignement", "xpack.lens.shared.legendInsideAlignmentLabel": "Alignement", "xpack.lens.shared.legendInsideColumnsLabel": "Nombre de colonnes", @@ -730,78 +731,77 @@ "xpack.lens.xyChart.axisSide.left": "Gauche", "xpack.lens.xyChart.axisSide.right": "Droite", "xpack.lens.xyChart.axisSide.top": "Haut", - "xpack.lens.xyChart.axisTitlesSettings.help": "Afficher les titres des axes X et Y", + "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "Afficher les titres des axes X et Y", "xpack.lens.xyChart.bottomAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe du bas est activé.", "xpack.lens.xyChart.bottomAxisLabel": "Axe du bas", "xpack.lens.xyChart.boundaryError": "La limite inférieure doit être plus grande que la limite supérieure", "xpack.lens.xyChart.curveStyleLabel": "Courbes", - "xpack.lens.xyChart.curveType.help": "Définir de quelle façon le type de courbe est rendu pour un graphique linéaire", - "xpack.lens.xyChart.emptyXLabel": "(vide)", - "xpack.lens.xyChart.extentMode.help": "Mode d'extension", - "xpack.lens.xyChart.fillOpacity.help": "Définir l'opacité du remplissage du graphique en aires", + "expressionXY.xyVis.curveType.help": "Définir de quelle façon le type de courbe est rendu pour un graphique linéaire", + "expressionXY.xyChart.emptyXLabel": "(vide)", + "expressionXY.axisExtentConfig.extentMode.help": "Mode d'extension", + "expressionXY.xyVis.fillOpacity.help": "Définir l'opacité du remplissage du graphique en aires", "xpack.lens.xyChart.fillOpacityLabel": "Opacité de remplissage", - "xpack.lens.xyChart.fittingFunction.help": "Définir le mode de traitement des valeurs manquantes", - "xpack.lens.xyChart.floatingColumns.help": "Spécifie le nombre de colonnes lorsque la légende est affichée à l'intérieur du graphique.", + "expressionXY.xyVis.fittingFunction.help": "Définir le mode de traitement des valeurs manquantes", + "expressionXY.legendConfig.floatingColumns.help": "Spécifie le nombre de colonnes lorsque la légende est affichée à l'intérieur du graphique.", "xpack.lens.xyChart.Gridlines": "Quadrillage", - "xpack.lens.xyChart.gridlinesSettings.help": "Afficher le quadrillage des axes X et Y", - "xpack.lens.xyChart.help": "Graphique X/Y", - "xpack.lens.xyChart.hideEndzones.help": "Masquer les marqueurs de zone de fin pour les données partielles", - "xpack.lens.xyChart.horizontalAlignment.help": "Spécifie l'alignement horizontal de la légende lorsqu'elle est affichée à l'intérieur du graphique.", + "expressionXY.xyVis.gridlinesVisibilitySettings.help": "Afficher le quadrillage des axes X et Y", + "expressionXY.xyVis.help": "Graphique X/Y", + "expressionXY.xyVis.hideEndzones.help": "Masquer les marqueurs de zone de fin pour les données partielles", + "expressionXY.legendConfig.horizontalAlignment.help": "Spécifie l'alignement horizontal de la légende lorsqu'elle est affichée à l'intérieur du graphique.", "xpack.lens.xyChart.horizontalAxisLabel": "Axe horizontal", "xpack.lens.xyChart.inclusiveZero": "Les limites doivent inclure zéro.", - "xpack.lens.xyChart.isInside.help": "Spécifie si une légende se trouve à l'intérieur d'un graphique", - "xpack.lens.xyChart.isVisible.help": "Spécifie si la légende est visible ou non.", - "xpack.lens.xyChart.labelsOrientation.help": "Définit la rotation des étiquettes des axes", + "expressionXY.legendConfig.isInside.help": "Spécifie si une légende se trouve à l'intérieur d'un graphique", + "expressionXY.legendConfig.isVisible.help": "Spécifie si la légende est visible ou non.", + "expressionXY.xyVis.labelsOrientation.help": "Définit la rotation des étiquettes des axes", "xpack.lens.xyChart.leftAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe de gauche est activé.", "xpack.lens.xyChart.leftAxisLabel": "Axe de gauche", - "xpack.lens.xyChart.legend.help": "Configurez la légende du graphique.", + "expressionXY.xyVis.legend.help": "Configurez la légende du graphique.", "xpack.lens.xyChart.legendLocation.inside": "Intérieur", "xpack.lens.xyChart.legendLocation.outside": "Extérieur", "xpack.lens.xyChart.legendVisibility.auto": "Auto", "xpack.lens.xyChart.legendVisibility.hide": "Masquer", "xpack.lens.xyChart.legendVisibility.show": "Afficher", - "xpack.lens.xyChart.maxLines.help": "Spécifie le nombre de lignes par élément de légende.", + "expressionXY.legendConfig.maxLines.help": "Spécifie le nombre de lignes par élément de légende.", "xpack.lens.xyChart.missingValuesLabel": "Valeurs manquantes", "xpack.lens.xyChart.missingValuesLabelHelpText": "Par défaut, Lens masque les blancs dans les données. Pour remplir le blanc, effectuez une sélection.", "xpack.lens.xyChart.nestUnderRoot": "Ensemble de données entier", - "xpack.lens.xyChart.position.help": "Spécifie la position de la légende.", - "xpack.lens.xyChart.renderer.help": "Outil de rendu de graphique X/Y", + "expressionXY.legendConfig.position.help": "Spécifie la position de la légende.", + "expressionXY.xyVis.renderer.help": "Outil de rendu de graphique X/Y", "xpack.lens.xyChart.rightAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe de droite est activé.", "xpack.lens.xyChart.rightAxisLabel": "Axe de droite", "xpack.lens.xyChart.seriesColor.auto": "Auto", "xpack.lens.xyChart.seriesColor.label": "Couleur de la série", - "xpack.lens.xyChart.shouldTruncate.help": "Spécifie si les éléments de légende seront tronqués ou non", + "expressionXY.legendConfig.shouldTruncate.help": "Spécifie si les éléments de légende seront tronqués ou non", "xpack.lens.xyChart.showEnzones": "Afficher les marqueurs de données partielles", - "xpack.lens.xyChart.showSingleSeries.help": "Spécifie si une légende comportant une seule entrée doit être affichée", + "expressionXY.legendConfig.showSingleSeries.help": "Spécifie si une légende comportant une seule entrée doit être affichée", "xpack.lens.xyChart.splitSeries": "Répartir par", "xpack.lens.xyChart.tickLabels": "Étiquettes de graduation", - "xpack.lens.xyChart.tickLabelsSettings.help": "Afficher les étiquettes de graduation des axes X et Y", - "xpack.lens.xyChart.title.help": "Titre de l'axe", + "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "Afficher les étiquettes de graduation des axes X et Y", "xpack.lens.xyChart.topAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe du haut est activé.", "xpack.lens.xyChart.topAxisLabel": "Axe du haut", "xpack.lens.xyChart.valuesHistogramDisabledHelpText": "Ce paramètre ne peut pas être modifié dans les histogrammes.", - "xpack.lens.xyChart.valuesInLegend.help": "Afficher les valeurs dans la légende", + "expressionXY.xyVis.valuesInLegend.help": "Afficher les valeurs dans la légende", "xpack.lens.xyChart.valuesPercentageDisabledHelpText": "Ce paramètre ne peut pas être modifié dans les graphiques en aires à pourcentages.", "xpack.lens.xyChart.valuesStackedDisabledHelpText": "Ce paramètre ne peut pas être modifié dans les graphiques empilés ou les graphiques à barres à pourcentages", - "xpack.lens.xyChart.verticalAlignment.help": "Spécifie l'alignement vertical de la légende lorsqu'elle est affichée à l'intérieur du graphique.", + "expressionXY.legendConfig.verticalAlignment.help": "Spécifie l'alignement vertical de la légende lorsqu'elle est affichée à l'intérieur du graphique.", "xpack.lens.xyChart.verticalAxisLabel": "Axe vertical", - "xpack.lens.xyChart.xAxisGridlines.help": "Spécifie si le quadrillage de l'axe X est visible ou non.", - "xpack.lens.xyChart.xAxisLabelsOrientation.help": "Spécifie l'orientation des étiquettes de l'axe X.", - "xpack.lens.xyChart.xAxisTickLabels.help": "Spécifie si les étiquettes de graduation de l'axe X sont visibles ou non.", - "xpack.lens.xyChart.xAxisTitle.help": "Spécifie si le titre de l'axe X est visible ou non.", - "xpack.lens.xyChart.xTitle.help": "Titre de l'axe X", - "xpack.lens.xyChart.yLeftAxisgridlines.help": "Spécifie si le quadrillage de l'axe Y de gauche est visible ou non.", - "xpack.lens.xyChart.yLeftAxisLabelsOrientation.help": "Spécifie l'orientation des étiquettes de l'axe Y de gauche.", - "xpack.lens.xyChart.yLeftAxisTickLabels.help": "Spécifie si les étiquettes de graduation de l'axe Y de gauche sont visibles ou non.", - "xpack.lens.xyChart.yLeftAxisTitle.help": "Spécifie si le titre de l'axe Y de gauche est visible ou non.", - "xpack.lens.xyChart.yLeftExtent.help": "Portée de l'axe Y de gauche", - "xpack.lens.xyChart.yLeftTitle.help": "Titre de l'axe Y de gauche", - "xpack.lens.xyChart.yRightAxisgridlines.help": "Spécifie si le quadrillage de l'axe Y de droite est visible ou non.", - "xpack.lens.xyChart.yRightAxisLabelsOrientation.help": "Spécifie l'orientation des étiquettes de l'axe Y de droite.", - "xpack.lens.xyChart.yRightAxisTickLabels.help": "Spécifie si les étiquettes de graduation de l'axe Y de droite sont visibles ou non.", - "xpack.lens.xyChart.yRightAxisTitle.help": "Spécifie si le titre de l'axe Y de droite est visible ou non.", - "xpack.lens.xyChart.yRightExtent.help": "Portée de l'axe Y de droite", - "xpack.lens.xyChart.yRightTitle.help": "Titre de l'axe Y de droite", + "expressionXY.gridlinesConfig.x.help": "Spécifie si le quadrillage de l'axe X est visible ou non.", + "expressionXY.labelsOrientationConfig.x.help": "Spécifie l'orientation des étiquettes de l'axe X.", + "expressionXY.tickLabelsConfig.x.help": "Spécifie si les étiquettes de graduation de l'axe X sont visibles ou non.", + "expressionXY.axisTitlesVisibilityConfig.x.help": "Spécifie si le titre de l'axe X est visible ou non.", + "expressionXY.xyVis.xTitle.help": "Titre de l'axe X", + "expressionXY.gridlinesConfig.yLeft.help": "Spécifie si le quadrillage de l'axe Y de gauche est visible ou non.", + "expressionXY.labelsOrientationConfig.yLeft.help": "Spécifie l'orientation des étiquettes de l'axe Y de gauche.", + "expressionXY.tickLabelsConfig.yLeft.help": "Spécifie si les étiquettes de graduation de l'axe Y de gauche sont visibles ou non.", + "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "Spécifie si le titre de l'axe Y de gauche est visible ou non.", + "expressionXY.xyVis.yLeftExtent.help": "Portée de l'axe Y de gauche", + "expressionXY.xyVis.yLeftTitle.help": "Titre de l'axe Y de gauche", + "expressionXY.gridlinesConfig.yRight.help": "Spécifie si le quadrillage de l'axe Y de droite est visible ou non.", + "expressionXY.labelsOrientationConfig.yRight.help": "Spécifie l'orientation des étiquettes de l'axe Y de droite.", + "expressionXY.tickLabelsConfig.yRight.help": "Spécifie si les étiquettes de graduation de l'axe Y de droite sont visibles ou non.", + "expressionXY.axisTitlesVisibilityConfig.yRight.help": "Spécifie si le titre de l'axe Y de droite est visible ou non.", + "expressionXY.xyVis.yRightExtent.help": "Portée de l'axe Y de droite", + "expressionXY.xyVis.yRightTitle.help": "Titre de l'axe Y de droite", "xpack.lens.xySuggestions.asPercentageTitle": "Pourcentage", "xpack.lens.xySuggestions.barChartTitle": "Graphique à barres", "xpack.lens.xySuggestions.dateSuggestion": "{yTitle} sur {xTitle}", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index ab8c2681e7a45..fc47b7ddf92a4 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -770,8 +770,11 @@ "xpack.lens.shared.chartValueLabelVisibilityLabel": "ラベル", "xpack.lens.shared.curveLabel": "視覚オプション", "xpack.lens.shared.legend.filterForValueButtonAriaLabel": "値でフィルター", + "expressionXY.legend.filterForValueButtonAriaLabel": "値でフィルター", + "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}、フィルターオプション", "xpack.lens.shared.legend.filterOptionsLegend": "{legendDataLabel}、フィルターオプション", "xpack.lens.shared.legend.filterOutValueButtonAriaLabel": "値を除外", + "expressionXY.legend.filterOutValueButtonAriaLabel": "値を除外", "xpack.lens.shared.legendAlignmentLabel": "アラインメント", "xpack.lens.shared.legendInsideAlignmentLabel": "アラインメント", "xpack.lens.shared.legendInsideColumnsLabel": "列の数", @@ -868,34 +871,34 @@ "xpack.lens.xyChart.axisSide.left": "左", "xpack.lens.xyChart.axisSide.right": "右", "xpack.lens.xyChart.axisSide.top": "トップ", - "xpack.lens.xyChart.axisTitlesSettings.help": "xおよびy軸のタイトルを表示", + "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "xおよびy軸のタイトルを表示", "xpack.lens.xyChart.bottomAxisDisabledHelpText": "この設定は、下の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.bottomAxisLabel": "下の軸", "xpack.lens.xyChart.boundaryError": "下界は上界よりも大きくなければなりません", "xpack.lens.xyChart.curveStyleLabel": "曲線", - "xpack.lens.xyChart.curveType.help": "折れ線グラフで曲線タイプをレンダリングする方法を定義します", - "xpack.lens.xyChart.emptyXLabel": "(空)", - "xpack.lens.xyChart.extentMode.help": "範囲モード", - "xpack.lens.xyChart.fillOpacity.help": "エリアグラフの塗りつぶしの透明度を定義", + "expressionXY.xyVis.curveType.help": "折れ線グラフで曲線タイプをレンダリングする方法を定義します", + "expressionXY.xyChart.emptyXLabel": "(空)", + "expressionXY.axisExtentConfig.extentMode.help": "範囲モード", + "expressionXY.xyVis.fillOpacity.help": "エリアグラフの塗りつぶしの透明度を定義", "xpack.lens.xyChart.fillOpacityLabel": "塗りつぶしの透明度", - "xpack.lens.xyChart.fittingFunction.help": "欠測値の処理方法を定義", - "xpack.lens.xyChart.floatingColumns.help": "凡例がグラフ内に表示されるときに列数を指定します。", + "expressionXY.xyVis.fittingFunction.help": "欠測値の処理方法を定義", + "expressionXY.legendConfig.floatingColumns.help": "凡例がグラフ内に表示されるときに列数を指定します。", "xpack.lens.xyChart.Gridlines": "グリッド線", - "xpack.lens.xyChart.gridlinesSettings.help": "xおよびy軸のグリッド線を表示", - "xpack.lens.xyChart.help": "X/Y チャート", - "xpack.lens.xyChart.hideEndzones.help": "部分データの終了ゾーンマーカーを非表示", - "xpack.lens.xyChart.horizontalAlignment.help": "凡例がグラフ内に表示されるときに凡例の横の配置を指定します。", + "expressionXY.xyVis.gridlinesVisibilitySettings.help": "xおよびy軸のグリッド線を表示", + "expressionXY.xyVis.help": "X/Y チャート", + "expressionXY.xyVis.hideEndzones.help": "部分データの終了ゾーンマーカーを非表示", + "expressionXY.legendConfig.horizontalAlignment.help": "凡例がグラフ内に表示されるときに凡例の横の配置を指定します。", "xpack.lens.xyChart.horizontalAxisLabel": "横軸", "xpack.lens.xyChart.horizontalLeftAxisLabel": "横上軸", "xpack.lens.xyChart.horizontalRightAxisLabel": "横下軸", "xpack.lens.xyChart.inclusiveZero": "境界にはゼロを含める必要があります。", - "xpack.lens.xyChart.isInside.help": "凡例がグラフ内に表示されるかどうかを指定します", - "xpack.lens.xyChart.isVisible.help": "判例の表示・非表示を指定します。", - "xpack.lens.xyChart.labelsOrientation.help": "軸ラベルの回転を定義します", + "expressionXY.legendConfig.isInside.help": "凡例がグラフ内に表示されるかどうかを指定します", + "expressionXY.legendConfig.isVisible.help": "判例の表示・非表示を指定します。", + "expressionXY.xyVis.labelsOrientation.help": "軸ラベルの回転を定義します", "xpack.lens.xyChart.layerReferenceLineLabel": "基準線", "xpack.lens.xyChart.leftAxisDisabledHelpText": "この設定は、左の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.leftAxisLabel": "左の軸", - "xpack.lens.xyChart.legend.help": "チャートの凡例を構成します。", + "expressionXY.xyVis.legend.help": "チャートの凡例を構成します。", "xpack.lens.xyChart.legendLocation.inside": "内部", "xpack.lens.xyChart.legendLocation.outside": "外側", "xpack.lens.xyChart.legendVisibility.auto": "自動", @@ -905,50 +908,49 @@ "xpack.lens.xyChart.markerPosition.below": "一番下", "xpack.lens.xyChart.markerPosition.left": "左", "xpack.lens.xyChart.markerPosition.right": "右", - "xpack.lens.xyChart.maxLines.help": "凡例項目ごとの行数を指定します。", + "expressionXY.legendConfig.maxLines.help": "凡例項目ごとの行数を指定します。", "xpack.lens.xyChart.missingValuesLabel": "欠測値", "xpack.lens.xyChart.missingValuesLabelHelpText": "デフォルトでは、Lensではデータのギャップが表示されません。ギャップを埋めるには、選択します。", "xpack.lens.xyChart.nestUnderRoot": "データセット全体", - "xpack.lens.xyChart.position.help": "凡例の配置を指定します。", - "xpack.lens.xyChart.renderer.help": "X/Y チャートを再レンダリング", + "expressionXY.legendConfig.position.help": "凡例の配置を指定します。", + "expressionXY.xyVis.renderer.help": "X/Y チャートを再レンダリング", "xpack.lens.xyChart.rightAxisDisabledHelpText": "この設定は、右の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.rightAxisLabel": "右の軸", "xpack.lens.xyChart.seriesColor.auto": "自動", "xpack.lens.xyChart.seriesColor.label": "系列色", - "xpack.lens.xyChart.shouldTruncate.help": "凡例項目が切り捨てられるかどうかを指定します", + "expressionXY.legendConfig.shouldTruncate.help": "凡例項目が切り捨てられるかどうかを指定します", "xpack.lens.xyChart.showEnzones": "部分データマーカーを表示", - "xpack.lens.xyChart.showSingleSeries.help": "エントリが1件の凡例を表示するかどうかを指定します", + "expressionXY.legendConfig.showSingleSeries.help": "エントリが1件の凡例を表示するかどうかを指定します", "xpack.lens.xyChart.splitSeries": "内訳の基準", "xpack.lens.xyChart.tickLabels": "目盛ラベル", - "xpack.lens.xyChart.tickLabelsSettings.help": "xおよびy軸の目盛ラベルを表示", - "xpack.lens.xyChart.title.help": "軸のタイトル", + "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "xおよびy軸の目盛ラベルを表示", "xpack.lens.xyChart.topAxisDisabledHelpText": "この設定は、上の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.topAxisLabel": "上の軸", "xpack.lens.xyChart.valuesHistogramDisabledHelpText": "この設定はヒストグラムで変更できません。", - "xpack.lens.xyChart.valuesInLegend.help": "凡例に値を表示", + "expressionXY.xyVis.valuesInLegend.help": "凡例に値を表示", "xpack.lens.xyChart.valuesPercentageDisabledHelpText": "この設定は割合エリアグラフで変更できません。", "xpack.lens.xyChart.valuesStackedDisabledHelpText": "この設定は積み上げ棒グラフまたは割合棒グラフで変更できません", - "xpack.lens.xyChart.verticalAlignment.help": "凡例がグラフ内に表示されるときに凡例の縦の配置を指定します。", + "expressionXY.legendConfig.verticalAlignment.help": "凡例がグラフ内に表示されるときに凡例の縦の配置を指定します。", "xpack.lens.xyChart.verticalAxisLabel": "縦軸", "xpack.lens.xyChart.verticalLeftAxisLabel": "縦左軸", "xpack.lens.xyChart.verticalRightAxisLabel": "縦右軸", - "xpack.lens.xyChart.xAxisGridlines.help": "x 軸のグリッド線を表示するかどうかを指定します。", - "xpack.lens.xyChart.xAxisLabelsOrientation.help": "x軸のラベルの向きを指定します。", - "xpack.lens.xyChart.xAxisTickLabels.help": "x軸の目盛ラベルを表示するかどうかを指定します。", - "xpack.lens.xyChart.xAxisTitle.help": "x軸のタイトルを表示するかどうかを指定します。", - "xpack.lens.xyChart.xTitle.help": "x軸のタイトル", - "xpack.lens.xyChart.yLeftAxisgridlines.help": "左y軸のグリッド線を表示するかどうかを指定します。", - "xpack.lens.xyChart.yLeftAxisLabelsOrientation.help": "左y軸のラベルの向きを指定します。", - "xpack.lens.xyChart.yLeftAxisTickLabels.help": "左y軸の目盛ラベルを表示するかどうかを指定します。", - "xpack.lens.xyChart.yLeftAxisTitle.help": "左y軸のタイトルを表示するかどうかを指定します。", - "xpack.lens.xyChart.yLeftExtent.help": "Y左軸範囲", - "xpack.lens.xyChart.yLeftTitle.help": "左y軸のタイトル", - "xpack.lens.xyChart.yRightAxisgridlines.help": "右y軸のグリッド線を表示するかどうかを指定します。", - "xpack.lens.xyChart.yRightAxisLabelsOrientation.help": "右y軸のラベルの向きを指定します。", - "xpack.lens.xyChart.yRightAxisTickLabels.help": "右y軸の目盛ラベルを表示するかどうかを指定します。", - "xpack.lens.xyChart.yRightAxisTitle.help": "右y軸のタイトルを表示するかどうかを指定します。", - "xpack.lens.xyChart.yRightExtent.help": "Y右軸範囲", - "xpack.lens.xyChart.yRightTitle.help": "右 y 軸のタイトル", + "expressionXY.gridlinesConfig.x.help": "x 軸のグリッド線を表示するかどうかを指定します。", + "expressionXY.labelsOrientationConfig.x.help": "x軸のラベルの向きを指定します。", + "expressionXY.tickLabelsConfig.x.help": "x軸の目盛ラベルを表示するかどうかを指定します。", + "expressionXY.axisTitlesVisibilityConfig.x.help": "x軸のタイトルを表示するかどうかを指定します。", + "expressionXY.xyVis.xTitle.help": "x軸のタイトル", + "expressionXY.gridlinesConfig.yLeft.help": "左y軸のグリッド線を表示するかどうかを指定します。", + "expressionXY.labelsOrientationConfig.yLeft.help": "左y軸のラベルの向きを指定します。", + "expressionXY.tickLabelsConfig.yLeft.help": "左y軸の目盛ラベルを表示するかどうかを指定します。", + "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "左y軸のタイトルを表示するかどうかを指定します。", + "expressionXY.xyVis.yLeftExtent.help": "Y左軸範囲", + "expressionXY.xyVis.yLeftTitle.help": "左y軸のタイトル", + "expressionXY.gridlinesConfig.yRight.help": "右y軸のグリッド線を表示するかどうかを指定します。", + "expressionXY.labelsOrientationConfig.yRight.help": "右y軸のラベルの向きを指定します。", + "expressionXY.tickLabelsConfig.yRight.help": "右y軸の目盛ラベルを表示するかどうかを指定します。", + "expressionXY.axisTitlesVisibilityConfig.yRight.help": "右y軸のタイトルを表示するかどうかを指定します。", + "expressionXY.xyVis.yRightExtent.help": "Y右軸範囲", + "expressionXY.xyVis.yRightTitle.help": "右 y 軸のタイトル", "xpack.lens.xySuggestions.asPercentageTitle": "割合(%)", "xpack.lens.xySuggestions.barChartTitle": "棒グラフ", "xpack.lens.xySuggestions.dateSuggestion": "{xTitle}の上の {yTitle}", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index d8d945fb4f06d..8ce79eb897cb5 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -775,9 +775,10 @@ "xpack.lens.shared.axisNameLabel": "轴标题", "xpack.lens.shared.chartValueLabelVisibilityLabel": "标签", "xpack.lens.shared.curveLabel": "视觉选项", - "xpack.lens.shared.legend.filterForValueButtonAriaLabel": "筛留值", + "expressionXY.legend.filterForValueButtonAriaLabel": "筛留值", + "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}, 筛选选项", "xpack.lens.shared.legend.filterOptionsLegend": "{legendDataLabel}, 筛选选项", - "xpack.lens.shared.legend.filterOutValueButtonAriaLabel": "筛除值", + "expressionXY.legend.filterOutValueButtonAriaLabel": "筛除值", "xpack.lens.shared.legendAlignmentLabel": "对齐方式", "xpack.lens.shared.legendInsideAlignmentLabel": "对齐方式", "xpack.lens.shared.legendInsideColumnsLabel": "列数目", @@ -874,34 +875,34 @@ "xpack.lens.xyChart.axisSide.left": "左", "xpack.lens.xyChart.axisSide.right": "右", "xpack.lens.xyChart.axisSide.top": "顶部", - "xpack.lens.xyChart.axisTitlesSettings.help": "显示 x 和 y 轴标题", + "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "显示 x 和 y 轴标题", "xpack.lens.xyChart.bottomAxisDisabledHelpText": "此设置仅在启用底轴时应用。", "xpack.lens.xyChart.bottomAxisLabel": "底轴", "xpack.lens.xyChart.boundaryError": "下边界必须大于上边界", "xpack.lens.xyChart.curveStyleLabel": "曲线", - "xpack.lens.xyChart.curveType.help": "定义为折线图渲染曲线类型的方式", - "xpack.lens.xyChart.emptyXLabel": "(空)", - "xpack.lens.xyChart.extentMode.help": "范围模式", - "xpack.lens.xyChart.fillOpacity.help": "定义面积图填充透明度", + "expressionXY.xyVis.curveType.help": "定义为折线图渲染曲线类型的方式", + "expressionXY.xyChart.emptyXLabel": "(空)", + "expressionXY.axisExtentConfig.extentMode.help": "范围模式", + "expressionXY.xyVis.fillOpacity.help": "定义面积图填充透明度", "xpack.lens.xyChart.fillOpacityLabel": "填充透明度", - "xpack.lens.xyChart.fittingFunction.help": "定义处理缺失值的方式", - "xpack.lens.xyChart.floatingColumns.help": "指定图例显示在图表内时的列数。", + "expressionXY.xyVis.fittingFunction.help": "定义处理缺失值的方式", + "expressionXY.legendConfig.floatingColumns.help": "指定图例显示在图表内时的列数。", "xpack.lens.xyChart.Gridlines": "网格线", - "xpack.lens.xyChart.gridlinesSettings.help": "显示 x 和 y 轴网格线", - "xpack.lens.xyChart.help": "X/Y 图表", - "xpack.lens.xyChart.hideEndzones.help": "隐藏部分数据的末日区域标记", - "xpack.lens.xyChart.horizontalAlignment.help": "指定图例显示在图表内时水平对齐。", + "expressionXY.xyVis.gridlinesVisibilitySettings.help": "显示 x 和 y 轴网格线", + "expressionXY.xyVis.help": "X/Y 图表", + "expressionXY.xyVis.hideEndzones.help": "隐藏部分数据的末日区域标记", + "expressionXY.legendConfig.horizontalAlignment.help": "指定图例显示在图表内时水平对齐。", "xpack.lens.xyChart.horizontalAxisLabel": "水平轴", "xpack.lens.xyChart.horizontalLeftAxisLabel": "水平顶轴", "xpack.lens.xyChart.horizontalRightAxisLabel": "水平底轴", "xpack.lens.xyChart.inclusiveZero": "边界必须包括零。", - "xpack.lens.xyChart.isInside.help": "指定图例是否在图表内", - "xpack.lens.xyChart.isVisible.help": "指定图例是否可见。", - "xpack.lens.xyChart.labelsOrientation.help": "定义轴标签的旋转", + "expressionXY.legendConfig.isInside.help": "指定图例是否在图表内", + "expressionXY.legendConfig.isVisible.help": "指定图例是否可见。", + "expressionXY.xyVis.labelsOrientation.help": "定义轴标签的旋转", "xpack.lens.xyChart.layerReferenceLineLabel": "参考线", "xpack.lens.xyChart.leftAxisDisabledHelpText": "此设置仅在启用左轴时应用。", "xpack.lens.xyChart.leftAxisLabel": "左轴", - "xpack.lens.xyChart.legend.help": "配置图表图例。", + "expressionXY.xyVis.legend.help": "配置图表图例。", "xpack.lens.xyChart.legendLocation.inside": "内部", "xpack.lens.xyChart.legendLocation.outside": "外部", "xpack.lens.xyChart.legendVisibility.auto": "自动", @@ -911,50 +912,49 @@ "xpack.lens.xyChart.markerPosition.below": "底部", "xpack.lens.xyChart.markerPosition.left": "左", "xpack.lens.xyChart.markerPosition.right": "右", - "xpack.lens.xyChart.maxLines.help": "指定每个图例项的行数。", + "expressionXY.legendConfig.maxLines.help": "指定每个图例项的行数。", "xpack.lens.xyChart.missingValuesLabel": "缺少的值", "xpack.lens.xyChart.missingValuesLabelHelpText": "默认情况下,Lens 隐藏数据中的缺口。要填充缺口,请进行选择。", "xpack.lens.xyChart.nestUnderRoot": "整个数据集", - "xpack.lens.xyChart.position.help": "指定图例位置。", - "xpack.lens.xyChart.renderer.help": "X/Y 图表呈现器", + "expressionXY.legendConfig.position.help": "指定图例位置。", + "expressionXY.xyVis.renderer.help": "X/Y 图表呈现器", "xpack.lens.xyChart.rightAxisDisabledHelpText": "此设置仅在启用右轴时应用。", "xpack.lens.xyChart.rightAxisLabel": "右轴", "xpack.lens.xyChart.seriesColor.auto": "自动", "xpack.lens.xyChart.seriesColor.label": "系列颜色", - "xpack.lens.xyChart.shouldTruncate.help": "指定是否将截断图例项", + "expressionXY.legendConfig.shouldTruncate.help": "指定是否将截断图例项", "xpack.lens.xyChart.showEnzones": "显示部分数据标记", - "xpack.lens.xyChart.showSingleSeries.help": "指定是否应显示只包含一个条目的图例", + "expressionXY.legendConfig.showSingleSeries.help": "指定是否应显示只包含一个条目的图例", "xpack.lens.xyChart.splitSeries": "细分方式", "xpack.lens.xyChart.tickLabels": "刻度标签", - "xpack.lens.xyChart.tickLabelsSettings.help": "显示 x 和 y 轴刻度标签", - "xpack.lens.xyChart.title.help": "轴标题", + "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "显示 x 和 y 轴刻度标签", "xpack.lens.xyChart.topAxisDisabledHelpText": "此设置仅在启用顶轴时应用。", "xpack.lens.xyChart.topAxisLabel": "顶轴", "xpack.lens.xyChart.valuesHistogramDisabledHelpText": "不能在直方图上更改此设置。", - "xpack.lens.xyChart.valuesInLegend.help": "在图例中显示值", + "expressionXY.xyVis.valuesInLegend.help": "在图例中显示值", "xpack.lens.xyChart.valuesPercentageDisabledHelpText": "不能在百分比面积图上更改此设置。", "xpack.lens.xyChart.valuesStackedDisabledHelpText": "不能在堆积图或百分比条形图上更改此设置", - "xpack.lens.xyChart.verticalAlignment.help": "指定图例显示在图表内时垂直对齐。", + "expressionXY.legendConfig.verticalAlignment.help": "指定图例显示在图表内时垂直对齐。", "xpack.lens.xyChart.verticalAxisLabel": "垂直轴", "xpack.lens.xyChart.verticalLeftAxisLabel": "垂直左轴", "xpack.lens.xyChart.verticalRightAxisLabel": "垂直右轴", - "xpack.lens.xyChart.xAxisGridlines.help": "指定 x 轴的网格线是否可见。", - "xpack.lens.xyChart.xAxisLabelsOrientation.help": "指定 x 轴的标签方向。", - "xpack.lens.xyChart.xAxisTickLabels.help": "指定 x 轴的刻度标签是否可见。", - "xpack.lens.xyChart.xAxisTitle.help": "指定 x 轴的标题是否可见。", - "xpack.lens.xyChart.xTitle.help": "X 轴标题", - "xpack.lens.xyChart.yLeftAxisgridlines.help": "指定左侧 y 轴的网格线是否可见。", - "xpack.lens.xyChart.yLeftAxisLabelsOrientation.help": "指定左 y 轴的标签方向。", - "xpack.lens.xyChart.yLeftAxisTickLabels.help": "指定左侧 y 轴的刻度标签是否可见。", - "xpack.lens.xyChart.yLeftAxisTitle.help": "指定左侧 y 轴的标题是否可见。", - "xpack.lens.xyChart.yLeftExtent.help": "左侧 Y 轴范围", - "xpack.lens.xyChart.yLeftTitle.help": "左侧 Y 轴标题", - "xpack.lens.xyChart.yRightAxisgridlines.help": "指定右侧 y 轴的网格线是否可见。", - "xpack.lens.xyChart.yRightAxisLabelsOrientation.help": "指定右 y 轴的标签方向。", - "xpack.lens.xyChart.yRightAxisTickLabels.help": "指定右侧 y 轴的刻度标签是否可见。", - "xpack.lens.xyChart.yRightAxisTitle.help": "指定右侧 y 轴的标题是否可见。", - "xpack.lens.xyChart.yRightExtent.help": "右侧 Y 轴范围", - "xpack.lens.xyChart.yRightTitle.help": "右侧 Y 轴标题", + "expressionXY.gridlinesConfig.x.help": "指定 x 轴的网格线是否可见。", + "expressionXY.labelsOrientationConfig.x.help": "指定 x 轴的标签方向。", + "expressionXY.tickLabelsConfig.x.help": "指定 x 轴的刻度标签是否可见。", + "expressionXY.axisTitlesVisibilityConfig.x.help": "指定 x 轴的标题是否可见。", + "expressionXY.xyVis.xTitle.help": "X 轴标题", + "expressionXY.gridlinesConfig.yLeft.help": "指定左侧 y 轴的网格线是否可见。", + "expressionXY.labelsOrientationConfig.yLeft.help": "指定左 y 轴的标签方向。", + "expressionXY.tickLabelsConfig.yLeft.help": "指定左侧 y 轴的刻度标签是否可见。", + "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "指定左侧 y 轴的标题是否可见。", + "expressionXY.xyVis.yLeftExtent.help": "左侧 Y 轴范围", + "expressionXY.xyVis.yLeftTitle.help": "左侧 Y 轴标题", + "expressionXY.gridlinesConfig.yRight.help": "指定右侧 y 轴的网格线是否可见。", + "expressionXY.labelsOrientationConfig.yRight.help": "指定右 y 轴的标签方向。", + "expressionXY.tickLabelsConfig.yRight.help": "指定右侧 y 轴的刻度标签是否可见。", + "expressionXY.axisTitlesVisibilityConfig.yRight.help": "指定右侧 y 轴的标题是否可见。", + "expressionXY.xyVis.yRightExtent.help": "右侧 Y 轴范围", + "expressionXY.xyVis.yRightTitle.help": "右侧 Y 轴标题", "xpack.lens.xySuggestions.asPercentageTitle": "百分比", "xpack.lens.xySuggestions.barChartTitle": "条形图", "xpack.lens.xySuggestions.dateSuggestion": "{yTitle} / {xTitle}", diff --git a/x-pack/test/examples/embedded_lens/embedded_example.ts b/x-pack/test/examples/embedded_lens/embedded_example.ts index d11495f0450b4..bdd881b3ea318 100644 --- a/x-pack/test/examples/embedded_lens/embedded_example.ts +++ b/x-pack/test/examples/embedded_lens/embedded_example.ts @@ -27,12 +27,12 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.common.navigateToApp('embedded_lens_example'); await elasticChart.setNewChartUiDebugFlag(true); await testSubjects.click('lns-example-change-time-range'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); }); it('should show chart', async () => { await testSubjects.click('lns-example-change-color'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await checkData(); }); @@ -60,7 +60,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('should load Lens editor', async () => { await testSubjects.click('lns-example-open-editor'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await checkData(); }); }); diff --git a/x-pack/test/functional/apps/dashboard/_async_dashboard.ts b/x-pack/test/functional/apps/dashboard/_async_dashboard.ts index 92cdc72ffc81a..71ef909ffa24a 100644 --- a/x-pack/test/functional/apps/dashboard/_async_dashboard.ts +++ b/x-pack/test/functional/apps/dashboard/_async_dashboard.ts @@ -137,7 +137,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { // check at least one visualization await renderable.waitForRender(); log.debug('Checking charts rendered'); - await elasticChart.waitForRenderComplete('lnsVisualizationContainer'); + await elasticChart.waitForRenderComplete('xyVisChart'); await appMenu.clickLink('Discover'); await retry.try(async function () { @@ -148,7 +148,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.header.waitUntilLoadingHasFinished(); await renderable.waitForRender(); log.debug('Checking charts rendered'); - await elasticChart.waitForRenderComplete('lnsVisualizationContainer'); + await elasticChart.waitForRenderComplete('xyVisChart'); }); it('toggle from Discover to Dashboard attempt 1', async () => { @@ -161,7 +161,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.header.waitUntilLoadingHasFinished(); await renderable.waitForRender(); log.debug('Checking charts rendered'); - await elasticChart.waitForRenderComplete('lnsVisualizationContainer'); + await elasticChart.waitForRenderComplete('xyVisChart'); }); it('toggle from Discover to Dashboard attempt 2', async () => { @@ -174,7 +174,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.header.waitUntilLoadingHasFinished(); await renderable.waitForRender(); log.debug('Checking charts rendered'); - await elasticChart.waitForRenderComplete('lnsVisualizationContainer'); + await elasticChart.waitForRenderComplete('xyVisChart'); log.debug('Checking saved searches rendered'); await dashboardExpect.savedSearchRowCount(10); diff --git a/x-pack/test/functional/apps/dashboard/dashboard_lens_by_value.ts b/x-pack/test/functional/apps/dashboard/dashboard_lens_by_value.ts index 382449e5e2586..9e4c2554100b9 100644 --- a/x-pack/test/functional/apps/dashboard/dashboard_lens_by_value.ts +++ b/x-pack/test/functional/apps/dashboard/dashboard_lens_by_value.ts @@ -92,7 +92,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { operation: 'average', field: 'bytes', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await PageObjects.lens.notLinkedToOriginatingApp(); // return to origin should not be present in save modal diff --git a/x-pack/test/functional/apps/dashboard/feature_controls/time_to_visualize_security.ts b/x-pack/test/functional/apps/dashboard/feature_controls/time_to_visualize_security.ts index 1d2d3f6862e43..9eeb49f5eb0d2 100644 --- a/x-pack/test/functional/apps/dashboard/feature_controls/time_to_visualize_security.ts +++ b/x-pack/test/functional/apps/dashboard/feature_controls/time_to_visualize_security.ts @@ -130,7 +130,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.lens.switchToVisualization('lnsMetric'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); await PageObjects.lens.assertMetric('Average of bytes', '5,727.322'); await PageObjects.header.waitUntilLoadingHasFinished(); diff --git a/x-pack/test/functional/apps/lens/add_to_dashboard.ts b/x-pack/test/functional/apps/lens/add_to_dashboard.ts index d9bdfbd1ffb6a..5fbfdd0a5806e 100644 --- a/x-pack/test/functional/apps/lens/add_to_dashboard.ts +++ b/x-pack/test/functional/apps/lens/add_to_dashboard.ts @@ -254,11 +254,9 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { field: 'bytes', }); - await PageObjects.lens.waitForVisualization(); - await PageObjects.lens.switchToVisualization('heatmap', 'heat'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); await PageObjects.lens.openDimensionEditor('lnsHeatmap_cellPanel > lns-dimensionTrigger'); await PageObjects.lens.openPalettePanel('lnsHeatmap'); await testSubjects.click('lnsPalettePanel_dynamicColoring_rangeType_groups_number'); diff --git a/x-pack/test/functional/apps/lens/chart_data.ts b/x-pack/test/functional/apps/lens/chart_data.ts index 8a43ff909fea5..ff2f5b339fe53 100644 --- a/x-pack/test/functional/apps/lens/chart_data.ts +++ b/x-pack/test/functional/apps/lens/chart_data.ts @@ -32,8 +32,6 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { operation: 'average', field: 'bytes', }); - - await PageObjects.lens.waitForVisualization(); }); const expectedData = [ @@ -75,34 +73,36 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { } it('should render xy chart', async () => { + await PageObjects.lens.waitForVisualization('xyVisChart'); + const data = await PageObjects.lens.getCurrentChartDebugState(); assertMatchesExpectedData(data!); }); it('should render pie chart', async () => { await PageObjects.lens.switchToVisualization('pie'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('partitionVisChart'); const data = await PageObjects.lens.getCurrentChartDebugState(); assertMatchesExpectedPieData(data!); }); it('should render donut chart', async () => { await PageObjects.lens.switchToVisualization('donut'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('partitionVisChart'); const data = await PageObjects.lens.getCurrentChartDebugState(); assertMatchesExpectedPieData(data!); }); it('should render treemap chart', async () => { await PageObjects.lens.switchToVisualization('treemap', 'treemap'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('partitionVisChart'); const data = await PageObjects.lens.getCurrentChartDebugState(); assertMatchesExpectedPieData(data!); }); it('should render heatmap chart', async () => { await PageObjects.lens.switchToVisualization('heatmap', 'heat'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); if (!debugState) { @@ -150,7 +150,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('should render metric', async () => { await PageObjects.lens.switchToVisualization('lnsMetric'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); await PageObjects.lens.assertMetric('Average of bytes', '5,727.322'); }); }); diff --git a/x-pack/test/functional/apps/lens/disable_auto_apply.ts b/x-pack/test/functional/apps/lens/disable_auto_apply.ts index 3660de10ecd47..e280bbd148493 100644 --- a/x-pack/test/functional/apps/lens/disable_auto_apply.ts +++ b/x-pack/test/functional/apps/lens/disable_auto_apply.ts @@ -83,7 +83,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.applyChanges(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); }); it('should hide suggestions when a change is made', async () => { diff --git a/x-pack/test/functional/apps/lens/drag_and_drop.ts b/x-pack/test/functional/apps/lens/drag_and_drop.ts index 1a7b8e96d6802..d5b929481e6dc 100644 --- a/x-pack/test/functional/apps/lens/drag_and_drop.ts +++ b/x-pack/test/functional/apps/lens/drag_and_drop.ts @@ -10,6 +10,7 @@ import { FtrProviderContext } from '../../ftr_provider_context'; export default function ({ getPageObjects }: FtrProviderContext) { const PageObjects = getPageObjects(['visualize', 'lens', 'common', 'header']); + const xyChartContainer = 'xyVisChart'; describe('lens drag and drop tests', () => { describe('basic drag and drop', () => { @@ -18,7 +19,7 @@ export default function ({ getPageObjects }: FtrProviderContext) { await PageObjects.visualize.clickVisType('lens'); await PageObjects.lens.goToTimeRange(); await PageObjects.header.waitUntilLoadingHasFinished(); - await PageObjects.lens.dragFieldToWorkspace('@timestamp'); + await PageObjects.lens.dragFieldToWorkspace('@timestamp', xyChartContainer); expect(await PageObjects.lens.getDimensionTriggerText('lnsXY_xDimensionPanel')).to.eql( '@timestamp' @@ -136,7 +137,7 @@ export default function ({ getPageObjects }: FtrProviderContext) { it('Should duplicate and swap elements when dragging over secondary drop targets', async () => { await PageObjects.lens.removeLayer(); await PageObjects.lens.switchToVisualization('bar'); - await PageObjects.lens.dragFieldToWorkspace('@timestamp'); + await PageObjects.lens.dragFieldToWorkspace('@timestamp', xyChartContainer); await PageObjects.lens.dragDimensionToExtraDropType( 'lnsXY_xDimensionPanel > lns-dimensionTrigger', @@ -165,8 +166,8 @@ export default function ({ getPageObjects }: FtrProviderContext) { it('should combine breakdown dimension with the horizontal one', async () => { await PageObjects.lens.removeLayer(); - await PageObjects.lens.dragFieldToWorkspace('clientip'); - await PageObjects.lens.dragFieldToWorkspace('@message.raw'); + await PageObjects.lens.dragFieldToWorkspace('clientip', xyChartContainer); + await PageObjects.lens.dragFieldToWorkspace('@message.raw', xyChartContainer); await PageObjects.lens.dragDimensionToExtraDropType( 'lnsXY_splitDimensionPanel > lns-dimensionTrigger', @@ -180,7 +181,7 @@ export default function ({ getPageObjects }: FtrProviderContext) { it('should combine field to existing horizontal dimension', async () => { await PageObjects.lens.removeLayer(); - await PageObjects.lens.dragFieldToWorkspace('clientip'); + await PageObjects.lens.dragFieldToWorkspace('clientip', xyChartContainer); await PageObjects.lens.dragFieldToExtraDropType( '@message.raw', @@ -194,7 +195,7 @@ export default function ({ getPageObjects }: FtrProviderContext) { it('should combine two multi terms dimensions', async () => { await PageObjects.lens.removeLayer(); - await PageObjects.lens.dragFieldToWorkspace('clientip'); + await PageObjects.lens.dragFieldToWorkspace('clientip', xyChartContainer); await PageObjects.lens.dragFieldToExtraDropType( '@message.raw', @@ -313,10 +314,10 @@ export default function ({ getPageObjects }: FtrProviderContext) { await PageObjects.visualize.clickVisType('lens'); await PageObjects.lens.goToTimeRange(); await PageObjects.header.waitUntilLoadingHasFinished(); - await PageObjects.lens.dragFieldToWorkspace('@timestamp'); - await PageObjects.lens.waitForVisualization(); - await PageObjects.lens.dragFieldToWorkspace('clientip'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.dragFieldToWorkspace('@timestamp', xyChartContainer); + await PageObjects.lens.waitForVisualization(xyChartContainer); + await PageObjects.lens.dragFieldToWorkspace('clientip', xyChartContainer); + await PageObjects.lens.waitForVisualization(xyChartContainer); expect( await PageObjects.lens.getDimensionTriggersTexts('lnsXY_splitDimensionPanel') ).to.eql(['Top 3 values of clientip']); @@ -329,11 +330,11 @@ export default function ({ getPageObjects }: FtrProviderContext) { it('overwrite existing time dimension if one exists already', async () => { await PageObjects.lens.searchField('utc'); - await PageObjects.lens.dragFieldToWorkspace('utc_time'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.dragFieldToWorkspace('utc_time', xyChartContainer); + await PageObjects.lens.waitForVisualization(xyChartContainer); await PageObjects.lens.searchField('client'); - await PageObjects.lens.dragFieldToWorkspace('clientip'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.dragFieldToWorkspace('clientip', xyChartContainer); + await PageObjects.lens.waitForVisualization(xyChartContainer); expect(await PageObjects.lens.getDimensionTriggersTexts('lnsXY_xDimensionPanel')).to.eql([ 'utc_time', ]); diff --git a/x-pack/test/functional/apps/lens/epoch_millis.ts b/x-pack/test/functional/apps/lens/epoch_millis.ts index deaa3e720101e..d882d69ddd1fd 100644 --- a/x-pack/test/functional/apps/lens/epoch_millis.ts +++ b/x-pack/test/functional/apps/lens/epoch_millis.ts @@ -43,7 +43,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { operation: 'count', field: 'Records', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); expect(await PageObjects.lens.getDatatableCellText(0, 0)).to.eql('1'); }); @@ -52,7 +52,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.enableTimeShift(); await PageObjects.lens.setTimeShift('3d'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); expect(await PageObjects.lens.getDatatableCellText(0, 0)).to.eql('2'); }); }); diff --git a/x-pack/test/functional/apps/lens/formula.ts b/x-pack/test/functional/apps/lens/formula.ts index c2e42328dc943..02d4fda0e96a6 100644 --- a/x-pack/test/functional/apps/lens/formula.ts +++ b/x-pack/test/functional/apps/lens/formula.ts @@ -32,7 +32,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { }); await PageObjects.lens.switchToFormula(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // .echLegendItem__title is the only viable way of getting the xy chart's // legend item(s), so we're using a class selector here. // 4th item is the other bucket @@ -174,7 +174,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { operation: 'formula', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); expect(await PageObjects.lens.getErrorCount()).to.eql(0); }); diff --git a/x-pack/test/functional/apps/lens/gauge.ts b/x-pack/test/functional/apps/lens/gauge.ts index cce05d7b9baba..c21ddf5b70791 100644 --- a/x-pack/test/functional/apps/lens/gauge.ts +++ b/x-pack/test/functional/apps/lens/gauge.ts @@ -32,7 +32,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { operation: 'average', field: 'bytes', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); }); it('should switch to gauge and render a gauge with default values', async () => { diff --git a/x-pack/test/functional/apps/lens/heatmap.ts b/x-pack/test/functional/apps/lens/heatmap.ts index 946de0c9c8e93..1386e1beea899 100644 --- a/x-pack/test/functional/apps/lens/heatmap.ts +++ b/x-pack/test/functional/apps/lens/heatmap.ts @@ -33,12 +33,12 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { field: 'bytes', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); }); it('should render heatmap chart with the temperature palette', async () => { await PageObjects.lens.switchToVisualization('heatmap', 'heat'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); if (!debugState) { @@ -78,7 +78,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { typeCharByChar: true, }); }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); @@ -98,7 +98,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('should not change when passing from percentage to number', async () => { await testSubjects.click('lnsPalettePanel_dynamicColoring_rangeType_groups_number'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); @@ -124,7 +124,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await testSubjects.setValue('lnsPalettePanel_dynamicColoring_range_value_0', '0', { clearWithKeyboard: true, }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); @@ -144,7 +144,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('should reset stop numbers when changing palette', async () => { await PageObjects.lens.changePaletteTo('status'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); @@ -164,7 +164,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('should not change when passing from number to percent', async () => { await testSubjects.click('lnsPalettePanel_dynamicColoring_rangeType_groups_percent'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('heatmapChart'); const debugState = await PageObjects.lens.getCurrentChartDebugState(); diff --git a/x-pack/test/functional/apps/lens/inspector.ts b/x-pack/test/functional/apps/lens/inspector.ts index 9db804d324936..d94d3413c07b0 100644 --- a/x-pack/test/functional/apps/lens/inspector.ts +++ b/x-pack/test/functional/apps/lens/inspector.ts @@ -32,7 +32,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { field: 'bytes', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await inspector.open('lnsApp_inspectButton'); }); diff --git a/x-pack/test/functional/apps/lens/persistent_context.ts b/x-pack/test/functional/apps/lens/persistent_context.ts index ff677440e8fe0..445caa1abbec2 100644 --- a/x-pack/test/functional/apps/lens/persistent_context.ts +++ b/x-pack/test/functional/apps/lens/persistent_context.ts @@ -83,7 +83,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.navigationalSearch.clickOnOption(0); await PageObjects.lens.waitForEmptyWorkspace(); await PageObjects.lens.switchToVisualization('lnsMetric'); - await PageObjects.lens.dragFieldToWorkspace('@timestamp'); + await PageObjects.lens.dragFieldToWorkspace('@timestamp', 'mtrVis'); }); it('preserves time range', async () => { // fill the navigation search and select empty @@ -120,7 +120,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.visualize.clickVisType('lens'); await PageObjects.lens.waitForEmptyWorkspace(); await PageObjects.lens.switchToVisualization('lnsMetric'); - await PageObjects.lens.dragFieldToWorkspace('@timestamp'); + await PageObjects.lens.dragFieldToWorkspace('@timestamp', 'mtrVis'); const timePickerValues = await PageObjects.timePicker.getTimeConfigAsAbsoluteTimes(); expect(timePickerValues.start).to.eql(PageObjects.timePicker.defaultStartTime); diff --git a/x-pack/test/functional/apps/lens/rollup.ts b/x-pack/test/functional/apps/lens/rollup.ts index 7de0d7e76c95c..25ab766d04bbd 100644 --- a/x-pack/test/functional/apps/lens/rollup.ts +++ b/x-pack/test/functional/apps/lens/rollup.ts @@ -86,12 +86,12 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { operation: 'sum', field: 'bytes', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); await PageObjects.lens.assertMetric('Sum of bytes', '16,788'); await PageObjects.lens.switchFirstLayerIndexPattern('lens_rolled_up_data'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('mtrVis'); await PageObjects.lens.assertMetric('Sum of bytes', '16,788'); }); diff --git a/x-pack/test/functional/apps/lens/show_underlying_data.ts b/x-pack/test/functional/apps/lens/show_underlying_data.ts index aa2bc03ec3069..4bc8be22eb8f4 100644 --- a/x-pack/test/functional/apps/lens/show_underlying_data.ts +++ b/x-pack/test/functional/apps/lens/show_underlying_data.ts @@ -23,7 +23,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.clickVisualizeListItemTitle('lnsXYvis'); await PageObjects.lens.goToTimeRange(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await PageObjects.lens.configureDimension({ dimension: 'lnsXY_splitDimensionPanel > lns-dimensionTrigger', @@ -31,7 +31,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { field: 'extension.raw', }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // expect the button is shown and enabled @@ -59,7 +59,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.closeDimensionEditor(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // expect the button is shown and enabled await testSubjects.clickWhenNotDisabled(`lnsApp_openInDiscover`); @@ -96,7 +96,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.closeDimensionEditor(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await testSubjects.clickWhenNotDisabled(`lnsApp_openInDiscover`); @@ -132,7 +132,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.closeDimensionEditor(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // expect the button is shown and enabled await testSubjects.clickWhenNotDisabled(`lnsApp_openInDiscover`); @@ -167,7 +167,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.setFilterBy('bytes > 4000'); await PageObjects.common.sleep(1000); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // expect the button is shown and enabled await testSubjects.clickWhenNotDisabled(`lnsApp_openInDiscover`); diff --git a/x-pack/test/functional/apps/lens/smokescreen.ts b/x-pack/test/functional/apps/lens/smokescreen.ts index f0cc3b0da7201..c2a98d2d5dedc 100644 --- a/x-pack/test/functional/apps/lens/smokescreen.ts +++ b/x-pack/test/functional/apps/lens/smokescreen.ts @@ -60,7 +60,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await listingTable.searchForItemWithName('Afancilenstest'); await PageObjects.lens.clickVisualizeListItemTitle('Afancilenstest'); await PageObjects.lens.goToTimeRange(); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); expect(await PageObjects.lens.getTitle()).to.eql('Afancilenstest'); @@ -82,7 +82,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { keepOpen: true, }); await PageObjects.lens.addFilterToAgg(`geo.src : CN`); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // Verify that the field was persisted from the transition expect(await PageObjects.lens.getFiltersAggLabels()).to.eql([`ip : *`, `geo.src : CN`]); @@ -199,7 +199,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { const longLabel = 'Veryveryveryveryveryveryveryveryveryveryveryveryveryveryveryveryveryveryveryveryveryvery long label wrapping multiple lines'; await PageObjects.lens.editDimensionLabel(longLabel); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await PageObjects.lens.closeDimensionEditor(); expect(await PageObjects.lens.getDimensionTriggerText('lnsXY_yDimensionPanel')).to.eql( @@ -239,19 +239,19 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { }); await PageObjects.lens.changeAxisSide('right'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); let data = await PageObjects.lens.getCurrentChartDebugState(); expect(data?.axes?.y.length).to.eql(2); expect(data?.axes?.y.some(({ position }) => position === 'right')).to.eql(true); await PageObjects.lens.changeAxisSide('left'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); data = await PageObjects.lens.getCurrentChartDebugState(); expect(data?.axes?.y.length).to.eql(1); expect(data?.axes?.y.some(({ position }) => position === 'right')).to.eql(false); await PageObjects.lens.changeAxisSide('right'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); await PageObjects.lens.closeDimensionEditor(); }); @@ -261,7 +261,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.lens.openVisualOptions(); await testSubjects.click('lns_valueLabels_inside'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // check for value labels let data = await PageObjects.lens.getCurrentChartDebugState(); @@ -269,7 +269,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { // switch to stacked bar chart await PageObjects.lens.switchToVisualization('bar_stacked'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); // check for value labels data = await PageObjects.lens.getCurrentChartDebugState(); @@ -282,14 +282,14 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await testSubjects.setValue('lnsyLeftAxisTitle', axisTitle, { clearWithKeyboard: true, }); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); let data = await PageObjects.lens.getCurrentChartDebugState(); expect(data?.axes?.y?.[0].title).to.eql(axisTitle); // hide the gridlines await testSubjects.click('lnsshowyLeftAxisGridlines'); - await PageObjects.lens.waitForVisualization(); + await PageObjects.lens.waitForVisualization('xyVisChart'); data = await PageObjects.lens.getCurrentChartDebugState(); expect(data?.axes?.y?.[0].gridlines.length).to.eql(0); diff --git a/x-pack/test/functional/apps/lens/tsvb_open_in_lens.ts b/x-pack/test/functional/apps/lens/tsvb_open_in_lens.ts index 0856fbb4ff1ec..0315d20e5fc91 100644 --- a/x-pack/test/functional/apps/lens/tsvb_open_in_lens.ts +++ b/x-pack/test/functional/apps/lens/tsvb_open_in_lens.ts @@ -48,7 +48,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { it('visualizes field to Lens and loads fields to the dimesion editor', async () => { const button = await testSubjects.find('visualizeEditInLensButton'); await button.click(); - await lens.waitForVisualization(); + await lens.waitForVisualization('xyVisChart'); await retry.try(async () => { const dimensions = await testSubjects.findAll('lns-dimensionTrigger'); expect(dimensions).to.have.length(2); @@ -72,7 +72,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { await header.waitUntilLoadingHasFinished(); const button = await testSubjects.find('visualizeEditInLensButton'); await button.click(); - await lens.waitForVisualization(); + await lens.waitForVisualization('xyVisChart'); expect(await filterBar.hasFilter('extension', 'css')).to.be(true); }); @@ -86,7 +86,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { await header.waitUntilLoadingHasFinished(); const button = await testSubjects.find('visualizeEditInLensButton'); await button.click(); - await lens.waitForVisualization(); + await lens.waitForVisualization('xyVisChart'); expect(await queryBar.getQueryString()).to.equal('machine.os : ios'); }); @@ -128,7 +128,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { const button = await testSubjects.find('visualizeEditInLensButton'); await button.click(); - await lens.waitForVisualization(); + await lens.waitForVisualization('xyVisChart'); await retry.try(async () => { const dimensions = await testSubjects.findAll('lns-dimensionTrigger'); expect(await dimensions[1].getVisibleText()).to.be('Count of records'); @@ -157,7 +157,7 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { const button = await testSubjects.find('visualizeEditInLensButton'); await button.click(); - await lens.waitForVisualization(); + await lens.waitForVisualization('mtrVis'); await retry.try(async () => { const dimensions = await testSubjects.findAll('lns-dimensionTrigger'); expect(await dimensions[1].getVisibleText()).to.be('Count of records'); diff --git a/x-pack/test/functional/apps/maps/lens/choropleth_chart.ts b/x-pack/test/functional/apps/maps/lens/choropleth_chart.ts index daa490f8ef051..420f895fe6aa6 100644 --- a/x-pack/test/functional/apps/maps/lens/choropleth_chart.ts +++ b/x-pack/test/functional/apps/maps/lens/choropleth_chart.ts @@ -47,7 +47,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.visualize.clickVisType('lens'); await PageObjects.lens.goToTimeRange(); - await PageObjects.lens.dragFieldToWorkspace('geo.dest'); + await PageObjects.lens.dragFieldToWorkspace('geo.dest', 'xyVisChart'); // add filter to force data fetch to set activeData await filterBar.addFilter('bytes', 'is between', '200', '10000'); diff --git a/x-pack/test/functional/apps/ml/data_visualizer/index_data_visualizer.ts b/x-pack/test/functional/apps/ml/data_visualizer/index_data_visualizer.ts index a20962e607af2..a65468e0ca3ec 100644 --- a/x-pack/test/functional/apps/ml/data_visualizer/index_data_visualizer.ts +++ b/x-pack/test/functional/apps/ml/data_visualizer/index_data_visualizer.ts @@ -254,7 +254,10 @@ export default function ({ getPageObject, getService }: FtrProviderContext) { const lensMetricField = testData.expected.metricFields![0]; if (lensMetricField) { - await ml.dataVisualizerTable.assertLensActionShowChart(lensMetricField.fieldName); + await ml.dataVisualizerTable.assertLensActionShowChart( + lensMetricField.fieldName, + 'mtrVis' + ); await ml.navigation.browserBackTo('dataVisualizerTable'); } const lensNonMetricField = testData.expected.nonMetricFields?.find( @@ -262,7 +265,10 @@ export default function ({ getPageObject, getService }: FtrProviderContext) { ); if (lensNonMetricField) { - await ml.dataVisualizerTable.assertLensActionShowChart(lensNonMetricField.fieldName); + await ml.dataVisualizerTable.assertLensActionShowChart( + lensNonMetricField.fieldName, + 'mtrVis' + ); await ml.navigation.browserBackTo('dataVisualizerTable'); } }); diff --git a/x-pack/test/functional/page_objects/lens_page.ts b/x-pack/test/functional/page_objects/lens_page.ts index a4f6493d513cb..fa46052705c91 100644 --- a/x-pack/test/functional/page_objects/lens_page.ts +++ b/x-pack/test/functional/page_objects/lens_page.ts @@ -201,7 +201,7 @@ export function LensPageProvider({ getService, getPageObjects }: FtrProviderCont * * @param field - the desired field for the dimension * */ - async dragFieldToWorkspace(field: string) { + async dragFieldToWorkspace(field: string, visualizationTestSubj?: string) { const from = `lnsFieldListPanelField-${field}`; await find.existsByCssSelector(from); await browser.html5DragAndDrop( @@ -209,7 +209,7 @@ export function LensPageProvider({ getService, getPageObjects }: FtrProviderCont testSubjects.getCssSelector('lnsWorkspace') ); await this.waitForLensDragDropToFinish(); - await this.waitForVisualization(); + await this.waitForVisualization(visualizationTestSubj); }, /** diff --git a/x-pack/test/functional/services/ml/data_visualizer_table.ts b/x-pack/test/functional/services/ml/data_visualizer_table.ts index cf9b1f8fa35a5..e5c0dafbd00f7 100644 --- a/x-pack/test/functional/services/ml/data_visualizer_table.ts +++ b/x-pack/test/functional/services/ml/data_visualizer_table.ts @@ -565,12 +565,12 @@ export function MachineLearningDataVisualizerTableProvider( } } - public async assertLensActionShowChart(fieldName: string) { + public async assertLensActionShowChart(fieldName: string, visualizationContainer?: string) { await retry.tryForTime(30 * 1000, async () => { await testSubjects.clickWhenNotDisabled( this.rowSelector(fieldName, 'dataVisualizerActionViewInLensButton') ); - await testSubjects.existOrFail('lnsVisualizationContainer', { + await testSubjects.existOrFail(visualizationContainer ?? 'lnsVisualizationContainer', { timeout: 15 * 1000, }); }); diff --git a/x-pack/test/search_sessions_integration/tests/apps/dashboard/async_search/save_search_session_relative_time.ts b/x-pack/test/search_sessions_integration/tests/apps/dashboard/async_search/save_search_session_relative_time.ts index 71bf03365e66d..d257a2fb560dd 100644 --- a/x-pack/test/search_sessions_integration/tests/apps/dashboard/async_search/save_search_session_relative_time.ts +++ b/x-pack/test/search_sessions_integration/tests/apps/dashboard/async_search/save_search_session_relative_time.ts @@ -63,7 +63,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await searchSessions.save(); await searchSessions.expectState('backgroundCompleted'); - await checkSampleDashboardLoaded(); + await checkSampleDashboardLoaded('xyVisChart'); // load URL to restore a saved session await PageObjects.searchSessionsManagement.goTo(); @@ -74,7 +74,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await PageObjects.header.waitUntilLoadingHasFinished(); await PageObjects.dashboard.waitForRenderComplete(); - await checkSampleDashboardLoaded(); + await checkSampleDashboardLoaded('xyVisChart'); // Check that session is restored await searchSessions.expectState('restored'); @@ -83,11 +83,11 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { // HELPERS - async function checkSampleDashboardLoaded() { + async function checkSampleDashboardLoaded(visualizationContainer?: string) { log.debug('Checking no error labels'); await testSubjects.missingOrFail('embeddableErrorLabel'); log.debug('Checking charts rendered'); - await elasticChart.waitForRenderComplete('lnsVisualizationContainer'); + await elasticChart.waitForRenderComplete(visualizationContainer ?? 'lnsVisualizationContainer'); log.debug('Checking saved searches rendered'); await dashboardExpect.savedSearchRowCount(11); log.debug('Checking input controls rendered'); From 310c1baffe847d1bae8f554dda0f1c4529dcd8a9 Mon Sep 17 00:00:00 2001 From: Nathan Reese Date: Mon, 28 Mar 2022 09:19:42 -0600 Subject: [PATCH 028/160] [Maps] record hexagon clustering layer in telemetry (#128409) * [Maps] record hexagon clustering layer in telemetry * update comments * telemtry_check Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../maps_telemetry/collectors/register.ts | 9 ++++++ .../map_stats/map_stats_collector.ts | 2 ++ .../server/maps_telemetry/map_stats/types.ts | 1 + .../schema/xpack_plugins.json | 28 +++++++++++++++++++ 4 files changed, 40 insertions(+) diff --git a/x-pack/plugins/maps/server/maps_telemetry/collectors/register.ts b/x-pack/plugins/maps/server/maps_telemetry/collectors/register.ts index ea2c59eb5f12c..471e0bd77e84b 100644 --- a/x-pack/plugins/maps/server/maps_telemetry/collectors/register.ts +++ b/x-pack/plugins/maps/server/maps_telemetry/collectors/register.ts @@ -64,6 +64,15 @@ export function registerMapsUsageCollector(usageCollection?: UsageCollectionSetu _meta: { description: 'total number of es grid layers in cluster' }, }, }, + es_agg_hexagons: { + min: { type: 'long', _meta: { description: 'min number of es hexagon layers per map' } }, + max: { type: 'long', _meta: { description: 'max number of es hexagon layers per map' } }, + avg: { type: 'float', _meta: { description: 'avg number of es hexagon layers per map' } }, + total: { + type: 'long', + _meta: { description: 'total number of es hexagon layers in cluster' }, + }, + }, es_agg_heatmap: { min: { type: 'long', _meta: { description: 'min number of es heatmap layers per map' } }, max: { type: 'long', _meta: { description: 'max number of es heatmap layers per map' } }, diff --git a/x-pack/plugins/maps/server/maps_telemetry/map_stats/map_stats_collector.ts b/x-pack/plugins/maps/server/maps_telemetry/map_stats/map_stats_collector.ts index d1d5ceb525e09..f57c3afa7e0b5 100644 --- a/x-pack/plugins/maps/server/maps_telemetry/map_stats/map_stats_collector.ts +++ b/x-pack/plugins/maps/server/maps_telemetry/map_stats/map_stats_collector.ts @@ -334,6 +334,8 @@ function getLayerKey(layerDescriptor: LayerDescriptor): LAYER_KEYS | null { return LAYER_KEYS.ES_AGG_CLUSTERS; } else if (sourceDescriptor.requestType === RENDER_AS.GRID) { return LAYER_KEYS.ES_AGG_GRIDS; + } else if (sourceDescriptor.requestType === RENDER_AS.HEX) { + return LAYER_KEYS.ES_AGG_HEXAGONS; } } diff --git a/x-pack/plugins/maps/server/maps_telemetry/map_stats/types.ts b/x-pack/plugins/maps/server/maps_telemetry/map_stats/types.ts index 64f574c1fe31a..78190873a1768 100644 --- a/x-pack/plugins/maps/server/maps_telemetry/map_stats/types.ts +++ b/x-pack/plugins/maps/server/maps_telemetry/map_stats/types.ts @@ -30,6 +30,7 @@ export enum LAYER_KEYS { ES_POINT_TO_POINT = 'es_point_to_point', ES_AGG_CLUSTERS = 'es_agg_clusters', ES_AGG_GRIDS = 'es_agg_grids', + ES_AGG_HEXAGONS = 'es_agg_hexagons', ES_AGG_HEATMAP = 'es_agg_heatmap', EMS_REGION = 'ems_region', EMS_BASEMAP = 'ems_basemap', diff --git a/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json b/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json index 244599b3fc5e4..99b11d1d14cf6 100644 --- a/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json +++ b/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json @@ -5060,6 +5060,34 @@ } } }, + "es_agg_hexagons": { + "properties": { + "min": { + "type": "long", + "_meta": { + "description": "min number of es hexagon layers per map" + } + }, + "max": { + "type": "long", + "_meta": { + "description": "max number of es hexagon layers per map" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "avg number of es hexagon layers per map" + } + }, + "total": { + "type": "long", + "_meta": { + "description": "total number of es hexagon layers in cluster" + } + } + } + }, "es_agg_heatmap": { "properties": { "min": { From c0a8bfaf37fba982050561ac535028e18220e079 Mon Sep 17 00:00:00 2001 From: Devon Thomson Date: Mon, 28 Mar 2022 11:26:23 -0400 Subject: [PATCH 029/160] [Controls] Do not Close Flyouts on Outside Click (#128548) Do not close on outside click for controls flyouts --- ...ana-plugin-core-public.overlayflyoutopenoptions.md | 1 + ...lic.overlayflyoutopenoptions.outsideclickcloses.md | 11 +++++++++++ src/core/public/overlays/flyout/flyout_service.tsx | 1 + src/core/public/public.api.md | 2 ++ .../public/control_group/editor/create_control.tsx | 1 + .../public/control_group/editor/edit_control.tsx | 1 + .../control_group/editor/edit_control_group.tsx | 1 + 7 files changed, 18 insertions(+) create mode 100644 docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.outsideclickcloses.md diff --git a/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.md b/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.md index defbf79b0ffe2..86117422e5faf 100644 --- a/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.md +++ b/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.md @@ -23,6 +23,7 @@ export interface OverlayFlyoutOpenOptions | [maskProps?](./kibana-plugin-core-public.overlayflyoutopenoptions.maskprops.md) | EuiOverlayMaskProps | (Optional) | | [maxWidth?](./kibana-plugin-core-public.overlayflyoutopenoptions.maxwidth.md) | boolean \| number \| string | (Optional) | | [onClose?](./kibana-plugin-core-public.overlayflyoutopenoptions.onclose.md) | (flyout: OverlayRef) => void | (Optional) EuiFlyout onClose handler. If provided the consumer is responsible for calling flyout.close() to close the flyout; | +| [outsideClickCloses?](./kibana-plugin-core-public.overlayflyoutopenoptions.outsideclickcloses.md) | boolean | (Optional) | | [ownFocus?](./kibana-plugin-core-public.overlayflyoutopenoptions.ownfocus.md) | boolean | (Optional) | | [size?](./kibana-plugin-core-public.overlayflyoutopenoptions.size.md) | EuiFlyoutSize | (Optional) | diff --git a/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.outsideclickcloses.md b/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.outsideclickcloses.md new file mode 100644 index 0000000000000..acb9bac6f55da --- /dev/null +++ b/docs/development/core/public/kibana-plugin-core-public.overlayflyoutopenoptions.outsideclickcloses.md @@ -0,0 +1,11 @@ + + +[Home](./index.md) > [kibana-plugin-core-public](./kibana-plugin-core-public.md) > [OverlayFlyoutOpenOptions](./kibana-plugin-core-public.overlayflyoutopenoptions.md) > [outsideClickCloses](./kibana-plugin-core-public.overlayflyoutopenoptions.outsideclickcloses.md) + +## OverlayFlyoutOpenOptions.outsideClickCloses property + +Signature: + +```typescript +outsideClickCloses?: boolean; +``` diff --git a/src/core/public/overlays/flyout/flyout_service.tsx b/src/core/public/overlays/flyout/flyout_service.tsx index 600e1e0e97b25..94c0ffdf95b23 100644 --- a/src/core/public/overlays/flyout/flyout_service.tsx +++ b/src/core/public/overlays/flyout/flyout_service.tsx @@ -87,6 +87,7 @@ export interface OverlayFlyoutOpenOptions { size?: EuiFlyoutSize; maxWidth?: boolean | number | string; hideCloseButton?: boolean; + outsideClickCloses?: boolean; maskProps?: EuiOverlayMaskProps; /** * EuiFlyout onClose handler. diff --git a/src/core/public/public.api.md b/src/core/public/public.api.md index b9a0ca45e4629..44224e6fcaea7 100644 --- a/src/core/public/public.api.md +++ b/src/core/public/public.api.md @@ -829,6 +829,8 @@ export interface OverlayFlyoutOpenOptions { maxWidth?: boolean | number | string; onClose?: (flyout: OverlayRef) => void; // (undocumented) + outsideClickCloses?: boolean; + // (undocumented) ownFocus?: boolean; // (undocumented) size?: EuiFlyoutSize; diff --git a/src/plugins/controls/public/control_group/editor/create_control.tsx b/src/plugins/controls/public/control_group/editor/create_control.tsx index 005341359a8a9..094a65f3bb9d0 100644 --- a/src/plugins/controls/public/control_group/editor/create_control.tsx +++ b/src/plugins/controls/public/control_group/editor/create_control.tsx @@ -92,6 +92,7 @@ export const CreateControlButton = ({ ), { + outsideClickCloses: false, onClose: (flyout) => onCancel(flyout), } ); diff --git a/src/plugins/controls/public/control_group/editor/edit_control.tsx b/src/plugins/controls/public/control_group/editor/edit_control.tsx index b70b7ef5f7e40..55848e5363729 100644 --- a/src/plugins/controls/public/control_group/editor/edit_control.tsx +++ b/src/plugins/controls/public/control_group/editor/edit_control.tsx @@ -123,6 +123,7 @@ export const EditControlButton = ({ embeddableId }: { embeddableId: string }) => reduxContainerContext ), { + outsideClickCloses: false, onClose: (flyout) => onCancel(flyout), } ); diff --git a/src/plugins/controls/public/control_group/editor/edit_control_group.tsx b/src/plugins/controls/public/control_group/editor/edit_control_group.tsx index f21d5d550f1a3..dcf955666657f 100644 --- a/src/plugins/controls/public/control_group/editor/edit_control_group.tsx +++ b/src/plugins/controls/public/control_group/editor/edit_control_group.tsx @@ -59,6 +59,7 @@ export const EditControlGroup = ({ ), { + outsideClickCloses: false, onClose: () => flyoutInstance.close(), } ); From a89ae4a6a082a54a630136a47ac7e9fb2279d167 Mon Sep 17 00:00:00 2001 From: Dima Arnautov Date: Mon, 28 Mar 2022 17:36:09 +0200 Subject: [PATCH 030/160] [ML] Add `throughput_last_minute` to the Deployment stats (#128611) * replace state column with throughput_last_minute * model size stats formatting * update type * fix i18n --- .../plugins/ml/common/types/trained_models.ts | 2 + .../models_management/expanded_row.tsx | 94 +++++++++++-------- .../nodes_overview/allocated_models.tsx | 19 ++-- .../nodes_overview/expanded_row.tsx | 4 +- .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - 6 files changed, 71 insertions(+), 50 deletions(-) diff --git a/x-pack/plugins/ml/common/types/trained_models.ts b/x-pack/plugins/ml/common/types/trained_models.ts index 3de759d9dbc87..ad59b7a917c49 100644 --- a/x-pack/plugins/ml/common/types/trained_models.ts +++ b/x-pack/plugins/ml/common/types/trained_models.ts @@ -158,6 +158,7 @@ export interface TrainedModelDeploymentStatsResponse { last_access: number; number_of_pending_requests: number; start_time: number; + throughput_last_minute: number; }>; } @@ -190,6 +191,7 @@ export interface AllocatedModel { last_access?: number; number_of_pending_requests: number; start_time: number; + throughput_last_minute: number; }; } diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/expanded_row.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/expanded_row.tsx index d3c8d9c17e17a..a50844bdac26f 100644 --- a/x-pack/plugins/ml/public/application/trained_models/models_management/expanded_row.tsx +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/expanded_row.tsx @@ -5,7 +5,7 @@ * 2.0. */ -import React, { FC, useEffect, useState } from 'react'; +import React, { FC, useEffect, useState, useMemo, useCallback } from 'react'; import { omit, pick } from 'lodash'; import { EuiBadge, @@ -17,18 +17,19 @@ import { EuiPanel, EuiSpacer, EuiTabbedContent, - EuiTitle, EuiTabbedContentTab, + EuiTitle, } from '@elastic/eui'; import type { EuiDescriptionListProps } from '@elastic/eui/src/components/description_list/description_list'; import { FormattedMessage } from '@kbn/i18n-react'; import type { ModelItemFull } from './models_list'; -import { timeFormatter } from '../../../../common/util/date_utils'; import { isDefined } from '../../../../common/types/guards'; import { isPopulatedObject } from '../../../../common'; import { ModelPipelines } from './pipelines'; import { AllocatedModels } from '../nodes_overview/allocated_models'; import type { AllocatedModel } from '../../../../common/types/trained_models'; +import { useFieldFormatter } from '../../contexts/kibana/use_field_formatter'; +import { FIELD_FORMAT_IDS } from '../../../../../../../src/plugins/field_formats/common'; interface ExpandedRowProps { item: ModelItemFull; @@ -47,48 +48,62 @@ const badgeFormatter = (items: string[]) => { ); }; -const formatterDictionary: Record JSX.Element | string | undefined> = { - tags: badgeFormatter, - roles: badgeFormatter, - create_time: timeFormatter, - timestamp: timeFormatter, -}; +export function useListItemsFormatter() { + const bytesFormatter = useFieldFormatter(FIELD_FORMAT_IDS.BYTES); + const dateFormatter = useFieldFormatter(FIELD_FORMAT_IDS.DATE); -export function formatToListItems( - items: Record | object -): EuiDescriptionListProps['listItems'] { - return Object.entries(items) - .filter(([, value]) => isDefined(value)) - .map(([title, value]) => { - if (title in formatterDictionary) { - return { - title, - description: formatterDictionary[title](value), - }; - } - return { - title, - description: - typeof value === 'object' ? ( - - {JSON.stringify(value, null, 2)} - - ) : ( - value.toString() - ), - }; - }); + const formatterDictionary: Record JSX.Element | string | undefined> = + useMemo( + () => ({ + tags: badgeFormatter, + roles: badgeFormatter, + create_time: dateFormatter, + timestamp: dateFormatter, + model_size_bytes: bytesFormatter, + required_native_memory_bytes: bytesFormatter, + }), + [] + ); + + return useCallback( + (items: Record | object): EuiDescriptionListProps['listItems'] => { + return Object.entries(items) + .filter(([, value]) => isDefined(value)) + .map(([title, value]) => { + if (title in formatterDictionary) { + return { + title, + description: formatterDictionary[title](value), + }; + } + return { + title, + description: + typeof value === 'object' ? ( + + {JSON.stringify(value, null, 2)} + + ) : ( + value.toString() + ), + }; + }); + }, + [formatterDictionary] + ); } export const ExpandedRow: FC = ({ item }) => { const [modelItems, setModelItems] = useState([]); + const formatToListItems = useListItemsFormatter(); + const { inference_config: inferenceConfig, stats, @@ -140,6 +155,7 @@ export const ExpandedRow: FC = ({ item }) => { 'last_access', 'number_of_pending_requests', 'start_time', + 'throughput_last_minute', ]), name: nodeName, } as AllocatedModel['node'], diff --git a/x-pack/plugins/ml/public/application/trained_models/nodes_overview/allocated_models.tsx b/x-pack/plugins/ml/public/application/trained_models/nodes_overview/allocated_models.tsx index 4fb77c02779f9..79c2cbc1e4a42 100644 --- a/x-pack/plugins/ml/public/application/trained_models/nodes_overview/allocated_models.tsx +++ b/x-pack/plugins/ml/public/application/trained_models/nodes_overview/allocated_models.tsx @@ -35,7 +35,7 @@ export const AllocatedModels: FC = ({ name: i18n.translate('xpack.ml.trainedModels.nodesList.modelsList.nodeNameHeader', { defaultMessage: 'Node name', }), - width: '200px', + width: '150px', sortable: true, truncateText: false, 'data-test-subj': 'mlAllocatedModelsTableNodeName', @@ -46,7 +46,7 @@ export const AllocatedModels: FC = ({ name: i18n.translate('xpack.ml.trainedModels.nodesList.modelsList.modelNameHeader', { defaultMessage: 'Name', }), - width: '300px', + width: '250px', sortable: true, truncateText: false, 'data-test-subj': 'mlAllocatedModelsTableName', @@ -63,13 +63,16 @@ export const AllocatedModels: FC = ({ }, }, { - field: 'state', - name: i18n.translate('xpack.ml.trainedModels.nodesList.modelsList.modelStateHeader', { - defaultMessage: 'State', - }), + field: 'node.throughput_last_minute', + name: i18n.translate( + 'xpack.ml.trainedModels.nodesList.modelsList.throughputLastMinuteHeader', + { + defaultMessage: 'Throughput', + } + ), width: '100px', truncateText: false, - 'data-test-subj': 'mlAllocatedModelsTableState', + 'data-test-subj': 'mlAllocatedModelsTableThroughput', }, { name: i18n.translate( @@ -117,7 +120,7 @@ export const AllocatedModels: FC = ({ width: '200px', 'data-test-subj': 'mlAllocatedModelsTableInferenceCount', render: (v: AllocatedModel) => { - return dateFormatter(v.node.last_access); + return v.node.last_access ? dateFormatter(v.node.last_access) : '-'; }, }, { diff --git a/x-pack/plugins/ml/public/application/trained_models/nodes_overview/expanded_row.tsx b/x-pack/plugins/ml/public/application/trained_models/nodes_overview/expanded_row.tsx index dde486aeec39b..b8920acde568e 100644 --- a/x-pack/plugins/ml/public/application/trained_models/nodes_overview/expanded_row.tsx +++ b/x-pack/plugins/ml/public/application/trained_models/nodes_overview/expanded_row.tsx @@ -17,7 +17,7 @@ import { import { FormattedMessage } from '@kbn/i18n-react'; import { cloneDeep } from 'lodash'; import { NodeItem } from './nodes_list'; -import { formatToListItems } from '../models_management/expanded_row'; +import { useListItemsFormatter } from '../models_management/expanded_row'; import { AllocatedModels } from './allocated_models'; import { useFieldFormatter } from '../../contexts/kibana/use_field_formatter'; import { FIELD_FORMAT_IDS } from '../../../../../../../src/plugins/field_formats/common'; @@ -29,6 +29,8 @@ interface ExpandedRowProps { export const ExpandedRow: FC = ({ item }) => { const bytesFormatter = useFieldFormatter(FIELD_FORMAT_IDS.BYTES); + const formatToListItems = useListItemsFormatter(); + const { allocated_models: allocatedModels, attributes, diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index fc47b7ddf92a4..e2e106515d408 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -19016,7 +19016,6 @@ "xpack.ml.trainedModels.nodesList.modelsList.modelRoutingStateHeader": "ルーティング状態", "xpack.ml.trainedModels.nodesList.modelsList.modelSizeHeader": "サイズ", "xpack.ml.trainedModels.nodesList.modelsList.modelStartTimeHeader": "開始時刻", - "xpack.ml.trainedModels.nodesList.modelsList.modelStateHeader": "ステータス", "xpack.ml.trainedModels.nodesList.modelsList.nodeNameHeader": "ノード名", "xpack.ml.trainedModels.nodesList.modelsMemoryUsage": "学習済みモデル", "xpack.ml.trainedModels.nodesList.nodeMemoryUsageHeader": "メモリー使用状況", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 8ce79eb897cb5..0ddb9de4feb12 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -19041,7 +19041,6 @@ "xpack.ml.trainedModels.nodesList.modelsList.modelRoutingStateHeader": "路由状态", "xpack.ml.trainedModels.nodesList.modelsList.modelSizeHeader": "大小", "xpack.ml.trainedModels.nodesList.modelsList.modelStartTimeHeader": "开始时间", - "xpack.ml.trainedModels.nodesList.modelsList.modelStateHeader": "状态", "xpack.ml.trainedModels.nodesList.modelsList.nodeNameHeader": "节点名称", "xpack.ml.trainedModels.nodesList.modelsMemoryUsage": "已训练模型", "xpack.ml.trainedModels.nodesList.nodeMemoryUsageHeader": "内存使用", From b20de118cdeaf4e57563762e864f0e180b923a85 Mon Sep 17 00:00:00 2001 From: Lee Drengenberg Date: Mon, 28 Mar 2022 10:46:05 -0500 Subject: [PATCH 031/160] use format.utc instead of format (#128567) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- test/functional/page_objects/common_page.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/functional/page_objects/common_page.ts b/test/functional/page_objects/common_page.ts index 0150daec3afb5..28ac88674b4a6 100644 --- a/test/functional/page_objects/common_page.ts +++ b/test/functional/page_objects/common_page.ts @@ -517,7 +517,7 @@ export class CommonPageObject extends FtrService { */ formatTime(time: TimeStrings, fmt: string = 'MMM D, YYYY @ HH:mm:ss.SSS') { return Object.keys(time) - .map((x) => moment(time[x], [fmt]).format()) + .map((x) => moment.utc(time[x], [fmt]).format()) .reduce( (acc, curr, idx) => { if (idx === 0) acc.from = curr; From d202b73da7316ba35263c4d89fb27d63aa100742 Mon Sep 17 00:00:00 2001 From: Devon Thomson Date: Mon, 28 Mar 2022 11:51:19 -0400 Subject: [PATCH 032/160] [Controls] Select Relevant Data View ID (#128440) Get relevant data view id when creating control --- .../control_group/editor/control_editor.tsx | 6 +++ .../control_group/editor/create_control.tsx | 6 +++ .../control_group/editor/edit_control.tsx | 3 ++ .../embeddable/control_group_container.tsx | 17 +++++++++ .../options_list/options_list_editor.tsx | 6 ++- src/plugins/controls/public/types.ts | 2 + .../hooks/use_dashboard_app_state.ts | 8 +++- .../controls/options_list.ts | 38 ++++++++++++++++++- .../page_objects/dashboard_page_controls.ts | 16 +++++++- 9 files changed, 97 insertions(+), 5 deletions(-) diff --git a/src/plugins/controls/public/control_group/editor/control_editor.tsx b/src/plugins/controls/public/control_group/editor/control_editor.tsx index 0a26f966503f7..1fb21aa9cf1bc 100644 --- a/src/plugins/controls/public/control_group/editor/control_editor.tsx +++ b/src/plugins/controls/public/control_group/editor/control_editor.tsx @@ -56,6 +56,8 @@ interface EditControlProps { removeControl?: () => void; updateTitle: (title?: string) => void; updateWidth: (newWidth: ControlWidth) => void; + getRelevantDataViewId?: () => string | undefined; + setLastUsedDataViewId?: (newDataViewId: string) => void; onTypeEditorChange: (partial: Partial) => void; } @@ -70,6 +72,8 @@ export const ControlEditor = ({ updateTitle, updateWidth, onTypeEditorChange, + getRelevantDataViewId, + setLastUsedDataViewId, }: EditControlProps) => { const { controls } = pluginServices.getServices(); const { getControlTypes, getControlFactory } = controls; @@ -87,6 +91,8 @@ export const ControlEditor = ({ const ControlTypeEditor = (factory as IEditableControlFactory).controlEditorComponent; return ControlTypeEditor ? ( void; addNewEmbeddable: (type: string, input: Omit) => void; + setLastUsedDataViewId?: (newDataViewId: string) => void; + getRelevantDataViewId?: () => string | undefined; buttonType: CreateControlButtonTypes; closePopover?: () => void; } @@ -37,6 +39,8 @@ export const CreateControlButton = ({ addNewEmbeddable, buttonType, closePopover, + setLastUsedDataViewId, + getRelevantDataViewId, }: CreateControlButtonProps) => { // Controls Services Context const { overlays, controls } = pluginServices.getServices(); @@ -72,6 +76,8 @@ export const CreateControlButton = ({ toMountPoint( (inputToReturn.title = newTitle)} diff --git a/src/plugins/controls/public/control_group/editor/edit_control.tsx b/src/plugins/controls/public/control_group/editor/edit_control.tsx index 55848e5363729..5b7177a64c633 100644 --- a/src/plugins/controls/public/control_group/editor/edit_control.tsx +++ b/src/plugins/controls/public/control_group/editor/edit_control.tsx @@ -20,6 +20,7 @@ import { IEditableControlFactory, ControlInput } from '../../types'; import { controlGroupReducers } from '../state/control_group_reducers'; import { EmbeddableFactoryNotFoundError } from '../../../../embeddable/public'; import { useReduxContainerContext } from '../../../../presentation_util/public'; +import { ControlGroupContainer } from '../embeddable/control_group_container'; export const EditControlButton = ({ embeddableId }: { embeddableId: string }) => { // Controls Services Context @@ -53,6 +54,7 @@ export const EditControlButton = ({ embeddableId }: { embeddableId: string }) => const panel = panels[embeddableId]; const factory = getControlFactory(panel.type); const embeddable = await untilEmbeddableLoaded(embeddableId); + const controlGroup = embeddable.getRoot() as ControlGroupContainer; let inputToReturn: Partial = {}; @@ -93,6 +95,7 @@ export const EditControlButton = ({ embeddableId }: { embeddableId: string }) => title={embeddable.getTitle()} onCancel={() => onCancel(flyoutInstance)} updateTitle={(newTitle) => (inputToReturn.title = newTitle)} + setLastUsedDataViewId={(lastUsed) => controlGroup.setLastUsedDataViewId(lastUsed)} updateWidth={(newWidth) => dispatch(setControlWidth({ width: newWidth, embeddableId }))} onTypeEditorChange={(partialInput) => (inputToReturn = { ...inputToReturn, ...partialInput }) diff --git a/src/plugins/controls/public/control_group/embeddable/control_group_container.tsx b/src/plugins/controls/public/control_group/embeddable/control_group_container.tsx index e73aff832ab1e..064dfb8a0d7a1 100644 --- a/src/plugins/controls/public/control_group/embeddable/control_group_container.tsx +++ b/src/plugins/controls/public/control_group/embeddable/control_group_container.tsx @@ -81,6 +81,21 @@ export class ControlGroupContainer extends Container< private childOrderCache: ChildEmbeddableOrderCache; private recalculateFilters$: Subject; + private relevantDataViewId?: string; + private lastUsedDataViewId?: string; + + public setLastUsedDataViewId = (lastUsedDataViewId: string) => { + this.lastUsedDataViewId = lastUsedDataViewId; + }; + + public setRelevantDataViewId = (newRelevantDataViewId: string) => { + this.relevantDataViewId = newRelevantDataViewId; + }; + + public getMostRelevantDataViewId = () => { + return this.lastUsedDataViewId ?? this.relevantDataViewId; + }; + /** * Returns a button that allows controls to be created externally using the embeddable * @param buttonType Controls the button styling @@ -99,6 +114,8 @@ export class ControlGroupContainer extends Container< updateDefaultWidth={(defaultControlWidth) => this.updateInput({ defaultControlWidth })} addNewEmbeddable={(type, input) => this.addNewEmbeddable(type, input)} closePopover={closePopover} + getRelevantDataViewId={() => this.getMostRelevantDataViewId()} + setLastUsedDataViewId={(newId) => this.setLastUsedDataViewId(newId)} /> ); }; diff --git a/src/plugins/controls/public/control_types/options_list/options_list_editor.tsx b/src/plugins/controls/public/control_types/options_list/options_list_editor.tsx index fec580f7243be..141641f2a9030 100644 --- a/src/plugins/controls/public/control_types/options_list/options_list_editor.tsx +++ b/src/plugins/controls/public/control_types/options_list/options_list_editor.tsx @@ -38,6 +38,8 @@ export const OptionsListEditor = ({ initialInput, setValidState, setDefaultTitle, + getRelevantDataViewId, + setLastUsedDataViewId, }: ControlEditorProps) => { // Controls Services Context const { dataViews } = pluginServices.getHooks(); @@ -54,7 +56,8 @@ export const OptionsListEditor = ({ if (state.fieldName) setDefaultTitle(state.fieldName); (async () => { const dataViewListItems = await getIdsWithTitle(); - const initialId = initialInput?.dataViewId ?? (await getDefaultId()); + const initialId = + initialInput?.dataViewId ?? getRelevantDataViewId?.() ?? (await getDefaultId()); let dataView: DataView | undefined; if (initialId) { onChange({ dataViewId: initialId }); @@ -81,6 +84,7 @@ export const OptionsListEditor = ({ dataViews={state.dataViewListItems} selectedDataViewId={dataView?.id} onChangeDataViewId={(dataViewId) => { + setLastUsedDataViewId?.(dataViewId); onChange({ dataViewId }); get(dataViewId).then((newDataView) => setState((s) => ({ ...s, dataView: newDataView })) diff --git a/src/plugins/controls/public/types.ts b/src/plugins/controls/public/types.ts index 92d03c8dd42c0..745aa1bc32465 100644 --- a/src/plugins/controls/public/types.ts +++ b/src/plugins/controls/public/types.ts @@ -46,6 +46,8 @@ export interface IEditableControlFactory } export interface ControlEditorProps { initialInput?: Partial; + getRelevantDataViewId?: () => string | undefined; + setLastUsedDataViewId?: (newId: string) => void; onChange: (partial: Partial) => void; setValidState: (valid: boolean) => void; setDefaultTitle: (defaultTitle: string) => void; diff --git a/src/plugins/dashboard/public/application/hooks/use_dashboard_app_state.ts b/src/plugins/dashboard/public/application/hooks/use_dashboard_app_state.ts index eb5beeb858226..a8daffcf61440 100644 --- a/src/plugins/dashboard/public/application/hooks/use_dashboard_app_state.ts +++ b/src/plugins/dashboard/public/application/hooks/use_dashboard_app_state.ts @@ -235,8 +235,12 @@ export const useDashboardAppState = ({ const dataViewsSubscription = syncDashboardDataViews({ dashboardContainer, dataViews: dashboardBuildContext.dataViews, - onUpdateDataViews: (newDataViews: DataView[]) => - setDashboardAppState((s) => ({ ...s, dataViews: newDataViews })), + onUpdateDataViews: (newDataViews: DataView[]) => { + if (newDataViews.length > 0 && newDataViews[0].id) { + dashboardContainer.controlGroup?.setRelevantDataViewId(newDataViews[0].id); + } + setDashboardAppState((s) => ({ ...s, dataViews: newDataViews })); + }, }); /** diff --git a/test/functional/apps/dashboard_elements/controls/options_list.ts b/test/functional/apps/dashboard_elements/controls/options_list.ts index 6272448a68f93..6c52581d2878f 100644 --- a/test/functional/apps/dashboard_elements/controls/options_list.ts +++ b/test/functional/apps/dashboard_elements/controls/options_list.ts @@ -17,6 +17,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { const filterBar = getService('filterBar'); const testSubjects = getService('testSubjects'); const dashboardAddPanel = getService('dashboardAddPanel'); + const dashboardPanelActions = getService('dashboardPanelActions'); const { dashboardControls, timePicker, common, dashboard, header } = getPageObjects([ 'dashboardControls', 'timePicker', @@ -33,9 +34,44 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await timePicker.setDefaultDataRange(); }); + describe('Options List Control Editor selects relevant data views', async () => { + it('selects the default data view when the dashboard is blank', async () => { + expect(await dashboardControls.optionsListEditorGetCurrentDataView(true)).to.eql( + 'logstash-*' + ); + }); + + it('selects a relevant data view based on the panels on the dashboard', async () => { + await dashboardAddPanel.addVisualization('Rendering-Test:-animal-sounds-pie'); + await dashboard.waitForRenderComplete(); + expect(await dashboardControls.optionsListEditorGetCurrentDataView(true)).to.eql( + 'animals-*' + ); + await dashboardPanelActions.removePanelByTitle('Rendering Test: animal sounds pie'); + await dashboard.waitForRenderComplete(); + expect(await dashboardControls.optionsListEditorGetCurrentDataView(true)).to.eql( + 'logstash-*' + ); + }); + + it('selects the last used data view by default', async () => { + await dashboardControls.createOptionsListControl({ + dataViewTitle: 'animals-*', + fieldName: 'sound.keyword', + }); + expect(await dashboardControls.optionsListEditorGetCurrentDataView(true)).to.eql( + 'animals-*' + ); + await dashboardControls.deleteAllControls(); + }); + }); + describe('Options List Control creation and editing experience', async () => { it('can add a new options list control from a blank state', async () => { - await dashboardControls.createOptionsListControl({ fieldName: 'machine.os.raw' }); + await dashboardControls.createOptionsListControl({ + dataViewTitle: 'logstash-*', + fieldName: 'machine.os.raw', + }); expect(await dashboardControls.getControlsCount()).to.be(1); }); diff --git a/test/functional/page_objects/dashboard_page_controls.ts b/test/functional/page_objects/dashboard_page_controls.ts index c57c6d304e1e5..f0dd7ed9ddd3d 100644 --- a/test/functional/page_objects/dashboard_page_controls.ts +++ b/test/functional/page_objects/dashboard_page_controls.ts @@ -336,9 +336,12 @@ export class DashboardPageControls extends FtrService { await this.testSubjects.click(`control-editor-save`); } - public async controlEditorCancel() { + public async controlEditorCancel(confirm?: boolean) { this.log.debug(`Canceling changes in control editor`); await this.testSubjects.click(`control-editor-cancel`); + if (confirm) { + await this.common.clickConfirmOnModal(); + } } // Options List editor functions @@ -364,6 +367,17 @@ export class DashboardPageControls extends FtrService { await this.controlEditorSave(); } + public async optionsListEditorGetCurrentDataView(openAndCloseFlyout?: boolean) { + if (openAndCloseFlyout) { + await this.openCreateControlFlyout(OPTIONS_LIST_CONTROL); + } + const dataViewName = (await this.testSubjects.find('open-data-view-picker')).getVisibleText(); + if (openAndCloseFlyout) { + await this.controlEditorCancel(true); + } + return dataViewName; + } + public async optionsListEditorSetDataView(dataViewTitle: string) { this.log.debug(`Setting options list data view to ${dataViewTitle}`); await this.testSubjects.click('open-data-view-picker'); From 7494a91a1fe5cc15ec5f7c3c2e405248777d1415 Mon Sep 17 00:00:00 2001 From: Sander Philipse <94373878+sphilipse@users.noreply.github.com> Date: Mon, 28 Mar 2022 17:52:33 +0200 Subject: [PATCH 033/160] [Workplace Search] Fix external connector button stuck loading (#128617) * [Workplace Search] Fix external connector button stuck loading --- .../external_connector_logic.test.ts | 80 +++++++++++++++---- .../external_connector_logic.ts | 4 + 2 files changed, 68 insertions(+), 16 deletions(-) diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.test.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.test.ts index 0e9ad386a353d..1f15ef2ae7b67 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.test.ts +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.test.ts @@ -45,6 +45,16 @@ describe('ExternalConnectorLogic', () => { insecureUrl: true, }; + const DEFAULT_VALUES_SUCCESS: ExternalConnectorValues = { + ...DEFAULT_VALUES, + externalConnectorApiKey: 'asdf1234', + externalConnectorUrl: 'https://www.elastic.co', + formDisabled: false, + insecureUrl: false, + dataLoading: false, + sourceConfigData, + }; + beforeEach(() => { jest.clearAllMocks(); mount(); @@ -61,38 +71,56 @@ describe('ExternalConnectorLogic', () => { }); it('turns off the data loading flag', () => { - expect(ExternalConnectorLogic.values.dataLoading).toEqual(false); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES_SUCCESS, + dataLoading: false, + }); }); it('saves the external url', () => { - expect(ExternalConnectorLogic.values.externalConnectorUrl).toEqual( - sourceConfigData.configuredFields.externalConnectorUrl - ); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES_SUCCESS, + externalConnectorUrl: sourceConfigData.configuredFields.externalConnectorUrl, + }); }); it('saves the source config', () => { - expect(ExternalConnectorLogic.values.sourceConfigData).toEqual(sourceConfigData); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES_SUCCESS, + sourceConfigData, + }); }); it('sets undefined url to empty string', () => { - ExternalConnectorLogic.actions.fetchExternalSourceSuccess({ + const newSourceConfigData = { ...sourceConfigData, configuredFields: { ...sourceConfigData.configuredFields, externalConnectorUrl: undefined, }, + }; + ExternalConnectorLogic.actions.fetchExternalSourceSuccess(newSourceConfigData); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES_SUCCESS, + externalConnectorUrl: '', + insecureUrl: true, + sourceConfigData: newSourceConfigData, }); - expect(ExternalConnectorLogic.values.externalConnectorUrl).toEqual(''); }); it('sets undefined api key to empty string', () => { - ExternalConnectorLogic.actions.fetchExternalSourceSuccess({ + const newSourceConfigData = { ...sourceConfigData, configuredFields: { ...sourceConfigData.configuredFields, externalConnectorApiKey: undefined, }, + }; + ExternalConnectorLogic.actions.fetchExternalSourceSuccess(newSourceConfigData); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES_SUCCESS, + externalConnectorApiKey: '', + sourceConfigData: newSourceConfigData, }); - expect(ExternalConnectorLogic.values.externalConnectorApiKey).toEqual(''); }); }); @@ -104,7 +132,19 @@ describe('ExternalConnectorLogic', () => { ExternalConnectorLogic.actions.saveExternalConnectorConfigSuccess('external'); - expect(ExternalConnectorLogic.values.buttonLoading).toEqual(false); + expect(ExternalConnectorLogic.values).toEqual({ ...DEFAULT_VALUES, buttonLoading: false }); + }); + }); + + describe('saveExternalConnectorConfigError', () => { + it('turns off the button loading flag', () => { + mount({ + buttonLoading: true, + }); + + ExternalConnectorLogic.actions.saveExternalConnectorConfigError(); + + expect(ExternalConnectorLogic.values).toEqual({ ...DEFAULT_VALUES, buttonLoading: false }); }); }); @@ -112,7 +152,10 @@ describe('ExternalConnectorLogic', () => { it('updates the api key', () => { ExternalConnectorLogic.actions.setExternalConnectorApiKey('abcd1234'); - expect(ExternalConnectorLogic.values.externalConnectorApiKey).toEqual('abcd1234'); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES, + externalConnectorApiKey: 'abcd1234', + }); }); }); @@ -120,23 +163,28 @@ describe('ExternalConnectorLogic', () => { it('updates the url', () => { ExternalConnectorLogic.actions.setExternalConnectorUrl('https://www.elastic.co'); - expect(ExternalConnectorLogic.values.externalConnectorUrl).toEqual( - 'https://www.elastic.co' - ); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES, + externalConnectorUrl: 'https://www.elastic.co', + insecureUrl: false, + }); }); }); describe('setUrlValidation', () => { it('updates the url validation', () => { ExternalConnectorLogic.actions.setUrlValidation(false); - expect(ExternalConnectorLogic.values.urlValid).toEqual(false); + expect(ExternalConnectorLogic.values).toEqual({ ...DEFAULT_VALUES, urlValid: false }); }); }); describe('setShowInsecureUrlCallout', () => { it('updates the url validation', () => { ExternalConnectorLogic.actions.setShowInsecureUrlCallout(true); - expect(ExternalConnectorLogic.values.showInsecureUrlCallout).toEqual(true); + expect(ExternalConnectorLogic.values).toEqual({ + ...DEFAULT_VALUES, + showInsecureUrlCallout: true, + }); }); }); }); diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.ts index 3bf96a31dd8c5..ecb139ede3132 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.ts +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_external_connector/external_connector_logic.ts @@ -25,6 +25,7 @@ import { AddSourceLogic, SourceConfigData } from '../add_source_logic'; export interface ExternalConnectorActions { fetchExternalSource: () => true; fetchExternalSourceSuccess(sourceConfigData: SourceConfigData): SourceConfigData; + saveExternalConnectorConfigError: () => true; saveExternalConnectorConfigSuccess(externalConnectorId: string): string; setExternalConnectorApiKey(externalConnectorApiKey: string): string; saveExternalConnectorConfig(config: ExternalConnectorConfig): ExternalConnectorConfig; @@ -59,6 +60,7 @@ export const ExternalConnectorLogic = kea< actions: { fetchExternalSource: true, fetchExternalSourceSuccess: (sourceConfigData) => sourceConfigData, + saveExternalConnectorConfigError: true, saveExternalConnectorConfigSuccess: (externalConnectorId) => externalConnectorId, saveExternalConnectorConfig: (config) => config, setExternalConnectorApiKey: (externalConnectorApiKey: string) => externalConnectorApiKey, @@ -78,6 +80,7 @@ export const ExternalConnectorLogic = kea< false, { saveExternalConnectorConfigSuccess: () => false, + saveExternalConnectorConfigError: () => false, saveExternalConnectorConfig: () => true, }, ], @@ -168,6 +171,7 @@ export const ExternalConnectorLogic = kea< getSourcesPath(`${getAddPath('external')}`, AppLogic.values.isOrganization) ); } catch (e) { + actions.saveExternalConnectorConfigError(); flashAPIErrors(e); } } From 56c65bc9efca0acfb32e9c376d9c3b485bf12bab Mon Sep 17 00:00:00 2001 From: Dario Gieselaar Date: Mon, 28 Mar 2022 18:02:45 +0200 Subject: [PATCH 034/160] [APM] Make optimised loading of service inventory opt-in (#128471) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../plugins/apm/common/service_inventory.ts | 10 + .../app/service_inventory/index.tsx | 45 +++- .../service_inventory/service_list/index.tsx | 87 +++---- .../service_list/order_service_items.test.ts | 230 ++++++++++++++++++ .../service_list/order_service_items.ts | 75 ++++++ .../service_list/service_list.stories.tsx | 9 + x-pack/plugins/observability/common/index.ts | 1 + .../observability/common/ui_settings_keys.ts | 2 + .../observability/server/ui_settings.ts | 19 ++ 9 files changed, 420 insertions(+), 58 deletions(-) create mode 100644 x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.test.ts create mode 100644 x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.ts diff --git a/x-pack/plugins/apm/common/service_inventory.ts b/x-pack/plugins/apm/common/service_inventory.ts index b7c8c0ea90a58..022980b6c8193 100644 --- a/x-pack/plugins/apm/common/service_inventory.ts +++ b/x-pack/plugins/apm/common/service_inventory.ts @@ -18,3 +18,13 @@ export interface ServiceListItem { transactionErrorRate?: number | null; environments?: string[]; } + +export enum ServiceInventoryFieldName { + ServiceName = 'serviceName', + HealthStatus = 'healthStatus', + Environments = 'environments', + TransactionType = 'transactionType', + Throughput = 'throughput', + Latency = 'latency', + TransactionErrorRate = 'transactionErrorRate', +} diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx b/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx index 2ed0052547ed6..082ab1733547e 100644 --- a/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx +++ b/x-pack/plugins/apm/public/components/app/service_inventory/index.tsx @@ -18,6 +18,10 @@ import { SearchBar } from '../../shared/search_bar'; import { ServiceList } from './service_list'; import { MLCallout, shouldDisplayMlCallout } from '../../shared/ml_callout'; import { joinByKey } from '../../../../common/utils/join_by_key'; +import { useKibana } from '../../../../../../../src/plugins/kibana_react/public'; +import { apmServiceInventoryOptimizedSorting } from '../../../../../observability/common'; +import { ServiceInventoryFieldName } from '../../../../common/service_inventory'; +import { orderServiceItems } from './service_list/order_service_items'; const initialData = { requestId: '', @@ -157,10 +161,36 @@ export function ServiceInventory() { /> ); + const mainStatisticsItems = mainStatisticsFetch.data?.items ?? []; + const preloadedServices = sortedAndFilteredServicesFetch.data?.services || []; + + const displayHealthStatus = [ + ...mainStatisticsItems, + ...preloadedServices, + ].some((item) => 'healthStatus' in item); + + const tiebreakerField = useKibana().services.uiSettings?.get( + apmServiceInventoryOptimizedSorting + ) + ? ServiceInventoryFieldName.ServiceName + : ServiceInventoryFieldName.Throughput; + + const initialSortField = displayHealthStatus + ? ServiceInventoryFieldName.HealthStatus + : tiebreakerField; + + const initialSortDirection = + initialSortField === ServiceInventoryFieldName.ServiceName ? 'asc' : 'desc'; + const items = joinByKey( [ - ...(sortedAndFilteredServicesFetch.data?.services ?? []), - ...(mainStatisticsFetch.data?.items ?? []), + // only use preloaded services if tiebreaker field is service.name, + // otherwise ignore them to prevent re-sorting of the table + // once the tiebreaking metric comes in + ...(tiebreakerField === ServiceInventoryFieldName.ServiceName + ? preloadedServices + : []), + ...mainStatisticsItems, ], 'serviceName' ); @@ -187,6 +217,17 @@ export function ServiceInventory() { comparisonFetch.status === FETCH_STATUS.LOADING || comparisonFetch.status === FETCH_STATUS.NOT_INITIATED } + displayHealthStatus={displayHealthStatus} + initialSortField={initialSortField} + initialSortDirection={initialSortDirection} + sortFn={(itemsToSort, sortField, sortDirection) => { + return orderServiceItems({ + items: itemsToSort, + primarySortField: sortField, + sortDirection, + tiebreakerField, + }); + }} comparisonData={comparisonFetch?.data} noItemsMessage={noItemsMessage} /> diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/service_list/index.tsx b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/index.tsx index cc43be6a790ea..7bf340bed12a9 100644 --- a/x-pack/plugins/apm/public/components/app/service_inventory/service_list/index.tsx +++ b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/index.tsx @@ -15,7 +15,6 @@ import { } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { TypeOf } from '@kbn/typed-react-router-config'; -import { orderBy } from 'lodash'; import React, { useMemo } from 'react'; import { NOT_AVAILABLE_LABEL } from '../../../../../common/i18n'; import { ServiceHealthStatus } from '../../../../../common/service_health_status'; @@ -45,7 +44,10 @@ import { getTimeSeriesColor, } from '../../../shared/charts/helper/get_timeseries_color'; import { HealthBadge } from './health_badge'; -import { ServiceListItem } from '../../../../../common/service_inventory'; +import { + ServiceInventoryFieldName, + ServiceListItem, +} from '../../../../../common/service_inventory'; type ServicesDetailedStatisticsAPIResponse = APIReturnType<'GET /internal/apm/services/detailed_statistics'>; @@ -54,13 +56,6 @@ function formatString(value?: string | null) { return value || NOT_AVAILABLE_LABEL; } -const SERVICE_HEALTH_STATUS_ORDER = [ - ServiceHealthStatus.unknown, - ServiceHealthStatus.healthy, - ServiceHealthStatus.warning, - ServiceHealthStatus.critical, -]; - export function getServiceColumns({ query, showTransactionTypeColumn, @@ -84,7 +79,7 @@ export function getServiceColumns({ ...(showHealthStatusColumn ? [ { - field: 'healthStatus', + field: ServiceInventoryFieldName.HealthStatus, name: i18n.translate('xpack.apm.servicesTable.healthColumnLabel', { defaultMessage: 'Health', }), @@ -101,7 +96,7 @@ export function getServiceColumns({ ] : []), { - field: 'serviceName', + field: ServiceInventoryFieldName.ServiceName, name: i18n.translate('xpack.apm.servicesTable.nameColumnLabel', { defaultMessage: 'Name', }), @@ -123,7 +118,7 @@ export function getServiceColumns({ ...(showWhenSmallOrGreaterThanLarge ? [ { - field: 'environments', + field: ServiceInventoryFieldName.Environments, name: i18n.translate( 'xpack.apm.servicesTable.environmentColumnLabel', { @@ -141,7 +136,7 @@ export function getServiceColumns({ ...(showTransactionTypeColumn && showWhenSmallOrGreaterThanXL ? [ { - field: 'transactionType', + field: ServiceInventoryFieldName.TransactionType, name: i18n.translate( 'xpack.apm.servicesTable.transactionColumnLabel', { defaultMessage: 'Transaction type' } @@ -152,7 +147,7 @@ export function getServiceColumns({ ] : []), { - field: 'latency', + field: ServiceInventoryFieldName.Latency, name: i18n.translate('xpack.apm.servicesTable.latencyAvgColumnLabel', { defaultMessage: 'Latency (avg.)', }), @@ -179,7 +174,7 @@ export function getServiceColumns({ align: RIGHT_ALIGNMENT, }, { - field: 'throughput', + field: ServiceInventoryFieldName.Throughput, name: i18n.translate('xpack.apm.servicesTable.throughputColumnLabel', { defaultMessage: 'Throughput', }), @@ -207,7 +202,7 @@ export function getServiceColumns({ align: RIGHT_ALIGNMENT, }, { - field: 'transactionErrorRate', + field: ServiceInventoryFieldName.TransactionErrorRate, name: i18n.translate('xpack.apm.servicesTable.transactionErrorRate', { defaultMessage: 'Failed transaction rate', }), @@ -246,6 +241,14 @@ interface Props { noItemsMessage?: React.ReactNode; isLoading: boolean; isFailure?: boolean; + displayHealthStatus: boolean; + initialSortField: ServiceInventoryFieldName; + initialSortDirection: 'asc' | 'desc'; + sortFn: ( + sortItems: ServiceListItem[], + sortField: ServiceInventoryFieldName, + sortDirection: 'asc' | 'desc' + ) => ServiceListItem[]; } export function ServiceList({ @@ -255,9 +258,12 @@ export function ServiceList({ comparisonData, isLoading, isFailure, + displayHealthStatus, + initialSortField, + initialSortDirection, + sortFn, }: Props) { const breakpoints = useBreakpoints(); - const displayHealthStatus = items.some((item) => 'healthStatus' in item); const showTransactionTypeColumn = items.some( ({ transactionType }) => @@ -292,9 +298,6 @@ export function ServiceList({ ] ); - const initialSortField = displayHealthStatus ? 'healthStatus' : 'serviceName'; - const initialSortDirection = displayHealthStatus ? 'desc' : 'asc'; - return ( @@ -333,7 +336,7 @@ export function ServiceList({ - isLoading={isLoading} error={isFailure} columns={serviceColumns} @@ -341,41 +344,13 @@ export function ServiceList({ noItemsMessage={noItemsMessage} initialSortField={initialSortField} initialSortDirection={initialSortDirection} - sortFn={(itemsToSort, sortField, sortDirection) => { - // For healthStatus, sort items by healthStatus first, then by name - return sortField === 'healthStatus' - ? orderBy( - itemsToSort, - [ - (item) => { - return item.healthStatus - ? SERVICE_HEALTH_STATUS_ORDER.indexOf(item.healthStatus) - : -1; - }, - (item) => item.serviceName.toLowerCase(), - ], - [sortDirection, sortDirection === 'asc' ? 'desc' : 'asc'] - ) - : orderBy( - itemsToSort, - (item) => { - switch (sortField) { - // Use `?? -1` here so `undefined` will appear after/before `0`. - // In the table this will make the "N/A" items always at the - // bottom/top. - case 'latency': - return item.latency ?? -1; - case 'throughput': - return item.throughput ?? -1; - case 'transactionErrorRate': - return item.transactionErrorRate ?? -1; - default: - return item[sortField as keyof typeof item]; - } - }, - sortDirection - ); - }} + sortFn={(itemsToSort, sortField, sortDirection) => + sortFn( + itemsToSort, + sortField as ServiceInventoryFieldName, + sortDirection + ) + } /> diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.test.ts b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.test.ts new file mode 100644 index 0000000000000..5877ee64239b6 --- /dev/null +++ b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.test.ts @@ -0,0 +1,230 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { ServiceHealthStatus } from '../../../../../common/service_health_status'; +import { ServiceInventoryFieldName } from '../../../../../common/service_inventory'; +import { orderServiceItems } from './order_service_items'; + +describe('orderServiceItems', () => { + describe('when sorting by health status', () => { + describe('desc', () => { + it('orders from critical to unknown', () => { + const sortedItems = orderServiceItems({ + primarySortField: ServiceInventoryFieldName.HealthStatus, + sortDirection: 'desc', + tiebreakerField: ServiceInventoryFieldName.Throughput, + items: [ + { + serviceName: 'critical-service', + healthStatus: ServiceHealthStatus.critical, + }, + { + serviceName: 'healthy-service', + healthStatus: ServiceHealthStatus.healthy, + }, + { + serviceName: 'warning-service', + healthStatus: ServiceHealthStatus.warning, + }, + { + serviceName: 'unknown-service', + healthStatus: ServiceHealthStatus.unknown, + }, + ], + }); + + expect(sortedItems.map((item) => item.serviceName)).toEqual([ + 'critical-service', + 'warning-service', + 'healthy-service', + 'unknown-service', + ]); + }); + + it('sorts by service name ascending as a tie-breaker', () => { + const sortedItems = orderServiceItems({ + primarySortField: ServiceInventoryFieldName.HealthStatus, + sortDirection: 'desc', + tiebreakerField: ServiceInventoryFieldName.ServiceName, + items: [ + { + serviceName: 'b-critical-service', + healthStatus: ServiceHealthStatus.critical, + }, + { + serviceName: 'a-critical-service', + healthStatus: ServiceHealthStatus.critical, + }, + { + serviceName: 'a-unknown-service', + healthStatus: ServiceHealthStatus.unknown, + }, + { + serviceName: 'b-unknown-service', + healthStatus: ServiceHealthStatus.unknown, + }, + ], + }); + + expect(sortedItems.map((item) => item.serviceName)).toEqual([ + 'a-critical-service', + 'b-critical-service', + 'a-unknown-service', + 'b-unknown-service', + ]); + }); + + it('sorts by metric descending as a tie-breaker', () => { + const sortedItems = orderServiceItems({ + primarySortField: ServiceInventoryFieldName.HealthStatus, + sortDirection: 'desc', + tiebreakerField: ServiceInventoryFieldName.Throughput, + items: [ + { + serviceName: 'low-throughput-service', + healthStatus: ServiceHealthStatus.unknown, + throughput: 1, + }, + { + serviceName: 'high-throughput-service', + healthStatus: ServiceHealthStatus.unknown, + throughput: 100, + }, + { + serviceName: 'med-throughput-service', + healthStatus: ServiceHealthStatus.unknown, + throughput: 10, + }, + { + serviceName: 'critical-service', + healthStatus: ServiceHealthStatus.critical, + throughput: 0, + }, + ], + }); + + expect(sortedItems.map((item) => item.serviceName)).toEqual([ + 'critical-service', + 'high-throughput-service', + 'med-throughput-service', + 'low-throughput-service', + ]); + }); + }); + + describe('asc', () => { + it('orders from unknown to critical', () => { + const sortedItems = orderServiceItems({ + primarySortField: ServiceInventoryFieldName.HealthStatus, + sortDirection: 'asc', + tiebreakerField: ServiceInventoryFieldName.Throughput, + items: [ + { + serviceName: 'critical-service', + healthStatus: ServiceHealthStatus.critical, + }, + { + serviceName: 'healthy-service', + healthStatus: ServiceHealthStatus.healthy, + }, + { + serviceName: 'warning-service', + healthStatus: ServiceHealthStatus.warning, + }, + { + serviceName: 'unknown-service', + healthStatus: ServiceHealthStatus.unknown, + }, + ], + }); + + expect(sortedItems.map((item) => item.serviceName)).toEqual([ + 'unknown-service', + 'healthy-service', + 'warning-service', + 'critical-service', + ]); + }); + }); + }); + + describe('when sorting by metric fields', () => { + it('sorts correctly', () => { + const sortedItems = orderServiceItems({ + primarySortField: ServiceInventoryFieldName.Throughput, + sortDirection: 'desc', + tiebreakerField: ServiceInventoryFieldName.Throughput, + items: [ + { + serviceName: 'low-throughput-service', + healthStatus: ServiceHealthStatus.unknown, + throughput: 1, + }, + { + serviceName: 'high-throughput-service', + healthStatus: ServiceHealthStatus.unknown, + throughput: 100, + }, + { + serviceName: 'med-throughput-service', + healthStatus: ServiceHealthStatus.unknown, + throughput: 10, + }, + { + serviceName: 'critical-service', + healthStatus: ServiceHealthStatus.critical, + throughput: 0, + }, + ], + }); + + expect(sortedItems.map((item) => item.serviceName)).toEqual([ + 'high-throughput-service', + 'med-throughput-service', + 'low-throughput-service', + 'critical-service', + ]); + }); + }); + + describe('when sorting by alphabetical fields', () => { + const sortedItems = orderServiceItems({ + primarySortField: ServiceInventoryFieldName.ServiceName, + sortDirection: 'asc', + tiebreakerField: ServiceInventoryFieldName.ServiceName, + items: [ + { + serviceName: 'd-service', + healthStatus: ServiceHealthStatus.unknown, + }, + { + serviceName: 'a-service', + healthStatus: ServiceHealthStatus.unknown, + }, + { + serviceName: 'b-service', + healthStatus: ServiceHealthStatus.unknown, + }, + { + serviceName: 'c-service', + healthStatus: ServiceHealthStatus.unknown, + }, + { + serviceName: '0-service', + healthStatus: ServiceHealthStatus.unknown, + }, + ], + }); + + expect(sortedItems.map((item) => item.serviceName)).toEqual([ + '0-service', + 'a-service', + 'b-service', + 'c-service', + 'd-service', + ]); + }); +}); diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.ts b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.ts new file mode 100644 index 0000000000000..1e685d8215413 --- /dev/null +++ b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/order_service_items.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { orderBy } from 'lodash'; +import { ServiceHealthStatus } from '../../../../../common/service_health_status'; +import { + ServiceListItem, + ServiceInventoryFieldName, +} from '../../../../../common/service_inventory'; + +type SortValueGetter = (item: ServiceListItem) => string | number; + +const SERVICE_HEALTH_STATUS_ORDER = [ + ServiceHealthStatus.unknown, + ServiceHealthStatus.healthy, + ServiceHealthStatus.warning, + ServiceHealthStatus.critical, +]; + +const sorts: Record = { + [ServiceInventoryFieldName.HealthStatus]: (item) => + item.healthStatus + ? SERVICE_HEALTH_STATUS_ORDER.indexOf(item.healthStatus) + : -1, + [ServiceInventoryFieldName.ServiceName]: (item) => + item.serviceName.toLowerCase(), + [ServiceInventoryFieldName.Environments]: (item) => + item.environments?.join(', ').toLowerCase() ?? '', + [ServiceInventoryFieldName.TransactionType]: (item) => + item.transactionType ?? '', + [ServiceInventoryFieldName.Latency]: (item) => item.latency ?? -1, + [ServiceInventoryFieldName.Throughput]: (item) => item.throughput ?? -1, + [ServiceInventoryFieldName.TransactionErrorRate]: (item) => + item.transactionErrorRate ?? -1, +}; + +function reverseSortDirection(sortDirection: 'asc' | 'desc') { + return sortDirection === 'asc' ? 'desc' : 'asc'; +} + +export function orderServiceItems({ + items, + primarySortField, + tiebreakerField, + sortDirection, +}: { + items: ServiceListItem[]; + primarySortField: ServiceInventoryFieldName; + tiebreakerField: ServiceInventoryFieldName; + sortDirection: 'asc' | 'desc'; +}): ServiceListItem[] { + // For healthStatus, sort items by healthStatus first, then by tie-breaker + + const sortFn = sorts[primarySortField as ServiceInventoryFieldName]; + + if (primarySortField === ServiceInventoryFieldName.HealthStatus) { + const tiebreakerSortDirection = + tiebreakerField === ServiceInventoryFieldName.ServiceName + ? reverseSortDirection(sortDirection) + : sortDirection; + + const tiebreakerSortFn = sorts[tiebreakerField]; + + return orderBy( + items, + [sortFn, tiebreakerSortFn], + [sortDirection, tiebreakerSortDirection] + ); + } + + return orderBy(items, sortFn, sortDirection); +} diff --git a/x-pack/plugins/apm/public/components/app/service_inventory/service_list/service_list.stories.tsx b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/service_list.stories.tsx index 628ef4617417c..290f1e6b69b77 100644 --- a/x-pack/plugins/apm/public/components/app/service_inventory/service_list/service_list.stories.tsx +++ b/x-pack/plugins/apm/public/components/app/service_inventory/service_list/service_list.stories.tsx @@ -11,6 +11,7 @@ import { MemoryRouter } from 'react-router-dom'; import { CoreStart } from '../../../../../../../../src/core/public'; import { createKibanaReactContext } from '../../../../../../../../src/plugins/kibana_react/public'; import { ServiceHealthStatus } from '../../../../../common/service_health_status'; +import { ServiceInventoryFieldName } from '../../../../../common/service_inventory'; import type { ApmPluginContextValue } from '../../../../context/apm_plugin/apm_plugin_context'; import { MockApmPluginContextWrapper } from '../../../../context/apm_plugin/mock_apm_plugin_context'; import { ServiceList } from './'; @@ -59,6 +60,10 @@ export const Example: Story = (args) => { Example.args = { isLoading: false, items, + displayHealthStatus: true, + initialSortField: ServiceInventoryFieldName.HealthStatus, + initialSortDirection: 'desc', + sortFn: (sortItems) => sortItems, }; export const EmptyState: Story = (args) => { @@ -67,6 +72,10 @@ export const EmptyState: Story = (args) => { EmptyState.args = { isLoading: false, items: [], + displayHealthStatus: true, + initialSortField: ServiceInventoryFieldName.HealthStatus, + initialSortDirection: 'desc', + sortFn: (sortItems) => sortItems, }; export const WithHealthWarnings: Story = (args) => { diff --git a/x-pack/plugins/observability/common/index.ts b/x-pack/plugins/observability/common/index.ts index 3f31eb5f9140c..1ca110f40bdbf 100644 --- a/x-pack/plugins/observability/common/index.ts +++ b/x-pack/plugins/observability/common/index.ts @@ -15,6 +15,7 @@ export { enableComparisonByDefault, enableInfrastructureView, defaultApmServiceEnvironment, + apmServiceInventoryOptimizedSorting, } from './ui_settings_keys'; export const casesFeatureId = 'observabilityCases'; diff --git a/x-pack/plugins/observability/common/ui_settings_keys.ts b/x-pack/plugins/observability/common/ui_settings_keys.ts index b1328aec7420b..54eaa9046d874 100644 --- a/x-pack/plugins/observability/common/ui_settings_keys.ts +++ b/x-pack/plugins/observability/common/ui_settings_keys.ts @@ -11,3 +11,5 @@ export const enableComparisonByDefault = 'observability:enableComparisonByDefaul export const enableInfrastructureView = 'observability:enableInfrastructureView'; export const defaultApmServiceEnvironment = 'observability:apmDefaultServiceEnvironment'; export const enableServiceGroups = 'observability:enableServiceGroups'; +export const apmServiceInventoryOptimizedSorting = + 'observability:apmServiceInventoryOptimizedSorting'; diff --git a/x-pack/plugins/observability/server/ui_settings.ts b/x-pack/plugins/observability/server/ui_settings.ts index db6bc3041fe34..60dcc1384aa22 100644 --- a/x-pack/plugins/observability/server/ui_settings.ts +++ b/x-pack/plugins/observability/server/ui_settings.ts @@ -16,6 +16,7 @@ import { enableInfrastructureView, defaultApmServiceEnvironment, enableServiceGroups, + apmServiceInventoryOptimizedSorting, } from '../common/ui_settings_keys'; const technicalPreviewLabel = i18n.translate( @@ -98,4 +99,22 @@ export const uiSettings: Record[${technicalPreviewLabel}]` }, + } + ), + schema: schema.boolean(), + value: false, + requiresPageReload: false, + type: 'boolean', + }, }; From a35600f90eec0a25dd55dd194dcce8e9efc19e80 Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Mon, 28 Mar 2022 18:32:51 +0200 Subject: [PATCH 035/160] fix scrollbars (#128515) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- src/plugins/vis_types/vega/public/components/vega_vis.scss | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/plugins/vis_types/vega/public/components/vega_vis.scss b/src/plugins/vis_types/vega/public/components/vega_vis.scss index f0062869e0046..ce66dc1d7f928 100644 --- a/src/plugins/vis_types/vega/public/components/vega_vis.scss +++ b/src/plugins/vis_types/vega/public/components/vega_vis.scss @@ -24,6 +24,10 @@ width: 100%; height: 100%; + canvas { + display: block; + } + // BUG #23514: Make sure Vega doesn't display the controls in two places .vega-bindings { // sass-lint:disable no-important From 06105a89e663252e737438d345065f7addcee1a7 Mon Sep 17 00:00:00 2001 From: Scotty Bollinger Date: Mon, 28 Mar 2022 11:52:34 -0500 Subject: [PATCH 036/160] [App Search] Refactor UI to list only aliases in elasticsearch index list (#128551) Refactors the fetch_indices util to create an array of indices that start with `search-*`, instead of using the actual elasticsearch index name. --- .../enterprise_search/common/types/indices.ts | 1 - .../server/lib/fetch_indices.test.ts | 20 ++++-- .../server/lib/fetch_indices.ts | 63 +++++++++++-------- 3 files changed, 54 insertions(+), 30 deletions(-) diff --git a/x-pack/plugins/enterprise_search/common/types/indices.ts b/x-pack/plugins/enterprise_search/common/types/indices.ts index a0be781638fb5..61d61b73b6a45 100644 --- a/x-pack/plugins/enterprise_search/common/types/indices.ts +++ b/x-pack/plugins/enterprise_search/common/types/indices.ts @@ -19,5 +19,4 @@ export interface ElasticsearchIndex { size_in_bytes: string; }; }; - aliases: string | string[]; } diff --git a/x-pack/plugins/enterprise_search/server/lib/fetch_indices.test.ts b/x-pack/plugins/enterprise_search/server/lib/fetch_indices.test.ts index c983df7241e0a..6bf95487a0022 100644 --- a/x-pack/plugins/enterprise_search/server/lib/fetch_indices.test.ts +++ b/x-pack/plugins/enterprise_search/server/lib/fetch_indices.test.ts @@ -70,7 +70,6 @@ describe('fetchIndices lib function', () => { size_in_bytes: '105.47kb', }, }, - aliases: 'none', name: 'search-regular-index', }, ]); @@ -120,8 +119,22 @@ describe('fetchIndices lib function', () => { size_in_bytes: '105.47kb', }, }, - aliases: ['search-aliased', 'search-double-aliased'], - name: 'index-without-prefix', + name: 'search-aliased', + }, + { + health: 'green', + status: 'open', + uuid: '83a81e7e-5955-4255-b008-5d6961203f57', + total: { + docs: { + count: 100, + deleted: 0, + }, + store: { + size_in_bytes: '105.47kb', + }, + }, + name: 'search-double-aliased', }, ]); }); @@ -139,7 +152,6 @@ describe('fetchIndices lib function', () => { // deleted index won't be present in the indices stats call response await expect(fetchIndices(mockClient as unknown as IScopedClusterClient)).resolves.toEqual([ { - aliases: 'none', name: 'search-regular-index', total: { docs: { diff --git a/x-pack/plugins/enterprise_search/server/lib/fetch_indices.ts b/x-pack/plugins/enterprise_search/server/lib/fetch_indices.ts index 770b967bf7fb3..4b8c2612f6467 100644 --- a/x-pack/plugins/enterprise_search/server/lib/fetch_indices.ts +++ b/x-pack/plugins/enterprise_search/server/lib/fetch_indices.ts @@ -13,6 +13,7 @@ import { ElasticsearchIndex } from '../../common/types'; export const fetchIndices = async (client: IScopedClusterClient): Promise => { const indexNamesString = 'search-*'; + const indexNamesRegEx = /^search-*/; // This call retrieves alias and settings information about indices const indices = await client.asCurrentUser.indices.get({ @@ -36,31 +37,43 @@ export const fetchIndices = async (client: IScopedClusterClient): Promise { - const indexData = indices[indexName]; - const indexStats = indicesStats[indexName]; - const aliases = Object.keys(indexData.aliases!); - const sizeInBytes = new ByteSizeValue(indexStats?.total?.store?.size_in_bytes ?? 0).toString(); + return indicesNames + .map((indexName: string) => { + const indexData = indices[indexName]; + const indexStats = indicesStats[indexName]; + const aliases = Object.keys(indexData.aliases!); + const sizeInBytes = new ByteSizeValue( + indexStats?.total?.store?.size_in_bytes ?? 0 + ).toString(); - const docCount = indexStats?.total?.docs?.count ?? 0; - const docDeleted = indexStats?.total?.docs?.deleted ?? 0; - const total = { - docs: { - count: docCount, - deleted: docDeleted, - }, - store: { - size_in_bytes: sizeInBytes, - }, - }; + const docCount = indexStats?.total?.docs?.count ?? 0; + const docDeleted = indexStats?.total?.docs?.deleted ?? 0; + const total = { + docs: { + count: docCount, + deleted: docDeleted, + }, + store: { + size_in_bytes: sizeInBytes, + }, + }; - return { - health: indexStats?.health, - status: indexStats?.status, - name: indexName, - uuid: indexStats?.uuid, - total, - aliases: aliases.length ? aliases : 'none', - }; - }); + return { + health: indexStats?.health, + status: indexStats?.status, + name: indexName, + uuid: indexStats?.uuid, + total, + aliases, + }; + }) + .flatMap(({ name, aliases, ...engineData }) => { + const engines = []; + engines.push({ name, ...engineData }); + aliases.forEach((alias) => { + engines.push({ name: alias, ...engineData }); + }); + return engines; + }) + .filter(({ name }) => name.match(indexNamesRegEx)); }; From 96b1f27b455f307b754ae392e3407bd33e3a4f7a Mon Sep 17 00:00:00 2001 From: Quynh Nguyen <43350163+qn895@users.noreply.github.com> Date: Mon, 28 Mar 2022 12:01:08 -0500 Subject: [PATCH 037/160] [ML] Fix Index data visualizer reaching Elasticsearch rate request limits (#124898) * Add pagination fetching, need fix on table sorting callback * Reset fetch state * Fix sorting * Add max concurrent reqs to overall stats * Add loading spinners, clean up * Fix onTableChange * [ML] Fix field stats missing * Fix loading when show empty fields on * Fix loading spinner for numeric fields * Change switch map to map Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../common/types/field_request_config.ts | 1 + .../fields_stats_grid/filter_fields.ts | 16 +- .../data_visualizer_stats_table.tsx | 10 + .../constants/index_data_visualizer_viewer.ts | 2 + .../grid_embeddable/grid_embeddable.tsx | 1 + .../hooks/use_data_visualizer_grid_data.ts | 82 ++++---- .../hooks/use_field_stats.ts | 117 +++++++---- .../hooks/use_overall_stats.ts | 189 ++++++++++-------- .../search_strategy/requests/overall_stats.ts | 7 + 9 files changed, 256 insertions(+), 169 deletions(-) diff --git a/x-pack/plugins/data_visualizer/common/types/field_request_config.ts b/x-pack/plugins/data_visualizer/common/types/field_request_config.ts index f0ea7079bf750..e15e39ffb46de 100644 --- a/x-pack/plugins/data_visualizer/common/types/field_request_config.ts +++ b/x-pack/plugins/data_visualizer/common/types/field_request_config.ts @@ -17,6 +17,7 @@ export interface FieldRequestConfig { fieldName: string; type: JobFieldType; cardinality: number; + existsInDocs: boolean; } export interface DocumentCountBuckets { diff --git a/x-pack/plugins/data_visualizer/public/application/common/components/fields_stats_grid/filter_fields.ts b/x-pack/plugins/data_visualizer/public/application/common/components/fields_stats_grid/filter_fields.ts index de97b6007d877..145a8fa5f8867 100644 --- a/x-pack/plugins/data_visualizer/public/application/common/components/fields_stats_grid/filter_fields.ts +++ b/x-pack/plugins/data_visualizer/public/application/common/components/fields_stats_grid/filter_fields.ts @@ -6,15 +6,15 @@ */ import { JOB_FIELD_TYPES } from '../../../../../common/constants'; -import type { - FileBasedFieldVisConfig, - FileBasedUnknownFieldVisConfig, -} from '../../../../../common/types/field_vis_config'; -export function filterFields( - fields: Array, - visibleFieldNames: string[], - visibleFieldTypes: string[] +interface CommonFieldConfig { + type: string; + fieldName?: string; +} +export function filterFields( + fields: T[], + visibleFieldNames: string[] | undefined, + visibleFieldTypes: string[] | undefined ) { let items = fields; diff --git a/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/data_visualizer_stats_table.tsx b/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/data_visualizer_stats_table.tsx index cc9cd075c7615..5d4c4de8ca901 100644 --- a/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/data_visualizer_stats_table.tsx +++ b/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/data_visualizer_stats_table.tsx @@ -19,6 +19,7 @@ import { LEFT_ALIGNMENT, RIGHT_ALIGNMENT, EuiResizeObserver, + EuiLoadingSpinner, } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { EuiTableComputedColumnType } from '@elastic/eui/src/components/basic_table/table_types'; @@ -279,6 +280,15 @@ export const DataVisualizerTable = ({ ), render: (item: DataVisualizerTableItem) => { if (item === undefined || showDistributions === false) return null; + + if ('loading' in item && item.loading === true) { + return ( + + + + ); + } + if ( (item.type === JOB_FIELD_TYPES.KEYWORD || item.type === JOB_FIELD_TYPES.IP) && item.stats?.topValues !== undefined diff --git a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/constants/index_data_visualizer_viewer.ts b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/constants/index_data_visualizer_viewer.ts index cd12706d0bc9b..c1b314a19cf37 100644 --- a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/constants/index_data_visualizer_viewer.ts +++ b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/constants/index_data_visualizer_viewer.ts @@ -6,3 +6,5 @@ */ export const DATA_VISUALIZER_INDEX_VIEWER = 'DATA_VISUALIZER_INDEX_VIEWER'; + +export const MAX_CONCURRENT_REQUESTS = 10; diff --git a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx index 8097d400c3b71..c44932470c7e8 100644 --- a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx +++ b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx @@ -84,6 +84,7 @@ export const EmbeddableWrapper = ({ }, [dataVisualizerListState, onOutputChange] ); + const { configs, searchQueryLanguage, searchString, extendedColumns, progress, setLastRefresh } = useDataVisualizerGridData(input, dataVisualizerListState); diff --git a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_data_visualizer_grid_data.ts b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_data_visualizer_grid_data.ts index bbf088c53d94c..7c821f698d8df 100644 --- a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_data_visualizer_grid_data.ts +++ b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_data_visualizer_grid_data.ts @@ -53,7 +53,6 @@ export const useDataVisualizerGridData = ( const { services } = useDataVisualizerKibana(); const { uiSettings, data } = services; const { samplerShardSize, visibleFieldTypes, showEmptyFields } = dataVisualizerListState; - const dataVisualizerListStateRef = useRef(dataVisualizerListState); const [lastRefresh, setLastRefresh] = useState(0); const searchSessionId = input.sessionId; @@ -227,11 +226,11 @@ export const useDataVisualizerGridData = ( if (overallStatsProgress.loaded < 100) return; const existMetricFields = metricConfigs .map((config) => { - if (config.existsInDocs === false) return; return { fieldName: config.fieldName, type: config.type, cardinality: config.stats?.cardinality ?? 0, + existsInDocs: config.existsInDocs, }; }) .filter((c) => c !== undefined) as FieldRequestConfig[]; @@ -240,11 +239,11 @@ export const useDataVisualizerGridData = ( // Top values will be obtained on a sample if cardinality > 100000. const existNonMetricFields: FieldRequestConfig[] = nonMetricConfigs .map((config) => { - if (config.existsInDocs === false) return; return { fieldName: config.fieldName, type: config.type, cardinality: config.stats?.cardinality ?? 0, + existsInDocs: config.existsInDocs, }; }) .filter((c) => c !== undefined) as FieldRequestConfig[]; @@ -255,7 +254,7 @@ export const useDataVisualizerGridData = ( const strategyResponse = useFieldStatsSearchStrategy( fieldStatsRequest, configsWithoutStats, - dataVisualizerListStateRef.current + dataVisualizerListState ); const combinedProgress = useMemo( @@ -325,7 +324,7 @@ export const useDataVisualizerGridData = ( ...fieldData, fieldFormat: currentDataView.getFormatterForField(field), type: JOB_FIELD_TYPES.NUMBER, - loading: true, + loading: fieldData?.existsInDocs ?? true, aggregatable: true, deletable: field.runtimeField !== undefined, }; @@ -436,41 +435,46 @@ export const useDataVisualizerGridData = ( // eslint-disable-next-line react-hooks/exhaustive-deps }, [overallStats, showEmptyFields]); - const configs = useMemo(() => { - const fieldStats = strategyResponse.fieldStats; - let combinedConfigs = [...nonMetricConfigs, ...metricConfigs]; - if (visibleFieldTypes && visibleFieldTypes.length > 0) { - combinedConfigs = combinedConfigs.filter( - (config) => visibleFieldTypes.findIndex((field) => field === config.type) > -1 - ); - } - if (visibleFieldNames && visibleFieldNames.length > 0) { - combinedConfigs = combinedConfigs.filter( - (config) => visibleFieldNames.findIndex((field) => field === config.fieldName) > -1 - ); - } - - if (fieldStats) { - combinedConfigs = combinedConfigs.map((c) => { - const loadedFullStats = fieldStats.get(c.fieldName) ?? {}; - return loadedFullStats - ? { - ...c, - loading: false, - stats: { ...c.stats, ...loadedFullStats }, - } - : c; - }); - } + const configs = useMemo( + () => { + const fieldStats = strategyResponse.fieldStats; + let combinedConfigs = [...nonMetricConfigs, ...metricConfigs]; + if (visibleFieldTypes && visibleFieldTypes.length > 0) { + combinedConfigs = combinedConfigs.filter( + (config) => visibleFieldTypes.findIndex((field) => field === config.type) > -1 + ); + } + if (visibleFieldNames && visibleFieldNames.length > 0) { + combinedConfigs = combinedConfigs.filter( + (config) => visibleFieldNames.findIndex((field) => field === config.fieldName) > -1 + ); + } - return combinedConfigs; - }, [ - nonMetricConfigs, - metricConfigs, - visibleFieldTypes, - visibleFieldNames, - strategyResponse.fieldStats, - ]); + if (fieldStats) { + combinedConfigs = combinedConfigs.map((c) => { + const loadedFullStats = fieldStats.get(c.fieldName) ?? {}; + return loadedFullStats + ? { + ...c, + loading: false, + stats: { ...c.stats, ...loadedFullStats }, + } + : c; + }); + } + return combinedConfigs; + }, + // eslint-disable-next-line react-hooks/exhaustive-deps + [ + nonMetricConfigs, + metricConfigs, + visibleFieldTypes, + visibleFieldNames, + strategyResponse.progress.loaded, + dataVisualizerListState.pageIndex, + dataVisualizerListState.pageSize, + ] + ); // Some actions open up fly-out or popup // This variable is used to keep track of them and clean up when unmounting diff --git a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_field_stats.ts b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_field_stats.ts index 19eaf8be68327..750c1d417e84d 100644 --- a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_field_stats.ts +++ b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_field_stats.ts @@ -6,10 +6,11 @@ */ import { useCallback, useEffect, useReducer, useRef, useState } from 'react'; -import { combineLatest, Observable, Subject, Subscription } from 'rxjs'; +import { combineLatest, from, Observable, Subject, Subscription } from 'rxjs'; import { i18n } from '@kbn/i18n'; import { last, cloneDeep } from 'lodash'; -import { switchMap } from 'rxjs/operators'; +import { mergeMap, switchMap } from 'rxjs/operators'; +import { Comparators } from '@elastic/eui'; import type { DataStatsFetchProgress, FieldStatsSearchStrategyReturnBase, @@ -29,6 +30,9 @@ import { getInitialProgress, getReducer } from '../progress_utils'; import { MAX_EXAMPLES_DEFAULT } from '../search_strategy/requests/constants'; import type { ISearchOptions } from '../../../../../../../src/plugins/data/common'; import { getFieldsStats } from '../search_strategy/requests/get_fields_stats'; +import { MAX_CONCURRENT_REQUESTS } from '../constants/index_data_visualizer_viewer'; +import { filterFields } from '../../common/components/fields_stats_grid/filter_fields'; + interface FieldStatsParams { metricConfigs: FieldRequestConfig[]; nonMetricConfigs: FieldRequestConfig[]; @@ -61,7 +65,7 @@ const createBatchedRequests = (fields: Field[], maxBatchSize = 10) => { export function useFieldStatsSearchStrategy( searchStrategyParams: OverallStatsSearchStrategyParams | undefined, fieldStatsParams: FieldStatsParams | undefined, - initialDataVisualizerListState: DataVisualizerIndexBasedAppState + dataVisualizerListState: DataVisualizerIndexBasedAppState ): FieldStatsSearchStrategyReturnBase { const { services: { @@ -106,19 +110,41 @@ export function useFieldStatsSearchStrategy( return; } - const { sortField, sortDirection } = initialDataVisualizerListState; + const { sortField, sortDirection } = dataVisualizerListState; /** * Sort the list of fields by the initial sort field and sort direction * Then divide into chunks by the initial page size */ - let sortedConfigs = [...fieldStatsParams.metricConfigs, ...fieldStatsParams.nonMetricConfigs]; + const itemsSorter = Comparators.property( + sortField as string, + Comparators.default(sortDirection as 'asc' | 'desc' | undefined) + ); - if (sortField === 'fieldName' || sortField === 'type') { - sortedConfigs = sortedConfigs.sort((a, b) => a[sortField].localeCompare(b[sortField])); - } - if (sortDirection === 'desc') { - sortedConfigs = sortedConfigs.reverse(); + const preslicedSortedConfigs = [ + ...fieldStatsParams.metricConfigs, + ...fieldStatsParams.nonMetricConfigs, + ].sort(itemsSorter); + + const filteredItems = filterFields( + preslicedSortedConfigs, + dataVisualizerListState.visibleFieldNames, + dataVisualizerListState.visibleFieldTypes + ); + + const { pageIndex, pageSize } = dataVisualizerListState; + + const pageOfConfigs = filteredItems.filteredFields + ?.slice(pageIndex * pageSize, (pageIndex + 1) * pageSize) + .filter((d) => d.existsInDocs === true); + + if (!pageOfConfigs || pageOfConfigs.length === 0) { + setFetchState({ + loaded: 100, + isRunning: false, + }); + + return; } const filterCriteria = buildBaseFilterCriteria( @@ -149,7 +175,7 @@ export function useFieldStatsSearchStrategy( }; const batches = createBatchedRequests( - sortedConfigs.map((config, idx) => ({ + pageOfConfigs.map((config, idx) => ({ fieldName: config.fieldName, type: config.type, cardinality: config.cardinality, @@ -161,11 +187,10 @@ export function useFieldStatsSearchStrategy( const statsMap$ = new Subject(); const fieldsToRetry$ = new Subject(); - const fieldStatsSub = combineLatest( - batches - .map((batch) => getFieldsStats(data.search, params, batch, searchOptions)) - .filter((obs) => obs !== undefined) as Array> - ); + const fieldStatsToFetch = batches + .map((batch) => getFieldsStats(data.search, params, batch, searchOptions)) + .filter((obs) => obs !== undefined) as Array>; + const onError = (error: any) => { toasts.addError(error, { title: i18n.translate('xpack.dataVisualizer.index.errorFetchingFieldStatisticsMessage', { @@ -184,17 +209,24 @@ export function useFieldStatsSearchStrategy( }); }; + const statsMapTmp = new Map(); + // First, attempt to fetch field stats in batches of 10 - searchSubscription$.current = fieldStatsSub.subscribe({ - next: (resp) => { - if (resp) { - const statsMap = new Map(); - const failedFields: Field[] = []; - resp.forEach((batchResponse) => { + searchSubscription$.current = from(fieldStatsToFetch) + .pipe(mergeMap((observable) => observable, MAX_CONCURRENT_REQUESTS)) + .subscribe({ + next: (batchResponse) => { + setFetchState({ + ...getInitialProgress(), + error: undefined, + }); + + if (batchResponse) { + const failedFields: Field[] = []; if (Array.isArray(batchResponse)) { batchResponse.forEach((f) => { if (f.fieldName !== undefined) { - statsMap.set(f.fieldName, f); + statsMapTmp.set(f.fieldName, f); } }); } else { @@ -202,23 +234,22 @@ export function useFieldStatsSearchStrategy( // retry each field in the failed batch individually failedFields.push(...(batchResponse.fields ?? [])); } - }); - setFetchState({ - loaded: (statsMap.size / sortedConfigs.length) * 100, - isRunning: true, - }); + setFieldStats(statsMapTmp); + setFetchState({ + loaded: (statsMapTmp.size / pageOfConfigs.length) * 100, + isRunning: true, + }); - setFieldStats(statsMap); - if (failedFields.length > 0) { - statsMap$.next(statsMap); - fieldsToRetry$.next(failedFields); + if (failedFields.length > 0) { + statsMap$.next(statsMapTmp); + fieldsToRetry$.next(failedFields); + } } - } - }, - error: onError, - complete: onComplete, - }); + }, + error: onError, + complete: onComplete, + }); // If any of batches failed, retry each of the failed field at least one time individually retries$.current = combineLatest([ @@ -247,7 +278,7 @@ export function useFieldStatsSearchStrategy( }); setFieldStats(statsMap); setFetchState({ - loaded: (statsMap.size / sortedConfigs.length) * 100, + loaded: (statsMap.size / pageOfConfigs.length) * 100, isRunning: true, }); } @@ -256,7 +287,15 @@ export function useFieldStatsSearchStrategy( complete: onComplete, }); // eslint-disable-next-line react-hooks/exhaustive-deps - }, [data.search, toasts, fieldStatsParams, initialDataVisualizerListState]); + }, [ + data.search, + toasts, + fieldStatsParams, + dataVisualizerListState.pageSize, + dataVisualizerListState.pageIndex, + dataVisualizerListState.sortDirection, + dataVisualizerListState.sortField, + ]); const cancelFetch = useCallback(() => { searchSubscription$.current?.unsubscribe(); diff --git a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_overall_stats.ts b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_overall_stats.ts index 8995a6adc4d46..0ad8ec7037153 100644 --- a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_overall_stats.ts +++ b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/hooks/use_overall_stats.ts @@ -6,8 +6,8 @@ */ import { useCallback, useEffect, useState, useRef, useMemo, useReducer } from 'react'; -import { forkJoin, of, Subscription } from 'rxjs'; -import { switchMap } from 'rxjs/operators'; +import { from, of, Subscription, Observable } from 'rxjs'; +import { mergeMap, last, map, toArray } from 'rxjs/operators'; import { i18n } from '@kbn/i18n'; import type { ToastsStart } from 'kibana/public'; import { chunk } from 'lodash'; @@ -16,6 +16,7 @@ import { AggregatableFieldOverallStats, checkAggregatableFieldsExistRequest, checkNonAggregatableFieldExistsRequest, + isAggregatableFieldOverallStats, processAggregatableFieldsExistResponse, processNonAggregatableFieldsExistResponse, } from '../search_strategy/requests/overall_stats'; @@ -36,6 +37,31 @@ import { processDocumentCountStats, } from '../search_strategy/requests/get_document_stats'; import { getInitialProgress, getReducer } from '../progress_utils'; +import { MAX_CONCURRENT_REQUESTS } from '../constants/index_data_visualizer_viewer'; + +/** + * Helper function to run forkJoin + * with restrictions on how many input observables can be subscribed to concurrently + */ +export function rateLimitingForkJoin( + observables: Array>, + maxConcurrentRequests = MAX_CONCURRENT_REQUESTS +): Observable { + return from(observables).pipe( + mergeMap( + (observable, index) => + observable.pipe( + last(), + map((value) => ({ index, value })) + ), + maxConcurrentRequests + ), + toArray(), + map((indexedObservables) => + indexedObservables.sort((l, r) => l.index - r.index).map((obs) => obs.value) + ) + ); +} function displayError(toastNotifications: ToastsStart, index: string, err: any) { if (err.statusCode === 500) { @@ -116,72 +142,63 @@ export function useOverallStats 0 - ? forkJoin( - nonAggregatableFields.map((fieldName: string) => - data.search - .search( - { - params: checkNonAggregatableFieldExistsRequest( - index, - searchQuery, - fieldName, - timeFieldName, - earliest, - latest, - runtimeFieldMap - ), - }, - searchOptions - ) - .pipe( - switchMap((resp) => { - return of({ - ...resp, - rawResponse: { ...resp.rawResponse, fieldName }, - } as IKibanaSearchResponse); - }) - ) - ) - ) - : of(undefined); + + const nonAggregatableFieldsObs = nonAggregatableFields.map((fieldName: string) => + data.search + .search( + { + params: checkNonAggregatableFieldExistsRequest( + index, + searchQuery, + fieldName, + timeFieldName, + earliest, + latest, + runtimeFieldMap + ), + }, + searchOptions + ) + .pipe( + map((resp) => { + return { + ...resp, + rawResponse: { ...resp.rawResponse, fieldName }, + } as IKibanaSearchResponse; + }) + ) + ); // Have to divide into smaller requests to avoid 413 payload too large const aggregatableFieldsChunks = chunk(aggregatableFields, 30); - const aggregatableOverallStats$ = forkJoin( - aggregatableFields.length > 0 - ? aggregatableFieldsChunks.map((aggregatableFieldsChunk) => - data.search - .search( - { - params: checkAggregatableFieldsExistRequest( - index, - searchQuery, - aggregatableFieldsChunk, - samplerShardSize, - timeFieldName, - earliest, - latest, - undefined, - runtimeFieldMap - ), - }, - searchOptions - ) - .pipe( - switchMap((resp) => { - return of({ - ...resp, - aggregatableFields: aggregatableFieldsChunk, - } as AggregatableFieldOverallStats); - }) - ) - ) - : of(undefined) + const aggregatableOverallStatsObs = aggregatableFieldsChunks.map((aggregatableFieldsChunk) => + data.search + .search( + { + params: checkAggregatableFieldsExistRequest( + index, + searchQuery, + aggregatableFieldsChunk, + samplerShardSize, + timeFieldName, + earliest, + latest, + undefined, + runtimeFieldMap + ), + }, + searchOptions + ) + .pipe( + map((resp) => { + return { + ...resp, + aggregatableFields: aggregatableFieldsChunk, + } as AggregatableFieldOverallStats; + }) + ) ); - const documentCountStats$ = !fieldsToFetch && timeFieldName !== undefined && intervalMs !== undefined && intervalMs > 0 ? data.search.search( @@ -191,28 +208,42 @@ export function useOverallStats { + + const sub = rateLimitingForkJoin< + AggregatableFieldOverallStats | IKibanaSearchResponse | undefined + >( + [documentCountStats$, ...aggregatableOverallStatsObs, ...nonAggregatableFieldsObs], + MAX_CONCURRENT_REQUESTS + ); + + searchSubscription$.current = sub.subscribe({ + next: (value) => { + { + const aggregatableOverallStatsResp: AggregatableFieldOverallStats[] = []; + const nonAggregatableOverallStatsResp: IKibanaSearchResponse[] = []; + const documentCountStatsResp = value[0]; + + value.forEach((resp, idx) => { + if (!resp) return; + if (isAggregatableFieldOverallStats(resp)) { + aggregatableOverallStatsResp.push(resp); + } else { + nonAggregatableOverallStatsResp.push(resp); + } + }); + const aggregatableOverallStats = processAggregatableFieldsExistResponse( aggregatableOverallStatsResp, aggregatableFields, samplerShardSize ); + const nonAggregatableOverallStats = processNonAggregatableFieldsExistResponse( nonAggregatableOverallStatsResp, nonAggregatableFields ); - return of({ + setOverallStats({ documentCountStats: processDocumentCountStats( documentCountStatsResp?.rawResponse, searchStrategyParams @@ -221,14 +252,6 @@ export function useOverallStats { - if (overallStats) { - setOverallStats(overallStats); - } }, error: (error) => { displayError(toasts, searchStrategyParams.index, extractErrorProperties(error)); diff --git a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/search_strategy/requests/overall_stats.ts b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/search_strategy/requests/overall_stats.ts index 1e7c99ce25428..a96244ece334a 100644 --- a/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/search_strategy/requests/overall_stats.ts +++ b/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/search_strategy/requests/overall_stats.ts @@ -90,6 +90,13 @@ export const checkAggregatableFieldsExistRequest = ( export interface AggregatableFieldOverallStats extends IKibanaSearchResponse { aggregatableFields: string[]; } + +export function isAggregatableFieldOverallStats( + arg: unknown +): arg is AggregatableFieldOverallStats { + return isPopulatedObject(arg, ['aggregatableFields']); +} + export const processAggregatableFieldsExistResponse = ( responses: AggregatableFieldOverallStats[] | undefined, aggregatableFields: string[], From 385a0becc9a125738961715b946aed1c0314d617 Mon Sep 17 00:00:00 2001 From: Sander Philipse <94373878+sphilipse@users.noreply.github.com> Date: Mon, 28 Mar 2022 19:31:07 +0200 Subject: [PATCH 038/160] [Workplace Search] Configured sources with multiple options now route correctly when connecting (#128658) --- .../components/add_source/add_source.test.tsx | 12 ++++++++++++ .../components/add_source/add_source.tsx | 18 ++++++++++++++---- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx index d4b5a1dbd9829..e9cbafd01003e 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx @@ -52,6 +52,7 @@ describe('AddSourceList', () => { dataLoading: false, newCustomSource: {}, isOrganization: true, + externalConfigured: false, }; beforeEach(() => { @@ -72,6 +73,17 @@ describe('AddSourceList', () => { expect(setAddSourceStep).toHaveBeenCalledWith(AddSourceSteps.SaveConfigStep); }); + it('renders default state correctly when there are multiple connector options, but all connectors have been configured', () => { + setMockValues({ ...mockValues, externalConfigured: true }); + const sourceData = { + ...staticSourceData[0], + externalConnectorAvailable: true, + configured: true, + }; + shallow(); + expect(initializeAddSource).toHaveBeenCalledWith(expect.objectContaining({ connect: true })); + }); + it('renders default state correctly when there are multiple connector options', () => { const wrapper = shallow( = (props) => { const { initializeAddSource, setAddSourceStep, saveSourceConfig, resetSourceState } = useActions(AddSourceLogic); const { addSourceCurrentStep, sourceConfigData, dataLoading } = useValues(AddSourceLogic); - const { name, categories, needsPermissions, accountContextOnly, privateSourcesEnabled } = - sourceConfigData; - const { serviceType, configuration, features, objTypes } = props.sourceData; + const { + name, + categories, + needsPermissions, + accountContextOnly, + privateSourcesEnabled, + configured, + } = sourceConfigData; + const { serviceType, configuration, features, objTypes, externalConnectorAvailable } = + props.sourceData; const addPath = getAddPath(serviceType); const { isOrganization } = useValues(AppLogic); const { externalConfigured } = useValues(SourcesLogic); useEffect(() => { - initializeAddSource(props); + // We can land on this page from a choice page for multiple types of connectors + // If that's the case we want to skip the intro and configuration, if the external & internal connector have already been configured + const goToConnect = externalConnectorAvailable && externalConfigured && configured; + initializeAddSource(goToConnect ? props : { ...props, connect: true }); return resetSourceState; }, []); From f278da737fba466ecc7fa47a72d37aa400d0086d Mon Sep 17 00:00:00 2001 From: Ying Mao Date: Mon, 28 Mar 2022 13:33:19 -0400 Subject: [PATCH 039/160] [Response Ops] Add alerting/action execution errors to execution log API response (#128413) * Adding audit and feature for getExecutionErrors * Revert Adding audit and feature for getExecutionErrors * Querying for errors and adding to execution log API response * Adding error message to exec log message * Fixing checks * Adding execution timeout errors * Fixing functional test * PR feedback Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../lib/format_execution_log_errors.test.ts | 230 ++++++++++ .../server/lib/format_execution_log_errors.ts | 58 +++ .../lib/get_execution_log_aggregation.test.ts | 230 +++++++++- .../lib/get_execution_log_aggregation.ts | 23 +- .../routes/get_rule_execution_log.test.ts | 22 +- .../server/rules_client/rules_client.ts | 64 ++- .../tests/get_execution_log.test.ts | 427 ++++++++++++++++++ .../tests/alerting/get_execution_log.ts | 45 ++ 8 files changed, 1070 insertions(+), 29 deletions(-) create mode 100644 x-pack/plugins/alerting/server/lib/format_execution_log_errors.test.ts create mode 100644 x-pack/plugins/alerting/server/lib/format_execution_log_errors.ts diff --git a/x-pack/plugins/alerting/server/lib/format_execution_log_errors.test.ts b/x-pack/plugins/alerting/server/lib/format_execution_log_errors.test.ts new file mode 100644 index 0000000000000..70cfe4294020f --- /dev/null +++ b/x-pack/plugins/alerting/server/lib/format_execution_log_errors.test.ts @@ -0,0 +1,230 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { formatExecutionErrorsResult } from './format_execution_log_errors'; +import { QueryEventsBySavedObjectResult } from '../../../event_log/server'; + +describe('formatExecutionErrorsResult', () => { + test('should return empty results if data is undefined', () => { + expect(formatExecutionErrorsResult({} as QueryEventsBySavedObjectResult)).toEqual({ + totalErrors: 0, + errors: [], + }); + }); + test('should format results correctly', () => { + const results = getEsResults({ + data: [ + { + timestamp: '2022-03-23T17:37:07.106Z', + provider: 'actions', + action: 'execute', + outcome: 'failure', + kind: 'action', + executionUuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector', + errorMessage: + 'an error occurred while running the action executor: something funky with the server log', + }, + { + timestamp: '2022-03-23T17:37:07.102Z', + provider: 'actions', + action: 'execute', + outcome: 'failure', + kind: 'action', + executionUuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector', + errorMessage: + 'an error occurred while running the action executor: something funky with the server log', + }, + { + timestamp: '2022-03-23T17:23:05.249Z', + provider: 'alerting', + action: 'execute', + outcome: 'failure', + kind: 'alert', + executionUuid: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + message: `rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule'`, + errorMessage: 'I am erroring in rule execution!!', + }, + ], + }); + expect(formatExecutionErrorsResult(results)).toEqual({ + totalErrors: 6, + errors: [ + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.106Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector - an error occurred while running the action executor: something funky with the server log', + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.102Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector - an error occurred while running the action executor: something funky with the server log', + }, + { + id: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + timestamp: '2022-03-23T17:23:05.249Z', + type: 'alerting', + message: `rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' - I am erroring in rule execution!!`, + }, + ], + }); + }); + test('should format results correctly with timeout', () => { + const results = getEsResults({ + data: [ + { + timestamp: '2022-03-24T15:34:13.199Z', + provider: 'alerting', + action: 'execute-timeout', + kind: 'alert', + executionUuid: 'a427f8cb-0e03-4270-90b2-ec325f4f082c', + message: `rule: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' execution cancelled due to timeout - exceeded rule type timeout of 3s`, + }, + { + timestamp: '2022-03-23T17:37:07.106Z', + provider: 'actions', + action: 'execute', + outcome: 'failure', + kind: 'action', + executionUuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector', + errorMessage: + 'an error occurred while running the action executor: something funky with the server log', + }, + { + timestamp: '2022-03-23T17:37:07.102Z', + provider: 'actions', + action: 'execute', + outcome: 'failure', + kind: 'action', + executionUuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector', + errorMessage: + 'an error occurred while running the action executor: something funky with the server log', + }, + { + timestamp: '2022-03-23T17:23:05.249Z', + provider: 'alerting', + action: 'execute', + outcome: 'failure', + kind: 'alert', + executionUuid: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + message: `rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule'`, + errorMessage: 'I am erroring in rule execution!!', + }, + ], + }); + expect(formatExecutionErrorsResult(results)).toEqual({ + totalErrors: 6, + errors: [ + { + id: 'a427f8cb-0e03-4270-90b2-ec325f4f082c', + timestamp: '2022-03-24T15:34:13.199Z', + type: 'alerting', + message: + "rule: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' execution cancelled due to timeout - exceeded rule type timeout of 3s", + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.106Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector - an error occurred while running the action executor: something funky with the server log', + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.102Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: test-connector - an error occurred while running the action executor: something funky with the server log', + }, + { + id: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + timestamp: '2022-03-23T17:23:05.249Z', + type: 'alerting', + message: `rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' - I am erroring in rule execution!!`, + }, + ], + }); + }); +}); + +interface GetEsResult { + timestamp: string; + provider: string; + action: string; + outcome?: string; + kind: string; + executionUuid: string; + message: string; + errorMessage?: string; +} +interface GetEsResultsOpts { + page?: number; + perPage?: number; + total?: number; + data: GetEsResult[]; +} + +function getEsResults({ + page = 1, + perPage = 500, + total = 6, + data, +}: GetEsResultsOpts): QueryEventsBySavedObjectResult { + return { + page, + per_page: perPage, + total, + data: data.map((d: GetEsResult) => ({ + '@timestamp': d.timestamp, + event: { + provider: d.provider, + action: d.action, + kind: d.kind, + ...(d.outcome ? { outcome: d.outcome } : {}), + }, + kibana: { + alert: { + rule: { + execution: { + uuid: d.executionUuid, + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:37:04.674Z', + schedule_delay: 2431000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + message: d.message, + ...(d.errorMessage ? { error: { message: d.errorMessage } } : {}), + ecs: { + version: '1.8.0', + }, + })), + }; +} diff --git a/x-pack/plugins/alerting/server/lib/format_execution_log_errors.ts b/x-pack/plugins/alerting/server/lib/format_execution_log_errors.ts new file mode 100644 index 0000000000000..a169640c4fc83 --- /dev/null +++ b/x-pack/plugins/alerting/server/lib/format_execution_log_errors.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { get } from 'lodash'; +import { QueryEventsBySavedObjectResult, IValidatedEvent } from '../../../event_log/server'; + +const EXECUTION_UUID_FIELD = 'kibana.alert.rule.execution.uuid'; +const TIMESTAMP_FIELD = '@timestamp'; +const PROVIDER_FIELD = 'event.provider'; +const MESSAGE_FIELD = 'message'; +const ERROR_MESSAGE_FIELD = 'error.message'; + +export interface IExecutionErrors { + id: string; + timestamp: string; + type: string; + message: string; +} + +export interface IExecutionErrorsResult { + totalErrors: number; + errors: IExecutionErrors[]; +} + +export const EMPTY_EXECUTION_ERRORS_RESULT = { + totalErrors: 0, + errors: [], +}; + +function formatEvent(event: IValidatedEvent): IExecutionErrors { + const message = get(event, MESSAGE_FIELD, ''); + const errorMessage = get(event, ERROR_MESSAGE_FIELD, null); + return { + id: get(event, EXECUTION_UUID_FIELD, ''), + timestamp: get(event, TIMESTAMP_FIELD, ''), + type: get(event, PROVIDER_FIELD, ''), + message: errorMessage ? `${message} - ${errorMessage}` : message, + }; +} + +export function formatExecutionErrorsResult( + results: QueryEventsBySavedObjectResult +): IExecutionErrorsResult { + const { total, data } = results; + + if (!data) { + return EMPTY_EXECUTION_ERRORS_RESULT; + } + + return { + totalErrors: total, + errors: data.map((event: IValidatedEvent) => formatEvent(event)), + }; +} diff --git a/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.test.ts b/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.test.ts index 92999a80f6b99..6d6871b7ac111 100644 --- a/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.test.ts +++ b/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.test.ts @@ -197,7 +197,10 @@ describe('getExecutionLogAggregation', () => { }, executionDuration: { max: { field: 'event.duration' } }, outcomeAndMessage: { - top_hits: { size: 1, _source: { includes: ['event.outcome', 'message'] } }, + top_hits: { + size: 1, + _source: { includes: ['event.outcome', 'message', 'error.message'] }, + }, }, }, }, @@ -446,6 +449,231 @@ describe('formatExecutionLogResult', () => { }); }); + test('should format results correctly with rule execution errors', () => { + const results = { + aggregations: { + executionUuid: { + meta: {}, + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [ + { + key: '6705da7d-2635-499d-a6a8-1aee1ae1eac9', + doc_count: 27, + timeoutMessage: { + meta: {}, + doc_count: 0, + }, + alertCounts: { + meta: {}, + buckets: { + activeAlerts: { + doc_count: 5, + }, + newAlerts: { + doc_count: 5, + }, + recoveredAlerts: { + doc_count: 0, + }, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 5.0, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'S4wIZX8B8TGQpG7XQZns', + _score: 1.0, + _source: { + event: { + outcome: 'failure', + }, + message: + "rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule'", + error: { + message: 'I am erroring in rule execution!!', + }, + }, + }, + ], + }, + }, + scheduleDelay: { + value: 3.074e9, + }, + totalSearchDuration: { + value: 0.0, + }, + esSearchDuration: { + value: 0.0, + }, + executionDuration: { + value: 1.056e9, + }, + executeStartTime: { + value: 1.646667512617e12, + value_as_string: '2022-03-07T15:38:32.617Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 5, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [ + { + key: 'success', + doc_count: 5, + }, + ], + }, + }, + }, + { + key: '41b2755e-765a-4044-9745-b03875d5e79a', + doc_count: 32, + timeoutMessage: { + meta: {}, + doc_count: 0, + }, + alertCounts: { + meta: {}, + buckets: { + activeAlerts: { + doc_count: 5, + }, + newAlerts: { + doc_count: 5, + }, + recoveredAlerts: { + doc_count: 5, + }, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 5.0, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'a4wIZX8B8TGQpG7Xwpnz', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule'", + }, + }, + ], + }, + }, + scheduleDelay: { + value: 3.126e9, + }, + totalSearchDuration: { + value: 0.0, + }, + esSearchDuration: { + value: 0.0, + }, + executionDuration: { + value: 1.165e9, + }, + executeStartTime: { + value: 1.646667545604e12, + value_as_string: '2022-03-07T15:39:05.604Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 5, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [ + { + key: 'success', + doc_count: 5, + }, + ], + }, + }, + }, + ], + }, + executionUuidCardinality: { + value: 374, + }, + }, + }; + expect(formatExecutionLogResult(results)).toEqual({ + total: 374, + data: [ + { + id: '6705da7d-2635-499d-a6a8-1aee1ae1eac9', + timestamp: '2022-03-07T15:38:32.617Z', + duration_ms: 1056, + status: 'failure', + message: + "rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' - I am erroring in rule execution!!", + num_active_alerts: 5, + num_new_alerts: 5, + num_recovered_alerts: 0, + num_triggered_actions: 5, + num_succeeded_actions: 5, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 0, + timed_out: false, + schedule_delay_ms: 3074, + }, + { + id: '41b2755e-765a-4044-9745-b03875d5e79a', + timestamp: '2022-03-07T15:39:05.604Z', + duration_ms: 1165, + status: 'success', + message: + "rule executed: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule'", + num_active_alerts: 5, + num_new_alerts: 5, + num_recovered_alerts: 5, + num_triggered_actions: 5, + num_succeeded_actions: 5, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 0, + timed_out: false, + schedule_delay_ms: 3126, + }, + ], + }); + }); + test('should format results correctly when execution timeouts occur', () => { const results = { aggregations: { diff --git a/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts b/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts index 445cec6ad8412..22b7d15f72c11 100644 --- a/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts +++ b/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts @@ -19,6 +19,7 @@ const ACTION_FIELD = 'event.action'; const OUTCOME_FIELD = 'event.outcome'; const DURATION_FIELD = 'event.duration'; const MESSAGE_FIELD = 'message'; +const ERROR_MESSAGE_FIELD = 'error.message'; const SCHEDULE_DELAY_FIELD = 'kibana.task.schedule_delay'; const ES_SEARCH_DURATION_FIELD = 'kibana.alert.rule.execution.metrics.es_search_duration_ms'; const TOTAL_SEARCH_DURATION_FIELD = 'kibana.alert.rule.execution.metrics.total_search_duration_ms'; @@ -51,6 +52,11 @@ export interface IExecutionLogResult { data: IExecutionLog[]; } +export const EMPTY_EXECUTION_LOG_RESULT = { + total: 0, + data: [], +}; + interface IAlertCounts extends estypes.AggregationsMultiBucketAggregateBase { buckets: { activeAlerts: estypes.AggregationsSingleBucketAggregateBase; @@ -207,7 +213,7 @@ export function getExecutionLogAggregation({ page, perPage, sort }: IExecutionLo top_hits: { size: 1, _source: { - includes: [OUTCOME_FIELD, MESSAGE_FIELD], + includes: [OUTCOME_FIELD, MESSAGE_FIELD, ERROR_MESSAGE_FIELD], }, }, }, @@ -256,12 +262,18 @@ function formatExecutionLogAggBucket(bucket: IExecutionUuidAggBucket): IExecutio const actionExecutionError = actionExecutionOutcomes.find((subBucket) => subBucket?.key === 'failure')?.doc_count ?? 0; + const outcomeAndMessage = bucket?.ruleExecution?.outcomeAndMessage?.hits?.hits[0]?._source; + const status = outcomeAndMessage ? outcomeAndMessage?.event?.outcome ?? '' : ''; + const message = + status === 'failure' + ? `${outcomeAndMessage?.message ?? ''} - ${outcomeAndMessage?.error?.message ?? ''}` + : outcomeAndMessage?.message ?? ''; return { id: bucket?.key ?? '', timestamp: bucket?.ruleExecution?.executeStartTime.value_as_string ?? '', duration_ms: durationUs / Millis2Nanos, - status: bucket?.ruleExecution?.outcomeAndMessage?.hits?.hits[0]?._source?.event?.outcome, - message: bucket?.ruleExecution?.outcomeAndMessage?.hits?.hits[0]?._source?.message, + status, + message, num_active_alerts: bucket?.alertCounts?.buckets?.activeAlerts?.doc_count ?? 0, num_new_alerts: bucket?.alertCounts?.buckets?.newAlerts?.doc_count ?? 0, num_recovered_alerts: bucket?.alertCounts?.buckets?.recoveredAlerts?.doc_count ?? 0, @@ -281,10 +293,7 @@ export function formatExecutionLogResult( const { aggregations } = results; if (!aggregations) { - return { - total: 0, - data: [], - }; + return EMPTY_EXECUTION_LOG_RESULT; } const total = (aggregations.executionUuidCardinality as estypes.AggregationsCardinalityAggregate) diff --git a/x-pack/plugins/alerting/server/routes/get_rule_execution_log.test.ts b/x-pack/plugins/alerting/server/routes/get_rule_execution_log.test.ts index e359e9c52dda0..19a2885dadaf7 100644 --- a/x-pack/plugins/alerting/server/routes/get_rule_execution_log.test.ts +++ b/x-pack/plugins/alerting/server/routes/get_rule_execution_log.test.ts @@ -11,7 +11,7 @@ import { licenseStateMock } from '../lib/license_state.mock'; import { mockHandlerArguments } from './_mock_handler_arguments'; import { SavedObjectsErrorHelpers } from 'src/core/server'; import { rulesClientMock } from '../rules_client.mock'; -import { IExecutionLogResult } from '../lib/get_execution_log_aggregation'; +import { IExecutionLogWithErrorsResult } from '../rules_client'; const rulesClient = rulesClientMock.create(); jest.mock('../lib/license_api_access.ts', () => ({ @@ -24,7 +24,7 @@ beforeEach(() => { describe('getRuleExecutionLogRoute', () => { const dateString = new Date().toISOString(); - const mockedExecutionLog: IExecutionLogResult = { + const mockedExecutionLogWithErrors: IExecutionLogWithErrorsResult = { total: 374, data: [ { @@ -64,6 +64,22 @@ describe('getRuleExecutionLogRoute', () => { schedule_delay_ms: 3008, }, ], + totalErrors: 2, + errors: [ + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.086Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s - an error occurred while running the action executor: something funky with the server log', + }, + { + id: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + timestamp: '2022-03-23T17:23:05.249Z', + type: 'alerting', + message: `rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' - I am erroring in rule execution!!`, + }, + ], }; it('gets rule execution log', async () => { @@ -76,7 +92,7 @@ describe('getRuleExecutionLogRoute', () => { expect(config.path).toMatchInlineSnapshot(`"/internal/alerting/rule/{id}/_execution_log"`); - rulesClient.getExecutionLogForRule.mockResolvedValue(mockedExecutionLog); + rulesClient.getExecutionLogForRule.mockResolvedValue(mockedExecutionLogWithErrors); const [context, req, res] = mockHandlerArguments( { rulesClient }, diff --git a/x-pack/plugins/alerting/server/rules_client/rules_client.ts b/x-pack/plugins/alerting/server/rules_client/rules_client.ts index 4dc1ab6ce1122..c60fce223bea7 100644 --- a/x-pack/plugins/alerting/server/rules_client/rules_client.ts +++ b/x-pack/plugins/alerting/server/rules_client/rules_client.ts @@ -92,6 +92,10 @@ import { } from '../lib/get_execution_log_aggregation'; import { validateSnoozeDate } from '../lib/validate_snooze_date'; import { RuleMutedError } from '../lib/errors/rule_muted'; +import { + formatExecutionErrorsResult, + IExecutionErrorsResult, +} from '../lib/format_execution_log_errors'; export interface RegistryAlertTypeWithAuth extends RegistryRuleType { authorizedConsumers: string[]; @@ -259,6 +263,7 @@ export interface GetExecutionLogByIdParams { sort: estypes.Sort; } +export type IExecutionLogWithErrorsResult = IExecutionLogResult & IExecutionErrorsResult; interface ScheduleRuleOptions { id: string; consumer: string; @@ -622,7 +627,6 @@ export class RulesClient { entity: AlertingAuthorizationEntity.Rule, }); - // default duration of instance summary is 60 * rule interval const dateNow = new Date(); const durationMillis = parseDuration(rule.schedule.interval) * (numberOfExecutions ?? 60); const defaultDateStart = new Date(dateNow.valueOf() - durationMillis); @@ -688,7 +692,7 @@ export class RulesClient { page, perPage, sort, - }: GetExecutionLogByIdParams): Promise { + }: GetExecutionLogByIdParams): Promise { this.logger.debug(`getExecutionLogForRule(): getting execution log for rule ${id}`); const rule = (await this.get({ id, includeLegacyId: true })) as SanitizedRuleWithLegacyId; @@ -725,23 +729,47 @@ export class RulesClient { const eventLogClient = await this.getEventLogClient(); - const results = await eventLogClient.aggregateEventsBySavedObjectIds( - 'alert', - [id], - { - start: parsedDateStart.toISOString(), - end: parsedDateEnd.toISOString(), - filter, - aggs: getExecutionLogAggregation({ - page, - perPage, - sort, - }), - }, - rule.legacyId !== null ? [rule.legacyId] : undefined - ); + try { + const [aggResult, errorResult] = await Promise.all([ + eventLogClient.aggregateEventsBySavedObjectIds( + 'alert', + [id], + { + start: parsedDateStart.toISOString(), + end: parsedDateEnd.toISOString(), + filter, + aggs: getExecutionLogAggregation({ + page, + perPage, + sort, + }), + }, + rule.legacyId !== null ? [rule.legacyId] : undefined + ), + eventLogClient.findEventsBySavedObjectIds( + 'alert', + [id], + { + start: parsedDateStart.toISOString(), + end: parsedDateEnd.toISOString(), + per_page: 500, + filter: `(event.action:execute AND event.outcome:failure) OR (event.action:execute-timeout)`, + sort: [{ sort_field: '@timestamp', sort_order: 'desc' }], + }, + rule.legacyId !== null ? [rule.legacyId] : undefined + ), + ]); - return formatExecutionLogResult(results); + return { + ...formatExecutionLogResult(aggResult), + ...formatExecutionErrorsResult(errorResult), + }; + } catch (err) { + this.logger.debug( + `rulesClient.getExecutionLogForRule(): error searching event log for rule ${id}: ${err.message}` + ); + throw err; + } } public async find({ diff --git a/x-pack/plugins/alerting/server/rules_client/tests/get_execution_log.test.ts b/x-pack/plugins/alerting/server/rules_client/tests/get_execution_log.test.ts index 8ad904bacd5d3..53c8884798325 100644 --- a/x-pack/plugins/alerting/server/rules_client/tests/get_execution_log.test.ts +++ b/x-pack/plugins/alerting/server/rules_client/tests/get_execution_log.test.ts @@ -273,6 +273,313 @@ const aggregateResults = { }, }; +const findResults = { + page: 1, + per_page: 500, + total: 6, + data: [ + { + '@timestamp': '2022-03-23T17:37:07.106Z', + event: { + provider: 'actions', + action: 'execute', + kind: 'action', + start: '2022-03-23T17:37:07.105Z', + end: '2022-03-23T17:37:07.105Z', + duration: 0, + outcome: 'failure', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'action', + id: '9e67b8b0-9e2c-11ec-bd64-774ed95c43ef', + type_id: '.server-log', + }, + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:37:04.674Z', + schedule_delay: 2431000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + message: 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s', + error: { + message: + 'an error occurred while running the action executor: something funky with the server log', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-23T17:37:07.102Z', + event: { + provider: 'actions', + action: 'execute', + kind: 'action', + start: '2022-03-23T17:37:07.101Z', + end: '2022-03-23T17:37:07.102Z', + duration: 1000000, + outcome: 'failure', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'action', + id: '9e67b8b0-9e2c-11ec-bd64-774ed95c43ef', + type_id: '.server-log', + }, + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:37:04.676Z', + schedule_delay: 2425000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + message: 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s', + error: { + message: + 'an error occurred while running the action executor: something funky with the server log', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-23T17:37:07.098Z', + event: { + provider: 'actions', + action: 'execute', + kind: 'action', + start: '2022-03-23T17:37:07.098Z', + end: '2022-03-23T17:37:07.098Z', + duration: 0, + outcome: 'failure', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'action', + id: '9e67b8b0-9e2c-11ec-bd64-774ed95c43ef', + type_id: '.server-log', + }, + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:37:04.673Z', + schedule_delay: 2425000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + message: 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s', + error: { + message: + 'an error occurred while running the action executor: something funky with the server log', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-23T17:37:07.096Z', + event: { + provider: 'actions', + action: 'execute', + kind: 'action', + start: '2022-03-23T17:37:07.095Z', + end: '2022-03-23T17:37:07.096Z', + duration: 1000000, + outcome: 'failure', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'action', + id: '9e67b8b0-9e2c-11ec-bd64-774ed95c43ef', + type_id: '.server-log', + }, + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:37:04.677Z', + schedule_delay: 2418000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + message: 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s', + error: { + message: + 'an error occurred while running the action executor: something funky with the server log', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-23T17:37:07.086Z', + event: { + provider: 'actions', + action: 'execute', + kind: 'action', + start: '2022-03-23T17:37:07.084Z', + end: '2022-03-23T17:37:07.086Z', + duration: 2000000, + outcome: 'failure', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'action', + id: '9e67b8b0-9e2c-11ec-bd64-774ed95c43ef', + type_id: '.server-log', + }, + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:37:04.678Z', + schedule_delay: 2406000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + message: 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s', + error: { + message: + 'an error occurred while running the action executor: something funky with the server log', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-23T17:23:05.249Z', + event: { + provider: 'alerting', + action: 'execute', + kind: 'alert', + category: ['AlertingExample'], + start: '2022-03-23T17:23:05.131Z', + outcome: 'failure', + end: '2022-03-23T17:23:05.248Z', + duration: 117000000, + reason: 'execute', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + type_id: 'example.always-firing', + }, + ], + task: { + scheduled: '2022-03-23T17:22:23.618Z', + schedule_delay: 41512000000, + }, + alerting: { + status: 'error', + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'a348a740-9e2c-11ec-bd64-774ed95c43ef', + license: 'basic', + category: 'example.always-firing', + ruleset: 'AlertingExample', + }, + message: + "rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule'", + error: { + message: 'I am erroring in rule execution!!', + }, + ecs: { + version: '1.8.0', + }, + }, + ], +}; + function getRuleSavedObject(attributes: Partial = {}): SavedObject { return { ...BaseRuleSavedObject, @@ -301,6 +608,7 @@ describe('getExecutionLogForRule()', () => { const ruleSO = getRuleSavedObject({}); unsecuredSavedObjectsClient.get.mockResolvedValueOnce(ruleSO); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); const result = await rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()); expect(result).toEqual({ @@ -343,6 +651,50 @@ describe('getExecutionLogForRule()', () => { schedule_delay_ms: 3345, }, ], + totalErrors: 6, + errors: [ + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.106Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s - an error occurred while running the action executor: something funky with the server log', + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.102Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s - an error occurred while running the action executor: something funky with the server log', + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.098Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s - an error occurred while running the action executor: something funky with the server log', + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.096Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s - an error occurred while running the action executor: something funky with the server log', + }, + { + id: '08d9b0f5-0b41-47c9-951f-a666b5788ddc', + timestamp: '2022-03-23T17:37:07.086Z', + type: 'actions', + message: + 'action execution failure: .server-log:9e67b8b0-9e2c-11ec-bd64-774ed95c43ef: s - an error occurred while running the action executor: something funky with the server log', + }, + { + id: 'c1c04f04-312e-4e23-8e36-e01eb4332ed6', + timestamp: '2022-03-23T17:23:05.249Z', + type: 'alerting', + message: `rule execution failure: example.always-firing:a348a740-9e2c-11ec-bd64-774ed95c43ef: 'test rule' - I am erroring in rule execution!!`, + }, + ], }); }); @@ -353,6 +705,7 @@ describe('getExecutionLogForRule()', () => { test('calls saved objects and event log client with default params', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); await rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()); @@ -372,6 +725,19 @@ describe('getExecutionLogForRule()', () => { }, undefined, ]); + expect(eventLogClient.findEventsBySavedObjectIds).toHaveBeenCalledTimes(1); + expect(eventLogClient.findEventsBySavedObjectIds.mock.calls[0]).toEqual([ + 'alert', + ['1'], + { + per_page: 500, + filter: `(event.action:execute AND event.outcome:failure) OR (event.action:execute-timeout)`, + sort: [{ sort_field: '@timestamp', sort_order: 'desc' }], + end: mockedDateString, + start: '2019-02-12T20:01:22.479Z', + }, + undefined, + ]); }); test('calls event log client with legacy ids param', async () => { @@ -379,6 +745,7 @@ describe('getExecutionLogForRule()', () => { getRuleSavedObject({ legacyId: '99999' }) ); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); await rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()); @@ -398,11 +765,25 @@ describe('getExecutionLogForRule()', () => { }, ['99999'], ]); + expect(eventLogClient.findEventsBySavedObjectIds).toHaveBeenCalledTimes(1); + expect(eventLogClient.findEventsBySavedObjectIds.mock.calls[0]).toEqual([ + 'alert', + ['1'], + { + per_page: 500, + filter: `(event.action:execute AND event.outcome:failure) OR (event.action:execute-timeout)`, + sort: [{ sort_field: '@timestamp', sort_order: 'desc' }], + end: mockedDateString, + start: '2019-02-12T20:01:22.479Z', + }, + ['99999'], + ]); }); test('calls event log client with end date if specified', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); await rulesClient.getExecutionLogForRule( getExecutionLogByIdParams({ dateEnd: new Date(Date.now() - 2700000).toISOString() }) @@ -424,11 +805,25 @@ describe('getExecutionLogForRule()', () => { }, undefined, ]); + expect(eventLogClient.findEventsBySavedObjectIds).toHaveBeenCalledTimes(1); + expect(eventLogClient.findEventsBySavedObjectIds.mock.calls[0]).toEqual([ + 'alert', + ['1'], + { + per_page: 500, + filter: `(event.action:execute AND event.outcome:failure) OR (event.action:execute-timeout)`, + sort: [{ sort_field: '@timestamp', sort_order: 'desc' }], + end: '2019-02-12T20:16:22.479Z', + start: '2019-02-12T20:01:22.479Z', + }, + undefined, + ]); }); test('calls event log client with filter if specified', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); await rulesClient.getExecutionLogForRule( getExecutionLogByIdParams({ filter: 'event.outcome: success' }) @@ -451,11 +846,25 @@ describe('getExecutionLogForRule()', () => { }, undefined, ]); + expect(eventLogClient.findEventsBySavedObjectIds).toHaveBeenCalledTimes(1); + expect(eventLogClient.findEventsBySavedObjectIds.mock.calls[0]).toEqual([ + 'alert', + ['1'], + { + per_page: 500, + filter: `(event.action:execute AND event.outcome:failure) OR (event.action:execute-timeout)`, + sort: [{ sort_field: '@timestamp', sort_order: 'desc' }], + end: mockedDateString, + start: '2019-02-12T20:01:22.479Z', + }, + undefined, + ]); }); test('invalid start date throws an error', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); const dateStart = 'ain"t no way this will get parsed as a date'; expect( @@ -468,6 +877,7 @@ describe('getExecutionLogForRule()', () => { test('invalid end date throws an error', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); const dateEnd = 'ain"t no way this will get parsed as a date'; expect( @@ -480,6 +890,7 @@ describe('getExecutionLogForRule()', () => { test('invalid page value throws an error', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); expect( rulesClient.getExecutionLogForRule(getExecutionLogByIdParams({ page: -3 })) @@ -489,6 +900,7 @@ describe('getExecutionLogForRule()', () => { test('invalid perPage value throws an error', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); expect( rulesClient.getExecutionLogForRule(getExecutionLogByIdParams({ perPage: -3 })) @@ -498,6 +910,7 @@ describe('getExecutionLogForRule()', () => { test('invalid sort value throws an error', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); expect( rulesClient.getExecutionLogForRule( @@ -511,6 +924,7 @@ describe('getExecutionLogForRule()', () => { test('throws error when saved object get throws an error', async () => { unsecuredSavedObjectsClient.get.mockRejectedValueOnce(new Error('OMG!')); eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); expect( rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()) @@ -520,12 +934,23 @@ describe('getExecutionLogForRule()', () => { test('throws error when eventLog.aggregateEventsBySavedObjectIds throws an error', async () => { unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); eventLogClient.aggregateEventsBySavedObjectIds.mockRejectedValueOnce(new Error('OMG 2!')); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); expect( rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()) ).rejects.toMatchInlineSnapshot(`[Error: OMG 2!]`); }); + test('throws error when eventLog.findEventsBySavedObjectIds throws an error', async () => { + unsecuredSavedObjectsClient.get.mockResolvedValueOnce(getRuleSavedObject()); + eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockRejectedValueOnce(new Error('OMG 3!')); + + expect( + rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()) + ).rejects.toMatchInlineSnapshot(`[Error: OMG 3!]`); + }); + describe('authorization', () => { beforeEach(() => { const ruleSO = getRuleSavedObject({}); @@ -534,6 +959,7 @@ describe('getExecutionLogForRule()', () => { test('ensures user is authorised to get this type of alert under the consumer', async () => { eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); await rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()); expect(authorization.ensureAuthorized).toHaveBeenCalledWith({ @@ -570,6 +996,7 @@ describe('getExecutionLogForRule()', () => { test('logs audit event when getting a rule execution log', async () => { eventLogClient.aggregateEventsBySavedObjectIds.mockResolvedValueOnce(aggregateResults); + eventLogClient.findEventsBySavedObjectIds.mockResolvedValueOnce(findResults); await rulesClient.getExecutionLogForRule(getExecutionLogByIdParams()); expect(auditLogger.log).toHaveBeenCalledWith( expect.objectContaining({ diff --git a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/get_execution_log.ts b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/get_execution_log.ts index 5b2ba00ace7f8..c7bb15ba12a98 100644 --- a/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/get_execution_log.ts +++ b/x-pack/test/alerting_api_integration/spaces_only/tests/alerting/get_execution_log.ts @@ -69,6 +69,8 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(response.status).to.eql(200); expect(response.body.total).to.eql(2); + expect(response.body.totalErrors).to.eql(0); + expect(response.body.errors).to.eql([]); const execLogs = response.body.data; expect(execLogs.length).to.eql(2); @@ -120,6 +122,8 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(response.body.total).to.eql(0); expect(response.body.data).to.eql([]); + expect(response.body.totalErrors).to.eql(0); + expect(response.body.errors).to.eql([]); }); it('gets execution log for rule that performs ES searches', async () => { @@ -148,6 +152,8 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(response.status).to.eql(200); expect(response.body.total).to.eql(1); + expect(response.body.totalErrors).to.eql(0); + expect(response.body.errors).to.eql([]); const execLogs = response.body.data; expect(execLogs.length).to.eql(1); @@ -202,6 +208,19 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo for (const log of execLogs) { expect(log.status).to.equal('failure'); expect(log.timed_out).to.equal(false); + expect(log.message).to.equal( + `rule execution failure: test.throw:${createdRule.id}: 'abc' - this alert is intended to fail` + ); + } + + expect(response.body.totalErrors).to.eql(1); + expect(response.body.errors.length).to.eql(1); + + for (const errors of response.body.errors) { + expect(errors.type).to.equal('alerting'); + expect(errors.message).to.equal( + `rule execution failure: test.throw:${createdRule.id}: 'abc' - this alert is intended to fail` + ); } }); @@ -238,6 +257,16 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(log.status).to.equal('success'); expect(log.timed_out).to.equal(true); } + + expect(response.body.totalErrors).to.eql(1); + expect(response.body.errors.length).to.eql(1); + + for (const errors of response.body.errors) { + expect(errors.type).to.equal('alerting'); + expect(errors.message).to.equal( + `rule: test.patternLongRunning:${createdRule.id}: 'abc' execution cancelled due to timeout - exceeded rule type timeout of 3s` + ); + } }); it('gets execution log for rule that triggers actions', async () => { @@ -281,6 +310,8 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(response.status).to.eql(200); expect(response.body.total).to.eql(1); + expect(response.body.totalErrors).to.eql(0); + expect(response.body.errors).to.eql([]); const execLogs = response.body.data; expect(execLogs.length).to.eql(1); @@ -352,6 +383,16 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(log.num_succeeded_actions).to.equal(0); expect(log.num_errored_actions).to.equal(1); } + + expect(response.body.totalErrors).to.eql(1); + expect(response.body.errors.length).to.eql(1); + + for (const errors of response.body.errors) { + expect(errors.type).to.equal('actions'); + expect(errors.message).to.equal( + `action execution failure: test.throw:${createdConnector.id}: connector that throws - an error occurred while running the action executor: this action is intended to fail` + ); + } }); it('handles date_end if specified', async () => { @@ -376,6 +417,8 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(response.body.total).to.eql(0); expect(response.body.data.length).to.eql(0); + expect(response.body.totalErrors).to.eql(0); + expect(response.body.errors.length).to.eql(0); }); it('handles sort query parameter', async () => { @@ -396,6 +439,8 @@ export default function createGetExecutionLogTests({ getService }: FtrProviderCo expect(response.status).to.eql(200); expect(response.body.total).to.eql(3); + expect(response.body.totalErrors).to.eql(0); + expect(response.body.errors).to.eql([]); const execLogs = response.body.data; expect(execLogs.length).to.eql(3); From cc9f93197243bc82377bf6c8f75721766bcad294 Mon Sep 17 00:00:00 2001 From: Jonathan Budzenski Date: Mon, 28 Mar 2022 12:33:29 -0500 Subject: [PATCH 040/160] [ci] Enable cross compiled docker images (#128430) --- .buildkite/scripts/build_kibana.sh | 2 +- .buildkite/scripts/steps/artifacts/build.sh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.buildkite/scripts/build_kibana.sh b/.buildkite/scripts/build_kibana.sh index a7fbcc0ea4b92..482f730284a94 100755 --- a/.buildkite/scripts/build_kibana.sh +++ b/.buildkite/scripts/build_kibana.sh @@ -8,7 +8,7 @@ echo "--- Build Kibana Distribution" if [[ "${GITHUB_PR_LABELS:-}" == *"ci:build-all-platforms"* ]]; then node scripts/build --all-platforms --skip-os-packages elif [[ "${GITHUB_PR_LABELS:-}" == *"ci:build-os-packages"* ]]; then - node scripts/build --all-platforms + node scripts/build --all-platforms --docker-cross-compile else node scripts/build fi diff --git a/.buildkite/scripts/steps/artifacts/build.sh b/.buildkite/scripts/steps/artifacts/build.sh index 211bfddecd010..db1faa184b35a 100644 --- a/.buildkite/scripts/steps/artifacts/build.sh +++ b/.buildkite/scripts/steps/artifacts/build.sh @@ -5,7 +5,7 @@ set -euo pipefail .buildkite/scripts/bootstrap.sh echo "--- Build Kibana Distribution" -node scripts/build --all-platforms --debug --skip-docker-cloud +node scripts/build --all-platforms --debug --docker-cross-compile --skip-docker-cloud echo "--- Build dependencies report" node scripts/licenses_csv_report --csv=target/dependencies_report.csv From 210a59425fc9734102d6f2209ed57556f85ac196 Mon Sep 17 00:00:00 2001 From: Christos Nasikas Date: Mon, 28 Mar 2022 20:43:57 +0300 Subject: [PATCH 041/160] [Cases] Delete autogenerated docs (#128605) --- x-pack/plugins/cases/docs/README.md | 42 - .../plugins/cases/docs/cases_client/.nojekyll | 1 - .../plugins/cases/docs/cases_client/README.md | 18 - ...ient._internal_namespace.ActionExecutor.md | 153 -- ...._internal_namespace.ActionTypeRegistry.md | 288 --- .../client._internal_namespace.Actions.md | 144 -- ...internal_namespace.ActionsAuthorization.md | 99 - ...lient._internal_namespace.ActionsClient.md | 432 ---- ...client._internal_namespace.AlertService.md | 206 -- ...ent._internal_namespace.AlertingActions.md | 68 - .../client._internal_namespace.ApiActions.md | 65 - .../client._internal_namespace.AppActions.md | 65 - ...t._internal_namespace.AttachmentService.md | 217 -- ...lient._internal_namespace.Authorization.md | 241 -- ...rnal_namespace.AuthorizationAuditLogger.md | 117 - .../client._internal_namespace.BasePath.md | 189 -- ...ient._internal_namespace.BuilderFactory.md | 47 - ...internal_namespace.CaseConfigureService.md | 135 - ...nternal_namespace.CaseUserActionService.md | 304 --- ...client._internal_namespace.CasesActions.md | 66 - ..._internal_namespace.CasesClientInternal.md | 59 - ...client._internal_namespace.CasesService.md | 470 ---- ...rnal_namespace.ConnectorMappingsService.md | 93 - ...internal_namespace.ConnectorTokenClient.md | 162 -- ...internal_namespace.ElasticsearchFeature.md | 122 - ...lient._internal_namespace.KibanaFeature.md | 268 -- ...ient._internal_namespace.KibanaMigrator.md | 286 --- ...lient._internal_namespace.KibanaRequest.md | 347 --- ...client._internal_namespace.LicenseState.md | 215 -- ...internal_namespace.RouteValidationError.md | 40 - ...ient._internal_namespace.RouteValidator.md | 272 -- ...._internal_namespace.SavedObjectActions.md | 66 - ...ernal_namespace.SavedObjectTypeRegistry.md | 306 --- ...._internal_namespace.SavedObjectsClient.md | 617 ----- ...rnal_namespace.SavedObjectsErrorHelpers.md | 665 ----- ...ternal_namespace.SavedObjectsRepository.md | 1082 -------- ...client._internal_namespace.SpaceActions.md | 59 - .../client._internal_namespace.SubFeature.md | 97 - ...t._internal_namespace.TaskRunnerFactory.md | 114 - .../client._internal_namespace.UIActions.md | 66 - ...t._internal_namespace.UserActionBuilder.md | 251 -- .../classes/client.casesclient.md | 214 -- ...nal_namespace.ActionExecutionSourceType.md | 32 - ...t._internal_namespace.AuthorizationMode.md | 32 - ...client._internal_namespace.CaseStatuses.md | 43 - .../client._internal_namespace.TaskStatus.md | 65 - .../client._internal_namespace.ViewMode.md | 54 - ...ents_client._internal_namespace.AddArgs.md | 38 - ...lient._internal_namespace.DeleteAllArgs.md | 25 - ...s_client._internal_namespace.DeleteArgs.md | 38 - ...nts_client._internal_namespace.FindArgs.md | 54 - ...rnal_namespace.GetAllAlertsAttachToCase.md | 23 - ...s_client._internal_namespace.GetAllArgs.md | 25 - ...ents_client._internal_namespace.GetArgs.md | 36 - ...s_client._internal_namespace.UpdateArgs.md | 38 - ...attachments_client.attachmentssubclient.md | 198 -- .../interfaces/cases_client.casessubclient.md | 249 -- .../cases_get.casesbyalertidparams.md | 44 - .../interfaces/cases_get.getparams.md | 38 - .../interfaces/cases_push.pushparams.md | 38 - .../client._internal_namespace.Action.md | 72 - ...nternal_namespace.ActionExecutionSource.md | 38 - ...nternal_namespace.ActionExecutorContext.md | 112 - ...client._internal_namespace.ActionResult.md | 90 - ...client._internal_namespace.ActionType-1.md | 120 - .../client._internal_namespace.ActionType.md | 76 - ...nal_namespace.ActionTypeExecutorOptions.md | 95 - ...rnal_namespace.ActionTypeExecutorResult.md | 82 - ...ternal_namespace.ActionTypeRegistryOpts.md | 76 - ...client._internal_namespace.ActionUpdate.md | 51 - ...namespace.ActionsConfigurationUtilities.md | 217 -- ...nal_namespace.ActionsLicenseInformation.md | 43 - ...._internal_namespace.AggregationBuilder.md | 68 - .../client._internal_namespace.Alert.md | 43 - ...client._internal_namespace.AlertIdIndex.md | 32 - .../client._internal_namespace.AlertInfo.md | 34 - ...ient._internal_namespace.AlertsResponse.md | 21 - .../client._internal_namespace.AppCategory.md | 83 - ...._internal_namespace.AttachedToCaseArgs.md | 55 - .../client._internal_namespace.Attributes.md | 84 - .../client._internal_namespace.AuditEvent.md | 59 - .../client._internal_namespace.AuditLogger.md | 52 - ...t._internal_namespace.AuthFilterHelpers.md | 38 - ...t._internal_namespace.AuthenticatedUser.md | 170 -- ...ternal_namespace.AuthenticationProvider.md | 34 - ..._internal_namespace.AuthorizationMode-1.md | 31 - ...nal_namespace.AuthorizationServiceSetup.md | 71 - ...t._internal_namespace.BeforeSaveContext.md | 21 - ...t._internal_namespace.BuilderParameters.md | 205 -- ...._internal_namespace.BuilderReturnValue.md | 32 - ....BulkCreateAttachmentDeletionUserAction.md | 125 - ...ace.BulkCreateBulkUpdateCaseUserActions.md | 72 - ...espace.BulkCreateCaseDeletionUserAction.md | 61 - ...rnal_namespace.BulkUpdateAttachmentArgs.md | 42 - ...ent._internal_namespace.CancellableTask.md | 32 - ...client._internal_namespace.Capabilities.md | 63 - ...nt._internal_namespace.CaseCommentStats.md | 32 - ...ent._internal_namespace.CasesClientArgs.md | 160 -- ...internal_namespace.CasesMapWithPageInfo.md | 54 - ...ent._internal_namespace.CheckPrivileges.md | 78 - ...ternal_namespace.CheckPrivilegesOptions.md | 27 - ...ternal_namespace.CheckPrivilegesPayload.md | 39 - ...ernal_namespace.CheckPrivilegesResponse.md | 52 - ...client._internal_namespace.ClientArgs-1.md | 55 - ...client._internal_namespace.ClientArgs-2.md | 31 - .../client._internal_namespace.ClientArgs.md | 33 - ...ent._internal_namespace.CommonArguments.md | 84 - ...internal_namespace.ConcreteTaskInstance.md | 291 --- ...ient._internal_namespace.ConnectorToken.md | 82 - ...internal_namespace.ConstructorOptions-1.md | 60 - ...internal_namespace.ConstructorOptions-2.md | 43 - ...._internal_namespace.ConstructorOptions.md | 153 -- ...amespace.CountActionsAttachedToCaseArgs.md | 72 - ...internal_namespace.CreateAttachmentArgs.md | 64 - ...internal_namespace.CreateAuditMsgParams.md | 43 - ...ent._internal_namespace.CreateOptions-1.md | 54 - ...lient._internal_namespace.CreateOptions.md | 21 - ...nt._internal_namespace.CreateUserAction.md | 38 - ...._internal_namespace.CreateUserActionES.md | 59 - ...ient._internal_namespace.DecoratedError.md | 27 - ...al_namespace.ElasticsearchFeatureConfig.md | 94 - ..._namespace.EmbeddableRegistryDefinition.md | 157 -- ...l_namespace.EncryptedSavedObjectsClient.md | 39 - ...nt._internal_namespace.ExecuteOptions-1.md | 101 - ...ient._internal_namespace.ExecuteOptions.md | 104 - ...amespace.FeatureElasticsearchPrivileges.md | 106 - ...ernal_namespace.FeatureKibanaPrivileges.md | 246 -- ...rnal_namespace.FeatureUsageServiceSetup.md | 34 - ...nt._internal_namespace.FindActionResult.md | 117 - ...internal_namespace.FindCaseCommentsArgs.md | 43 - ...nternal_namespace.FindCaseConfigureArgs.md | 42 - ...lient._internal_namespace.FindCasesArgs.md | 42 - ...nt._internal_namespace.FindCommentsArgs.md | 43 - ...nal_namespace.FindConnectorMappingsArgs.md | 42 - ..._internal_namespace.GetAllSpacesOptions.md | 44 - ...t._internal_namespace.GetAttachmentArgs.md | 42 - .../client._internal_namespace.GetCaseArgs.md | 42 - ...internal_namespace.GetCaseConfigureArgs.md | 42 - ...ernal_namespace.GetCaseIdsByAlertIdArgs.md | 53 - ...nternal_namespace.GetCaseUserActionArgs.md | 42 - ...client._internal_namespace.GetCasesArgs.md | 42 - ...nt._internal_namespace.GetReportersArgs.md | 32 - ...ient._internal_namespace.GetSpaceResult.md | 176 -- .../client._internal_namespace.GetTagsArgs.md | 32 - ...namespace.GetUserActionItemByDifference.md | 162 -- .../client._internal_namespace.GetUserArgs.md | 21 - ...client._internal_namespace.IEventLogger.md | 73 - ...lient._internal_namespace.IKibanaSocket.md | 150 -- .../client._internal_namespace.ILicense.md | 236 -- ...amespace.ISavedObjectsPointInTimeFinder.md | 61 - ...internal_namespace.IScopedClusterClient.md | 43 - ...lient._internal_namespace.ISpacesClient.md | 151 -- ...lient._internal_namespace.IUsageCounter.md | 37 - ...ternal_namespace.IncrementCounterParams.md | 51 - ...client._internal_namespace.IndexMapping.md | 45 - ...nt._internal_namespace.IndexMappingMeta.md | 27 - ...nt._internal_namespace.IntervalSchedule.md | 23 - ..._internal_namespace.KibanaFeatureConfig.md | 257 -- ...nternal_namespace.KibanaMigratorOptions.md | 76 - ...internal_namespace.KibanaMigratorStatus.md | 43 - ..._internal_namespace.KibanaRequestEvents.md | 43 - ...internal_namespace.LegacyUrlAliasTarget.md | 51 - ...client._internal_namespace.LicenseCheck.md | 36 - ...ient._internal_namespace.LicenseFeature.md | 32 - ...internal_namespace.LicensingPluginSetup.md | 60 - .../client._internal_namespace.Middleware.md | 43 - ...nt._internal_namespace.OperationDetails.md | 91 - .../client._internal_namespace.OwnerEntity.md | 35 - .../client._internal_namespace.PatchCase.md | 54 - ...ternal_namespace.PatchCaseConfigureArgs.md | 64 - ...ient._internal_namespace.PatchCasesArgs.md | 42 - ...nt._internal_namespace.PersistableState.md | 133 - ..._internal_namespace.PluginStartContract.md | 40 - ...client._internal_namespace.PostCaseArgs.md | 53 - ...nternal_namespace.PostCaseConfigureArgs.md | 53 - ...ternal_namespace.PostCaseUserActionArgs.md | 42 - ...nal_namespace.PostConnectorMappingsArgs.md | 60 - ..._internal_namespace.PreConfiguredAction.md | 124 - ...lient._internal_namespace.ProxySettings.md | 65 - ...lient._internal_namespace.PublicLicense.md | 80 - ...t._internal_namespace.PublicLicenseJSON.md | 46 - .../client._internal_namespace.PushedArgs.md | 40 - ...client._internal_namespace.Referencable.md | 21 - ...ernal_namespace.ReservedKibanaPrivilege.md | 32 - ...nt._internal_namespace.ResponseSettings.md | 32 - ...._internal_namespace.RouteConfigOptions.md | 100 - ...ternal_namespace.RouteConfigOptionsBody.md | 89 - ..._namespace.RouteValidationResultFactory.md | 71 - ...internal_namespace.RouteValidatorConfig.md | 60 - ...nternal_namespace.RouteValidatorOptions.md | 33 - .../client._internal_namespace.RunContext.md | 25 - ...client._internal_namespace.RunNowResult.md | 32 - .../client._internal_namespace.SSLSettings.md | 21 - .../client._internal_namespace.SavedObject.md | 167 -- ...nternal_namespace.SavedObjectAttributes.md | 20 - ...ient._internal_namespace.SavedObjectDoc.md | 128 - ...nt._internal_namespace.SavedObjectError.md | 54 - ...l_namespace.SavedObjectMigrationContext.md | 64 - ...ernal_namespace.SavedObjectMigrationMap.md | 23 - ...internal_namespace.SavedObjectReference.md | 45 - ...mespace.SavedObjectReferenceWithContext.md | 91 - ...ernal_namespace.SavedObjectsBaseOptions.md | 47 - ..._namespace.SavedObjectsBulkCreateObject.md | 136 - ...nal_namespace.SavedObjectsBulkGetObject.md | 65 - ...namespace.SavedObjectsBulkResolveObject.md | 32 - ...mespace.SavedObjectsBulkResolveResponse.md | 27 - ...rnal_namespace.SavedObjectsBulkResponse.md | 27 - ..._namespace.SavedObjectsBulkUpdateObject.md | 111 - ...namespace.SavedObjectsBulkUpdateOptions.md | 46 - ...amespace.SavedObjectsBulkUpdateResponse.md | 27 - ...espace.SavedObjectsCheckConflictsObject.md | 32 - ...pace.SavedObjectsCheckConflictsResponse.md | 21 - ...ce.SavedObjectsClosePointInTimeResponse.md | 37 - ...tsCollectMultiNamespaceReferencesObject.md | 38 - ...sCollectMultiNamespaceReferencesOptions.md | 48 - ...CollectMultiNamespaceReferencesResponse.md | 23 - ...nal_namespace.SavedObjectsCreateOptions.md | 162 -- ...ectsCreatePointInTimeFinderDependencies.md | 21 - ...ce.SavedObjectsDeleteByNamespaceOptions.md | 46 - ...nal_namespace.SavedObjectsDeleteOptions.md | 59 - ...pace.SavedObjectsExportTransformContext.md | 26 - ...ernal_namespace.SavedObjectsFindOptions.md | 270 -- ...espace.SavedObjectsFindOptionsReference.md | 32 - ...rnal_namespace.SavedObjectsFindResponse.md | 88 - ...ternal_namespace.SavedObjectsFindResult.md | 262 -- ...SavedObjectsImportActionRequiredWarning.md | 65 - ..._namespace.SavedObjectsImportHookResult.md | 25 - ...mespace.SavedObjectsImportSimpleWarning.md | 36 - ...space.SavedObjectsIncrementCounterField.md | 36 - ...ace.SavedObjectsIncrementCounterOptions.md | 93 - ...namespace.SavedObjectsMappingProperties.md | 11 - ...l_namespace.SavedObjectsMigrationLogger.md | 124 - ..._namespace.SavedObjectsMigrationVersion.md | 21 - ...pace.SavedObjectsOpenPointInTimeOptions.md | 54 - ...ace.SavedObjectsOpenPointInTimeResponse.md | 23 - ...nternal_namespace.SavedObjectsPitParams.md | 32 - ...e.SavedObjectsRemoveReferencesToOptions.md | 46 - ....SavedObjectsRemoveReferencesToResponse.md | 46 - ...l_namespace.SavedObjectsResolveResponse.md | 61 - ...nt._internal_namespace.SavedObjectsType.md | 212 -- ...ce.SavedObjectsTypeManagementDefinition.md | 299 --- ...space.SavedObjectsTypeMappingDefinition.md | 62 - ...e.SavedObjectsUpdateObjectsSpacesObject.md | 68 - ....SavedObjectsUpdateObjectsSpacesOptions.md | 48 - ...SavedObjectsUpdateObjectsSpacesResponse.md | 23 - ...bjectsUpdateObjectsSpacesResponseObject.md | 64 - ...nal_namespace.SavedObjectsUpdateOptions.md | 91 - ...al_namespace.SavedObjectsUpdateResponse.md | 199 -- ...nal_namespace.SavedObjectsValidationMap.md | 34 - .../client._internal_namespace.Services.md | 43 - .../client._internal_namespace.Space.md | 131 - ...._internal_namespace.SpacesServiceStart.md | 150 -- ...nt._internal_namespace.SubFeatureConfig.md | 38 - ...nal_namespace.SubFeaturePrivilegeConfig.md | 334 --- ...amespace.SubFeaturePrivilegeGroupConfig.md | 43 - .../client._internal_namespace.TaskInfo.md | 32 - ...client._internal_namespace.TaskInstance.md | 199 -- ...rnal_namespace.TaskManagerSetupContract.md | 70 - ...ternal_namespace.TaskRegisterDefinition.md | 130 - ...t._internal_namespace.TaskRunnerContext.md | 89 - ..._namespace.TranslatedUpdateAlertRequest.md | 43 - ...._internal_namespace.UpdateAlertRequest.md | 45 - .../client._internal_namespace.UpdateArgs.md | 43 - ...l_namespace.UpdateConnectorMappingsArgs.md | 64 - ...ent._internal_namespace.UpdateOptions-1.md | 54 - ...lient._internal_namespace.UpdateOptions.md | 32 - .../client._internal_namespace.User.md | 90 - .../client._internal_namespace.UserRealm.md | 32 - ...lient._internal_namespace.ValidatorType.md | 37 - .../client._internal_namespace.Verbs.md | 45 - ...._internal_namespace.CreateMappingsArgs.md | 42 - ...client._internal_namespace.MappingsArgs.md | 29 - ...._internal_namespace.UpdateMappingsArgs.md | 42 - .../configure_client.configuresubclient.md | 100 - .../metrics_client.MetricsSubClient.md | 33 - ...t._internal_namespace.CaseMetricsParams.md | 36 - .../interfaces/stats_client.statssubclient.md | 36 - ...typedoc_interfaces.ICaseResolveResponse.md | 49 - ...typedoc_interfaces.iallcommentsresponse.md | 11 - .../typedoc_interfaces.icasepostrequest.md | 91 - .../typedoc_interfaces.icaseresponse.md | 239 -- ...typedoc_interfaces.icasesconfigurepatch.md | 49 - ...pedoc_interfaces.icasesconfigurerequest.md | 49 - ...edoc_interfaces.icasesconfigureresponse.md | 145 -- .../typedoc_interfaces.icasesfindrequest.md | 148 -- .../typedoc_interfaces.icasesfindresponse.md | 93 - .../typedoc_interfaces.icasespatchrequest.md | 27 - .../typedoc_interfaces.icasesresponse.md | 11 - ...doc_interfaces.icaseuseractionsresponse.md | 11 - .../typedoc_interfaces.icommentsresponse.md | 60 - .../user_actions_client.useractionget.md | 25 - ...ser_actions_client.useractionssubclient.md | 35 - .../attachments_client._internal_namespace.md | 18 - .../modules/attachments_client.md | 13 - .../docs/cases_client/modules/cases_client.md | 9 - .../modules/cases_get._internal_namespace.md | 35 - .../docs/cases_client/modules/cases_get.md | 93 - .../docs/cases_client/modules/cases_push.md | 9 - .../modules/client._internal_namespace.md | 2213 ----------------- .../cases/docs/cases_client/modules/client.md | 13 - .../configure_client._internal_namespace.md | 13 - .../cases_client/modules/configure_client.md | 37 - .../metrics_client._internal_namespace.md | 11 - .../cases_client/modules/metrics_client.md | 13 - .../docs/cases_client/modules/stats_client.md | 9 - .../typedoc_interfaces._internal_namespace.md | 277 --- .../modules/typedoc_interfaces.md | 28 - .../modules/user_actions_client.md | 10 - .../cases/docs/cases_client_typedoc.json | 27 - 309 files changed, 29087 deletions(-) delete mode 100644 x-pack/plugins/cases/docs/README.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/.nojekyll delete mode 100644 x-pack/plugins/cases/docs/cases_client/README.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionExecutor.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionTypeRegistry.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Actions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsAuthorization.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertService.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertingActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ApiActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AppActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AttachmentService.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Authorization.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AuthorizationAuditLogger.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BasePath.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BuilderFactory.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseConfigureService.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseUserActionService.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesClientInternal.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesService.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorMappingsService.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorTokenClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ElasticsearchFeature.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaFeature.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaMigrator.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaRequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.LicenseState.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidationError.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidator.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectTypeRegistry.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsErrorHelpers.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsRepository.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SpaceActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SubFeature.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.TaskRunnerFactory.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UIActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UserActionBuilder.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/classes/client.casesclient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ActionExecutionSourceType.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.AuthorizationMode.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.CaseStatuses.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.TaskStatus.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ViewMode.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.AddArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteAllArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.FindArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllAlertsAttachToCase.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.UpdateArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client.attachmentssubclient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/cases_client.casessubclient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.casesbyalertidparams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.getparams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/cases_push.pushparams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Action.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutionSource.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutorContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeRegistryOpts.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionUpdate.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsConfigurationUtilities.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsLicenseInformation.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AggregationBuilder.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Alert.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertIdIndex.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertInfo.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertsResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AppCategory.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AttachedToCaseArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Attributes.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditEvent.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditLogger.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthFilterHelpers.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticatedUser.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticationProvider.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationMode-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationServiceSetup.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BeforeSaveContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderParameters.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderReturnValue.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateCaseDeletionUserAction.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkUpdateAttachmentArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CancellableTask.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Capabilities.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CaseCommentStats.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesClientArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesMapWithPageInfo.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivileges.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesPayload.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-2.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CommonArguments.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConcreteTaskInstance.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConnectorToken.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-2.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CountActionsAttachedToCaseArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAttachmentArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAuditMsgParams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserAction.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserActionES.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.DecoratedError.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EmbeddableRegistryDefinition.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EncryptedSavedObjectsClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureKibanaPrivileges.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureUsageServiceSetup.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindActionResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseCommentsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseConfigureArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCasesArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCommentsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindConnectorMappingsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAllSpacesOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAttachmentArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseConfigureArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseIdsByAlertIdArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseUserActionArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCasesArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetReportersArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetSpaceResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetTagsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserActionItemByDifference.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IEventLogger.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IKibanaSocket.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ILicense.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IScopedClusterClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISpacesClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IUsageCounter.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IncrementCounterParams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMapping.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMappingMeta.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IntervalSchedule.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaFeatureConfig.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorStatus.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaRequestEvents.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LegacyUrlAliasTarget.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseCheck.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseFeature.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicensingPluginSetup.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Middleware.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OperationDetails.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OwnerEntity.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCase.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCaseConfigureArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCasesArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PersistableState.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PluginStartContract.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseConfigureArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseUserActionArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostConnectorMappingsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PreConfiguredAction.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ProxySettings.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicense.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicenseJSON.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PushedArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Referencable.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ReservedKibanaPrivilege.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ResponseSettings.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptionsBody.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidationResultFactory.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorConfig.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunNowResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SSLSettings.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectAttributes.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectDoc.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectError.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationMap.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReference.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReferenceWithContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBaseOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreateOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptionsReference.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportHookResult.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMappingProperties.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationLogger.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationVersion.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsPitParams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsResolveResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsType.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeManagementDefinition.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeMappingDefinition.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsValidationMap.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Services.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Space.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SpacesServiceStart.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeatureConfig.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeConfig.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeGroupConfig.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInfo.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInstance.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskManagerSetupContract.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRegisterDefinition.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRunnerContext.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateAlertRequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateConnectorMappingsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions-1.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.User.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UserRealm.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ValidatorType.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Verbs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.CreateMappingsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.MappingsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.UpdateMappingsArgs.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/configure_client.configuresubclient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client.MetricsSubClient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client._internal_namespace.CaseMetricsParams.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/stats_client.statssubclient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.ICaseResolveResponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.iallcommentsresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasepostrequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurepatch.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurerequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigureresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindrequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasespatchrequest.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseuseractionsresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icommentsresponse.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionget.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionssubclient.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/attachments_client._internal_namespace.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/attachments_client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/cases_client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/cases_get._internal_namespace.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/cases_get.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/cases_push.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/client._internal_namespace.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/configure_client._internal_namespace.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/configure_client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/metrics_client._internal_namespace.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/metrics_client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/stats_client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces._internal_namespace.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces.md delete mode 100644 x-pack/plugins/cases/docs/cases_client/modules/user_actions_client.md delete mode 100644 x-pack/plugins/cases/docs/cases_client_typedoc.json diff --git a/x-pack/plugins/cases/docs/README.md b/x-pack/plugins/cases/docs/README.md deleted file mode 100644 index 03f089280bc57..0000000000000 --- a/x-pack/plugins/cases/docs/README.md +++ /dev/null @@ -1,42 +0,0 @@ -# Cases Client API Docs - -This directory contains generated docs using `typedoc` for the cases client API that can be called from other server -plugins. This README will describe how to generate a new version of these markdown docs in the event that new methods -or parameters are added. - -## TypeDoc Info - -See more info at: -markdown plugin: -missing exports plugin: - -## Install dependencies - -Ensure that your global typescript version is the same as kibana's - -You can run `npx tsc --version` to find the global compiler version and then check the version under `node_modules/typescript/lib`. - -```bash -yarn global add typedoc typedoc-plugin-markdown typedoc-plugin-missing-exports -``` - -## Generate the docs - -```bash -cd x-pack/plugins/cases/docs -npx typedoc --options cases_client_typedoc.json -``` - -After running the above commands the files in the `server` directory will be updated to match the new tsdocs. -If additional markdown directory should be created we can create a new typedoc configuration file and adjust the `out` -directory accordingly. - -## Troubleshooting - -If you run into tsc errors that seem unrelated to the cases plugin try executing these commands before running `typedoc` - -```bash -cd -npx yarn kbn bootstrap -node scripts/build_ts_refs.js --clean --no-cache -``` diff --git a/x-pack/plugins/cases/docs/cases_client/.nojekyll b/x-pack/plugins/cases/docs/cases_client/.nojekyll deleted file mode 100644 index e2ac6616addc2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/.nojekyll +++ /dev/null @@ -1 +0,0 @@ -TypeDoc added this file to prevent GitHub Pages from using Jekyll. You can turn off this behavior by setting the `githubPages` option to false. \ No newline at end of file diff --git a/x-pack/plugins/cases/docs/cases_client/README.md b/x-pack/plugins/cases/docs/cases_client/README.md deleted file mode 100644 index c3fa291458cca..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/README.md +++ /dev/null @@ -1,18 +0,0 @@ -Cases Client API Interface - -# Cases Client API Interface - -## Table of contents - -### Modules - -- [attachments/client](modules/attachments_client.md) -- [cases/client](modules/cases_client.md) -- [cases/get](modules/cases_get.md) -- [cases/push](modules/cases_push.md) -- [client](modules/client.md) -- [configure/client](modules/configure_client.md) -- [metrics/client](modules/metrics_client.md) -- [stats/client](modules/stats_client.md) -- [typedoc\_interfaces](modules/typedoc_interfaces.md) -- [user\_actions/client](modules/user_actions_client.md) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionExecutor.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionExecutor.md deleted file mode 100644 index 720db77a77e7e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionExecutor.md +++ /dev/null @@ -1,153 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionExecutor - -# Class: ActionExecutor - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionExecutor - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ActionExecutor.md#constructor) - -### Properties - -- [actionExecutorContext](client._internal_namespace.ActionExecutor.md#actionexecutorcontext) -- [actionInfo](client._internal_namespace.ActionExecutor.md#actioninfo) -- [isESOCanEncrypt](client._internal_namespace.ActionExecutor.md#isesocanencrypt) -- [isInitialized](client._internal_namespace.ActionExecutor.md#isinitialized) - -### Methods - -- [execute](client._internal_namespace.ActionExecutor.md#execute) -- [initialize](client._internal_namespace.ActionExecutor.md#initialize) -- [logCancellation](client._internal_namespace.ActionExecutor.md#logcancellation) - -## Constructors - -### constructor - -• **new ActionExecutor**(`__namedParameters`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.isESOCanEncrypt` | `boolean` | - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:40 - -## Properties - -### actionExecutorContext - -• `Private` `Optional` **actionExecutorContext**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:37 - -___ - -### actionInfo - -• `Private` **actionInfo**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:39 - -___ - -### isESOCanEncrypt - -• `Private` `Readonly` **isESOCanEncrypt**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:38 - -___ - -### isInitialized - -• `Private` **isInitialized**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:36 - -## Methods - -### execute - -▸ **execute**(`__namedParameters`): `Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`ExecuteOptions`](../interfaces/client._internal_namespace.ExecuteOptions.md)<`unknown`\> | - -#### Returns - -`Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`unknown`\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:44 - -___ - -### initialize - -▸ **initialize**(`actionExecutorContext`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionExecutorContext` | [`ActionExecutorContext`](../interfaces/client._internal_namespace.ActionExecutorContext.md) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:43 - -___ - -### logCancellation - -▸ **logCancellation**<`Source`\>(`__namedParameters`): `Promise`<`void`\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Source` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.actionId` | `string` | -| `__namedParameters.executionId?` | `string` | -| `__namedParameters.relatedSavedObjects` | `Readonly`<{ `namespace?`: `string` ; `typeId?`: `string` } & { `id`: `string` ; `type`: `string` }\>[] | -| `__namedParameters.request` | [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | -| `__namedParameters.source?` | [`ActionExecutionSource`](../interfaces/client._internal_namespace.ActionExecutionSource.md)<`Source`\> | -| `__namedParameters.taskInfo?` | [`TaskInfo`](../interfaces/client._internal_namespace.TaskInfo.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:45 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionTypeRegistry.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionTypeRegistry.md deleted file mode 100644 index b801bdf26a158..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionTypeRegistry.md +++ /dev/null @@ -1,288 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionTypeRegistry - -# Class: ActionTypeRegistry - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionTypeRegistry - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ActionTypeRegistry.md#constructor) - -### Properties - -- [actionTypes](client._internal_namespace.ActionTypeRegistry.md#actiontypes) -- [actionsConfigUtils](client._internal_namespace.ActionTypeRegistry.md#actionsconfigutils) -- [licenseState](client._internal_namespace.ActionTypeRegistry.md#licensestate) -- [licensing](client._internal_namespace.ActionTypeRegistry.md#licensing) -- [preconfiguredActions](client._internal_namespace.ActionTypeRegistry.md#preconfiguredactions) -- [taskManager](client._internal_namespace.ActionTypeRegistry.md#taskmanager) -- [taskRunnerFactory](client._internal_namespace.ActionTypeRegistry.md#taskrunnerfactory) - -### Methods - -- [ensureActionTypeEnabled](client._internal_namespace.ActionTypeRegistry.md#ensureactiontypeenabled) -- [get](client._internal_namespace.ActionTypeRegistry.md#get) -- [has](client._internal_namespace.ActionTypeRegistry.md#has) -- [isActionExecutable](client._internal_namespace.ActionTypeRegistry.md#isactionexecutable) -- [isActionTypeEnabled](client._internal_namespace.ActionTypeRegistry.md#isactiontypeenabled) -- [list](client._internal_namespace.ActionTypeRegistry.md#list) -- [register](client._internal_namespace.ActionTypeRegistry.md#register) - -## Constructors - -### constructor - -• **new ActionTypeRegistry**(`constructorParams`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `constructorParams` | [`ActionTypeRegistryOpts`](../interfaces/client._internal_namespace.ActionTypeRegistryOpts.md) | - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:23 - -## Properties - -### actionTypes - -• `Private` `Readonly` **actionTypes**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:17 - -___ - -### actionsConfigUtils - -• `Private` `Readonly` **actionsConfigUtils**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:19 - -___ - -### licenseState - -• `Private` `Readonly` **licenseState**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:20 - -___ - -### licensing - -• `Private` `Readonly` **licensing**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:22 - -___ - -### preconfiguredActions - -• `Private` `Readonly` **preconfiguredActions**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:21 - -___ - -### taskManager - -• `Private` `Readonly` **taskManager**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:16 - -___ - -### taskRunnerFactory - -• `Private` `Readonly` **taskRunnerFactory**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:18 - -## Methods - -### ensureActionTypeEnabled - -▸ **ensureActionTypeEnabled**(`id`): `void` - -Throws error if action type is not enabled. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `string` | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:31 - -___ - -### get - -▸ **get**<`Config`, `Secrets`, `Params`, `ExecutorResultData`\>(`id`): [`ActionType`](../interfaces/client._internal_namespace.ActionType-1.md)<`Config`, `Secrets`, `Params`, `ExecutorResultData`\> - -Returns an action type, throws if not registered - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Config` | extends [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) = [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) | -| `Secrets` | extends [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) = [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) | -| `Params` | extends [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams) = [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams) | -| `ExecutorResultData` | `void` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `string` | - -#### Returns - -[`ActionType`](../interfaces/client._internal_namespace.ActionType-1.md)<`Config`, `Secrets`, `Params`, `ExecutorResultData`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:51 - -___ - -### has - -▸ **has**(`id`): `boolean` - -Returns if the action type registry has the given action type registered - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:27 - -___ - -### isActionExecutable - -▸ **isActionExecutable**(`actionId`, `actionTypeId`, `options?`): `boolean` - -Returns true if action type is enabled or it is a preconfigured action type. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionId` | `string` | -| `actionTypeId` | `string` | -| `options?` | `Object` | -| `options.notifyUsage` | `boolean` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:41 - -___ - -### isActionTypeEnabled - -▸ **isActionTypeEnabled**(`id`, `options?`): `boolean` - -Returns true if action type is enabled in the config and a valid license is used. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `string` | -| `options?` | `Object` | -| `options.notifyUsage` | `boolean` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:35 - -___ - -### list - -▸ **list**(): [`ActionType`](../interfaces/client._internal_namespace.ActionType.md)[] - -Returns a list of registered action types [{ id, name, enabled }] - -#### Returns - -[`ActionType`](../interfaces/client._internal_namespace.ActionType.md)[] - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:55 - -___ - -### register - -▸ **register**<`Config`, `Secrets`, `Params`, `ExecutorResultData`\>(`actionType`): `void` - -Registers an action type to the action type registry - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Config` | extends [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) = [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) | -| `Secrets` | extends [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) = [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) | -| `Params` | extends [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams) = [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams) | -| `ExecutorResultData` | `void` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionType` | [`ActionType`](../interfaces/client._internal_namespace.ActionType-1.md)<`Config`, `Secrets`, `Params`, `ExecutorResultData`\> | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:47 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Actions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Actions.md deleted file mode 100644 index c05dbe40c3657..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Actions.md +++ /dev/null @@ -1,144 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Actions - -# Class: Actions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Actions - -Actions are used to create the "actions" that are associated with Elasticsearch's -application privileges, and are used to perform the authorization checks implemented -by the various `checkPrivilegesWithRequest` derivatives. - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.Actions.md#constructor) - -### Properties - -- [alerting](client._internal_namespace.Actions.md#alerting) -- [api](client._internal_namespace.Actions.md#api) -- [app](client._internal_namespace.Actions.md#app) -- [cases](client._internal_namespace.Actions.md#cases) -- [login](client._internal_namespace.Actions.md#login) -- [savedObject](client._internal_namespace.Actions.md#savedobject) -- [space](client._internal_namespace.Actions.md#space) -- [ui](client._internal_namespace.Actions.md#ui) -- [version](client._internal_namespace.Actions.md#version) -- [versionNumber](client._internal_namespace.Actions.md#versionnumber) - -## Constructors - -### constructor - -• **new Actions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:23 - -## Properties - -### alerting - -• `Readonly` **alerting**: [`AlertingActions`](client._internal_namespace.AlertingActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:19 - -___ - -### api - -• `Readonly` **api**: [`ApiActions`](client._internal_namespace.ApiActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:14 - -___ - -### app - -• `Readonly` **app**: [`AppActions`](client._internal_namespace.AppActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:15 - -___ - -### cases - -• `Readonly` **cases**: [`CasesActions`](client._internal_namespace.CasesActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:16 - -___ - -### login - -• `Readonly` **login**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:17 - -___ - -### savedObject - -• `Readonly` **savedObject**: [`SavedObjectActions`](client._internal_namespace.SavedObjectActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:18 - -___ - -### space - -• `Readonly` **space**: [`SpaceActions`](client._internal_namespace.SpaceActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:20 - -___ - -### ui - -• `Readonly` **ui**: [`UIActions`](client._internal_namespace.UIActions.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:21 - -___ - -### version - -• `Readonly` **version**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:22 - -___ - -### versionNumber - -• `Private` `Readonly` **versionNumber**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/actions.d.ts:13 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsAuthorization.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsAuthorization.md deleted file mode 100644 index eb1403431969d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsAuthorization.md +++ /dev/null @@ -1,99 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionsAuthorization - -# Class: ActionsAuthorization - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionsAuthorization - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ActionsAuthorization.md#constructor) - -### Properties - -- [authorization](client._internal_namespace.ActionsAuthorization.md#authorization) -- [authorizationMode](client._internal_namespace.ActionsAuthorization.md#authorizationmode) -- [isOperationExemptDueToLegacyRbac](client._internal_namespace.ActionsAuthorization.md#isoperationexemptduetolegacyrbac) -- [request](client._internal_namespace.ActionsAuthorization.md#request) - -### Methods - -- [ensureAuthorized](client._internal_namespace.ActionsAuthorization.md#ensureauthorized) - -## Constructors - -### constructor - -• **new ActionsAuthorization**(`__namedParameters`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`ConstructorOptions`](../interfaces/client._internal_namespace.ConstructorOptions-1.md) | - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:14 - -## Properties - -### authorization - -• `Private` `Optional` `Readonly` **authorization**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:12 - -___ - -### authorizationMode - -• `Private` `Readonly` **authorizationMode**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:13 - -___ - -### isOperationExemptDueToLegacyRbac - -• `Private` **isOperationExemptDueToLegacyRbac**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:16 - -___ - -### request - -• `Private` `Readonly` **request**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:11 - -## Methods - -### ensureAuthorized - -▸ **ensureAuthorized**(`operation`, `actionTypeId?`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `operation` | `string` | -| `actionTypeId?` | `string` | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:15 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsClient.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsClient.md deleted file mode 100644 index a566950c5fa21..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ActionsClient.md +++ /dev/null @@ -1,432 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionsClient - -# Class: ActionsClient - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionsClient - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ActionsClient.md#constructor) - -### Properties - -- [actionExecutor](client._internal_namespace.ActionsClient.md#actionexecutor) -- [actionTypeRegistry](client._internal_namespace.ActionsClient.md#actiontyperegistry) -- [auditLogger](client._internal_namespace.ActionsClient.md#auditlogger) -- [authorization](client._internal_namespace.ActionsClient.md#authorization) -- [connectorTokenClient](client._internal_namespace.ActionsClient.md#connectortokenclient) -- [defaultKibanaIndex](client._internal_namespace.ActionsClient.md#defaultkibanaindex) -- [ephemeralExecutionEnqueuer](client._internal_namespace.ActionsClient.md#ephemeralexecutionenqueuer) -- [executionEnqueuer](client._internal_namespace.ActionsClient.md#executionenqueuer) -- [preconfiguredActions](client._internal_namespace.ActionsClient.md#preconfiguredactions) -- [request](client._internal_namespace.ActionsClient.md#request) -- [scopedClusterClient](client._internal_namespace.ActionsClient.md#scopedclusterclient) -- [unsecuredSavedObjectsClient](client._internal_namespace.ActionsClient.md#unsecuredsavedobjectsclient) -- [usageCounter](client._internal_namespace.ActionsClient.md#usagecounter) - -### Methods - -- [create](client._internal_namespace.ActionsClient.md#create) -- [delete](client._internal_namespace.ActionsClient.md#delete) -- [enqueueExecution](client._internal_namespace.ActionsClient.md#enqueueexecution) -- [ephemeralEnqueuedExecution](client._internal_namespace.ActionsClient.md#ephemeralenqueuedexecution) -- [execute](client._internal_namespace.ActionsClient.md#execute) -- [get](client._internal_namespace.ActionsClient.md#get) -- [getAll](client._internal_namespace.ActionsClient.md#getall) -- [getBulk](client._internal_namespace.ActionsClient.md#getbulk) -- [isActionTypeEnabled](client._internal_namespace.ActionsClient.md#isactiontypeenabled) -- [isPreconfigured](client._internal_namespace.ActionsClient.md#ispreconfigured) -- [listTypes](client._internal_namespace.ActionsClient.md#listtypes) -- [update](client._internal_namespace.ActionsClient.md#update) - -## Constructors - -### constructor - -• **new ActionsClient**(`__namedParameters`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`ConstructorOptions`](../interfaces/client._internal_namespace.ConstructorOptions.md) | - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:57 - -## Properties - -### actionExecutor - -• `Private` `Readonly` **actionExecutor**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:49 - -___ - -### actionTypeRegistry - -• `Private` `Readonly` **actionTypeRegistry**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:47 - -___ - -### auditLogger - -• `Private` `Optional` `Readonly` **auditLogger**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:54 - -___ - -### authorization - -• `Private` `Readonly` **authorization**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:51 - -___ - -### connectorTokenClient - -• `Private` `Readonly` **connectorTokenClient**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:56 - -___ - -### defaultKibanaIndex - -• `Private` `Readonly` **defaultKibanaIndex**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:44 - -___ - -### ephemeralExecutionEnqueuer - -• `Private` `Readonly` **ephemeralExecutionEnqueuer**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:53 - -___ - -### executionEnqueuer - -• `Private` `Readonly` **executionEnqueuer**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:52 - -___ - -### preconfiguredActions - -• `Private` `Readonly` **preconfiguredActions**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:48 - -___ - -### request - -• `Private` `Readonly` **request**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:50 - -___ - -### scopedClusterClient - -• `Private` `Readonly` **scopedClusterClient**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:45 - -___ - -### unsecuredSavedObjectsClient - -• `Private` `Readonly` **unsecuredSavedObjectsClient**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:46 - -___ - -### usageCounter - -• `Private` `Optional` `Readonly` **usageCounter**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:55 - -## Methods - -### create - -▸ **create**(`__namedParameters`): `Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>\> - -Create an action - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CreateOptions`](../interfaces/client._internal_namespace.CreateOptions.md) | - -#### Returns - -`Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:61 - -___ - -### delete - -▸ **delete**(`__namedParameters`): `Promise`<{}\> - -Delete action - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.id` | `string` | - -#### Returns - -`Promise`<{}\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:83 - -___ - -### enqueueExecution - -▸ **enqueueExecution**(`options`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `options` | [`ExecuteOptions`](../interfaces/client._internal_namespace.ExecuteOptions-1.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:87 - -___ - -### ephemeralEnqueuedExecution - -▸ **ephemeralEnqueuedExecution**(`options`): `Promise`<[`RunNowResult`](../interfaces/client._internal_namespace.RunNowResult.md)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `options` | [`ExecuteOptions`](../interfaces/client._internal_namespace.ExecuteOptions-1.md) | - -#### Returns - -`Promise`<[`RunNowResult`](../interfaces/client._internal_namespace.RunNowResult.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:88 - -___ - -### execute - -▸ **execute**(`__namedParameters`): `Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Omit`<[`ExecuteOptions`](../interfaces/client._internal_namespace.ExecuteOptions.md)<`unknown`\>, ``"request"``\> | - -#### Returns - -`Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`unknown`\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:86 - -___ - -### get - -▸ **get**(`__namedParameters`): `Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>\> - -Get an action - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.id` | `string` | - -#### Returns - -`Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:69 - -___ - -### getAll - -▸ **getAll**(): `Promise`<[`FindActionResult`](../interfaces/client._internal_namespace.FindActionResult.md)[]\> - -Get all actions with preconfigured list - -#### Returns - -`Promise`<[`FindActionResult`](../interfaces/client._internal_namespace.FindActionResult.md)[]\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:75 - -___ - -### getBulk - -▸ **getBulk**(`ids`): `Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>[]\> - -Get bulk actions with preconfigured list - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `ids` | `string`[] | - -#### Returns - -`Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>[]\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:79 - -___ - -### isActionTypeEnabled - -▸ **isActionTypeEnabled**(`actionTypeId`, `options?`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionTypeId` | `string` | -| `options?` | `Object` | -| `options.notifyUsage` | `boolean` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:90 - -___ - -### isPreconfigured - -▸ **isPreconfigured**(`connectorId`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `connectorId` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:93 - -___ - -### listTypes - -▸ **listTypes**(): `Promise`<[`ActionType`](../interfaces/client._internal_namespace.ActionType.md)[]\> - -#### Returns - -`Promise`<[`ActionType`](../interfaces/client._internal_namespace.ActionType.md)[]\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:89 - -___ - -### update - -▸ **update**(`__namedParameters`): `Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>\> - -Update action - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`UpdateOptions`](../interfaces/client._internal_namespace.UpdateOptions.md) | - -#### Returns - -`Promise`<[`ActionResult`](../interfaces/client._internal_namespace.ActionResult.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig)\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:65 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertService.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertService.md deleted file mode 100644 index b231fddac4c61..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertService.md +++ /dev/null @@ -1,206 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AlertService - -# Class: AlertService - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AlertService - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.AlertService.md#constructor) - -### Methods - -- [bucketAlertsByIndexAndStatus](client._internal_namespace.AlertService.md#bucketalertsbyindexandstatus) -- [executeAggregations](client._internal_namespace.AlertService.md#executeaggregations) -- [getAlerts](client._internal_namespace.AlertService.md#getalerts) -- [translateStatus](client._internal_namespace.AlertService.md#translatestatus) -- [updateAlertsStatus](client._internal_namespace.AlertService.md#updatealertsstatus) -- [updateByQuery](client._internal_namespace.AlertService.md#updatebyquery) -- [getUniqueIdsIndices](client._internal_namespace.AlertService.md#getuniqueidsindices) -- [isEmptyAlert](client._internal_namespace.AlertService.md#isemptyalert) - -## Constructors - -### constructor - -• **new AlertService**(`scopedClusterClient`, `logger`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `scopedClusterClient` | [`ElasticsearchClient`](../modules/client._internal_namespace.md#elasticsearchclient) | -| `logger` | `Logger` | - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:24](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L24) - -## Methods - -### bucketAlertsByIndexAndStatus - -▸ `Private` **bucketAlertsByIndexAndStatus**(`alerts`): `Map`<`string`, `Map`<`STATUS_VALUES`, [`TranslatedUpdateAlertRequest`](../interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md)[]\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alerts` | [`UpdateAlertRequest`](../interfaces/client._internal_namespace.UpdateAlertRequest.md)[] | - -#### Returns - -`Map`<`string`, `Map`<`STATUS_VALUES`, [`TranslatedUpdateAlertRequest`](../interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md)[]\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:98](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L98) - -___ - -### executeAggregations - -▸ **executeAggregations**(`__namedParameters`): `Promise`<[`AggregationResponse`](../modules/client._internal_namespace.md#aggregationresponse)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.aggregationBuilders` | [`AggregationBuilder`](../interfaces/client._internal_namespace.AggregationBuilder.md)[] | -| `__namedParameters.alerts` | [`AlertIdIndex`](../interfaces/client._internal_namespace.AlertIdIndex.md)[] | - -#### Returns - -`Promise`<[`AggregationResponse`](../modules/client._internal_namespace.md#aggregationresponse)\> - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:29](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L29) - -___ - -### getAlerts - -▸ **getAlerts**(`alertsInfo`): `Promise`<`undefined` \| [`AlertsResponse`](../interfaces/client._internal_namespace.AlertsResponse.md)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alertsInfo` | [`AlertInfo`](../interfaces/client._internal_namespace.AlertInfo.md)[] | - -#### Returns - -`Promise`<`undefined` \| [`AlertsResponse`](../interfaces/client._internal_namespace.AlertsResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:182](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L182) - -___ - -### translateStatus - -▸ `Private` **translateStatus**(`alert`): `STATUS_VALUES` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alert` | [`UpdateAlertRequest`](../interfaces/client._internal_namespace.UpdateAlertRequest.md) | - -#### Returns - -`STATUS_VALUES` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:133](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L133) - -___ - -### updateAlertsStatus - -▸ **updateAlertsStatus**(`alerts`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alerts` | [`UpdateAlertRequest`](../interfaces/client._internal_namespace.UpdateAlertRequest.md)[] | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:78](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L78) - -___ - -### updateByQuery - -▸ `Private` **updateByQuery**(`__namedParameters`): `Promise`<`TransportResult`<`UpdateByQueryResponse`, `unknown`\>[]\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`string`, `Map`<`STATUS_VALUES`, [`TranslatedUpdateAlertRequest`](../interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md)[]\>] | - -#### Returns - -`Promise`<`TransportResult`<`UpdateByQueryResponse`, `unknown`\>[]\> - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:151](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L151) - -___ - -### getUniqueIdsIndices - -▸ `Static` `Private` **getUniqueIdsIndices**(`alerts`): `Object` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alerts` | [`AlertIdIndex`](../interfaces/client._internal_namespace.AlertIdIndex.md)[] | - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `ids` | `string`[] | -| `indices` | `string`[] | - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:62](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L62) - -___ - -### isEmptyAlert - -▸ `Static` `Private` **isEmptyAlert**(`alert`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alert` | [`AlertInfo`](../interfaces/client._internal_namespace.AlertInfo.md) | - -#### Returns - -`boolean` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:129](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L129) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertingActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertingActions.md deleted file mode 100644 index 6b45ea9b28110..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AlertingActions.md +++ /dev/null @@ -1,68 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AlertingActions - -# Class: AlertingActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AlertingActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.AlertingActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.AlertingActions.md#prefix) - -### Methods - -- [get](client._internal_namespace.AlertingActions.md#get) - -## Constructors - -### constructor - -• **new AlertingActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/alerting.d.ts:3 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/alerting.d.ts:2 - -## Methods - -### get - -▸ **get**(`ruleTypeId`, `consumer`, `alertingEntity`, `operation`): `string` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `ruleTypeId` | `string` | -| `consumer` | `string` | -| `alertingEntity` | `string` | -| `operation` | `string` | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/alerting.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ApiActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ApiActions.md deleted file mode 100644 index a7e6c51d4a649..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ApiActions.md +++ /dev/null @@ -1,65 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ApiActions - -# Class: ApiActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ApiActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ApiActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.ApiActions.md#prefix) - -### Methods - -- [get](client._internal_namespace.ApiActions.md#get) - -## Constructors - -### constructor - -• **new ApiActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/api.d.ts:3 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/api.d.ts:2 - -## Methods - -### get - -▸ **get**(`operation`): `string` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `operation` | `string` | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/api.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AppActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AppActions.md deleted file mode 100644 index 76fbfc84021c5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AppActions.md +++ /dev/null @@ -1,65 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AppActions - -# Class: AppActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AppActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.AppActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.AppActions.md#prefix) - -### Methods - -- [get](client._internal_namespace.AppActions.md#get) - -## Constructors - -### constructor - -• **new AppActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/app.d.ts:3 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/app.d.ts:2 - -## Methods - -### get - -▸ **get**(`appId`): `string` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `appId` | `string` | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/app.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AttachmentService.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AttachmentService.md deleted file mode 100644 index 064f9cf9567b3..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AttachmentService.md +++ /dev/null @@ -1,217 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AttachmentService - -# Class: AttachmentService - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AttachmentService - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.AttachmentService.md#constructor) - -### Methods - -- [buildCountAlertsAggs](client._internal_namespace.AttachmentService.md#buildcountalertsaggs) -- [bulkUpdate](client._internal_namespace.AttachmentService.md#bulkupdate) -- [countAlertsAttachedToCase](client._internal_namespace.AttachmentService.md#countalertsattachedtocase) -- [create](client._internal_namespace.AttachmentService.md#create) -- [delete](client._internal_namespace.AttachmentService.md#delete) -- [executeCaseActionsAggregations](client._internal_namespace.AttachmentService.md#executecaseactionsaggregations) -- [get](client._internal_namespace.AttachmentService.md#get) -- [getAllAlertsAttachToCase](client._internal_namespace.AttachmentService.md#getallalertsattachtocase) -- [update](client._internal_namespace.AttachmentService.md#update) - -## Constructors - -### constructor - -• **new AttachmentService**(`log`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `log` | `Logger` | - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:66](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L66) - -## Methods - -### buildCountAlertsAggs - -▸ `Private` **buildCountAlertsAggs**(): `Record`<`string`, `AggregationsAggregationContainer`\> - -#### Returns - -`Record`<`string`, `AggregationsAggregationContainer`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:104](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L104) - -___ - -### bulkUpdate - -▸ **bulkUpdate**(`__namedParameters`): `Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`BulkUpdateAttachmentArgs`](../interfaces/client._internal_namespace.BulkUpdateAttachmentArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:262](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L262) - -___ - -### countAlertsAttachedToCase - -▸ **countAlertsAttachedToCase**(`__namedParameters`): `Promise`<`undefined` \| `number`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`AttachedToCaseArgs`](../interfaces/client._internal_namespace.AttachedToCaseArgs.md) | - -#### Returns - -`Promise`<`undefined` \| `number`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:68](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L68) - -___ - -### create - -▸ **create**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CreateAttachmentArgs`](../interfaces/client._internal_namespace.CreateAttachmentArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:220](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L220) - -___ - -### delete - -▸ **delete**(`__namedParameters`): `Promise`<{}\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetAttachmentArgs`](../interfaces/client._internal_namespace.GetAttachmentArgs.md) | - -#### Returns - -`Promise`<{}\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:210](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L210) - -___ - -### executeCaseActionsAggregations - -▸ **executeCaseActionsAggregations**(`__namedParameters`): `Promise`<[`AggregationResponse`](../modules/client._internal_namespace.md#aggregationresponse)\> - -Executes the aggregations against the actions attached to a case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CountActionsAttachedToCaseArgs`](../interfaces/client._internal_namespace.CountActionsAttachedToCaseArgs.md) | - -#### Returns - -`Promise`<[`AggregationResponse`](../modules/client._internal_namespace.md#aggregationresponse)\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:157](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L157) - -___ - -### get - -▸ **get**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetAttachmentArgs`](../interfaces/client._internal_namespace.GetAttachmentArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:194](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L194) - -___ - -### getAllAlertsAttachToCase - -▸ **getAllAlertsAttachToCase**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>[]\> - -Retrieves all the alerts attached to a case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`AttachedToCaseArgs`](../interfaces/client._internal_namespace.AttachedToCaseArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>[]\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:117](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L117) - -___ - -### update - -▸ **update**(`__namedParameters`): `Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`UpdateAttachmentArgs`](../modules/client._internal_namespace.md#updateattachmentargs) | - -#### Returns - -`Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:242](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L242) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Authorization.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Authorization.md deleted file mode 100644 index 7c09e59f2216a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.Authorization.md +++ /dev/null @@ -1,241 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Authorization - -# Class: Authorization - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Authorization - -This class handles ensuring that the user making a request has the correct permissions -for the API request. - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.Authorization.md#constructor) - -### Properties - -- [auditLogger](client._internal_namespace.Authorization.md#auditlogger) -- [featureCaseOwners](client._internal_namespace.Authorization.md#featurecaseowners) -- [request](client._internal_namespace.Authorization.md#request) -- [securityAuth](client._internal_namespace.Authorization.md#securityauth) - -### Methods - -- [\_ensureAuthorized](client._internal_namespace.Authorization.md#_ensureauthorized) -- [\_getAuthorizationFilter](client._internal_namespace.Authorization.md#_getauthorizationfilter) -- [ensureAuthorized](client._internal_namespace.Authorization.md#ensureauthorized) -- [getAuthorizationFilter](client._internal_namespace.Authorization.md#getauthorizationfilter) -- [getAuthorizedOwners](client._internal_namespace.Authorization.md#getauthorizedowners) -- [shouldCheckAuthorization](client._internal_namespace.Authorization.md#shouldcheckauthorization) -- [create](client._internal_namespace.Authorization.md#create) - -## Constructors - -### constructor - -• `Private` **new Authorization**(`__namedParameters`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.auditLogger` | [`AuthorizationAuditLogger`](client._internal_namespace.AuthorizationAuditLogger.md) | -| `__namedParameters.caseOwners` | `Set`<`string`\> | -| `__namedParameters.request` | [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | -| `__namedParameters.securityAuth?` | [`AuthorizationServiceSetup`](../interfaces/client._internal_namespace.AuthorizationServiceSetup.md) | - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:27](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L27) - -## Properties - -### auditLogger - -• `Private` `Readonly` **auditLogger**: [`AuthorizationAuditLogger`](client._internal_namespace.AuthorizationAuditLogger.md) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L25) - -___ - -### featureCaseOwners - -• `Private` `Readonly` **featureCaseOwners**: `Set`<`string`\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:24](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L24) - -___ - -### request - -• `Private` `Readonly` **request**: [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:22](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L22) - -___ - -### securityAuth - -• `Private` `Readonly` **securityAuth**: `undefined` \| [`AuthorizationServiceSetup`](../interfaces/client._internal_namespace.AuthorizationServiceSetup.md) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:23](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L23) - -## Methods - -### \_ensureAuthorized - -▸ `Private` **_ensureAuthorized**(`owners`, `operation`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `owners` | `string`[] | -| `operation` | [`OperationDetails`](../interfaces/client._internal_namespace.OperationDetails.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:135](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L135) - -___ - -### \_getAuthorizationFilter - -▸ `Private` **_getAuthorizationFilter**(`operation`): `Promise`<[`AuthFilterHelpers`](../interfaces/client._internal_namespace.AuthFilterHelpers.md)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `operation` | [`OperationDetails`](../interfaces/client._internal_namespace.OperationDetails.md) | - -#### Returns - -`Promise`<[`AuthFilterHelpers`](../interfaces/client._internal_namespace.AuthFilterHelpers.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:170](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L170) - -___ - -### ensureAuthorized - -▸ **ensureAuthorized**(`__namedParameters`): `Promise`<`void`\> - -Checks that the user making the request for the passed in owners and operation has the correct authorization. This -function will throw if the user is not authorized for the requested operation and owners. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.entities` | [`OwnerEntity`](../interfaces/client._internal_namespace.OwnerEntity.md)[] | -| `__namedParameters.operation` | [`OperationDetails`](../interfaces/client._internal_namespace.OperationDetails.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:97](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L97) - -___ - -### getAuthorizationFilter - -▸ **getAuthorizationFilter**(`operation`): `Promise`<[`AuthFilterHelpers`](../interfaces/client._internal_namespace.AuthFilterHelpers.md)\> - -Returns an object to filter the saved object find request to the authorized owners of an entity. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `operation` | [`OperationDetails`](../interfaces/client._internal_namespace.OperationDetails.md) | - -#### Returns - -`Promise`<[`AuthFilterHelpers`](../interfaces/client._internal_namespace.AuthFilterHelpers.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:126](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L126) - -___ - -### getAuthorizedOwners - -▸ `Private` **getAuthorizedOwners**(`operations`): `Promise`<{ `authorizedOwners`: `string`[] ; `hasAllRequested`: `boolean` ; `username?`: `string` }\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `operations` | [`OperationDetails`](../interfaces/client._internal_namespace.OperationDetails.md)[] | - -#### Returns - -`Promise`<{ `authorizedOwners`: `string`[] ; `hasAllRequested`: `boolean` ; `username?`: `string` }\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:207](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L207) - -___ - -### shouldCheckAuthorization - -▸ `Private` **shouldCheckAuthorization**(): `boolean` - -#### Returns - -`boolean` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:85](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L85) - -___ - -### create - -▸ `Static` **create**(`__namedParameters`): `Promise`<[`Authorization`](client._internal_namespace.Authorization.md)\> - -Creates an Authorization object. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.auditLogger` | [`AuthorizationAuditLogger`](client._internal_namespace.AuthorizationAuditLogger.md) | -| `__namedParameters.features` | [`PluginStartContract`](../interfaces/client._internal_namespace.PluginStartContract.md) | -| `__namedParameters.getSpace` | [`GetSpaceFn`](../modules/client._internal_namespace.md#getspacefn) | -| `__namedParameters.logger` | `Logger` | -| `__namedParameters.request` | [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | -| `__namedParameters.securityAuth?` | [`AuthorizationServiceSetup`](../interfaces/client._internal_namespace.AuthorizationServiceSetup.md) | - -#### Returns - -`Promise`<[`Authorization`](client._internal_namespace.Authorization.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/authorization.ts:47](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/authorization.ts#L47) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AuthorizationAuditLogger.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AuthorizationAuditLogger.md deleted file mode 100644 index 5f80d4d21f4b2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.AuthorizationAuditLogger.md +++ /dev/null @@ -1,117 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthorizationAuditLogger - -# Class: AuthorizationAuditLogger - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthorizationAuditLogger - -Audit logger for authorization operations - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.AuthorizationAuditLogger.md#constructor) - -### Properties - -- [auditLogger](client._internal_namespace.AuthorizationAuditLogger.md#auditlogger) - -### Methods - -- [log](client._internal_namespace.AuthorizationAuditLogger.md#log) -- [createAuditMsg](client._internal_namespace.AuthorizationAuditLogger.md#createauditmsg) -- [createFailureMessage](client._internal_namespace.AuthorizationAuditLogger.md#createfailuremessage) - -## Constructors - -### constructor - -• **new AuthorizationAuditLogger**(`logger?`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `logger?` | [`AuditLogger`](../interfaces/client._internal_namespace.AuditLogger.md) | - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L25) - -## Properties - -### auditLogger - -• `Private` `Optional` `Readonly` **auditLogger**: [`AuditLogger`](../interfaces/client._internal_namespace.AuditLogger.md) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:23](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L23) - -## Methods - -### log - -▸ **log**(`auditMsgParams`): `void` - -Logs an audit event based on the status of an operation. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `auditMsgParams` | [`CreateAuditMsgParams`](../interfaces/client._internal_namespace.CreateAuditMsgParams.md) | - -#### Returns - -`void` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:98](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L98) - -___ - -### createAuditMsg - -▸ `Static` `Private` **createAuditMsg**(`__namedParameters`): [`AuditEvent`](../interfaces/client._internal_namespace.AuditEvent.md) - -Creates an AuditEvent describing the state of a request. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CreateAuditMsgParams`](../interfaces/client._internal_namespace.CreateAuditMsgParams.md) | - -#### Returns - -[`AuditEvent`](../interfaces/client._internal_namespace.AuditEvent.md) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:32](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L32) - -___ - -### createFailureMessage - -▸ `Static` **createFailureMessage**(`__namedParameters`): `string` - -Creates a message to be passed to an Error or Boom. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.operation` | [`OperationDetails`](../interfaces/client._internal_namespace.OperationDetails.md) | -| `__namedParameters.owners` | `string`[] | - -#### Returns - -`string` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L79) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BasePath.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BasePath.md deleted file mode 100644 index 50d50b457bfea..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BasePath.md +++ /dev/null @@ -1,189 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BasePath - -# Class: BasePath - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BasePath - -Access or manipulate the Kibana base path - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.BasePath.md#constructor) - -### Properties - -- [basePathCache](client._internal_namespace.BasePath.md#basepathcache) -- [get](client._internal_namespace.BasePath.md#get) -- [prepend](client._internal_namespace.BasePath.md#prepend) -- [publicBaseUrl](client._internal_namespace.BasePath.md#publicbaseurl) -- [remove](client._internal_namespace.BasePath.md#remove) -- [serverBasePath](client._internal_namespace.BasePath.md#serverbasepath) -- [set](client._internal_namespace.BasePath.md#set) - -## Constructors - -### constructor - -• **new BasePath**(`serverBasePath?`, `publicBaseUrl?`) - -**`internal`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `serverBasePath?` | `string` | -| `publicBaseUrl?` | `string` | - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:24 - -## Properties - -### basePathCache - -• `Private` `Readonly` **basePathCache**: `any` - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:8 - -___ - -### get - -• **get**: (`request`: [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\>) => `string` - -#### Type declaration - -▸ (`request`): `string` - -returns `basePath` value, specific for an incoming request. - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | - -##### Returns - -`string` - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:28 - -___ - -### prepend - -• **prepend**: (`path`: `string`) => `string` - -#### Type declaration - -▸ (`path`): `string` - -Prepends `path` with the basePath. - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `path` | `string` | - -##### Returns - -`string` - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:38 - -___ - -### publicBaseUrl - -• `Optional` `Readonly` **publicBaseUrl**: `string` - -The server's publicly exposed base URL, if configured. Includes protocol, host, port (optional) and the -[BasePath.serverBasePath](client._internal_namespace.BasePath.md#serverbasepath). - -**`remarks`** -Should be used for generating external URL links back to this Kibana instance. - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:22 - -___ - -### remove - -• **remove**: (`path`: `string`) => `string` - -#### Type declaration - -▸ (`path`): `string` - -Removes the prepended basePath from the `path`. - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `path` | `string` | - -##### Returns - -`string` - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:42 - -___ - -### serverBasePath - -• `Readonly` **serverBasePath**: `string` - -returns the server's basePath - -See [BasePath.get](client._internal_namespace.BasePath.md#get) for getting the basePath value for a specific request - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:14 - -___ - -### set - -• **set**: (`request`: [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\>, `requestSpecificBasePath`: `string`) => `void` - -#### Type declaration - -▸ (`request`, `requestSpecificBasePath`): `void` - -sets `basePath` value, specific for an incoming request. - -**`privateremarks`** should work only for KibanaRequest as soon as spaces migrate to NP - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | -| `requestSpecificBasePath` | `string` | - -##### Returns - -`void` - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:34 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BuilderFactory.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BuilderFactory.md deleted file mode 100644 index a6f48bc77918b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.BuilderFactory.md +++ /dev/null @@ -1,47 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BuilderFactory - -# Class: BuilderFactory - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BuilderFactory - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.BuilderFactory.md#constructor) - -### Methods - -- [getBuilder](client._internal_namespace.BuilderFactory.md#getbuilder) - -## Constructors - -### constructor - -• **new BuilderFactory**() - -## Methods - -### getBuilder - -▸ **getBuilder**<`T`\>(`type`): `undefined` \| [`UserActionBuilder`](client._internal_namespace.UserActionBuilder.md) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | extends ``"description"`` \| ``"tags"`` \| ``"title"`` \| ``"connector"`` \| ``"settings"`` \| ``"status"`` \| ``"comment"`` \| ``"pushed"`` \| ``"create_case"`` \| ``"delete_case"`` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `T` | - -#### Returns - -`undefined` \| [`UserActionBuilder`](client._internal_namespace.UserActionBuilder.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/builder_factory.ts:35](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/builder_factory.ts#L35) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseConfigureService.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseConfigureService.md deleted file mode 100644 index bf61548e826ce..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseConfigureService.md +++ /dev/null @@ -1,135 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CaseConfigureService - -# Class: CaseConfigureService - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CaseConfigureService - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.CaseConfigureService.md#constructor) - -### Methods - -- [delete](client._internal_namespace.CaseConfigureService.md#delete) -- [find](client._internal_namespace.CaseConfigureService.md#find) -- [get](client._internal_namespace.CaseConfigureService.md#get) -- [patch](client._internal_namespace.CaseConfigureService.md#patch) -- [post](client._internal_namespace.CaseConfigureService.md#post) - -## Constructors - -### constructor - -• **new CaseConfigureService**(`log`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `log` | `Logger` | - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:52](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L52) - -## Methods - -### delete - -▸ **delete**(`__namedParameters`): `Promise`<{}\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseConfigureArgs`](../interfaces/client._internal_namespace.GetCaseConfigureArgs.md) | - -#### Returns - -`Promise`<{}\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:54](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L54) - -___ - -### find - -▸ **find**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`FindCaseConfigureArgs`](../interfaces/client._internal_namespace.FindCaseConfigureArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:82](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L82) - -___ - -### get - -▸ **get**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseConfigureArgs`](../interfaces/client._internal_namespace.GetCaseConfigureArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:64](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L64) - -___ - -### patch - -▸ **patch**(`__namedParameters`): `Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `closure_type`: `undefined` \| ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: `undefined` \| { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = CaseConnectorRt } & { `version`: `string` = rt.string }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PatchCaseConfigureArgs`](../interfaces/client._internal_namespace.PatchCaseConfigureArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `closure_type`: `undefined` \| ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: `undefined` \| { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = CaseConnectorRt } & { `version`: `string` = rt.string }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:125](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L125) - -___ - -### post - -▸ **post**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PostCaseConfigureArgs`](../interfaces/client._internal_namespace.PostCaseConfigureArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:104](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L104) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseUserActionService.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseUserActionService.md deleted file mode 100644 index ed34d0f5389b7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CaseUserActionService.md +++ /dev/null @@ -1,304 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CaseUserActionService - -# Class: CaseUserActionService - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CaseUserActionService - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.CaseUserActionService.md#constructor) - -### Properties - -- [builderFactory](client._internal_namespace.CaseUserActionService.md#builderfactory) -- [userActionFieldsAllowed](client._internal_namespace.CaseUserActionService.md#useractionfieldsallowed) - -### Methods - -- [buildCountConnectorsAggs](client._internal_namespace.CaseUserActionService.md#buildcountconnectorsaggs) -- [bulkCreate](client._internal_namespace.CaseUserActionService.md#bulkcreate) -- [bulkCreateAttachmentDeletion](client._internal_namespace.CaseUserActionService.md#bulkcreateattachmentdeletion) -- [bulkCreateCaseDeletion](client._internal_namespace.CaseUserActionService.md#bulkcreatecasedeletion) -- [bulkCreateUpdateCase](client._internal_namespace.CaseUserActionService.md#bulkcreateupdatecase) -- [create](client._internal_namespace.CaseUserActionService.md#create) -- [createUserAction](client._internal_namespace.CaseUserActionService.md#createuseraction) -- [findStatusChanges](client._internal_namespace.CaseUserActionService.md#findstatuschanges) -- [getAll](client._internal_namespace.CaseUserActionService.md#getall) -- [getUniqueConnectors](client._internal_namespace.CaseUserActionService.md#getuniqueconnectors) -- [getUserActionItemByDifference](client._internal_namespace.CaseUserActionService.md#getuseractionitembydifference) - -## Constructors - -### constructor - -• **new CaseUserActionService**(`log`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `log` | `Logger` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:106](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L106) - -## Properties - -### builderFactory - -• `Private` `Readonly` **builderFactory**: [`BuilderFactory`](client._internal_namespace.BuilderFactory.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:104](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L104) - -___ - -### userActionFieldsAllowed - -▪ `Static` `Private` `Readonly` **userActionFieldsAllowed**: `Set`<`string`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:102](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L102) - -## Methods - -### buildCountConnectorsAggs - -▸ `Private` **buildCountConnectorsAggs**(`size?`): `Record`<`string`, `AggregationsAggregationContainer`\> - -#### Parameters - -| Name | Type | Default value | -| :------ | :------ | :------ | -| `size` | `number` | `100` | - -#### Returns - -`Record`<`string`, `AggregationsAggregationContainer`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:470](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L470) - -___ - -### bulkCreate - -▸ **bulkCreate**(`__namedParameters`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PostCaseUserActionArgs`](../interfaces/client._internal_namespace.PostCaseUserActionArgs.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:352](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L352) - -___ - -### bulkCreateAttachmentDeletion - -▸ **bulkCreateAttachmentDeletion**(`__namedParameters`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`BulkCreateAttachmentDeletionUserAction`](../interfaces/client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:244](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L244) - -___ - -### bulkCreateCaseDeletion - -▸ **bulkCreateCaseDeletion**(`__namedParameters`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`BulkCreateCaseDeletionUserAction`](../interfaces/client._internal_namespace.BulkCreateCaseDeletionUserAction.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:171](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L171) - -___ - -### bulkCreateUpdateCase - -▸ **bulkCreateUpdateCase**(`__namedParameters`): `Promise`<`void`\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`BulkCreateBulkUpdateCaseUserActions`](../interfaces/client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:198](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L198) - -___ - -### create - -▸ **create**<`T`\>(`__namedParameters`): `Promise`<`void`\> - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CreateUserActionES`](../interfaces/client._internal_namespace.CreateUserActionES.md)<`T`\> | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:335](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L335) - -___ - -### createUserAction - -▸ **createUserAction**<`T`\>(`__namedParameters`): `Promise`<`void`\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | extends keyof [`BuilderParameters`](../interfaces/client._internal_namespace.BuilderParameters.md) | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CreateUserActionClient`](../modules/client._internal_namespace.md#createuseractionclient)<`T`\> | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:275](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L275) - -___ - -### findStatusChanges - -▸ **findStatusChanges**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `payload`: { description: string; } = DescriptionUserActionPayloadRt; `type`: ``"description"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { comment: { comment: string; type: CommentType.user; owner: string; } \| { type: CommentType.alert; alertId: string \| string[]; index: string \| string[]; rule: { id: string \| null; name: string \| null; }; owner: string; } \| { ...; }; } = CommentUserActionPayloadRt; `type`: ``"comment"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { tags: string[]; } = TagsUserActionPayloadRt; `type`: ``"tags"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { title: string; } = TitleUserActionPayloadRt; `type`: ``"title"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { settings: { syncAlerts: boolean; }; } = SettingsUserActionPayloadRt; `type`: ``"settings"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { status: CaseStatuses; } = StatusUserActionPayloadRt; `type`: ``"status"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `type`: ``"create_case"`` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } & { description: string; status: string; tags: string[]; title: string; settings: { syncAlerts: boolean; }; owner: string; } } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } = ConnectorUserActionPayloadRt; `type`: ``"connector"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { externalService: { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| ... 1 more ... \| undefined; username: string \| ... 1 more ... \| undefined; }; }; } = PushedUserActionPayloadRt; `type`: ``"pushed"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: {} ; `type`: ``"delete_case"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` }\>[]\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.caseId` | `string` | -| `__namedParameters.filter?` | `KueryNode` | -| `__namedParameters.unsecuredSavedObjectsClient` | [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `payload`: { description: string; } = DescriptionUserActionPayloadRt; `type`: ``"description"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { comment: { comment: string; type: CommentType.user; owner: string; } \| { type: CommentType.alert; alertId: string \| string[]; index: string \| string[]; rule: { id: string \| null; name: string \| null; }; owner: string; } \| { ...; }; } = CommentUserActionPayloadRt; `type`: ``"comment"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { tags: string[]; } = TagsUserActionPayloadRt; `type`: ``"tags"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { title: string; } = TitleUserActionPayloadRt; `type`: ``"title"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { settings: { syncAlerts: boolean; }; } = SettingsUserActionPayloadRt; `type`: ``"settings"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { status: CaseStatuses; } = StatusUserActionPayloadRt; `type`: ``"status"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `type`: ``"create_case"`` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } & { description: string; status: string; tags: string[]; title: string; settings: { syncAlerts: boolean; }; owner: string; } } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } = ConnectorUserActionPayloadRt; `type`: ``"connector"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { externalService: { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| ... 1 more ... \| undefined; username: string \| ... 1 more ... \| undefined; }; }; } = PushedUserActionPayloadRt; `type`: ``"pushed"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: {} ; `type`: ``"delete_case"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` }\>[]\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:372](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L372) - -___ - -### getAll - -▸ **getAll**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `payload`: { description: string; } = DescriptionUserActionPayloadRt; `type`: ``"description"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { comment: { comment: string; type: CommentType.user; owner: string; } \| { type: CommentType.alert; alertId: string \| string[]; index: string \| string[]; rule: { id: string \| null; name: string \| null; }; owner: string; } \| { ...; }; } = CommentUserActionPayloadRt; `type`: ``"comment"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { tags: string[]; } = TagsUserActionPayloadRt; `type`: ``"tags"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { title: string; } = TitleUserActionPayloadRt; `type`: ``"title"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { settings: { syncAlerts: boolean; }; } = SettingsUserActionPayloadRt; `type`: ``"settings"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { status: CaseStatuses; } = StatusUserActionPayloadRt; `type`: ``"status"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `type`: ``"create_case"`` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } & { description: string; status: string; tags: string[]; title: string; settings: { syncAlerts: boolean; }; owner: string; } } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } = ConnectorUserActionPayloadRt; `type`: ``"connector"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { externalService: { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| ... 1 more ... \| undefined; username: string \| ... 1 more ... \| undefined; }; }; } = PushedUserActionPayloadRt; `type`: ``"pushed"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: {} ; `type`: ``"delete_case"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` }, `unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseUserActionArgs`](../interfaces/client._internal_namespace.GetCaseUserActionArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `payload`: { description: string; } = DescriptionUserActionPayloadRt; `type`: ``"description"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { comment: { comment: string; type: CommentType.user; owner: string; } \| { type: CommentType.alert; alertId: string \| string[]; index: string \| string[]; rule: { id: string \| null; name: string \| null; }; owner: string; } \| { ...; }; } = CommentUserActionPayloadRt; `type`: ``"comment"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { tags: string[]; } = TagsUserActionPayloadRt; `type`: ``"tags"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { title: string; } = TitleUserActionPayloadRt; `type`: ``"title"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { settings: { syncAlerts: boolean; }; } = SettingsUserActionPayloadRt; `type`: ``"settings"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { status: CaseStatuses; } = StatusUserActionPayloadRt; `type`: ``"status"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `type`: ``"create_case"`` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } & { description: string; status: string; tags: string[]; title: string; settings: { syncAlerts: boolean; }; owner: string; } } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; }) \| ... 4 more ... \| ({ ...; } & { ...; })); } = ConnectorUserActionPayloadRt; `type`: ``"connector"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: { externalService: { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| ... 1 more ... \| undefined; username: string \| ... 1 more ... \| undefined; }; }; } = PushedUserActionPayloadRt; `type`: ``"pushed"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` } & { `payload`: {} ; `type`: ``"delete_case"`` } & { `action`: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` = ActionsRt; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string } & { `action_id`: `string` = rt.string; `case_id`: `string` = rt.string; `comment_id`: ``null`` \| `string` }, `unknown`\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:310](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L310) - -___ - -### getUniqueConnectors - -▸ **getUniqueConnectors**(`__namedParameters`): `Promise`<{ `id`: `string` }[]\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.caseId` | `string` | -| `__namedParameters.filter?` | `KueryNode` | -| `__namedParameters.unsecuredSavedObjectsClient` | [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) | - -#### Returns - -`Promise`<{ `id`: `string` }[]\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:426](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L426) - -___ - -### getUserActionItemByDifference - -▸ `Private` **getUserActionItemByDifference**(`__namedParameters`): [`BuilderReturnValue`](../interfaces/client._internal_namespace.BuilderReturnValue.md)[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetUserActionItemByDifference`](../interfaces/client._internal_namespace.GetUserActionItemByDifference.md) | - -#### Returns - -[`BuilderReturnValue`](../interfaces/client._internal_namespace.BuilderReturnValue.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:108](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L108) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesActions.md deleted file mode 100644 index 40c474c66fc37..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesActions.md +++ /dev/null @@ -1,66 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CasesActions - -# Class: CasesActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CasesActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.CasesActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.CasesActions.md#prefix) - -### Methods - -- [get](client._internal_namespace.CasesActions.md#get) - -## Constructors - -### constructor - -• **new CasesActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/cases.d.ts:3 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/cases.d.ts:2 - -## Methods - -### get - -▸ **get**(`owner`, `operation`): `string` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `owner` | `string` | -| `operation` | `string` | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/cases.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesClientInternal.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesClientInternal.md deleted file mode 100644 index 9a7fe6f6c11d5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesClientInternal.md +++ /dev/null @@ -1,59 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CasesClientInternal - -# Class: CasesClientInternal - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CasesClientInternal - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.CasesClientInternal.md#constructor) - -### Properties - -- [\_configuration](client._internal_namespace.CasesClientInternal.md#_configuration) - -### Accessors - -- [configuration](client._internal_namespace.CasesClientInternal.md#configuration) - -## Constructors - -### constructor - -• **new CasesClientInternal**(`args`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `args` | [`CasesClientArgs`](../interfaces/client._internal_namespace.CasesClientArgs.md) | - -#### Defined in - -[x-pack/plugins/cases/server/client/client_internal.ts:17](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client_internal.ts#L17) - -## Properties - -### \_configuration - -• `Private` `Readonly` **\_configuration**: `InternalConfigureSubClient` - -#### Defined in - -[x-pack/plugins/cases/server/client/client_internal.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client_internal.ts#L15) - -## Accessors - -### configuration - -• `get` **configuration**(): `InternalConfigureSubClient` - -#### Returns - -`InternalConfigureSubClient` - -#### Defined in - -[x-pack/plugins/cases/server/client/client_internal.ts:21](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client_internal.ts#L21) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesService.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesService.md deleted file mode 100644 index eb31fa2722c15..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.CasesService.md +++ /dev/null @@ -1,470 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CasesService - -# Class: CasesService - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CasesService - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.CasesService.md#constructor) - -### Methods - -- [asArray](client._internal_namespace.CasesService.md#asarray) -- [buildCaseIdsAggs](client._internal_namespace.CasesService.md#buildcaseidsaggs) -- [deleteCase](client._internal_namespace.CasesService.md#deletecase) -- [findCaseStatusStats](client._internal_namespace.CasesService.md#findcasestatusstats) -- [findCases](client._internal_namespace.CasesService.md#findcases) -- [findCasesGroupedByID](client._internal_namespace.CasesService.md#findcasesgroupedbyid) -- [getAllCaseComments](client._internal_namespace.CasesService.md#getallcasecomments) -- [getAllComments](client._internal_namespace.CasesService.md#getallcomments) -- [getCase](client._internal_namespace.CasesService.md#getcase) -- [getCaseCommentStats](client._internal_namespace.CasesService.md#getcasecommentstats) -- [getCaseIdsByAlertId](client._internal_namespace.CasesService.md#getcaseidsbyalertid) -- [getCases](client._internal_namespace.CasesService.md#getcases) -- [getReporters](client._internal_namespace.CasesService.md#getreporters) -- [getResolveCase](client._internal_namespace.CasesService.md#getresolvecase) -- [getTags](client._internal_namespace.CasesService.md#gettags) -- [getUser](client._internal_namespace.CasesService.md#getuser) -- [patchCase](client._internal_namespace.CasesService.md#patchcase) -- [patchCases](client._internal_namespace.CasesService.md#patchcases) -- [postNewCase](client._internal_namespace.CasesService.md#postnewcase) -- [getCaseIDsFromAlertAggs](client._internal_namespace.CasesService.md#getcaseidsfromalertaggs) - -## Constructors - -### constructor - -• **new CasesService**(`log`, `authentication?`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `log` | `Logger` | -| `authentication?` | `Object` | -| `authentication.getCurrentUser` | (`request`: [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\>) => ``null`` \| [`AuthenticatedUser`](../interfaces/client._internal_namespace.AuthenticatedUser.md) | - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:138](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L138) - -## Methods - -### asArray - -▸ `Private` **asArray**(`id`): `string`[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `undefined` \| `string` \| `string`[] | - -#### Returns - -`string`[] - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:413](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L413) - -___ - -### buildCaseIdsAggs - -▸ `Private` **buildCaseIdsAggs**(`size?`): `Record`<`string`, `AggregationsAggregationContainer`\> - -#### Parameters - -| Name | Type | Default value | -| :------ | :------ | :------ | -| `size` | `number` | `100` | - -#### Returns - -`Record`<`string`, `AggregationsAggregationContainer`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:143](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L143) - -___ - -### deleteCase - -▸ **deleteCase**(`__namedParameters`): `Promise`<{}\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseArgs`](../interfaces/client._internal_namespace.GetCaseArgs.md) | - -#### Returns - -`Promise`<{}\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:332](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L332) - -___ - -### findCaseStatusStats - -▸ **findCaseStatusStats**(`__namedParameters`): `Promise`<`number`\> - -Retrieves the number of cases that exist with a given status (open, closed, etc). - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.caseOptions` | [`SavedObjectFindOptionsKueryNode`](../modules/client._internal_namespace.md#savedobjectfindoptionskuerynode) | -| `__namedParameters.ensureSavedObjectsAreAuthorized` | [`EnsureSOAuthCallback`](../modules/client._internal_namespace.md#ensuresoauthcallback) | -| `__namedParameters.unsecuredSavedObjectsClient` | [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) | - -#### Returns - -`Promise`<`number`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:251](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L251) - -___ - -### findCases - -▸ **findCases**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`FindCasesArgs`](../interfaces/client._internal_namespace.FindCasesArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:395](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L395) - -___ - -### findCasesGroupedByID - -▸ **findCasesGroupedByID**(`__namedParameters`): `Promise`<[`CasesMapWithPageInfo`](../interfaces/client._internal_namespace.CasesMapWithPageInfo.md)\> - -Returns a map of all cases. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.caseOptions` | [`FindCaseOptions`](../modules/client._internal_namespace.md#findcaseoptions) | -| `__namedParameters.unsecuredSavedObjectsClient` | [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) | - -#### Returns - -`Promise`<[`CasesMapWithPageInfo`](../interfaces/client._internal_namespace.CasesMapWithPageInfo.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:206](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L206) - -___ - -### getAllCaseComments - -▸ **getAllCaseComments**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -Default behavior is to retrieve all comments that adhere to a given filter (if one is included). -to override this pass in the either the page or perPage options. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`FindCaseCommentsArgs`](../interfaces/client._internal_namespace.FindCaseCommentsArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:455](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L455) - -___ - -### getAllComments - -▸ `Private` **getAllComments**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`FindCommentsArgs`](../interfaces/client._internal_namespace.FindCommentsArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, `unknown`\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:423](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L423) - -___ - -### getCase - -▸ **getCase**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseArgs`](../interfaces/client._internal_namespace.GetCaseArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:342](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L342) - -___ - -### getCaseCommentStats - -▸ **getCaseCommentStats**(`__namedParameters`): `Promise`<[`CaseCommentStats`](../interfaces/client._internal_namespace.CaseCommentStats.md)\> - -Returns the number of total comments and alerts for a case - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.ids` | `string`[] | -| `__namedParameters.unsecuredSavedObjectsClient` | [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) | - -#### Returns - -`Promise`<[`CaseCommentStats`](../interfaces/client._internal_namespace.CaseCommentStats.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:280](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L280) - -___ - -### getCaseIdsByAlertId - -▸ **getCaseIdsByAlertId**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, { `references`: { doc\_count: number; caseIds: { buckets: { key: string; }[]; }; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseIdsByAlertIdArgs`](../interfaces/client._internal_namespace.GetCaseIdsByAlertIdArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, { `references`: { doc\_count: number; caseIds: { buckets: { key: string; }[]; }; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:161](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L161) - -___ - -### getCases - -▸ **getCases**(`__namedParameters`): `Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCasesArgs`](../interfaces/client._internal_namespace.GetCasesArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:379](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L379) - -___ - -### getReporters - -▸ **getReporters**(`__namedParameters`): `Promise`<{ `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` }[]\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetReportersArgs`](../interfaces/client._internal_namespace.GetReportersArgs.md) | - -#### Returns - -`Promise`<{ `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` }[]\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:488](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L488) - -___ - -### getResolveCase - -▸ **getResolveCase**(`__namedParameters`): `Promise`<[`SavedObjectsResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetCaseArgs`](../interfaces/client._internal_namespace.GetCaseArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:359](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L359) - -___ - -### getTags - -▸ **getTags**(`__namedParameters`): `Promise`<`string`[]\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetTagsArgs`](../interfaces/client._internal_namespace.GetTagsArgs.md) | - -#### Returns - -`Promise`<`string`[]\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:552](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L552) - -___ - -### getUser - -▸ **getUser**(`__namedParameters`): [`AuthenticatedUser`](../interfaces/client._internal_namespace.AuthenticatedUser.md) \| { `email`: ``null`` = null; `full_name`: ``null`` = null; `username`: ``null`` = null } - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetUserArgs`](../interfaces/client._internal_namespace.GetUserArgs.md) | - -#### Returns - -[`AuthenticatedUser`](../interfaces/client._internal_namespace.AuthenticatedUser.md) \| { `email`: ``null`` = null; `full_name`: ``null`` = null; `username`: ``null`` = null } - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:582](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L582) - -___ - -### patchCase - -▸ **patchCase**(`__namedParameters`): `Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PatchCaseArgs`](../modules/client._internal_namespace.md#patchcaseargs) | - -#### Returns - -`Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:627](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L627) - -___ - -### patchCases - -▸ **patchCases**(`__namedParameters`): `Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PatchCasesArgs`](../interfaces/client._internal_namespace.PatchCasesArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:655](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L655) - -___ - -### postNewCase - -▸ **postNewCase**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PostCaseArgs`](../interfaces/client._internal_namespace.PostCaseArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:607](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L607) - -___ - -### getCaseIDsFromAlertAggs - -▸ `Static` **getCaseIDsFromAlertAggs**(`result`): `string`[] - -Extracts the case IDs from the alert aggregation - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `result` | [`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }, { `references`: { doc\_count: number; caseIds: { buckets: { key: string; }[]; }; } }\> | - -#### Returns - -`string`[] - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:197](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L197) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorMappingsService.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorMappingsService.md deleted file mode 100644 index 2b6649eca4111..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorMappingsService.md +++ /dev/null @@ -1,93 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConnectorMappingsService - -# Class: ConnectorMappingsService - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConnectorMappingsService - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ConnectorMappingsService.md#constructor) - -### Methods - -- [find](client._internal_namespace.ConnectorMappingsService.md#find) -- [post](client._internal_namespace.ConnectorMappingsService.md#post) -- [update](client._internal_namespace.ConnectorMappingsService.md#update) - -## Constructors - -### constructor - -• **new ConnectorMappingsService**(`log`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `log` | `Logger` | - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:33](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L33) - -## Methods - -### find - -▸ **find**(`__namedParameters`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }, `unknown`\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`FindConnectorMappingsArgs`](../interfaces/client._internal_namespace.FindConnectorMappingsArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }, `unknown`\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:35](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L35) - -___ - -### post - -▸ **post**(`__namedParameters`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`PostConnectorMappingsArgs`](../interfaces/client._internal_namespace.PostConnectorMappingsArgs.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:48](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L48) - -___ - -### update - -▸ **update**(`__namedParameters`): `Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`UpdateConnectorMappingsArgs`](../interfaces/client._internal_namespace.UpdateConnectorMappingsArgs.md) | - -#### Returns - -`Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }\>\> - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:68](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L68) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorTokenClient.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorTokenClient.md deleted file mode 100644 index 7e2a19e11efbe..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ConnectorTokenClient.md +++ /dev/null @@ -1,162 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConnectorTokenClient - -# Class: ConnectorTokenClient - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConnectorTokenClient - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ConnectorTokenClient.md#constructor) - -### Properties - -- [encryptedSavedObjectsClient](client._internal_namespace.ConnectorTokenClient.md#encryptedsavedobjectsclient) -- [logger](client._internal_namespace.ConnectorTokenClient.md#logger) -- [unsecuredSavedObjectsClient](client._internal_namespace.ConnectorTokenClient.md#unsecuredsavedobjectsclient) - -### Methods - -- [create](client._internal_namespace.ConnectorTokenClient.md#create) -- [deleteConnectorTokens](client._internal_namespace.ConnectorTokenClient.md#deleteconnectortokens) -- [get](client._internal_namespace.ConnectorTokenClient.md#get) -- [update](client._internal_namespace.ConnectorTokenClient.md#update) - -## Constructors - -### constructor - -• **new ConnectorTokenClient**(`__namedParameters`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`ConstructorOptions`](../interfaces/client._internal_namespace.ConstructorOptions-2.md) | - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:26 - -## Properties - -### encryptedSavedObjectsClient - -• `Private` `Readonly` **encryptedSavedObjectsClient**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:25 - -___ - -### logger - -• `Private` `Readonly` **logger**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:23 - -___ - -### unsecuredSavedObjectsClient - -• `Private` `Readonly` **unsecuredSavedObjectsClient**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:24 - -## Methods - -### create - -▸ **create**(`__namedParameters`): `Promise`<[`ConnectorToken`](../interfaces/client._internal_namespace.ConnectorToken.md)\> - -Create new token for connector - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CreateOptions`](../interfaces/client._internal_namespace.CreateOptions-1.md) | - -#### Returns - -`Promise`<[`ConnectorToken`](../interfaces/client._internal_namespace.ConnectorToken.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:30 - -___ - -### deleteConnectorTokens - -▸ **deleteConnectorTokens**(`__namedParameters`): `Promise`<{}[]\> - -Delete all connector tokens - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.connectorId` | `string` | -| `__namedParameters.tokenType?` | `string` | - -#### Returns - -`Promise`<{}[]\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:48 - -___ - -### get - -▸ **get**(`__namedParameters`): `Promise`<{ `connectorToken`: ``null`` \| [`ConnectorToken`](../interfaces/client._internal_namespace.ConnectorToken.md) ; `hasErrors`: `boolean` }\> - -Get connector token - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.connectorId` | `string` | -| `__namedParameters.tokenType?` | `string` | - -#### Returns - -`Promise`<{ `connectorToken`: ``null`` \| [`ConnectorToken`](../interfaces/client._internal_namespace.ConnectorToken.md) ; `hasErrors`: `boolean` }\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:38 - -___ - -### update - -▸ **update**(`__namedParameters`): `Promise`<``null`` \| [`ConnectorToken`](../interfaces/client._internal_namespace.ConnectorToken.md)\> - -Update connector token - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`UpdateOptions`](../interfaces/client._internal_namespace.UpdateOptions-1.md) | - -#### Returns - -`Promise`<``null`` \| [`ConnectorToken`](../interfaces/client._internal_namespace.ConnectorToken.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:34 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ElasticsearchFeature.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ElasticsearchFeature.md deleted file mode 100644 index 95ffabe03d983..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.ElasticsearchFeature.md +++ /dev/null @@ -1,122 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ElasticsearchFeature - -# Class: ElasticsearchFeature - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ElasticsearchFeature - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.ElasticsearchFeature.md#constructor) - -### Properties - -- [config](client._internal_namespace.ElasticsearchFeature.md#config) - -### Accessors - -- [catalogue](client._internal_namespace.ElasticsearchFeature.md#catalogue) -- [id](client._internal_namespace.ElasticsearchFeature.md#id) -- [management](client._internal_namespace.ElasticsearchFeature.md#management) -- [privileges](client._internal_namespace.ElasticsearchFeature.md#privileges) - -### Methods - -- [toRaw](client._internal_namespace.ElasticsearchFeature.md#toraw) - -## Constructors - -### constructor - -• **new ElasticsearchFeature**(`config`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `config` | `Readonly`<{ `catalogue?`: `RecursiveReadonlyArray`<`string`\> ; `id`: `string` ; `management?`: `Readonly`<{ [x: string]: RecursiveReadonlyArray; }\> ; `privileges`: `RecursiveReadonlyArray`<[`FeatureElasticsearchPrivileges`](../interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md)\> }\> | - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:54 - -## Properties - -### config - -• `Protected` `Readonly` **config**: `Readonly`<{ `catalogue?`: `RecursiveReadonlyArray`<`string`\> ; `id`: `string` ; `management?`: `Readonly`<{ [x: string]: RecursiveReadonlyArray; }\> ; `privileges`: `RecursiveReadonlyArray`<[`FeatureElasticsearchPrivileges`](../interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md)\> }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:53 - -## Accessors - -### catalogue - -• `get` **catalogue**(): `undefined` \| `RecursiveReadonlyArray`<`string`\> - -#### Returns - -`undefined` \| `RecursiveReadonlyArray`<`string`\> - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:56 - -___ - -### id - -• `get` **id**(): `string` - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:55 - -___ - -### management - -• `get` **management**(): `undefined` \| `Readonly`<{ [x: string]: `RecursiveReadonlyArray`; }\> - -#### Returns - -`undefined` \| `Readonly`<{ [x: string]: `RecursiveReadonlyArray`; }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:57 - -___ - -### privileges - -• `get` **privileges**(): `RecursiveReadonlyArray`<[`FeatureElasticsearchPrivileges`](../interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md)\> - -#### Returns - -`RecursiveReadonlyArray`<[`FeatureElasticsearchPrivileges`](../interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md)\> - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:60 - -## Methods - -### toRaw - -▸ **toRaw**(): [`ElasticsearchFeatureConfig`](../interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md) - -#### Returns - -[`ElasticsearchFeatureConfig`](../interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md) - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:61 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaFeature.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaFeature.md deleted file mode 100644 index 88e1f958de6dc..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaFeature.md +++ /dev/null @@ -1,268 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaFeature - -# Class: KibanaFeature - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaFeature - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.KibanaFeature.md#constructor) - -### Properties - -- [config](client._internal_namespace.KibanaFeature.md#config) -- [subFeatures](client._internal_namespace.KibanaFeature.md#subfeatures) - -### Accessors - -- [alerting](client._internal_namespace.KibanaFeature.md#alerting) -- [app](client._internal_namespace.KibanaFeature.md#app) -- [cases](client._internal_namespace.KibanaFeature.md#cases) -- [catalogue](client._internal_namespace.KibanaFeature.md#catalogue) -- [category](client._internal_namespace.KibanaFeature.md#category) -- [excludeFromBasePrivileges](client._internal_namespace.KibanaFeature.md#excludefrombaseprivileges) -- [id](client._internal_namespace.KibanaFeature.md#id) -- [management](client._internal_namespace.KibanaFeature.md#management) -- [minimumLicense](client._internal_namespace.KibanaFeature.md#minimumlicense) -- [name](client._internal_namespace.KibanaFeature.md#name) -- [order](client._internal_namespace.KibanaFeature.md#order) -- [privileges](client._internal_namespace.KibanaFeature.md#privileges) -- [reserved](client._internal_namespace.KibanaFeature.md#reserved) - -### Methods - -- [toRaw](client._internal_namespace.KibanaFeature.md#toraw) - -## Constructors - -### constructor - -• **new KibanaFeature**(`config`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `config` | `Readonly`<{ `alerting?`: readonly `string`[] ; `app`: readonly `string`[] ; `cases?`: readonly `string`[] ; `catalogue?`: readonly `string`[] ; `category`: `Readonly`<{ id: string; label: string; ariaLabel?: string \| undefined; order?: number \| undefined; euiIconType?: string \| undefined; }\> ; `excludeFromBasePrivileges?`: `boolean` ; `id`: `string` ; `management?`: `Readonly`<{ [x: string]: readonly string[]; }\> ; `minimumLicense?`: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` ; `name`: `string` ; `order?`: `number` ; `privileges`: ``null`` \| `Readonly`<{ all: Readonly<{ excludeFromBasePrivileges?: boolean \| undefined; requireAllSpaces?: boolean \| undefined; disabled?: boolean \| undefined; management?: Readonly<{ [x: string]: readonly string[]; }\> \| undefined; ... 6 more ...; ui: readonly string[]; }\>; read: Readonly<...\>; }\> ; `privilegesTooltip?`: `string` ; `reserved?`: `Readonly`<{ description: string; privileges: readonly Readonly<{ id: string; privilege: Readonly<{ excludeFromBasePrivileges?: boolean \| undefined; requireAllSpaces?: boolean \| undefined; disabled?: boolean \| undefined; ... 7 more ...; ui: readonly string[]; }\>; }\>[]; }\> ; `subFeatures?`: readonly `Readonly`<{ name: string; privilegeGroups: readonly Readonly<{ groupType: SubFeaturePrivilegeGroupType; privileges: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; ... 10 more ...; ui: readonly string[]; }\>[]; }\>[]; }\>[] }\> | - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:123 - -## Properties - -### config - -• `Protected` `Readonly` **config**: `Readonly`<{ `alerting?`: readonly `string`[] ; `app`: readonly `string`[] ; `cases?`: readonly `string`[] ; `catalogue?`: readonly `string`[] ; `category`: `Readonly`<{ id: string; label: string; ariaLabel?: string \| undefined; order?: number \| undefined; euiIconType?: string \| undefined; }\> ; `excludeFromBasePrivileges?`: `boolean` ; `id`: `string` ; `management?`: `Readonly`<{ [x: string]: readonly string[]; }\> ; `minimumLicense?`: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` ; `name`: `string` ; `order?`: `number` ; `privileges`: ``null`` \| `Readonly`<{ all: Readonly<{ excludeFromBasePrivileges?: boolean \| undefined; requireAllSpaces?: boolean \| undefined; disabled?: boolean \| undefined; management?: Readonly<{ [x: string]: readonly string[]; }\> \| undefined; ... 6 more ...; ui: readonly string[]; }\>; read: Readonly<...\>; }\> ; `privilegesTooltip?`: `string` ; `reserved?`: `Readonly`<{ description: string; privileges: readonly Readonly<{ id: string; privilege: Readonly<{ excludeFromBasePrivileges?: boolean \| undefined; requireAllSpaces?: boolean \| undefined; disabled?: boolean \| undefined; ... 7 more ...; ui: readonly string[]; }\>; }\>[]; }\> ; `subFeatures?`: readonly `Readonly`<{ name: string; privilegeGroups: readonly Readonly<{ groupType: SubFeaturePrivilegeGroupType; privileges: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; ... 10 more ...; ui: readonly string[]; }\>[]; }\>[]; }\>[] }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:121 - -___ - -### subFeatures - -• `Readonly` **subFeatures**: [`SubFeature`](client._internal_namespace.SubFeature.md)[] - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:122 - -## Accessors - -### alerting - -• `get` **alerting**(): `undefined` \| readonly `string`[] - -#### Returns - -`undefined` \| readonly `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:202 - -___ - -### app - -• `get` **app**(): readonly `string`[] - -#### Returns - -readonly `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:134 - -___ - -### cases - -• `get` **cases**(): `undefined` \| readonly `string`[] - -#### Returns - -`undefined` \| readonly `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:203 - -___ - -### catalogue - -• `get` **catalogue**(): `undefined` \| readonly `string`[] - -#### Returns - -`undefined` \| readonly `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:135 - -___ - -### category - -• `get` **category**(): `Readonly`<{ `ariaLabel?`: `string` ; `euiIconType?`: `string` ; `id`: `string` ; `label`: `string` ; `order?`: `number` }\> - -#### Returns - -`Readonly`<{ `ariaLabel?`: `string` ; `euiIconType?`: `string` ; `id`: `string` ; `label`: `string` ; `order?`: `number` }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:127 - -___ - -### excludeFromBasePrivileges - -• `get` **excludeFromBasePrivileges**(): `boolean` - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:204 - -___ - -### id - -• `get` **id**(): `string` - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:124 - -___ - -### management - -• `get` **management**(): `undefined` \| `Readonly`<{ [x: string]: readonly `string`[]; }\> - -#### Returns - -`undefined` \| `Readonly`<{ [x: string]: readonly `string`[]; }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:136 - -___ - -### minimumLicense - -• `get` **minimumLicense**(): `undefined` \| ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -#### Returns - -`undefined` \| ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:139 - -___ - -### name - -• `get` **name**(): `string` - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:125 - -___ - -### order - -• `get` **order**(): `undefined` \| `number` - -#### Returns - -`undefined` \| `number` - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:126 - -___ - -### privileges - -• `get` **privileges**(): ``null`` \| `Readonly`<{ `all`: `Readonly`<{ `alerting?`: `Readonly`<{ `alert?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `rule?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> }\> ; `api?`: readonly `string`[] ; `app?`: readonly `string`[] ; `cases?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `catalogue?`: readonly `string`[] ; `disabled?`: `boolean` ; `excludeFromBasePrivileges?`: `boolean` ; `management?`: `Readonly`<{ [x: string]: readonly `string`[]; }\> ; `requireAllSpaces?`: `boolean` ; `savedObject`: `Readonly`<{ `all`: readonly `string`[] ; `read`: readonly `string`[] }\> ; `ui`: readonly `string`[] }\> ; `read`: `Readonly`<{ `alerting?`: `Readonly`<{ `alert?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `rule?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> }\> ; `api?`: readonly `string`[] ; `app?`: readonly `string`[] ; `cases?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `catalogue?`: readonly `string`[] ; `disabled?`: `boolean` ; `excludeFromBasePrivileges?`: `boolean` ; `management?`: `Readonly`<{ [x: string]: readonly `string`[]; }\> ; `requireAllSpaces?`: `boolean` ; `savedObject`: `Readonly`<{ `all`: readonly `string`[] ; `read`: readonly `string`[] }\> ; `ui`: readonly `string`[] }\> }\> - -#### Returns - -``null`` \| `Readonly`<{ `all`: `Readonly`<{ `alerting?`: `Readonly`<{ `alert?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `rule?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> }\> ; `api?`: readonly `string`[] ; `app?`: readonly `string`[] ; `cases?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `catalogue?`: readonly `string`[] ; `disabled?`: `boolean` ; `excludeFromBasePrivileges?`: `boolean` ; `management?`: `Readonly`<{ [x: string]: readonly `string`[]; }\> ; `requireAllSpaces?`: `boolean` ; `savedObject`: `Readonly`<{ `all`: readonly `string`[] ; `read`: readonly `string`[] }\> ; `ui`: readonly `string`[] }\> ; `read`: `Readonly`<{ `alerting?`: `Readonly`<{ `alert?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `rule?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> }\> ; `api?`: readonly `string`[] ; `app?`: readonly `string`[] ; `cases?`: `Readonly`<{ `all?`: readonly `string`[] ; `read?`: readonly `string`[] }\> ; `catalogue?`: readonly `string`[] ; `disabled?`: `boolean` ; `excludeFromBasePrivileges?`: `boolean` ; `management?`: `Readonly`<{ [x: string]: readonly `string`[]; }\> ; `requireAllSpaces?`: `boolean` ; `savedObject`: `Readonly`<{ `all`: readonly `string`[] ; `read`: readonly `string`[] }\> ; `ui`: readonly `string`[] }\> }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:140 - -___ - -### reserved - -• `get` **reserved**(): `undefined` \| `Readonly`<{ `description`: `string` ; `privileges`: readonly `Readonly`<{ `id`: `string` ; `privilege`: `Readonly`<{ `alerting?`: `Readonly`<{ `alert?`: `Readonly`<{ `all?`: readonly string[] ; `read?`: readonly string[] }\> ; `rule?`: `Readonly`<{ `all?`: readonly string[] ; `read?`: readonly string[] }\> }\> ; `api?`: readonly string[] ; `app?`: readonly string[] ; `cases?`: `Readonly`<{ `all?`: readonly string[] ; `read?`: readonly string[] }\> ; `catalogue?`: readonly string[] ; `disabled?`: `boolean` ; `excludeFromBasePrivileges?`: `boolean` ; `management?`: `Readonly`<{ [x: string]: readonly `string`[]; }\> ; `requireAllSpaces?`: `boolean` ; `savedObject`: `Readonly`<{ `all`: readonly string[] ; `read`: readonly string[] }\> ; `ui`: readonly string[] }\> }\>[] }\> - -#### Returns - -`undefined` \| `Readonly`<{ `description`: `string` ; `privileges`: readonly `Readonly`<{ `id`: `string` ; `privilege`: `Readonly`<{ `alerting?`: `Readonly`<{ `alert?`: `Readonly`<{ `all?`: readonly string[] ; `read?`: readonly string[] }\> ; `rule?`: `Readonly`<{ `all?`: readonly string[] ; `read?`: readonly string[] }\> }\> ; `api?`: readonly string[] ; `app?`: readonly string[] ; `cases?`: `Readonly`<{ `all?`: readonly string[] ; `read?`: readonly string[] }\> ; `catalogue?`: readonly string[] ; `disabled?`: `boolean` ; `excludeFromBasePrivileges?`: `boolean` ; `management?`: `Readonly`<{ [x: string]: readonly `string`[]; }\> ; `requireAllSpaces?`: `boolean` ; `savedObject`: `Readonly`<{ `all`: readonly string[] ; `read`: readonly string[] }\> ; `ui`: readonly string[] }\> }\>[] }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:205 - -## Methods - -### toRaw - -▸ **toRaw**(): [`KibanaFeatureConfig`](../interfaces/client._internal_namespace.KibanaFeatureConfig.md) - -#### Returns - -[`KibanaFeatureConfig`](../interfaces/client._internal_namespace.KibanaFeatureConfig.md) - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:241 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaMigrator.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaMigrator.md deleted file mode 100644 index a26089d3ed6f4..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaMigrator.md +++ /dev/null @@ -1,286 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaMigrator - -# Class: KibanaMigrator - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaMigrator - -Manages the shape of mappings and documents in the Kibana index. - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.KibanaMigrator.md#constructor) - -### Properties - -- [activeMappings](client._internal_namespace.KibanaMigrator.md#activemappings) -- [client](client._internal_namespace.KibanaMigrator.md#client) -- [documentMigrator](client._internal_namespace.KibanaMigrator.md#documentmigrator) -- [kibanaIndex](client._internal_namespace.KibanaMigrator.md#kibanaindex) -- [kibanaVersion](client._internal_namespace.KibanaMigrator.md#kibanaversion) -- [log](client._internal_namespace.KibanaMigrator.md#log) -- [mappingProperties](client._internal_namespace.KibanaMigrator.md#mappingproperties) -- [migrationResult](client._internal_namespace.KibanaMigrator.md#migrationresult) -- [runMigrationsInternal](client._internal_namespace.KibanaMigrator.md#runmigrationsinternal) -- [serializer](client._internal_namespace.KibanaMigrator.md#serializer) -- [soMigrationsConfig](client._internal_namespace.KibanaMigrator.md#somigrationsconfig) -- [status$](client._internal_namespace.KibanaMigrator.md#status$) -- [typeRegistry](client._internal_namespace.KibanaMigrator.md#typeregistry) - -### Methods - -- [getActiveMappings](client._internal_namespace.KibanaMigrator.md#getactivemappings) -- [getStatus$](client._internal_namespace.KibanaMigrator.md#getstatus$) -- [migrateDocument](client._internal_namespace.KibanaMigrator.md#migratedocument) -- [prepareMigrations](client._internal_namespace.KibanaMigrator.md#preparemigrations) -- [runMigrations](client._internal_namespace.KibanaMigrator.md#runmigrations) - -## Constructors - -### constructor - -• **new KibanaMigrator**(`__namedParameters`) - -Creates an instance of KibanaMigrator. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`KibanaMigratorOptions`](../interfaces/client._internal_namespace.KibanaMigratorOptions.md) | - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:42 - -## Properties - -### activeMappings - -• `Private` `Readonly` **activeMappings**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:36 - -___ - -### client - -• `Private` `Readonly` **client**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:27 - -___ - -### documentMigrator - -• `Private` `Readonly` **documentMigrator**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:28 - -___ - -### kibanaIndex - -• `Private` `Readonly` **kibanaIndex**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:29 - -___ - -### kibanaVersion - -• `Readonly` **kibanaVersion**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:38 - -___ - -### log - -• `Private` `Readonly` **log**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:30 - -___ - -### mappingProperties - -• `Private` `Readonly` **mappingProperties**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:31 - -___ - -### migrationResult - -• `Private` `Optional` **migrationResult**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:34 - -___ - -### runMigrationsInternal - -• `Private` **runMigrationsInternal**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:68 - -___ - -### serializer - -• `Private` `Readonly` **serializer**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:33 - -___ - -### soMigrationsConfig - -• `Private` `Readonly` **soMigrationsConfig**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:37 - -___ - -### status$ - -• `Private` `Readonly` **status$**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:35 - -___ - -### typeRegistry - -• `Private` `Readonly` **typeRegistry**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:32 - -## Methods - -### getActiveMappings - -▸ **getActiveMappings**(): [`IndexMapping`](../interfaces/client._internal_namespace.IndexMapping.md) - -Gets all the index mappings defined by Kibana's enabled plugins. - -#### Returns - -[`IndexMapping`](../interfaces/client._internal_namespace.IndexMapping.md) - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:73 - -___ - -### getStatus$ - -▸ **getStatus$**(): `Observable`<[`KibanaMigratorStatus`](../interfaces/client._internal_namespace.KibanaMigratorStatus.md)\> - -#### Returns - -`Observable`<[`KibanaMigratorStatus`](../interfaces/client._internal_namespace.KibanaMigratorStatus.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:67 - -___ - -### migrateDocument - -▸ **migrateDocument**(`doc`): [`SavedObjectUnsanitizedDoc`](../modules/client._internal_namespace.md#savedobjectunsanitizeddoc)<`unknown`\> - -Migrates an individual doc to the latest version, as defined by the plugin migrations. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `doc` | [`SavedObjectUnsanitizedDoc`](../modules/client._internal_namespace.md#savedobjectunsanitizeddoc)<`unknown`\> | The saved object to migrate | - -#### Returns - -[`SavedObjectUnsanitizedDoc`](../modules/client._internal_namespace.md#savedobjectunsanitizeddoc)<`unknown`\> - -`doc` with all registered migrations applied. - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:80 - -___ - -### prepareMigrations - -▸ **prepareMigrations**(): `void` - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:66 - -___ - -### runMigrations - -▸ **runMigrations**(`rerun?`): `Promise`<{ `status`: `string` }[]\> - -Migrates the mappings and documents in the Kibana index. By default, this will run only -once and subsequent calls will return the result of the original call. - -**`remarks`** When the `rerun` parameter is set to true, no checks are performed to ensure that no migration -is currently running. Chained or concurrent calls to `runMigrations({ rerun: true })` can lead to -multiple migrations running at the same time. When calling with this parameter, it's expected that the calling -code should ensure that the initial call resolves before calling the function again. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `rerun?` | `Object` | If true, method will run a new migration when called again instead of returning the result of the initial migration. This should only be used when factors external to Kibana itself alter the kibana index causing the saved objects mappings or data to change after the Kibana server performed the initial migration. | -| `rerun.rerun?` | `boolean` | - | - -#### Returns - -`Promise`<{ `status`: `string` }[]\> - -- A promise which resolves once all migrations have been applied. - The promise resolves with an array of migration statuses, one for each - elasticsearch index which was migrated. - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:61 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaRequest.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaRequest.md deleted file mode 100644 index e0aae4835d6b7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.KibanaRequest.md +++ /dev/null @@ -1,347 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaRequest - -# Class: KibanaRequest - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaRequest - -Kibana specific abstraction for an incoming request. - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Params` | `unknown` | -| `Query` | `unknown` | -| `Body` | `unknown` | -| `Method` | extends [`RouteMethod`](../modules/client._internal_namespace.md#routemethod) = `any` | - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.KibanaRequest.md#constructor) - -### Properties - -- [[requestSymbol]](client._internal_namespace.KibanaRequest.md#[requestsymbol]) -- [auth](client._internal_namespace.KibanaRequest.md#auth) -- [body](client._internal_namespace.KibanaRequest.md#body) -- [events](client._internal_namespace.KibanaRequest.md#events) -- [getAuthRequired](client._internal_namespace.KibanaRequest.md#getauthrequired) -- [getEvents](client._internal_namespace.KibanaRequest.md#getevents) -- [getRouteInfo](client._internal_namespace.KibanaRequest.md#getrouteinfo) -- [headers](client._internal_namespace.KibanaRequest.md#headers) -- [id](client._internal_namespace.KibanaRequest.md#id) -- [isSystemRequest](client._internal_namespace.KibanaRequest.md#issystemrequest) -- [params](client._internal_namespace.KibanaRequest.md#params) -- [query](client._internal_namespace.KibanaRequest.md#query) -- [rewrittenUrl](client._internal_namespace.KibanaRequest.md#rewrittenurl) -- [route](client._internal_namespace.KibanaRequest.md#route) -- [socket](client._internal_namespace.KibanaRequest.md#socket) -- [url](client._internal_namespace.KibanaRequest.md#url) -- [uuid](client._internal_namespace.KibanaRequest.md#uuid) -- [withoutSecretHeaders](client._internal_namespace.KibanaRequest.md#withoutsecretheaders) -- [validate](client._internal_namespace.KibanaRequest.md#validate) - -### Methods - -- [from](client._internal_namespace.KibanaRequest.md#from) - -## Constructors - -### constructor - -• **new KibanaRequest**<`Params`, `Query`, `Body`, `Method`\>(`request`, `params`, `query`, `body`, `withoutSecretHeaders`) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Params` | `unknown` | -| `Query` | `unknown` | -| `Body` | `unknown` | -| `Method` | extends [`RouteMethod`](../modules/client._internal_namespace.md#routemethod) = `any` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | `Request` | -| `params` | `Params` | -| `query` | `Query` | -| `body` | `Body` | -| `withoutSecretHeaders` | `boolean` | - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:126 - -## Properties - -### [requestSymbol] - -• `Protected` `Readonly` **[requestSymbol]**: `Request` - -**`internal`** - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:125 - -___ - -### auth - -• `Readonly` **auth**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `isAuthenticated` | `boolean` | - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:117 - -___ - -### body - -• `Readonly` **body**: `Body` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:66 - -___ - -### events - -• `Readonly` **events**: [`KibanaRequestEvents`](../interfaces/client._internal_namespace.KibanaRequestEvents.md) - -Request events [KibanaRequestEvents](../interfaces/client._internal_namespace.KibanaRequestEvents.md) - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:116 - -___ - -### getAuthRequired - -• `Private` **getAuthRequired**: `any` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:129 - -___ - -### getEvents - -• `Private` **getEvents**: `any` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:127 - -___ - -### getRouteInfo - -• `Private` **getRouteInfo**: `any` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:128 - -___ - -### headers - -• `Readonly` **headers**: [`Headers`](../modules/client._internal_namespace.md#headers) - -Readonly copy of incoming request headers. - -**`remarks`** -This property will contain a `filtered` copy of request headers. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:107 - -___ - -### id - -• `Readonly` **id**: `string` - -A identifier to identify this request. - -**`remarks`** -Depending on the user's configuration, this value may be sourced from the -incoming request's `X-Opaque-Id` header which is not guaranteed to be unique -per request. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:89 - -___ - -### isSystemRequest - -• `Readonly` **isSystemRequest**: `boolean` - -Whether or not the request is a "system request" rather than an application-level request. -Can be set on the client using the `HttpFetchOptions#asSystemRequest` option. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:112 - -___ - -### params - -• `Readonly` **params**: `Params` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:64 - -___ - -### query - -• `Readonly` **query**: `Query` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:65 - -___ - -### rewrittenUrl - -• `Optional` `Readonly` **rewrittenUrl**: `URL` - -URL rewritten in onPreRouting request interceptor. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:123 - -___ - -### route - -• `Readonly` **route**: `Readonly`<{ `method`: `RecursiveReadonly`<`Method`\> ; `options`: `RecursiveReadonly`<[`KibanaRequestRouteOptions`](../modules/client._internal_namespace.md#kibanarequestrouteoptions)<`Method`\>\> ; `path`: `string` }\> - -matched route details - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:101 - -___ - -### socket - -• `Readonly` **socket**: [`IKibanaSocket`](../interfaces/client._internal_namespace.IKibanaSocket.md) - -[IKibanaSocket](../interfaces/client._internal_namespace.IKibanaSocket.md) - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:114 - -___ - -### url - -• `Readonly` **url**: `URL` - -a WHATWG URL standard object. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:99 - -___ - -### uuid - -• `Readonly` **uuid**: `string` - -A UUID to identify this request. - -**`remarks`** -This value is NOT sourced from the incoming request's `X-Opaque-Id` header. it -is always a UUID uniquely identifying the request. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:97 - -___ - -### withoutSecretHeaders - -• `Private` `Readonly` **withoutSecretHeaders**: `any` - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:67 - -___ - -### validate - -▪ `Static` `Private` **validate**: `any` - -Validates the different parts of a request based on the schemas defined for -the route. Builds up the actual params, query and body object that will be -received in the route handler. - -**`internal`** - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:80 - -## Methods - -### from - -▸ `Static` **from**<`P`, `Q`, `B`\>(`req`, `routeSchemas?`, `withoutSecretHeaders?`): [`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`P`, `Q`, `B`, `any`\> - -Factory for creating requests. Validates the request before creating an -instance of a KibanaRequest. - -**`internal`** - -#### Type parameters - -| Name | -| :------ | -| `P` | -| `Q` | -| `B` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `req` | `Request` | -| `routeSchemas?` | [`RouteValidator`](client._internal_namespace.RouteValidator.md)<`P`, `Q`, `B`\> \| [`RouteValidatorFullConfig`](../modules/client._internal_namespace.md#routevalidatorfullconfig)<`P`, `Q`, `B`\> | -| `withoutSecretHeaders?` | `boolean` | - -#### Returns - -[`KibanaRequest`](client._internal_namespace.KibanaRequest.md)<`P`, `Q`, `B`, `any`\> - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:73 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.LicenseState.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.LicenseState.md deleted file mode 100644 index 9b8af11cd73cf..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.LicenseState.md +++ /dev/null @@ -1,215 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / LicenseState - -# Class: LicenseState - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).LicenseState - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.LicenseState.md#constructor) - -### Properties - -- [\_notifyUsage](client._internal_namespace.LicenseState.md#_notifyusage) -- [license](client._internal_namespace.LicenseState.md#license) -- [licenseInformation](client._internal_namespace.LicenseState.md#licenseinformation) -- [notifyUsage](client._internal_namespace.LicenseState.md#notifyusage) -- [subscription](client._internal_namespace.LicenseState.md#subscription) -- [updateInformation](client._internal_namespace.LicenseState.md#updateinformation) - -### Methods - -- [checkLicense](client._internal_namespace.LicenseState.md#checklicense) -- [clean](client._internal_namespace.LicenseState.md#clean) -- [ensureLicenseForActionType](client._internal_namespace.LicenseState.md#ensurelicenseforactiontype) -- [getLicenseInformation](client._internal_namespace.LicenseState.md#getlicenseinformation) -- [isLicenseValidForActionType](client._internal_namespace.LicenseState.md#islicensevalidforactiontype) -- [setNotifyUsage](client._internal_namespace.LicenseState.md#setnotifyusage) - -## Constructors - -### constructor - -• **new LicenseState**(`license$`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `license$` | `Observable`<[`ILicense`](../interfaces/client._internal_namespace.ILicense.md)\> | - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:17 - -## Properties - -### \_notifyUsage - -• `Private` **\_notifyUsage**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:16 - -___ - -### license - -• `Private` `Optional` **license**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:15 - -___ - -### licenseInformation - -• `Private` **licenseInformation**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:13 - -___ - -### notifyUsage - -• `Private` **notifyUsage**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:30 - -___ - -### subscription - -• `Private` **subscription**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:14 - -___ - -### updateInformation - -• `Private` **updateInformation**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:18 - -## Methods - -### checkLicense - -▸ **checkLicense**(`license`): [`ActionsLicenseInformation`](../interfaces/client._internal_namespace.ActionsLicenseInformation.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `license` | `undefined` \| [`ILicense`](../interfaces/client._internal_namespace.ILicense.md) | - -#### Returns - -[`ActionsLicenseInformation`](../interfaces/client._internal_namespace.ActionsLicenseInformation.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:32 - -___ - -### clean - -▸ **clean**(): `void` - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:20 - -___ - -### ensureLicenseForActionType - -▸ **ensureLicenseForActionType**(`actionType`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionType` | [`ActionType`](../interfaces/client._internal_namespace.ActionType-1.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig), [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets), [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams), `void`\> | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:31 - -___ - -### getLicenseInformation - -▸ **getLicenseInformation**(): [`ActionsLicenseInformation`](../interfaces/client._internal_namespace.ActionsLicenseInformation.md) - -#### Returns - -[`ActionsLicenseInformation`](../interfaces/client._internal_namespace.ActionsLicenseInformation.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:21 - -___ - -### isLicenseValidForActionType - -▸ **isLicenseValidForActionType**(`actionType`, `__namedParameters?`): { `isValid`: ``true`` } \| { `isValid`: ``false`` ; `reason`: ``"unavailable"`` \| ``"expired"`` \| ``"invalid"`` } - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionType` | [`ActionType`](../interfaces/client._internal_namespace.ActionType-1.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig), [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets), [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams), `void`\> | -| `__namedParameters?` | `Object` | -| `__namedParameters.notifyUsage` | `boolean` | - -#### Returns - -{ `isValid`: ``true`` } \| { `isValid`: ``false`` ; `reason`: ``"unavailable"`` \| ``"expired"`` \| ``"invalid"`` } - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:22 - -___ - -### setNotifyUsage - -▸ **setNotifyUsage**(`notifyUsage`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `notifyUsage` | (`featureName`: `string`, `usedAt?`: `number` \| `Date`) => `void` | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:19 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidationError.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidationError.md deleted file mode 100644 index a9fcf909bd74a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidationError.md +++ /dev/null @@ -1,40 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteValidationError - -# Class: RouteValidationError - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteValidationError - -Error to return when the validation is not successful. - -## Hierarchy - -- `SchemaTypeError` - - ↳ **`RouteValidationError`** - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.RouteValidationError.md#constructor) - -## Constructors - -### constructor - -• **new RouteValidationError**(`error`, `path?`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `string` \| `Error` | -| `path?` | `string`[] | - -#### Overrides - -SchemaTypeError.constructor - -#### Defined in - -src/core/target/types/server/http/router/validator/validator_error.d.ts:7 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidator.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidator.md deleted file mode 100644 index bf73fbda85719..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.RouteValidator.md +++ /dev/null @@ -1,272 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteValidator - -# Class: RouteValidator - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteValidator - -Route validator class to define the validation logic for each new route. - -**`internal`** - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `P` | {} | -| `Q` | {} | -| `B` | {} | - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.RouteValidator.md#constructor) - -### Properties - -- [config](client._internal_namespace.RouteValidator.md#config) -- [customValidation](client._internal_namespace.RouteValidator.md#customvalidation) -- [options](client._internal_namespace.RouteValidator.md#options) -- [preValidateSchema](client._internal_namespace.RouteValidator.md#prevalidateschema) -- [safetyPostchecks](client._internal_namespace.RouteValidator.md#safetypostchecks) -- [safetyPrechecks](client._internal_namespace.RouteValidator.md#safetyprechecks) -- [validate](client._internal_namespace.RouteValidator.md#validate) -- [validateFunction](client._internal_namespace.RouteValidator.md#validatefunction) -- [ResultFactory](client._internal_namespace.RouteValidator.md#resultfactory) - -### Methods - -- [getBody](client._internal_namespace.RouteValidator.md#getbody) -- [getParams](client._internal_namespace.RouteValidator.md#getparams) -- [getQuery](client._internal_namespace.RouteValidator.md#getquery) -- [hasBody](client._internal_namespace.RouteValidator.md#hasbody) -- [from](client._internal_namespace.RouteValidator.md#from) - -## Constructors - -### constructor - -• `Private` **new RouteValidator**<`P`, `Q`, `B`\>() - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `P` | {} | -| `Q` | {} | -| `B` | {} | - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:112 - -## Properties - -### config - -• `Private` `Readonly` **config**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:108 - -___ - -### customValidation - -• `Private` **customValidation**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:136 - -___ - -### options - -• `Private` `Readonly` **options**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:109 - -___ - -### preValidateSchema - -• `Private` **preValidateSchema**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:138 - -___ - -### safetyPostchecks - -• `Private` **safetyPostchecks**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:135 - -___ - -### safetyPrechecks - -• `Private` **safetyPrechecks**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:134 - -___ - -### validate - -• `Private` **validate**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:133 - -___ - -### validateFunction - -• `Private` **validateFunction**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:137 - -___ - -### ResultFactory - -▪ `Static` `Private` **ResultFactory**: `any` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:111 - -## Methods - -### getBody - -▸ **getBody**(`data`, `namespace?`): `Readonly`<`B`\> - -Get validated body - -**`internal`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `data` | `unknown` | -| `namespace?` | `string` | - -#### Returns - -`Readonly`<`B`\> - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:127 - -___ - -### getParams - -▸ **getParams**(`data`, `namespace?`): `Readonly`<`P`\> - -Get validated URL params - -**`internal`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `data` | `unknown` | -| `namespace?` | `string` | - -#### Returns - -`Readonly`<`P`\> - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:117 - -___ - -### getQuery - -▸ **getQuery**(`data`, `namespace?`): `Readonly`<`Q`\> - -Get validated query params - -**`internal`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `data` | `unknown` | -| `namespace?` | `string` | - -#### Returns - -`Readonly`<`Q`\> - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:122 - -___ - -### hasBody - -▸ **hasBody**(): `boolean` - -Has body validation - -**`internal`** - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:132 - -___ - -### from - -▸ `Static` **from**<`_P`, `_Q`, `_B`\>(`opts`): [`RouteValidator`](client._internal_namespace.RouteValidator.md)<`_P`, `_Q`, `_B`\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `_P` | {} | -| `_Q` | {} | -| `_B` | {} | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `opts` | [`RouteValidator`](client._internal_namespace.RouteValidator.md)<`_P`, `_Q`, `_B`\> \| [`RouteValidatorFullConfig`](../modules/client._internal_namespace.md#routevalidatorfullconfig)<`_P`, `_Q`, `_B`\> | - -#### Returns - -[`RouteValidator`](client._internal_namespace.RouteValidator.md)<`_P`, `_Q`, `_B`\> - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:110 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectActions.md deleted file mode 100644 index cced678be25cc..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectActions.md +++ /dev/null @@ -1,66 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectActions - -# Class: SavedObjectActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SavedObjectActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.SavedObjectActions.md#prefix) - -### Methods - -- [get](client._internal_namespace.SavedObjectActions.md#get) - -## Constructors - -### constructor - -• **new SavedObjectActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/saved_object.d.ts:3 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/saved_object.d.ts:2 - -## Methods - -### get - -▸ **get**(`type`, `operation`): `string` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `operation` | `string` | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/saved_object.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectTypeRegistry.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectTypeRegistry.md deleted file mode 100644 index bc38c9d6773b1..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectTypeRegistry.md +++ /dev/null @@ -1,306 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectTypeRegistry - -# Class: SavedObjectTypeRegistry - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectTypeRegistry - -Registry holding information about all the registered [saved object types](../interfaces/client._internal_namespace.SavedObjectsType.md). - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SavedObjectTypeRegistry.md#constructor) - -### Properties - -- [types](client._internal_namespace.SavedObjectTypeRegistry.md#types) - -### Methods - -- [getAllTypes](client._internal_namespace.SavedObjectTypeRegistry.md#getalltypes) -- [getImportableAndExportableTypes](client._internal_namespace.SavedObjectTypeRegistry.md#getimportableandexportabletypes) -- [getIndex](client._internal_namespace.SavedObjectTypeRegistry.md#getindex) -- [getType](client._internal_namespace.SavedObjectTypeRegistry.md#gettype) -- [getVisibleTypes](client._internal_namespace.SavedObjectTypeRegistry.md#getvisibletypes) -- [isHidden](client._internal_namespace.SavedObjectTypeRegistry.md#ishidden) -- [isImportableAndExportable](client._internal_namespace.SavedObjectTypeRegistry.md#isimportableandexportable) -- [isMultiNamespace](client._internal_namespace.SavedObjectTypeRegistry.md#ismultinamespace) -- [isNamespaceAgnostic](client._internal_namespace.SavedObjectTypeRegistry.md#isnamespaceagnostic) -- [isShareable](client._internal_namespace.SavedObjectTypeRegistry.md#isshareable) -- [isSingleNamespace](client._internal_namespace.SavedObjectTypeRegistry.md#issinglenamespace) -- [registerType](client._internal_namespace.SavedObjectTypeRegistry.md#registertype) - -## Constructors - -### constructor - -• **new SavedObjectTypeRegistry**() - -## Properties - -### types - -• `Private` `Readonly` **types**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:14 - -## Methods - -### getAllTypes - -▸ **getAllTypes**(): [`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\>[] - -Return all [types](../interfaces/client._internal_namespace.SavedObjectsType.md) currently registered, including the hidden ones. - -To only get the visible types (which is the most common use case), use `getVisibleTypes` instead. - -#### Returns - -[`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:35 - -___ - -### getImportableAndExportableTypes - -▸ **getImportableAndExportableTypes**(): [`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\>[] - -Return all [types](../interfaces/client._internal_namespace.SavedObjectsType.md) currently registered that are importable/exportable. - -#### Returns - -[`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:39 - -___ - -### getIndex - -▸ **getIndex**(`type`): `undefined` \| `string` - -Returns the `indexPattern` property for given type, or `undefined` if -the type is not registered. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`undefined` \| `string` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:69 - -___ - -### getType - -▸ **getType**(`type`): `undefined` \| [`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\> - -Return the [type](../interfaces/client._internal_namespace.SavedObjectsType.md) definition for given type name. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`undefined` \| [`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\> - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:23 - -___ - -### getVisibleTypes - -▸ **getVisibleTypes**(): [`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\>[] - -Returns all visible [types](../interfaces/client._internal_namespace.SavedObjectsType.md). - -A visible type is a type that doesn't explicitly define `hidden=true` during registration. - -#### Returns - -[`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:29 - -___ - -### isHidden - -▸ **isHidden**(`type`): `boolean` - -Returns the `hidden` property for given type, or `false` if -the type is not registered. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:64 - -___ - -### isImportableAndExportable - -▸ **isImportableAndExportable**(`type`): `boolean` - -Returns the `management.importableAndExportable` property for given type, or -`false` if the type is not registered or does not define a management section. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:74 - -___ - -### isMultiNamespace - -▸ **isMultiNamespace**(`type`): `boolean` - -Returns whether the type is multi-namespace (shareable *or* isolated); -resolves to `false` if the type is not registered - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:54 - -___ - -### isNamespaceAgnostic - -▸ **isNamespaceAgnostic**(`type`): `boolean` - -Returns whether the type is namespace-agnostic (global); -resolves to `false` if the type is not registered - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:44 - -___ - -### isShareable - -▸ **isShareable**(`type`): `boolean` - -Returns whether the type is multi-namespace (shareable); -resolves to `false` if the type is not registered - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:59 - -___ - -### isSingleNamespace - -▸ **isSingleNamespace**(`type`): `boolean` - -Returns whether the type is single-namespace (isolated); -resolves to `true` if the type is not registered - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:49 - -___ - -### registerType - -▸ **registerType**(`type`): `void` - -Register a [type](../interfaces/client._internal_namespace.SavedObjectsType.md) inside the registry. -A type can only be registered once. subsequent calls with the same type name will throw an error. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | [`SavedObjectsType`](../interfaces/client._internal_namespace.SavedObjectsType.md)<`any`\> | - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:19 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsClient.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsClient.md deleted file mode 100644 index 1d97deadff81a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsClient.md +++ /dev/null @@ -1,617 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsClient - -# Class: SavedObjectsClient - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsClient - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SavedObjectsClient.md#constructor) - -### Properties - -- [\_repository](client._internal_namespace.SavedObjectsClient.md#_repository) -- [errors](client._internal_namespace.SavedObjectsClient.md#errors) -- [errors](client._internal_namespace.SavedObjectsClient.md#errors) - -### Methods - -- [bulkCreate](client._internal_namespace.SavedObjectsClient.md#bulkcreate) -- [bulkGet](client._internal_namespace.SavedObjectsClient.md#bulkget) -- [bulkResolve](client._internal_namespace.SavedObjectsClient.md#bulkresolve) -- [bulkUpdate](client._internal_namespace.SavedObjectsClient.md#bulkupdate) -- [checkConflicts](client._internal_namespace.SavedObjectsClient.md#checkconflicts) -- [closePointInTime](client._internal_namespace.SavedObjectsClient.md#closepointintime) -- [collectMultiNamespaceReferences](client._internal_namespace.SavedObjectsClient.md#collectmultinamespacereferences) -- [create](client._internal_namespace.SavedObjectsClient.md#create) -- [createPointInTimeFinder](client._internal_namespace.SavedObjectsClient.md#createpointintimefinder) -- [delete](client._internal_namespace.SavedObjectsClient.md#delete) -- [find](client._internal_namespace.SavedObjectsClient.md#find) -- [get](client._internal_namespace.SavedObjectsClient.md#get) -- [openPointInTimeForType](client._internal_namespace.SavedObjectsClient.md#openpointintimefortype) -- [removeReferencesTo](client._internal_namespace.SavedObjectsClient.md#removereferencesto) -- [resolve](client._internal_namespace.SavedObjectsClient.md#resolve) -- [update](client._internal_namespace.SavedObjectsClient.md#update) -- [updateObjectsSpaces](client._internal_namespace.SavedObjectsClient.md#updateobjectsspaces) - -## Constructors - -### constructor - -• **new SavedObjectsClient**(`repository`) - -**`internal`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `repository` | [`ISavedObjectsRepository`](../modules/client._internal_namespace.md#isavedobjectsrepository) | - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:371 - -## Properties - -### \_repository - -• `Private` **\_repository**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:369 - -___ - -### errors - -• **errors**: typeof [`SavedObjectsErrorHelpers`](client._internal_namespace.SavedObjectsErrorHelpers.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:368 - -___ - -### errors - -▪ `Static` **errors**: typeof [`SavedObjectsErrorHelpers`](client._internal_namespace.SavedObjectsErrorHelpers.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:367 - -## Methods - -### bulkCreate - -▸ **bulkCreate**<`T`\>(`objects`, `options?`): `Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -Persists multiple documents batched together as a single request - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects` | [`SavedObjectsBulkCreateObject`](../interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md)<`T`\>[] | -| `options?` | [`SavedObjectsCreateOptions`](../interfaces/client._internal_namespace.SavedObjectsCreateOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:386 - -___ - -### bulkGet - -▸ **bulkGet**<`T`\>(`objects?`, `options?`): `Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -Returns an array of objects by id - -**`example`** - -bulkGet([ - { id: 'one', type: 'config' }, - { id: 'foo', type: 'index-pattern' } -]) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects?` | [`SavedObjectsBulkGetObject`](../interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md)[] | an array of ids, or an array of objects containing id, type and optionally fields | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:420 - -___ - -### bulkResolve - -▸ **bulkResolve**<`T`\>(`objects`, `options?`): `Promise`<[`SavedObjectsBulkResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md)<`T`\>\> - -Resolves an array of objects by id, using any legacy URL aliases if they exist - -**`example`** - -bulkResolve([ - { id: 'one', type: 'config' }, - { id: 'foo', type: 'index-pattern' } -]) - -**`note`** Saved objects that Kibana fails to find are replaced with an error object and an "exactMatch" outcome. The rationale behind the -outcome is that "exactMatch" is the default outcome, and the outcome only changes if an alias is found. This behavior is unique to -`bulkResolve`; the regular `resolve` API will throw an error instead. - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects` | [`SavedObjectsBulkResolveObject`](../interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md)[] | an array of objects containing id, type | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsBulkResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:444 - -___ - -### bulkUpdate - -▸ **bulkUpdate**<`T`\>(`objects`, `options?`): `Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<`T`\>\> - -Bulk Updates multiple SavedObject at once - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects` | [`SavedObjectsBulkUpdateObject`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md)<`T`\>[] | -| `options?` | [`SavedObjectsBulkUpdateOptions`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:466 - -___ - -### checkConflicts - -▸ **checkConflicts**(`objects?`, `options?`): `Promise`<[`SavedObjectsCheckConflictsResponse`](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md)\> - -Check what conflicts will result when creating a given array of saved objects. This includes "unresolvable conflicts", which are -multi-namespace objects that exist in a different namespace; such conflicts cannot be resolved/overwritten. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects?` | [`SavedObjectsCheckConflictsObject`](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md)[] | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsCheckConflictsResponse`](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:394 - -___ - -### closePointInTime - -▸ **closePointInTime**(`id`, `options?`): `Promise`<[`SavedObjectsClosePointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md)\> - -Closes a Point In Time (PIT) by ID. This simply proxies the request to ES via the -Elasticsearch client, and is included in the Saved Objects Client as a convenience -for consumers who are using [SavedObjectsClient.openPointInTimeForType](client._internal_namespace.SavedObjectsClient.md#openpointintimefortype). - -Only use this API if you have an advanced use case that's not solved by the -[SavedObjectsClient.createPointInTimeFinder](client._internal_namespace.SavedObjectsClient.md#createpointintimefinder) method. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `string` | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsClosePointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:488 - -___ - -### collectMultiNamespaceReferences - -▸ **collectMultiNamespaceReferences**(`objects`, `options?`): `Promise`<[`SavedObjectsCollectMultiNamespaceReferencesResponse`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md)\> - -Gets all references and transitive references of the listed objects. Ignores any object that is not a multi-namespace type. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects` | [`SavedObjectsCollectMultiNamespaceReferencesObject`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md)[] | -| `options?` | [`SavedObjectsCollectMultiNamespaceReferencesOptions`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsCollectMultiNamespaceReferencesResponse`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:541 - -___ - -### create - -▸ **create**<`T`\>(`type`, `attributes`, `options?`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -Persists a SavedObject - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `attributes` | `T` | -| `options?` | [`SavedObjectsCreateOptions`](../interfaces/client._internal_namespace.SavedObjectsCreateOptions.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:379 - -___ - -### createPointInTimeFinder - -▸ **createPointInTimeFinder**<`T`, `A`\>(`findOptions`, `dependencies?`): [`ISavedObjectsPointInTimeFinder`](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md)<`T`, `A`\> - -Returns a [ISavedObjectsPointInTimeFinder](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md) to help page through -large sets of saved objects. We strongly recommend using this API for -any `find` queries that might return more than 1000 saved objects, -however this API is only intended for use in server-side "batch" -processing of objects where you are collecting all objects in memory -or streaming them back to the client. - -Do NOT use this API in a route handler to facilitate paging through -saved objects on the client-side unless you are streaming all of the -results back to the client at once. Because the returned generator is -stateful, you cannot rely on subsequent http requests retrieving new -pages from the same Kibana server in multi-instance deployments. - -The generator wraps calls to [SavedObjectsClient.find](client._internal_namespace.SavedObjectsClient.md#find) and iterates -over multiple pages of results using `_pit` and `search_after`. This will -open a new Point-In-Time (PIT), and continue paging until a set of -results is received that's smaller than the designated `perPage`. - -Once you have retrieved all of the results you need, it is recommended -to call `close()` to clean up the PIT and prevent Elasticsearch from -consuming resources unnecessarily. This is only required if you are -done iterating and have not yet paged through all of the results: the -PIT will automatically be closed for you once you reach the last page -of results, or if the underlying call to `find` fails for any reason. - -**`example`** -```ts -const findOptions: SavedObjectsCreatePointInTimeFinderOptions = { - type: 'visualization', - search: 'foo*', - perPage: 100, -}; - -const finder = savedObjectsClient.createPointInTimeFinder(findOptions); - -const responses: SavedObjectFindResponse[] = []; -for await (const response of finder.find()) { - responses.push(...response); - if (doneSearching) { - await finder.close(); - } -} -``` - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | -| `A` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `findOptions` | [`SavedObjectsCreatePointInTimeFinderOptions`](../modules/client._internal_namespace.md#savedobjectscreatepointintimefinderoptions) | -| `dependencies?` | [`SavedObjectsCreatePointInTimeFinderDependencies`](../interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md) | - -#### Returns - -[`ISavedObjectsPointInTimeFinder`](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md)<`T`, `A`\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:534 - -___ - -### delete - -▸ **delete**(`type`, `id`, `options?`): `Promise`<{}\> - -Deletes a SavedObject - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsDeleteOptions`](../interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md) | - -#### Returns - -`Promise`<{}\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:402 - -___ - -### find - -▸ **find**<`T`, `A`\>(`options`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<`T`, `A`\>\> - -Find all SavedObjects matching the search query - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | -| `A` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `options` | [`SavedObjectsFindOptions`](../interfaces/client._internal_namespace.SavedObjectsFindOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<`T`, `A`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:408 - -___ - -### get - -▸ **get**<`T`\>(`type`, `id`, `options?`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -Retrieves a single object - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `type` | `string` | The type of SavedObject to retrieve | -| `id` | `string` | The ID of the SavedObject to retrieve | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:428 - -___ - -### openPointInTimeForType - -▸ **openPointInTimeForType**(`type`, `options?`): `Promise`<[`SavedObjectsOpenPointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md)\> - -Opens a Point In Time (PIT) against the indices for the specified Saved Object types. -The returned `id` can then be passed to [SavedObjectsClient.find](client._internal_namespace.SavedObjectsClient.md#find) to search -against that PIT. - -Only use this API if you have an advanced use case that's not solved by the -[SavedObjectsClient.createPointInTimeFinder](client._internal_namespace.SavedObjectsClient.md#createpointintimefinder) method. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` \| `string`[] | -| `options?` | [`SavedObjectsOpenPointInTimeOptions`](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsOpenPointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:479 - -___ - -### removeReferencesTo - -▸ **removeReferencesTo**(`type`, `id`, `options?`): `Promise`<[`SavedObjectsRemoveReferencesToResponse`](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md)\> - -Updates all objects containing a reference to the given {type, id} tuple to remove the said reference. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsRemoveReferencesToOptions`](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsRemoveReferencesToResponse`](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:470 - -___ - -### resolve - -▸ **resolve**<`T`\>(`type`, `id`, `options?`): `Promise`<[`SavedObjectsResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md)<`T`\>\> - -Resolves a single object, using any legacy URL alias if it exists - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `type` | `string` | The type of SavedObject to retrieve | -| `id` | `string` | The ID of the SavedObject to retrieve | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | | - -#### Returns - -`Promise`<[`SavedObjectsResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:452 - -___ - -### update - -▸ **update**<`T`\>(`type`, `id`, `attributes`, `options?`): `Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<`T`\>\> - -Updates an SavedObject - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `attributes` | `Partial`<`T`\> | -| `options?` | [`SavedObjectsUpdateOptions`](../interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md)<`T`\> | - -#### Returns - -`Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:460 - -___ - -### updateObjectsSpaces - -▸ **updateObjectsSpaces**(`objects`, `spacesToAdd`, `spacesToRemove`, `options?`): `Promise`<[`SavedObjectsUpdateObjectsSpacesResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md)\> - -Updates one or more objects to add and/or remove them from specified spaces. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects` | [`SavedObjectsUpdateObjectsSpacesObject`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md)[] | -| `spacesToAdd` | `string`[] | -| `spacesToRemove` | `string`[] | -| `options?` | [`SavedObjectsUpdateObjectsSpacesOptions`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsUpdateObjectsSpacesResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:550 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsErrorHelpers.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsErrorHelpers.md deleted file mode 100644 index c428ccb237f1b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsErrorHelpers.md +++ /dev/null @@ -1,665 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsErrorHelpers - -# Class: SavedObjectsErrorHelpers - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsErrorHelpers - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SavedObjectsErrorHelpers.md#constructor) - -### Methods - -- [createBadRequestError](client._internal_namespace.SavedObjectsErrorHelpers.md#createbadrequesterror) -- [createConflictError](client._internal_namespace.SavedObjectsErrorHelpers.md#createconflicterror) -- [createGenericNotFoundError](client._internal_namespace.SavedObjectsErrorHelpers.md#creategenericnotfounderror) -- [createGenericNotFoundEsUnavailableError](client._internal_namespace.SavedObjectsErrorHelpers.md#creategenericnotfoundesunavailableerror) -- [createIndexAliasNotFoundError](client._internal_namespace.SavedObjectsErrorHelpers.md#createindexaliasnotfounderror) -- [createInvalidVersionError](client._internal_namespace.SavedObjectsErrorHelpers.md#createinvalidversionerror) -- [createTooManyRequestsError](client._internal_namespace.SavedObjectsErrorHelpers.md#createtoomanyrequestserror) -- [createUnsupportedTypeError](client._internal_namespace.SavedObjectsErrorHelpers.md#createunsupportedtypeerror) -- [decorateBadRequestError](client._internal_namespace.SavedObjectsErrorHelpers.md#decoratebadrequesterror) -- [decorateConflictError](client._internal_namespace.SavedObjectsErrorHelpers.md#decorateconflicterror) -- [decorateEsCannotExecuteScriptError](client._internal_namespace.SavedObjectsErrorHelpers.md#decorateescannotexecutescripterror) -- [decorateEsUnavailableError](client._internal_namespace.SavedObjectsErrorHelpers.md#decorateesunavailableerror) -- [decorateForbiddenError](client._internal_namespace.SavedObjectsErrorHelpers.md#decorateforbiddenerror) -- [decorateGeneralError](client._internal_namespace.SavedObjectsErrorHelpers.md#decorategeneralerror) -- [decorateIndexAliasNotFoundError](client._internal_namespace.SavedObjectsErrorHelpers.md#decorateindexaliasnotfounderror) -- [decorateNotAuthorizedError](client._internal_namespace.SavedObjectsErrorHelpers.md#decoratenotauthorizederror) -- [decorateRequestEntityTooLargeError](client._internal_namespace.SavedObjectsErrorHelpers.md#decoraterequestentitytoolargeerror) -- [decorateTooManyRequestsError](client._internal_namespace.SavedObjectsErrorHelpers.md#decoratetoomanyrequestserror) -- [isBadRequestError](client._internal_namespace.SavedObjectsErrorHelpers.md#isbadrequesterror) -- [isConflictError](client._internal_namespace.SavedObjectsErrorHelpers.md#isconflicterror) -- [isEsCannotExecuteScriptError](client._internal_namespace.SavedObjectsErrorHelpers.md#isescannotexecutescripterror) -- [isEsUnavailableError](client._internal_namespace.SavedObjectsErrorHelpers.md#isesunavailableerror) -- [isForbiddenError](client._internal_namespace.SavedObjectsErrorHelpers.md#isforbiddenerror) -- [isGeneralError](client._internal_namespace.SavedObjectsErrorHelpers.md#isgeneralerror) -- [isInvalidVersionError](client._internal_namespace.SavedObjectsErrorHelpers.md#isinvalidversionerror) -- [isNotAuthorizedError](client._internal_namespace.SavedObjectsErrorHelpers.md#isnotauthorizederror) -- [isNotFoundError](client._internal_namespace.SavedObjectsErrorHelpers.md#isnotfounderror) -- [isRequestEntityTooLargeError](client._internal_namespace.SavedObjectsErrorHelpers.md#isrequestentitytoolargeerror) -- [isSavedObjectsClientError](client._internal_namespace.SavedObjectsErrorHelpers.md#issavedobjectsclienterror) -- [isTooManyRequestsError](client._internal_namespace.SavedObjectsErrorHelpers.md#istoomanyrequestserror) - -## Constructors - -### constructor - -• **new SavedObjectsErrorHelpers**() - -## Methods - -### createBadRequestError - -▸ `Static` **createBadRequestError**(`reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:12 - -___ - -### createConflictError - -▸ `Static` **createConflictError**(`type`, `id`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:28 - -___ - -### createGenericNotFoundError - -▸ `Static` **createGenericNotFoundError**(`type?`, `id?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type?` | ``null`` \| `string` | -| `id?` | ``null`` \| `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:23 - -___ - -### createGenericNotFoundEsUnavailableError - -▸ `Static` **createGenericNotFoundEsUnavailableError**(`type?`, `id?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type?` | ``null`` \| `string` | -| `id?` | ``null`` \| `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:39 - -___ - -### createIndexAliasNotFoundError - -▸ `Static` **createIndexAliasNotFoundError**(`alias`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `alias` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:24 - -___ - -### createInvalidVersionError - -▸ `Static` **createInvalidVersionError**(`versionInput?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionInput?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:15 - -___ - -### createTooManyRequestsError - -▸ `Static` **createTooManyRequestsError**(`type`, `id`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:31 - -___ - -### createUnsupportedTypeError - -▸ `Static` **createUnsupportedTypeError**(`type`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:13 - -___ - -### decorateBadRequestError - -▸ `Static` **decorateBadRequestError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:11 - -___ - -### decorateConflictError - -▸ `Static` **decorateConflictError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:27 - -___ - -### decorateEsCannotExecuteScriptError - -▸ `Static` **decorateEsCannotExecuteScriptError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:33 - -___ - -### decorateEsUnavailableError - -▸ `Static` **decorateEsUnavailableError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:35 - -___ - -### decorateForbiddenError - -▸ `Static` **decorateForbiddenError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:19 - -___ - -### decorateGeneralError - -▸ `Static` **decorateGeneralError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:37 - -___ - -### decorateIndexAliasNotFoundError - -▸ `Static` **decorateIndexAliasNotFoundError**(`error`, `alias`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `alias` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:25 - -___ - -### decorateNotAuthorizedError - -▸ `Static` **decorateNotAuthorizedError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:17 - -___ - -### decorateRequestEntityTooLargeError - -▸ `Static` **decorateRequestEntityTooLargeError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:21 - -___ - -### decorateTooManyRequestsError - -▸ `Static` **decorateTooManyRequestsError**(`error`, `reason?`): [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `Error` | -| `reason?` | `string` | - -#### Returns - -[`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:30 - -___ - -### isBadRequestError - -▸ `Static` **isBadRequestError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:14 - -___ - -### isConflictError - -▸ `Static` **isConflictError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:29 - -___ - -### isEsCannotExecuteScriptError - -▸ `Static` **isEsCannotExecuteScriptError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:34 - -___ - -### isEsUnavailableError - -▸ `Static` **isEsUnavailableError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:36 - -___ - -### isForbiddenError - -▸ `Static` **isForbiddenError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:20 - -___ - -### isGeneralError - -▸ `Static` **isGeneralError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:38 - -___ - -### isInvalidVersionError - -▸ `Static` **isInvalidVersionError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:16 - -___ - -### isNotAuthorizedError - -▸ `Static` **isNotAuthorizedError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:18 - -___ - -### isNotFoundError - -▸ `Static` **isNotFoundError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:26 - -___ - -### isRequestEntityTooLargeError - -▸ `Static` **isRequestEntityTooLargeError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:22 - -___ - -### isSavedObjectsClientError - -▸ `Static` **isSavedObjectsClientError**(`error`): error is DecoratedError - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `any` | - -#### Returns - -error is DecoratedError - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:10 - -___ - -### isTooManyRequestsError - -▸ `Static` **isTooManyRequestsError**(`error`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | [`DecoratedError`](../interfaces/client._internal_namespace.DecoratedError.md) \| `Error` | - -#### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:32 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsRepository.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsRepository.md deleted file mode 100644 index 967fa67b35640..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SavedObjectsRepository.md +++ /dev/null @@ -1,1082 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsRepository - -# Class: SavedObjectsRepository - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsRepository - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SavedObjectsRepository.md#constructor) - -### Properties - -- [\_allowedTypes](client._internal_namespace.SavedObjectsRepository.md#_allowedtypes) -- [\_index](client._internal_namespace.SavedObjectsRepository.md#_index) -- [\_logger](client._internal_namespace.SavedObjectsRepository.md#_logger) -- [\_mappings](client._internal_namespace.SavedObjectsRepository.md#_mappings) -- [\_migrator](client._internal_namespace.SavedObjectsRepository.md#_migrator) -- [\_rawToSavedObject](client._internal_namespace.SavedObjectsRepository.md#_rawtosavedobject) -- [\_registry](client._internal_namespace.SavedObjectsRepository.md#_registry) -- [\_serializer](client._internal_namespace.SavedObjectsRepository.md#_serializer) -- [client](client._internal_namespace.SavedObjectsRepository.md#client) -- [getIndexForType](client._internal_namespace.SavedObjectsRepository.md#getindexfortype) -- [getIndicesForTypes](client._internal_namespace.SavedObjectsRepository.md#getindicesfortypes) -- [incrementCounterInternal](client._internal_namespace.SavedObjectsRepository.md#incrementcounterinternal) -- [preflightCheckForUpsertAliasConflict](client._internal_namespace.SavedObjectsRepository.md#preflightcheckforupsertaliasconflict) -- [preflightCheckNamespaces](client._internal_namespace.SavedObjectsRepository.md#preflightchecknamespaces) -- [rawDocExistsInNamespace](client._internal_namespace.SavedObjectsRepository.md#rawdocexistsinnamespace) -- [rawDocExistsInNamespaces](client._internal_namespace.SavedObjectsRepository.md#rawdocexistsinnamespaces) -- [validateInitialNamespaces](client._internal_namespace.SavedObjectsRepository.md#validateinitialnamespaces) -- [validateObjectAttributes](client._internal_namespace.SavedObjectsRepository.md#validateobjectattributes) -- [validateObjectNamespaces](client._internal_namespace.SavedObjectsRepository.md#validateobjectnamespaces) - -### Methods - -- [bulkCreate](client._internal_namespace.SavedObjectsRepository.md#bulkcreate) -- [bulkGet](client._internal_namespace.SavedObjectsRepository.md#bulkget) -- [bulkResolve](client._internal_namespace.SavedObjectsRepository.md#bulkresolve) -- [bulkUpdate](client._internal_namespace.SavedObjectsRepository.md#bulkupdate) -- [checkConflicts](client._internal_namespace.SavedObjectsRepository.md#checkconflicts) -- [closePointInTime](client._internal_namespace.SavedObjectsRepository.md#closepointintime) -- [collectMultiNamespaceReferences](client._internal_namespace.SavedObjectsRepository.md#collectmultinamespacereferences) -- [create](client._internal_namespace.SavedObjectsRepository.md#create) -- [createPointInTimeFinder](client._internal_namespace.SavedObjectsRepository.md#createpointintimefinder) -- [delete](client._internal_namespace.SavedObjectsRepository.md#delete) -- [deleteByNamespace](client._internal_namespace.SavedObjectsRepository.md#deletebynamespace) -- [find](client._internal_namespace.SavedObjectsRepository.md#find) -- [get](client._internal_namespace.SavedObjectsRepository.md#get) -- [incrementCounter](client._internal_namespace.SavedObjectsRepository.md#incrementcounter) -- [openPointInTimeForType](client._internal_namespace.SavedObjectsRepository.md#openpointintimefortype) -- [removeReferencesTo](client._internal_namespace.SavedObjectsRepository.md#removereferencesto) -- [resolve](client._internal_namespace.SavedObjectsRepository.md#resolve) -- [update](client._internal_namespace.SavedObjectsRepository.md#update) -- [updateObjectsSpaces](client._internal_namespace.SavedObjectsRepository.md#updateobjectsspaces) -- [createRepository](client._internal_namespace.SavedObjectsRepository.md#createrepository) - -## Constructors - -### constructor - -• `Private` **new SavedObjectsRepository**() - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:88 - -## Properties - -### \_allowedTypes - -• `Private` **\_allowedTypes**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:75 - -___ - -### \_index - -• `Private` **\_index**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:72 - -___ - -### \_logger - -• `Private` **\_logger**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:78 - -___ - -### \_mappings - -• `Private` **\_mappings**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:73 - -___ - -### \_migrator - -• `Private` **\_migrator**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:71 - -___ - -### \_rawToSavedObject - -• `Private` **\_rawToSavedObject**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:445 - -___ - -### \_registry - -• `Private` **\_registry**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:74 - -___ - -### \_serializer - -• `Private` **\_serializer**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:77 - -___ - -### client - -• `Private` `Readonly` **client**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:76 - -___ - -### getIndexForType - -• `Private` **getIndexForType**: `any` - -Returns index specified by the given type or the default index - -**`param`** the type - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:436 - -___ - -### getIndicesForTypes - -• `Private` **getIndicesForTypes**: `any` - -Returns an array of indices as specified in `this._registry` for each of the -given `types`. If any of the types don't have an associated index, the -default index `this._index` will be included. - -**`param`** The types whose indices should be retrieved - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:444 - -___ - -### incrementCounterInternal - -• `Private` **incrementCounterInternal**: `any` - -**`internal`** incrementCounter function that is used internally and bypasses validation checks. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:305 - -___ - -### preflightCheckForUpsertAliasConflict - -• `Private` **preflightCheckForUpsertAliasConflict**: `any` - -Pre-flight check to ensure that an upsert which would create a new object does not result in an alias conflict. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:455 - -___ - -### preflightCheckNamespaces - -• `Private` **preflightCheckNamespaces**: `any` - -Pre-flight check to ensure that a multi-namespace object exists in the current namespace. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:451 - -___ - -### rawDocExistsInNamespace - -• `Private` **rawDocExistsInNamespace**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:447 - -___ - -### rawDocExistsInNamespaces - -• `Private` **rawDocExistsInNamespaces**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:446 - -___ - -### validateInitialNamespaces - -• `Private` **validateInitialNamespaces**: `any` - -The `initialNamespaces` field (create, bulkCreate) is used to create an object in an initial set of spaces. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:457 - -___ - -### validateObjectAttributes - -• `Private` **validateObjectAttributes**: `any` - -Validate a migrated doc against the registered saved object type's schema. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:461 - -___ - -### validateObjectNamespaces - -• `Private` **validateObjectNamespaces**: `any` - -The object-specific `namespaces` field (bulkGet) is used to check if an object exists in any of a given number of spaces. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:459 - -## Methods - -### bulkCreate - -▸ **bulkCreate**<`T`\>(`objects`, `options?`): `Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -Creates multiple documents at once - -**`property`** {boolean} [options.overwrite=false] - overwrites existing documents - -**`property`** {string} [options.namespace] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects` | [`SavedObjectsBulkCreateObject`](../interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md)<`T`\>[] | [{ type, id, attributes, references, migrationVersion }] | -| `options?` | [`SavedObjectsCreateOptions`](../interfaces/client._internal_namespace.SavedObjectsCreateOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -- {saved_objects: [[{ id, type, version, references, attributes, error: { message } }]} - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:112 - -___ - -### bulkGet - -▸ **bulkGet**<`T`\>(`objects?`, `options?`): `Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -Returns an array of objects by id - -**`property`** {string} [options.namespace] - -**`example`** - -bulkGet([ - { id: 'one', type: 'config' }, - { id: 'foo', type: 'index-pattern' } -]) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects?` | [`SavedObjectsBulkGetObject`](../interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md)[] | an array of objects containing id, type and optionally fields | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsBulkResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md)<`T`\>\> - -- { saved_objects: [{ id, type, version, attributes }] } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:169 - -___ - -### bulkResolve - -▸ **bulkResolve**<`T`\>(`objects`, `options?`): `Promise`<[`SavedObjectsBulkResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md)<`T`\>\> - -Resolves an array of objects by id, using any legacy URL aliases if they exist - -**`property`** {string} [options.namespace] - -**`example`** - -bulkResolve([ - { id: 'one', type: 'config' }, - { id: 'foo', type: 'index-pattern' } -]) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects` | [`SavedObjectsBulkResolveObject`](../interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md)[] | an array of objects containing id, type | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsBulkResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md)<`T`\>\> - -- { resolved_objects: [{ saved_object, outcome }] } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:184 - -___ - -### bulkUpdate - -▸ **bulkUpdate**<`T`\>(`objects`, `options?`): `Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<`T`\>\> - -Updates multiple objects in bulk - -**`property`** {string} options.version - ensures version matches that of persisted object - -**`property`** {string} [options.namespace] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects` | [`SavedObjectsBulkUpdateObject`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md)<`T`\>[] | [{ type, id, attributes, options: { version, namespace } references }] | -| `options?` | [`SavedObjectsBulkUpdateOptions`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsBulkUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md)<`T`\>\> - -- {saved_objects: [[{ id, type, version, references, attributes, error: { message } }]} - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:241 - -___ - -### checkConflicts - -▸ **checkConflicts**(`objects?`, `options?`): `Promise`<[`SavedObjectsCheckConflictsResponse`](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md)\> - -Check what conflicts will result when creating a given array of saved objects. This includes "unresolvable conflicts", which are -multi-namespace objects that exist in a different namespace; such conflicts cannot be resolved/overwritten. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects?` | [`SavedObjectsCheckConflictsObject`](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md)[] | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsCheckConflictsResponse`](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:117 - -___ - -### closePointInTime - -▸ **closePointInTime**(`id`, `options?`): `Promise`<[`SavedObjectsClosePointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md)\> - -Closes a Point In Time (PIT) by ID. This simply proxies the request to ES -via the Elasticsearch client, and is included in the Saved Objects Client -as a convenience for consumers who are using `openPointInTimeForType`. - -Only use this API if you have an advanced use case that's not solved by the -[SavedObjectsRepository.createPointInTimeFinder](client._internal_namespace.SavedObjectsRepository.md#createpointintimefinder) method. - -**`remarks`** -While the `keepAlive` that is provided will cause a PIT to automatically close, -it is highly recommended to explicitly close a PIT when you are done with it -in order to avoid consuming unneeded resources in Elasticsearch. - -**`example`** -```ts -const repository = coreStart.savedObjects.createInternalRepository(); - -const { id } = await repository.openPointInTimeForType( - type: 'index-pattern', - { keepAlive: '2m' }, -); - -const response = await repository.find({ - type: 'index-pattern', - search: 'foo*', - sortField: 'name', - sortOrder: 'desc', - pit: { - id: 'abc123', - keepAlive: '2m', - }, - searchAfter: [1234, 'abcd'], -}); - -await repository.closePointInTime(response.pit_id); -``` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | `string` | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsClosePointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md)\> - -- [SavedObjectsClosePointInTimeResponse](../interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:384 - -___ - -### collectMultiNamespaceReferences - -▸ **collectMultiNamespaceReferences**(`objects`, `options?`): `Promise`<[`SavedObjectsCollectMultiNamespaceReferencesResponse`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md)\> - -Gets all references and transitive references of the given objects. Ignores any object and/or reference that is not a multi-namespace -type. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `objects` | [`SavedObjectsCollectMultiNamespaceReferencesObject`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md)[] | The objects to get the references for. | -| `options?` | [`SavedObjectsCollectMultiNamespaceReferencesOptions`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md) | - | - -#### Returns - -`Promise`<[`SavedObjectsCollectMultiNamespaceReferencesResponse`](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:223 - -___ - -### create - -▸ **create**<`T`\>(`type`, `attributes`, `options?`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -Persists an object - -**`property`** {string} [options.id] - force id on creation, not recommended - -**`property`** {boolean} [options.overwrite=false] - -**`property`** {object} [options.migrationVersion=undefined] - -**`property`** {string} [options.namespace] - -**`property`** {array} [options.references=[]] - [{ name, type, id }] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `attributes` | `T` | -| `options?` | [`SavedObjectsCreateOptions`](../interfaces/client._internal_namespace.SavedObjectsCreateOptions.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -- { id, type, version, attributes } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:102 - -___ - -### createPointInTimeFinder - -▸ **createPointInTimeFinder**<`T`, `A`\>(`findOptions`, `dependencies?`): [`ISavedObjectsPointInTimeFinder`](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md)<`T`, `A`\> - -Returns a [ISavedObjectsPointInTimeFinder](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md) to help page through -large sets of saved objects. We strongly recommend using this API for -any `find` queries that might return more than 1000 saved objects, -however this API is only intended for use in server-side "batch" -processing of objects where you are collecting all objects in memory -or streaming them back to the client. - -Do NOT use this API in a route handler to facilitate paging through -saved objects on the client-side unless you are streaming all of the -results back to the client at once. Because the returned generator is -stateful, you cannot rely on subsequent http requests retrieving new -pages from the same Kibana server in multi-instance deployments. - -This generator wraps calls to [SavedObjectsRepository.find](client._internal_namespace.SavedObjectsRepository.md#find) and -iterates over multiple pages of results using `_pit` and `search_after`. -This will open a new Point-In-Time (PIT), and continue paging until a -set of results is received that's smaller than the designated `perPage`. - -Once you have retrieved all of the results you need, it is recommended -to call `close()` to clean up the PIT and prevent Elasticsearch from -consuming resources unnecessarily. This is only required if you are -done iterating and have not yet paged through all of the results: the -PIT will automatically be closed for you once you reach the last page -of results, or if the underlying call to `find` fails for any reason. - -**`example`** -```ts -const findOptions: SavedObjectsCreatePointInTimeFinderOptions = { - type: 'visualization', - search: 'foo*', - perPage: 100, -}; - -const finder = savedObjectsClient.createPointInTimeFinder(findOptions); - -const responses: SavedObjectFindResponse[] = []; -for await (const response of finder.find()) { - responses.push(...response); - if (doneSearching) { - await finder.close(); - } -} -``` - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | -| `A` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `findOptions` | [`SavedObjectsCreatePointInTimeFinderOptions`](../modules/client._internal_namespace.md#savedobjectscreatepointintimefinderoptions) | -| `dependencies?` | [`SavedObjectsCreatePointInTimeFinderDependencies`](../interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md) | - -#### Returns - -[`ISavedObjectsPointInTimeFinder`](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md)<`T`, `A`\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:430 - -___ - -### delete - -▸ **delete**(`type`, `id`, `options?`): `Promise`<{}\> - -Deletes an object - -**`property`** {string} [options.namespace] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsDeleteOptions`](../interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md) | - -#### Returns - -`Promise`<{}\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:127 - -___ - -### deleteByNamespace - -▸ **deleteByNamespace**(`namespace`, `options?`): `Promise`<`any`\> - -Deletes all objects from the provided namespace. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `namespace` | `string` | -| `options?` | [`SavedObjectsDeleteByNamespaceOptions`](../interfaces/client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md) | - -#### Returns - -`Promise`<`any`\> - -- { took, timed_out, total, deleted, batches, version_conflicts, noops, retries, failures } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:134 - -___ - -### find - -▸ **find**<`T`, `A`\>(`options`): `Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<`T`, `A`\>\> - -**`property`** {(string|Array)} [options.type] - -**`property`** {string} [options.search] - -**`property`** {string} [options.defaultSearchOperator] - -**`property`** {Array} [options.searchFields] - see Elasticsearch Simple Query String - Query field argument for more information - -**`property`** {integer} [options.page=1] - -**`property`** {integer} [options.perPage=20] - -**`property`** {Array} [options.searchAfter] - -**`property`** {string} [options.sortField] - -**`property`** {string} [options.sortOrder] - -**`property`** {Array} [options.fields] - -**`property`** {string} [options.namespace] - -**`property`** {object} [options.hasReference] - { type, id } - -**`property`** {string} [options.pit] - -**`property`** {string} [options.preference] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | -| `A` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `options` | [`SavedObjectsFindOptions`](../interfaces/client._internal_namespace.SavedObjectsFindOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsFindResponse`](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md)<`T`, `A`\>\> - -- { saved_objects: [{ id, type, version, attributes }], total, per_page, page } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:154 - -___ - -### get - -▸ **get**<`T`\>(`type`, `id`, `options?`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -Gets a single object - -**`property`** {string} [options.namespace] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -- { id, type, version, attributes } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:194 - -___ - -### incrementCounter - -▸ **incrementCounter**<`T`\>(`type`, `id`, `counterFields`, `options?`): `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -Increments all the specified counter fields (by one by default). Creates the document -if one doesn't exist for the given id. - -**`remarks`** -When supplying a field name like `stats.api.counter` the field name will -be used as-is to create a document like: - `{attributes: {'stats.api.counter': 1}}` -It will not create a nested structure like: - `{attributes: {stats: {api: {counter: 1}}}}` - -When using incrementCounter for collecting usage data, you need to ensure -that usage collection happens on a best-effort basis and doesn't -negatively affect your plugin or users. See https://github.com/elastic/kibana/blob/main/src/plugins/usage_collection/README.mdx#tracking-interactions-with-incrementcounter) - -**`example`** -```ts -const repository = coreStart.savedObjects.createInternalRepository(); - -// Initialize all fields to 0 -repository - .incrementCounter('dashboard_counter_type', 'counter_id', [ - 'stats.apiCalls', - 'stats.sampleDataInstalled', - ], {initialize: true}); - -// Increment the apiCalls field counter -repository - .incrementCounter('dashboard_counter_type', 'counter_id', [ - 'stats.apiCalls', - ]) - -// Increment the apiCalls field counter by 4 -repository - .incrementCounter('dashboard_counter_type', 'counter_id', [ - { fieldName: 'stats.apiCalls' incrementBy: 4 }, - ]) - -// Initialize the document with arbitrary fields if not present -repository.incrementCounter<{ appId: string }>( - 'dashboard_counter_type', - 'counter_id', - [ 'stats.apiCalls'], - { upsertAttributes: { appId: 'myId' } } -) -``` - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `type` | `string` | The type of saved object whose fields should be incremented | -| `id` | `string` | The id of the document whose fields should be incremented | -| `counterFields` | (`string` \| [`SavedObjectsIncrementCounterField`](../interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md))[] | An array of field names to increment or an array of [SavedObjectsIncrementCounterField](../interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md) | -| `options?` | [`SavedObjectsIncrementCounterOptions`](../interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md)<`T`\> | [SavedObjectsIncrementCounterOptions](../interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md) | - -#### Returns - -`Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>\> - -The saved object after the specified fields were incremented - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:303 - -___ - -### openPointInTimeForType - -▸ **openPointInTimeForType**(`type`, `[options]?`): `Promise`<[`SavedObjectsOpenPointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md)\> - -Opens a Point In Time (PIT) against the indices for the specified Saved Object types. -The returned `id` can then be passed to `SavedObjects.find` to search against that PIT. - -Only use this API if you have an advanced use case that's not solved by the -[SavedObjectsRepository.createPointInTimeFinder](client._internal_namespace.SavedObjectsRepository.md#createpointintimefinder) method. - -**`example`** -```ts -const { id } = await savedObjectsClient.openPointInTimeForType( - type: 'visualization', - { keepAlive: '5m' }, -); -const page1 = await savedObjectsClient.find({ - type: 'visualization', - sortField: 'updated_at', - sortOrder: 'asc', - pit: { id, keepAlive: '2m' }, -}); -const lastHit = page1.saved_objects[page1.saved_objects.length - 1]; -const page2 = await savedObjectsClient.find({ - type: 'visualization', - sortField: 'updated_at', - sortOrder: 'asc', - pit: { id: page1.pit_id }, - searchAfter: lastHit.sort, -}); -await savedObjectsClient.closePointInTime(page2.pit_id); -``` - -**`property`** {string} [options.keepAlive] - -**`property`** {string} [options.preference] - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `type` | `string` \| `string`[] | | -| `[options]?` | [`SavedObjectsOpenPointInTimeOptions`](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md) | [SavedObjectsOpenPointInTimeOptions](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsOpenPointInTimeResponse`](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md)\> - -- { id: string } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:342 - -___ - -### removeReferencesTo - -▸ **removeReferencesTo**(`type`, `id`, `options?`): `Promise`<[`SavedObjectsRemoveReferencesToResponse`](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md)\> - -Updates all objects containing a reference to the given {type, id} tuple to remove the said reference. - -**`remarks`** Will throw a conflict error if the `update_by_query` operation returns any failure. In that case - some references might have been removed, and some were not. It is the caller's responsibility - to handle and fix this situation if it was to happen. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsRemoveReferencesToOptions`](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsRemoveReferencesToResponse`](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:249 - -___ - -### resolve - -▸ **resolve**<`T`\>(`type`, `id`, `options?`): `Promise`<[`SavedObjectsResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md)<`T`\>\> - -Resolves a single object, using any legacy URL alias if it exists - -**`property`** {string} [options.namespace] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsBaseOptions`](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsResolveResponse`](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md)<`T`\>\> - -- { saved_object, outcome } - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:204 - -___ - -### update - -▸ **update**<`T`\>(`type`, `id`, `attributes`, `options?`): `Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<`T`\>\> - -Updates an object - -**`property`** {string} options.version - ensures version matches that of persisted object - -**`property`** {string} [options.namespace] - -**`property`** {array} [options.references] - [{ name, type, id }] - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `attributes` | `Partial`<`T`\> | -| `options?` | [`SavedObjectsUpdateOptions`](../interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md)<`T`\> | - -#### Returns - -`Promise`<[`SavedObjectsUpdateResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md)<`T`\>\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:216 - -___ - -### updateObjectsSpaces - -▸ **updateObjectsSpaces**(`objects`, `spacesToAdd`, `spacesToRemove`, `options?`): `Promise`<[`SavedObjectsUpdateObjectsSpacesResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md)\> - -Updates one or more objects to add and/or remove them from specified spaces. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `objects` | [`SavedObjectsUpdateObjectsSpacesObject`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md)[] | -| `spacesToAdd` | `string`[] | -| `spacesToRemove` | `string`[] | -| `options?` | [`SavedObjectsUpdateObjectsSpacesOptions`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md) | - -#### Returns - -`Promise`<[`SavedObjectsUpdateObjectsSpacesResponse`](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:232 - -___ - -### createRepository - -▸ `Static` **createRepository**(`migrator`, `typeRegistry`, `indexName`, `client`, `logger`, `includedHiddenTypes?`, `injectedConstructor?`): [`ISavedObjectsRepository`](../modules/client._internal_namespace.md#isavedobjectsrepository) - -A factory function for creating SavedObjectRepository instances. - -**`internalremarks`** -Tests are located in ./repository_create_repository.test.ts - -**`internal`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `migrator` | [`IKibanaMigrator`](../modules/client._internal_namespace.md#ikibanamigrator) | -| `typeRegistry` | [`ISavedObjectTypeRegistry`](../modules/client._internal_namespace.md#isavedobjecttyperegistry) | -| `indexName` | `string` | -| `client` | [`ElasticsearchClient`](../modules/client._internal_namespace.md#elasticsearchclient) | -| `logger` | `Logger` | -| `includedHiddenTypes?` | `string`[] | -| `injectedConstructor?` | `any` | - -#### Returns - -[`ISavedObjectsRepository`](../modules/client._internal_namespace.md#isavedobjectsrepository) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:87 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SpaceActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SpaceActions.md deleted file mode 100644 index b39329e27b8ba..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SpaceActions.md +++ /dev/null @@ -1,59 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SpaceActions - -# Class: SpaceActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SpaceActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SpaceActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.SpaceActions.md#prefix) - -### Accessors - -- [manage](client._internal_namespace.SpaceActions.md#manage) - -## Constructors - -### constructor - -• **new SpaceActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/space.d.ts:3 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/space.d.ts:2 - -## Accessors - -### manage - -• `get` **manage**(): `string` - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/space.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SubFeature.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SubFeature.md deleted file mode 100644 index 4e300b2231285..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.SubFeature.md +++ /dev/null @@ -1,97 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SubFeature - -# Class: SubFeature - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SubFeature - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.SubFeature.md#constructor) - -### Properties - -- [config](client._internal_namespace.SubFeature.md#config) - -### Accessors - -- [name](client._internal_namespace.SubFeature.md#name) -- [privilegeGroups](client._internal_namespace.SubFeature.md#privilegegroups) - -### Methods - -- [toRaw](client._internal_namespace.SubFeature.md#toraw) - -## Constructors - -### constructor - -• **new SubFeature**(`config`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `config` | `Readonly`<{ `name`: `string` ; `privilegeGroups`: readonly `Readonly`<{ groupType: SubFeaturePrivilegeGroupType; privileges: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; minimumLicense?: "basic" \| "standard" \| ... 4 more ... \| undefined; ... 9 more ...; ui: readonly string[]; }\>[]; }\>[] }\> | - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:66 - -## Properties - -### config - -• `Protected` `Readonly` **config**: `Readonly`<{ `name`: `string` ; `privilegeGroups`: readonly `Readonly`<{ groupType: SubFeaturePrivilegeGroupType; privileges: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; minimumLicense?: "basic" \| "standard" \| ... 4 more ... \| undefined; ... 9 more ...; ui: readonly string[]; }\>[]; }\>[] }\> - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:65 - -## Accessors - -### name - -• `get` **name**(): `string` - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:67 - -___ - -### privilegeGroups - -• `get` **privilegeGroups**(): readonly `Readonly`<{ `groupType`: [`SubFeaturePrivilegeGroupType`](../modules/client._internal_namespace.md#subfeatureprivilegegrouptype) ; `privileges`: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; minimumLicense?: "basic" \| "standard" \| "gold" \| "platinum" \| "enterprise" \| "trial" \| undefined; management?: Readonly<{ [x: string]: readonly string[]; }\> \| undefined; ... 8 more ...; savedObject: Readonly<...\>; }\>[] }\>[] - -#### Returns - -readonly `Readonly`<{ `groupType`: [`SubFeaturePrivilegeGroupType`](../modules/client._internal_namespace.md#subfeatureprivilegegrouptype) ; `privileges`: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; minimumLicense?: "basic" \| "standard" \| "gold" \| "platinum" \| "enterprise" \| "trial" \| undefined; management?: Readonly<{ [x: string]: readonly string[]; }\> \| undefined; ... 8 more ...; savedObject: Readonly<...\>; }\>[] }\>[] - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:68 - -## Methods - -### toRaw - -▸ **toRaw**(): `Object` - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `name` | `string` | -| `privilegeGroups` | readonly `Readonly`<{ `groupType`: [`SubFeaturePrivilegeGroupType`](../modules/client._internal_namespace.md#subfeatureprivilegegrouptype) ; `privileges`: readonly Readonly<{ id: string; name: string; includeIn: "all" \| "none" \| "read"; minimumLicense?: "basic" \| "standard" \| "gold" \| "platinum" \| "enterprise" \| "trial" \| undefined; management?: Readonly<{ [x: string]: readonly string[]; }\> \| undefined; ... 8 more ...; savedObject: Readonly<...\>; }\>[] }\>[] | - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:104 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.TaskRunnerFactory.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.TaskRunnerFactory.md deleted file mode 100644 index 7aed74f96c698..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.TaskRunnerFactory.md +++ /dev/null @@ -1,114 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskRunnerFactory - -# Class: TaskRunnerFactory - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskRunnerFactory - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.TaskRunnerFactory.md#constructor) - -### Properties - -- [actionExecutor](client._internal_namespace.TaskRunnerFactory.md#actionexecutor) -- [isInitialized](client._internal_namespace.TaskRunnerFactory.md#isinitialized) -- [taskRunnerContext](client._internal_namespace.TaskRunnerFactory.md#taskrunnercontext) - -### Methods - -- [create](client._internal_namespace.TaskRunnerFactory.md#create) -- [initialize](client._internal_namespace.TaskRunnerFactory.md#initialize) - -## Constructors - -### constructor - -• **new TaskRunnerFactory**(`actionExecutor`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionExecutor` | [`ActionExecutorContract`](../modules/client._internal_namespace.md#actionexecutorcontract) | - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:18 - -## Properties - -### actionExecutor - -• `Private` `Readonly` **actionExecutor**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:17 - -___ - -### isInitialized - -• `Private` **isInitialized**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:15 - -___ - -### taskRunnerContext - -• `Private` `Optional` **taskRunnerContext**: `any` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:16 - -## Methods - -### create - -▸ **create**(`__namedParameters`, `maxAttempts?`): `Object` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`RunContext`](../interfaces/client._internal_namespace.RunContext.md) | -| `maxAttempts?` | `number` | - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `cancel` | () => `Promise`<{ `state`: {} }\> | -| `run` | () => `Promise`<`void`\> | - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:20 - -___ - -### initialize - -▸ **initialize**(`taskRunnerContext`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `taskRunnerContext` | [`TaskRunnerContext`](../interfaces/client._internal_namespace.TaskRunnerContext.md) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:19 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UIActions.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UIActions.md deleted file mode 100644 index 8f74b5fff8806..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UIActions.md +++ /dev/null @@ -1,66 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UIActions - -# Class: UIActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UIActions - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.UIActions.md#constructor) - -### Properties - -- [prefix](client._internal_namespace.UIActions.md#prefix) - -### Methods - -- [get](client._internal_namespace.UIActions.md#get) - -## Constructors - -### constructor - -• **new UIActions**(`versionNumber`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `versionNumber` | `string` | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/ui.d.ts:4 - -## Properties - -### prefix - -• `Private` `Readonly` **prefix**: `any` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/ui.d.ts:3 - -## Methods - -### get - -▸ **get**(`featureId`, ...`uiCapabilityParts`): `string` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `featureId` | keyof [`Capabilities`](../interfaces/client._internal_namespace.Capabilities.md) | -| `...uiCapabilityParts` | `string`[] | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/actions/ui.d.ts:5 diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UserActionBuilder.md b/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UserActionBuilder.md deleted file mode 100644 index 361d5e50fd923..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client._internal_namespace.UserActionBuilder.md +++ /dev/null @@ -1,251 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UserActionBuilder - -# Class: UserActionBuilder - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UserActionBuilder - -## Table of contents - -### Constructors - -- [constructor](client._internal_namespace.UserActionBuilder.md#constructor) - -### Methods - -- [build](client._internal_namespace.UserActionBuilder.md#build) -- [buildCommonUserAction](client._internal_namespace.UserActionBuilder.md#buildcommonuseraction) -- [createActionReference](client._internal_namespace.UserActionBuilder.md#createactionreference) -- [createCaseReferences](client._internal_namespace.UserActionBuilder.md#createcasereferences) -- [createCommentReferences](client._internal_namespace.UserActionBuilder.md#createcommentreferences) -- [createConnectorPushReference](client._internal_namespace.UserActionBuilder.md#createconnectorpushreference) -- [createConnectorReference](client._internal_namespace.UserActionBuilder.md#createconnectorreference) -- [extractConnectorId](client._internal_namespace.UserActionBuilder.md#extractconnectorid) -- [extractConnectorIdFromExternalService](client._internal_namespace.UserActionBuilder.md#extractconnectoridfromexternalservice) -- [getCommonUserActionAttributes](client._internal_namespace.UserActionBuilder.md#getcommonuseractionattributes) - -## Constructors - -### constructor - -• **new UserActionBuilder**() - -## Methods - -### build - -▸ `Abstract` **build**<`T`\>(`args`): [`BuilderReturnValue`](../interfaces/client._internal_namespace.BuilderReturnValue.md) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | extends keyof [`BuilderParameters`](../interfaces/client._internal_namespace.BuilderParameters.md) | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `args` | [`UserActionParameters`](../modules/client._internal_namespace.md#useractionparameters)<`T`\> | - -#### Returns - -[`BuilderReturnValue`](../interfaces/client._internal_namespace.BuilderReturnValue.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:119](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L119) - -___ - -### buildCommonUserAction - -▸ `Protected` **buildCommonUserAction**(`__namedParameters`): [`BuilderReturnValue`](../interfaces/client._internal_namespace.BuilderReturnValue.md) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CommonBuilderArguments`](../modules/client._internal_namespace.md#commonbuilderarguments) | - -#### Returns - -[`BuilderReturnValue`](../interfaces/client._internal_namespace.BuilderReturnValue.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:88](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L88) - -___ - -### createActionReference - -▸ `Protected` **createActionReference**(`id`, `name`): [`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | ``null`` \| `string` | -| `name` | `string` | - -#### Returns - -[`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:55](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L55) - -___ - -### createCaseReferences - -▸ `Protected` **createCaseReferences**(`caseId`): [`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `caseId` | `string` | - -#### Returns - -[`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:45](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L45) - -___ - -### createCommentReferences - -▸ `Protected` **createCommentReferences**(`id`): [`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | ``null`` \| `string` | - -#### Returns - -[`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:61](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L61) - -___ - -### createConnectorPushReference - -▸ `Protected` **createConnectorPushReference**(`id`): [`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | ``null`` \| `string` | - -#### Returns - -[`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:77](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L77) - -___ - -### createConnectorReference - -▸ `Protected` **createConnectorReference**(`id`): [`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `id` | ``null`` \| `string` | - -#### Returns - -[`SavedObjectReference`](../interfaces/client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:73](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L73) - -___ - -### extractConnectorId - -▸ `Protected` **extractConnectorId**(`connector`): `Omit`<{ `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string }, ``"id"``\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `connector` | { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } | - -#### Returns - -`Omit`<{ `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string }, ``"id"``\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:40](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L40) - -___ - -### extractConnectorIdFromExternalService - -▸ `Protected` **extractConnectorIdFromExternalService**(`externalService`): `Omit`<{ `connector_id`: `string` = rt.string } & { `connector_name`: `string` = rt.string; `external_id`: `string` = rt.string; `external_title`: `string` = rt.string; `external_url`: `string` = rt.string; `pushed_at`: `string` = rt.string; `pushed_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT }, ``"connector_id"``\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `externalService` | { `connector_id`: `string` = rt.string } & { `connector_name`: `string` = rt.string; `external_id`: `string` = rt.string; `external_title`: `string` = rt.string; `external_url`: `string` = rt.string; `pushed_at`: `string` = rt.string; `pushed_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT } | - -#### Returns - -`Omit`<{ `connector_id`: `string` = rt.string } & { `connector_name`: `string` = rt.string; `external_id`: `string` = rt.string; `external_title`: `string` = rt.string; `external_url`: `string` = rt.string; `pushed_at`: `string` = rt.string; `pushed_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT }, ``"connector_id"``\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:81](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L81) - -___ - -### getCommonUserActionAttributes - -▸ `Protected` **getCommonUserActionAttributes**(`__namedParameters`): `Object` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | `Object` | -| `__namedParameters.owner` | `string` | -| `__namedParameters.user` | `Object` | -| `__namedParameters.user.email` | `undefined` \| ``null`` \| `string` | -| `__namedParameters.user.full_name` | `undefined` \| ``null`` \| `string` | -| `__namedParameters.user.username` | `undefined` \| ``null`` \| `string` | - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `created_at` | `string` | -| `created_by` | `Object` | -| `created_by.email` | `undefined` \| ``null`` \| `string` | -| `created_by.full_name` | `undefined` \| ``null`` \| `string` | -| `created_by.username` | `undefined` \| ``null`` \| `string` | -| `owner` | `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts:32](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/abstract_builder.ts#L32) diff --git a/x-pack/plugins/cases/docs/cases_client/classes/client.casesclient.md b/x-pack/plugins/cases/docs/cases_client/classes/client.casesclient.md deleted file mode 100644 index d00f9f0edcd88..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/classes/client.casesclient.md +++ /dev/null @@ -1,214 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / CasesClient - -# Class: CasesClient - -[client](../modules/client.md).CasesClient - -Client wrapper that contains accessor methods for individual entities within the cases system. - -## Table of contents - -### Constructors - -- [constructor](client.CasesClient.md#constructor) - -### Properties - -- [\_attachments](client.CasesClient.md#_attachments) -- [\_cases](client.CasesClient.md#_cases) -- [\_casesClientInternal](client.CasesClient.md#_casesclientinternal) -- [\_configure](client.CasesClient.md#_configure) -- [\_metrics](client.CasesClient.md#_metrics) -- [\_stats](client.CasesClient.md#_stats) -- [\_userActions](client.CasesClient.md#_useractions) - -### Accessors - -- [attachments](client.CasesClient.md#attachments) -- [cases](client.CasesClient.md#cases) -- [configure](client.CasesClient.md#configure) -- [metrics](client.CasesClient.md#metrics) -- [stats](client.CasesClient.md#stats) -- [userActions](client.CasesClient.md#useractions) - -## Constructors - -### constructor - -• **new CasesClient**(`args`) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `args` | [`CasesClientArgs`](../interfaces/client._internal_namespace.CasesClientArgs.md) | - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:29](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L29) - -## Properties - -### \_attachments - -• `Private` `Readonly` **\_attachments**: [`AttachmentsSubClient`](../interfaces/attachments_client.AttachmentsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:23](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L23) - -___ - -### \_cases - -• `Private` `Readonly` **\_cases**: [`CasesSubClient`](../interfaces/cases_client.CasesSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:22](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L22) - -___ - -### \_casesClientInternal - -• `Private` `Readonly` **\_casesClientInternal**: [`CasesClientInternal`](client._internal_namespace.CasesClientInternal.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:21](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L21) - -___ - -### \_configure - -• `Private` `Readonly` **\_configure**: [`ConfigureSubClient`](../interfaces/configure_client.ConfigureSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L25) - -___ - -### \_metrics - -• `Private` `Readonly` **\_metrics**: [`MetricsSubClient`](../interfaces/metrics_client.MetricsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:27](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L27) - -___ - -### \_stats - -• `Private` `Readonly` **\_stats**: [`StatsSubClient`](../interfaces/stats_client.StatsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:26](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L26) - -___ - -### \_userActions - -• `Private` `Readonly` **\_userActions**: [`UserActionsSubClient`](../interfaces/user_actions_client.UserActionsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:24](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L24) - -## Accessors - -### attachments - -• `get` **attachments**(): [`AttachmentsSubClient`](../interfaces/attachments_client.AttachmentsSubClient.md) - -Retrieves an interface for interacting with attachments (comments) entities. - -#### Returns - -[`AttachmentsSubClient`](../interfaces/attachments_client.AttachmentsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:49](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L49) - -___ - -### cases - -• `get` **cases**(): [`CasesSubClient`](../interfaces/cases_client.CasesSubClient.md) - -Retrieves an interface for interacting with cases entities. - -#### Returns - -[`CasesSubClient`](../interfaces/cases_client.CasesSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:42](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L42) - -___ - -### configure - -• `get` **configure**(): [`ConfigureSubClient`](../interfaces/configure_client.ConfigureSubClient.md) - -Retrieves an interface for interacting with the configuration of external connectors for the plugin entities. - -#### Returns - -[`ConfigureSubClient`](../interfaces/configure_client.ConfigureSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:63](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L63) - -___ - -### metrics - -• `get` **metrics**(): [`MetricsSubClient`](../interfaces/metrics_client.MetricsSubClient.md) - -Retrieves an interface for retrieving metrics related to the cases entities. - -#### Returns - -[`MetricsSubClient`](../interfaces/metrics_client.MetricsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:77](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L77) - -___ - -### stats - -• `get` **stats**(): [`StatsSubClient`](../interfaces/stats_client.StatsSubClient.md) - -Retrieves an interface for retrieving statistics related to the cases entities. - -#### Returns - -[`StatsSubClient`](../interfaces/stats_client.StatsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:70](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L70) - -___ - -### userActions - -• `get` **userActions**(): [`UserActionsSubClient`](../interfaces/user_actions_client.UserActionsSubClient.md) - -Retrieves an interface for interacting with the user actions associated with the plugin entities. - -#### Returns - -[`UserActionsSubClient`](../interfaces/user_actions_client.UserActionsSubClient.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/client.ts:56](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/client.ts#L56) diff --git a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ActionExecutionSourceType.md b/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ActionExecutionSourceType.md deleted file mode 100644 index 9d4fbc639a26c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ActionExecutionSourceType.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionExecutionSourceType - -# Enumeration: ActionExecutionSourceType - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionExecutionSourceType - -## Table of contents - -### Enumeration members - -- [HTTP\_REQUEST](client._internal_namespace.ActionExecutionSourceType.md#http_request) -- [SAVED\_OBJECT](client._internal_namespace.ActionExecutionSourceType.md#saved_object) - -## Enumeration members - -### HTTP\_REQUEST - -• **HTTP\_REQUEST** = `"HTTP_REQUEST"` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_execution_source.d.ts:4 - -___ - -### SAVED\_OBJECT - -• **SAVED\_OBJECT** = `"SAVED_OBJECT"` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_execution_source.d.ts:3 diff --git a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.AuthorizationMode.md b/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.AuthorizationMode.md deleted file mode 100644 index f1dc071f463d6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.AuthorizationMode.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthorizationMode - -# Enumeration: AuthorizationMode - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthorizationMode - -## Table of contents - -### Enumeration members - -- [Legacy](client._internal_namespace.AuthorizationMode.md#legacy) -- [RBAC](client._internal_namespace.AuthorizationMode.md#rbac) - -## Enumeration members - -### Legacy - -• **Legacy** = `0` - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/get_authorization_mode_by_source.d.ts:4 - -___ - -### RBAC - -• **RBAC** = `1` - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/get_authorization_mode_by_source.d.ts:5 diff --git a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.CaseStatuses.md b/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.CaseStatuses.md deleted file mode 100644 index 48d5689a52400..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.CaseStatuses.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CaseStatuses - -# Enumeration: CaseStatuses - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CaseStatuses - -## Table of contents - -### Enumeration members - -- [closed](client._internal_namespace.CaseStatuses.md#closed) -- [in-progress](client._internal_namespace.CaseStatuses.md#in-progress) -- [open](client._internal_namespace.CaseStatuses.md#open) - -## Enumeration members - -### closed - -• **closed** = `"closed"` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/status.ts:13](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/status.ts#L13) - -___ - -### in-progress - -• **in-progress** = `"in-progress"` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/status.ts:12](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/status.ts#L12) - -___ - -### open - -• **open** = `"open"` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/status.ts:11](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/status.ts#L11) diff --git a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.TaskStatus.md b/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.TaskStatus.md deleted file mode 100644 index a92a96681e137..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.TaskStatus.md +++ /dev/null @@ -1,65 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskStatus - -# Enumeration: TaskStatus - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskStatus - -## Table of contents - -### Enumeration members - -- [Claiming](client._internal_namespace.TaskStatus.md#claiming) -- [Failed](client._internal_namespace.TaskStatus.md#failed) -- [Idle](client._internal_namespace.TaskStatus.md#idle) -- [Running](client._internal_namespace.TaskStatus.md#running) -- [Unrecognized](client._internal_namespace.TaskStatus.md#unrecognized) - -## Enumeration members - -### Claiming - -• **Claiming** = `"claiming"` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:124 - -___ - -### Failed - -• **Failed** = `"failed"` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:126 - -___ - -### Idle - -• **Idle** = `"idle"` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:123 - -___ - -### Running - -• **Running** = `"running"` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:125 - -___ - -### Unrecognized - -• **Unrecognized** = `"unrecognized"` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:127 diff --git a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ViewMode.md b/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ViewMode.md deleted file mode 100644 index c00d063ffc864..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/enums/client._internal_namespace.ViewMode.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ViewMode - -# Enumeration: ViewMode - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ViewMode - -## Table of contents - -### Enumeration members - -- [EDIT](client._internal_namespace.ViewMode.md#edit) -- [PREVIEW](client._internal_namespace.ViewMode.md#preview) -- [PRINT](client._internal_namespace.ViewMode.md#print) -- [VIEW](client._internal_namespace.ViewMode.md#view) - -## Enumeration members - -### EDIT - -• **EDIT** = `"edit"` - -#### Defined in - -src/plugins/embeddable/target/types/common/types.d.ts:5 - -___ - -### PREVIEW - -• **PREVIEW** = `"preview"` - -#### Defined in - -src/plugins/embeddable/target/types/common/types.d.ts:6 - -___ - -### PRINT - -• **PRINT** = `"print"` - -#### Defined in - -src/plugins/embeddable/target/types/common/types.d.ts:7 - -___ - -### VIEW - -• **VIEW** = `"view"` - -#### Defined in - -src/plugins/embeddable/target/types/common/types.d.ts:8 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.AddArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.AddArgs.md deleted file mode 100644 index b1a96017c439b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.AddArgs.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / AddArgs - -# Interface: AddArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).AddArgs - -The arguments needed for creating a new attachment to a case. - -## Table of contents - -### Properties - -- [caseId](attachments_client._internal_namespace.AddArgs.md#caseid) -- [comment](attachments_client._internal_namespace.AddArgs.md#comment) - -## Properties - -### caseId - -• **caseId**: `string` - -The case ID that this attachment will be associated with - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/add.ts:77](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/add.ts#L77) - -___ - -### comment - -• **comment**: { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } - -The attachment values. - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/add.ts:81](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/add.ts#L81) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteAllArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteAllArgs.md deleted file mode 100644 index d2f34ab040eb3..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteAllArgs.md +++ /dev/null @@ -1,25 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / DeleteAllArgs - -# Interface: DeleteAllArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).DeleteAllArgs - -Parameters for deleting all comments of a case. - -## Table of contents - -### Properties - -- [caseID](attachments_client._internal_namespace.DeleteAllArgs.md#caseid) - -## Properties - -### caseID - -• **caseID**: `string` - -The case ID to delete all attachments for - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/delete.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/delete.ts#L25) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteArgs.md deleted file mode 100644 index 0bee9af6c4f24..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.DeleteArgs.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / DeleteArgs - -# Interface: DeleteArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).DeleteArgs - -Parameters for deleting a single attachment of a case. - -## Table of contents - -### Properties - -- [attachmentID](attachments_client._internal_namespace.DeleteArgs.md#attachmentid) -- [caseID](attachments_client._internal_namespace.DeleteArgs.md#caseid) - -## Properties - -### attachmentID - -• **attachmentID**: `string` - -The attachment ID to delete - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/delete.ts:39](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/delete.ts#L39) - -___ - -### caseID - -• **caseID**: `string` - -The case ID to delete an attachment from - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/delete.ts:35](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/delete.ts#L35) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.FindArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.FindArgs.md deleted file mode 100644 index 2fd5a356bc6f5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.FindArgs.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / FindArgs - -# Interface: FindArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).FindArgs - -Parameters for finding attachments of a case - -## Table of contents - -### Properties - -- [caseID](attachments_client._internal_namespace.FindArgs.md#caseid) -- [queryParams](attachments_client._internal_namespace.FindArgs.md#queryparams) - -## Properties - -### caseID - -• **caseID**: `string` - -The case ID for finding associated attachments - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/get.ts:42](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/get.ts#L42) - -___ - -### queryParams - -• `Optional` **queryParams**: `Object` - -Optional parameters for filtering the returned attachments - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `defaultSearchOperator` | `undefined` \| ``"AND"`` \| ``"OR"`` | -| `fields` | `undefined` \| `string`[] | -| `filter` | `undefined` \| `string` | -| `hasReference` | `undefined` \| { `id`: `string` = rt.string; `type`: `string` = rt.string } \| { `id`: `string` = rt.string; `type`: `string` = rt.string }[] | -| `hasReferenceOperator` | `undefined` \| ``"AND"`` \| ``"OR"`` | -| `page` | `undefined` \| `number` | -| `perPage` | `undefined` \| `number` | -| `search` | `undefined` \| `string` | -| `searchFields` | `undefined` \| `string`[] | -| `sortField` | `undefined` \| `string` | -| `sortOrder` | `undefined` \| ``"desc"`` \| ``"asc"`` | - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/get.ts:46](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/get.ts#L46) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllAlertsAttachToCase.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllAlertsAttachToCase.md deleted file mode 100644 index d45019010a3d6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllAlertsAttachToCase.md +++ /dev/null @@ -1,23 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / GetAllAlertsAttachToCase - -# Interface: GetAllAlertsAttachToCase - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).GetAllAlertsAttachToCase - -## Table of contents - -### Properties - -- [caseId](attachments_client._internal_namespace.GetAllAlertsAttachToCase.md#caseid) - -## Properties - -### caseId - -• **caseId**: `string` - -The ID of the case to retrieve the alerts from - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/get.ts:74](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/get.ts#L74) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllArgs.md deleted file mode 100644 index f5ebbd40a2d08..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetAllArgs.md +++ /dev/null @@ -1,25 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / GetAllArgs - -# Interface: GetAllArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).GetAllArgs - -Parameters for retrieving all attachments of a case - -## Table of contents - -### Properties - -- [caseID](attachments_client._internal_namespace.GetAllArgs.md#caseid) - -## Properties - -### caseID - -• **caseID**: `string` - -The case ID to retrieve all attachments for - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/get.ts:56](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/get.ts#L56) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetArgs.md deleted file mode 100644 index 8c36ea3ab2f12..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.GetArgs.md +++ /dev/null @@ -1,36 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / GetArgs - -# Interface: GetArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).GetArgs - -## Table of contents - -### Properties - -- [attachmentID](attachments_client._internal_namespace.GetArgs.md#attachmentid) -- [caseID](attachments_client._internal_namespace.GetArgs.md#caseid) - -## Properties - -### attachmentID - -• **attachmentID**: `string` - -The ID of the attachment to retrieve - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/get.ts:67](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/get.ts#L67) - -___ - -### caseID - -• **caseID**: `string` - -The ID of the case to retrieve an attachment from - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/get.ts:63](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/get.ts#L63) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.UpdateArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.UpdateArgs.md deleted file mode 100644 index 75650928ba124..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client._internal_namespace.UpdateArgs.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / [\_internal\_namespace](../modules/attachments_client._internal_namespace.md) / UpdateArgs - -# Interface: UpdateArgs - -[attachments/client](../modules/attachments_client.md).[_internal_namespace](../modules/attachments_client._internal_namespace.md).UpdateArgs - -Parameters for updating a single attachment - -## Table of contents - -### Properties - -- [caseID](attachments_client._internal_namespace.UpdateArgs.md#caseid) -- [updateRequest](attachments_client._internal_namespace.UpdateArgs.md#updaterequest) - -## Properties - -### caseID - -• **caseID**: `string` - -The ID of the case that is associated with this attachment - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/update.ts:28](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/update.ts#L28) - -___ - -### updateRequest - -• **updateRequest**: { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `id`: `string` = rt.string; `version`: `string` = rt.string } - -The full attachment request with the fields updated with appropriate values - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/update.ts:32](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/update.ts#L32) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client.attachmentssubclient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client.attachmentssubclient.md deleted file mode 100644 index 04b77c2141ed8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/attachments_client.attachmentssubclient.md +++ /dev/null @@ -1,198 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](../modules/attachments_client.md) / AttachmentsSubClient - -# Interface: AttachmentsSubClient - -[attachments/client](../modules/attachments_client.md).AttachmentsSubClient - -API for interacting with the attachments to a case. - -## Table of contents - -### Methods - -- [add](attachments_client.AttachmentsSubClient.md#add) -- [delete](attachments_client.AttachmentsSubClient.md#delete) -- [deleteAll](attachments_client.AttachmentsSubClient.md#deleteall) -- [find](attachments_client.AttachmentsSubClient.md#find) -- [get](attachments_client.AttachmentsSubClient.md#get) -- [getAll](attachments_client.AttachmentsSubClient.md#getall) -- [getAllAlertsAttachToCase](attachments_client.AttachmentsSubClient.md#getallalertsattachtocase) -- [update](attachments_client.AttachmentsSubClient.md#update) - -## Methods - -### add - -▸ **add**(`params`): `Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -Adds an attachment to a case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`AddArgs`](attachments_client._internal_namespace.AddArgs.md) | - -#### Returns - -`Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:35](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L35) - -___ - -### delete - -▸ **delete**(`deleteArgs`): `Promise`<`void`\> - -Deletes a single attachment for a specific case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `deleteArgs` | [`DeleteArgs`](attachments_client._internal_namespace.DeleteArgs.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:43](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L43) - -___ - -### deleteAll - -▸ **deleteAll**(`deleteAllArgs`): `Promise`<`void`\> - -Deletes all attachments associated with a single case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `deleteAllArgs` | [`DeleteAllArgs`](attachments_client._internal_namespace.DeleteAllArgs.md) | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:39](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L39) - -___ - -### find - -▸ **find**(`findArgs`): `Promise`<[`ICommentsResponse`](typedoc_interfaces.ICommentsResponse.md)\> - -Retrieves all comments matching the search criteria. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `findArgs` | [`FindArgs`](attachments_client._internal_namespace.FindArgs.md) | - -#### Returns - -`Promise`<[`ICommentsResponse`](typedoc_interfaces.ICommentsResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:47](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L47) - -___ - -### get - -▸ **get**(`getArgs`): `Promise`<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }\> - -Retrieves a single attachment for a case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `getArgs` | [`GetArgs`](attachments_client._internal_namespace.GetArgs.md) | - -#### Returns - -`Promise`<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:59](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L59) - -___ - -### getAll - -▸ **getAll**(`getAllArgs`): `Promise`<[`IAllCommentsResponse`](typedoc_interfaces.IAllCommentsResponse.md)\> - -Gets all attachments for a single case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `getAllArgs` | [`GetAllArgs`](attachments_client._internal_namespace.GetAllArgs.md) | - -#### Returns - -`Promise`<[`IAllCommentsResponse`](typedoc_interfaces.IAllCommentsResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:55](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L55) - -___ - -### getAllAlertsAttachToCase - -▸ **getAllAlertsAttachToCase**(`params`): `Promise`<{ `attached_at`: `string` = rt.string; `id`: `string` = rt.string; `index`: `string` = rt.string }[]\> - -Retrieves all alerts attach to a case given a single case ID - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`GetAllAlertsAttachToCase`](attachments_client._internal_namespace.GetAllAlertsAttachToCase.md) | - -#### Returns - -`Promise`<{ `attached_at`: `string` = rt.string; `id`: `string` = rt.string; `index`: `string` = rt.string }[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:51](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L51) - -___ - -### update - -▸ **update**(`updateArgs`): `Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -Updates a specific attachment. - -The request must include all fields for the attachment. Even the fields that are not changing. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `updateArgs` | [`UpdateArgs`](attachments_client._internal_namespace.UpdateArgs.md) | - -#### Returns - -`Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/attachments/client.ts:65](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/attachments/client.ts#L65) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_client.casessubclient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/cases_client.casessubclient.md deleted file mode 100644 index df4d1bdf7966f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_client.casessubclient.md +++ /dev/null @@ -1,249 +0,0 @@ -[Cases Client API Interface](../README.md) / [cases/client](../modules/cases_client.md) / CasesSubClient - -# Interface: CasesSubClient - -[cases/client](../modules/cases_client.md).CasesSubClient - -API for interacting with the cases entities. - -## Table of contents - -### Methods - -- [create](cases_client.CasesSubClient.md#create) -- [delete](cases_client.CasesSubClient.md#delete) -- [find](cases_client.CasesSubClient.md#find) -- [get](cases_client.CasesSubClient.md#get) -- [getCasesByAlertID](cases_client.CasesSubClient.md#getcasesbyalertid) -- [getReporters](cases_client.CasesSubClient.md#getreporters) -- [getTags](cases_client.CasesSubClient.md#gettags) -- [push](cases_client.CasesSubClient.md#push) -- [resolve](cases_client.CasesSubClient.md#resolve) -- [update](cases_client.CasesSubClient.md#update) - -## Methods - -### create - -▸ **create**(`data`): `Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -Creates a case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `data` | [`ICasePostRequest`](typedoc_interfaces.ICasePostRequest.md) | - -#### Returns - -`Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:51](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L51) - -___ - -### delete - -▸ **delete**(`ids`): `Promise`<`void`\> - -Delete a case and all its comments. - -**`params`** ids an array of case IDs to delete - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `ids` | `string`[] | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:80](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L80) - -___ - -### find - -▸ **find**(`params`): `Promise`<[`ICasesFindResponse`](typedoc_interfaces.ICasesFindResponse.md)\> - -Returns cases that match the search criteria. - -If the `owner` field is left empty then all the cases that the user has access to will be returned. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`ICasesFindRequest`](typedoc_interfaces.ICasesFindRequest.md) | - -#### Returns - -`Promise`<[`ICasesFindResponse`](typedoc_interfaces.ICasesFindResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:57](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L57) - -___ - -### get - -▸ **get**(`params`): `Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -Retrieves a single case with the specified ID. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`GetParams`](cases_get.GetParams.md) | - -#### Returns - -`Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:61](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L61) - -___ - -### getCasesByAlertID - -▸ **getCasesByAlertID**(`params`): `Promise`<{ `id`: `string` = rt.string; `title`: `string` = rt.string }[]\> - -Retrieves the cases ID and title that have the requested alert attached to them - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`CasesByAlertIDParams`](cases_get.CasesByAlertIDParams.md) | - -#### Returns - -`Promise`<{ `id`: `string` = rt.string; `title`: `string` = rt.string }[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:92](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L92) - -___ - -### getReporters - -▸ **getReporters**(`params`): `Promise`<{ `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` }[]\> - -Retrieves all the reporters across all accessible cases. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Object` | -| `params.owner` | `undefined` \| `string` \| `string`[] | - -#### Returns - -`Promise`<{ `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` }[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:88](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L88) - -___ - -### getTags - -▸ **getTags**(`params`): `Promise`<`string`[]\> - -Retrieves all the tags across all cases the user making the request has access to. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Object` | -| `params.owner` | `undefined` \| `string` \| `string`[] | - -#### Returns - -`Promise`<`string`[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:84](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L84) - -___ - -### push - -▸ **push**(`args`): `Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -Pushes a specific case to an external system. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `args` | [`PushParams`](cases_push.PushParams.md) | - -#### Returns - -`Promise`<[`ICaseResponse`](typedoc_interfaces.ICaseResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:70](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L70) - -___ - -### resolve - -▸ **resolve**(`params`): `Promise`<[`ICaseResolveResponse`](typedoc_interfaces.ICaseResolveResponse.md)\> - -**`experimental`** -Retrieves a single case resolving the specified ID. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`GetParams`](cases_get.GetParams.md) | - -#### Returns - -`Promise`<[`ICaseResolveResponse`](typedoc_interfaces.ICaseResolveResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:66](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L66) - -___ - -### update - -▸ **update**(`cases`): `Promise`<[`ICasesResponse`](typedoc_interfaces.ICasesResponse.md)\> - -Update the specified cases with the passed in values. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `cases` | [`ICasesPatchRequest`](typedoc_interfaces.ICasesPatchRequest.md) | - -#### Returns - -`Promise`<[`ICasesResponse`](typedoc_interfaces.ICasesResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/client.ts:74](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/client.ts#L74) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.casesbyalertidparams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.casesbyalertidparams.md deleted file mode 100644 index 2e0cf957be8e3..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.casesbyalertidparams.md +++ /dev/null @@ -1,44 +0,0 @@ -[Cases Client API Interface](../README.md) / [cases/get](../modules/cases_get.md) / CasesByAlertIDParams - -# Interface: CasesByAlertIDParams - -[cases/get](../modules/cases_get.md).CasesByAlertIDParams - -Parameters for finding cases IDs using an alert ID - -## Table of contents - -### Properties - -- [alertID](cases_get.CasesByAlertIDParams.md#alertid) -- [options](cases_get.CasesByAlertIDParams.md#options) - -## Properties - -### alertID - -• **alertID**: `string` - -The alert ID to search for - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:45](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L45) - -___ - -### options - -• **options**: `Object` - -The filtering options when searching for associated cases. - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `owner` | `undefined` \| `string` \| `string`[] | - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:49](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L49) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.getparams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.getparams.md deleted file mode 100644 index ccd09fd4db48c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_get.getparams.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [cases/get](../modules/cases_get.md) / GetParams - -# Interface: GetParams - -[cases/get](../modules/cases_get.md).GetParams - -The parameters for retrieving a case - -## Table of contents - -### Properties - -- [id](cases_get.GetParams.md#id) -- [includeComments](cases_get.GetParams.md#includecomments) - -## Properties - -### id - -• **id**: `string` - -Case ID - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:144](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L144) - -___ - -### includeComments - -• `Optional` **includeComments**: `boolean` - -Whether to include the attachments for a case in the response - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:148](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L148) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_push.pushparams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/cases_push.pushparams.md deleted file mode 100644 index 436850a7b64fd..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/cases_push.pushparams.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [cases/push](../modules/cases_push.md) / PushParams - -# Interface: PushParams - -[cases/push](../modules/cases_push.md).PushParams - -Parameters for pushing a case to an external system - -## Table of contents - -### Properties - -- [caseId](cases_push.PushParams.md#caseid) -- [connectorId](cases_push.PushParams.md#connectorid) - -## Properties - -### caseId - -• **caseId**: `string` - -The ID of a case - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/push.ts:48](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/push.ts#L48) - -___ - -### connectorId - -• **connectorId**: `string` - -The ID of an external system to push to - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/push.ts:52](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/push.ts#L52) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Action.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Action.md deleted file mode 100644 index 7f8e04653acf6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Action.md +++ /dev/null @@ -1,72 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Action - -# Interface: Action - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Action - -## Hierarchy - -- [`ActionUpdate`](client._internal_namespace.ActionUpdate.md) - - ↳ **`Action`** - -## Table of contents - -### Properties - -- [actionTypeId](client._internal_namespace.Action.md#actiontypeid) -- [config](client._internal_namespace.Action.md#config) -- [name](client._internal_namespace.Action.md#name) -- [secrets](client._internal_namespace.Action.md#secrets) - -## Properties - -### actionTypeId - -• **actionTypeId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:19 - -___ - -### config - -• **config**: [`SavedObjectAttributes`](client._internal_namespace.SavedObjectAttributes.md) - -#### Inherited from - -[ActionUpdate](client._internal_namespace.ActionUpdate.md).[config](client._internal_namespace.ActionUpdate.md#config) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:15 - -___ - -### name - -• **name**: `string` - -#### Inherited from - -[ActionUpdate](client._internal_namespace.ActionUpdate.md).[name](client._internal_namespace.ActionUpdate.md#name) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:14 - -___ - -### secrets - -• **secrets**: [`SavedObjectAttributes`](client._internal_namespace.SavedObjectAttributes.md) - -#### Inherited from - -[ActionUpdate](client._internal_namespace.ActionUpdate.md).[secrets](client._internal_namespace.ActionUpdate.md#secrets) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:16 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutionSource.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutionSource.md deleted file mode 100644 index 1b7033f5805c8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutionSource.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionExecutionSource - -# Interface: ActionExecutionSource - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionExecutionSource - -## Type parameters - -| Name | -| :------ | -| `T` | - -## Table of contents - -### Properties - -- [source](client._internal_namespace.ActionExecutionSource.md#source) -- [type](client._internal_namespace.ActionExecutionSource.md#type) - -## Properties - -### source - -• **source**: `T` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_execution_source.d.ts:8 - -___ - -### type - -• **type**: [`ActionExecutionSourceType`](../enums/client._internal_namespace.ActionExecutionSourceType.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_execution_source.d.ts:7 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutorContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutorContext.md deleted file mode 100644 index 093b2933ddfac..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionExecutorContext.md +++ /dev/null @@ -1,112 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionExecutorContext - -# Interface: ActionExecutorContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionExecutorContext - -## Table of contents - -### Properties - -- [actionTypeRegistry](client._internal_namespace.ActionExecutorContext.md#actiontyperegistry) -- [encryptedSavedObjectsClient](client._internal_namespace.ActionExecutorContext.md#encryptedsavedobjectsclient) -- [eventLogger](client._internal_namespace.ActionExecutorContext.md#eventlogger) -- [getServices](client._internal_namespace.ActionExecutorContext.md#getservices) -- [logger](client._internal_namespace.ActionExecutorContext.md#logger) -- [preconfiguredActions](client._internal_namespace.ActionExecutorContext.md#preconfiguredactions) -- [spaces](client._internal_namespace.ActionExecutorContext.md#spaces) - -### Methods - -- [getActionsClientWithRequest](client._internal_namespace.ActionExecutorContext.md#getactionsclientwithrequest) - -## Properties - -### actionTypeRegistry - -• **actionTypeRegistry**: [`ActionTypeRegistryContract`](../modules/client._internal_namespace.md#actiontyperegistrycontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:16 - -___ - -### encryptedSavedObjectsClient - -• **encryptedSavedObjectsClient**: [`EncryptedSavedObjectsClient`](client._internal_namespace.EncryptedSavedObjectsClient.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:15 - -___ - -### eventLogger - -• **eventLogger**: [`IEventLogger`](client._internal_namespace.IEventLogger.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:17 - -___ - -### getServices - -• **getServices**: [`GetServicesFunction`](../modules/client._internal_namespace.md#getservicesfunction) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:13 - -___ - -### logger - -• **logger**: `Logger` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:11 - -___ - -### preconfiguredActions - -• **preconfiguredActions**: [`PreConfiguredAction`](client._internal_namespace.PreConfiguredAction.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig), [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets)\>[] - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:18 - -___ - -### spaces - -• `Optional` **spaces**: [`SpacesServiceStart`](client._internal_namespace.SpacesServiceStart.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:12 - -## Methods - -### getActionsClientWithRequest - -▸ **getActionsClientWithRequest**(`request`, `authorizationContext?`): `Promise`<`PublicMethodsOf`<[`ActionsClient`](../classes/client._internal_namespace.ActionsClient.md)\>\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | -| `authorizationContext?` | [`ActionExecutionSource`](client._internal_namespace.ActionExecutionSource.md)<`unknown`\> | - -#### Returns - -`Promise`<`PublicMethodsOf`<[`ActionsClient`](../classes/client._internal_namespace.ActionsClient.md)\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:14 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionResult.md deleted file mode 100644 index 7a303e0216b3a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionResult.md +++ /dev/null @@ -1,90 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionResult - -# Interface: ActionResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionResult - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Config` | extends [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) = [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) | - -## Hierarchy - -- **`ActionResult`** - - ↳ [`FindActionResult`](client._internal_namespace.FindActionResult.md) - - ↳ [`PreConfiguredAction`](client._internal_namespace.PreConfiguredAction.md) - -## Table of contents - -### Properties - -- [actionTypeId](client._internal_namespace.ActionResult.md#actiontypeid) -- [config](client._internal_namespace.ActionResult.md#config) -- [id](client._internal_namespace.ActionResult.md#id) -- [isMissingSecrets](client._internal_namespace.ActionResult.md#ismissingsecrets) -- [isPreconfigured](client._internal_namespace.ActionResult.md#ispreconfigured) -- [name](client._internal_namespace.ActionResult.md#name) - -## Properties - -### actionTypeId - -• **actionTypeId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:50 - -___ - -### config - -• `Optional` **config**: `Config` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:53 - -___ - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:49 - -___ - -### isMissingSecrets - -• `Optional` **isMissingSecrets**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:52 - -___ - -### isPreconfigured - -• **isPreconfigured**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:54 - -___ - -### name - -• **name**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:51 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType-1.md deleted file mode 100644 index ac0b15f74c84d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType-1.md +++ /dev/null @@ -1,120 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionType - -# Interface: ActionType - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionType - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Config` | extends [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) = [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) | -| `Secrets` | extends [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) = [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) | -| `Params` | extends [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams) = [`ActionTypeParams`](../modules/client._internal_namespace.md#actiontypeparams) | -| `ExecutorResultData` | `void` | - -## Table of contents - -### Properties - -- [executor](client._internal_namespace.ActionType-1.md#executor) -- [id](client._internal_namespace.ActionType-1.md#id) -- [maxAttempts](client._internal_namespace.ActionType-1.md#maxattempts) -- [minimumLicenseRequired](client._internal_namespace.ActionType-1.md#minimumlicenserequired) -- [name](client._internal_namespace.ActionType-1.md#name) -- [validate](client._internal_namespace.ActionType-1.md#validate) - -### Methods - -- [renderParameterTemplates](client._internal_namespace.ActionType-1.md#renderparametertemplates) - -## Properties - -### executor - -• **executor**: [`ExecutorType`](../modules/client._internal_namespace.md#executortype)<`Config`, `Secrets`, `Params`, `ExecutorResultData`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:82 - -___ - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:71 - -___ - -### maxAttempts - -• `Optional` **maxAttempts**: `number` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:73 - -___ - -### minimumLicenseRequired - -• **minimumLicenseRequired**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:74 - -___ - -### name - -• **name**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:72 - -___ - -### validate - -• `Optional` **validate**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `config?` | [`ValidatorType`](client._internal_namespace.ValidatorType.md)<`Config`\> | -| `params?` | [`ValidatorType`](client._internal_namespace.ValidatorType.md)<`Params`\> | -| `secrets?` | [`ValidatorType`](client._internal_namespace.ValidatorType.md)<`Secrets`\> | -| `connector?` | (`config`: `Config`, `secrets`: `Secrets`) => ``null`` \| `string` | - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:75 - -## Methods - -### renderParameterTemplates - -▸ `Optional` **renderParameterTemplates**(`params`, `variables`, `actionId?`): `Params` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Params` | -| `variables` | `Record`<`string`, `unknown`\> | -| `actionId?` | `string` | - -#### Returns - -`Params` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:81 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType.md deleted file mode 100644 index 286e699d5c2f7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionType.md +++ /dev/null @@ -1,76 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionType - -# Interface: ActionType - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionType - -## Table of contents - -### Properties - -- [enabled](client._internal_namespace.ActionType.md#enabled) -- [enabledInConfig](client._internal_namespace.ActionType.md#enabledinconfig) -- [enabledInLicense](client._internal_namespace.ActionType.md#enabledinlicense) -- [id](client._internal_namespace.ActionType.md#id) -- [minimumLicenseRequired](client._internal_namespace.ActionType.md#minimumlicenserequired) -- [name](client._internal_namespace.ActionType.md#name) - -## Properties - -### enabled - -• **enabled**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:5 - -___ - -### enabledInConfig - -• **enabledInConfig**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:6 - -___ - -### enabledInLicense - -• **enabledInLicense**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:7 - -___ - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:3 - -___ - -### minimumLicenseRequired - -• **minimumLicenseRequired**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:8 - -___ - -### name - -• **name**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorOptions.md deleted file mode 100644 index 9c06e78c9c199..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorOptions.md +++ /dev/null @@ -1,95 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionTypeExecutorOptions - -# Interface: ActionTypeExecutorOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionTypeExecutorOptions - -## Type parameters - -| Name | -| :------ | -| `Config` | -| `Secrets` | -| `Params` | - -## Table of contents - -### Properties - -- [actionId](client._internal_namespace.ActionTypeExecutorOptions.md#actionid) -- [config](client._internal_namespace.ActionTypeExecutorOptions.md#config) -- [isEphemeral](client._internal_namespace.ActionTypeExecutorOptions.md#isephemeral) -- [params](client._internal_namespace.ActionTypeExecutorOptions.md#params) -- [secrets](client._internal_namespace.ActionTypeExecutorOptions.md#secrets) -- [services](client._internal_namespace.ActionTypeExecutorOptions.md#services) -- [taskInfo](client._internal_namespace.ActionTypeExecutorOptions.md#taskinfo) - -## Properties - -### actionId - -• **actionId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:40 - -___ - -### config - -• **config**: `Config` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:42 - -___ - -### isEphemeral - -• `Optional` **isEphemeral**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:45 - -___ - -### params - -• **params**: `Params` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:44 - -___ - -### secrets - -• **secrets**: `Secrets` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:43 - -___ - -### services - -• **services**: [`Services`](client._internal_namespace.Services.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:41 - -___ - -### taskInfo - -• `Optional` **taskInfo**: [`TaskInfo`](client._internal_namespace.TaskInfo.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:46 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorResult.md deleted file mode 100644 index 039de06431a7c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeExecutorResult.md +++ /dev/null @@ -1,82 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionTypeExecutorResult - -# Interface: ActionTypeExecutorResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionTypeExecutorResult - -## Type parameters - -| Name | -| :------ | -| `Data` | - -## Table of contents - -### Properties - -- [actionId](client._internal_namespace.ActionTypeExecutorResult.md#actionid) -- [data](client._internal_namespace.ActionTypeExecutorResult.md#data) -- [message](client._internal_namespace.ActionTypeExecutorResult.md#message) -- [retry](client._internal_namespace.ActionTypeExecutorResult.md#retry) -- [serviceMessage](client._internal_namespace.ActionTypeExecutorResult.md#servicemessage) -- [status](client._internal_namespace.ActionTypeExecutorResult.md#status) - -## Properties - -### actionId - -• **actionId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:20 - -___ - -### data - -• `Optional` **data**: `Data` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:24 - -___ - -### message - -• `Optional` **message**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:22 - -___ - -### retry - -• `Optional` **retry**: ``null`` \| `boolean` \| `Date` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:25 - -___ - -### serviceMessage - -• `Optional` **serviceMessage**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:23 - -___ - -### status - -• **status**: ``"error"`` \| ``"ok"`` - -#### Defined in - -x-pack/plugins/actions/target/types/common/types.d.ts:21 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeRegistryOpts.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeRegistryOpts.md deleted file mode 100644 index 2f83edd5720f0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionTypeRegistryOpts.md +++ /dev/null @@ -1,76 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionTypeRegistryOpts - -# Interface: ActionTypeRegistryOpts - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionTypeRegistryOpts - -## Table of contents - -### Properties - -- [actionsConfigUtils](client._internal_namespace.ActionTypeRegistryOpts.md#actionsconfigutils) -- [licenseState](client._internal_namespace.ActionTypeRegistryOpts.md#licensestate) -- [licensing](client._internal_namespace.ActionTypeRegistryOpts.md#licensing) -- [preconfiguredActions](client._internal_namespace.ActionTypeRegistryOpts.md#preconfiguredactions) -- [taskManager](client._internal_namespace.ActionTypeRegistryOpts.md#taskmanager) -- [taskRunnerFactory](client._internal_namespace.ActionTypeRegistryOpts.md#taskrunnerfactory) - -## Properties - -### actionsConfigUtils - -• **actionsConfigUtils**: [`ActionsConfigurationUtilities`](client._internal_namespace.ActionsConfigurationUtilities.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:11 - -___ - -### licenseState - -• **licenseState**: [`ILicenseState`](../modules/client._internal_namespace.md#ilicensestate) - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:12 - -___ - -### licensing - -• **licensing**: [`LicensingPluginSetup`](client._internal_namespace.LicensingPluginSetup.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:8 - -___ - -### preconfiguredActions - -• **preconfiguredActions**: [`PreConfiguredAction`](client._internal_namespace.PreConfiguredAction.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig), [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets)\>[] - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:13 - -___ - -### taskManager - -• **taskManager**: [`TaskManagerSetupContract`](client._internal_namespace.TaskManagerSetupContract.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:9 - -___ - -### taskRunnerFactory - -• **taskRunnerFactory**: [`TaskRunnerFactory`](../classes/client._internal_namespace.TaskRunnerFactory.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/action_type_registry.d.ts:10 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionUpdate.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionUpdate.md deleted file mode 100644 index 1326f4f3b3361..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionUpdate.md +++ /dev/null @@ -1,51 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionUpdate - -# Interface: ActionUpdate - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionUpdate - -## Hierarchy - -- [`SavedObjectAttributes`](client._internal_namespace.SavedObjectAttributes.md) - - ↳ **`ActionUpdate`** - - ↳↳ [`Action`](client._internal_namespace.Action.md) - -## Table of contents - -### Properties - -- [config](client._internal_namespace.ActionUpdate.md#config) -- [name](client._internal_namespace.ActionUpdate.md#name) -- [secrets](client._internal_namespace.ActionUpdate.md#secrets) - -## Properties - -### config - -• **config**: [`SavedObjectAttributes`](client._internal_namespace.SavedObjectAttributes.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:15 - -___ - -### name - -• **name**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:14 - -___ - -### secrets - -• **secrets**: [`SavedObjectAttributes`](client._internal_namespace.SavedObjectAttributes.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:16 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsConfigurationUtilities.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsConfigurationUtilities.md deleted file mode 100644 index f2562a697f255..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsConfigurationUtilities.md +++ /dev/null @@ -1,217 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionsConfigurationUtilities - -# Interface: ActionsConfigurationUtilities - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionsConfigurationUtilities - -## Table of contents - -### Methods - -- [ensureActionTypeEnabled](client._internal_namespace.ActionsConfigurationUtilities.md#ensureactiontypeenabled) -- [ensureHostnameAllowed](client._internal_namespace.ActionsConfigurationUtilities.md#ensurehostnameallowed) -- [ensureUriAllowed](client._internal_namespace.ActionsConfigurationUtilities.md#ensureuriallowed) -- [getCustomHostSettings](client._internal_namespace.ActionsConfigurationUtilities.md#getcustomhostsettings) -- [getMicrosoftGraphApiUrl](client._internal_namespace.ActionsConfigurationUtilities.md#getmicrosoftgraphapiurl) -- [getProxySettings](client._internal_namespace.ActionsConfigurationUtilities.md#getproxysettings) -- [getResponseSettings](client._internal_namespace.ActionsConfigurationUtilities.md#getresponsesettings) -- [getSSLSettings](client._internal_namespace.ActionsConfigurationUtilities.md#getsslsettings) -- [isActionTypeEnabled](client._internal_namespace.ActionsConfigurationUtilities.md#isactiontypeenabled) -- [isHostnameAllowed](client._internal_namespace.ActionsConfigurationUtilities.md#ishostnameallowed) -- [isUriAllowed](client._internal_namespace.ActionsConfigurationUtilities.md#isuriallowed) - -## Methods - -### ensureActionTypeEnabled - -▸ **ensureActionTypeEnabled**(`actionType`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionType` | `string` | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:10 - -___ - -### ensureHostnameAllowed - -▸ **ensureHostnameAllowed**(`hostname`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `hostname` | `string` | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:8 - -___ - -### ensureUriAllowed - -▸ **ensureUriAllowed**(`uri`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `uri` | `string` | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:9 - -___ - -### getCustomHostSettings - -▸ **getCustomHostSettings**(`targetUrl`): `undefined` \| `Readonly`<{ `smtp?`: `Readonly`<{ `ignoreTLS?`: `boolean` ; `requireTLS?`: `boolean` }\> ; `ssl?`: `Readonly`<{ `certificateAuthoritiesData?`: `string` ; `certificateAuthoritiesFiles?`: `string` \| `string`[] ; `rejectUnauthorized?`: `boolean` ; `verificationMode?`: ``"none"`` \| ``"certificate"`` \| ``"full"`` }\> } & { `url`: `string` }\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `targetUrl` | `string` | - -#### Returns - -`undefined` \| `Readonly`<{ `smtp?`: `Readonly`<{ `ignoreTLS?`: `boolean` ; `requireTLS?`: `boolean` }\> ; `ssl?`: `Readonly`<{ `certificateAuthoritiesData?`: `string` ; `certificateAuthoritiesFiles?`: `string` \| `string`[] ; `rejectUnauthorized?`: `boolean` ; `verificationMode?`: ``"none"`` \| ``"certificate"`` \| ``"full"`` }\> } & { `url`: `string` }\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:14 - -___ - -### getMicrosoftGraphApiUrl - -▸ **getMicrosoftGraphApiUrl**(): `undefined` \| `string` - -#### Returns - -`undefined` \| `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:15 - -___ - -### getProxySettings - -▸ **getProxySettings**(): `undefined` \| [`ProxySettings`](client._internal_namespace.ProxySettings.md) - -#### Returns - -`undefined` \| [`ProxySettings`](client._internal_namespace.ProxySettings.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:12 - -___ - -### getResponseSettings - -▸ **getResponseSettings**(): [`ResponseSettings`](client._internal_namespace.ResponseSettings.md) - -#### Returns - -[`ResponseSettings`](client._internal_namespace.ResponseSettings.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:13 - -___ - -### getSSLSettings - -▸ **getSSLSettings**(): [`SSLSettings`](client._internal_namespace.SSLSettings.md) - -#### Returns - -[`SSLSettings`](client._internal_namespace.SSLSettings.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:11 - -___ - -### isActionTypeEnabled - -▸ **isActionTypeEnabled**(`actionType`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `actionType` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:7 - -___ - -### isHostnameAllowed - -▸ **isHostnameAllowed**(`hostname`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `hostname` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:5 - -___ - -### isUriAllowed - -▸ **isUriAllowed**(`uri`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `uri` | `string` | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_config.d.ts:6 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsLicenseInformation.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsLicenseInformation.md deleted file mode 100644 index c7ab568b57c35..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ActionsLicenseInformation.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ActionsLicenseInformation - -# Interface: ActionsLicenseInformation - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ActionsLicenseInformation - -## Table of contents - -### Properties - -- [enableAppLink](client._internal_namespace.ActionsLicenseInformation.md#enableapplink) -- [message](client._internal_namespace.ActionsLicenseInformation.md#message) -- [showAppLink](client._internal_namespace.ActionsLicenseInformation.md#showapplink) - -## Properties - -### enableAppLink - -• **enableAppLink**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:9 - -___ - -### message - -• **message**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:10 - -___ - -### showAppLink - -• **showAppLink**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:8 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AggregationBuilder.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AggregationBuilder.md deleted file mode 100644 index 9790711e77193..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AggregationBuilder.md +++ /dev/null @@ -1,68 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AggregationBuilder - -# Interface: AggregationBuilder - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AggregationBuilder - -## Table of contents - -### Methods - -- [build](client._internal_namespace.AggregationBuilder.md#build) -- [formatResponse](client._internal_namespace.AggregationBuilder.md#formatresponse) -- [getName](client._internal_namespace.AggregationBuilder.md#getname) - -## Methods - -### build - -▸ **build**(): `Record`<`string`, `AggregationsAggregationContainer`\> - -#### Returns - -`Record`<`string`, `AggregationsAggregationContainer`\> - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/types.ts:20](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/types.ts#L20) - -___ - -### formatResponse - -▸ **formatResponse**(`aggregations`): `Object` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `aggregations` | [`AggregationResponse`](../modules/client._internal_namespace.md#aggregationresponse) | - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `actions` | `undefined` \| { isolateHost?: { isolate: { total: number; }; unisolate: { total: number; }; } \| undefined; } | -| `alerts` | `undefined` \| { count?: number \| undefined; hosts?: { total: number; values: { name: string \| undefined; id: string; count: number; }[]; } \| undefined; users?: { total: number; values: { name: string; count: number; }[]; } \| undefined; } | -| `connectors` | `undefined` \| { `total`: `number` = rt.number } | -| `lifespan` | `undefined` \| { `closeDate`: ``null`` \| `string` ; `creationDate`: `string` = rt.string; `statusInfo`: { openDuration: number; inProgressDuration: number; reopenDates: string[]; } = StatusInfoRt } | - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/types.ts:21](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/types.ts#L21) - -___ - -### getName - -▸ **getName**(): `string` - -#### Returns - -`string` - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/types.ts:22](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/types.ts#L22) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Alert.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Alert.md deleted file mode 100644 index 71ae71dd5cfaf..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Alert.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Alert - -# Interface: Alert - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Alert - -## Table of contents - -### Properties - -- [\_id](client._internal_namespace.Alert.md#_id) -- [\_index](client._internal_namespace.Alert.md#_index) -- [\_source](client._internal_namespace.Alert.md#_source) - -## Properties - -### \_id - -• **\_id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:233](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L233) - -___ - -### \_index - -• **\_index**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:234](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L234) - -___ - -### \_source - -• **\_source**: `Record`<`string`, `unknown`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:235](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L235) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertIdIndex.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertIdIndex.md deleted file mode 100644 index b9a09536ed21c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertIdIndex.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AlertIdIndex - -# Interface: AlertIdIndex - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AlertIdIndex - -## Table of contents - -### Properties - -- [id](client._internal_namespace.AlertIdIndex.md#id) -- [index](client._internal_namespace.AlertIdIndex.md#index) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:243](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L243) - -___ - -### index - -• **index**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:244](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L244) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertInfo.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertInfo.md deleted file mode 100644 index acf8e3b09b74f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertInfo.md +++ /dev/null @@ -1,34 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AlertInfo - -# Interface: AlertInfo - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AlertInfo - -This structure holds the alert ID and index from an alert comment - -## Table of contents - -### Properties - -- [id](client._internal_namespace.AlertInfo.md#id) -- [index](client._internal_namespace.AlertInfo.md#index) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/common/types.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/common/types.ts#L15) - -___ - -### index - -• **index**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/common/types.ts:16](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/common/types.ts#L16) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertsResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertsResponse.md deleted file mode 100644 index aae855d5d0d4a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AlertsResponse.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AlertsResponse - -# Interface: AlertsResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AlertsResponse - -## Table of contents - -### Properties - -- [docs](client._internal_namespace.AlertsResponse.md#docs) - -## Properties - -### docs - -• **docs**: [`Alert`](client._internal_namespace.Alert.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:239](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L239) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AppCategory.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AppCategory.md deleted file mode 100644 index 7ab9c4c95ff66..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AppCategory.md +++ /dev/null @@ -1,83 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AppCategory - -# Interface: AppCategory - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AppCategory - -A category definition for nav links to know where to sort them in the left hand nav - -## Table of contents - -### Properties - -- [ariaLabel](client._internal_namespace.AppCategory.md#arialabel) -- [euiIconType](client._internal_namespace.AppCategory.md#euiicontype) -- [id](client._internal_namespace.AppCategory.md#id) -- [label](client._internal_namespace.AppCategory.md#label) -- [order](client._internal_namespace.AppCategory.md#order) - -## Properties - -### ariaLabel - -• `Optional` **ariaLabel**: `string` - -If the visual label isn't appropriate for screen readers, -can override it here - -#### Defined in - -src/core/target/types/types/app_category.d.ts:20 - -___ - -### euiIconType - -• `Optional` **euiIconType**: `string` - -Define an icon to be used for the category -If the category is only 1 item, and no icon is defined, will default to the product icon -Defaults to initials if no icon is defined - -#### Defined in - -src/core/target/types/types/app_category.d.ts:32 - -___ - -### id - -• **id**: `string` - -Unique identifier for the categories - -#### Defined in - -src/core/target/types/types/app_category.d.ts:10 - -___ - -### label - -• **label**: `string` - -Label used for category name. -Also used as aria-label if one isn't set. - -#### Defined in - -src/core/target/types/types/app_category.d.ts:15 - -___ - -### order - -• `Optional` **order**: `number` - -The order that categories will be sorted in -Prefer large steps between categories to allow for further editing -(Default categories are in steps of 1000) - -#### Defined in - -src/core/target/types/types/app_category.d.ts:26 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AttachedToCaseArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AttachedToCaseArgs.md deleted file mode 100644 index 86ea1605c1374..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AttachedToCaseArgs.md +++ /dev/null @@ -1,55 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AttachedToCaseArgs - -# Interface: AttachedToCaseArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AttachedToCaseArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`AttachedToCaseArgs`** - - ↳↳ [`CountActionsAttachedToCaseArgs`](client._internal_namespace.CountActionsAttachedToCaseArgs.md) - -## Table of contents - -### Properties - -- [caseId](client._internal_namespace.AttachedToCaseArgs.md#caseid) -- [filter](client._internal_namespace.AttachedToCaseArgs.md#filter) -- [unsecuredSavedObjectsClient](client._internal_namespace.AttachedToCaseArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### caseId - -• **caseId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:33](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L33) - -___ - -### filter - -• `Optional` **filter**: `KueryNode` - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:34](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L34) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Attributes.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Attributes.md deleted file mode 100644 index fd8a32f7afb6b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Attributes.md +++ /dev/null @@ -1,84 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Attributes - -# Interface: Attributes - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Attributes - -## Table of contents - -### Properties - -- [action](client._internal_namespace.Attributes.md#action) -- [created\_at](client._internal_namespace.Attributes.md#created_at) -- [created\_by](client._internal_namespace.Attributes.md#created_by) -- [owner](client._internal_namespace.Attributes.md#owner) -- [payload](client._internal_namespace.Attributes.md#payload) -- [type](client._internal_namespace.Attributes.md#type) - -## Properties - -### action - -• **action**: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:84](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L84) - -___ - -### created\_at - -• **created\_at**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:85](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L85) - -___ - -### created\_by - -• **created\_by**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:86](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L86) - -___ - -### owner - -• **owner**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:87](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L87) - -___ - -### payload - -• **payload**: `Record`<`string`, `unknown`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:89](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L89) - -___ - -### type - -• **type**: ``"description"`` \| ``"tags"`` \| ``"title"`` \| ``"connector"`` \| ``"settings"`` \| ``"status"`` \| ``"comment"`` \| ``"pushed"`` \| ``"create_case"`` \| ``"delete_case"`` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:88](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L88) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditEvent.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditEvent.md deleted file mode 100644 index d0bbaabfc416b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditEvent.md +++ /dev/null @@ -1,59 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuditEvent - -# Interface: AuditEvent - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuditEvent - -Audit event schema using ECS format: https://www.elastic.co/guide/en/ecs/1.12/index.html - -If you add additional fields to the schema ensure you update the Kibana Filebeat module: -https://github.com/elastic/beats/tree/master/filebeat/module/kibana - -## Hierarchy - -- `LogMeta` - - ↳ **`AuditEvent`** - -## Table of contents - -### Properties - -- [kibana](client._internal_namespace.AuditEvent.md#kibana) -- [message](client._internal_namespace.AuditEvent.md#message) - -## Properties - -### kibana - -• `Optional` **kibana**: `Object` - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `add_to_spaces?` | readonly `string`[] | Set of space IDs that a saved object was shared to. | -| `authentication_provider?` | `string` | Name of authentication provider associated with a login event. | -| `authentication_realm?` | `string` | Name of Elasticsearch realm that has authenticated the user. | -| `authentication_type?` | `string` | Type of authentication provider associated with a login event. | -| `delete_from_spaces?` | readonly `string`[] | Set of space IDs that a saved object was removed from. | -| `lookup_realm?` | `string` | Name of Elasticsearch realm where the user details were retrieved from. | -| `saved_object?` | `Object` | Saved object that was created, changed, deleted or accessed as part of this event. | -| `saved_object.id` | `string` | - | -| `saved_object.type` | `string` | - | -| `session_id?` | `string` | The ID of the user session associated with this event. Each login attempt results in a unique session id. | -| `space_id?` | `string` | The ID of the space associated with this event. | - -#### Defined in - -x-pack/plugins/security/target/types/server/audit/audit_events.d.ts:14 - -___ - -### message - -• **message**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/server/audit/audit_events.d.ts:13 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditLogger.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditLogger.md deleted file mode 100644 index c4caafd67c08d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuditLogger.md +++ /dev/null @@ -1,52 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuditLogger - -# Interface: AuditLogger - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuditLogger - -## Table of contents - -### Methods - -- [log](client._internal_namespace.AuditLogger.md#log) - -## Methods - -### log - -▸ **log**(`event`): `void` - -Logs an [AuditEvent](client._internal_namespace.AuditEvent.md) and automatically adds meta data about the -current user, space and correlation id. - -Guidelines around what events should be logged and how they should be -structured can be found in: `/x-pack/plugins/security/README.md` - -**`example`** -```typescript -const auditLogger = securitySetup.audit.asScoped(request); -auditLogger.log({ - message: 'User is updating dashboard [id=123]', - event: { - action: 'saved_object_update', - outcome: 'unknown' - }, - kibana: { - saved_object: { type: 'dashboard', id: '123' } - }, -}); -``` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `event` | `undefined` \| [`AuditEvent`](client._internal_namespace.AuditEvent.md) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/security/target/types/server/audit/audit_service.d.ts:32 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthFilterHelpers.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthFilterHelpers.md deleted file mode 100644 index c4117202317cc..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthFilterHelpers.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthFilterHelpers - -# Interface: AuthFilterHelpers - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthFilterHelpers - -Defines the helper methods and necessary information for authorizing the find API's request. - -## Table of contents - -### Properties - -- [ensureSavedObjectsAreAuthorized](client._internal_namespace.AuthFilterHelpers.md#ensuresavedobjectsareauthorized) -- [filter](client._internal_namespace.AuthFilterHelpers.md#filter) - -## Properties - -### ensureSavedObjectsAreAuthorized - -• **ensureSavedObjectsAreAuthorized**: [`EnsureSOAuthCallback`](../modules/client._internal_namespace.md#ensuresoauthcallback) - -Utility function for checking that the returned entities are in fact authorized for the user making the request - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:123](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L123) - -___ - -### filter - -• `Optional` **filter**: `KueryNode` - -The owner filter to pass to the saved object client's find operation that is scoped to the authorized owners - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:119](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L119) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticatedUser.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticatedUser.md deleted file mode 100644 index 69dc207747edf..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticatedUser.md +++ /dev/null @@ -1,170 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthenticatedUser - -# Interface: AuthenticatedUser - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthenticatedUser - -Represents the currently authenticated user. - -## Hierarchy - -- [`User`](client._internal_namespace.User.md) - - ↳ **`AuthenticatedUser`** - -## Table of contents - -### Properties - -- [authentication\_provider](client._internal_namespace.AuthenticatedUser.md#authentication_provider) -- [authentication\_realm](client._internal_namespace.AuthenticatedUser.md#authentication_realm) -- [authentication\_type](client._internal_namespace.AuthenticatedUser.md#authentication_type) -- [email](client._internal_namespace.AuthenticatedUser.md#email) -- [enabled](client._internal_namespace.AuthenticatedUser.md#enabled) -- [full\_name](client._internal_namespace.AuthenticatedUser.md#full_name) -- [lookup\_realm](client._internal_namespace.AuthenticatedUser.md#lookup_realm) -- [metadata](client._internal_namespace.AuthenticatedUser.md#metadata) -- [roles](client._internal_namespace.AuthenticatedUser.md#roles) -- [username](client._internal_namespace.AuthenticatedUser.md#username) - -## Properties - -### authentication\_provider - -• **authentication\_provider**: [`AuthenticationProvider`](client._internal_namespace.AuthenticationProvider.md) - -The authentication provider that used to authenticate user. - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authenticated_user.d.ts:22 - -___ - -### authentication\_realm - -• **authentication\_realm**: [`UserRealm`](client._internal_namespace.UserRealm.md) - -The name and type of the Realm that has authenticated the user. - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authenticated_user.d.ts:14 - -___ - -### authentication\_type - -• **authentication\_type**: `string` - -The AuthenticationType used by ES to authenticate the user. - -**`example`** "realm" | "api_key" | "token" | "anonymous" | "internal" - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authenticated_user.d.ts:28 - -___ - -### email - -• `Optional` **email**: `string` - -#### Inherited from - -[User](client._internal_namespace.User.md).[email](client._internal_namespace.User.md#email) - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:3 - -___ - -### enabled - -• **enabled**: `boolean` - -#### Inherited from - -[User](client._internal_namespace.User.md).[enabled](client._internal_namespace.User.md#enabled) - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:6 - -___ - -### full\_name - -• `Optional` **full\_name**: `string` - -#### Inherited from - -[User](client._internal_namespace.User.md).[full_name](client._internal_namespace.User.md#full_name) - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:4 - -___ - -### lookup\_realm - -• **lookup\_realm**: [`UserRealm`](client._internal_namespace.UserRealm.md) - -The name and type of the Realm where the user information were retrieved from. - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authenticated_user.d.ts:18 - -___ - -### metadata - -• `Optional` **metadata**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `_deprecated?` | `boolean` | -| `_deprecated_reason?` | `string` | -| `_reserved` | `boolean` | - -#### Inherited from - -[User](client._internal_namespace.User.md).[metadata](client._internal_namespace.User.md#metadata) - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:7 - -___ - -### roles - -• **roles**: readonly `string`[] - -#### Inherited from - -[User](client._internal_namespace.User.md).[roles](client._internal_namespace.User.md#roles) - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:5 - -___ - -### username - -• **username**: `string` - -#### Inherited from - -[User](client._internal_namespace.User.md).[username](client._internal_namespace.User.md#username) - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:2 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticationProvider.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticationProvider.md deleted file mode 100644 index a10edc042b528..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthenticationProvider.md +++ /dev/null @@ -1,34 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthenticationProvider - -# Interface: AuthenticationProvider - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthenticationProvider - -Type and name tuple to identify provider used to authenticate user. - -## Table of contents - -### Properties - -- [name](client._internal_namespace.AuthenticationProvider.md#name) -- [type](client._internal_namespace.AuthenticationProvider.md#type) - -## Properties - -### name - -• **name**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authentication_provider.d.ts:6 - -___ - -### type - -• **type**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authentication_provider.d.ts:5 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationMode-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationMode-1.md deleted file mode 100644 index ff75cd19e524c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationMode-1.md +++ /dev/null @@ -1,31 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthorizationMode - -# Interface: AuthorizationMode - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthorizationMode - -## Table of contents - -### Methods - -- [useRbacForRequest](client._internal_namespace.AuthorizationMode-1.md#userbacforrequest) - -## Methods - -### useRbacForRequest - -▸ **useRbacForRequest**(`request`): `boolean` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/mode.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationServiceSetup.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationServiceSetup.md deleted file mode 100644 index 5011fe972f36e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.AuthorizationServiceSetup.md +++ /dev/null @@ -1,71 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / AuthorizationServiceSetup - -# Interface: AuthorizationServiceSetup - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).AuthorizationServiceSetup - -Authorization services available on the setup contract of the security plugin. - -## Table of contents - -### Properties - -- [actions](client._internal_namespace.AuthorizationServiceSetup.md#actions) -- [checkPrivilegesDynamicallyWithRequest](client._internal_namespace.AuthorizationServiceSetup.md#checkprivilegesdynamicallywithrequest) -- [checkPrivilegesWithRequest](client._internal_namespace.AuthorizationServiceSetup.md#checkprivilegeswithrequest) -- [checkSavedObjectsPrivilegesWithRequest](client._internal_namespace.AuthorizationServiceSetup.md#checksavedobjectsprivilegeswithrequest) -- [mode](client._internal_namespace.AuthorizationServiceSetup.md#mode) - -## Properties - -### actions - -• **actions**: [`Actions`](../classes/client._internal_namespace.Actions.md) - -Actions are used to create the "actions" that are associated with Elasticsearch's -application privileges, and are used to perform the authorization checks implemented -by the various `checkPrivilegesWithRequest` derivatives. - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/authorization_service.d.ts:52 - -___ - -### checkPrivilegesDynamicallyWithRequest - -• **checkPrivilegesDynamicallyWithRequest**: [`CheckPrivilegesDynamicallyWithRequest`](../modules/client._internal_namespace.md#checkprivilegesdynamicallywithrequest) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/authorization_service.d.ts:54 - -___ - -### checkPrivilegesWithRequest - -• **checkPrivilegesWithRequest**: [`CheckPrivilegesWithRequest`](../modules/client._internal_namespace.md#checkprivilegeswithrequest) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/authorization_service.d.ts:53 - -___ - -### checkSavedObjectsPrivilegesWithRequest - -• **checkSavedObjectsPrivilegesWithRequest**: [`CheckSavedObjectsPrivilegesWithRequest`](../modules/client._internal_namespace.md#checksavedobjectsprivilegeswithrequest) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/authorization_service.d.ts:55 - -___ - -### mode - -• **mode**: [`AuthorizationMode`](client._internal_namespace.AuthorizationMode-1.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/authorization_service.d.ts:56 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BeforeSaveContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BeforeSaveContext.md deleted file mode 100644 index 6e52bf637eada..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BeforeSaveContext.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BeforeSaveContext - -# Interface: BeforeSaveContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BeforeSaveContext - -## Table of contents - -### Properties - -- [taskInstance](client._internal_namespace.BeforeSaveContext.md#taskinstance) - -## Properties - -### taskInstance - -• **taskInstance**: [`TaskInstance`](client._internal_namespace.TaskInstance.md) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderParameters.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderParameters.md deleted file mode 100644 index c91716f5b2248..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderParameters.md +++ /dev/null @@ -1,205 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BuilderParameters - -# Interface: BuilderParameters - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BuilderParameters - -## Table of contents - -### Properties - -- [comment](client._internal_namespace.BuilderParameters.md#comment) -- [connector](client._internal_namespace.BuilderParameters.md#connector) -- [create\_case](client._internal_namespace.BuilderParameters.md#create_case) -- [delete\_case](client._internal_namespace.BuilderParameters.md#delete_case) -- [description](client._internal_namespace.BuilderParameters.md#description) -- [pushed](client._internal_namespace.BuilderParameters.md#pushed) -- [settings](client._internal_namespace.BuilderParameters.md#settings) -- [status](client._internal_namespace.BuilderParameters.md#status) -- [tags](client._internal_namespace.BuilderParameters.md#tags) -- [title](client._internal_namespace.BuilderParameters.md#title) - -## Properties - -### comment - -• **comment**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.attachment` | { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:44](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L44) - -___ - -### connector - -• **connector**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.connector` | { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:49](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L49) - -___ - -### create\_case - -• **create\_case**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.connector` | { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } | -| `parameters.payload.description` | `string` | -| `parameters.payload.owner` | `string` | -| `parameters.payload.settings` | { syncAlerts: boolean; } | -| `parameters.payload.tags` | `string`[] | -| `parameters.payload.title` | `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:56](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L56) - -___ - -### delete\_case - -• **delete\_case**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:61](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L61) - -___ - -### description - -• **description**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.description` | `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L25) - -___ - -### pushed - -• **pushed**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.externalService` | { `connector_id`: `string` = rt.string } & { `connector_name`: `string` = rt.string; `external_id`: `string` = rt.string; `external_title`: `string` = rt.string; `external_url`: `string` = rt.string; `pushed_at`: `string` = rt.string; `pushed_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT } | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:34](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L34) - -___ - -### settings - -• **settings**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.settings` | `Object` | -| `parameters.payload.settings.syncAlerts` | `boolean` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:41](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L41) - -___ - -### status - -• **status**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.status` | [`CaseStatuses`](../enums/client._internal_namespace.CaseStatuses.md) | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:28](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L28) - -___ - -### tags - -• **tags**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.tags` | `string`[] | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:31](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L31) - -___ - -### title - -• **title**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `parameters` | `Object` | -| `parameters.payload` | `Object` | -| `parameters.payload.title` | `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:22](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L22) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderReturnValue.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderReturnValue.md deleted file mode 100644 index ab7e6bdade21e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BuilderReturnValue.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BuilderReturnValue - -# Interface: BuilderReturnValue - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BuilderReturnValue - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.BuilderReturnValue.md#attributes) -- [references](client._internal_namespace.BuilderReturnValue.md#references) - -## Properties - -### attributes - -• **attributes**: [`Attributes`](client._internal_namespace.Attributes.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:93](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L93) - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:94](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L94) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md deleted file mode 100644 index ac16ce838e615..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md +++ /dev/null @@ -1,125 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BulkCreateAttachmentDeletionUserAction - -# Interface: BulkCreateAttachmentDeletionUserAction - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BulkCreateAttachmentDeletionUserAction - -## Hierarchy - -- `Omit`<[`CommonUserActionArgs`](../modules/client._internal_namespace.md#commonuseractionargs), ``"owner"``\> - - ↳ **`BulkCreateAttachmentDeletionUserAction`** - -## Table of contents - -### Properties - -- [action](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#action) -- [attachmentId](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#attachmentid) -- [attachments](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#attachments) -- [caseId](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#caseid) -- [connectorId](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#connectorid) -- [unsecuredSavedObjectsClient](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#unsecuredsavedobjectsclient) -- [user](client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md#user) - -## Properties - -### action - -• `Optional` **action**: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` - -#### Inherited from - -Omit.action - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:80](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L80) - -___ - -### attachmentId - -• `Optional` **attachmentId**: `string` - -#### Inherited from - -Omit.attachmentId - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:78](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L78) - -___ - -### attachments - -• **attachments**: { `attachment`: { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } ; `id`: `string` ; `owner`: `string` }[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:95](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L95) - -___ - -### caseId - -• **caseId**: `string` - -#### Inherited from - -Omit.caseId - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:76](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L76) - -___ - -### connectorId - -• `Optional` **connectorId**: `string` - -#### Inherited from - -Omit.connectorId - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L79) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -Omit.unsecuredSavedObjectsClient - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) - -___ - -### user - -• **user**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Inherited from - -Omit.user - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:75](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L75) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md deleted file mode 100644 index 5acc559d72638..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md +++ /dev/null @@ -1,72 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BulkCreateBulkUpdateCaseUserActions - -# Interface: BulkCreateBulkUpdateCaseUserActions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BulkCreateBulkUpdateCaseUserActions - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`BulkCreateBulkUpdateCaseUserActions`** - -## Table of contents - -### Properties - -- [originalCases](client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md#originalcases) -- [unsecuredSavedObjectsClient](client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md#unsecuredsavedobjectsclient) -- [updatedCases](client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md#updatedcases) -- [user](client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md#user) - -## Properties - -### originalCases - -• **originalCases**: [`SavedObject`](client._internal_namespace.SavedObject.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:89](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L89) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) - -___ - -### updatedCases - -• **updatedCases**: [`SavedObjectsUpdateResponse`](client._internal_namespace.SavedObjectsUpdateResponse.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\>[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:90](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L90) - -___ - -### user - -• **user**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:91](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L91) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateCaseDeletionUserAction.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateCaseDeletionUserAction.md deleted file mode 100644 index d925395547e55..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkCreateCaseDeletionUserAction.md +++ /dev/null @@ -1,61 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BulkCreateCaseDeletionUserAction - -# Interface: BulkCreateCaseDeletionUserAction - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BulkCreateCaseDeletionUserAction - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`BulkCreateCaseDeletionUserAction`** - -## Table of contents - -### Properties - -- [cases](client._internal_namespace.BulkCreateCaseDeletionUserAction.md#cases) -- [unsecuredSavedObjectsClient](client._internal_namespace.BulkCreateCaseDeletionUserAction.md#unsecuredsavedobjectsclient) -- [user](client._internal_namespace.BulkCreateCaseDeletionUserAction.md#user) - -## Properties - -### cases - -• **cases**: { `connectorId`: `string` ; `id`: `string` ; `owner`: `string` }[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:78](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L78) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) - -___ - -### user - -• **user**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L79) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkUpdateAttachmentArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkUpdateAttachmentArgs.md deleted file mode 100644 index ecaf5f4b535f7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.BulkUpdateAttachmentArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / BulkUpdateAttachmentArgs - -# Interface: BulkUpdateAttachmentArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).BulkUpdateAttachmentArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`BulkUpdateAttachmentArgs`** - -## Table of contents - -### Properties - -- [comments](client._internal_namespace.BulkUpdateAttachmentArgs.md#comments) -- [unsecuredSavedObjectsClient](client._internal_namespace.BulkUpdateAttachmentArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### comments - -• **comments**: [`UpdateArgs`](client._internal_namespace.UpdateArgs.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:62](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L62) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CancellableTask.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CancellableTask.md deleted file mode 100644 index f7a6457695400..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CancellableTask.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CancellableTask - -# Interface: CancellableTask - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CancellableTask - -## Table of contents - -### Properties - -- [cancel](client._internal_namespace.CancellableTask.md#cancel) -- [run](client._internal_namespace.CancellableTask.md#run) - -## Properties - -### cancel - -• `Optional` **cancel**: [`CancelFunction`](../modules/client._internal_namespace.md#cancelfunction) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:68 - -___ - -### run - -• **run**: [`RunFunction`](../modules/client._internal_namespace.md#runfunction) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:67 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Capabilities.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Capabilities.md deleted file mode 100644 index b9cddb8df9faf..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Capabilities.md +++ /dev/null @@ -1,63 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Capabilities - -# Interface: Capabilities - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Capabilities - -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. - -## Indexable - -▪ [key: `string`]: `Record`<`string`, `boolean` \| `Record`<`string`, `boolean`\>\> - -Custom capabilities, registered by plugins. - -## Table of contents - -### Properties - -- [catalogue](client._internal_namespace.Capabilities.md#catalogue) -- [management](client._internal_namespace.Capabilities.md#management) -- [navLinks](client._internal_namespace.Capabilities.md#navlinks) - -## Properties - -### catalogue - -• **catalogue**: `Record`<`string`, `boolean`\> - -Catalogue capabilities. Catalogue entries drive the visibility of the Kibana homepage options. - -#### Defined in - -src/core/target/types/types/capabilities.d.ts:16 - -___ - -### management - -• **management**: `Object` - -Management section capabilities. - -#### Index signature - -▪ [sectionId: `string`]: `Record`<`string`, `boolean`\> - -#### Defined in - -src/core/target/types/types/capabilities.d.ts:12 - -___ - -### navLinks - -• **navLinks**: `Record`<`string`, `boolean`\> - -Navigation link capabilities. - -#### Defined in - -src/core/target/types/types/capabilities.d.ts:10 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CaseCommentStats.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CaseCommentStats.md deleted file mode 100644 index e4596ea3eacc1..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CaseCommentStats.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CaseCommentStats - -# Interface: CaseCommentStats - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CaseCommentStats - -## Table of contents - -### Properties - -- [alertTotals](client._internal_namespace.CaseCommentStats.md#alerttotals) -- [commentTotals](client._internal_namespace.CaseCommentStats.md#commenttotals) - -## Properties - -### alertTotals - -• **alertTotals**: `Map`<`string`, `number`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:115](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L115) - -___ - -### commentTotals - -• **commentTotals**: `Map`<`string`, `number`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:114](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L114) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesClientArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesClientArgs.md deleted file mode 100644 index 9ec38679b26d0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesClientArgs.md +++ /dev/null @@ -1,160 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CasesClientArgs - -# Interface: CasesClientArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CasesClientArgs - -Parameters for initializing a cases client - -## Table of contents - -### Properties - -- [actionsClient](client._internal_namespace.CasesClientArgs.md#actionsclient) -- [alertsService](client._internal_namespace.CasesClientArgs.md#alertsservice) -- [attachmentService](client._internal_namespace.CasesClientArgs.md#attachmentservice) -- [authorization](client._internal_namespace.CasesClientArgs.md#authorization) -- [caseConfigureService](client._internal_namespace.CasesClientArgs.md#caseconfigureservice) -- [caseService](client._internal_namespace.CasesClientArgs.md#caseservice) -- [connectorMappingsService](client._internal_namespace.CasesClientArgs.md#connectormappingsservice) -- [lensEmbeddableFactory](client._internal_namespace.CasesClientArgs.md#lensembeddablefactory) -- [logger](client._internal_namespace.CasesClientArgs.md#logger) -- [unsecuredSavedObjectsClient](client._internal_namespace.CasesClientArgs.md#unsecuredsavedobjectsclient) -- [user](client._internal_namespace.CasesClientArgs.md#user) -- [userActionService](client._internal_namespace.CasesClientArgs.md#useractionservice) - -## Properties - -### actionsClient - -• `Readonly` **actionsClient**: `PublicMethodsOf`<[`ActionsClient`](../modules/client._internal_namespace.md#actionsclient)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:38](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L38) - -___ - -### alertsService - -• `Readonly` **alertsService**: [`AlertService`](../classes/client._internal_namespace.AlertService.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:33](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L33) - -___ - -### attachmentService - -• `Readonly` **attachmentService**: [`AttachmentService`](../classes/client._internal_namespace.AttachmentService.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:34](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L34) - -___ - -### authorization - -• `Readonly` **authorization**: `PublicMethodsOf`<[`Authorization`](../classes/client._internal_namespace.Authorization.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:37](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L37) - -___ - -### caseConfigureService - -• `Readonly` **caseConfigureService**: [`CaseConfigureService`](../classes/client._internal_namespace.CaseConfigureService.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:27](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L27) - -___ - -### caseService - -• `Readonly` **caseService**: [`CasesService`](../classes/client._internal_namespace.CasesService.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:28](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L28) - -___ - -### connectorMappingsService - -• `Readonly` **connectorMappingsService**: [`ConnectorMappingsService`](../classes/client._internal_namespace.ConnectorMappingsService.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:29](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L29) - -___ - -### lensEmbeddableFactory - -• `Readonly` **lensEmbeddableFactory**: () => [`EmbeddableRegistryDefinition`](client._internal_namespace.EmbeddableRegistryDefinition.md)<[`EmbeddableStateWithType`](../modules/client._internal_namespace.md#embeddablestatewithtype)\> - -#### Type declaration - -▸ (): [`EmbeddableRegistryDefinition`](client._internal_namespace.EmbeddableRegistryDefinition.md)<[`EmbeddableStateWithType`](../modules/client._internal_namespace.md#embeddablestatewithtype)\> - -##### Returns - -[`EmbeddableRegistryDefinition`](client._internal_namespace.EmbeddableRegistryDefinition.md)<[`EmbeddableStateWithType`](../modules/client._internal_namespace.md#embeddablestatewithtype)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:36](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L36) - -___ - -### logger - -• `Readonly` **logger**: `Logger` - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:35](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L35) - -___ - -### unsecuredSavedObjectsClient - -• `Readonly` **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:31](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L31) - -___ - -### user - -• `Readonly` **user**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L30) - -___ - -### userActionService - -• `Readonly` **userActionService**: [`CaseUserActionService`](../classes/client._internal_namespace.CaseUserActionService.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/types.ts:32](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/types.ts#L32) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesMapWithPageInfo.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesMapWithPageInfo.md deleted file mode 100644 index a39f560b084af..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CasesMapWithPageInfo.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CasesMapWithPageInfo - -# Interface: CasesMapWithPageInfo - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CasesMapWithPageInfo - -## Table of contents - -### Properties - -- [casesMap](client._internal_namespace.CasesMapWithPageInfo.md#casesmap) -- [page](client._internal_namespace.CasesMapWithPageInfo.md#page) -- [perPage](client._internal_namespace.CasesMapWithPageInfo.md#perpage) -- [total](client._internal_namespace.CasesMapWithPageInfo.md#total) - -## Properties - -### casesMap - -• **casesMap**: `Map`<`string`, { `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `totalAlerts`: `number` = rt.number; `totalComment`: `number` = rt.number; `version`: `string` = rt.string } & { `comments`: `undefined` \| { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }[] }\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:119](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L119) - -___ - -### page - -• **page**: `number` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:120](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L120) - -___ - -### perPage - -• **perPage**: `number` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:121](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L121) - -___ - -### total - -• **total**: `number` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:122](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L122) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivileges.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivileges.md deleted file mode 100644 index 6cf7583198177..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivileges.md +++ /dev/null @@ -1,78 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CheckPrivileges - -# Interface: CheckPrivileges - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CheckPrivileges - -## Table of contents - -### Methods - -- [atSpace](client._internal_namespace.CheckPrivileges.md#atspace) -- [atSpaces](client._internal_namespace.CheckPrivileges.md#atspaces) -- [globally](client._internal_namespace.CheckPrivileges.md#globally) - -## Methods - -### atSpace - -▸ **atSpace**(`spaceId`, `privileges`, `options?`): `Promise`<[`CheckPrivilegesResponse`](client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `spaceId` | `string` | -| `privileges` | [`CheckPrivilegesPayload`](client._internal_namespace.CheckPrivilegesPayload.md) | -| `options?` | [`CheckPrivilegesOptions`](client._internal_namespace.CheckPrivilegesOptions.md) | - -#### Returns - -`Promise`<[`CheckPrivilegesResponse`](client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:61 - -___ - -### atSpaces - -▸ **atSpaces**(`spaceIds`, `privileges`, `options?`): `Promise`<[`CheckPrivilegesResponse`](client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `spaceIds` | `string`[] | -| `privileges` | [`CheckPrivilegesPayload`](client._internal_namespace.CheckPrivilegesPayload.md) | -| `options?` | [`CheckPrivilegesOptions`](client._internal_namespace.CheckPrivilegesOptions.md) | - -#### Returns - -`Promise`<[`CheckPrivilegesResponse`](client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:62 - -___ - -### globally - -▸ **globally**(`privileges`, `options?`): `Promise`<[`CheckPrivilegesResponse`](client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `privileges` | [`CheckPrivilegesPayload`](client._internal_namespace.CheckPrivilegesPayload.md) | -| `options?` | [`CheckPrivilegesOptions`](client._internal_namespace.CheckPrivilegesOptions.md) | - -#### Returns - -`Promise`<[`CheckPrivilegesResponse`](client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:63 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesOptions.md deleted file mode 100644 index 85caefaa3b490..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesOptions.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CheckPrivilegesOptions - -# Interface: CheckPrivilegesOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CheckPrivilegesOptions - -Options to influce the privilege checks. - -## Table of contents - -### Properties - -- [requireLoginAction](client._internal_namespace.CheckPrivilegesOptions.md#requireloginaction) - -## Properties - -### requireLoginAction - -• `Optional` **requireLoginAction**: `boolean` - -Whether or not the `login` action should be required (default: true). -Setting this to false is not advised except for special circumstances, when you do not require -the request to belong to a user capable of logging into Kibana. - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:31 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesPayload.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesPayload.md deleted file mode 100644 index 29242fb43dbab..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesPayload.md +++ /dev/null @@ -1,39 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CheckPrivilegesPayload - -# Interface: CheckPrivilegesPayload - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CheckPrivilegesPayload - -## Table of contents - -### Properties - -- [elasticsearch](client._internal_namespace.CheckPrivilegesPayload.md#elasticsearch) -- [kibana](client._internal_namespace.CheckPrivilegesPayload.md#kibana) - -## Properties - -### elasticsearch - -• `Optional` **elasticsearch**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `cluster` | `string`[] | -| `index` | `Record`<`string`, `string`[]\> | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:67 - -___ - -### kibana - -• `Optional` **kibana**: `string` \| `string`[] - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:66 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesResponse.md deleted file mode 100644 index 8e4ce4ae9c815..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CheckPrivilegesResponse.md +++ /dev/null @@ -1,52 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CheckPrivilegesResponse - -# Interface: CheckPrivilegesResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CheckPrivilegesResponse - -## Table of contents - -### Properties - -- [hasAllRequested](client._internal_namespace.CheckPrivilegesResponse.md#hasallrequested) -- [privileges](client._internal_namespace.CheckPrivilegesResponse.md#privileges) -- [username](client._internal_namespace.CheckPrivilegesResponse.md#username) - -## Properties - -### hasAllRequested - -• **hasAllRequested**: `boolean` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:34 - -___ - -### privileges - -• **privileges**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `elasticsearch` | `Object` | -| `elasticsearch.cluster` | { `authorized`: `boolean` ; `privilege`: `string` }[] | -| `elasticsearch.index` | `Object` | -| `kibana` | { `authorized`: `boolean` ; `privilege`: `string` ; `resource?`: `string` }[] | - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:36 - -___ - -### username - -• **username**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:35 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-1.md deleted file mode 100644 index ded25fa2ce105..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-1.md +++ /dev/null @@ -1,55 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ClientArgs - -# Interface: ClientArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ClientArgs - -## Hierarchy - -- **`ClientArgs`** - - ↳ [`GetCaseIdsByAlertIdArgs`](client._internal_namespace.GetCaseIdsByAlertIdArgs.md) - - ↳ [`GetCaseArgs`](client._internal_namespace.GetCaseArgs.md) - - ↳ [`GetCasesArgs`](client._internal_namespace.GetCasesArgs.md) - - ↳ [`FindCasesArgs`](client._internal_namespace.FindCasesArgs.md) - - ↳ [`PostCaseArgs`](client._internal_namespace.PostCaseArgs.md) - - ↳ [`PatchCasesArgs`](client._internal_namespace.PatchCasesArgs.md) - - ↳ [`BulkCreateCaseDeletionUserAction`](client._internal_namespace.BulkCreateCaseDeletionUserAction.md) - - ↳ [`BulkCreateBulkUpdateCaseUserActions`](client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md) - - ↳ [`GetCaseUserActionArgs`](client._internal_namespace.GetCaseUserActionArgs.md) - - ↳ [`CreateUserActionES`](client._internal_namespace.CreateUserActionES.md) - - ↳ [`PostCaseUserActionArgs`](client._internal_namespace.PostCaseUserActionArgs.md) - - ↳ [`AttachedToCaseArgs`](client._internal_namespace.AttachedToCaseArgs.md) - - ↳ [`GetAttachmentArgs`](client._internal_namespace.GetAttachmentArgs.md) - - ↳ [`CreateAttachmentArgs`](client._internal_namespace.CreateAttachmentArgs.md) - - ↳ [`BulkUpdateAttachmentArgs`](client._internal_namespace.BulkUpdateAttachmentArgs.md) - -## Table of contents - -### Properties - -- [unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -## Properties - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-2.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-2.md deleted file mode 100644 index 78bc19f876c89..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs-2.md +++ /dev/null @@ -1,31 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ClientArgs - -# Interface: ClientArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ClientArgs - -## Hierarchy - -- **`ClientArgs`** - - ↳ [`FindConnectorMappingsArgs`](client._internal_namespace.FindConnectorMappingsArgs.md) - - ↳ [`PostConnectorMappingsArgs`](client._internal_namespace.PostConnectorMappingsArgs.md) - - ↳ [`UpdateConnectorMappingsArgs`](client._internal_namespace.UpdateConnectorMappingsArgs.md) - -## Table of contents - -### Properties - -- [unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-2.md#unsecuredsavedobjectsclient) - -## Properties - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L15) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs.md deleted file mode 100644 index 9e5709a8b99ba..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ClientArgs.md +++ /dev/null @@ -1,33 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ClientArgs - -# Interface: ClientArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ClientArgs - -## Hierarchy - -- **`ClientArgs`** - - ↳ [`GetCaseConfigureArgs`](client._internal_namespace.GetCaseConfigureArgs.md) - - ↳ [`FindCaseConfigureArgs`](client._internal_namespace.FindCaseConfigureArgs.md) - - ↳ [`PostCaseConfigureArgs`](client._internal_namespace.PostCaseConfigureArgs.md) - - ↳ [`PatchCaseConfigureArgs`](client._internal_namespace.PatchCaseConfigureArgs.md) - -## Table of contents - -### Properties - -- [unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L30) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CommonArguments.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CommonArguments.md deleted file mode 100644 index ed1bb0d81f42a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CommonArguments.md +++ /dev/null @@ -1,84 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CommonArguments - -# Interface: CommonArguments - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CommonArguments - -## Table of contents - -### Properties - -- [action](client._internal_namespace.CommonArguments.md#action) -- [attachmentId](client._internal_namespace.CommonArguments.md#attachmentid) -- [caseId](client._internal_namespace.CommonArguments.md#caseid) -- [connectorId](client._internal_namespace.CommonArguments.md#connectorid) -- [owner](client._internal_namespace.CommonArguments.md#owner) -- [user](client._internal_namespace.CommonArguments.md#user) - -## Properties - -### action - -• `Optional` **action**: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:80](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L80) - -___ - -### attachmentId - -• `Optional` **attachmentId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:78](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L78) - -___ - -### caseId - -• **caseId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:76](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L76) - -___ - -### connectorId - -• `Optional` **connectorId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L79) - -___ - -### owner - -• **owner**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:77](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L77) - -___ - -### user - -• **user**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:75](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L75) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConcreteTaskInstance.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConcreteTaskInstance.md deleted file mode 100644 index db3d362c3dbc3..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConcreteTaskInstance.md +++ /dev/null @@ -1,291 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConcreteTaskInstance - -# Interface: ConcreteTaskInstance - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConcreteTaskInstance - -A task instance that has an id and is ready for storage. - -## Hierarchy - -- [`TaskInstance`](client._internal_namespace.TaskInstance.md) - - ↳ **`ConcreteTaskInstance`** - -## Table of contents - -### Properties - -- [attempts](client._internal_namespace.ConcreteTaskInstance.md#attempts) -- [id](client._internal_namespace.ConcreteTaskInstance.md#id) -- [ownerId](client._internal_namespace.ConcreteTaskInstance.md#ownerid) -- [params](client._internal_namespace.ConcreteTaskInstance.md#params) -- [retryAt](client._internal_namespace.ConcreteTaskInstance.md#retryat) -- [runAt](client._internal_namespace.ConcreteTaskInstance.md#runat) -- [schedule](client._internal_namespace.ConcreteTaskInstance.md#schedule) -- [scheduledAt](client._internal_namespace.ConcreteTaskInstance.md#scheduledat) -- [scope](client._internal_namespace.ConcreteTaskInstance.md#scope) -- [startedAt](client._internal_namespace.ConcreteTaskInstance.md#startedat) -- [state](client._internal_namespace.ConcreteTaskInstance.md#state) -- [status](client._internal_namespace.ConcreteTaskInstance.md#status) -- [taskType](client._internal_namespace.ConcreteTaskInstance.md#tasktype) -- [traceparent](client._internal_namespace.ConcreteTaskInstance.md#traceparent) -- [user](client._internal_namespace.ConcreteTaskInstance.md#user) -- [version](client._internal_namespace.ConcreteTaskInstance.md#version) - -## Properties - -### attempts - -• **attempts**: `number` - -The number of unsuccessful attempts since the last successful run. This -will be zeroed out after a successful run. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:244 - -___ - -### id - -• **id**: `string` - -The id of the Elastic document that stores this instance's data. This can -be passed by the caller when scheduling the task. - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[id](client._internal_namespace.TaskInstance.md#id) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:230 - -___ - -### ownerId - -• **ownerId**: ``null`` \| `string` - -The random uuid of the Kibana instance which claimed ownership of the task last - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[ownerId](client._internal_namespace.TaskInstance.md#ownerid) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:274 - -___ - -### params - -• **params**: `Record`<`string`, `any`\> - -A task-specific set of parameters, used by the task's run function to tailor -its work. This is generally user-input, such as { sms: '333-444-2222' }. - -#### Inherited from - -[TaskInstance](client._internal_namespace.TaskInstance.md).[params](client._internal_namespace.TaskInstance.md#params) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:182 - -___ - -### retryAt - -• **retryAt**: ``null`` \| `Date` - -The date and time that this task should re-execute if stuck in "running" / timeout -status. This value is only set when status is set to "running". - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[retryAt](client._internal_namespace.TaskInstance.md#retryat) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:264 - -___ - -### runAt - -• **runAt**: `Date` - -The date and time that this task is scheduled to be run. It is not guaranteed -to run at this time, but it is guaranteed not to run earlier than this. - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[runAt](client._internal_namespace.TaskInstance.md#runat) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:253 - -___ - -### schedule - -• `Optional` **schedule**: [`IntervalSchedule`](client._internal_namespace.IntervalSchedule.md) - -A TaskSchedule string, which specifies this as a recurring task. - -Currently, this supports a single format: an interval in minutes or seconds (e.g. '5m', '30s'). - -#### Inherited from - -[TaskInstance](client._internal_namespace.TaskInstance.md).[schedule](client._internal_namespace.TaskInstance.md#schedule) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:177 - -___ - -### scheduledAt - -• **scheduledAt**: `Date` - -The date and time that this task was originally scheduled. This is used -for convenience to task run functions, and for troubleshooting. - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[scheduledAt](client._internal_namespace.TaskInstance.md#scheduledat) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:239 - -___ - -### scope - -• `Optional` **scope**: `string`[] - -Used to group tasks for querying. So, reporting might schedule tasks with a scope of 'reporting', -and then query such tasks to provide a glimpse at only reporting tasks, rather than at all tasks. - -#### Inherited from - -[TaskInstance](client._internal_namespace.TaskInstance.md).[scope](client._internal_namespace.TaskInstance.md#scope) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:201 - -___ - -### startedAt - -• **startedAt**: ``null`` \| `Date` - -The date and time that this task started execution. This is used to determine -the "real" runAt that ended up running the task. This value is only set -when status is set to "running". - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[startedAt](client._internal_namespace.TaskInstance.md#startedat) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:259 - -___ - -### state - -• **state**: `Record`<`string`, `any`\> - -The state passed into the task's run function, and returned by the previous -run. If there was no previous run, or if the previous run did not return -any state, this will be the empy object: {} - -#### Overrides - -[TaskInstance](client._internal_namespace.TaskInstance.md).[state](client._internal_namespace.TaskInstance.md#state) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:270 - -___ - -### status - -• **status**: [`TaskStatus`](../enums/client._internal_namespace.TaskStatus.md) - -Indicates whether or not the task is currently running. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:248 - -___ - -### taskType - -• **taskType**: `string` - -The task definition type whose run function will execute this instance. - -#### Inherited from - -[TaskInstance](client._internal_namespace.TaskInstance.md).[taskType](client._internal_namespace.TaskInstance.md#tasktype) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:149 - -___ - -### traceparent - -• `Optional` **traceparent**: `string` - -The serialized traceparent string of the current APM transaction or span. - -#### Inherited from - -[TaskInstance](client._internal_namespace.TaskInstance.md).[traceparent](client._internal_namespace.TaskInstance.md#traceparent) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:192 - -___ - -### user - -• `Optional` **user**: `string` - -The id of the user who scheduled this task. - -#### Inherited from - -[TaskInstance](client._internal_namespace.TaskInstance.md).[user](client._internal_namespace.TaskInstance.md#user) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:196 - -___ - -### version - -• `Optional` **version**: `string` - -The saved object version from the Elaticsearch document. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:234 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConnectorToken.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConnectorToken.md deleted file mode 100644 index c60e9bca79a7f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConnectorToken.md +++ /dev/null @@ -1,82 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConnectorToken - -# Interface: ConnectorToken - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConnectorToken - -## Hierarchy - -- [`SavedObjectAttributes`](client._internal_namespace.SavedObjectAttributes.md) - - ↳ **`ConnectorToken`** - -## Table of contents - -### Properties - -- [connectorId](client._internal_namespace.ConnectorToken.md#connectorid) -- [createdAt](client._internal_namespace.ConnectorToken.md#createdat) -- [expiresAt](client._internal_namespace.ConnectorToken.md#expiresat) -- [token](client._internal_namespace.ConnectorToken.md#token) -- [tokenType](client._internal_namespace.ConnectorToken.md#tokentype) -- [updatedAt](client._internal_namespace.ConnectorToken.md#updatedat) - -## Properties - -### connectorId - -• **connectorId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:123 - -___ - -### createdAt - -• **createdAt**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:127 - -___ - -### expiresAt - -• **expiresAt**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:126 - -___ - -### token - -• **token**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:125 - -___ - -### tokenType - -• **tokenType**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:124 - -___ - -### updatedAt - -• `Optional` **updatedAt**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:128 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-1.md deleted file mode 100644 index 1f7901ac983f1..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-1.md +++ /dev/null @@ -1,60 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConstructorOptions - -# Interface: ConstructorOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConstructorOptions - -## Table of contents - -### Properties - -- [authentication](client._internal_namespace.ConstructorOptions-1.md#authentication) -- [authorization](client._internal_namespace.ConstructorOptions-1.md#authorization) -- [authorizationMode](client._internal_namespace.ConstructorOptions-1.md#authorizationmode) -- [request](client._internal_namespace.ConstructorOptions-1.md#request) - -## Properties - -### authentication - -• `Optional` **authentication**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `getCurrentUser` | (`request`: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\>) => ``null`` \| [`AuthenticatedUser`](client._internal_namespace.AuthenticatedUser.md) | - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:7 - -___ - -### authorization - -• `Optional` **authorization**: [`AuthorizationServiceSetup`](client._internal_namespace.AuthorizationServiceSetup.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:6 - -___ - -### authorizationMode - -• `Optional` **authorizationMode**: [`AuthorizationMode`](../enums/client._internal_namespace.AuthorizationMode.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:8 - -___ - -### request - -• **request**: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/authorization/actions_authorization.d.ts:5 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-2.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-2.md deleted file mode 100644 index fed308c053049..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions-2.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConstructorOptions - -# Interface: ConstructorOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConstructorOptions - -## Table of contents - -### Properties - -- [encryptedSavedObjectsClient](client._internal_namespace.ConstructorOptions-2.md#encryptedsavedobjectsclient) -- [logger](client._internal_namespace.ConstructorOptions-2.md#logger) -- [unsecuredSavedObjectsClient](client._internal_namespace.ConstructorOptions-2.md#unsecuredsavedobjectsclient) - -## Properties - -### encryptedSavedObjectsClient - -• **encryptedSavedObjectsClient**: [`EncryptedSavedObjectsClient`](client._internal_namespace.EncryptedSavedObjectsClient.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:6 - -___ - -### logger - -• **logger**: `Logger` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:8 - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:7 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions.md deleted file mode 100644 index 67923b89864f8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ConstructorOptions.md +++ /dev/null @@ -1,153 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ConstructorOptions - -# Interface: ConstructorOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ConstructorOptions - -## Table of contents - -### Properties - -- [actionExecutor](client._internal_namespace.ConstructorOptions.md#actionexecutor) -- [actionTypeRegistry](client._internal_namespace.ConstructorOptions.md#actiontyperegistry) -- [auditLogger](client._internal_namespace.ConstructorOptions.md#auditlogger) -- [authorization](client._internal_namespace.ConstructorOptions.md#authorization) -- [connectorTokenClient](client._internal_namespace.ConstructorOptions.md#connectortokenclient) -- [defaultKibanaIndex](client._internal_namespace.ConstructorOptions.md#defaultkibanaindex) -- [ephemeralExecutionEnqueuer](client._internal_namespace.ConstructorOptions.md#ephemeralexecutionenqueuer) -- [executionEnqueuer](client._internal_namespace.ConstructorOptions.md#executionenqueuer) -- [preconfiguredActions](client._internal_namespace.ConstructorOptions.md#preconfiguredactions) -- [request](client._internal_namespace.ConstructorOptions.md#request) -- [scopedClusterClient](client._internal_namespace.ConstructorOptions.md#scopedclusterclient) -- [unsecuredSavedObjectsClient](client._internal_namespace.ConstructorOptions.md#unsecuredsavedobjectsclient) -- [usageCounter](client._internal_namespace.ConstructorOptions.md#usagecounter) - -## Properties - -### actionExecutor - -• **actionExecutor**: [`ActionExecutorContract`](../modules/client._internal_namespace.md#actionexecutorcontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:30 - -___ - -### actionTypeRegistry - -• **actionTypeRegistry**: [`ActionTypeRegistry`](../classes/client._internal_namespace.ActionTypeRegistry.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:27 - -___ - -### auditLogger - -• `Optional` **auditLogger**: [`AuditLogger`](client._internal_namespace.AuditLogger.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:35 - -___ - -### authorization - -• **authorization**: [`ActionsAuthorization`](../classes/client._internal_namespace.ActionsAuthorization.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:34 - -___ - -### connectorTokenClient - -• **connectorTokenClient**: [`ConnectorTokenClientContract`](../modules/client._internal_namespace.md#connectortokenclientcontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:37 - -___ - -### defaultKibanaIndex - -• **defaultKibanaIndex**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:25 - -___ - -### ephemeralExecutionEnqueuer - -• **ephemeralExecutionEnqueuer**: [`ExecutionEnqueuer`](../modules/client._internal_namespace.md#executionenqueuer)<[`RunNowResult`](client._internal_namespace.RunNowResult.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:32 - -___ - -### executionEnqueuer - -• **executionEnqueuer**: [`ExecutionEnqueuer`](../modules/client._internal_namespace.md#executionenqueuer)<`void`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:31 - -___ - -### preconfiguredActions - -• **preconfiguredActions**: [`PreConfiguredAction`](client._internal_namespace.PreConfiguredAction.md)<[`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig), [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets)\>[] - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:29 - -___ - -### request - -• **request**: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:33 - -___ - -### scopedClusterClient - -• **scopedClusterClient**: [`IScopedClusterClient`](client._internal_namespace.IScopedClusterClient.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:26 - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:28 - -___ - -### usageCounter - -• `Optional` **usageCounter**: [`IUsageCounter`](client._internal_namespace.IUsageCounter.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:36 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CountActionsAttachedToCaseArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CountActionsAttachedToCaseArgs.md deleted file mode 100644 index a71324b5543ff..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CountActionsAttachedToCaseArgs.md +++ /dev/null @@ -1,72 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CountActionsAttachedToCaseArgs - -# Interface: CountActionsAttachedToCaseArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CountActionsAttachedToCaseArgs - -## Hierarchy - -- [`AttachedToCaseArgs`](client._internal_namespace.AttachedToCaseArgs.md) - - ↳ **`CountActionsAttachedToCaseArgs`** - -## Table of contents - -### Properties - -- [aggregations](client._internal_namespace.CountActionsAttachedToCaseArgs.md#aggregations) -- [caseId](client._internal_namespace.CountActionsAttachedToCaseArgs.md#caseid) -- [filter](client._internal_namespace.CountActionsAttachedToCaseArgs.md#filter) -- [unsecuredSavedObjectsClient](client._internal_namespace.CountActionsAttachedToCaseArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### aggregations - -• **aggregations**: `Record`<`string`, `AggregationsAggregationContainer`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:40](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L40) - -___ - -### caseId - -• **caseId**: `string` - -#### Inherited from - -[AttachedToCaseArgs](client._internal_namespace.AttachedToCaseArgs.md).[caseId](client._internal_namespace.AttachedToCaseArgs.md#caseid) - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:33](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L33) - -___ - -### filter - -• `Optional` **filter**: `KueryNode` - -#### Inherited from - -[AttachedToCaseArgs](client._internal_namespace.AttachedToCaseArgs.md).[filter](client._internal_namespace.AttachedToCaseArgs.md#filter) - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:34](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L34) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[AttachedToCaseArgs](client._internal_namespace.AttachedToCaseArgs.md).[unsecuredSavedObjectsClient](client._internal_namespace.AttachedToCaseArgs.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAttachmentArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAttachmentArgs.md deleted file mode 100644 index 50030284f8fb6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAttachmentArgs.md +++ /dev/null @@ -1,64 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CreateAttachmentArgs - -# Interface: CreateAttachmentArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CreateAttachmentArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`CreateAttachmentArgs`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.CreateAttachmentArgs.md#attributes) -- [id](client._internal_namespace.CreateAttachmentArgs.md#id) -- [references](client._internal_namespace.CreateAttachmentArgs.md#references) -- [unsecuredSavedObjectsClient](client._internal_namespace.CreateAttachmentArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### attributes - -• **attributes**: { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:48](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L48) - -___ - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:50](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L50) - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:49](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L49) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAuditMsgParams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAuditMsgParams.md deleted file mode 100644 index 30c4ab0076bf0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateAuditMsgParams.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CreateAuditMsgParams - -# Interface: CreateAuditMsgParams - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CreateAuditMsgParams - -## Table of contents - -### Properties - -- [entity](client._internal_namespace.CreateAuditMsgParams.md#entity) -- [error](client._internal_namespace.CreateAuditMsgParams.md#error) -- [operation](client._internal_namespace.CreateAuditMsgParams.md#operation) - -## Properties - -### entity - -• `Optional` **entity**: [`OwnerEntity`](client._internal_namespace.OwnerEntity.md) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L15) - -___ - -### error - -• `Optional` **error**: `Error` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:16](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L16) - -___ - -### operation - -• **operation**: [`OperationDetails`](client._internal_namespace.OperationDetails.md) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/audit_logger.ts:14](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/audit_logger.ts#L14) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions-1.md deleted file mode 100644 index 77e84843801b5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions-1.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CreateOptions - -# Interface: CreateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CreateOptions - -## Table of contents - -### Properties - -- [connectorId](client._internal_namespace.CreateOptions-1.md#connectorid) -- [expiresAtMillis](client._internal_namespace.CreateOptions-1.md#expiresatmillis) -- [token](client._internal_namespace.CreateOptions-1.md#token) -- [tokenType](client._internal_namespace.CreateOptions-1.md#tokentype) - -## Properties - -### connectorId - -• **connectorId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:11 - -___ - -### expiresAtMillis - -• **expiresAtMillis**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:13 - -___ - -### token - -• **token**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:12 - -___ - -### tokenType - -• `Optional` **tokenType**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:14 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions.md deleted file mode 100644 index 1070beb2f0304..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateOptions.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CreateOptions - -# Interface: CreateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CreateOptions - -## Table of contents - -### Properties - -- [action](client._internal_namespace.CreateOptions.md#action) - -## Properties - -### action - -• **action**: [`Action`](client._internal_namespace.Action.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:22 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserAction.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserAction.md deleted file mode 100644 index 5211a50019cae..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserAction.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CreateUserAction - -# Interface: CreateUserAction - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CreateUserAction - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | extends keyof [`BuilderParameters`](client._internal_namespace.BuilderParameters.md) | - -## Table of contents - -### Properties - -- [payload](client._internal_namespace.CreateUserAction.md#payload) -- [type](client._internal_namespace.CreateUserAction.md#type) - -## Properties - -### payload - -• **payload**: [`BuilderParameters`](client._internal_namespace.BuilderParameters.md)[`T`][``"parameters"``][``"payload"``] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:68](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L68) - -___ - -### type - -• **type**: `T` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:67](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L67) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserActionES.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserActionES.md deleted file mode 100644 index efc0b67c18a3e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.CreateUserActionES.md +++ /dev/null @@ -1,59 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / CreateUserActionES - -# Interface: CreateUserActionES - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).CreateUserActionES - -## Type parameters - -| Name | -| :------ | -| `T` | - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`CreateUserActionES`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.CreateUserActionES.md#attributes) -- [references](client._internal_namespace.CreateUserActionES.md#references) -- [unsecuredSavedObjectsClient](client._internal_namespace.CreateUserActionES.md#unsecuredsavedobjectsclient) - -## Properties - -### attributes - -• **attributes**: `T` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:71](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L71) - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:72](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L72) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.DecoratedError.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.DecoratedError.md deleted file mode 100644 index 77ef99caaf16a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.DecoratedError.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / DecoratedError - -# Interface: DecoratedError - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).DecoratedError - -## Hierarchy - -- `Boom` - - ↳ **`DecoratedError`** - -## Table of contents - -### Properties - -- [[code]](client._internal_namespace.DecoratedError.md#[code]) - -## Properties - -### [code] - -• `Optional` **[code]**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/errors.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md deleted file mode 100644 index 373ba63e5c659..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md +++ /dev/null @@ -1,94 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ElasticsearchFeatureConfig - -# Interface: ElasticsearchFeatureConfig - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ElasticsearchFeatureConfig - -Interface for registering an Elasticsearch feature. -Feature registration allows plugins to hide their applications based -on configured cluster or index privileges. - -## Table of contents - -### Properties - -- [catalogue](client._internal_namespace.ElasticsearchFeatureConfig.md#catalogue) -- [id](client._internal_namespace.ElasticsearchFeatureConfig.md#id) -- [management](client._internal_namespace.ElasticsearchFeatureConfig.md#management) -- [privileges](client._internal_namespace.ElasticsearchFeatureConfig.md#privileges) - -## Properties - -### catalogue - -• `Optional` **catalogue**: `string`[] - -If this feature includes a catalogue entry, you can specify them here to control visibility based on the current space. - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:34 - -___ - -### id - -• **id**: `string` - -Unique identifier for this feature. -This identifier is also used when generating UI Capabilities. - -**`see`** UICapabilities - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:15 - -___ - -### management - -• `Optional` **management**: `Object` - -Management sections associated with this feature. - -**`example`** -```ts - // Enables access to the "Advanced Settings" management page within the Kibana section - management: { - kibana: ['settings'] - } -``` - -#### Index signature - -▪ [sectionId: `string`]: `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:27 - -___ - -### privileges - -• **privileges**: [`FeatureElasticsearchPrivileges`](client._internal_namespace.FeatureElasticsearchPrivileges.md)[] - -Feature privilege definition. Specify one or more privileges which grant access to this feature. -Users must satisfy all privileges in at least one of the defined sets of privileges in order to be granted access. - -**`example`** -```ts - [{ - requiredClusterPrivileges: ['monitor'], - requiredIndexPrivileges: { - ['metricbeat-*']: ['read', 'view_index_metadata'] - } - }] -``` - -**`see`** FeatureElasticsearchPrivileges - -#### Defined in - -x-pack/plugins/features/target/types/common/elasticsearch_feature.d.ts:50 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EmbeddableRegistryDefinition.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EmbeddableRegistryDefinition.md deleted file mode 100644 index 6a4eba88cc91d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EmbeddableRegistryDefinition.md +++ /dev/null @@ -1,157 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / EmbeddableRegistryDefinition - -# Interface: EmbeddableRegistryDefinition - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).EmbeddableRegistryDefinition - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `P` | extends [`EmbeddableStateWithType`](../modules/client._internal_namespace.md#embeddablestatewithtype) = [`EmbeddableStateWithType`](../modules/client._internal_namespace.md#embeddablestatewithtype) | - -## Hierarchy - -- [`PersistableStateDefinition`](../modules/client._internal_namespace.md#persistablestatedefinition)<`P`\> - - ↳ **`EmbeddableRegistryDefinition`** - -## Table of contents - -### Properties - -- [id](client._internal_namespace.EmbeddableRegistryDefinition.md#id) -- [migrations](client._internal_namespace.EmbeddableRegistryDefinition.md#migrations) - -### Methods - -- [extract](client._internal_namespace.EmbeddableRegistryDefinition.md#extract) -- [inject](client._internal_namespace.EmbeddableRegistryDefinition.md#inject) -- [telemetry](client._internal_namespace.EmbeddableRegistryDefinition.md#telemetry) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/plugins/embeddable/target/types/server/types.d.ts:13 - -___ - -### migrations - -• `Optional` **migrations**: [`MigrateFunctionsObject`](../modules/client._internal_namespace.md#migratefunctionsobject) \| [`GetMigrationFunctionObjectFn`](../modules/client._internal_namespace.md#getmigrationfunctionobjectfn) - -A list of migration functions, which migrate the persistable state -serializable object to the next version. Migration functions should are -keyed by the Kibana version using semver, where the version indicates to -which version the state will be migrated to. - -#### Inherited from - -PersistableStateDefinition.migrations - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:75 - -## Methods - -### extract - -▸ `Optional` **extract**(`state`): `Object` - -A function which receives state and should return the state with references -extracted and an array of the extracted references. The default case could -simply return the same state with an empty array of references. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `state` | `P` | The persistable state serializable state object. | - -#### Returns - -`Object` - -Persistable state object with references extracted and a list of - references. - -| Name | Type | -| :------ | :------ | -| `references` | [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] | -| `state` | `P` | - -#### Inherited from - -PersistableStateDefinition.extract - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:65 - -___ - -### inject - -▸ `Optional` **inject**(`state`, `references`): `P` - -A function which receives state and a list of references and should return -back the state with references injected. The default is an identity -function. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `state` | `P` | The persistable state serializable state object. | -| `references` | [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] | List of saved object references. | - -#### Returns - -`P` - -Persistable state object with references injected. - -#### Inherited from - -PersistableStateDefinition.inject - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:55 - -___ - -### telemetry - -▸ `Optional` **telemetry**(`state`, `stats`): `Record`<`string`, `any`\> - -Function which reports telemetry information. This function is essentially -a "reducer" - it receives the existing "stats" object and returns an -updated version of the "stats" object. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `state` | `P` | The persistable state serializable state object. | -| `stats` | `Record`<`string`, `any`\> | Stats object containing the stats which were already collected. This `stats` object shall not be mutated in-line. | - -#### Returns - -`Record`<`string`, `any`\> - -A new stats object augmented with new telemetry information. - -#### Inherited from - -PersistableStateDefinition.telemetry - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:45 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EncryptedSavedObjectsClient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EncryptedSavedObjectsClient.md deleted file mode 100644 index fff1cd9a9e369..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.EncryptedSavedObjectsClient.md +++ /dev/null @@ -1,39 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / EncryptedSavedObjectsClient - -# Interface: EncryptedSavedObjectsClient - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).EncryptedSavedObjectsClient - -## Table of contents - -### Methods - -- [getDecryptedAsInternalUser](client._internal_namespace.EncryptedSavedObjectsClient.md#getdecryptedasinternaluser) - -## Methods - -### getDecryptedAsInternalUser - -▸ **getDecryptedAsInternalUser**<`T`\>(`type`, `id`, `options?`): `Promise`<[`SavedObject`](client._internal_namespace.SavedObject.md)<`T`\>\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `type` | `string` | -| `id` | `string` | -| `options?` | [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) | - -#### Returns - -`Promise`<[`SavedObject`](client._internal_namespace.SavedObject.md)<`T`\>\> - -#### Defined in - -x-pack/plugins/encrypted_saved_objects/target/types/server/saved_objects/index.d.ts:18 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions-1.md deleted file mode 100644 index 4004d5c484793..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions-1.md +++ /dev/null @@ -1,101 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ExecuteOptions - -# Interface: ExecuteOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ExecuteOptions - -## Hierarchy - -- `Pick`<[`ExecuteOptions`](client._internal_namespace.ExecuteOptions.md), ``"params"`` \| ``"source"``\> - - ↳ **`ExecuteOptions`** - -## Table of contents - -### Properties - -- [apiKey](client._internal_namespace.ExecuteOptions-1.md#apikey) -- [executionId](client._internal_namespace.ExecuteOptions-1.md#executionid) -- [id](client._internal_namespace.ExecuteOptions-1.md#id) -- [params](client._internal_namespace.ExecuteOptions-1.md#params) -- [relatedSavedObjects](client._internal_namespace.ExecuteOptions-1.md#relatedsavedobjects) -- [source](client._internal_namespace.ExecuteOptions-1.md#source) -- [spaceId](client._internal_namespace.ExecuteOptions-1.md#spaceid) - -## Properties - -### apiKey - -• **apiKey**: ``null`` \| `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/create_execute_function.d.ts:15 - -___ - -### executionId - -• **executionId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/create_execute_function.d.ts:16 - -___ - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/create_execute_function.d.ts:13 - -___ - -### params - -• **params**: `Record`<`string`, `unknown`\> - -#### Inherited from - -Pick.params - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:28 - -___ - -### relatedSavedObjects - -• `Optional` **relatedSavedObjects**: `Readonly`<{ `namespace?`: `string` ; `typeId?`: `string` } & { `id`: `string` ; `type`: `string` }\>[] - -#### Defined in - -x-pack/plugins/actions/target/types/server/create_execute_function.d.ts:17 - -___ - -### source - -• `Optional` **source**: [`ActionExecutionSource`](client._internal_namespace.ActionExecutionSource.md)<`unknown`\> - -#### Inherited from - -Pick.source - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:29 - -___ - -### spaceId - -• **spaceId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/create_execute_function.d.ts:14 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions.md deleted file mode 100644 index fb808b1afbbee..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ExecuteOptions.md +++ /dev/null @@ -1,104 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ExecuteOptions - -# Interface: ExecuteOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ExecuteOptions - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Source` | `unknown` | - -## Table of contents - -### Properties - -- [actionId](client._internal_namespace.ExecuteOptions.md#actionid) -- [executionId](client._internal_namespace.ExecuteOptions.md#executionid) -- [isEphemeral](client._internal_namespace.ExecuteOptions.md#isephemeral) -- [params](client._internal_namespace.ExecuteOptions.md#params) -- [relatedSavedObjects](client._internal_namespace.ExecuteOptions.md#relatedsavedobjects) -- [request](client._internal_namespace.ExecuteOptions.md#request) -- [source](client._internal_namespace.ExecuteOptions.md#source) -- [taskInfo](client._internal_namespace.ExecuteOptions.md#taskinfo) - -## Properties - -### actionId - -• **actionId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:25 - -___ - -### executionId - -• `Optional` **executionId**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:31 - -___ - -### isEphemeral - -• `Optional` **isEphemeral**: `boolean` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:26 - -___ - -### params - -• **params**: `Record`<`string`, `unknown`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:28 - -___ - -### relatedSavedObjects - -• `Optional` **relatedSavedObjects**: `Readonly`<{ `namespace?`: `string` ; `typeId?`: `string` } & { `id`: `string` ; `type`: `string` }\>[] - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:32 - -___ - -### request - -• **request**: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:27 - -___ - -### source - -• `Optional` **source**: [`ActionExecutionSource`](client._internal_namespace.ActionExecutionSource.md)<`Source`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:29 - -___ - -### taskInfo - -• `Optional` **taskInfo**: [`TaskInfo`](client._internal_namespace.TaskInfo.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:30 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md deleted file mode 100644 index bb462c5341233..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md +++ /dev/null @@ -1,106 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FeatureElasticsearchPrivileges - -# Interface: FeatureElasticsearchPrivileges - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FeatureElasticsearchPrivileges - -Elasticsearch Feature privilege definition - -## Table of contents - -### Properties - -- [requiredClusterPrivileges](client._internal_namespace.FeatureElasticsearchPrivileges.md#requiredclusterprivileges) -- [requiredIndexPrivileges](client._internal_namespace.FeatureElasticsearchPrivileges.md#requiredindexprivileges) -- [requiredRoles](client._internal_namespace.FeatureElasticsearchPrivileges.md#requiredroles) -- [ui](client._internal_namespace.FeatureElasticsearchPrivileges.md#ui) - -## Properties - -### requiredClusterPrivileges - -• **requiredClusterPrivileges**: `string`[] - -A set of Elasticsearch cluster privileges which are required for this feature to be enabled. -See https://www.elastic.co/guide/en/elasticsearch/reference/current/security-privileges.html - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_elasticsearch_privileges.d.ts:10 - -___ - -### requiredIndexPrivileges - -• `Optional` **requiredIndexPrivileges**: `Object` - -A set of Elasticsearch index privileges which are required for this feature to be enabled, keyed on index name or pattern. -See https://www.elastic.co/guide/en/elasticsearch/reference/current/security-privileges.html#privileges-list-indices - -**`example`** - -Requiring `read` access to `logstash-*` and `all` access to `foo-*` -```ts -feature.registerElasticsearchPrivilege({ - privileges: [{ - requiredIndexPrivileges: { - ['logstash-*']: ['read'], - ['foo-*]: ['all'] - } - }] -}) -``` - -#### Index signature - -▪ [indexName: `string`]: `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_elasticsearch_privileges.d.ts:30 - -___ - -### requiredRoles - -• `Optional` **requiredRoles**: `string`[] - -A set of Elasticsearch roles which are required for this feature to be enabled. - -**`deprecated`** do not rely on hard-coded role names. - -This is relied on by the reporting feature, and should be removed once reporting -migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_elasticsearch_privileges.d.ts:41 - -___ - -### ui - -• **ui**: `string`[] - -A list of UI Capabilities that should be granted to users with this privilege. -These capabilities will automatically be namespaces within your feature id. - -**`example`** -```ts - { - ui: ['show', 'save'] - } - - This translates in the UI to the following (assuming a feature id of "foo"): - import { uiCapabilities } from 'ui/capabilities'; - - const canShowApp = uiCapabilities.foo.show; - const canSave = uiCapabilities.foo.save; -``` -Note: Since these are automatically namespaced, you are free to use generic names like "show" and "save". - -**`see`** UICapabilities - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_elasticsearch_privileges.d.ts:62 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureKibanaPrivileges.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureKibanaPrivileges.md deleted file mode 100644 index caf57a8ff8987..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureKibanaPrivileges.md +++ /dev/null @@ -1,246 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FeatureKibanaPrivileges - -# Interface: FeatureKibanaPrivileges - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FeatureKibanaPrivileges - -Feature privilege definition - -## Table of contents - -### Properties - -- [alerting](client._internal_namespace.FeatureKibanaPrivileges.md#alerting) -- [api](client._internal_namespace.FeatureKibanaPrivileges.md#api) -- [app](client._internal_namespace.FeatureKibanaPrivileges.md#app) -- [cases](client._internal_namespace.FeatureKibanaPrivileges.md#cases) -- [catalogue](client._internal_namespace.FeatureKibanaPrivileges.md#catalogue) -- [disabled](client._internal_namespace.FeatureKibanaPrivileges.md#disabled) -- [excludeFromBasePrivileges](client._internal_namespace.FeatureKibanaPrivileges.md#excludefrombaseprivileges) -- [management](client._internal_namespace.FeatureKibanaPrivileges.md#management) -- [requireAllSpaces](client._internal_namespace.FeatureKibanaPrivileges.md#requireallspaces) -- [savedObject](client._internal_namespace.FeatureKibanaPrivileges.md#savedobject) -- [ui](client._internal_namespace.FeatureKibanaPrivileges.md#ui) - -## Properties - -### alerting - -• `Optional` **alerting**: `Object` - -If your feature requires access to specific Alert Types, then specify your access needs here. -Include both Alert Types registered by the feature and external Alert Types such as built-in -Alert Types and Alert Types provided by other features to which you wish to grant access. - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `alert?` | `Object` | -| `alert.all?` | readonly `string`[] | -| `alert.read?` | readonly `string`[] | -| `rule?` | `Object` | -| `rule.all?` | readonly `string`[] | -| `rule.read?` | readonly `string`[] | - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:82 - -___ - -### api - -• `Optional` **api**: readonly `string`[] - -If your feature includes server-side APIs, you can tag those routes to secure access based on user permissions. - -**`example`** -```ts - // Configure your routes with a tag starting with the 'access:' prefix - server.route({ - path: '/api/my-route', - method: 'GET', - handler: () => { ...}, - options: { - tags: ['access:my_feature-admin'] - } - }); - - Then, specify the tags here (without the 'access:' prefix) which should be secured: - - { - api: ['my_feature-admin'] - } -``` - -NOTE: It is important to name your tags in a way that will not collide with other plugins/features. -A generic tag name like "access:read" could be used elsewhere, and access to that API endpoint would also -extend to any routes you have also tagged with that name. - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:64 - -___ - -### app - -• `Optional` **app**: readonly `string`[] - -If your feature exposes a client-side application (most of them do!), then you can control access to them here. - -**`example`** -```ts - { - app: ['my-app', 'kibana'] - } -``` - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:76 - -___ - -### cases - -• `Optional` **cases**: `Object` - -If your feature requires access to specific owners of cases (aka plugins that have created cases), then specify your access needs here. The values here should -be unique identifiers for the owners of cases you want access to. - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `all?` | readonly `string`[] | List of case owners which users should have full read/write access to when granted this privilege. **`example`** ```ts { all: ['securitySolution'] } ``` | -| `read?` | readonly `string`[] | List of case owners which users should have read-only access to when granted this privilege. **`example`** ```ts { read: ['securitySolution'] } ``` | - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:132 - -___ - -### catalogue - -• `Optional` **catalogue**: readonly `string`[] - -If this feature includes a catalogue entry, you can specify them here to control visibility based on user permissions. - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:37 - -___ - -### disabled - -• `Optional` **disabled**: `boolean` - -Whether or not this privilege should be hidden in the roles UI and disallowed on the API. Defaults to `false`. - -**`deprecated`** - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:18 - -___ - -### excludeFromBasePrivileges - -• `Optional` **excludeFromBasePrivileges**: `boolean` - -Whether or not this specific privilege should be excluded from the base privileges. - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:8 - -___ - -### management - -• `Optional` **management**: `Object` - -If this feature includes management sections, you can specify them here to control visibility of those -pages based on user privileges. - -**`example`** -```ts - // Enables access to the "Advanced Settings" management page within the Kibana section - management: { - kibana: ['settings'] - } -``` - -#### Index signature - -▪ [sectionId: `string`]: readonly `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:31 - -___ - -### requireAllSpaces - -• `Optional` **requireAllSpaces**: `boolean` - -Whether or not this privilege should only be granted to `All Spaces *`. Should be used for features that do not -support Spaces. Defaults to `false`. - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:13 - -___ - -### savedObject - -• **savedObject**: `Object` - -If your feature requires access to specific saved objects, then specify your access needs here. - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `all` | readonly `string`[] | List of saved object types which users should have full read/write access to when granted this privilege. **`example`** ```ts { all: ['my-saved-object-type'] } ``` | -| `read` | readonly `string`[] | List of saved object types which users should have read-only access to when granted this privilege. **`example`** ```ts { read: ['config'] } ``` | - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:157 - -___ - -### ui - -• **ui**: readonly `string`[] - -A list of UI Capabilities that should be granted to users with this privilege. -These capabilities will automatically be namespaces within your feature id. - -**`example`** -```ts - { - ui: ['show', 'save'] - } - - This translates in the UI to the following (assuming a feature id of "foo"): - import { uiCapabilities } from 'ui/capabilities'; - - const canShowApp = uiCapabilities.foo.show; - const canSave = uiCapabilities.foo.save; -``` -Note: Since these are automatically namespaced, you are free to use generic names like "show" and "save". - -**`see`** UICapabilities - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:199 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureUsageServiceSetup.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureUsageServiceSetup.md deleted file mode 100644 index 77770e22b41e2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FeatureUsageServiceSetup.md +++ /dev/null @@ -1,34 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FeatureUsageServiceSetup - -# Interface: FeatureUsageServiceSetup - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FeatureUsageServiceSetup - -## Table of contents - -### Methods - -- [register](client._internal_namespace.FeatureUsageServiceSetup.md#register) - -## Methods - -### register - -▸ **register**(`featureName`, `licenseType`): `void` - -Register a feature to be able to notify of it's usages using the {@link FeatureUsageServiceStart | service start contract}. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `featureName` | `string` | -| `licenseType` | ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/licensing/target/types/server/services/feature_usage_service.d.ts:7 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindActionResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindActionResult.md deleted file mode 100644 index e7306b5d7b931..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindActionResult.md +++ /dev/null @@ -1,117 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FindActionResult - -# Interface: FindActionResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FindActionResult - -## Hierarchy - -- [`ActionResult`](client._internal_namespace.ActionResult.md) - - ↳ **`FindActionResult`** - -## Table of contents - -### Properties - -- [actionTypeId](client._internal_namespace.FindActionResult.md#actiontypeid) -- [config](client._internal_namespace.FindActionResult.md#config) -- [id](client._internal_namespace.FindActionResult.md#id) -- [isMissingSecrets](client._internal_namespace.FindActionResult.md#ismissingsecrets) -- [isPreconfigured](client._internal_namespace.FindActionResult.md#ispreconfigured) -- [name](client._internal_namespace.FindActionResult.md#name) -- [referencedByCount](client._internal_namespace.FindActionResult.md#referencedbycount) - -## Properties - -### actionTypeId - -• **actionTypeId**: `string` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[actionTypeId](client._internal_namespace.ActionResult.md#actiontypeid) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:50 - -___ - -### config - -• `Optional` **config**: [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[config](client._internal_namespace.ActionResult.md#config) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:53 - -___ - -### id - -• **id**: `string` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[id](client._internal_namespace.ActionResult.md#id) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:49 - -___ - -### isMissingSecrets - -• `Optional` **isMissingSecrets**: `boolean` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[isMissingSecrets](client._internal_namespace.ActionResult.md#ismissingsecrets) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:52 - -___ - -### isPreconfigured - -• **isPreconfigured**: `boolean` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[isPreconfigured](client._internal_namespace.ActionResult.md#ispreconfigured) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:54 - -___ - -### name - -• **name**: `string` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[name](client._internal_namespace.ActionResult.md#name) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:51 - -___ - -### referencedByCount - -• **referencedByCount**: `number` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:60 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseCommentsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseCommentsArgs.md deleted file mode 100644 index a5b1689fc0e9b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseCommentsArgs.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FindCaseCommentsArgs - -# Interface: FindCaseCommentsArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FindCaseCommentsArgs - -## Table of contents - -### Properties - -- [id](client._internal_namespace.FindCaseCommentsArgs.md#id) -- [options](client._internal_namespace.FindCaseCommentsArgs.md#options) -- [unsecuredSavedObjectsClient](client._internal_namespace.FindCaseCommentsArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### id - -• **id**: `string` \| `string`[] - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:84](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L84) - -___ - -### options - -• `Optional` **options**: [`SavedObjectFindOptionsKueryNode`](../modules/client._internal_namespace.md#savedobjectfindoptionskuerynode) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:85](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L85) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:83](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L83) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseConfigureArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseConfigureArgs.md deleted file mode 100644 index 5e3635fe0c3ec..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCaseConfigureArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FindCaseConfigureArgs - -# Interface: FindCaseConfigureArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FindCaseConfigureArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs.md) - - ↳ **`FindCaseConfigureArgs`** - -## Table of contents - -### Properties - -- [options](client._internal_namespace.FindCaseConfigureArgs.md#options) -- [unsecuredSavedObjectsClient](client._internal_namespace.FindCaseConfigureArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### options - -• `Optional` **options**: [`SavedObjectFindOptionsKueryNode`](../modules/client._internal_namespace.md#savedobjectfindoptionskuerynode) - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:37](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L37) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L30) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCasesArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCasesArgs.md deleted file mode 100644 index 0ac807ecaadac..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCasesArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FindCasesArgs - -# Interface: FindCasesArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FindCasesArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`FindCasesArgs`** - -## Table of contents - -### Properties - -- [options](client._internal_namespace.FindCasesArgs.md#options) -- [unsecuredSavedObjectsClient](client._internal_namespace.FindCasesArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### options - -• `Optional` **options**: [`SavedObjectFindOptionsKueryNode`](../modules/client._internal_namespace.md#savedobjectfindoptionskuerynode) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:89](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L89) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCommentsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCommentsArgs.md deleted file mode 100644 index b88437b3e33a8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindCommentsArgs.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FindCommentsArgs - -# Interface: FindCommentsArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FindCommentsArgs - -## Table of contents - -### Properties - -- [id](client._internal_namespace.FindCommentsArgs.md#id) -- [options](client._internal_namespace.FindCommentsArgs.md#options) -- [unsecuredSavedObjectsClient](client._internal_namespace.FindCommentsArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### id - -• **id**: `string` \| `string`[] - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:78](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L78) - -___ - -### options - -• `Optional` **options**: [`SavedObjectFindOptionsKueryNode`](../modules/client._internal_namespace.md#savedobjectfindoptionskuerynode) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L79) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:77](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L77) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindConnectorMappingsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindConnectorMappingsArgs.md deleted file mode 100644 index 5f70d4ae539e8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.FindConnectorMappingsArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / FindConnectorMappingsArgs - -# Interface: FindConnectorMappingsArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).FindConnectorMappingsArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-2.md) - - ↳ **`FindConnectorMappingsArgs`** - -## Table of contents - -### Properties - -- [options](client._internal_namespace.FindConnectorMappingsArgs.md#options) -- [unsecuredSavedObjectsClient](client._internal_namespace.FindConnectorMappingsArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### options - -• `Optional` **options**: [`SavedObjectFindOptionsKueryNode`](../modules/client._internal_namespace.md#savedobjectfindoptionskuerynode) - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:18](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L18) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-2.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-2.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L15) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAllSpacesOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAllSpacesOptions.md deleted file mode 100644 index 905d61791cb2e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAllSpacesOptions.md +++ /dev/null @@ -1,44 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetAllSpacesOptions - -# Interface: GetAllSpacesOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetAllSpacesOptions - -Controls how spaces are retrieved. - -## Table of contents - -### Properties - -- [includeAuthorizedPurposes](client._internal_namespace.GetAllSpacesOptions.md#includeauthorizedpurposes) -- [purpose](client._internal_namespace.GetAllSpacesOptions.md#purpose) - -## Properties - -### includeAuthorizedPurposes - -• `Optional` **includeAuthorizedPurposes**: `boolean` - -Set to true to return a set of flags indicating which purposes the user is authorized for. - -**`see`** GetAllSpacesPurpose - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:65 - -___ - -### purpose - -• `Optional` **purpose**: [`GetAllSpacesPurpose`](../modules/client._internal_namespace.md#getallspacespurpose) - -An optional purpose describing how the set of spaces will be used. -The default purpose (`any`) will retrieve all spaces the user is authorized to see, -whereas a more specific purpose will retrieve all spaces the user is authorized to perform a specific action within. - -**`see`** GetAllSpacesPurpose - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:59 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAttachmentArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAttachmentArgs.md deleted file mode 100644 index 39f6f288c84c5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetAttachmentArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetAttachmentArgs - -# Interface: GetAttachmentArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetAttachmentArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`GetAttachmentArgs`** - -## Table of contents - -### Properties - -- [attachmentId](client._internal_namespace.GetAttachmentArgs.md#attachmentid) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetAttachmentArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### attachmentId - -• **attachmentId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:44](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L44) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseArgs.md deleted file mode 100644 index 5cca6876f1821..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetCaseArgs - -# Interface: GetCaseArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetCaseArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`GetCaseArgs`** - -## Table of contents - -### Properties - -- [id](client._internal_namespace.GetCaseArgs.md#id) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetCaseArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:69](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L69) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseConfigureArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseConfigureArgs.md deleted file mode 100644 index 2aa37a7bf78a9..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseConfigureArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetCaseConfigureArgs - -# Interface: GetCaseConfigureArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetCaseConfigureArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs.md) - - ↳ **`GetCaseConfigureArgs`** - -## Table of contents - -### Properties - -- [configurationId](client._internal_namespace.GetCaseConfigureArgs.md#configurationid) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetCaseConfigureArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### configurationId - -• **configurationId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:34](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L34) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L30) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseIdsByAlertIdArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseIdsByAlertIdArgs.md deleted file mode 100644 index 267aa4fe7100a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseIdsByAlertIdArgs.md +++ /dev/null @@ -1,53 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetCaseIdsByAlertIdArgs - -# Interface: GetCaseIdsByAlertIdArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetCaseIdsByAlertIdArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`GetCaseIdsByAlertIdArgs`** - -## Table of contents - -### Properties - -- [alertId](client._internal_namespace.GetCaseIdsByAlertIdArgs.md#alertid) -- [filter](client._internal_namespace.GetCaseIdsByAlertIdArgs.md#filter) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetCaseIdsByAlertIdArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### alertId - -• **alertId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:59](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L59) - -___ - -### filter - -• `Optional` **filter**: `KueryNode` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:60](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L60) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseUserActionArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseUserActionArgs.md deleted file mode 100644 index 08edac1f82b2c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCaseUserActionArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetCaseUserActionArgs - -# Interface: GetCaseUserActionArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetCaseUserActionArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`GetCaseUserActionArgs`** - -## Table of contents - -### Properties - -- [caseId](client._internal_namespace.GetCaseUserActionArgs.md#caseid) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetCaseUserActionArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### caseId - -• **caseId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:58](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L58) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCasesArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCasesArgs.md deleted file mode 100644 index d5e802e19b9c0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetCasesArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetCasesArgs - -# Interface: GetCasesArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetCasesArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`GetCasesArgs`** - -## Table of contents - -### Properties - -- [caseIds](client._internal_namespace.GetCasesArgs.md#caseids) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetCasesArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### caseIds - -• **caseIds**: `string`[] - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:73](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L73) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetReportersArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetReportersArgs.md deleted file mode 100644 index af1116f4c3ddb..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetReportersArgs.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetReportersArgs - -# Interface: GetReportersArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetReportersArgs - -## Table of contents - -### Properties - -- [filter](client._internal_namespace.GetReportersArgs.md#filter) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetReportersArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### filter - -• `Optional` **filter**: `KueryNode` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:134](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L134) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:133](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L133) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetSpaceResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetSpaceResult.md deleted file mode 100644 index 8e4162988105e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetSpaceResult.md +++ /dev/null @@ -1,176 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetSpaceResult - -# Interface: GetSpaceResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetSpaceResult - -Response format when querying for spaces. - -## Hierarchy - -- [`Space`](client._internal_namespace.Space.md) - - ↳ **`GetSpaceResult`** - -## Table of contents - -### Properties - -- [\_reserved](client._internal_namespace.GetSpaceResult.md#_reserved) -- [authorizedPurposes](client._internal_namespace.GetSpaceResult.md#authorizedpurposes) -- [color](client._internal_namespace.GetSpaceResult.md#color) -- [description](client._internal_namespace.GetSpaceResult.md#description) -- [disabledFeatures](client._internal_namespace.GetSpaceResult.md#disabledfeatures) -- [id](client._internal_namespace.GetSpaceResult.md#id) -- [imageUrl](client._internal_namespace.GetSpaceResult.md#imageurl) -- [initials](client._internal_namespace.GetSpaceResult.md#initials) -- [name](client._internal_namespace.GetSpaceResult.md#name) - -## Properties - -### \_reserved - -• `Optional` `Private` **\_reserved**: `boolean` - -Indicates that this space is reserved (system controlled). -Reserved spaces cannot be created or deleted by end-users. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[_reserved](client._internal_namespace.Space.md#_reserved) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:46 - -___ - -### authorizedPurposes - -• `Optional` **authorizedPurposes**: `Record`<[`GetAllSpacesPurpose`](../modules/client._internal_namespace.md#getallspacespurpose), `boolean`\> - -A set of flags indicating which purposes the user is authorized for. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:82 - -___ - -### color - -• `Optional` **color**: `string` - -Optional color (hex code) for this space. -If neither `color` nor `imageUrl` is specified, then a color will be automatically generated. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[color](client._internal_namespace.Space.md#color) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:24 - -___ - -### description - -• `Optional` **description**: `string` - -Optional description for this space. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[description](client._internal_namespace.Space.md#description) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:19 - -___ - -### disabledFeatures - -• **disabledFeatures**: `string`[] - -The set of feature ids that should be hidden within this space. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[disabledFeatures](client._internal_namespace.Space.md#disabledfeatures) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:40 - -___ - -### id - -• **id**: `string` - -The unique identifier for this space. -The id becomes part of the "URL Identifier" of the space. - -Example: an id of `marketing` would result in the URL identifier of `/s/marketing`. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[id](client._internal_namespace.Space.md#id) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:11 - -___ - -### imageUrl - -• `Optional` **imageUrl**: `string` - -Optional base-64 encoded data image url to show as this space's avatar. -This setting takes precedence over any configured `color` or `initials`. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[imageUrl](client._internal_namespace.Space.md#imageurl) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:36 - -___ - -### initials - -• `Optional` **initials**: `string` - -Optional display initials for this space's avatar. Supports a maximum of 2 characters. -If initials are not provided, then they will be derived from the space name automatically. - -Initials are not displayed if an `imageUrl` has been specified. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[initials](client._internal_namespace.Space.md#initials) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:31 - -___ - -### name - -• **name**: `string` - -Display name for this space. - -#### Inherited from - -[Space](client._internal_namespace.Space.md).[name](client._internal_namespace.Space.md#name) - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:15 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetTagsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetTagsArgs.md deleted file mode 100644 index 31088513fe67f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetTagsArgs.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetTagsArgs - -# Interface: GetTagsArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetTagsArgs - -## Table of contents - -### Properties - -- [filter](client._internal_namespace.GetTagsArgs.md#filter) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetTagsArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### filter - -• `Optional` **filter**: `KueryNode` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:129](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L129) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:128](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L128) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserActionItemByDifference.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserActionItemByDifference.md deleted file mode 100644 index 50f9ae9a6fc34..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserActionItemByDifference.md +++ /dev/null @@ -1,162 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetUserActionItemByDifference - -# Interface: GetUserActionItemByDifference - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetUserActionItemByDifference - -## Hierarchy - -- [`CommonUserActionArgs`](../modules/client._internal_namespace.md#commonuseractionargs) - - ↳ **`GetUserActionItemByDifference`** - -## Table of contents - -### Properties - -- [action](client._internal_namespace.GetUserActionItemByDifference.md#action) -- [attachmentId](client._internal_namespace.GetUserActionItemByDifference.md#attachmentid) -- [caseId](client._internal_namespace.GetUserActionItemByDifference.md#caseid) -- [connectorId](client._internal_namespace.GetUserActionItemByDifference.md#connectorid) -- [field](client._internal_namespace.GetUserActionItemByDifference.md#field) -- [newValue](client._internal_namespace.GetUserActionItemByDifference.md#newvalue) -- [originalValue](client._internal_namespace.GetUserActionItemByDifference.md#originalvalue) -- [owner](client._internal_namespace.GetUserActionItemByDifference.md#owner) -- [unsecuredSavedObjectsClient](client._internal_namespace.GetUserActionItemByDifference.md#unsecuredsavedobjectsclient) -- [user](client._internal_namespace.GetUserActionItemByDifference.md#user) - -## Properties - -### action - -• `Optional` **action**: ``"add"`` \| ``"create"`` \| ``"delete"`` \| ``"update"`` \| ``"push_to_service"`` - -#### Inherited from - -CommonUserActionArgs.action - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:80](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L80) - -___ - -### attachmentId - -• `Optional` **attachmentId**: `string` - -#### Inherited from - -CommonUserActionArgs.attachmentId - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:78](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L78) - -___ - -### caseId - -• **caseId**: `string` - -#### Inherited from - -CommonUserActionArgs.caseId - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:76](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L76) - -___ - -### connectorId - -• `Optional` **connectorId**: `string` - -#### Inherited from - -CommonUserActionArgs.connectorId - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L79) - -___ - -### field - -• **field**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:83](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L83) - -___ - -### newValue - -• **newValue**: `unknown` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:85](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L85) - -___ - -### originalValue - -• **originalValue**: `unknown` - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:84](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L84) - -___ - -### owner - -• **owner**: `string` - -#### Inherited from - -CommonUserActionArgs.owner - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:77](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L77) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -CommonUserActionArgs.unsecuredSavedObjectsClient - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) - -___ - -### user - -• **user**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Inherited from - -CommonUserActionArgs.user - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:75](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L75) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserArgs.md deleted file mode 100644 index d4913925ff206..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.GetUserArgs.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / GetUserArgs - -# Interface: GetUserArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).GetUserArgs - -## Table of contents - -### Properties - -- [request](client._internal_namespace.GetUserArgs.md#request) - -## Properties - -### request - -• **request**: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:110](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L110) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IEventLogger.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IEventLogger.md deleted file mode 100644 index a1b44e51859d4..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IEventLogger.md +++ /dev/null @@ -1,73 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IEventLogger - -# Interface: IEventLogger - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IEventLogger - -## Table of contents - -### Methods - -- [logEvent](client._internal_namespace.IEventLogger.md#logevent) -- [startTiming](client._internal_namespace.IEventLogger.md#starttiming) -- [stopTiming](client._internal_namespace.IEventLogger.md#stoptiming) - -## Methods - -### logEvent - -▸ **logEvent**(`properties`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `properties` | [`IEvent`](../modules/client._internal_namespace.md#ievent) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/event_log/target/types/server/types.d.ts:34 - -___ - -### startTiming - -▸ **startTiming**(`event`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `event` | [`IEvent`](../modules/client._internal_namespace.md#ievent) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/event_log/target/types/server/types.d.ts:35 - -___ - -### stopTiming - -▸ **stopTiming**(`event`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `event` | [`IEvent`](../modules/client._internal_namespace.md#ievent) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/event_log/target/types/server/types.d.ts:36 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IKibanaSocket.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IKibanaSocket.md deleted file mode 100644 index cc2ea54f3975a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IKibanaSocket.md +++ /dev/null @@ -1,150 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IKibanaSocket - -# Interface: IKibanaSocket - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IKibanaSocket - -A tiny abstraction for TCP socket. - -## Table of contents - -### Properties - -- [authorizationError](client._internal_namespace.IKibanaSocket.md#authorizationerror) -- [authorized](client._internal_namespace.IKibanaSocket.md#authorized) - -### Methods - -- [getPeerCertificate](client._internal_namespace.IKibanaSocket.md#getpeercertificate) -- [getProtocol](client._internal_namespace.IKibanaSocket.md#getprotocol) -- [renegotiate](client._internal_namespace.IKibanaSocket.md#renegotiate) - -## Properties - -### authorizationError - -• `Optional` `Readonly` **authorizationError**: `Error` - -The reason why the peer's certificate has not been verified. This property becomes available -only when `authorized` is `false`. - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:45 - -___ - -### authorized - -• `Optional` `Readonly` **authorized**: `boolean` - -Indicates whether or not the peer certificate was signed by one of the specified CAs. When TLS -isn't used the value is `undefined`. - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:40 - -## Methods - -### getPeerCertificate - -▸ **getPeerCertificate**(`detailed`): ``null`` \| `DetailedPeerCertificate` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `detailed` | ``true`` | - -#### Returns - -``null`` \| `DetailedPeerCertificate` - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:9 - -▸ **getPeerCertificate**(`detailed`): ``null`` \| `PeerCertificate` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `detailed` | ``false`` | - -#### Returns - -``null`` \| `PeerCertificate` - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:10 - -▸ **getPeerCertificate**(`detailed?`): ``null`` \| `DetailedPeerCertificate` \| `PeerCertificate` - -Returns an object representing the peer's certificate. -The returned object has some properties corresponding to the field of the certificate. -If detailed argument is true the full chain with issuer property will be returned, -if false only the top certificate without issuer property. -If the peer does not provide a certificate, it returns null. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `detailed?` | `boolean` | If true; the full chain with issuer property will be returned. | - -#### Returns - -``null`` \| `DetailedPeerCertificate` \| `PeerCertificate` - -An object representing the peer's certificate. - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:20 - -___ - -### getProtocol - -▸ **getProtocol**(): ``null`` \| `string` - -Returns a string containing the negotiated SSL/TLS protocol version of the current connection. The value 'unknown' will be returned for -connected sockets that have not completed the handshaking process. The value null will be returned for server sockets or disconnected -client sockets. See https://www.openssl.org/docs/man1.0.2/ssl/SSL_get_version.html for more information. - -#### Returns - -``null`` \| `string` - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:26 - -___ - -### renegotiate - -▸ **renegotiate**(`options`): `Promise`<`void`\> - -Renegotiates a connection to obtain the peer's certificate. This cannot be used when the protocol version is TLSv1.3. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `options` | `Object` | The options may contain the following fields: rejectUnauthorized, requestCert (See tls.createServer() for details). | -| `options.rejectUnauthorized?` | `boolean` | - | -| `options.requestCert?` | `boolean` | - | - -#### Returns - -`Promise`<`void`\> - -A Promise that will be resolved if renegotiation succeeded, or will be rejected if renegotiation failed. - -#### Defined in - -src/core/target/types/server/http/router/socket.d.ts:32 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ILicense.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ILicense.md deleted file mode 100644 index 8449411b85e42..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ILicense.md +++ /dev/null @@ -1,236 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ILicense - -# Interface: ILicense - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ILicense - -## Table of contents - -### Properties - -- [error](client._internal_namespace.ILicense.md#error) -- [expiryDateInMillis](client._internal_namespace.ILicense.md#expirydateinmillis) -- [isActive](client._internal_namespace.ILicense.md#isactive) -- [isAvailable](client._internal_namespace.ILicense.md#isavailable) -- [mode](client._internal_namespace.ILicense.md#mode) -- [signature](client._internal_namespace.ILicense.md#signature) -- [status](client._internal_namespace.ILicense.md#status) -- [type](client._internal_namespace.ILicense.md#type) -- [uid](client._internal_namespace.ILicense.md#uid) - -### Methods - -- [check](client._internal_namespace.ILicense.md#check) -- [getFeature](client._internal_namespace.ILicense.md#getfeature) -- [getUnavailableReason](client._internal_namespace.ILicense.md#getunavailablereason) -- [hasAtLeast](client._internal_namespace.ILicense.md#hasatleast) -- [toJSON](client._internal_namespace.ILicense.md#tojson) - -## Properties - -### error - -• `Optional` **error**: `string` - -A potential error denoting the failure of the license from being retrieved. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:119 - -___ - -### expiryDateInMillis - -• `Optional` **expiryDateInMillis**: `number` - -Unix epoch of the expiration date of the license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:94 - -___ - -### isActive - -• **isActive**: `boolean` - -Determine if the status of the license is active. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:90 - -___ - -### isAvailable - -• **isAvailable**: `boolean` - -Determine if the license container has information. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:111 - -___ - -### mode - -• `Optional` **mode**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -The license type, being usually one of basic, standard, gold, platinum, or trial. - -**`deprecated`** use 'type' instead. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:103 - -___ - -### signature - -• **signature**: `string` - -Signature of the license content. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:107 - -___ - -### status - -• `Optional` **status**: [`LicenseStatus`](../modules/client._internal_namespace.md#licensestatus) - -The validity status of the license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:86 - -___ - -### type - -• `Optional` **type**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -The license type, being usually one of basic, standard, gold, platinum, or trial. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:98 - -___ - -### uid - -• `Optional` **uid**: `string` - -UID for license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:82 - -## Methods - -### check - -▸ **check**(`pluginName`, `minimumLicenseRequired`): [`LicenseCheck`](client._internal_namespace.LicenseCheck.md) - -For a given plugin and license type, receive information about the status of the license. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `pluginName` | `string` | the name of the plugin | -| `minimumLicenseRequired` | ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` | the minimum valid license for operating the given plugin | - -#### Returns - -[`LicenseCheck`](client._internal_namespace.LicenseCheck.md) - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:134 - -___ - -### getFeature - -▸ **getFeature**(`name`): [`LicenseFeature`](client._internal_namespace.LicenseFeature.md) - -A specific API for interacting with the specific features of the license. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `name` | `string` | the name of the feature to interact with | - -#### Returns - -[`LicenseFeature`](client._internal_namespace.LicenseFeature.md) - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:139 - -___ - -### getUnavailableReason - -▸ **getUnavailableReason**(): `undefined` \| `string` - -If the license is not available, provides a string or Error containing the reason. - -#### Returns - -`undefined` \| `string` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:123 - -___ - -### hasAtLeast - -▸ **hasAtLeast**(`minimumLicenseRequired`): `boolean` - -Determine if license type >= minimal required license type. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `minimumLicenseRequired` | ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` | the minimum valid license required for the given feature | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:128 - -___ - -### toJSON - -▸ **toJSON**(): [`PublicLicenseJSON`](client._internal_namespace.PublicLicenseJSON.md) - -Returns - -#### Returns - -[`PublicLicenseJSON`](client._internal_namespace.PublicLicenseJSON.md) - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:115 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md deleted file mode 100644 index 17a5e67c8b2b6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md +++ /dev/null @@ -1,61 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ISavedObjectsPointInTimeFinder - -# Interface: ISavedObjectsPointInTimeFinder - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ISavedObjectsPointInTimeFinder - -## Type parameters - -| Name | -| :------ | -| `T` | -| `A` | - -## Table of contents - -### Methods - -- [close](client._internal_namespace.ISavedObjectsPointInTimeFinder.md#close) -- [find](client._internal_namespace.ISavedObjectsPointInTimeFinder.md#find) - -## Methods - -### close - -▸ **close**(): `Promise`<`void`\> - -Closes the Point-In-Time associated with this finder instance. - -Once you have retrieved all of the results you need, it is recommended -to call `close()` to clean up the PIT and prevent Elasticsearch from -consuming resources unnecessarily. This is only required if you are -done iterating and have not yet paged through all of the results: the -PIT will automatically be closed for you once you reach the last page -of results, or if the underlying call to `find` fails for any reason. - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/point_in_time_finder.d.ts:43 - -___ - -### find - -▸ **find**(): `AsyncGenerator`<[`SavedObjectsFindResponse`](client._internal_namespace.SavedObjectsFindResponse.md)<`T`, `A`\>, `any`, `unknown`\> - -An async generator which wraps calls to `savedObjectsClient.find` and -iterates over multiple pages of results using `_pit` and `search_after`. -This will open a new Point-In-Time (PIT), and continue paging until a set -of results is received that's smaller than the designated `perPage` size. - -#### Returns - -`AsyncGenerator`<[`SavedObjectsFindResponse`](client._internal_namespace.SavedObjectsFindResponse.md)<`T`, `A`\>, `any`, `unknown`\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/point_in_time_finder.d.ts:32 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IScopedClusterClient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IScopedClusterClient.md deleted file mode 100644 index 47f8263232290..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IScopedClusterClient.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IScopedClusterClient - -# Interface: IScopedClusterClient - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IScopedClusterClient - -Serves the same purpose as the normal {@link IClusterClient | cluster client} but exposes -an additional `asCurrentUser` method that doesn't use credentials of the Kibana internal -user (as `asInternalUser` does) to request Elasticsearch API, but rather passes HTTP headers -extracted from the current user request to the API instead. - -## Table of contents - -### Properties - -- [asCurrentUser](client._internal_namespace.IScopedClusterClient.md#ascurrentuser) -- [asInternalUser](client._internal_namespace.IScopedClusterClient.md#asinternaluser) - -## Properties - -### asCurrentUser - -• `Readonly` **asCurrentUser**: [`ElasticsearchClient`](../modules/client._internal_namespace.md#elasticsearchclient) - -A [client](../modules/client._internal_namespace.md#elasticsearchclient) to be used to query the elasticsearch cluster -on behalf of the user that initiated the request to the Kibana server. - -#### Defined in - -src/core/target/types/server/elasticsearch/client/scoped_cluster_client.d.ts:20 - -___ - -### asInternalUser - -• `Readonly` **asInternalUser**: [`ElasticsearchClient`](../modules/client._internal_namespace.md#elasticsearchclient) - -A [client](../modules/client._internal_namespace.md#elasticsearchclient) to be used to query the elasticsearch cluster -on behalf of the internal Kibana user. - -#### Defined in - -src/core/target/types/server/elasticsearch/client/scoped_cluster_client.d.ts:15 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISpacesClient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISpacesClient.md deleted file mode 100644 index 5b7aab2435b5a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ISpacesClient.md +++ /dev/null @@ -1,151 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ISpacesClient - -# Interface: ISpacesClient - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ISpacesClient - -Client interface for interacting with spaces. - -## Table of contents - -### Methods - -- [create](client._internal_namespace.ISpacesClient.md#create) -- [delete](client._internal_namespace.ISpacesClient.md#delete) -- [disableLegacyUrlAliases](client._internal_namespace.ISpacesClient.md#disablelegacyurlaliases) -- [get](client._internal_namespace.ISpacesClient.md#get) -- [getAll](client._internal_namespace.ISpacesClient.md#getall) -- [update](client._internal_namespace.ISpacesClient.md#update) - -## Methods - -### create - -▸ **create**(`space`): `Promise`<[`Space`](client._internal_namespace.Space.md)\> - -Creates a space. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `space` | [`Space`](client._internal_namespace.Space.md) | the space to create. | - -#### Returns - -`Promise`<[`Space`](client._internal_namespace.Space.md)\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_client/spaces_client.d.ts:22 - -___ - -### delete - -▸ **delete**(`id`): `Promise`<`void`\> - -Deletes a space, and all saved objects belonging to that space. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `id` | `string` | the id of the space to delete. | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_client/spaces_client.d.ts:33 - -___ - -### disableLegacyUrlAliases - -▸ **disableLegacyUrlAliases**(`aliases`): `Promise`<`void`\> - -Disables the specified legacy URL aliases. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `aliases` | [`LegacyUrlAliasTarget`](client._internal_namespace.LegacyUrlAliasTarget.md)[] | the aliases to disable. | - -#### Returns - -`Promise`<`void`\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_client/spaces_client.d.ts:38 - -___ - -### get - -▸ **get**(`id`): `Promise`<[`Space`](client._internal_namespace.Space.md)\> - -Retrieve a space by its id. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `id` | `string` | the space id. | - -#### Returns - -`Promise`<[`Space`](client._internal_namespace.Space.md)\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_client/spaces_client.d.ts:17 - -___ - -### getAll - -▸ **getAll**(`options?`): `Promise`<[`GetSpaceResult`](client._internal_namespace.GetSpaceResult.md)[]\> - -Retrieve all available spaces. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `options?` | [`GetAllSpacesOptions`](client._internal_namespace.GetAllSpacesOptions.md) | controls which spaces are retrieved. | - -#### Returns - -`Promise`<[`GetSpaceResult`](client._internal_namespace.GetSpaceResult.md)[]\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_client/spaces_client.d.ts:12 - -___ - -### update - -▸ **update**(`id`, `space`): `Promise`<[`Space`](client._internal_namespace.Space.md)\> - -Updates a space. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `id` | `string` | the id of the space to update. | -| `space` | [`Space`](client._internal_namespace.Space.md) | the updated space. | - -#### Returns - -`Promise`<[`Space`](client._internal_namespace.Space.md)\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_client/spaces_client.d.ts:28 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IUsageCounter.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IUsageCounter.md deleted file mode 100644 index 9ed76ff78e51b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IUsageCounter.md +++ /dev/null @@ -1,37 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IUsageCounter - -# Interface: IUsageCounter - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IUsageCounter - -Usage Counter allows to keep track of any events that occur. -By calling [IUsageCounter.incrementCounter](client._internal_namespace.IUsageCounter.md#incrementcounter) devs can notify this -API whenever the event happens. - -## Table of contents - -### Methods - -- [incrementCounter](client._internal_namespace.IUsageCounter.md#incrementcounter) - -## Methods - -### incrementCounter - -▸ **incrementCounter**(`params`): `void` - -Notifies the counter about a new event happening so it can increase the count internally. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `params` | [`IncrementCounterParams`](client._internal_namespace.IncrementCounterParams.md) | [IncrementCounterParams](client._internal_namespace.IncrementCounterParams.md) | - -#### Returns - -`void` - -#### Defined in - -src/plugins/usage_collection/target/types/server/usage_counters/usage_counter.d.ts:33 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IncrementCounterParams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IncrementCounterParams.md deleted file mode 100644 index 0c79f0d867cdc..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IncrementCounterParams.md +++ /dev/null @@ -1,51 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IncrementCounterParams - -# Interface: IncrementCounterParams - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IncrementCounterParams - -Details about the counter to be incremented - -## Table of contents - -### Properties - -- [counterName](client._internal_namespace.IncrementCounterParams.md#countername) -- [counterType](client._internal_namespace.IncrementCounterParams.md#countertype) -- [incrementBy](client._internal_namespace.IncrementCounterParams.md#incrementby) - -## Properties - -### counterName - -• **counterName**: `string` - -The name of the counter - -#### Defined in - -src/plugins/usage_collection/target/types/server/usage_counters/usage_counter.d.ts:17 - -___ - -### counterType - -• `Optional` **counterType**: `string` - -The counter type ("count" by default) - -#### Defined in - -src/plugins/usage_collection/target/types/server/usage_counters/usage_counter.d.ts:19 - -___ - -### incrementBy - -• `Optional` **incrementBy**: `number` - -Increment the counter by this number (1 if not specified) - -#### Defined in - -src/plugins/usage_collection/target/types/server/usage_counters/usage_counter.d.ts:21 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMapping.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMapping.md deleted file mode 100644 index 71cfddb7c8981..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMapping.md +++ /dev/null @@ -1,45 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IndexMapping - -# Interface: IndexMapping - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IndexMapping - -**`internal`** - -## Table of contents - -### Properties - -- [\_meta](client._internal_namespace.IndexMapping.md#_meta) -- [dynamic](client._internal_namespace.IndexMapping.md#dynamic) -- [properties](client._internal_namespace.IndexMapping.md#properties) - -## Properties - -### \_meta - -• `Optional` **\_meta**: [`IndexMappingMeta`](client._internal_namespace.IndexMappingMeta.md) - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:104 - -___ - -### dynamic - -• `Optional` **dynamic**: `boolean` \| ``"strict"`` - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:102 - -___ - -### properties - -• **properties**: [`SavedObjectsMappingProperties`](client._internal_namespace.SavedObjectsMappingProperties.md) - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:103 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMappingMeta.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMappingMeta.md deleted file mode 100644 index de9e76ae00099..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IndexMappingMeta.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IndexMappingMeta - -# Interface: IndexMappingMeta - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IndexMappingMeta - -**`internal`** - -## Table of contents - -### Properties - -- [migrationMappingPropertyHashes](client._internal_namespace.IndexMappingMeta.md#migrationmappingpropertyhashes) - -## Properties - -### migrationMappingPropertyHashes - -• `Optional` **migrationMappingPropertyHashes**: `Object` - -#### Index signature - -▪ [k: `string`]: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:108 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IntervalSchedule.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IntervalSchedule.md deleted file mode 100644 index 365dfd5f7dfdf..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.IntervalSchedule.md +++ /dev/null @@ -1,23 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / IntervalSchedule - -# Interface: IntervalSchedule - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).IntervalSchedule - -## Table of contents - -### Properties - -- [interval](client._internal_namespace.IntervalSchedule.md#interval) - -## Properties - -### interval - -• **interval**: `string` - -An interval in minutes (e.g. '5m'). If specified, this is a recurring task. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:137 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaFeatureConfig.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaFeatureConfig.md deleted file mode 100644 index 2013e42ad5bf2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaFeatureConfig.md +++ /dev/null @@ -1,257 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaFeatureConfig - -# Interface: KibanaFeatureConfig - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaFeatureConfig - -Interface for registering a feature. -Feature registration allows plugins to hide their applications with spaces, -and secure access when configured for security. - -## Table of contents - -### Properties - -- [alerting](client._internal_namespace.KibanaFeatureConfig.md#alerting) -- [app](client._internal_namespace.KibanaFeatureConfig.md#app) -- [cases](client._internal_namespace.KibanaFeatureConfig.md#cases) -- [catalogue](client._internal_namespace.KibanaFeatureConfig.md#catalogue) -- [category](client._internal_namespace.KibanaFeatureConfig.md#category) -- [excludeFromBasePrivileges](client._internal_namespace.KibanaFeatureConfig.md#excludefrombaseprivileges) -- [id](client._internal_namespace.KibanaFeatureConfig.md#id) -- [management](client._internal_namespace.KibanaFeatureConfig.md#management) -- [minimumLicense](client._internal_namespace.KibanaFeatureConfig.md#minimumlicense) -- [name](client._internal_namespace.KibanaFeatureConfig.md#name) -- [order](client._internal_namespace.KibanaFeatureConfig.md#order) -- [privileges](client._internal_namespace.KibanaFeatureConfig.md#privileges) -- [privilegesTooltip](client._internal_namespace.KibanaFeatureConfig.md#privilegestooltip) -- [reserved](client._internal_namespace.KibanaFeatureConfig.md#reserved) -- [subFeatures](client._internal_namespace.KibanaFeatureConfig.md#subfeatures) - -## Properties - -### alerting - -• `Optional` **alerting**: readonly `string`[] - -If your feature grants access to specific Alert Types, you can specify them here to control visibility based on the current space. -Include both Alert Types registered by the feature and external Alert Types such as built-in -Alert Types and Alert Types provided by other features to which you wish to grant access. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:83 - -___ - -### app - -• **app**: readonly `string`[] - -An array of app ids that are enabled when this feature is enabled. -Apps specified here will automatically cascade to the privileges defined below, unless specified differently there. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:54 - -___ - -### cases - -• `Optional` **cases**: readonly `string`[] - -If your feature grants access to specific case types, you can specify them here to control visibility based on the current space. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:87 - -___ - -### catalogue - -• `Optional` **catalogue**: readonly `string`[] - -If this feature includes a catalogue entry, you can specify them here to control visibility based on the current space. - -Items specified here will automatically cascade to the privileges defined below, unless specified differently there. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:77 - -___ - -### category - -• **category**: [`AppCategory`](client._internal_namespace.AppCategory.md) - -The category for this feature. -This will be used to organize the list of features for display within the -Spaces and Roles management screens. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:30 - -___ - -### excludeFromBasePrivileges - -• `Optional` **excludeFromBasePrivileges**: `boolean` - -Whether or not this feature should be excluded from the base privileges. -This is primarily helpful when migrating applications with a "legacy" privileges model -to use Kibana privileges. We don't want these features to be considered part of the `all` -or `read` base privileges in a minor release if the user was previously granted access -using an additional reserved role. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:42 - -___ - -### id - -• **id**: `string` - -Unique identifier for this feature. -This identifier is also used when generating UI Capabilities. - -**`see`** UICapabilities - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:19 - -___ - -### management - -• `Optional` **management**: `Object` - -If this feature includes management sections, you can specify them here to control visibility of those -pages based on the current space. - -Items specified here will automatically cascade to the privileges defined below, unless specified differently there. - -**`example`** -```ts - // Enables access to the "Advanced Settings" management page within the Kibana section - management: { - kibana: ['settings'] - } -``` - -#### Index signature - -▪ [sectionId: `string`]: readonly `string`[] - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:69 - -___ - -### minimumLicense - -• `Optional` **minimumLicense**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -Optional minimum supported license. -If omitted, all licenses are allowed. -This does not restrict access to your feature based on license. -Its only purpose is to inform the space and roles UIs on which features to display. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:49 - -___ - -### name - -• **name**: `string` - -Display name for this feature. -This will be displayed to end-users, so a translatable string is advised for i18n. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:24 - -___ - -### order - -• `Optional` **order**: `number` - -An ordinal used to sort features relative to one another for display. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:34 - -___ - -### privileges - -• **privileges**: ``null`` \| { `all`: [`FeatureKibanaPrivileges`](client._internal_namespace.FeatureKibanaPrivileges.md) ; `read`: [`FeatureKibanaPrivileges`](client._internal_namespace.FeatureKibanaPrivileges.md) } - -Feature privilege definition. - -**`example`** -```ts - { - all: {...}, - read: {...} - } -``` - -**`see`** FeatureKibanaPrivileges - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:100 - -___ - -### privilegesTooltip - -• `Optional` **privilegesTooltip**: `string` - -Optional message to display on the Role Management screen when configuring permissions for this feature. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:111 - -___ - -### reserved - -• `Optional` `Private` **reserved**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `description` | `string` | -| `privileges` | readonly [`ReservedKibanaPrivilege`](client._internal_namespace.ReservedKibanaPrivilege.md)[] | - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:115 - -___ - -### subFeatures - -• `Optional` **subFeatures**: readonly [`SubFeatureConfig`](client._internal_namespace.SubFeatureConfig.md)[] - -Optional sub-feature privilege definitions. This can only be specified if `privileges` are are also defined. - -#### Defined in - -x-pack/plugins/features/target/types/common/kibana_feature.d.ts:107 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorOptions.md deleted file mode 100644 index 1b316e68c5771..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorOptions.md +++ /dev/null @@ -1,76 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaMigratorOptions - -# Interface: KibanaMigratorOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaMigratorOptions - -## Table of contents - -### Properties - -- [client](client._internal_namespace.KibanaMigratorOptions.md#client) -- [kibanaIndex](client._internal_namespace.KibanaMigratorOptions.md#kibanaindex) -- [kibanaVersion](client._internal_namespace.KibanaMigratorOptions.md#kibanaversion) -- [logger](client._internal_namespace.KibanaMigratorOptions.md#logger) -- [soMigrationsConfig](client._internal_namespace.KibanaMigratorOptions.md#somigrationsconfig) -- [typeRegistry](client._internal_namespace.KibanaMigratorOptions.md#typeregistry) - -## Properties - -### client - -• **client**: [`ElasticsearchClient`](../modules/client._internal_namespace.md#elasticsearchclient) - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:10 - -___ - -### kibanaIndex - -• **kibanaIndex**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:13 - -___ - -### kibanaVersion - -• **kibanaVersion**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:14 - -___ - -### logger - -• **logger**: `Logger` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:15 - -___ - -### soMigrationsConfig - -• **soMigrationsConfig**: `Readonly`<{} & { `batchSize`: `number` ; `maxBatchSizeBytes`: `ByteSizeValue` ; `pollInterval`: `number` ; `retryAttempts`: `number` ; `scrollDuration`: `string` ; `skip`: `boolean` }\> - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:12 - -___ - -### typeRegistry - -• **typeRegistry**: [`ISavedObjectTypeRegistry`](../modules/client._internal_namespace.md#isavedobjecttyperegistry) - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:11 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorStatus.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorStatus.md deleted file mode 100644 index 21bba02200fa4..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaMigratorStatus.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaMigratorStatus - -# Interface: KibanaMigratorStatus - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaMigratorStatus - -## Table of contents - -### Properties - -- [result](client._internal_namespace.KibanaMigratorStatus.md#result) -- [status](client._internal_namespace.KibanaMigratorStatus.md#status) -- [waitingIndex](client._internal_namespace.KibanaMigratorStatus.md#waitingindex) - -## Properties - -### result - -• `Optional` **result**: [`MigrationResult`](../modules/client._internal_namespace.md#migrationresult)[] - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:20 - -___ - -### status - -• **status**: [`MigrationStatus`](../modules/client._internal_namespace.md#migrationstatus) - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:19 - -___ - -### waitingIndex - -• `Optional` **waitingIndex**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:21 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaRequestEvents.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaRequestEvents.md deleted file mode 100644 index c4b610af9ba99..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.KibanaRequestEvents.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / KibanaRequestEvents - -# Interface: KibanaRequestEvents - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).KibanaRequestEvents - -Request events. - -## Table of contents - -### Properties - -- [aborted$](client._internal_namespace.KibanaRequestEvents.md#aborted$) -- [completed$](client._internal_namespace.KibanaRequestEvents.md#completed$) - -## Properties - -### aborted$ - -• **aborted$**: `Observable`<`void`\> - -Observable that emits once if and when the request has been aborted. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:48 - -___ - -### completed$ - -• **completed$**: `Observable`<`void`\> - -Observable that emits once if and when the request has been completely handled. - -**`remarks`** -The request may be considered completed if: -- A response has been sent to the client; or -- The request was aborted. - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:57 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LegacyUrlAliasTarget.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LegacyUrlAliasTarget.md deleted file mode 100644 index 1580adc5c3127..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LegacyUrlAliasTarget.md +++ /dev/null @@ -1,51 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / LegacyUrlAliasTarget - -# Interface: LegacyUrlAliasTarget - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).LegacyUrlAliasTarget - -Client interface for interacting with legacy URL aliases. - -## Table of contents - -### Properties - -- [sourceId](client._internal_namespace.LegacyUrlAliasTarget.md#sourceid) -- [targetSpace](client._internal_namespace.LegacyUrlAliasTarget.md#targetspace) -- [targetType](client._internal_namespace.LegacyUrlAliasTarget.md#targettype) - -## Properties - -### sourceId - -• **sourceId**: `string` - -The original ID of the object, before it was converted. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:99 - -___ - -### targetSpace - -• **targetSpace**: `string` - -The namespace that the object existed in when it was converted. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:91 - -___ - -### targetType - -• **targetType**: `string` - -The type of the object when it was converted. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:95 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseCheck.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseCheck.md deleted file mode 100644 index 084c5ae23607e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseCheck.md +++ /dev/null @@ -1,36 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / LicenseCheck - -# Interface: LicenseCheck - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).LicenseCheck - -## Table of contents - -### Properties - -- [message](client._internal_namespace.LicenseCheck.md#message) -- [state](client._internal_namespace.LicenseCheck.md#state) - -## Properties - -### message - -• `Optional` **message**: `string` - -A message containing the reason for a license type not being valid. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:75 - -___ - -### state - -• **state**: [`LicenseCheckState`](../modules/client._internal_namespace.md#licensecheckstate) - -The state of checking the results of a license type meeting the license minimum. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:71 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseFeature.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseFeature.md deleted file mode 100644 index e6794cd50d933..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicenseFeature.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / LicenseFeature - -# Interface: LicenseFeature - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).LicenseFeature - -## Table of contents - -### Properties - -- [isAvailable](client._internal_namespace.LicenseFeature.md#isavailable) -- [isEnabled](client._internal_namespace.LicenseFeature.md#isenabled) - -## Properties - -### isAvailable - -• **isAvailable**: `boolean` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:16 - -___ - -### isEnabled - -• **isEnabled**: `boolean` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:17 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicensingPluginSetup.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicensingPluginSetup.md deleted file mode 100644 index 240dbd27ad2fc..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.LicensingPluginSetup.md +++ /dev/null @@ -1,60 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / LicensingPluginSetup - -# Interface: LicensingPluginSetup - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).LicensingPluginSetup - -## Table of contents - -### Properties - -- [featureUsage](client._internal_namespace.LicensingPluginSetup.md#featureusage) -- [license$](client._internal_namespace.LicensingPluginSetup.md#license$) - -### Methods - -- [refresh](client._internal_namespace.LicensingPluginSetup.md#refresh) - -## Properties - -### featureUsage - -• **featureUsage**: [`FeatureUsageServiceSetup`](client._internal_namespace.FeatureUsageServiceSetup.md) - -APIs to register licensed feature usage. - -#### Defined in - -x-pack/plugins/licensing/target/types/server/types.d.ts:49 - -___ - -### license$ - -• **license$**: `Observable`<[`ILicense`](client._internal_namespace.ILicense.md)\> - -Steam of licensing information [ILicense](client._internal_namespace.ILicense.md). - -**`deprecated`** in favour of the counterpart provided from start contract - -#### Defined in - -x-pack/plugins/licensing/target/types/server/types.d.ts:40 - -## Methods - -### refresh - -▸ **refresh**(): `Promise`<[`ILicense`](client._internal_namespace.ILicense.md)\> - -Triggers licensing information re-fetch. - -**`deprecated`** in favour of the counterpart provided from start contract - -#### Returns - -`Promise`<[`ILicense`](client._internal_namespace.ILicense.md)\> - -#### Defined in - -x-pack/plugins/licensing/target/types/server/types.d.ts:45 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Middleware.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Middleware.md deleted file mode 100644 index 0a6d5169b4278..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Middleware.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Middleware - -# Interface: Middleware - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Middleware - -## Table of contents - -### Properties - -- [beforeMarkRunning](client._internal_namespace.Middleware.md#beforemarkrunning) -- [beforeRun](client._internal_namespace.Middleware.md#beforerun) -- [beforeSave](client._internal_namespace.Middleware.md#beforesave) - -## Properties - -### beforeMarkRunning - -• **beforeMarkRunning**: [`BeforeRunContextFunction`](../modules/client._internal_namespace.md#beforeruncontextfunction) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:11 - -___ - -### beforeRun - -• **beforeRun**: [`BeforeRunContextFunction`](../modules/client._internal_namespace.md#beforeruncontextfunction) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:10 - -___ - -### beforeSave - -• **beforeSave**: [`BeforeSaveContextFunction`](../modules/client._internal_namespace.md#beforesavecontextfunction) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:9 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OperationDetails.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OperationDetails.md deleted file mode 100644 index a7e428f943d05..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OperationDetails.md +++ /dev/null @@ -1,91 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / OperationDetails - -# Interface: OperationDetails - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).OperationDetails - -Defines the structure for a case API route. - -## Table of contents - -### Properties - -- [action](client._internal_namespace.OperationDetails.md#action) -- [docType](client._internal_namespace.OperationDetails.md#doctype) -- [ecsType](client._internal_namespace.OperationDetails.md#ecstype) -- [name](client._internal_namespace.OperationDetails.md#name) -- [savedObjectType](client._internal_namespace.OperationDetails.md#savedobjecttype) -- [verbs](client._internal_namespace.OperationDetails.md#verbs) - -## Properties - -### action - -• **action**: `string` - -The ECS `event.action` field, should be in the form of _ e.g comment_get, case_fined - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:83](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L83) - -___ - -### docType - -• **docType**: `string` - -The readable name of the entity being operated on e.g. case, comment, configurations (make it plural if it reads better that way etc) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:91](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L91) - -___ - -### ecsType - -• **ecsType**: `EcsEventType` - -The ECS event type that this operation should be audit logged as (creation, deletion, access, etc) - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:74](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L74) - -___ - -### name - -• **name**: `string` - -The name of the operation to authorize against for the privilege check. -These values need to match one of the operation strings defined here: x-pack/plugins/security/server/authorization/privileges/feature_privilege_builder/cases.ts - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L79) - -___ - -### savedObjectType - -• **savedObjectType**: `string` - -The actual saved object type of the entity e.g. cases, cases-comments - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:95](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L95) - -___ - -### verbs - -• **verbs**: [`Verbs`](client._internal_namespace.Verbs.md) - -The verbs that are associated with this type of operation, these should line up with the event type e.g. creating, created, create etc - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:87](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L87) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OwnerEntity.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OwnerEntity.md deleted file mode 100644 index 771823c8e9711..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.OwnerEntity.md +++ /dev/null @@ -1,35 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / OwnerEntity - -# Interface: OwnerEntity - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).OwnerEntity - -Describes an entity with the necessary fields to identify if the user is authorized to interact with the saved object -returned from some find query. - -## Table of contents - -### Properties - -- [id](client._internal_namespace.OwnerEntity.md#id) -- [owner](client._internal_namespace.OwnerEntity.md#owner) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:104](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L104) - -___ - -### owner - -• **owner**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:103](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L103) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCase.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCase.md deleted file mode 100644 index 39774f46c552f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCase.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PatchCase - -# Interface: PatchCase - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PatchCase - -## Table of contents - -### Properties - -- [caseId](client._internal_namespace.PatchCase.md#caseid) -- [originalCase](client._internal_namespace.PatchCase.md#originalcase) -- [updatedAttributes](client._internal_namespace.PatchCase.md#updatedattributes) -- [version](client._internal_namespace.PatchCase.md#version) - -## Properties - -### caseId - -• **caseId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:98](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L98) - -___ - -### originalCase - -• **originalCase**: [`SavedObject`](client._internal_namespace.SavedObject.md)<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:100](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L100) - -___ - -### updatedAttributes - -• **updatedAttributes**: `Partial`<{ `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & [`PushedArgs`](client._internal_namespace.PushedArgs.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:99](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L99) - -___ - -### version - -• `Optional` **version**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:101](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L101) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCaseConfigureArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCaseConfigureArgs.md deleted file mode 100644 index c6909426e1088..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCaseConfigureArgs.md +++ /dev/null @@ -1,64 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PatchCaseConfigureArgs - -# Interface: PatchCaseConfigureArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PatchCaseConfigureArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs.md) - - ↳ **`PatchCaseConfigureArgs`** - -## Table of contents - -### Properties - -- [configurationId](client._internal_namespace.PatchCaseConfigureArgs.md#configurationid) -- [originalConfiguration](client._internal_namespace.PatchCaseConfigureArgs.md#originalconfiguration) -- [unsecuredSavedObjectsClient](client._internal_namespace.PatchCaseConfigureArgs.md#unsecuredsavedobjectsclient) -- [updatedAttributes](client._internal_namespace.PatchCaseConfigureArgs.md#updatedattributes) - -## Properties - -### configurationId - -• **configurationId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:46](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L46) - -___ - -### originalConfiguration - -• **originalConfiguration**: [`SavedObject`](client._internal_namespace.SavedObject.md)<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:48](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L48) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L30) - -___ - -### updatedAttributes - -• **updatedAttributes**: `Partial`<{ `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\> - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:47](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L47) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCasesArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCasesArgs.md deleted file mode 100644 index 24db998f64f3d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PatchCasesArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PatchCasesArgs - -# Interface: PatchCasesArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PatchCasesArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`PatchCasesArgs`** - -## Table of contents - -### Properties - -- [cases](client._internal_namespace.PatchCasesArgs.md#cases) -- [unsecuredSavedObjectsClient](client._internal_namespace.PatchCasesArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### cases - -• **cases**: [`PatchCase`](client._internal_namespace.PatchCase.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:106](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L106) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PersistableState.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PersistableState.md deleted file mode 100644 index 7300cc96a8fd2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PersistableState.md +++ /dev/null @@ -1,133 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PersistableState - -# Interface: PersistableState - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PersistableState - -Persistable state interface can be implemented by something that persists -(stores) state, for example, in a saved object. Once implemented that thing -will gain ability to "extract" and "inject" saved object references, which -are necessary for various saved object tasks, such as export. It will also be -able to do state migrations across Kibana versions, if the shape of the state -would change over time. - -**`todo`** Maybe rename it to `PersistableStateItem`? - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `P` | extends `SerializableRecord` = `SerializableRecord` | - -## Table of contents - -### Properties - -- [migrations](client._internal_namespace.PersistableState.md#migrations) - -### Methods - -- [extract](client._internal_namespace.PersistableState.md#extract) -- [inject](client._internal_namespace.PersistableState.md#inject) -- [telemetry](client._internal_namespace.PersistableState.md#telemetry) - -## Properties - -### migrations - -• **migrations**: [`MigrateFunctionsObject`](../modules/client._internal_namespace.md#migratefunctionsobject) \| [`GetMigrationFunctionObjectFn`](../modules/client._internal_namespace.md#getmigrationfunctionobjectfn) - -A list of migration functions, which migrate the persistable state -serializable object to the next version. Migration functions should are -keyed by the Kibana version using semver, where the version indicates to -which version the state will be migrated to. - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:75 - -## Methods - -### extract - -▸ **extract**(`state`): `Object` - -A function which receives state and should return the state with references -extracted and an array of the extracted references. The default case could -simply return the same state with an empty array of references. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `state` | `P` | The persistable state serializable state object. | - -#### Returns - -`Object` - -Persistable state object with references extracted and a list of - references. - -| Name | Type | -| :------ | :------ | -| `references` | [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] | -| `state` | `P` | - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:65 - -___ - -### inject - -▸ **inject**(`state`, `references`): `P` - -A function which receives state and a list of references and should return -back the state with references injected. The default is an identity -function. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `state` | `P` | The persistable state serializable state object. | -| `references` | [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] | List of saved object references. | - -#### Returns - -`P` - -Persistable state object with references injected. - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:55 - -___ - -### telemetry - -▸ **telemetry**(`state`, `stats`): `Record`<`string`, `any`\> - -Function which reports telemetry information. This function is essentially -a "reducer" - it receives the existing "stats" object and returns an -updated version of the "stats" object. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `state` | `P` | The persistable state serializable state object. | -| `stats` | `Record`<`string`, `any`\> | Stats object containing the stats which were already collected. This `stats` object shall not be mutated in-line. | - -#### Returns - -`Record`<`string`, `any`\> - -A new stats object augmented with new telemetry information. - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:45 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PluginStartContract.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PluginStartContract.md deleted file mode 100644 index 3ded8d5c50642..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PluginStartContract.md +++ /dev/null @@ -1,40 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PluginStartContract - -# Interface: PluginStartContract - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PluginStartContract - -## Table of contents - -### Methods - -- [getElasticsearchFeatures](client._internal_namespace.PluginStartContract.md#getelasticsearchfeatures) -- [getKibanaFeatures](client._internal_namespace.PluginStartContract.md#getkibanafeatures) - -## Methods - -### getElasticsearchFeatures - -▸ **getElasticsearchFeatures**(): [`ElasticsearchFeature`](../classes/client._internal_namespace.ElasticsearchFeature.md)[] - -#### Returns - -[`ElasticsearchFeature`](../classes/client._internal_namespace.ElasticsearchFeature.md)[] - -#### Defined in - -x-pack/plugins/features/target/types/server/plugin.d.ts:28 - -___ - -### getKibanaFeatures - -▸ **getKibanaFeatures**(): [`KibanaFeature`](../classes/client._internal_namespace.KibanaFeature.md)[] - -#### Returns - -[`KibanaFeature`](../classes/client._internal_namespace.KibanaFeature.md)[] - -#### Defined in - -x-pack/plugins/features/target/types/server/plugin.d.ts:29 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseArgs.md deleted file mode 100644 index 03690ece438b7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseArgs.md +++ /dev/null @@ -1,53 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PostCaseArgs - -# Interface: PostCaseArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PostCaseArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`PostCaseArgs`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.PostCaseArgs.md#attributes) -- [id](client._internal_namespace.PostCaseArgs.md#id) -- [unsecuredSavedObjectsClient](client._internal_namespace.PostCaseArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### attributes - -• **attributes**: { `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:93](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L93) - -___ - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:94](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L94) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseConfigureArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseConfigureArgs.md deleted file mode 100644 index b10f3e3ae51ba..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseConfigureArgs.md +++ /dev/null @@ -1,53 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PostCaseConfigureArgs - -# Interface: PostCaseConfigureArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PostCaseConfigureArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs.md) - - ↳ **`PostCaseConfigureArgs`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.PostCaseConfigureArgs.md#attributes) -- [id](client._internal_namespace.PostCaseConfigureArgs.md#id) -- [unsecuredSavedObjectsClient](client._internal_namespace.PostCaseConfigureArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### attributes - -• **attributes**: { `closure_type`: ``"close-by-user"`` \| ``"close-by-pushing"`` = ClosureTypeRT; `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt } & { `owner`: `string` = rt.string } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:41](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L41) - -___ - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:42](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L42) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/configure/index.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/configure/index.ts#L30) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseUserActionArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseUserActionArgs.md deleted file mode 100644 index 5b890d18106ea..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostCaseUserActionArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PostCaseUserActionArgs - -# Interface: PostCaseUserActionArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PostCaseUserActionArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-1.md) - - ↳ **`PostCaseUserActionArgs`** - -## Table of contents - -### Properties - -- [actions](client._internal_namespace.PostCaseUserActionArgs.md#actions) -- [unsecuredSavedObjectsClient](client._internal_namespace.PostCaseUserActionArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### actions - -• **actions**: [`BuilderReturnValue`](client._internal_namespace.BuilderReturnValue.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:67](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L67) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-1.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-1.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/index.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/index.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostConnectorMappingsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostConnectorMappingsArgs.md deleted file mode 100644 index d4cc3e71a0ba8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PostConnectorMappingsArgs.md +++ /dev/null @@ -1,60 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PostConnectorMappingsArgs - -# Interface: PostConnectorMappingsArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PostConnectorMappingsArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-2.md) - - ↳ **`PostConnectorMappingsArgs`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.PostConnectorMappingsArgs.md#attributes) -- [references](client._internal_namespace.PostConnectorMappingsArgs.md#references) -- [unsecuredSavedObjectsClient](client._internal_namespace.PostConnectorMappingsArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### attributes - -• **attributes**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `mappings` | { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] | -| `owner` | `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:22](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L22) - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:23](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L23) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-2.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-2.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L15) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PreConfiguredAction.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PreConfiguredAction.md deleted file mode 100644 index d5bd141afd372..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PreConfiguredAction.md +++ /dev/null @@ -1,124 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PreConfiguredAction - -# Interface: PreConfiguredAction - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PreConfiguredAction - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Config` | extends [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) = [`ActionTypeConfig`](../modules/client._internal_namespace.md#actiontypeconfig) | -| `Secrets` | extends [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) = [`ActionTypeSecrets`](../modules/client._internal_namespace.md#actiontypesecrets) | - -## Hierarchy - -- [`ActionResult`](client._internal_namespace.ActionResult.md)<`Config`\> - - ↳ **`PreConfiguredAction`** - -## Table of contents - -### Properties - -- [actionTypeId](client._internal_namespace.PreConfiguredAction.md#actiontypeid) -- [config](client._internal_namespace.PreConfiguredAction.md#config) -- [id](client._internal_namespace.PreConfiguredAction.md#id) -- [isMissingSecrets](client._internal_namespace.PreConfiguredAction.md#ismissingsecrets) -- [isPreconfigured](client._internal_namespace.PreConfiguredAction.md#ispreconfigured) -- [name](client._internal_namespace.PreConfiguredAction.md#name) -- [secrets](client._internal_namespace.PreConfiguredAction.md#secrets) - -## Properties - -### actionTypeId - -• **actionTypeId**: `string` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[actionTypeId](client._internal_namespace.ActionResult.md#actiontypeid) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:50 - -___ - -### config - -• `Optional` **config**: `Config` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[config](client._internal_namespace.ActionResult.md#config) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:53 - -___ - -### id - -• **id**: `string` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[id](client._internal_namespace.ActionResult.md#id) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:49 - -___ - -### isMissingSecrets - -• `Optional` **isMissingSecrets**: `boolean` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[isMissingSecrets](client._internal_namespace.ActionResult.md#ismissingsecrets) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:52 - -___ - -### isPreconfigured - -• **isPreconfigured**: `boolean` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[isPreconfigured](client._internal_namespace.ActionResult.md#ispreconfigured) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:54 - -___ - -### name - -• **name**: `string` - -#### Inherited from - -[ActionResult](client._internal_namespace.ActionResult.md).[name](client._internal_namespace.ActionResult.md#name) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:51 - -___ - -### secrets - -• **secrets**: `Secrets` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:57 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ProxySettings.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ProxySettings.md deleted file mode 100644 index e1816a9f513cd..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ProxySettings.md +++ /dev/null @@ -1,65 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ProxySettings - -# Interface: ProxySettings - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ProxySettings - -## Table of contents - -### Properties - -- [proxyBypassHosts](client._internal_namespace.ProxySettings.md#proxybypasshosts) -- [proxyHeaders](client._internal_namespace.ProxySettings.md#proxyheaders) -- [proxyOnlyHosts](client._internal_namespace.ProxySettings.md#proxyonlyhosts) -- [proxySSLSettings](client._internal_namespace.ProxySettings.md#proxysslsettings) -- [proxyUrl](client._internal_namespace.ProxySettings.md#proxyurl) - -## Properties - -### proxyBypassHosts - -• **proxyBypassHosts**: `undefined` \| `Set`<`string`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:110 - -___ - -### proxyHeaders - -• `Optional` **proxyHeaders**: `Record`<`string`, `string`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:112 - -___ - -### proxyOnlyHosts - -• **proxyOnlyHosts**: `undefined` \| `Set`<`string`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:111 - -___ - -### proxySSLSettings - -• **proxySSLSettings**: [`SSLSettings`](client._internal_namespace.SSLSettings.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:113 - -___ - -### proxyUrl - -• **proxyUrl**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:109 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicense.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicense.md deleted file mode 100644 index 63c54f6be23cd..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicense.md +++ /dev/null @@ -1,80 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PublicLicense - -# Interface: PublicLicense - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PublicLicense - -Subset of license data considered as non-sensitive information. -Can be passed to the client. - -## Table of contents - -### Properties - -- [expiryDateInMillis](client._internal_namespace.PublicLicense.md#expirydateinmillis) -- [mode](client._internal_namespace.PublicLicense.md#mode) -- [status](client._internal_namespace.PublicLicense.md#status) -- [type](client._internal_namespace.PublicLicense.md#type) -- [uid](client._internal_namespace.PublicLicense.md#uid) - -## Properties - -### expiryDateInMillis - -• **expiryDateInMillis**: `number` - -Unix epoch of the expiration date of the license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:36 - -___ - -### mode - -• **mode**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -The license type, being usually one of basic, standard, gold, platinum, or trial. - -**`deprecated`** use 'type' instead - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:45 - -___ - -### status - -• **status**: [`LicenseStatus`](../modules/client._internal_namespace.md#licensestatus) - -The validity status of the license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:32 - -___ - -### type - -• **type**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -The license type, being usually one of basic, standard, gold, platinum, or trial. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:40 - -___ - -### uid - -• **uid**: `string` - -UID for license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:28 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicenseJSON.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicenseJSON.md deleted file mode 100644 index 895a3654baaf2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PublicLicenseJSON.md +++ /dev/null @@ -1,46 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PublicLicenseJSON - -# Interface: PublicLicenseJSON - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PublicLicenseJSON - -Subset of license & features data considered as non-sensitive information. -Structured as json to be passed to the client. - -## Table of contents - -### Properties - -- [features](client._internal_namespace.PublicLicenseJSON.md#features) -- [license](client._internal_namespace.PublicLicenseJSON.md#license) -- [signature](client._internal_namespace.PublicLicenseJSON.md#signature) - -## Properties - -### features - -• `Optional` **features**: [`PublicFeatures`](../modules/client._internal_namespace.md#publicfeatures) - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:59 - -___ - -### license - -• `Optional` **license**: [`PublicLicense`](client._internal_namespace.PublicLicense.md) - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:58 - -___ - -### signature - -• **signature**: `string` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:60 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PushedArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PushedArgs.md deleted file mode 100644 index 0637bcb1cb21f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.PushedArgs.md +++ /dev/null @@ -1,40 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / PushedArgs - -# Interface: PushedArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).PushedArgs - -## Table of contents - -### Properties - -- [pushed\_at](client._internal_namespace.PushedArgs.md#pushed_at) -- [pushed\_by](client._internal_namespace.PushedArgs.md#pushed_by) - -## Properties - -### pushed\_at - -• **pushed\_at**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:64](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L64) - -___ - -### pushed\_by - -• **pushed\_by**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:65](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L65) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Referencable.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Referencable.md deleted file mode 100644 index b8914a27eb524..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Referencable.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Referencable - -# Interface: Referencable - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Referencable - -## Table of contents - -### Properties - -- [references](client._internal_namespace.Referencable.md#references) - -## Properties - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:40 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ReservedKibanaPrivilege.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ReservedKibanaPrivilege.md deleted file mode 100644 index cfd5cc23baa8c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ReservedKibanaPrivilege.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ReservedKibanaPrivilege - -# Interface: ReservedKibanaPrivilege - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ReservedKibanaPrivilege - -## Table of contents - -### Properties - -- [id](client._internal_namespace.ReservedKibanaPrivilege.md#id) -- [privilege](client._internal_namespace.ReservedKibanaPrivilege.md#privilege) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/features/target/types/common/reserved_kibana_privilege.d.ts:3 - -___ - -### privilege - -• **privilege**: [`FeatureKibanaPrivileges`](client._internal_namespace.FeatureKibanaPrivileges.md) - -#### Defined in - -x-pack/plugins/features/target/types/common/reserved_kibana_privilege.d.ts:4 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ResponseSettings.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ResponseSettings.md deleted file mode 100644 index b5c3a7374e03d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ResponseSettings.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ResponseSettings - -# Interface: ResponseSettings - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ResponseSettings - -## Table of contents - -### Properties - -- [maxContentLength](client._internal_namespace.ResponseSettings.md#maxcontentlength) -- [timeout](client._internal_namespace.ResponseSettings.md#timeout) - -## Properties - -### maxContentLength - -• **maxContentLength**: `number` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:116 - -___ - -### timeout - -• **timeout**: `number` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:117 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptions.md deleted file mode 100644 index 447612f4b9ece..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptions.md +++ /dev/null @@ -1,100 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteConfigOptions - -# Interface: RouteConfigOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteConfigOptions - -Additional route options. - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Method` | extends [`RouteMethod`](../modules/client._internal_namespace.md#routemethod) | - -## Table of contents - -### Properties - -- [authRequired](client._internal_namespace.RouteConfigOptions.md#authrequired) -- [body](client._internal_namespace.RouteConfigOptions.md#body) -- [tags](client._internal_namespace.RouteConfigOptions.md#tags) -- [timeout](client._internal_namespace.RouteConfigOptions.md#timeout) -- [xsrfRequired](client._internal_namespace.RouteConfigOptions.md#xsrfrequired) - -## Properties - -### authRequired - -• `Optional` **authRequired**: `boolean` \| ``"optional"`` - -Defines authentication mode for a route: -- true. A user has to have valid credentials to access a resource -- false. A user can access a resource without any credentials. -- 'optional'. A user can access a resource, and will be authenticated if provided credentials are valid. - Can be useful when we grant access to a resource but want to identify a user if possible. - -Defaults to `true` if an auth mechanism is registered. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:89 - -___ - -### body - -• `Optional` **body**: `Method` extends ``"options"`` \| ``"get"`` ? `undefined` : [`RouteConfigOptionsBody`](client._internal_namespace.RouteConfigOptionsBody.md) - -Additional body options [RouteConfigOptionsBody](client._internal_namespace.RouteConfigOptionsBody.md). - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:105 - -___ - -### tags - -• `Optional` **tags**: readonly `string`[] - -Additional metadata tag strings to attach to the route. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:101 - -___ - -### timeout - -• `Optional` **timeout**: `Object` - -Defines per-route timeouts. - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `idleSocket?` | `number` | Milliseconds the socket can be idle before it's closed | -| `payload?` | `Method` extends ``"options"`` \| ``"get"`` ? `undefined` : `number` | Milliseconds to receive the payload | - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:109 - -___ - -### xsrfRequired - -• `Optional` **xsrfRequired**: `Method` extends ``"get"`` ? `never` : `boolean` - -Defines xsrf protection requirements for a route: -- true. Requires an incoming POST/PUT/DELETE request to contain `kbn-xsrf` header. -- false. Disables xsrf protection. - -Set to true by default - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:97 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptionsBody.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptionsBody.md deleted file mode 100644 index c392c1845b22a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteConfigOptionsBody.md +++ /dev/null @@ -1,89 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteConfigOptionsBody - -# Interface: RouteConfigOptionsBody - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteConfigOptionsBody - -Additional body options for a route - -## Table of contents - -### Properties - -- [accepts](client._internal_namespace.RouteConfigOptionsBody.md#accepts) -- [maxBytes](client._internal_namespace.RouteConfigOptionsBody.md#maxbytes) -- [output](client._internal_namespace.RouteConfigOptionsBody.md#output) -- [parse](client._internal_namespace.RouteConfigOptionsBody.md#parse) - -## Properties - -### accepts - -• `Optional` **accepts**: `string` \| `string`[] \| [`RouteContentType`](../modules/client._internal_namespace.md#routecontenttype)[] - -A string or an array of strings with the allowed mime types for the endpoint. Use this settings to limit the set of allowed mime types. Note that allowing additional mime types not listed -above will not enable them to be parsed, and if parse is true, the request will result in an error response. - -Default value: allows parsing of the following mime types: -* application/json -* application/*+json -* application/octet-stream -* application/x-www-form-urlencoded -* multipart/form-data -* text/* - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:45 - -___ - -### maxBytes - -• `Optional` **maxBytes**: `number` - -Limits the size of incoming payloads to the specified byte count. Allowing very large payloads may cause the server to run out of memory. - -Default value: The one set in the kibana.yml config file under the parameter `server.maxPayload`. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:51 - -___ - -### output - -• `Optional` **output**: ``"data"`` \| ``"stream"`` - -The processed payload format. The value must be one of: -* 'data' - the incoming payload is read fully into memory. If parse is true, the payload is parsed (JSON, form-decoded, multipart) based on the 'Content-Type' header. If parse is false, a raw -Buffer is returned. -* 'stream' - the incoming payload is made available via a Stream.Readable interface. If the payload is 'multipart/form-data' and parse is true, field values are presented as text while files -are provided as streams. File streams from a 'multipart/form-data' upload will also have a hapi property containing the filename and headers properties. Note that payload streams for multipart -payloads are a synthetic interface created on top of the entire multipart content loaded into memory. To avoid loading large multipart payloads into memory, set parse to false and handle the -multipart payload in the handler using a streaming parser (e.g. pez). - -Default value: 'data', unless no validation.body is provided in the route definition. In that case the default is 'stream' to alleviate memory pressure. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:63 - -___ - -### parse - -• `Optional` **parse**: `boolean` \| ``"gunzip"`` - -Determines if the incoming payload is processed or presented raw. Available values: -* true - if the request 'Content-Type' matches the allowed mime types set by allow (for the whole payload as well as parts), the payload is converted into an object when possible. If the -format is unknown, a Bad Request (400) error response is sent. Any known content encoding is decoded. -* false - the raw payload is returned unmodified. -* 'gunzip' - the raw payload is returned unmodified after any known content encoding is decoded. - -Default value: true, unless no validation.body is provided in the route definition. In that case the default is false to alleviate memory pressure. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:73 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidationResultFactory.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidationResultFactory.md deleted file mode 100644 index 4e45bca74bdee..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidationResultFactory.md +++ /dev/null @@ -1,71 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteValidationResultFactory - -# Interface: RouteValidationResultFactory - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteValidationResultFactory - -Validation result factory to be used in the custom validation function to return the valid data or validation errors - -See [RouteValidationFunction](../modules/client._internal_namespace.md#routevalidationfunction). - -## Table of contents - -### Methods - -- [badRequest](client._internal_namespace.RouteValidationResultFactory.md#badrequest) -- [ok](client._internal_namespace.RouteValidationResultFactory.md#ok) - -## Methods - -### badRequest - -▸ **badRequest**(`error`, `path?`): `Object` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `error` | `string` \| `Error` | -| `path?` | `string`[] | - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `error` | [`RouteValidationError`](../classes/client._internal_namespace.RouteValidationError.md) | - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:14 - -___ - -### ok - -▸ **ok**<`T`\>(`value`): `Object` - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `value` | `T` | - -#### Returns - -`Object` - -| Name | Type | -| :------ | :------ | -| `value` | `T` | - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:11 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorConfig.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorConfig.md deleted file mode 100644 index dcea2693b8a07..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorConfig.md +++ /dev/null @@ -1,60 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteValidatorConfig - -# Interface: RouteValidatorConfig - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteValidatorConfig - -The configuration object to the RouteValidator class. -Set `params`, `query` and/or `body` to specify the validation logic to follow for that property. - -## Type parameters - -| Name | -| :------ | -| `P` | -| `Q` | -| `B` | - -## Table of contents - -### Properties - -- [body](client._internal_namespace.RouteValidatorConfig.md#body) -- [params](client._internal_namespace.RouteValidatorConfig.md#params) -- [query](client._internal_namespace.RouteValidatorConfig.md#query) - -## Properties - -### body - -• `Optional` **body**: [`RouteValidationSpec`](../modules/client._internal_namespace.md#routevalidationspec)<`B`\> - -Validation logic for the body payload - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:79 - -___ - -### params - -• `Optional` **params**: [`RouteValidationSpec`](../modules/client._internal_namespace.md#routevalidationspec)<`P`\> - -Validation logic for the URL params - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:69 - -___ - -### query - -• `Optional` **query**: [`RouteValidationSpec`](../modules/client._internal_namespace.md#routevalidationspec)<`Q`\> - -Validation logic for the Query params - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:74 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorOptions.md deleted file mode 100644 index 2652ad7475e82..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RouteValidatorOptions.md +++ /dev/null @@ -1,33 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RouteValidatorOptions - -# Interface: RouteValidatorOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RouteValidatorOptions - -Additional options for the RouteValidator class to modify its default behaviour. - -## Table of contents - -### Properties - -- [unsafe](client._internal_namespace.RouteValidatorOptions.md#unsafe) - -## Properties - -### unsafe - -• `Optional` **unsafe**: `Object` - -Set the `unsafe` config to avoid running some additional internal *safe* validations on top of your custom validation - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `body?` | `boolean` | -| `params?` | `boolean` | -| `query?` | `boolean` | - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:91 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunContext.md deleted file mode 100644 index 01eec0d08684b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunContext.md +++ /dev/null @@ -1,25 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RunContext - -# Interface: RunContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RunContext - -The run context is passed into a task's run function as its sole argument. - -## Table of contents - -### Properties - -- [taskInstance](client._internal_namespace.RunContext.md#taskinstance) - -## Properties - -### taskInstance - -• **taskInstance**: [`ConcreteTaskInstance`](client._internal_namespace.ConcreteTaskInstance.md) - -The document describing the task instance, its params, state, id, etc. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:23 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunNowResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunNowResult.md deleted file mode 100644 index d5a584a4b99c5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.RunNowResult.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / RunNowResult - -# Interface: RunNowResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).RunNowResult - -## Table of contents - -### Properties - -- [id](client._internal_namespace.RunNowResult.md#id) -- [state](client._internal_namespace.RunNowResult.md#state) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_scheduling.d.ts:18 - -___ - -### state - -• `Optional` **state**: `Record`<`string`, `any`\> - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_scheduling.d.ts:19 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SSLSettings.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SSLSettings.md deleted file mode 100644 index ce1f83e937876..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SSLSettings.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SSLSettings - -# Interface: SSLSettings - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SSLSettings - -## Table of contents - -### Properties - -- [verificationMode](client._internal_namespace.SSLSettings.md#verificationmode) - -## Properties - -### verificationMode - -• `Optional` **verificationMode**: ``"none"`` \| ``"certificate"`` \| ``"full"`` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:120 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObject.md deleted file mode 100644 index 7a2ab41e7cf9c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObject.md +++ /dev/null @@ -1,167 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObject - -# Interface: SavedObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObject - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Hierarchy - -- **`SavedObject`** - - ↳ [`SavedObjectsFindResult`](client._internal_namespace.SavedObjectsFindResult.md) - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.SavedObject.md#attributes) -- [coreMigrationVersion](client._internal_namespace.SavedObject.md#coremigrationversion) -- [error](client._internal_namespace.SavedObject.md#error) -- [id](client._internal_namespace.SavedObject.md#id) -- [migrationVersion](client._internal_namespace.SavedObject.md#migrationversion) -- [namespaces](client._internal_namespace.SavedObject.md#namespaces) -- [originId](client._internal_namespace.SavedObject.md#originid) -- [references](client._internal_namespace.SavedObject.md#references) -- [type](client._internal_namespace.SavedObject.md#type) -- [updated\_at](client._internal_namespace.SavedObject.md#updated_at) -- [version](client._internal_namespace.SavedObject.md#version) - -## Properties - -### attributes - -• **attributes**: `T` - -{@inheritdoc SavedObjectAttributes} - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:61 - -___ - -### coreMigrationVersion - -• `Optional` **coreMigrationVersion**: `string` - -A semver value that is used when upgrading objects between Kibana versions. - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:67 - -___ - -### error - -• `Optional` **error**: [`SavedObjectError`](client._internal_namespace.SavedObjectError.md) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:59 - -___ - -### id - -• **id**: `string` - -The ID of this Saved Object, guaranteed to be unique for all objects of the same `type` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:52 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -{@inheritdoc SavedObjectsMigrationVersion} - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:65 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -Space(s) that this saved object exists in. This attribute is not used for "global" saved object types which are registered with -`namespaceType: 'agnostic'`. - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:72 - -___ - -### originId - -• `Optional` **originId**: `string` - -The ID of the saved object this originated from. This is set if this object's `id` was regenerated; that can happen during migration -from a legacy single-namespace type, or during import. It is only set during migration or create operations. This is used during import -to ensure that ID regeneration is deterministic, so saved objects will be overwritten if they are imported multiple times into a given -space. - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:79 - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -{@inheritdoc SavedObjectReference} - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:63 - -___ - -### type - -• **type**: `string` - -The type of Saved Object. Each plugin can define it's own custom Saved Object types. - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:54 - -___ - -### updated\_at - -• `Optional` **updated\_at**: `string` - -Timestamp of the last time this document had been updated. - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:58 - -___ - -### version - -• `Optional` **version**: `string` - -An opaque version number which changes on each successful write operation. Can be used for implementing optimistic concurrency control. - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:56 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectAttributes.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectAttributes.md deleted file mode 100644 index 2f260171ce47a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectAttributes.md +++ /dev/null @@ -1,20 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectAttributes - -# Interface: SavedObjectAttributes - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectAttributes - -The data for a Saved Object is stored as an object in the `attributes` -property. - -## Hierarchy - -- **`SavedObjectAttributes`** - - ↳ [`ActionUpdate`](client._internal_namespace.ActionUpdate.md) - - ↳ [`ConnectorToken`](client._internal_namespace.ConnectorToken.md) - -## Indexable - -▪ [key: `string`]: [`SavedObjectAttribute`](../modules/client._internal_namespace.md#savedobjectattribute) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectDoc.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectDoc.md deleted file mode 100644 index 50478fb7b3cf2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectDoc.md +++ /dev/null @@ -1,128 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectDoc - -# Interface: SavedObjectDoc - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectDoc - -Saved Object base document - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.SavedObjectDoc.md#attributes) -- [coreMigrationVersion](client._internal_namespace.SavedObjectDoc.md#coremigrationversion) -- [id](client._internal_namespace.SavedObjectDoc.md#id) -- [migrationVersion](client._internal_namespace.SavedObjectDoc.md#migrationversion) -- [namespace](client._internal_namespace.SavedObjectDoc.md#namespace) -- [namespaces](client._internal_namespace.SavedObjectDoc.md#namespaces) -- [originId](client._internal_namespace.SavedObjectDoc.md#originid) -- [type](client._internal_namespace.SavedObjectDoc.md#type) -- [updated\_at](client._internal_namespace.SavedObjectDoc.md#updated_at) -- [version](client._internal_namespace.SavedObjectDoc.md#version) - -## Properties - -### attributes - -• **attributes**: `T` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:28 - -___ - -### coreMigrationVersion - -• `Optional` **coreMigrationVersion**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:34 - -___ - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:29 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:33 - -___ - -### namespace - -• `Optional` **namespace**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:31 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:32 - -___ - -### originId - -• `Optional` **originId**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:37 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:30 - -___ - -### updated\_at - -• `Optional` **updated\_at**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:36 - -___ - -### version - -• `Optional` **version**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:35 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectError.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectError.md deleted file mode 100644 index 8b93bb038d5fa..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectError.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectError - -# Interface: SavedObjectError - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectError - -## Table of contents - -### Properties - -- [error](client._internal_namespace.SavedObjectError.md#error) -- [message](client._internal_namespace.SavedObjectError.md#message) -- [metadata](client._internal_namespace.SavedObjectError.md#metadata) -- [statusCode](client._internal_namespace.SavedObjectError.md#statuscode) - -## Properties - -### error - -• **error**: `string` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:82 - -___ - -### message - -• **message**: `string` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:83 - -___ - -### metadata - -• `Optional` **metadata**: `Record`<`string`, `unknown`\> - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:85 - -___ - -### statusCode - -• **statusCode**: `number` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:84 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationContext.md deleted file mode 100644 index b16816fc5ec40..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationContext.md +++ /dev/null @@ -1,64 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectMigrationContext - -# Interface: SavedObjectMigrationContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectMigrationContext - -Migration context provided when invoking a [migration handler](../modules/client._internal_namespace.md#savedobjectmigrationfn) - -## Table of contents - -### Properties - -- [convertToMultiNamespaceTypeVersion](client._internal_namespace.SavedObjectMigrationContext.md#converttomultinamespacetypeversion) -- [isSingleNamespaceType](client._internal_namespace.SavedObjectMigrationContext.md#issinglenamespacetype) -- [log](client._internal_namespace.SavedObjectMigrationContext.md#log) -- [migrationVersion](client._internal_namespace.SavedObjectMigrationContext.md#migrationversion) - -## Properties - -### convertToMultiNamespaceTypeVersion - -• `Optional` `Readonly` **convertToMultiNamespaceTypeVersion**: `string` - -The version in which this object type is being converted to a multi-namespace type - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/types.d.ts:57 - -___ - -### isSingleNamespaceType - -• `Readonly` **isSingleNamespaceType**: `boolean` - -Whether this is a single-namespace type or not - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/types.d.ts:61 - -___ - -### log - -• `Readonly` **log**: [`SavedObjectsMigrationLogger`](client._internal_namespace.SavedObjectsMigrationLogger.md) - -logger instance to be used by the migration handler - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/types.d.ts:49 - -___ - -### migrationVersion - -• `Readonly` **migrationVersion**: `string` - -The migration version that this migration function is defined for - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/types.d.ts:53 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationMap.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationMap.md deleted file mode 100644 index 2632e6259ff5b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectMigrationMap.md +++ /dev/null @@ -1,23 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectMigrationMap - -# Interface: SavedObjectMigrationMap - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectMigrationMap - -A map of [migration functions](../modules/client._internal_namespace.md#savedobjectmigrationfn) to be used for a given type. -The map's keys must be valid semver versions, and they cannot exceed the current Kibana version. - -For a given document, only migrations with a higher version number than that of the document will be applied. -Migrations are executed in order, starting from the lowest version and ending with the highest one. - -**`example`** -```typescript -const migrationsMap: SavedObjectMigrationMap = { - '1.0.0': migrateToV1, - '2.1.0': migrateToV21 -} -``` - -## Indexable - -▪ [version: `string`]: [`SavedObjectMigrationFn`](../modules/client._internal_namespace.md#savedobjectmigrationfn)<`any`, `any`\> diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReference.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReference.md deleted file mode 100644 index 2c3f8ac1c7cc0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReference.md +++ /dev/null @@ -1,45 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectReference - -# Interface: SavedObjectReference - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectReference - -A reference to another saved object. - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectReference.md#id) -- [name](client._internal_namespace.SavedObjectReference.md#name) -- [type](client._internal_namespace.SavedObjectReference.md#type) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:30 - -___ - -### name - -• **name**: `string` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:28 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:29 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReferenceWithContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReferenceWithContext.md deleted file mode 100644 index 511e6aec3d9b6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectReferenceWithContext.md +++ /dev/null @@ -1,91 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectReferenceWithContext - -# Interface: SavedObjectReferenceWithContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectReferenceWithContext - -A returned input object or one of its references, with additional context. - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectReferenceWithContext.md#id) -- [inboundReferences](client._internal_namespace.SavedObjectReferenceWithContext.md#inboundreferences) -- [isMissing](client._internal_namespace.SavedObjectReferenceWithContext.md#ismissing) -- [spaces](client._internal_namespace.SavedObjectReferenceWithContext.md#spaces) -- [spacesWithMatchingAliases](client._internal_namespace.SavedObjectReferenceWithContext.md#spaceswithmatchingaliases) -- [type](client._internal_namespace.SavedObjectReferenceWithContext.md#type) - -## Properties - -### id - -• **id**: `string` - -The ID of the referenced object - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:45 - -___ - -### inboundReferences - -• **inboundReferences**: { `id`: `string` ; `name`: `string` ; `type`: `string` }[] - -References to this object; note that this does not contain _all inbound references everywhere for this object_, it only contains -inbound references for the scope of this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:52 - -___ - -### isMissing - -• `Optional` **isMissing**: `boolean` - -Whether or not this object or reference is missing - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:61 - -___ - -### spaces - -• **spaces**: `string`[] - -The space(s) that the referenced object exists in - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:47 - -___ - -### spacesWithMatchingAliases - -• `Optional` **spacesWithMatchingAliases**: `string`[] - -The space(s) that legacy URL aliases matching this type/id exist in - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:63 - -___ - -### type - -• **type**: `string` - -The type of the referenced object - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:43 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBaseOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBaseOptions.md deleted file mode 100644 index afce23c52c88d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBaseOptions.md +++ /dev/null @@ -1,47 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBaseOptions - -# Interface: SavedObjectsBaseOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBaseOptions - -## Hierarchy - -- **`SavedObjectsBaseOptions`** - - ↳ [`SavedObjectsRemoveReferencesToResponse`](client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md) - - ↳ [`SavedObjectsCreateOptions`](client._internal_namespace.SavedObjectsCreateOptions.md) - - ↳ [`SavedObjectsDeleteOptions`](client._internal_namespace.SavedObjectsDeleteOptions.md) - - ↳ [`SavedObjectsUpdateOptions`](client._internal_namespace.SavedObjectsUpdateOptions.md) - - ↳ [`SavedObjectsBulkUpdateOptions`](client._internal_namespace.SavedObjectsBulkUpdateOptions.md) - - ↳ [`SavedObjectsRemoveReferencesToOptions`](client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md) - - ↳ [`SavedObjectsCollectMultiNamespaceReferencesOptions`](client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md) - - ↳ [`SavedObjectsUpdateObjectsSpacesOptions`](client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md) - - ↳ [`SavedObjectsDeleteByNamespaceOptions`](client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md) - - ↳ [`SavedObjectsIncrementCounterOptions`](client._internal_namespace.SavedObjectsIncrementCounterOptions.md) - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md deleted file mode 100644 index 1a5bbd79801ba..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md +++ /dev/null @@ -1,136 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkCreateObject - -# Interface: SavedObjectsBulkCreateObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkCreateObject - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.SavedObjectsBulkCreateObject.md#attributes) -- [coreMigrationVersion](client._internal_namespace.SavedObjectsBulkCreateObject.md#coremigrationversion) -- [id](client._internal_namespace.SavedObjectsBulkCreateObject.md#id) -- [initialNamespaces](client._internal_namespace.SavedObjectsBulkCreateObject.md#initialnamespaces) -- [migrationVersion](client._internal_namespace.SavedObjectsBulkCreateObject.md#migrationversion) -- [originId](client._internal_namespace.SavedObjectsBulkCreateObject.md#originid) -- [references](client._internal_namespace.SavedObjectsBulkCreateObject.md#references) -- [type](client._internal_namespace.SavedObjectsBulkCreateObject.md#type) -- [version](client._internal_namespace.SavedObjectsBulkCreateObject.md#version) - -## Properties - -### attributes - -• **attributes**: `T` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:54 - -___ - -### coreMigrationVersion - -• `Optional` **coreMigrationVersion**: `string` - -A semver value that is used when upgrading objects between Kibana versions. If undefined, this will be automatically set to the current -Kibana version when the object is created. If this is set to a non-semver value, or it is set to a semver value greater than the -current Kibana version, it will result in an error. - -**`remarks`** -Do not attempt to set this manually. It should only be used if you retrieved an existing object that had the `coreMigrationVersion` -field set and you want to create it again. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:68 - -___ - -### id - -• `Optional` **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:52 - -___ - -### initialNamespaces - -• `Optional` **initialNamespaces**: `string`[] - -Optional initial namespaces for the object to be created in. If this is defined, it will supersede the namespace ID that is in -[SavedObjectsCreateOptions](client._internal_namespace.SavedObjectsCreateOptions.md). - -* For shareable object types (registered with `namespaceType: 'multiple'`): this option can be used to specify one or more spaces, - including the "All spaces" identifier (`'*'`). -* For isolated object types (registered with `namespaceType: 'single'` or `namespaceType: 'multiple-isolated'`): this option can only - be used to specify a single space, and the "All spaces" identifier (`'*'`) is not allowed. -* For global object types (registered with `namespaceType: 'agnostic'`): this option cannot be used. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:81 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -{@inheritDoc SavedObjectsMigrationVersion} - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:58 - -___ - -### originId - -• `Optional` **originId**: `string` - -Optional ID of the original saved object, if this object's `id` was regenerated - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:70 - -___ - -### references - -• `Optional` **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:56 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:53 - -___ - -### version - -• `Optional` **version**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:55 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md deleted file mode 100644 index 3b3dd0ecbc28b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md +++ /dev/null @@ -1,65 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkGetObject - -# Interface: SavedObjectsBulkGetObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkGetObject - -## Table of contents - -### Properties - -- [fields](client._internal_namespace.SavedObjectsBulkGetObject.md#fields) -- [id](client._internal_namespace.SavedObjectsBulkGetObject.md#id) -- [namespaces](client._internal_namespace.SavedObjectsBulkGetObject.md#namespaces) -- [type](client._internal_namespace.SavedObjectsBulkGetObject.md#type) - -## Properties - -### fields - -• `Optional` **fields**: `string`[] - -SavedObject fields to include in the response - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:239 - -___ - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:236 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -Optional namespace(s) for the object to be retrieved in. If this is defined, it will supersede the namespace ID that is in the -top-level options. - -* For shareable object types (registered with `namespaceType: 'multiple'`): this option can be used to specify one or more spaces, - including the "All spaces" identifier (`'*'`). -* For isolated object types (registered with `namespaceType: 'single'` or `namespaceType: 'multiple-isolated'`): this option can only - be used to specify a single space, and the "All spaces" identifier (`'*'`) is not allowed. -* For global object types (registered with `namespaceType: 'agnostic'`): this option cannot be used. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:250 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:237 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md deleted file mode 100644 index 56105f08768ae..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkResolveObject - -# Interface: SavedObjectsBulkResolveObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkResolveObject - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsBulkResolveObject.md#id) -- [type](client._internal_namespace.SavedObjectsBulkResolveObject.md#type) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:279 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:280 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md deleted file mode 100644 index 4f7fc1463bb4b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkResolveResponse - -# Interface: SavedObjectsBulkResolveResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkResolveResponse - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Table of contents - -### Properties - -- [resolved\_objects](client._internal_namespace.SavedObjectsBulkResolveResponse.md#resolved_objects) - -## Properties - -### resolved\_objects - -• **resolved\_objects**: [`SavedObjectsResolveResponse`](client._internal_namespace.SavedObjectsResolveResponse.md)<`T`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:287 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResponse.md deleted file mode 100644 index 76af857d6f612..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkResponse.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkResponse - -# Interface: SavedObjectsBulkResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkResponse - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Table of contents - -### Properties - -- [saved\_objects](client._internal_namespace.SavedObjectsBulkResponse.md#saved_objects) - -## Properties - -### saved\_objects - -• **saved\_objects**: [`SavedObject`](client._internal_namespace.SavedObject.md)<`T`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:107 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md deleted file mode 100644 index f0ae9c5aa503f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md +++ /dev/null @@ -1,111 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkUpdateObject - -# Interface: SavedObjectsBulkUpdateObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkUpdateObject - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Hierarchy - -- `Pick`<[`SavedObjectsUpdateOptions`](client._internal_namespace.SavedObjectsUpdateOptions.md)<`T`\>, ``"version"`` \| ``"references"``\> - - ↳ **`SavedObjectsBulkUpdateObject`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.SavedObjectsBulkUpdateObject.md#attributes) -- [id](client._internal_namespace.SavedObjectsBulkUpdateObject.md#id) -- [namespace](client._internal_namespace.SavedObjectsBulkUpdateObject.md#namespace) -- [references](client._internal_namespace.SavedObjectsBulkUpdateObject.md#references) -- [type](client._internal_namespace.SavedObjectsBulkUpdateObject.md#type) -- [version](client._internal_namespace.SavedObjectsBulkUpdateObject.md#version) - -## Properties - -### attributes - -• **attributes**: `Partial`<`T`\> - -{@inheritdoc SavedObjectAttributes} - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:93 - -___ - -### id - -• **id**: `string` - -The ID of this Saved Object, guaranteed to be unique for all objects of the same `type` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:89 - -___ - -### namespace - -• `Optional` **namespace**: `string` - -Optional namespace string to use when searching for this object. If this is defined, it will supersede the namespace ID that is in -[SavedObjectsBulkUpdateOptions](client._internal_namespace.SavedObjectsBulkUpdateOptions.md). - -Note: the default namespace's string representation is `'default'`, and its ID representation is `undefined`. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:100 - -___ - -### references - -• `Optional` **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -{@inheritdoc SavedObjectReference} - -#### Inherited from - -Pick.references - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:191 - -___ - -### type - -• **type**: `string` - -The type of this Saved Object. Each plugin can define it's own custom Saved Object types. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:91 - -___ - -### version - -• `Optional` **version**: `string` - -An opaque version number which changes on each successful write operation. Can be used for implementing optimistic concurrency control. - -#### Inherited from - -Pick.version - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:189 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md deleted file mode 100644 index 4de3a8eefdb02..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md +++ /dev/null @@ -1,46 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkUpdateOptions - -# Interface: SavedObjectsBulkUpdateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkUpdateOptions - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsBulkUpdateOptions`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsBulkUpdateOptions.md#namespace) -- [refresh](client._internal_namespace.SavedObjectsBulkUpdateOptions.md#refresh) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### refresh - -• `Optional` **refresh**: [`MutatingOperationRefreshSetting`](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -The Elasticsearch Refresh setting for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:219 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md deleted file mode 100644 index 93fb3c3f3a3b2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsBulkUpdateResponse - -# Interface: SavedObjectsBulkUpdateResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsBulkUpdateResponse - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Table of contents - -### Properties - -- [saved\_objects](client._internal_namespace.SavedObjectsBulkUpdateResponse.md#saved_objects) - -## Properties - -### saved\_objects - -• **saved\_objects**: [`SavedObjectsUpdateResponse`](client._internal_namespace.SavedObjectsUpdateResponse.md)<`T`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:264 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md deleted file mode 100644 index 7b8a8b1b6982f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCheckConflictsObject - -# Interface: SavedObjectsCheckConflictsObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCheckConflictsObject - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsCheckConflictsObject.md#id) -- [type](client._internal_namespace.SavedObjectsCheckConflictsObject.md#type) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:169 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:170 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md deleted file mode 100644 index d43f929a18fed..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCheckConflictsResponse - -# Interface: SavedObjectsCheckConflictsResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCheckConflictsResponse - -## Table of contents - -### Properties - -- [errors](client._internal_namespace.SavedObjectsCheckConflictsResponse.md#errors) - -## Properties - -### errors - -• **errors**: { `error`: [`SavedObjectError`](client._internal_namespace.SavedObjectError.md) ; `id`: `string` ; `type`: `string` }[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:177 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md deleted file mode 100644 index acf9af85bdc20..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md +++ /dev/null @@ -1,37 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsClosePointInTimeResponse - -# Interface: SavedObjectsClosePointInTimeResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsClosePointInTimeResponse - -## Table of contents - -### Properties - -- [num\_freed](client._internal_namespace.SavedObjectsClosePointInTimeResponse.md#num_freed) -- [succeeded](client._internal_namespace.SavedObjectsClosePointInTimeResponse.md#succeeded) - -## Properties - -### num\_freed - -• **num\_freed**: `number` - -The number of search contexts that have been successfully closed. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:360 - -___ - -### succeeded - -• **succeeded**: `boolean` - -If true, all search contexts associated with the PIT id are -successfully closed. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:356 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md deleted file mode 100644 index 7db1c04858eb3..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCollectMultiNamespaceReferencesObject - -# Interface: SavedObjectsCollectMultiNamespaceReferencesObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCollectMultiNamespaceReferencesObject - -An object to collect references for. It must be a multi-namespace type (in other words, the object type must be registered with the -`namespaceType: 'multiple'` or `namespaceType: 'multiple-isolated'` option). - -Note: if options.purpose is 'updateObjectsSpaces', it must be a shareable type (in other words, the object type must be registered with -the `namespaceType: 'multiple'`). - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md#id) -- [type](client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md#type) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:24 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:25 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md deleted file mode 100644 index 32ffe4158cc00..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md +++ /dev/null @@ -1,48 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCollectMultiNamespaceReferencesOptions - -# Interface: SavedObjectsCollectMultiNamespaceReferencesOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCollectMultiNamespaceReferencesOptions - -Options for collecting references. - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsCollectMultiNamespaceReferencesOptions`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md#namespace) -- [purpose](client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md#purpose) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### purpose - -• `Optional` **purpose**: ``"collectMultiNamespaceReferences"`` \| ``"updateObjectsSpaces"`` - -Optional purpose used to determine filtering and authorization checks; default is 'collectMultiNamespaceReferences' - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:34 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md deleted file mode 100644 index 768ce8c1c6094..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md +++ /dev/null @@ -1,23 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCollectMultiNamespaceReferencesResponse - -# Interface: SavedObjectsCollectMultiNamespaceReferencesResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCollectMultiNamespaceReferencesResponse - -The response when object references are collected. - -## Table of contents - -### Properties - -- [objects](client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md#objects) - -## Properties - -### objects - -• **objects**: [`SavedObjectReferenceWithContext`](client._internal_namespace.SavedObjectReferenceWithContext.md)[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/collect_multi_namespace_references.d.ts:71 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreateOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreateOptions.md deleted file mode 100644 index d2b13605808ac..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreateOptions.md +++ /dev/null @@ -1,162 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCreateOptions - -# Interface: SavedObjectsCreateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCreateOptions - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsCreateOptions`** - -## Table of contents - -### Properties - -- [coreMigrationVersion](client._internal_namespace.SavedObjectsCreateOptions.md#coremigrationversion) -- [id](client._internal_namespace.SavedObjectsCreateOptions.md#id) -- [initialNamespaces](client._internal_namespace.SavedObjectsCreateOptions.md#initialnamespaces) -- [migrationVersion](client._internal_namespace.SavedObjectsCreateOptions.md#migrationversion) -- [namespace](client._internal_namespace.SavedObjectsCreateOptions.md#namespace) -- [originId](client._internal_namespace.SavedObjectsCreateOptions.md#originid) -- [overwrite](client._internal_namespace.SavedObjectsCreateOptions.md#overwrite) -- [references](client._internal_namespace.SavedObjectsCreateOptions.md#references) -- [refresh](client._internal_namespace.SavedObjectsCreateOptions.md#refresh) -- [version](client._internal_namespace.SavedObjectsCreateOptions.md#version) - -## Properties - -### coreMigrationVersion - -• `Optional` **coreMigrationVersion**: `string` - -A semver value that is used when upgrading objects between Kibana versions. If undefined, this will be automatically set to the current -Kibana version when the object is created. If this is set to a non-semver value, or it is set to a semver value greater than the -current Kibana version, it will result in an error. - -**`remarks`** -Do not attempt to set this manually. It should only be used if you retrieved an existing object that had the `coreMigrationVersion` -field set and you want to create it again. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:29 - -___ - -### id - -• `Optional` **id**: `string` - -(not recommended) Specify an id for the document - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:10 - -___ - -### initialNamespaces - -• `Optional` **initialNamespaces**: `string`[] - -Optional initial namespaces for the object to be created in. If this is defined, it will supersede the namespace ID that is in -[SavedObjectsCreateOptions](client._internal_namespace.SavedObjectsCreateOptions.md). - -* For shareable object types (registered with `namespaceType: 'multiple'`): this option can be used to specify one or more spaces, - including the "All spaces" identifier (`'*'`). -* For isolated object types (registered with `namespaceType: 'single'` or `namespaceType: 'multiple-isolated'`): this option can only - be used to specify a single space, and the "All spaces" identifier (`'*'`) is not allowed. -* For global object types (registered with `namespaceType: 'agnostic'`): this option cannot be used. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:45 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -{@inheritDoc SavedObjectsMigrationVersion} - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:19 - -___ - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### originId - -• `Optional` **originId**: `string` - -Optional ID of the original saved object, if this object's `id` was regenerated - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:34 - -___ - -### overwrite - -• `Optional` **overwrite**: `boolean` - -Overwrite existing documents (defaults to false) - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:12 - -___ - -### references - -• `Optional` **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:30 - -___ - -### refresh - -• `Optional` **refresh**: [`MutatingOperationRefreshSetting`](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -The Elasticsearch Refresh setting for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:32 - -___ - -### version - -• `Optional` **version**: `string` - -An opaque version number which changes on each successful write operation. -Can be used in conjunction with `overwrite` for implementing optimistic concurrency control. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:17 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md deleted file mode 100644 index 3289e3cb4144f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsCreatePointInTimeFinderDependencies - -# Interface: SavedObjectsCreatePointInTimeFinderDependencies - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsCreatePointInTimeFinderDependencies - -## Table of contents - -### Properties - -- [client](client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md#client) - -## Properties - -### client - -• **client**: `Pick`<[`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract), ``"find"`` \| ``"openPointInTimeForType"`` \| ``"closePointInTime"``\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/point_in_time_finder.d.ts:12 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md deleted file mode 100644 index 17fa13e76ec5f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md +++ /dev/null @@ -1,46 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsDeleteByNamespaceOptions - -# Interface: SavedObjectsDeleteByNamespaceOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsDeleteByNamespaceOptions - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsDeleteByNamespaceOptions`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md#namespace) -- [refresh](client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md#refresh) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### refresh - -• `Optional` **refresh**: `boolean` - -The Elasticsearch supports only boolean flag for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:49 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md deleted file mode 100644 index 21bd9feec57cf..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md +++ /dev/null @@ -1,59 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsDeleteOptions - -# Interface: SavedObjectsDeleteOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsDeleteOptions - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsDeleteOptions`** - -## Table of contents - -### Properties - -- [force](client._internal_namespace.SavedObjectsDeleteOptions.md#force) -- [namespace](client._internal_namespace.SavedObjectsDeleteOptions.md#namespace) -- [refresh](client._internal_namespace.SavedObjectsDeleteOptions.md#refresh) - -## Properties - -### force - -• `Optional` **force**: `boolean` - -Force deletion of an object that exists in multiple namespaces - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:229 - -___ - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### refresh - -• `Optional` **refresh**: [`MutatingOperationRefreshSetting`](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -The Elasticsearch Refresh setting for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:227 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md deleted file mode 100644 index 2b82cecc98091..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md +++ /dev/null @@ -1,26 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsExportTransformContext - -# Interface: SavedObjectsExportTransformContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsExportTransformContext - -Context passed down to a [export transform function](../modules/client._internal_namespace.md#savedobjectsexporttransform) - -## Table of contents - -### Properties - -- [request](client._internal_namespace.SavedObjectsExportTransformContext.md#request) - -## Properties - -### request - -• **request**: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> - -The request that initiated the export request. Can be used to create scoped -services or client inside the [transformation](../modules/client._internal_namespace.md#savedobjectsexporttransform) - -#### Defined in - -src/core/target/types/server/saved_objects/export/types.d.ts:87 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptions.md deleted file mode 100644 index 1cc767734ce55..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptions.md +++ /dev/null @@ -1,270 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsFindOptions - -# Interface: SavedObjectsFindOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsFindOptions - -## Table of contents - -### Properties - -- [aggs](client._internal_namespace.SavedObjectsFindOptions.md#aggs) -- [defaultSearchOperator](client._internal_namespace.SavedObjectsFindOptions.md#defaultsearchoperator) -- [fields](client._internal_namespace.SavedObjectsFindOptions.md#fields) -- [filter](client._internal_namespace.SavedObjectsFindOptions.md#filter) -- [hasReference](client._internal_namespace.SavedObjectsFindOptions.md#hasreference) -- [hasReferenceOperator](client._internal_namespace.SavedObjectsFindOptions.md#hasreferenceoperator) -- [namespaces](client._internal_namespace.SavedObjectsFindOptions.md#namespaces) -- [page](client._internal_namespace.SavedObjectsFindOptions.md#page) -- [perPage](client._internal_namespace.SavedObjectsFindOptions.md#perpage) -- [pit](client._internal_namespace.SavedObjectsFindOptions.md#pit) -- [preference](client._internal_namespace.SavedObjectsFindOptions.md#preference) -- [rootSearchFields](client._internal_namespace.SavedObjectsFindOptions.md#rootsearchfields) -- [search](client._internal_namespace.SavedObjectsFindOptions.md#search) -- [searchAfter](client._internal_namespace.SavedObjectsFindOptions.md#searchafter) -- [searchFields](client._internal_namespace.SavedObjectsFindOptions.md#searchfields) -- [sortField](client._internal_namespace.SavedObjectsFindOptions.md#sortfield) -- [sortOrder](client._internal_namespace.SavedObjectsFindOptions.md#sortorder) -- [type](client._internal_namespace.SavedObjectsFindOptions.md#type) -- [typeToNamespacesMap](client._internal_namespace.SavedObjectsFindOptions.md#typetonamespacesmap) - -## Properties - -### aggs - -• `Optional` **aggs**: `Record`<`string`, `AggregationsAggregationContainer`\> - -A record of aggregations to perform. -The API currently only supports a limited set of metrics and bucket aggregation types. -Additional aggregation types can be contributed to Core. - -**`example`** -Aggregating on SO attribute field -```ts -const aggs = { latest_version: { max: { field: 'dashboard.attributes.version' } } }; -return client.find({ type: 'dashboard', aggs }) -``` - -**`example`** -Aggregating on SO root field -```ts -const aggs = { latest_update: { max: { field: 'dashboard.updated_at' } } }; -return client.find({ type: 'dashboard', aggs }) -``` - -**`alpha`** - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:103 - -___ - -### defaultSearchOperator - -• `Optional` **defaultSearchOperator**: ``"AND"`` \| ``"OR"`` - -The search operator to use with the provided filter. Defaults to `OR` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:80 - -___ - -### fields - -• `Optional` **fields**: `string`[] - -An array of fields to include in the results - -**`example`** -SavedObjects.find({type: 'dashboard', fields: ['attributes.name', 'attributes.location']}) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:54 - -___ - -### filter - -• `Optional` **filter**: `any` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:81 - -___ - -### hasReference - -• `Optional` **hasReference**: [`SavedObjectsFindOptionsReference`](client._internal_namespace.SavedObjectsFindOptionsReference.md) \| [`SavedObjectsFindOptionsReference`](client._internal_namespace.SavedObjectsFindOptionsReference.md)[] - -Search for documents having a reference to the specified objects. -Use `hasReferenceOperator` to specify the operator to use when searching for multiple references. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:72 - -___ - -### hasReferenceOperator - -• `Optional` **hasReferenceOperator**: ``"AND"`` \| ``"OR"`` - -The operator to use when searching by multiple references using the `hasReference` option. Defaults to `OR` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:76 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:104 - -___ - -### page - -• `Optional` **page**: `number` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:45 - -___ - -### perPage - -• `Optional` **perPage**: `number` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:46 - -___ - -### pit - -• `Optional` **pit**: [`SavedObjectsPitParams`](client._internal_namespace.SavedObjectsPitParams.md) - -Search against a specific Point In Time (PIT) that you've opened with [SavedObjectsClient.openPointInTimeForType](../classes/client._internal_namespace.SavedObjectsClient.md#openpointintimefortype). - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:118 - -___ - -### preference - -• `Optional` **preference**: `string` - -An optional ES preference value to be used for the query - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:114 - -___ - -### rootSearchFields - -• `Optional` **rootSearchFields**: `string`[] - -The fields to perform the parsed query against. Unlike the `searchFields` argument, these are expected to be root fields and will not -be modified. If used in conjunction with `searchFields`, both are concatenated together. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:67 - -___ - -### search - -• `Optional` **search**: `string` - -Search documents using the Elasticsearch Simple Query String syntax. See Elasticsearch Simple Query String `query` argument for more information - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:56 - -___ - -### searchAfter - -• `Optional` **searchAfter**: `string`[] - -Use the sort values from the previous page to retrieve the next page of results. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:62 - -___ - -### searchFields - -• `Optional` **searchFields**: `string`[] - -The fields to perform the parsed query against. See Elasticsearch Simple Query String `fields` argument for more information - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:58 - -___ - -### sortField - -• `Optional` **sortField**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:47 - -___ - -### sortOrder - -• `Optional` **sortOrder**: `SortOrder` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:48 - -___ - -### type - -• **type**: `string` \| `string`[] - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:44 - -___ - -### typeToNamespacesMap - -• `Optional` **typeToNamespacesMap**: `Map`<`string`, `undefined` \| `string`[]\> - -This map defines each type to search for, and the namespace(s) to search for the type in; this is only intended to be used by a saved -object client wrapper. -If this is defined, it supersedes the `type` and `namespaces` fields when building the Elasticsearch query. -Any types that are not included in this map will be excluded entirely. -If a type is included but its value is undefined, the operation will search for that type in the Default namespace. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:112 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptionsReference.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptionsReference.md deleted file mode 100644 index dd1f782c26b7d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindOptionsReference.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsFindOptionsReference - -# Interface: SavedObjectsFindOptionsReference - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsFindOptionsReference - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsFindOptionsReference.md#id) -- [type](client._internal_namespace.SavedObjectsFindOptionsReference.md#type) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:30 - -___ - -### type - -• **type**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:29 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResponse.md deleted file mode 100644 index 5fd16ec67e781..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResponse.md +++ /dev/null @@ -1,88 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsFindResponse - -# Interface: SavedObjectsFindResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsFindResponse - -Return type of the Saved Objects `find()` method. - -*Note*: this type is different between the Public and Server Saved Objects -clients. - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | -| `A` | `unknown` | - -## Table of contents - -### Properties - -- [aggregations](client._internal_namespace.SavedObjectsFindResponse.md#aggregations) -- [page](client._internal_namespace.SavedObjectsFindResponse.md#page) -- [per\_page](client._internal_namespace.SavedObjectsFindResponse.md#per_page) -- [pit\_id](client._internal_namespace.SavedObjectsFindResponse.md#pit_id) -- [saved\_objects](client._internal_namespace.SavedObjectsFindResponse.md#saved_objects) -- [total](client._internal_namespace.SavedObjectsFindResponse.md#total) - -## Properties - -### aggregations - -• `Optional` **aggregations**: `A` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:157 - -___ - -### page - -• **page**: `number` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:161 - -___ - -### per\_page - -• **per\_page**: `number` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:160 - -___ - -### pit\_id - -• `Optional` **pit\_id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:162 - -___ - -### saved\_objects - -• **saved\_objects**: [`SavedObjectsFindResult`](client._internal_namespace.SavedObjectsFindResult.md)<`T`\>[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:158 - -___ - -### total - -• **total**: `number` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:159 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResult.md deleted file mode 100644 index aa7578f7daaa6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsFindResult.md +++ /dev/null @@ -1,262 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsFindResult - -# Interface: SavedObjectsFindResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsFindResult - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Hierarchy - -- [`SavedObject`](client._internal_namespace.SavedObject.md)<`T`\> - - ↳ **`SavedObjectsFindResult`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.SavedObjectsFindResult.md#attributes) -- [coreMigrationVersion](client._internal_namespace.SavedObjectsFindResult.md#coremigrationversion) -- [error](client._internal_namespace.SavedObjectsFindResult.md#error) -- [id](client._internal_namespace.SavedObjectsFindResult.md#id) -- [migrationVersion](client._internal_namespace.SavedObjectsFindResult.md#migrationversion) -- [namespaces](client._internal_namespace.SavedObjectsFindResult.md#namespaces) -- [originId](client._internal_namespace.SavedObjectsFindResult.md#originid) -- [references](client._internal_namespace.SavedObjectsFindResult.md#references) -- [score](client._internal_namespace.SavedObjectsFindResult.md#score) -- [sort](client._internal_namespace.SavedObjectsFindResult.md#sort) -- [type](client._internal_namespace.SavedObjectsFindResult.md#type) -- [updated\_at](client._internal_namespace.SavedObjectsFindResult.md#updated_at) -- [version](client._internal_namespace.SavedObjectsFindResult.md#version) - -## Properties - -### attributes - -• **attributes**: `T` - -{@inheritdoc SavedObjectAttributes} - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[attributes](client._internal_namespace.SavedObject.md#attributes) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:61 - -___ - -### coreMigrationVersion - -• `Optional` **coreMigrationVersion**: `string` - -A semver value that is used when upgrading objects between Kibana versions. - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[coreMigrationVersion](client._internal_namespace.SavedObject.md#coremigrationversion) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:67 - -___ - -### error - -• `Optional` **error**: [`SavedObjectError`](client._internal_namespace.SavedObjectError.md) - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[error](client._internal_namespace.SavedObject.md#error) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:59 - -___ - -### id - -• **id**: `string` - -The ID of this Saved Object, guaranteed to be unique for all objects of the same `type` - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[id](client._internal_namespace.SavedObject.md#id) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:52 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -{@inheritdoc SavedObjectsMigrationVersion} - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[migrationVersion](client._internal_namespace.SavedObject.md#migrationversion) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:65 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -Space(s) that this saved object exists in. This attribute is not used for "global" saved object types which are registered with -`namespaceType: 'agnostic'`. - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[namespaces](client._internal_namespace.SavedObject.md#namespaces) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:72 - -___ - -### originId - -• `Optional` **originId**: `string` - -The ID of the saved object this originated from. This is set if this object's `id` was regenerated; that can happen during migration -from a legacy single-namespace type, or during import. It is only set during migration or create operations. This is used during import -to ensure that ID regeneration is deterministic, so saved objects will be overwritten if they are imported multiple times into a given -space. - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[originId](client._internal_namespace.SavedObject.md#originid) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:79 - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -{@inheritdoc SavedObjectReference} - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[references](client._internal_namespace.SavedObject.md#references) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:63 - -___ - -### score - -• **score**: `number` - -The Elasticsearch `_score` of this result. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:117 - -___ - -### sort - -• `Optional` **sort**: `string`[] - -The Elasticsearch `sort` value of this result. - -**`remarks`** -This can be passed directly to the `searchAfter` param in the [SavedObjectsFindOptions](client._internal_namespace.SavedObjectsFindOptions.md) -in order to page through large numbers of hits. It is recommended you use this alongside -a Point In Time (PIT) that was opened with [SavedObjectsClient.openPointInTimeForType](../classes/client._internal_namespace.SavedObjectsClient.md#openpointintimefortype). - -**`example`** -```ts -const { id } = await savedObjectsClient.openPointInTimeForType('visualization'); -const page1 = await savedObjectsClient.find({ - type: 'visualization', - sortField: 'updated_at', - sortOrder: 'asc', - pit: { id }, -}); -const lastHit = page1.saved_objects[page1.saved_objects.length - 1]; -const page2 = await savedObjectsClient.find({ - type: 'visualization', - sortField: 'updated_at', - sortOrder: 'asc', - pit: { id: page1.pit_id }, - searchAfter: lastHit.sort, -}); -await savedObjectsClient.closePointInTime(page2.pit_id); -``` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:146 - -___ - -### type - -• **type**: `string` - -The type of Saved Object. Each plugin can define it's own custom Saved Object types. - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[type](client._internal_namespace.SavedObject.md#type) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:54 - -___ - -### updated\_at - -• `Optional` **updated\_at**: `string` - -Timestamp of the last time this document had been updated. - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[updated_at](client._internal_namespace.SavedObject.md#updated_at) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:58 - -___ - -### version - -• `Optional` **version**: `string` - -An opaque version number which changes on each successful write operation. Can be used for implementing optimistic concurrency control. - -#### Inherited from - -[SavedObject](client._internal_namespace.SavedObject.md).[version](client._internal_namespace.SavedObject.md#version) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:56 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md deleted file mode 100644 index e2996e270116e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md +++ /dev/null @@ -1,65 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsImportActionRequiredWarning - -# Interface: SavedObjectsImportActionRequiredWarning - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsImportActionRequiredWarning - -A warning meant to notify that a specific user action is required to finalize the import -of some type of object. - -**`remark`** The `actionUrl` must be a path relative to the basePath, and not include it. - -## Table of contents - -### Properties - -- [actionPath](client._internal_namespace.SavedObjectsImportActionRequiredWarning.md#actionpath) -- [buttonLabel](client._internal_namespace.SavedObjectsImportActionRequiredWarning.md#buttonlabel) -- [message](client._internal_namespace.SavedObjectsImportActionRequiredWarning.md#message) -- [type](client._internal_namespace.SavedObjectsImportActionRequiredWarning.md#type) - -## Properties - -### actionPath - -• **actionPath**: `string` - -The path (without the basePath) that the user should be redirect to address this warning. - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:191 - -___ - -### buttonLabel - -• `Optional` **buttonLabel**: `string` - -An optional label to use for the link button. If unspecified, a default label will be used. - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:193 - -___ - -### message - -• **message**: `string` - -The translated message to display to the user. - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:189 - -___ - -### type - -• **type**: ``"action_required"`` - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:187 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportHookResult.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportHookResult.md deleted file mode 100644 index 37e2cbd5d788b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportHookResult.md +++ /dev/null @@ -1,25 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsImportHookResult - -# Interface: SavedObjectsImportHookResult - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsImportHookResult - -Result from a [import hook](../modules/client._internal_namespace.md#savedobjectsimporthook) - -## Table of contents - -### Properties - -- [warnings](client._internal_namespace.SavedObjectsImportHookResult.md#warnings) - -## Properties - -### warnings - -• `Optional` **warnings**: [`SavedObjectsImportWarning`](../modules/client._internal_namespace.md#savedobjectsimportwarning)[] - -An optional list of warnings to display in the UI when the import succeeds. - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:213 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md deleted file mode 100644 index 55f2c60462af4..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md +++ /dev/null @@ -1,36 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsImportSimpleWarning - -# Interface: SavedObjectsImportSimpleWarning - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsImportSimpleWarning - -A simple informative warning that will be displayed to the user. - -## Table of contents - -### Properties - -- [message](client._internal_namespace.SavedObjectsImportSimpleWarning.md#message) -- [type](client._internal_namespace.SavedObjectsImportSimpleWarning.md#type) - -## Properties - -### message - -• **message**: `string` - -The translated message to display to the user - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:176 - -___ - -### type - -• **type**: ``"simple"`` - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:174 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md deleted file mode 100644 index b215848243659..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md +++ /dev/null @@ -1,36 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsIncrementCounterField - -# Interface: SavedObjectsIncrementCounterField - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsIncrementCounterField - -## Table of contents - -### Properties - -- [fieldName](client._internal_namespace.SavedObjectsIncrementCounterField.md#fieldname) -- [incrementBy](client._internal_namespace.SavedObjectsIncrementCounterField.md#incrementby) - -## Properties - -### fieldName - -• **fieldName**: `string` - -The field name to increment the counter by. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:63 - -___ - -### incrementBy - -• `Optional` **incrementBy**: `number` - -The number to increment the field by (defaults to 1). - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:65 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md deleted file mode 100644 index ce239bd55e5c2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md +++ /dev/null @@ -1,93 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsIncrementCounterOptions - -# Interface: SavedObjectsIncrementCounterOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsIncrementCounterOptions - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Attributes` | `unknown` | - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsIncrementCounterOptions`** - -## Table of contents - -### Properties - -- [initialize](client._internal_namespace.SavedObjectsIncrementCounterOptions.md#initialize) -- [migrationVersion](client._internal_namespace.SavedObjectsIncrementCounterOptions.md#migrationversion) -- [namespace](client._internal_namespace.SavedObjectsIncrementCounterOptions.md#namespace) -- [refresh](client._internal_namespace.SavedObjectsIncrementCounterOptions.md#refresh) -- [upsertAttributes](client._internal_namespace.SavedObjectsIncrementCounterOptions.md#upsertattributes) - -## Properties - -### initialize - -• `Optional` **initialize**: `boolean` - -(default=false) If true, sets all the counter fields to 0 if they don't -already exist. Existing fields will be left as-is and won't be incremented. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:30 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -[SavedObjectsMigrationVersion](client._internal_namespace.SavedObjectsMigrationVersion.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:32 - -___ - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### refresh - -• `Optional` **refresh**: [`MutatingOperationRefreshSetting`](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -(default='wait_for') The Elasticsearch refresh setting for this -operation. See [MutatingOperationRefreshSetting](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:37 - -___ - -### upsertAttributes - -• `Optional` **upsertAttributes**: `Attributes` - -Attributes to use when upserting the document if it doesn't exist. - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:41 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMappingProperties.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMappingProperties.md deleted file mode 100644 index 5dca5a908c566..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMappingProperties.md +++ /dev/null @@ -1,11 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsMappingProperties - -# Interface: SavedObjectsMappingProperties - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsMappingProperties - -Describe the fields of a [saved object type](client._internal_namespace.SavedObjectsTypeMappingDefinition.md). - -## Indexable - -▪ [field: `string`]: [`SavedObjectsFieldMapping`](../modules/client._internal_namespace.md#savedobjectsfieldmapping) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationLogger.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationLogger.md deleted file mode 100644 index 399885d1ab4ae..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationLogger.md +++ /dev/null @@ -1,124 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsMigrationLogger - -# Interface: SavedObjectsMigrationLogger - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsMigrationLogger - -## Table of contents - -### Methods - -- [debug](client._internal_namespace.SavedObjectsMigrationLogger.md#debug) -- [error](client._internal_namespace.SavedObjectsMigrationLogger.md#error) -- [info](client._internal_namespace.SavedObjectsMigrationLogger.md#info) -- [warn](client._internal_namespace.SavedObjectsMigrationLogger.md#warn) -- [warning](client._internal_namespace.SavedObjectsMigrationLogger.md#warning) - -## Methods - -### debug - -▸ **debug**(`msg`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `msg` | `string` | - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/migration_logger.d.ts:5 - -___ - -### error - -▸ **error**<`Meta`\>(`msg`, `meta`): `void` - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Meta` | extends `LogMeta` = `LogMeta` | - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `msg` | `string` | -| `meta` | `Meta` | - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/migration_logger.d.ts:12 - -___ - -### info - -▸ **info**(`msg`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `msg` | `string` | - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/migration_logger.d.ts:6 - -___ - -### warn - -▸ **warn**(`msg`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `msg` | `string` | - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/migration_logger.d.ts:11 - -___ - -### warning - -▸ **warning**(`msg`): `void` - -**`deprecated`** Use `warn` instead. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `msg` | `string` | - -#### Returns - -`void` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/migration_logger.d.ts:10 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationVersion.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationVersion.md deleted file mode 100644 index deee7313ee96b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsMigrationVersion.md +++ /dev/null @@ -1,21 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsMigrationVersion - -# Interface: SavedObjectsMigrationVersion - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsMigrationVersion - -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. - -**`example`** -migrationVersion: { - dashboard: '7.1.1', - space: '6.6.6', -} - -## Indexable - -▪ [pluginName: `string`]: `string` diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md deleted file mode 100644 index 1b5d7dd5c90ea..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsOpenPointInTimeOptions - -# Interface: SavedObjectsOpenPointInTimeOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsOpenPointInTimeOptions - -## Table of contents - -### Properties - -- [keepAlive](client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md#keepalive) -- [namespaces](client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md#namespaces) -- [preference](client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md#preference) - -## Properties - -### keepAlive - -• `Optional` **keepAlive**: `string` - -Optionally specify how long ES should keep the PIT alive until the next request. Defaults to `5m`. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:320 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -An optional list of namespaces to be used when opening the PIT. - -When the spaces plugin is enabled: - - this will default to the user's current space (as determined by the URL) - - if specified, the user's current space will be ignored - - `['*']` will search across all available spaces - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:333 - -___ - -### preference - -• `Optional` **preference**: `string` - -An optional ES preference value to be used for the query. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:324 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md deleted file mode 100644 index 22718b1c3177c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md +++ /dev/null @@ -1,23 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsOpenPointInTimeResponse - -# Interface: SavedObjectsOpenPointInTimeResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsOpenPointInTimeResponse - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md#id) - -## Properties - -### id - -• **id**: `string` - -PIT ID returned from ES. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:342 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsPitParams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsPitParams.md deleted file mode 100644 index 0c2d6fdc1cc4e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsPitParams.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsPitParams - -# Interface: SavedObjectsPitParams - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsPitParams - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsPitParams.md#id) -- [keepAlive](client._internal_namespace.SavedObjectsPitParams.md#keepalive) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:36 - -___ - -### keepAlive - -• `Optional` **keepAlive**: `string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:37 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md deleted file mode 100644 index 79de02623cf8a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md +++ /dev/null @@ -1,46 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsRemoveReferencesToOptions - -# Interface: SavedObjectsRemoveReferencesToOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsRemoveReferencesToOptions - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsRemoveReferencesToOptions`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md#namespace) -- [refresh](client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md#refresh) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### refresh - -• `Optional` **refresh**: `boolean` - -The Elasticsearch Refresh setting for this operation. Defaults to `true` - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:203 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md deleted file mode 100644 index c6d285307c99d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md +++ /dev/null @@ -1,46 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsRemoveReferencesToResponse - -# Interface: SavedObjectsRemoveReferencesToResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsRemoveReferencesToResponse - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsRemoveReferencesToResponse`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md#namespace) -- [updated](client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md#updated) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### updated - -• **updated**: `number` - -The number of objects that have been updated by this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:211 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsResolveResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsResolveResponse.md deleted file mode 100644 index a4d66d064bf63..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsResolveResponse.md +++ /dev/null @@ -1,61 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsResolveResponse - -# Interface: SavedObjectsResolveResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsResolveResponse - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Table of contents - -### Properties - -- [alias\_target\_id](client._internal_namespace.SavedObjectsResolveResponse.md#alias_target_id) -- [outcome](client._internal_namespace.SavedObjectsResolveResponse.md#outcome) -- [saved\_object](client._internal_namespace.SavedObjectsResolveResponse.md#saved_object) - -## Properties - -### alias\_target\_id - -• `Optional` **alias\_target\_id**: `string` - -The ID of the object that the legacy URL alias points to. This is only defined when the outcome is `'aliasMatch'` or `'conflict'`. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:311 - -___ - -### outcome - -• **outcome**: ``"exactMatch"`` \| ``"aliasMatch"`` \| ``"conflict"`` - -The outcome for a successful `resolve` call is one of the following values: - - * `'exactMatch'` -- One document exactly matched the given ID. - * `'aliasMatch'` -- One document with a legacy URL alias matched the given ID; in this case the `saved_object.id` field is different - than the given ID. - * `'conflict'` -- Two documents matched the given ID, one was an exact match and another with a legacy URL alias; in this case the - `saved_object` object is the exact match, and the `saved_object.id` field is the same as the given ID. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:307 - -___ - -### saved\_object - -• **saved\_object**: [`SavedObject`](client._internal_namespace.SavedObject.md)<`T`\> - -The saved object that was found. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:297 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsType.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsType.md deleted file mode 100644 index b211135fc93ac..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsType.md +++ /dev/null @@ -1,212 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsType - -# Interface: SavedObjectsType - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsType - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Attributes` | `any` | - -## Table of contents - -### Properties - -- [convertToAliasScript](client._internal_namespace.SavedObjectsType.md#converttoaliasscript) -- [convertToMultiNamespaceTypeVersion](client._internal_namespace.SavedObjectsType.md#converttomultinamespacetypeversion) -- [excludeOnUpgrade](client._internal_namespace.SavedObjectsType.md#excludeonupgrade) -- [hidden](client._internal_namespace.SavedObjectsType.md#hidden) -- [indexPattern](client._internal_namespace.SavedObjectsType.md#indexpattern) -- [management](client._internal_namespace.SavedObjectsType.md#management) -- [mappings](client._internal_namespace.SavedObjectsType.md#mappings) -- [migrations](client._internal_namespace.SavedObjectsType.md#migrations) -- [name](client._internal_namespace.SavedObjectsType.md#name) -- [namespaceType](client._internal_namespace.SavedObjectsType.md#namespacetype) -- [schemas](client._internal_namespace.SavedObjectsType.md#schemas) - -## Properties - -### convertToAliasScript - -• `Optional` **convertToAliasScript**: `string` - -If defined, will be used to convert the type to an alias. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:235 - -___ - -### convertToMultiNamespaceTypeVersion - -• `Optional` **convertToMultiNamespaceTypeVersion**: `string` - -If defined, objects of this type will be converted to a 'multiple' or 'multiple-isolated' namespace type when migrating to this -version. - -Requirements: - - 1. This string value must be a valid semver version - 2. This type must have previously specified [`namespaceType: 'single'`](../modules/client._internal_namespace.md#savedobjectsnamespacetype) - 3. This type must also specify [`namespaceType: 'multiple'`](../modules/client._internal_namespace.md#savedobjectsnamespacetype) *or* - [`namespaceType: 'multiple-isolated'`](../modules/client._internal_namespace.md#savedobjectsnamespacetype) - -Example of a single-namespace type in 7.12: - -```ts -{ - name: 'foo', - hidden: false, - namespaceType: 'single', - mappings: {...} -} -``` - -Example after converting to a multi-namespace (isolated) type in 8.0: - -```ts -{ - name: 'foo', - hidden: false, - namespaceType: 'multiple-isolated', - mappings: {...}, - convertToMultiNamespaceTypeVersion: '8.0.0' -} -``` - -Example after converting to a multi-namespace (shareable) type in 8.1: - -```ts -{ - name: 'foo', - hidden: false, - namespaceType: 'multiple', - mappings: {...}, - convertToMultiNamespaceTypeVersion: '8.0.0' -} -``` - -Note: migration function(s) can be optionally specified for any of these versions and will not interfere with the conversion process. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:305 - -___ - -### excludeOnUpgrade - -• `Optional` **excludeOnUpgrade**: [`SavedObjectTypeExcludeFromUpgradeFilterHook`](../modules/client._internal_namespace.md#savedobjecttypeexcludefromupgradefilterhook) - -If defined, allows a type to exclude unneeded documents from the migration process and effectively be deleted. -See [SavedObjectTypeExcludeFromUpgradeFilterHook](../modules/client._internal_namespace.md#savedobjecttypeexcludefromupgradefilterhook) for more details. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:240 - -___ - -### hidden - -• **hidden**: `boolean` - -Is the type hidden by default. If true, repositories will not have access to this type unless explicitly -declared as an `extraType` when creating the repository. - -See {@link SavedObjectsServiceStart.createInternalRepository | createInternalRepository}. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:223 - -___ - -### indexPattern - -• `Optional` **indexPattern**: `string` - -If defined, the type instances will be stored in the given index instead of the default one. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:231 - -___ - -### management - -• `Optional` **management**: [`SavedObjectsTypeManagementDefinition`](client._internal_namespace.SavedObjectsTypeManagementDefinition.md)<`Attributes`\> - -An optional [saved objects management section](client._internal_namespace.SavedObjectsTypeManagementDefinition.md) definition for the type. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:309 - -___ - -### mappings - -• **mappings**: [`SavedObjectsTypeMappingDefinition`](client._internal_namespace.SavedObjectsTypeMappingDefinition.md) - -The [mapping definition](client._internal_namespace.SavedObjectsTypeMappingDefinition.md) for the type. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:244 - -___ - -### migrations - -• `Optional` **migrations**: [`SavedObjectMigrationMap`](client._internal_namespace.SavedObjectMigrationMap.md) \| () => [`SavedObjectMigrationMap`](client._internal_namespace.SavedObjectMigrationMap.md) - -An optional map of [migrations](../modules/client._internal_namespace.md#savedobjectmigrationfn) or a function returning a map of [migrations](../modules/client._internal_namespace.md#savedobjectmigrationfn) to be used to migrate the type. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:248 - -___ - -### name - -• **name**: `string` - -The name of the type, which is also used as the internal id. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:216 - -___ - -### namespaceType - -• **namespaceType**: [`SavedObjectsNamespaceType`](../modules/client._internal_namespace.md#savedobjectsnamespacetype) - -The [namespace type](../modules/client._internal_namespace.md#savedobjectsnamespacetype) for the type. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:227 - -___ - -### schemas - -• `Optional` **schemas**: [`SavedObjectsValidationMap`](client._internal_namespace.SavedObjectsValidationMap.md) \| () => [`SavedObjectsValidationMap`](client._internal_namespace.SavedObjectsValidationMap.md) - -An optional schema that can be used to validate the attributes of the type. - -When provided, calls to [create](../classes/client._internal_namespace.SavedObjectsClient.md#create) will be validated against this schema. - -See [SavedObjectsValidationMap](client._internal_namespace.SavedObjectsValidationMap.md) for more details. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:256 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeManagementDefinition.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeManagementDefinition.md deleted file mode 100644 index 4c9f9b9342215..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeManagementDefinition.md +++ /dev/null @@ -1,299 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsTypeManagementDefinition - -# Interface: SavedObjectsTypeManagementDefinition - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsTypeManagementDefinition - -Configuration options for the [type](client._internal_namespace.SavedObjectsType.md)'s management section. - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Attributes` | `any` | - -## Table of contents - -### Properties - -- [defaultSearchField](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#defaultsearchfield) -- [displayName](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#displayname) -- [icon](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#icon) -- [importableAndExportable](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#importableandexportable) -- [isExportable](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#isexportable) -- [onExport](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#onexport) -- [onImport](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#onimport) -- [visibleInManagement](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#visibleinmanagement) - -### Methods - -- [getEditUrl](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#getediturl) -- [getInAppUrl](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#getinappurl) -- [getTitle](client._internal_namespace.SavedObjectsTypeManagementDefinition.md#gettitle) - -## Properties - -### defaultSearchField - -• `Optional` **defaultSearchField**: `string` - -The default search field to use for this type. Defaults to `id`. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:337 - -___ - -### displayName - -• `Optional` **displayName**: `string` - -When specified, will be used instead of the type's name in SO management section's labels. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:324 - -___ - -### icon - -• `Optional` **icon**: `string` - -The eui icon name to display in the management table. -If not defined, the default icon will be used. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:342 - -___ - -### importableAndExportable - -• `Optional` **importableAndExportable**: `boolean` - -Is the type importable or exportable. Defaults to `false`. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:320 - -___ - -### isExportable - -• `Optional` **isExportable**: [`SavedObjectsExportablePredicate`](../modules/client._internal_namespace.md#savedobjectsexportablepredicate)<`Attributes`\> - -Optional hook to specify whether an object should be exportable. - -If specified, `isExportable` will be called during export for each -of this type's objects in the export, and the ones not matching the -predicate will be excluded from the export. - -When implementing both `isExportable` and `onExport`, it is mandatory that -`isExportable` returns the same value for an object before and after going -though the export transform. -E.g `isExportable(objectBeforeTransform) === isExportable(objectAfterTransform)` - -**`example`** -Registering a type with a per-object exportability predicate -```ts -// src/plugins/my_plugin/server/plugin.ts -import { myType } from './saved_objects'; - -export class Plugin() { - setup: (core: CoreSetup) => { - core.savedObjects.registerType({ - ...myType, - management: { - ...myType.management, - isExportable: (object) => { - if (object.attributes.myCustomAttr === 'foo') { - return false; - } - return true; - } - }, - }); - } -} -``` - -**`remarks`** `importableAndExportable` must be `true` to specify this property. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:462 - -___ - -### onExport - -• `Optional` **onExport**: [`SavedObjectsExportTransform`](../modules/client._internal_namespace.md#savedobjectsexporttransform)<`Attributes`\> - -An optional export transform function that can be used transform the objects of the registered type during -the export process. - -It can be used to either mutate the exported objects, or add additional objects (of any type) to the export list. - -See [the transform type documentation](../modules/client._internal_namespace.md#savedobjectsexporttransform) for more info and examples. - -When implementing both `isExportable` and `onExport`, it is mandatory that -`isExportable` returns the same value for an object before and after going -though the export transform. -E.g `isExportable(objectBeforeTransform) === isExportable(objectAfterTransform)` - -**`remarks`** `importableAndExportable` must be `true` to specify this property. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:380 - -___ - -### onImport - -• `Optional` **onImport**: [`SavedObjectsImportHook`](../modules/client._internal_namespace.md#savedobjectsimporthook)<`Attributes`\> - -An optional [import hook](../modules/client._internal_namespace.md#savedobjectsimporthook) to use when importing given type. - -Import hooks are executed during the savedObjects import process and allow to interact -with the imported objects. See the [hook documentation](../modules/client._internal_namespace.md#savedobjectsimporthook) -for more info. - -**`example`** -Registering a hook displaying a warning about a specific type of object -```ts -// src/plugins/my_plugin/server/plugin.ts -import { myType } from './saved_objects'; - -export class Plugin() { - setup: (core: CoreSetup) => { - core.savedObjects.registerType({ - ...myType, - management: { - ...myType.management, - onImport: (objects) => { - if(someActionIsNeeded(objects)) { - return { - warnings: [ - { - type: 'action_required', - message: 'Objects need to be manually enabled after import', - actionPath: '/app/my-app/require-activation', - }, - ] - } - } - return {}; - } - }, - }); - } -} -``` - -**`remarks`** messages returned in the warnings are user facing and must be translated. - -**`remarks`** `importableAndExportable` must be `true` to specify this property. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:423 - -___ - -### visibleInManagement - -• `Optional` **visibleInManagement**: `boolean` - -When set to false, the type will not be listed or searchable in the SO management section. -Main usage of setting this property to false for a type is when objects from the type should -be included in the export via references or export hooks, but should not directly appear in the SOM. -Defaults to `true`. - -**`remarks`** `importableAndExportable` must be `true` to specify this property. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:333 - -## Methods - -### getEditUrl - -▸ `Optional` **getEditUrl**(`savedObject`): `string` - -Function returning the url to use to redirect to the editing page of this object. -If not defined, editing will not be allowed. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `savedObject` | [`SavedObject`](client._internal_namespace.SavedObject.md)<`Attributes`\> | - -#### Returns - -`string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:352 - -___ - -### getInAppUrl - -▸ `Optional` **getInAppUrl**(`savedObject`): `Object` - -Function returning the url to use to redirect to this object from the management section. -If not defined, redirecting to the object will not be allowed. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `savedObject` | [`SavedObject`](client._internal_namespace.SavedObject.md)<`Attributes`\> | - -#### Returns - -`Object` - -an object containing a `path` and `uiCapabilitiesPath` properties. the `path` is the path to - the object page, relative to the base path. `uiCapabilitiesPath` is the path to check in the - [uiCapabilities](client._internal_namespace.Capabilities.md) to check if the user has permission to access the object. - -| Name | Type | -| :------ | :------ | -| `path` | `string` | -| `uiCapabilitiesPath` | `string` | - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:361 - -___ - -### getTitle - -▸ `Optional` **getTitle**(`savedObject`): `string` - -Function returning the title to display in the management table. -If not defined, will use the object's type and id to generate a label. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `savedObject` | [`SavedObject`](client._internal_namespace.SavedObject.md)<`Attributes`\> | - -#### Returns - -`string` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:347 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeMappingDefinition.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeMappingDefinition.md deleted file mode 100644 index 4ebbf456a0556..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsTypeMappingDefinition.md +++ /dev/null @@ -1,62 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsTypeMappingDefinition - -# Interface: SavedObjectsTypeMappingDefinition - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsTypeMappingDefinition - -Describe a saved object type mapping. - -**`example`** -```ts -const typeDefinition: SavedObjectsTypeMappingDefinition = { - properties: { - enabled: { - type: "boolean" - }, - sendUsageFrom: { - ignore_above: 256, - type: "keyword" - }, - lastReported: { - type: "date" - }, - lastVersionChecked: { - ignore_above: 256, - type: "keyword" - }, - } -} -``` - -## Table of contents - -### Properties - -- [dynamic](client._internal_namespace.SavedObjectsTypeMappingDefinition.md#dynamic) -- [properties](client._internal_namespace.SavedObjectsTypeMappingDefinition.md#properties) - -## Properties - -### dynamic - -• `Optional` **dynamic**: ``false`` \| ``"strict"`` - -The dynamic property of the mapping, either `false` or `'strict'`. If -unspecified `dynamic: 'strict'` will be inherited from the top-level -index mappings. - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:33 - -___ - -### properties - -• **properties**: [`SavedObjectsMappingProperties`](client._internal_namespace.SavedObjectsMappingProperties.md) - -The underlying properties of the type mapping - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:35 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md deleted file mode 100644 index 5f5243a72ad69..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md +++ /dev/null @@ -1,68 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsUpdateObjectsSpacesObject - -# Interface: SavedObjectsUpdateObjectsSpacesObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsUpdateObjectsSpacesObject - -An object that should have its spaces updated. - -## Table of contents - -### Properties - -- [id](client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md#id) -- [spaces](client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md#spaces) -- [type](client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md#type) -- [version](client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md#version) - -## Properties - -### id - -• **id**: `string` - -The type of the object to update - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:14 - -___ - -### spaces - -• `Optional` **spaces**: `string`[] - -The space(s) that the object to update currently exists in. This is only intended to be used by SOC wrappers. - -**`internal`** - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:22 - -___ - -### type - -• **type**: `string` - -The ID of the object to update - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:16 - -___ - -### version - -• `Optional` **version**: `string` - -The version of the object to update; this is used for optimistic concurrency control. This is only intended to be used by SOC wrappers. - -**`internal`** - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:28 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md deleted file mode 100644 index 403680115772c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md +++ /dev/null @@ -1,48 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsUpdateObjectsSpacesOptions - -# Interface: SavedObjectsUpdateObjectsSpacesOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsUpdateObjectsSpacesOptions - -Options for the update operation. - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsUpdateObjectsSpacesOptions`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md#namespace) -- [refresh](client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md#refresh) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### refresh - -• `Optional` **refresh**: [`MutatingOperationRefreshSetting`](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -The Elasticsearch Refresh setting for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:37 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md deleted file mode 100644 index 204b50f484657..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md +++ /dev/null @@ -1,23 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsUpdateObjectsSpacesResponse - -# Interface: SavedObjectsUpdateObjectsSpacesResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsUpdateObjectsSpacesResponse - -The response when objects' spaces are updated. - -## Table of contents - -### Properties - -- [objects](client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md#objects) - -## Properties - -### objects - -• **objects**: [`SavedObjectsUpdateObjectsSpacesResponseObject`](client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md)[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:45 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md deleted file mode 100644 index f529bdcf9344b..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md +++ /dev/null @@ -1,64 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsUpdateObjectsSpacesResponseObject - -# Interface: SavedObjectsUpdateObjectsSpacesResponseObject - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsUpdateObjectsSpacesResponseObject - -Details about a specific object's update result. - -## Table of contents - -### Properties - -- [error](client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md#error) -- [id](client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md#id) -- [spaces](client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md#spaces) -- [type](client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md#type) - -## Properties - -### error - -• `Optional` **error**: [`SavedObjectError`](client._internal_namespace.SavedObjectError.md) - -Included if there was an error updating this object's spaces - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:60 - -___ - -### id - -• **id**: `string` - -The ID of the referenced object - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:56 - -___ - -### spaces - -• **spaces**: `string`[] - -The space(s) that the referenced object exists in - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:58 - -___ - -### type - -• **type**: `string` - -The type of the referenced object - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/update_objects_spaces.d.ts:54 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md deleted file mode 100644 index 0c7500b08b2fe..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md +++ /dev/null @@ -1,91 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsUpdateOptions - -# Interface: SavedObjectsUpdateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsUpdateOptions - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `Attributes` | `unknown` | - -## Hierarchy - -- [`SavedObjectsBaseOptions`](client._internal_namespace.SavedObjectsBaseOptions.md) - - ↳ **`SavedObjectsUpdateOptions`** - -## Table of contents - -### Properties - -- [namespace](client._internal_namespace.SavedObjectsUpdateOptions.md#namespace) -- [references](client._internal_namespace.SavedObjectsUpdateOptions.md#references) -- [refresh](client._internal_namespace.SavedObjectsUpdateOptions.md#refresh) -- [upsert](client._internal_namespace.SavedObjectsUpdateOptions.md#upsert) -- [version](client._internal_namespace.SavedObjectsUpdateOptions.md#version) - -## Properties - -### namespace - -• `Optional` **namespace**: `string` - -Specify the namespace for this operation - -#### Inherited from - -[SavedObjectsBaseOptions](client._internal_namespace.SavedObjectsBaseOptions.md).[namespace](client._internal_namespace.SavedObjectsBaseOptions.md#namespace) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:126 - -___ - -### references - -• `Optional` **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -{@inheritdoc SavedObjectReference} - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:191 - -___ - -### refresh - -• `Optional` **refresh**: [`MutatingOperationRefreshSetting`](../modules/client._internal_namespace.md#mutatingoperationrefreshsetting) - -The Elasticsearch Refresh setting for this operation - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:193 - -___ - -### upsert - -• `Optional` **upsert**: `Attributes` - -If specified, will be used to perform an upsert if the document doesn't exist - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:195 - -___ - -### version - -• `Optional` **version**: `string` - -An opaque version number which changes on each successful write operation. Can be used for implementing optimistic concurrency control. - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:189 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md deleted file mode 100644 index 2fa6a0e54a556..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md +++ /dev/null @@ -1,199 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsUpdateResponse - -# Interface: SavedObjectsUpdateResponse - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsUpdateResponse - -## Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -## Hierarchy - -- `Omit`<[`SavedObject`](client._internal_namespace.SavedObject.md)<`T`\>, ``"attributes"`` \| ``"references"``\> - - ↳ **`SavedObjectsUpdateResponse`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.SavedObjectsUpdateResponse.md#attributes) -- [coreMigrationVersion](client._internal_namespace.SavedObjectsUpdateResponse.md#coremigrationversion) -- [error](client._internal_namespace.SavedObjectsUpdateResponse.md#error) -- [id](client._internal_namespace.SavedObjectsUpdateResponse.md#id) -- [migrationVersion](client._internal_namespace.SavedObjectsUpdateResponse.md#migrationversion) -- [namespaces](client._internal_namespace.SavedObjectsUpdateResponse.md#namespaces) -- [originId](client._internal_namespace.SavedObjectsUpdateResponse.md#originid) -- [references](client._internal_namespace.SavedObjectsUpdateResponse.md#references) -- [type](client._internal_namespace.SavedObjectsUpdateResponse.md#type) -- [updated\_at](client._internal_namespace.SavedObjectsUpdateResponse.md#updated_at) -- [version](client._internal_namespace.SavedObjectsUpdateResponse.md#version) - -## Properties - -### attributes - -• **attributes**: `Partial`<`T`\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:271 - -___ - -### coreMigrationVersion - -• `Optional` **coreMigrationVersion**: `string` - -A semver value that is used when upgrading objects between Kibana versions. - -#### Inherited from - -Omit.coreMigrationVersion - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:67 - -___ - -### error - -• `Optional` **error**: [`SavedObjectError`](client._internal_namespace.SavedObjectError.md) - -#### Inherited from - -Omit.error - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:59 - -___ - -### id - -• **id**: `string` - -The ID of this Saved Object, guaranteed to be unique for all objects of the same `type` - -#### Inherited from - -Omit.id - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:52 - -___ - -### migrationVersion - -• `Optional` **migrationVersion**: [`SavedObjectsMigrationVersion`](client._internal_namespace.SavedObjectsMigrationVersion.md) - -{@inheritdoc SavedObjectsMigrationVersion} - -#### Inherited from - -Omit.migrationVersion - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:65 - -___ - -### namespaces - -• `Optional` **namespaces**: `string`[] - -Space(s) that this saved object exists in. This attribute is not used for "global" saved object types which are registered with -`namespaceType: 'agnostic'`. - -#### Inherited from - -Omit.namespaces - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:72 - -___ - -### originId - -• `Optional` **originId**: `string` - -The ID of the saved object this originated from. This is set if this object's `id` was regenerated; that can happen during migration -from a legacy single-namespace type, or during import. It is only set during migration or create operations. This is used during import -to ensure that ID regeneration is deterministic, so saved objects will be overwritten if they are imported multiple times into a given -space. - -#### Inherited from - -Omit.originId - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:79 - -___ - -### references - -• **references**: `undefined` \| [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -src/core/target/types/server/saved_objects/service/saved_objects_client.d.ts:272 - -___ - -### type - -• **type**: `string` - -The type of Saved Object. Each plugin can define it's own custom Saved Object types. - -#### Inherited from - -Omit.type - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:54 - -___ - -### updated\_at - -• `Optional` **updated\_at**: `string` - -Timestamp of the last time this document had been updated. - -#### Inherited from - -Omit.updated\_at - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:58 - -___ - -### version - -• `Optional` **version**: `string` - -An opaque version number which changes on each successful write operation. Can be used for implementing optimistic concurrency control. - -#### Inherited from - -Omit.version - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:56 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsValidationMap.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsValidationMap.md deleted file mode 100644 index 366dc9fe0a476..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SavedObjectsValidationMap.md +++ /dev/null @@ -1,34 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SavedObjectsValidationMap - -# Interface: SavedObjectsValidationMap - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SavedObjectsValidationMap - -A map of [validation specs](../modules/client._internal_namespace.md#savedobjectsvalidationspec) to be used for a given type. -The map's keys must be valid semver versions. - -Any time you change the schema of a [SavedObjectsType](client._internal_namespace.SavedObjectsType.md), you should add a new entry -to this map for the Kibana version the change was introduced in. - -**`example`** -```typescript -const validationMap: SavedObjectsValidationMap = { - '1.0.0': schema.object({ - foo: schema.string(), - }), - '2.0.0': schema.object({ - foo: schema.string({ - minLength: 2, - validate(value) { - if (!/^[a-z]+$/.test(value)) { - return 'must be lowercase letters only'; - } - } - }), - }), -} -``` - -## Indexable - -▪ [version: `string`]: [`SavedObjectsValidationSpec`](../modules/client._internal_namespace.md#savedobjectsvalidationspec) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Services.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Services.md deleted file mode 100644 index 3a770aca3f595..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Services.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Services - -# Interface: Services - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Services - -## Table of contents - -### Properties - -- [connectorTokenClient](client._internal_namespace.Services.md#connectortokenclient) -- [savedObjectsClient](client._internal_namespace.Services.md#savedobjectsclient) -- [scopedClusterClient](client._internal_namespace.Services.md#scopedclusterclient) - -## Properties - -### connectorTokenClient - -• **connectorTokenClient**: [`ConnectorTokenClient`](../classes/client._internal_namespace.ConnectorTokenClient.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:26 - -___ - -### savedObjectsClient - -• **savedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:24 - -___ - -### scopedClusterClient - -• **scopedClusterClient**: [`ElasticsearchClient`](../modules/client._internal_namespace.md#elasticsearchclient) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:25 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Space.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Space.md deleted file mode 100644 index 018efefd6f456..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Space.md +++ /dev/null @@ -1,131 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Space - -# Interface: Space - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Space - -A Space. - -## Hierarchy - -- **`Space`** - - ↳ [`GetSpaceResult`](client._internal_namespace.GetSpaceResult.md) - -## Table of contents - -### Properties - -- [\_reserved](client._internal_namespace.Space.md#_reserved) -- [color](client._internal_namespace.Space.md#color) -- [description](client._internal_namespace.Space.md#description) -- [disabledFeatures](client._internal_namespace.Space.md#disabledfeatures) -- [id](client._internal_namespace.Space.md#id) -- [imageUrl](client._internal_namespace.Space.md#imageurl) -- [initials](client._internal_namespace.Space.md#initials) -- [name](client._internal_namespace.Space.md#name) - -## Properties - -### \_reserved - -• `Optional` `Private` **\_reserved**: `boolean` - -Indicates that this space is reserved (system controlled). -Reserved spaces cannot be created or deleted by end-users. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:46 - -___ - -### color - -• `Optional` **color**: `string` - -Optional color (hex code) for this space. -If neither `color` nor `imageUrl` is specified, then a color will be automatically generated. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:24 - -___ - -### description - -• `Optional` **description**: `string` - -Optional description for this space. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:19 - -___ - -### disabledFeatures - -• **disabledFeatures**: `string`[] - -The set of feature ids that should be hidden within this space. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:40 - -___ - -### id - -• **id**: `string` - -The unique identifier for this space. -The id becomes part of the "URL Identifier" of the space. - -Example: an id of `marketing` would result in the URL identifier of `/s/marketing`. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:11 - -___ - -### imageUrl - -• `Optional` **imageUrl**: `string` - -Optional base-64 encoded data image url to show as this space's avatar. -This setting takes precedence over any configured `color` or `initials`. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:36 - -___ - -### initials - -• `Optional` **initials**: `string` - -Optional display initials for this space's avatar. Supports a maximum of 2 characters. -If initials are not provided, then they will be derived from the space name automatically. - -Initials are not displayed if an `imageUrl` has been specified. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:31 - -___ - -### name - -• **name**: `string` - -Display name for this space. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:15 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SpacesServiceStart.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SpacesServiceStart.md deleted file mode 100644 index 5dd67943c579f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SpacesServiceStart.md +++ /dev/null @@ -1,150 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SpacesServiceStart - -# Interface: SpacesServiceStart - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SpacesServiceStart - -The Spaces service start contract. - -## Table of contents - -### Methods - -- [createSpacesClient](client._internal_namespace.SpacesServiceStart.md#createspacesclient) -- [getActiveSpace](client._internal_namespace.SpacesServiceStart.md#getactivespace) -- [getSpaceId](client._internal_namespace.SpacesServiceStart.md#getspaceid) -- [isInDefaultSpace](client._internal_namespace.SpacesServiceStart.md#isindefaultspace) -- [namespaceToSpaceId](client._internal_namespace.SpacesServiceStart.md#namespacetospaceid) -- [spaceIdToNamespace](client._internal_namespace.SpacesServiceStart.md#spaceidtonamespace) - -## Methods - -### createSpacesClient - -▸ **createSpacesClient**(`request`): [`ISpacesClient`](client._internal_namespace.ISpacesClient.md) - -Creates a scoped instance of the SpacesClient. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | the request. | - -#### Returns - -[`ISpacesClient`](client._internal_namespace.ISpacesClient.md) - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_service/spaces_service.d.ts:32 - -___ - -### getActiveSpace - -▸ **getActiveSpace**(`request`): `Promise`<[`Space`](client._internal_namespace.Space.md)\> - -Retrieves the Space associated with the provided request. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | the request. | - -#### Returns - -`Promise`<[`Space`](client._internal_namespace.Space.md)\> - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_service/spaces_service.d.ts:47 - -___ - -### getSpaceId - -▸ **getSpaceId**(`request`): `string` - -Retrieves the space id associated with the provided request. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | the request. | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_service/spaces_service.d.ts:37 - -___ - -### isInDefaultSpace - -▸ **isInDefaultSpace**(`request`): `boolean` - -Indicates if the provided request is executing within the context of the `default` space. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | the request. | - -#### Returns - -`boolean` - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_service/spaces_service.d.ts:42 - -___ - -### namespaceToSpaceId - -▸ **namespaceToSpaceId**(`namespace`): `string` - -Converts the provided namespace into the corresponding space id. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `namespace` | `undefined` \| `string` | the namespace to convert. | - -#### Returns - -`string` - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_service/spaces_service.d.ts:57 - -___ - -### spaceIdToNamespace - -▸ **spaceIdToNamespace**(`spaceId`): `undefined` \| `string` - -Converts the provided space id into the corresponding Saved Objects `namespace` id. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `spaceId` | `string` | the space id to convert. | - -#### Returns - -`undefined` \| `string` - -#### Defined in - -x-pack/plugins/spaces/target/types/server/spaces_service/spaces_service.d.ts:52 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeatureConfig.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeatureConfig.md deleted file mode 100644 index adfb11e4efd7d..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeatureConfig.md +++ /dev/null @@ -1,38 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SubFeatureConfig - -# Interface: SubFeatureConfig - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SubFeatureConfig - -Configuration for a sub-feature. - -## Table of contents - -### Properties - -- [name](client._internal_namespace.SubFeatureConfig.md#name) -- [privilegeGroups](client._internal_namespace.SubFeatureConfig.md#privilegegroups) - -## Properties - -### name - -• **name**: `string` - -Display name for this sub-feature - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:9 - -___ - -### privilegeGroups - -• **privilegeGroups**: readonly [`SubFeaturePrivilegeGroupConfig`](client._internal_namespace.SubFeaturePrivilegeGroupConfig.md)[] - -Collection of privilege groups - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:11 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeConfig.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeConfig.md deleted file mode 100644 index 4cbd7bc89efc7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeConfig.md +++ /dev/null @@ -1,334 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SubFeaturePrivilegeConfig - -# Interface: SubFeaturePrivilegeConfig - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SubFeaturePrivilegeConfig - -Configuration for a sub-feature privilege. - -## Hierarchy - -- `Omit`<[`FeatureKibanaPrivileges`](client._internal_namespace.FeatureKibanaPrivileges.md), ``"excludeFromBasePrivileges"``\> - - ↳ **`SubFeaturePrivilegeConfig`** - -## Table of contents - -### Properties - -- [alerting](client._internal_namespace.SubFeaturePrivilegeConfig.md#alerting) -- [api](client._internal_namespace.SubFeaturePrivilegeConfig.md#api) -- [app](client._internal_namespace.SubFeaturePrivilegeConfig.md#app) -- [cases](client._internal_namespace.SubFeaturePrivilegeConfig.md#cases) -- [catalogue](client._internal_namespace.SubFeaturePrivilegeConfig.md#catalogue) -- [disabled](client._internal_namespace.SubFeaturePrivilegeConfig.md#disabled) -- [id](client._internal_namespace.SubFeaturePrivilegeConfig.md#id) -- [includeIn](client._internal_namespace.SubFeaturePrivilegeConfig.md#includein) -- [management](client._internal_namespace.SubFeaturePrivilegeConfig.md#management) -- [minimumLicense](client._internal_namespace.SubFeaturePrivilegeConfig.md#minimumlicense) -- [name](client._internal_namespace.SubFeaturePrivilegeConfig.md#name) -- [requireAllSpaces](client._internal_namespace.SubFeaturePrivilegeConfig.md#requireallspaces) -- [savedObject](client._internal_namespace.SubFeaturePrivilegeConfig.md#savedobject) -- [ui](client._internal_namespace.SubFeaturePrivilegeConfig.md#ui) - -## Properties - -### alerting - -• `Optional` **alerting**: `Object` - -If your feature requires access to specific Alert Types, then specify your access needs here. -Include both Alert Types registered by the feature and external Alert Types such as built-in -Alert Types and Alert Types provided by other features to which you wish to grant access. - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `alert?` | `Object` | -| `alert.all?` | readonly `string`[] | -| `alert.read?` | readonly `string`[] | -| `rule?` | `Object` | -| `rule.all?` | readonly `string`[] | -| `rule.read?` | readonly `string`[] | - -#### Inherited from - -Omit.alerting - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:82 - -___ - -### api - -• `Optional` **api**: readonly `string`[] - -If your feature includes server-side APIs, you can tag those routes to secure access based on user permissions. - -**`example`** -```ts - // Configure your routes with a tag starting with the 'access:' prefix - server.route({ - path: '/api/my-route', - method: 'GET', - handler: () => { ...}, - options: { - tags: ['access:my_feature-admin'] - } - }); - - Then, specify the tags here (without the 'access:' prefix) which should be secured: - - { - api: ['my_feature-admin'] - } -``` - -NOTE: It is important to name your tags in a way that will not collide with other plugins/features. -A generic tag name like "access:read" could be used elsewhere, and access to that API endpoint would also -extend to any routes you have also tagged with that name. - -#### Inherited from - -Omit.api - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:64 - -___ - -### app - -• `Optional` **app**: readonly `string`[] - -If your feature exposes a client-side application (most of them do!), then you can control access to them here. - -**`example`** -```ts - { - app: ['my-app', 'kibana'] - } -``` - -#### Inherited from - -Omit.app - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:76 - -___ - -### cases - -• `Optional` **cases**: `Object` - -If your feature requires access to specific owners of cases (aka plugins that have created cases), then specify your access needs here. The values here should -be unique identifiers for the owners of cases you want access to. - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `all?` | readonly `string`[] | List of case owners which users should have full read/write access to when granted this privilege. **`example`** ```ts { all: ['securitySolution'] } ``` | -| `read?` | readonly `string`[] | List of case owners which users should have read-only access to when granted this privilege. **`example`** ```ts { read: ['securitySolution'] } ``` | - -#### Inherited from - -Omit.cases - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:132 - -___ - -### catalogue - -• `Optional` **catalogue**: readonly `string`[] - -If this feature includes a catalogue entry, you can specify them here to control visibility based on user permissions. - -#### Inherited from - -Omit.catalogue - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:37 - -___ - -### disabled - -• `Optional` **disabled**: `boolean` - -Whether or not this privilege should be hidden in the roles UI and disallowed on the API. Defaults to `false`. - -**`deprecated`** - -#### Inherited from - -Omit.disabled - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:18 - -___ - -### id - -• **id**: `string` - -Identifier for this privilege. Must be unique across all other privileges within a feature. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:47 - -___ - -### includeIn - -• **includeIn**: ``"all"`` \| ``"none"`` \| ``"read"`` - -Denotes which Primary Feature Privilege this sub-feature privilege should be included in. -`read` is also included in `all` automatically. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:56 - -___ - -### management - -• `Optional` **management**: `Object` - -If this feature includes management sections, you can specify them here to control visibility of those -pages based on user privileges. - -**`example`** -```ts - // Enables access to the "Advanced Settings" management page within the Kibana section - management: { - kibana: ['settings'] - } -``` - -#### Index signature - -▪ [sectionId: `string`]: readonly `string`[] - -#### Inherited from - -Omit.management - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:31 - -___ - -### minimumLicense - -• `Optional` **minimumLicense**: ``"basic"`` \| ``"standard"`` \| ``"gold"`` \| ``"platinum"`` \| ``"enterprise"`` \| ``"trial"`` - -The minimum supported license level for this sub-feature privilege. -If no license level is supplied, then this privilege will be available for all licences -that are valid for the overall feature. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:62 - -___ - -### name - -• **name**: `string` - -The display name for this privilege. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:51 - -___ - -### requireAllSpaces - -• `Optional` **requireAllSpaces**: `boolean` - -Whether or not this privilege should only be granted to `All Spaces *`. Should be used for features that do not -support Spaces. Defaults to `false`. - -#### Inherited from - -Omit.requireAllSpaces - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:13 - -___ - -### savedObject - -• **savedObject**: `Object` - -If your feature requires access to specific saved objects, then specify your access needs here. - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `all` | readonly `string`[] | List of saved object types which users should have full read/write access to when granted this privilege. **`example`** ```ts { all: ['my-saved-object-type'] } ``` | -| `read` | readonly `string`[] | List of saved object types which users should have read-only access to when granted this privilege. **`example`** ```ts { read: ['config'] } ``` | - -#### Inherited from - -Omit.savedObject - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:157 - -___ - -### ui - -• **ui**: readonly `string`[] - -A list of UI Capabilities that should be granted to users with this privilege. -These capabilities will automatically be namespaces within your feature id. - -**`example`** -```ts - { - ui: ['show', 'save'] - } - - This translates in the UI to the following (assuming a feature id of "foo"): - import { uiCapabilities } from 'ui/capabilities'; - - const canShowApp = uiCapabilities.foo.show; - const canSave = uiCapabilities.foo.save; -``` -Note: Since these are automatically namespaced, you are free to use generic names like "show" and "save". - -**`see`** UICapabilities - -#### Inherited from - -Omit.ui - -#### Defined in - -x-pack/plugins/features/target/types/common/feature_kibana_privileges.d.ts:199 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeGroupConfig.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeGroupConfig.md deleted file mode 100644 index 28dcebc6af10c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.SubFeaturePrivilegeGroupConfig.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / SubFeaturePrivilegeGroupConfig - -# Interface: SubFeaturePrivilegeGroupConfig - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).SubFeaturePrivilegeGroupConfig - -Configuration for a sub-feature privilege group. - -## Table of contents - -### Properties - -- [groupType](client._internal_namespace.SubFeaturePrivilegeGroupConfig.md#grouptype) -- [privileges](client._internal_namespace.SubFeaturePrivilegeGroupConfig.md#privileges) - -## Properties - -### groupType - -• **groupType**: [`SubFeaturePrivilegeGroupType`](../modules/client._internal_namespace.md#subfeatureprivilegegrouptype) - -The type of privilege group. -- `mutually_exclusive`:: - Users will be able to select at most one privilege within this group. - Privileges must be specified in descending order of permissiveness (e.g. `All`, `Read`, not `Read`, `All) -- `independent`:: - Users will be able to select any combination of privileges within this group. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:34 - -___ - -### privileges - -• **privileges**: readonly [`SubFeaturePrivilegeConfig`](client._internal_namespace.SubFeaturePrivilegeConfig.md)[] - -The privileges which belong to this group. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:38 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInfo.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInfo.md deleted file mode 100644 index 56843b1283c19..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInfo.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskInfo - -# Interface: TaskInfo - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskInfo - -## Table of contents - -### Properties - -- [attempts](client._internal_namespace.TaskInfo.md#attempts) -- [scheduled](client._internal_namespace.TaskInfo.md#scheduled) - -## Properties - -### attempts - -• **attempts**: `number` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:22 - -___ - -### scheduled - -• **scheduled**: `Date` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:21 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInstance.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInstance.md deleted file mode 100644 index 4cea61eafbdb2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskInstance.md +++ /dev/null @@ -1,199 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskInstance - -# Interface: TaskInstance - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskInstance - -## Hierarchy - -- **`TaskInstance`** - - ↳ [`ConcreteTaskInstance`](client._internal_namespace.ConcreteTaskInstance.md) - -## Table of contents - -### Properties - -- [id](client._internal_namespace.TaskInstance.md#id) -- [ownerId](client._internal_namespace.TaskInstance.md#ownerid) -- [params](client._internal_namespace.TaskInstance.md#params) -- [retryAt](client._internal_namespace.TaskInstance.md#retryat) -- [runAt](client._internal_namespace.TaskInstance.md#runat) -- [schedule](client._internal_namespace.TaskInstance.md#schedule) -- [scheduledAt](client._internal_namespace.TaskInstance.md#scheduledat) -- [scope](client._internal_namespace.TaskInstance.md#scope) -- [startedAt](client._internal_namespace.TaskInstance.md#startedat) -- [state](client._internal_namespace.TaskInstance.md#state) -- [taskType](client._internal_namespace.TaskInstance.md#tasktype) -- [traceparent](client._internal_namespace.TaskInstance.md#traceparent) -- [user](client._internal_namespace.TaskInstance.md#user) - -## Properties - -### id - -• `Optional` **id**: `string` - -Optional ID that can be passed by the caller. When ID is undefined, ES -will auto-generate a unique id. Otherwise, ID will be used to either -create a new document, or update existing document - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:145 - -___ - -### ownerId - -• `Optional` **ownerId**: ``null`` \| `string` - -The random uuid of the Kibana instance which claimed ownership of the task last - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:205 - -___ - -### params - -• **params**: `Record`<`string`, `any`\> - -A task-specific set of parameters, used by the task's run function to tailor -its work. This is generally user-input, such as { sms: '333-444-2222' }. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:182 - -___ - -### retryAt - -• `Optional` **retryAt**: ``null`` \| `Date` - -The date and time that this task should re-execute if stuck in "running" / timeout -status. This value is only set when status is set to "running". - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:165 - -___ - -### runAt - -• `Optional` **runAt**: `Date` - -The date and time that this task is scheduled to be run. It is not -guaranteed to run at this time, but it is guaranteed not to run earlier -than this. Defaults to immediately. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:171 - -___ - -### schedule - -• `Optional` **schedule**: [`IntervalSchedule`](client._internal_namespace.IntervalSchedule.md) - -A TaskSchedule string, which specifies this as a recurring task. - -Currently, this supports a single format: an interval in minutes or seconds (e.g. '5m', '30s'). - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:177 - -___ - -### scheduledAt - -• `Optional` **scheduledAt**: `Date` - -The date and time that this task was originally scheduled. This is used -for convenience to task run functions, and for troubleshooting. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:154 - -___ - -### scope - -• `Optional` **scope**: `string`[] - -Used to group tasks for querying. So, reporting might schedule tasks with a scope of 'reporting', -and then query such tasks to provide a glimpse at only reporting tasks, rather than at all tasks. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:201 - -___ - -### startedAt - -• `Optional` **startedAt**: ``null`` \| `Date` - -The date and time that this task started execution. This is used to determine -the "real" runAt that ended up running the task. This value is only set -when status is set to "running". - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:160 - -___ - -### state - -• **state**: `Record`<`string`, `any`\> - -The state passed into the task's run function, and returned by the previous -run. If there was no previous run, or if the previous run did not return -any state, this will be the empy object: {} - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:188 - -___ - -### taskType - -• **taskType**: `string` - -The task definition type whose run function will execute this instance. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:149 - -___ - -### traceparent - -• `Optional` **traceparent**: `string` - -The serialized traceparent string of the current APM transaction or span. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:192 - -___ - -### user - -• `Optional` **user**: `string` - -The id of the user who scheduled this task. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:196 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskManagerSetupContract.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskManagerSetupContract.md deleted file mode 100644 index 15c8f2fe2b91e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskManagerSetupContract.md +++ /dev/null @@ -1,70 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskManagerSetupContract - -# Interface: TaskManagerSetupContract - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskManagerSetupContract - -## Table of contents - -### Properties - -- [index](client._internal_namespace.TaskManagerSetupContract.md#index) - -### Methods - -- [addMiddleware](client._internal_namespace.TaskManagerSetupContract.md#addmiddleware) -- [registerTaskDefinitions](client._internal_namespace.TaskManagerSetupContract.md#registertaskdefinitions) - -## Properties - -### index - -• **index**: `string` - -**`deprecated`** - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/plugin.d.ts:12 - -## Methods - -### addMiddleware - -▸ **addMiddleware**(`middleware`): `void` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `middleware` | [`Middleware`](client._internal_namespace.Middleware.md) | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/plugin.d.ts:13 - -___ - -### registerTaskDefinitions - -▸ **registerTaskDefinitions**(`taskDefinitions`): `void` - -Method for allowing consumers to register task definitions into the system. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `taskDefinitions` | [`TaskDefinitionRegistry`](../modules/client._internal_namespace.md#taskdefinitionregistry) | The Kibana task definitions dictionary | - -#### Returns - -`void` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/plugin.d.ts:18 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRegisterDefinition.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRegisterDefinition.md deleted file mode 100644 index f5d534feba600..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRegisterDefinition.md +++ /dev/null @@ -1,130 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskRegisterDefinition - -# Interface: TaskRegisterDefinition - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskRegisterDefinition - -Defines a task which can be scheduled and run by the Kibana -task manager. - -## Table of contents - -### Properties - -- [createTaskRunner](client._internal_namespace.TaskRegisterDefinition.md#createtaskrunner) -- [description](client._internal_namespace.TaskRegisterDefinition.md#description) -- [maxAttempts](client._internal_namespace.TaskRegisterDefinition.md#maxattempts) -- [maxConcurrency](client._internal_namespace.TaskRegisterDefinition.md#maxconcurrency) -- [timeout](client._internal_namespace.TaskRegisterDefinition.md#timeout) -- [title](client._internal_namespace.TaskRegisterDefinition.md#title) - -### Methods - -- [getRetry](client._internal_namespace.TaskRegisterDefinition.md#getretry) - -## Properties - -### createTaskRunner - -• **createTaskRunner**: [`TaskRunCreatorFunction`](../modules/client._internal_namespace.md#taskruncreatorfunction) - -Creates an object that has a run function which performs the task's work, -and an optional cancel function which cancels the task. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:35 - -___ - -### description - -• `Optional` **description**: `string` - -An optional more detailed description of what this task does. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:22 - -___ - -### maxAttempts - -• `Optional` **maxAttempts**: `number` - -Up to how many times the task should retry when it fails to run. This will -default to the global variable. The default value, if not specified, is 1. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:40 - -___ - -### maxConcurrency - -• `Optional` **maxConcurrency**: `number` - -The maximum number tasks of this type that can be run concurrently per Kibana instance. -Setting this value will force Task Manager to poll for this task type separately from other task types -which can add significant load to the ES cluster, so please use this configuration only when absolutely necessary. -The default value, if not given, is 0. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:47 - -___ - -### timeout - -• `Optional` **timeout**: `string` - -How long, in minutes or seconds, the system should wait for the task to complete -before it is considered to be timed out. (e.g. '5m', the default). If -the task takes longer than this, Kibana will send it a kill command and -the task will be re-attempted. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:18 - -___ - -### title - -• `Optional` **title**: `string` - -A brief, human-friendly title for this task. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:11 - -## Methods - -### getRetry - -▸ `Optional` **getRetry**(`attempts`, `error`): `boolean` \| `Date` - -Function that customizes how the task should behave when the task fails. This -function can return `true`, `false` or a Date. True will tell task manager -to retry using default delay logic. False will tell task manager to stop retrying -this task. Date will suggest when to the task manager the task should retry. -This function isn't used for recurring tasks, those retry as per their configured recurring schedule. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `attempts` | `number` | -| `error` | `object` | - -#### Returns - -`boolean` \| `Date` - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:30 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRunnerContext.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRunnerContext.md deleted file mode 100644 index d79cef9c996c1..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TaskRunnerContext.md +++ /dev/null @@ -1,89 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TaskRunnerContext - -# Interface: TaskRunnerContext - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TaskRunnerContext - -## Table of contents - -### Properties - -- [actionTypeRegistry](client._internal_namespace.TaskRunnerContext.md#actiontyperegistry) -- [basePathService](client._internal_namespace.TaskRunnerContext.md#basepathservice) -- [encryptedSavedObjectsClient](client._internal_namespace.TaskRunnerContext.md#encryptedsavedobjectsclient) -- [logger](client._internal_namespace.TaskRunnerContext.md#logger) -- [spaceIdToNamespace](client._internal_namespace.TaskRunnerContext.md#spaceidtonamespace) - -### Methods - -- [getUnsecuredSavedObjectsClient](client._internal_namespace.TaskRunnerContext.md#getunsecuredsavedobjectsclient) - -## Properties - -### actionTypeRegistry - -• **actionTypeRegistry**: [`ActionTypeRegistryContract`](../modules/client._internal_namespace.md#actiontyperegistrycontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:8 - -___ - -### basePathService - -• **basePathService**: [`IBasePath`](../modules/client._internal_namespace.md#ibasepath) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:11 - -___ - -### encryptedSavedObjectsClient - -• **encryptedSavedObjectsClient**: [`EncryptedSavedObjectsClient`](client._internal_namespace.EncryptedSavedObjectsClient.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:9 - -___ - -### logger - -• **logger**: `Logger` - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:7 - -___ - -### spaceIdToNamespace - -• **spaceIdToNamespace**: [`SpaceIdToNamespaceFunction`](../modules/client._internal_namespace.md#spaceidtonamespacefunction) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:10 - -## Methods - -### getUnsecuredSavedObjectsClient - -▸ **getUnsecuredSavedObjectsClient**(`request`): [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)<`unknown`, `unknown`, `unknown`, `any`\> | - -#### Returns - -[`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/task_runner_factory.d.ts:12 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md deleted file mode 100644 index 0a44beb8592e7..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / TranslatedUpdateAlertRequest - -# Interface: TranslatedUpdateAlertRequest - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).TranslatedUpdateAlertRequest - -## Table of contents - -### Properties - -- [id](client._internal_namespace.TranslatedUpdateAlertRequest.md#id) -- [index](client._internal_namespace.TranslatedUpdateAlertRequest.md#index) -- [status](client._internal_namespace.TranslatedUpdateAlertRequest.md#status) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:208](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L208) - -___ - -### index - -• **index**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:209](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L209) - -___ - -### status - -• **status**: `STATUS_VALUES` - -#### Defined in - -[x-pack/plugins/cases/server/services/alerts/index.ts:210](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/alerts/index.ts#L210) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateAlertRequest.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateAlertRequest.md deleted file mode 100644 index 53ee404bbf12a..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateAlertRequest.md +++ /dev/null @@ -1,45 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UpdateAlertRequest - -# Interface: UpdateAlertRequest - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UpdateAlertRequest - -Defines the fields necessary to update an alert's status. - -## Table of contents - -### Properties - -- [id](client._internal_namespace.UpdateAlertRequest.md#id) -- [index](client._internal_namespace.UpdateAlertRequest.md#index) -- [status](client._internal_namespace.UpdateAlertRequest.md#status) - -## Properties - -### id - -• **id**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/client/alerts/types.ts:28](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/alerts/types.ts#L28) - -___ - -### index - -• **index**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/client/alerts/types.ts:29](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/alerts/types.ts#L29) - -___ - -### status - -• **status**: [`CaseStatuses`](../enums/client._internal_namespace.CaseStatuses.md) - -#### Defined in - -[x-pack/plugins/cases/server/client/alerts/types.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/alerts/types.ts#L30) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateArgs.md deleted file mode 100644 index c0f6cf3d0d1a2..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateArgs.md +++ /dev/null @@ -1,43 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UpdateArgs - -# Interface: UpdateArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UpdateArgs - -## Table of contents - -### Properties - -- [attachmentId](client._internal_namespace.UpdateArgs.md#attachmentid) -- [options](client._internal_namespace.UpdateArgs.md#options) -- [updatedAttributes](client._internal_namespace.UpdateArgs.md#updatedattributes) - -## Properties - -### attachmentId - -• **attachmentId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:54](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L54) - -___ - -### options - -• `Optional` **options**: [`SavedObjectsUpdateOptions`](client._internal_namespace.SavedObjectsUpdateOptions.md)<{ `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } \| { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } }\> - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:56](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L56) - -___ - -### updatedAttributes - -• **updatedAttributes**: { `created_at`: `undefined` \| `string` = rt.string; `created_by`: `undefined` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } = UserRT; `owner`: `undefined` \| `string` = rt.string; `pushed_at`: `undefined` \| ``null`` \| `string` ; `pushed_by`: `undefined` \| ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } ; `updated_at`: `undefined` \| ``null`` \| `string` ; `updated_by`: `undefined` \| ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } } & { `alertId`: `undefined` \| `string` \| `string`[] ; `index`: `undefined` \| `string` \| `string`[] ; `owner`: `undefined` \| `string` = rt.string; `rule`: `undefined` \| { `id`: ``null`` \| `string` ; `name`: ``null`` \| `string` } ; `type`: `undefined` \| [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `undefined` \| `string` = rt.string; `created_by`: `undefined` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } = UserRT; `owner`: `undefined` \| `string` = rt.string; `pushed_at`: `undefined` \| ``null`` \| `string` ; `pushed_by`: `undefined` \| ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } ; `updated_at`: `undefined` \| ``null`` \| `string` ; `updated_by`: `undefined` \| ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } } - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:55](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L55) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateConnectorMappingsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateConnectorMappingsArgs.md deleted file mode 100644 index 4af6344e575d6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateConnectorMappingsArgs.md +++ /dev/null @@ -1,64 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UpdateConnectorMappingsArgs - -# Interface: UpdateConnectorMappingsArgs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UpdateConnectorMappingsArgs - -## Hierarchy - -- [`ClientArgs`](client._internal_namespace.ClientArgs-2.md) - - ↳ **`UpdateConnectorMappingsArgs`** - -## Table of contents - -### Properties - -- [attributes](client._internal_namespace.UpdateConnectorMappingsArgs.md#attributes) -- [mappingId](client._internal_namespace.UpdateConnectorMappingsArgs.md#mappingid) -- [references](client._internal_namespace.UpdateConnectorMappingsArgs.md#references) -- [unsecuredSavedObjectsClient](client._internal_namespace.UpdateConnectorMappingsArgs.md#unsecuredsavedobjectsclient) - -## Properties - -### attributes - -• **attributes**: `Partial`<{ `mappings`: { action\_type: "append" \| "nothing" \| "overwrite"; source: "description" \| "title" \| "comments"; target: string; }[] ; `owner`: `string` = rt.string }\> - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:28](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L28) - -___ - -### mappingId - -• **mappingId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:27](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L27) - -___ - -### references - -• **references**: [`SavedObjectReference`](client._internal_namespace.SavedObjectReference.md)[] - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:29](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L29) - -___ - -### unsecuredSavedObjectsClient - -• **unsecuredSavedObjectsClient**: [`SavedObjectsClientContract`](../modules/client._internal_namespace.md#savedobjectsclientcontract) - -#### Inherited from - -[ClientArgs](client._internal_namespace.ClientArgs-2.md).[unsecuredSavedObjectsClient](client._internal_namespace.ClientArgs-2.md#unsecuredsavedobjectsclient) - -#### Defined in - -[x-pack/plugins/cases/server/services/connector_mappings/index.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/connector_mappings/index.ts#L15) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions-1.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions-1.md deleted file mode 100644 index cd8125ed13bf5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions-1.md +++ /dev/null @@ -1,54 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UpdateOptions - -# Interface: UpdateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UpdateOptions - -## Table of contents - -### Properties - -- [expiresAtMillis](client._internal_namespace.UpdateOptions-1.md#expiresatmillis) -- [id](client._internal_namespace.UpdateOptions-1.md#id) -- [token](client._internal_namespace.UpdateOptions-1.md#token) -- [tokenType](client._internal_namespace.UpdateOptions-1.md#tokentype) - -## Properties - -### expiresAtMillis - -• **expiresAtMillis**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:19 - -___ - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:17 - -___ - -### token - -• **token**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:18 - -___ - -### tokenType - -• `Optional` **tokenType**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/builtin_action_types/lib/connector_token_client.d.ts:20 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions.md deleted file mode 100644 index f1bc374522175..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UpdateOptions.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UpdateOptions - -# Interface: UpdateOptions - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UpdateOptions - -## Table of contents - -### Properties - -- [action](client._internal_namespace.UpdateOptions.md#action) -- [id](client._internal_namespace.UpdateOptions.md#id) - -## Properties - -### action - -• **action**: [`ActionUpdate`](client._internal_namespace.ActionUpdate.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:41 - -___ - -### id - -• **id**: `string` - -#### Defined in - -x-pack/plugins/actions/target/types/server/actions_client.d.ts:40 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.User.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.User.md deleted file mode 100644 index 947805536297f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.User.md +++ /dev/null @@ -1,90 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / User - -# Interface: User - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).User - -## Hierarchy - -- **`User`** - - ↳ [`AuthenticatedUser`](client._internal_namespace.AuthenticatedUser.md) - -## Table of contents - -### Properties - -- [email](client._internal_namespace.User.md#email) -- [enabled](client._internal_namespace.User.md#enabled) -- [full\_name](client._internal_namespace.User.md#full_name) -- [metadata](client._internal_namespace.User.md#metadata) -- [roles](client._internal_namespace.User.md#roles) -- [username](client._internal_namespace.User.md#username) - -## Properties - -### email - -• `Optional` **email**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:3 - -___ - -### enabled - -• **enabled**: `boolean` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:6 - -___ - -### full\_name - -• `Optional` **full\_name**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:4 - -___ - -### metadata - -• `Optional` **metadata**: `Object` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `_deprecated?` | `boolean` | -| `_deprecated_reason?` | `string` | -| `_reserved` | `boolean` | - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:7 - -___ - -### roles - -• **roles**: readonly `string`[] - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:5 - -___ - -### username - -• **username**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/user.d.ts:2 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UserRealm.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UserRealm.md deleted file mode 100644 index 2d1d75692a0e0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.UserRealm.md +++ /dev/null @@ -1,32 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / UserRealm - -# Interface: UserRealm - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).UserRealm - -## Table of contents - -### Properties - -- [name](client._internal_namespace.UserRealm.md#name) -- [type](client._internal_namespace.UserRealm.md#type) - -## Properties - -### name - -• **name**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authenticated_user.d.ts:4 - -___ - -### type - -• **type**: `string` - -#### Defined in - -x-pack/plugins/security/target/types/common/model/authenticated_user.d.ts:5 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ValidatorType.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ValidatorType.md deleted file mode 100644 index c771a20cde115..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.ValidatorType.md +++ /dev/null @@ -1,37 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / ValidatorType - -# Interface: ValidatorType - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).ValidatorType - -## Type parameters - -| Name | -| :------ | -| `Type` | - -## Table of contents - -### Methods - -- [validate](client._internal_namespace.ValidatorType.md#validate) - -## Methods - -### validate - -▸ **validate**(`value`): `Type` - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `value` | `unknown` | - -#### Returns - -`Type` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:64 diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Verbs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Verbs.md deleted file mode 100644 index 6234a71241e99..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/client._internal_namespace.Verbs.md +++ /dev/null @@ -1,45 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](../modules/client.md) / [\_internal\_namespace](../modules/client._internal_namespace.md) / Verbs - -# Interface: Verbs - -[client](../modules/client.md).[_internal_namespace](../modules/client._internal_namespace.md).Verbs - -The tenses for describing the action performed by a API route - -## Table of contents - -### Properties - -- [past](client._internal_namespace.Verbs.md#past) -- [present](client._internal_namespace.Verbs.md#present) -- [progressive](client._internal_namespace.Verbs.md#progressive) - -## Properties - -### past - -• **past**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:18](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L18) - -___ - -### present - -• **present**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:16](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L16) - -___ - -### progressive - -• **progressive**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:17](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L17) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.CreateMappingsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.CreateMappingsArgs.md deleted file mode 100644 index 14e3f0fc93459..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.CreateMappingsArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [configure/client](../modules/configure_client.md) / [\_internal\_namespace](../modules/configure_client._internal_namespace.md) / CreateMappingsArgs - -# Interface: CreateMappingsArgs - -[configure/client](../modules/configure_client.md).[_internal_namespace](../modules/configure_client._internal_namespace.md).CreateMappingsArgs - -## Hierarchy - -- [`MappingsArgs`](configure_client._internal_namespace.MappingsArgs.md) - - ↳ **`CreateMappingsArgs`** - -## Table of contents - -### Properties - -- [connector](configure_client._internal_namespace.CreateMappingsArgs.md#connector) -- [owner](configure_client._internal_namespace.CreateMappingsArgs.md#owner) - -## Properties - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } - -#### Inherited from - -[MappingsArgs](configure_client._internal_namespace.MappingsArgs.md).[connector](configure_client._internal_namespace.MappingsArgs.md#connector) - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/types.ts:11](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/types.ts#L11) - -___ - -### owner - -• **owner**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/types.ts:15](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/types.ts#L15) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.MappingsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.MappingsArgs.md deleted file mode 100644 index b21de0e3f9018..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.MappingsArgs.md +++ /dev/null @@ -1,29 +0,0 @@ -[Cases Client API Interface](../README.md) / [configure/client](../modules/configure_client.md) / [\_internal\_namespace](../modules/configure_client._internal_namespace.md) / MappingsArgs - -# Interface: MappingsArgs - -[configure/client](../modules/configure_client.md).[_internal_namespace](../modules/configure_client._internal_namespace.md).MappingsArgs - -## Hierarchy - -- **`MappingsArgs`** - - ↳ [`CreateMappingsArgs`](configure_client._internal_namespace.CreateMappingsArgs.md) - - ↳ [`UpdateMappingsArgs`](configure_client._internal_namespace.UpdateMappingsArgs.md) - -## Table of contents - -### Properties - -- [connector](configure_client._internal_namespace.MappingsArgs.md#connector) - -## Properties - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/types.ts:11](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/types.ts#L11) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.UpdateMappingsArgs.md b/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.UpdateMappingsArgs.md deleted file mode 100644 index e81c67f5bd4a0..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client._internal_namespace.UpdateMappingsArgs.md +++ /dev/null @@ -1,42 +0,0 @@ -[Cases Client API Interface](../README.md) / [configure/client](../modules/configure_client.md) / [\_internal\_namespace](../modules/configure_client._internal_namespace.md) / UpdateMappingsArgs - -# Interface: UpdateMappingsArgs - -[configure/client](../modules/configure_client.md).[_internal_namespace](../modules/configure_client._internal_namespace.md).UpdateMappingsArgs - -## Hierarchy - -- [`MappingsArgs`](configure_client._internal_namespace.MappingsArgs.md) - - ↳ **`UpdateMappingsArgs`** - -## Table of contents - -### Properties - -- [connector](configure_client._internal_namespace.UpdateMappingsArgs.md#connector) -- [mappingId](configure_client._internal_namespace.UpdateMappingsArgs.md#mappingid) - -## Properties - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } - -#### Inherited from - -[MappingsArgs](configure_client._internal_namespace.MappingsArgs.md).[connector](configure_client._internal_namespace.MappingsArgs.md#connector) - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/types.ts:11](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/types.ts#L11) - -___ - -### mappingId - -• **mappingId**: `string` - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/types.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/types.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client.configuresubclient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client.configuresubclient.md deleted file mode 100644 index 393957ba1c7f5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/configure_client.configuresubclient.md +++ /dev/null @@ -1,100 +0,0 @@ -[Cases Client API Interface](../README.md) / [configure/client](../modules/configure_client.md) / ConfigureSubClient - -# Interface: ConfigureSubClient - -[configure/client](../modules/configure_client.md).ConfigureSubClient - -This is the public API for interacting with the connector configuration for cases. - -## Table of contents - -### Methods - -- [create](configure_client.ConfigureSubClient.md#create) -- [get](configure_client.ConfigureSubClient.md#get) -- [getConnectors](configure_client.ConfigureSubClient.md#getconnectors) -- [update](configure_client.ConfigureSubClient.md#update) - -## Methods - -### create - -▸ **create**(`configuration`): `Promise`<[`ICasesConfigureResponse`](typedoc_interfaces.ICasesConfigureResponse.md)\> - -Creates a configuration if one does not already exist. If one exists it is deleted and a new one is created. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `configuration` | [`ICasesConfigureRequest`](typedoc_interfaces.ICasesConfigureRequest.md) | - -#### Returns - -`Promise`<[`ICasesConfigureResponse`](typedoc_interfaces.ICasesConfigureResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/client.ts:93](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/client.ts#L93) - -___ - -### get - -▸ **get**(`params`): `Promise`<{} \| [`ICasesConfigureResponse`](typedoc_interfaces.ICasesConfigureResponse.md)\> - -Retrieves the external connector configuration for a particular case owner. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Object` | -| `params.owner` | `undefined` \| `string` \| `string`[] | - -#### Returns - -`Promise`<{} \| [`ICasesConfigureResponse`](typedoc_interfaces.ICasesConfigureResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/client.ts:75](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/client.ts#L75) - -___ - -### getConnectors - -▸ **getConnectors**(): `Promise`<[`FindActionResult`](client._internal_namespace.FindActionResult.md)[]\> - -Retrieves the valid external connectors supported by the cases plugin. - -#### Returns - -`Promise`<[`FindActionResult`](client._internal_namespace.FindActionResult.md)[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/client.ts:79](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/client.ts#L79) - -___ - -### update - -▸ **update**(`configurationId`, `configurations`): `Promise`<[`ICasesConfigureResponse`](typedoc_interfaces.ICasesConfigureResponse.md)\> - -Updates a particular configuration with new values. - -#### Parameters - -| Name | Type | Description | -| :------ | :------ | :------ | -| `configurationId` | `string` | the ID of the configuration to update | -| `configurations` | [`ICasesConfigurePatch`](typedoc_interfaces.ICasesConfigurePatch.md) | the new configuration parameters | - -#### Returns - -`Promise`<[`ICasesConfigureResponse`](typedoc_interfaces.ICasesConfigureResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/client.ts:86](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/client.ts#L86) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client.MetricsSubClient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client.MetricsSubClient.md deleted file mode 100644 index c59b437c7f23e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client.MetricsSubClient.md +++ /dev/null @@ -1,33 +0,0 @@ -[Cases Client API Interface](../README.md) / [metrics/client](../modules/metrics_client.md) / MetricsSubClient - -# Interface: MetricsSubClient - -[metrics/client](../modules/metrics_client.md).MetricsSubClient - -API for interacting with the metrics. - -## Table of contents - -### Methods - -- [getCaseMetrics](metrics_client.MetricsSubClient.md#getcasemetrics) - -## Methods - -### getCaseMetrics - -▸ **getCaseMetrics**(`params`): `Promise`<{ `actions`: `undefined` \| { isolateHost?: { isolate: { total: number; }; unisolate: { total: number; }; } \| undefined; } ; `alerts`: `undefined` \| { count?: number \| undefined; hosts?: { total: number; values: { name: string \| undefined; id: string; count: number; }[]; } \| undefined; users?: { total: number; values: { name: string; count: number; }[]; } \| undefined; } ; `connectors`: `undefined` \| { `total`: `number` = rt.number } ; `lifespan`: `undefined` \| { `closeDate`: ``null`` \| `string` ; `creationDate`: `string` = rt.string; `statusInfo`: { openDuration: number; inProgressDuration: number; reopenDates: string[]; } = StatusInfoRt } }\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | [`CaseMetricsParams`](metrics_client._internal_namespace.CaseMetricsParams.md) | - -#### Returns - -`Promise`<{ `actions`: `undefined` \| { isolateHost?: { isolate: { total: number; }; unisolate: { total: number; }; } \| undefined; } ; `alerts`: `undefined` \| { count?: number \| undefined; hosts?: { total: number; values: { name: string \| undefined; id: string; count: number; }[]; } \| undefined; users?: { total: number; values: { name: string; count: number; }[]; } \| undefined; } ; `connectors`: `undefined` \| { `total`: `number` = rt.number } ; `lifespan`: `undefined` \| { `closeDate`: ``null`` \| `string` ; `creationDate`: `string` = rt.string; `statusInfo`: { openDuration: number; inProgressDuration: number; reopenDates: string[]; } = StatusInfoRt } }\> - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/client.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/client.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client._internal_namespace.CaseMetricsParams.md b/x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client._internal_namespace.CaseMetricsParams.md deleted file mode 100644 index 8f03bed67e646..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/metrics_client._internal_namespace.CaseMetricsParams.md +++ /dev/null @@ -1,36 +0,0 @@ -[Cases Client API Interface](../README.md) / [metrics/client](../modules/metrics_client.md) / [\_internal\_namespace](../modules/metrics_client._internal_namespace.md) / CaseMetricsParams - -# Interface: CaseMetricsParams - -[metrics/client](../modules/metrics_client.md).[_internal_namespace](../modules/metrics_client._internal_namespace.md).CaseMetricsParams - -## Table of contents - -### Properties - -- [caseId](metrics_client._internal_namespace.CaseMetricsParams.md#caseid) -- [features](metrics_client._internal_namespace.CaseMetricsParams.md#features) - -## Properties - -### caseId - -• **caseId**: `string` - -The ID of the case. - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/get_case_metrics.ts:26](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/get_case_metrics.ts#L26) - -___ - -### features - -• **features**: `string`[] - -The metrics to retrieve. - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/get_case_metrics.ts:30](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/get_case_metrics.ts#L30) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/stats_client.statssubclient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/stats_client.statssubclient.md deleted file mode 100644 index 37dab1782ee06..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/stats_client.statssubclient.md +++ /dev/null @@ -1,36 +0,0 @@ -[Cases Client API Interface](../README.md) / [stats/client](../modules/stats_client.md) / StatsSubClient - -# Interface: StatsSubClient - -[stats/client](../modules/stats_client.md).StatsSubClient - -Statistics API contract. - -## Table of contents - -### Methods - -- [getStatusTotalsByType](stats_client.StatsSubClient.md#getstatustotalsbytype) - -## Methods - -### getStatusTotalsByType - -▸ **getStatusTotalsByType**(`params`): `Promise`<{ `count_closed_cases`: `number` = rt.number; `count_in_progress_cases`: `number` = rt.number; `count_open_cases`: `number` = rt.number }\> - -Retrieves the total number of open, closed, and in-progress cases. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Object` | -| `params.owner` | `undefined` \| `string` \| `string`[] | - -#### Returns - -`Promise`<{ `count_closed_cases`: `number` = rt.number; `count_in_progress_cases`: `number` = rt.number; `count_open_cases`: `number` = rt.number }\> - -#### Defined in - -[x-pack/plugins/cases/server/client/stats/client.ts:34](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/stats/client.ts#L34) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.ICaseResolveResponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.ICaseResolveResponse.md deleted file mode 100644 index a428247ab70ba..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.ICaseResolveResponse.md +++ /dev/null @@ -1,49 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICaseResolveResponse - -# Interface: ICaseResolveResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICaseResolveResponse - -## Hierarchy - -- [`CaseResolveResponse`](../modules/typedoc_interfaces._internal_namespace.md#caseresolveresponse) - - ↳ **`ICaseResolveResponse`** - -## Table of contents - -### Properties - -- [alias\_target\_id](typedoc_interfaces.ICaseResolveResponse.md#alias_target_id) -- [case](typedoc_interfaces.ICaseResolveResponse.md#case) -- [outcome](typedoc_interfaces.ICaseResolveResponse.md#outcome) - -## Properties - -### alias\_target\_id - -• **alias\_target\_id**: `undefined` \| `string` = `rt.string` - -#### Inherited from - -CaseResolveResponse.alias\_target\_id - -___ - -### case - -• **case**: { `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `totalAlerts`: `number` = rt.number; `totalComment`: `number` = rt.number; `version`: `string` = rt.string } & { `comments`: `undefined` \| { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }[] } = `CaseResponseRt` - -#### Inherited from - -CaseResolveResponse.case - -___ - -### outcome - -• **outcome**: ``"exactMatch"`` \| ``"aliasMatch"`` \| ``"conflict"`` - -#### Inherited from - -CaseResolveResponse.outcome diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.iallcommentsresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.iallcommentsresponse.md deleted file mode 100644 index e4d0d7cdaa594..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.iallcommentsresponse.md +++ /dev/null @@ -1,11 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / IAllCommentsResponse - -# Interface: IAllCommentsResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).IAllCommentsResponse - -## Hierarchy - -- [`AllCommentsResponse`](../modules/typedoc_interfaces._internal_namespace.md#allcommentsresponse) - - ↳ **`IAllCommentsResponse`** diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasepostrequest.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasepostrequest.md deleted file mode 100644 index bcca7301539f5..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasepostrequest.md +++ /dev/null @@ -1,91 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasePostRequest - -# Interface: ICasePostRequest - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasePostRequest - -These are simply to make typedoc not attempt to expand the type aliases. If it attempts to expand them -the docs are huge. - -## Hierarchy - -- [`CasePostRequest`](../modules/typedoc_interfaces._internal_namespace.md#casepostrequest) - - ↳ **`ICasePostRequest`** - -## Table of contents - -### Properties - -- [connector](typedoc_interfaces.ICasePostRequest.md#connector) -- [description](typedoc_interfaces.ICasePostRequest.md#description) -- [owner](typedoc_interfaces.ICasePostRequest.md#owner) -- [settings](typedoc_interfaces.ICasePostRequest.md#settings) -- [tags](typedoc_interfaces.ICasePostRequest.md#tags) -- [title](typedoc_interfaces.ICasePostRequest.md#title) - -## Properties - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = `CaseConnectorRt` - -#### Inherited from - -CasePostRequest.connector - -___ - -### description - -• **description**: `string` = `rt.string` - -#### Inherited from - -CasePostRequest.description - -___ - -### owner - -• **owner**: `string` = `rt.string` - -#### Inherited from - -CasePostRequest.owner - -___ - -### settings - -• **settings**: `Object` = `SettingsRt` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `syncAlerts` | `boolean` | - -#### Inherited from - -CasePostRequest.settings - -___ - -### tags - -• **tags**: `string`[] - -#### Inherited from - -CasePostRequest.tags - -___ - -### title - -• **title**: `string` = `rt.string` - -#### Inherited from - -CasePostRequest.title diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseresponse.md deleted file mode 100644 index 5a323c8095768..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseresponse.md +++ /dev/null @@ -1,239 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICaseResponse - -# Interface: ICaseResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICaseResponse - -## Hierarchy - -- [`CaseResponse`](../modules/typedoc_interfaces._internal_namespace.md#caseresponse) - - ↳ **`ICaseResponse`** - -## Table of contents - -### Properties - -- [closed\_at](typedoc_interfaces.ICaseResponse.md#closed_at) -- [closed\_by](typedoc_interfaces.ICaseResponse.md#closed_by) -- [comments](typedoc_interfaces.ICaseResponse.md#comments) -- [connector](typedoc_interfaces.ICaseResponse.md#connector) -- [created\_at](typedoc_interfaces.ICaseResponse.md#created_at) -- [created\_by](typedoc_interfaces.ICaseResponse.md#created_by) -- [description](typedoc_interfaces.ICaseResponse.md#description) -- [external\_service](typedoc_interfaces.ICaseResponse.md#external_service) -- [id](typedoc_interfaces.ICaseResponse.md#id) -- [owner](typedoc_interfaces.ICaseResponse.md#owner) -- [settings](typedoc_interfaces.ICaseResponse.md#settings) -- [status](typedoc_interfaces.ICaseResponse.md#status) -- [tags](typedoc_interfaces.ICaseResponse.md#tags) -- [title](typedoc_interfaces.ICaseResponse.md#title) -- [totalAlerts](typedoc_interfaces.ICaseResponse.md#totalalerts) -- [totalComment](typedoc_interfaces.ICaseResponse.md#totalcomment) -- [updated\_at](typedoc_interfaces.ICaseResponse.md#updated_at) -- [updated\_by](typedoc_interfaces.ICaseResponse.md#updated_by) -- [version](typedoc_interfaces.ICaseResponse.md#version) - -## Properties - -### closed\_at - -• **closed\_at**: ``null`` \| `string` - -#### Inherited from - -CaseResponse.closed\_at - -___ - -### closed\_by - -• **closed\_by**: ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } - -#### Inherited from - -CaseResponse.closed\_by - -___ - -### comments - -• **comments**: `undefined` \| { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }[] - -#### Inherited from - -CaseResponse.comments - -___ - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = `CaseConnectorRt` - -#### Inherited from - -CaseResponse.connector - -___ - -### created\_at - -• **created\_at**: `string` = `rt.string` - -#### Inherited from - -CaseResponse.created\_at - -___ - -### created\_by - -• **created\_by**: `Object` = `UserRT` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Inherited from - -CaseResponse.created\_by - -___ - -### description - -• **description**: `string` = `rt.string` - -#### Inherited from - -CaseResponse.description - -___ - -### external\_service - -• **external\_service**: ``null`` \| { `connector_id`: `string` = rt.string } & { `connector_name`: `string` = rt.string; `external_id`: `string` = rt.string; `external_title`: `string` = rt.string; `external_url`: `string` = rt.string; `pushed_at`: `string` = rt.string; `pushed_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT } = `CaseFullExternalServiceRt` - -#### Inherited from - -CaseResponse.external\_service - -___ - -### id - -• **id**: `string` = `rt.string` - -#### Inherited from - -CaseResponse.id - -___ - -### owner - -• **owner**: `string` = `rt.string` - -#### Inherited from - -CaseResponse.owner - -___ - -### settings - -• **settings**: `Object` = `SettingsRt` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `syncAlerts` | `boolean` | - -#### Inherited from - -CaseResponse.settings - -___ - -### status - -• **status**: `CaseStatuses` = `CaseStatusRt` - -#### Inherited from - -CaseResponse.status - -___ - -### tags - -• **tags**: `string`[] - -#### Inherited from - -CaseResponse.tags - -___ - -### title - -• **title**: `string` = `rt.string` - -#### Inherited from - -CaseResponse.title - -___ - -### totalAlerts - -• **totalAlerts**: `number` = `rt.number` - -#### Inherited from - -CaseResponse.totalAlerts - -___ - -### totalComment - -• **totalComment**: `number` = `rt.number` - -#### Inherited from - -CaseResponse.totalComment - -___ - -### updated\_at - -• **updated\_at**: ``null`` \| `string` - -#### Inherited from - -CaseResponse.updated\_at - -___ - -### updated\_by - -• **updated\_by**: ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } - -#### Inherited from - -CaseResponse.updated\_by - -___ - -### version - -• **version**: `string` = `rt.string` - -#### Inherited from - -CaseResponse.version diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurepatch.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurepatch.md deleted file mode 100644 index b645740febc08..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurepatch.md +++ /dev/null @@ -1,49 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesConfigurePatch - -# Interface: ICasesConfigurePatch - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesConfigurePatch - -## Hierarchy - -- [`CasesConfigurePatch`](../modules/typedoc_interfaces._internal_namespace.md#casesconfigurepatch) - - ↳ **`ICasesConfigurePatch`** - -## Table of contents - -### Properties - -- [closure\_type](typedoc_interfaces.ICasesConfigurePatch.md#closure_type) -- [connector](typedoc_interfaces.ICasesConfigurePatch.md#connector) -- [version](typedoc_interfaces.ICasesConfigurePatch.md#version) - -## Properties - -### closure\_type - -• **closure\_type**: `undefined` \| ``"close-by-user"`` \| ``"close-by-pushing"`` = `ClosureTypeRT` - -#### Inherited from - -CasesConfigurePatch.closure\_type - -___ - -### connector - -• **connector**: `undefined` \| { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = `CaseConnectorRt` - -#### Inherited from - -CasesConfigurePatch.connector - -___ - -### version - -• **version**: `string` = `rt.string` - -#### Inherited from - -CasesConfigurePatch.version diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurerequest.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurerequest.md deleted file mode 100644 index 5dc7249d20f57..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigurerequest.md +++ /dev/null @@ -1,49 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesConfigureRequest - -# Interface: ICasesConfigureRequest - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesConfigureRequest - -## Hierarchy - -- [`CasesConfigureRequest`](../modules/typedoc_interfaces._internal_namespace.md#casesconfigurerequest) - - ↳ **`ICasesConfigureRequest`** - -## Table of contents - -### Properties - -- [closure\_type](typedoc_interfaces.ICasesConfigureRequest.md#closure_type) -- [connector](typedoc_interfaces.ICasesConfigureRequest.md#connector) -- [owner](typedoc_interfaces.ICasesConfigureRequest.md#owner) - -## Properties - -### closure\_type - -• **closure\_type**: ``"close-by-user"`` \| ``"close-by-pushing"`` = `ClosureTypeRT` - -#### Inherited from - -CasesConfigureRequest.closure\_type - -___ - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = `CaseConnectorRt` - -#### Inherited from - -CasesConfigureRequest.connector - -___ - -### owner - -• **owner**: `string` = `rt.string` - -#### Inherited from - -CasesConfigureRequest.owner diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigureresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigureresponse.md deleted file mode 100644 index 20754bcaa22b6..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesconfigureresponse.md +++ /dev/null @@ -1,145 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesConfigureResponse - -# Interface: ICasesConfigureResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesConfigureResponse - -## Hierarchy - -- [`CasesConfigureResponse`](../modules/typedoc_interfaces._internal_namespace.md#casesconfigureresponse) - - ↳ **`ICasesConfigureResponse`** - -## Table of contents - -### Properties - -- [closure\_type](typedoc_interfaces.ICasesConfigureResponse.md#closure_type) -- [connector](typedoc_interfaces.ICasesConfigureResponse.md#connector) -- [created\_at](typedoc_interfaces.ICasesConfigureResponse.md#created_at) -- [created\_by](typedoc_interfaces.ICasesConfigureResponse.md#created_by) -- [error](typedoc_interfaces.ICasesConfigureResponse.md#error) -- [id](typedoc_interfaces.ICasesConfigureResponse.md#id) -- [mappings](typedoc_interfaces.ICasesConfigureResponse.md#mappings) -- [owner](typedoc_interfaces.ICasesConfigureResponse.md#owner) -- [updated\_at](typedoc_interfaces.ICasesConfigureResponse.md#updated_at) -- [updated\_by](typedoc_interfaces.ICasesConfigureResponse.md#updated_by) -- [version](typedoc_interfaces.ICasesConfigureResponse.md#version) - -## Properties - -### closure\_type - -• **closure\_type**: ``"close-by-user"`` \| ``"close-by-pushing"`` = `ClosureTypeRT` - -#### Inherited from - -CasesConfigureResponse.closure\_type - -___ - -### connector - -• **connector**: { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = `CaseConnectorRt` - -#### Inherited from - -CasesConfigureResponse.connector - -___ - -### created\_at - -• **created\_at**: `string` = `rt.string` - -#### Inherited from - -CasesConfigureResponse.created\_at - -___ - -### created\_by - -• **created\_by**: `Object` = `UserRT` - -#### Type declaration - -| Name | Type | -| :------ | :------ | -| `email` | `undefined` \| ``null`` \| `string` | -| `full_name` | `undefined` \| ``null`` \| `string` | -| `username` | `undefined` \| ``null`` \| `string` | - -#### Inherited from - -CasesConfigureResponse.created\_by - -___ - -### error - -• **error**: ``null`` \| `string` - -#### Inherited from - -CasesConfigureResponse.error - -___ - -### id - -• **id**: `string` = `rt.string` - -#### Inherited from - -CasesConfigureResponse.id - -___ - -### mappings - -• **mappings**: { `action_type`: ``"append"`` \| ``"nothing"`` \| ``"overwrite"`` = ActionTypeRT; `source`: ``"description"`` \| ``"title"`` \| ``"comments"`` = CaseFieldRT; `target`: `string` = ThirdPartyFieldRT }[] - -#### Inherited from - -CasesConfigureResponse.mappings - -___ - -### owner - -• **owner**: `string` = `rt.string` - -#### Inherited from - -CasesConfigureResponse.owner - -___ - -### updated\_at - -• **updated\_at**: ``null`` \| `string` - -#### Inherited from - -CasesConfigureResponse.updated\_at - -___ - -### updated\_by - -• **updated\_by**: ``null`` \| { `email`: `undefined` \| ``null`` \| `string` ; `full_name`: `undefined` \| ``null`` \| `string` ; `username`: `undefined` \| ``null`` \| `string` } - -#### Inherited from - -CasesConfigureResponse.updated\_by - -___ - -### version - -• **version**: `string` = `rt.string` - -#### Inherited from - -CasesConfigureResponse.version diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindrequest.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindrequest.md deleted file mode 100644 index b9cc22c6eee44..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindrequest.md +++ /dev/null @@ -1,148 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesFindRequest - -# Interface: ICasesFindRequest - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesFindRequest - -## Hierarchy - -- [`CasesFindRequest`](../modules/client._internal_namespace.md#casesfindrequest) - - ↳ **`ICasesFindRequest`** - -## Table of contents - -### Properties - -- [defaultSearchOperator](typedoc_interfaces.ICasesFindRequest.md#defaultsearchoperator) -- [fields](typedoc_interfaces.ICasesFindRequest.md#fields) -- [owner](typedoc_interfaces.ICasesFindRequest.md#owner) -- [page](typedoc_interfaces.ICasesFindRequest.md#page) -- [perPage](typedoc_interfaces.ICasesFindRequest.md#perpage) -- [reporters](typedoc_interfaces.ICasesFindRequest.md#reporters) -- [search](typedoc_interfaces.ICasesFindRequest.md#search) -- [searchFields](typedoc_interfaces.ICasesFindRequest.md#searchfields) -- [sortField](typedoc_interfaces.ICasesFindRequest.md#sortfield) -- [sortOrder](typedoc_interfaces.ICasesFindRequest.md#sortorder) -- [status](typedoc_interfaces.ICasesFindRequest.md#status) -- [tags](typedoc_interfaces.ICasesFindRequest.md#tags) - -## Properties - -### defaultSearchOperator - -• **defaultSearchOperator**: `undefined` \| ``"AND"`` \| ``"OR"`` - -#### Inherited from - -CasesFindRequest.defaultSearchOperator - -___ - -### fields - -• **fields**: `undefined` \| `string`[] - -#### Inherited from - -CasesFindRequest.fields - -___ - -### owner - -• **owner**: `undefined` \| `string` \| `string`[] - -#### Inherited from - -CasesFindRequest.owner - -___ - -### page - -• **page**: `undefined` \| `number` = `NumberFromString` - -#### Inherited from - -CasesFindRequest.page - -___ - -### perPage - -• **perPage**: `undefined` \| `number` = `NumberFromString` - -#### Inherited from - -CasesFindRequest.perPage - -___ - -### reporters - -• **reporters**: `undefined` \| `string` \| `string`[] - -#### Inherited from - -CasesFindRequest.reporters - -___ - -### search - -• **search**: `undefined` \| `string` = `rt.string` - -#### Inherited from - -CasesFindRequest.search - -___ - -### searchFields - -• **searchFields**: `undefined` \| `string` \| `string`[] - -#### Inherited from - -CasesFindRequest.searchFields - -___ - -### sortField - -• **sortField**: `undefined` \| `string` = `rt.string` - -#### Inherited from - -CasesFindRequest.sortField - -___ - -### sortOrder - -• **sortOrder**: `undefined` \| ``"desc"`` \| ``"asc"`` - -#### Inherited from - -CasesFindRequest.sortOrder - -___ - -### status - -• **status**: `undefined` \| [`open`](../enums/client._internal_namespace.CaseStatuses.md#open) \| `any`[`any`] \| [`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed) = `CaseStatusRt` - -#### Inherited from - -CasesFindRequest.status - -___ - -### tags - -• **tags**: `undefined` \| `string` \| `string`[] - -#### Inherited from - -CasesFindRequest.tags diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindresponse.md deleted file mode 100644 index 16b88c29d4d8e..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesfindresponse.md +++ /dev/null @@ -1,93 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesFindResponse - -# Interface: ICasesFindResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesFindResponse - -## Hierarchy - -- [`CasesFindResponse`](../modules/typedoc_interfaces._internal_namespace.md#casesfindresponse) - - ↳ **`ICasesFindResponse`** - -## Table of contents - -### Properties - -- [cases](typedoc_interfaces.ICasesFindResponse.md#cases) -- [count\_closed\_cases](typedoc_interfaces.ICasesFindResponse.md#count_closed_cases) -- [count\_in\_progress\_cases](typedoc_interfaces.ICasesFindResponse.md#count_in_progress_cases) -- [count\_open\_cases](typedoc_interfaces.ICasesFindResponse.md#count_open_cases) -- [page](typedoc_interfaces.ICasesFindResponse.md#page) -- [per\_page](typedoc_interfaces.ICasesFindResponse.md#per_page) -- [total](typedoc_interfaces.ICasesFindResponse.md#total) - -## Properties - -### cases - -• **cases**: { `connector`: { id: string; } & { type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.none; fields: null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.resilient; fields: { incidentTypes: string[] \| null; severityCode: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowITSM; fields: { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.serviceNowSIR; fields: { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } \| null; } & { name: string; } & { id: string; } & { type: ConnectorTypes.swimlane; fields: { caseId: string \| null; } \| null; } & { name: string; } = CaseConnectorRt; `description`: `string` = rt.string; `owner`: `string` = rt.string; `settings`: { syncAlerts: boolean; } = SettingsRt; `status`: `CaseStatuses` = CaseStatusRt; `tags`: `string`[] ; `title`: `string` = rt.string } & { `closed_at`: ``null`` \| `string` ; `closed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `external_service`: ``null`` \| { connector\_id: string; } & { connector\_name: string; external\_id: string; external\_title: string; external\_url: string; pushed\_at: string; pushed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| ... 1 more ... \| undefined; }; } = CaseFullExternalServiceRt; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `totalAlerts`: `number` = rt.number; `totalComment`: `number` = rt.number; `version`: `string` = rt.string } & { `comments`: `undefined` \| { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }[] }[] - -#### Inherited from - -CasesFindResponse.cases - -___ - -### count\_closed\_cases - -• **count\_closed\_cases**: `number` = `rt.number` - -#### Inherited from - -CasesFindResponse.count\_closed\_cases - -___ - -### count\_in\_progress\_cases - -• **count\_in\_progress\_cases**: `number` = `rt.number` - -#### Inherited from - -CasesFindResponse.count\_in\_progress\_cases - -___ - -### count\_open\_cases - -• **count\_open\_cases**: `number` = `rt.number` - -#### Inherited from - -CasesFindResponse.count\_open\_cases - -___ - -### page - -• **page**: `number` = `rt.number` - -#### Inherited from - -CasesFindResponse.page - -___ - -### per\_page - -• **per\_page**: `number` = `rt.number` - -#### Inherited from - -CasesFindResponse.per\_page - -___ - -### total - -• **total**: `number` = `rt.number` - -#### Inherited from - -CasesFindResponse.total diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasespatchrequest.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasespatchrequest.md deleted file mode 100644 index 5cf299204ef13..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasespatchrequest.md +++ /dev/null @@ -1,27 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesPatchRequest - -# Interface: ICasesPatchRequest - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesPatchRequest - -## Hierarchy - -- [`CasesPatchRequest`](../modules/typedoc_interfaces._internal_namespace.md#casespatchrequest) - - ↳ **`ICasesPatchRequest`** - -## Table of contents - -### Properties - -- [cases](typedoc_interfaces.ICasesPatchRequest.md#cases) - -## Properties - -### cases - -• **cases**: { `connector`: `undefined` \| { `id`: `string` = rt.string } & { `fields`: ``null`` \| { issueType: string \| null; priority: string \| null; parent: string \| null; } ; `type`: [`jira`](../modules/client._internal_namespace.md#jira) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` = rt.null; `type`: [`none`](../modules/client._internal_namespace.md#none) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { incidentTypes: string[] \| null; severityCode: string \| null; } ; `type`: [`resilient`](../modules/client._internal_namespace.md#resilient) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { impact: string \| null; severity: string \| null; urgency: string \| null; category: string \| null; subcategory: string \| null; } ; `type`: [`serviceNowITSM`](../modules/client._internal_namespace.md#servicenowitsm) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { category: string \| null; destIp: boolean \| null; malwareHash: boolean \| null; malwareUrl: boolean \| null; priority: string \| null; sourceIp: boolean \| null; subcategory: string \| null; } ; `type`: [`serviceNowSIR`](../modules/client._internal_namespace.md#servicenowsir) } & { `name`: `string` = rt.string } & { `id`: `string` = rt.string } & { `fields`: ``null`` \| { caseId: string \| null; } ; `type`: [`swimlane`](../modules/client._internal_namespace.md#swimlane) } & { `name`: `string` = rt.string } = CaseConnectorRt; `description`: `undefined` \| `string` = rt.string; `owner`: `undefined` \| `string` = rt.string; `settings`: `undefined` \| { `syncAlerts`: `boolean` = rt.boolean } = SettingsRt; `status`: `undefined` \| [`open`](../enums/client._internal_namespace.CaseStatuses.md#open) \| `any`[`any`] \| [`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed) = CaseStatusRt; `tags`: `undefined` \| `string`[] ; `title`: `undefined` \| `string` = rt.string } & { `id`: `string` = rt.string; `version`: `string` = rt.string }[] - -#### Inherited from - -CasesPatchRequest.cases diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesresponse.md deleted file mode 100644 index 250ac66e4a680..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icasesresponse.md +++ /dev/null @@ -1,11 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICasesResponse - -# Interface: ICasesResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICasesResponse - -## Hierarchy - -- [`CasesResponse`](../modules/typedoc_interfaces._internal_namespace.md#casesresponse) - - ↳ **`ICasesResponse`** diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseuseractionsresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseuseractionsresponse.md deleted file mode 100644 index d3b936903e42c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icaseuseractionsresponse.md +++ /dev/null @@ -1,11 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICaseUserActionsResponse - -# Interface: ICaseUserActionsResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICaseUserActionsResponse - -## Hierarchy - -- [`CaseUserActionsResponse`](../modules/typedoc_interfaces._internal_namespace.md#caseuseractionsresponse) - - ↳ **`ICaseUserActionsResponse`** diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icommentsresponse.md b/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icommentsresponse.md deleted file mode 100644 index 012b28393f5b9..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/typedoc_interfaces.icommentsresponse.md +++ /dev/null @@ -1,60 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](../modules/typedoc_interfaces.md) / ICommentsResponse - -# Interface: ICommentsResponse - -[typedoc_interfaces](../modules/typedoc_interfaces.md).ICommentsResponse - -## Hierarchy - -- [`CommentsResponse`](../modules/typedoc_interfaces._internal_namespace.md#commentsresponse) - - ↳ **`ICommentsResponse`** - -## Table of contents - -### Properties - -- [comments](typedoc_interfaces.ICommentsResponse.md#comments) -- [page](typedoc_interfaces.ICommentsResponse.md#page) -- [per\_page](typedoc_interfaces.ICommentsResponse.md#per_page) -- [total](typedoc_interfaces.ICommentsResponse.md#total) - -## Properties - -### comments - -• **comments**: { `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`user`](../modules/client._internal_namespace.md#user) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `alertId`: `string` \| `string`[] ; `index`: `string` \| `string`[] ; `owner`: `string` = rt.string; `rule`: { id: string \| null; name: string \| null; } ; `type`: [`alert`](../modules/client._internal_namespace.md#alert) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string } & { `actions`: { targets: { hostname: string; endpointId: string; }[]; type: string; } ; `comment`: `string` = rt.string; `owner`: `string` = rt.string; `type`: [`actions`](../modules/client._internal_namespace.md#actions) } & { `created_at`: `string` = rt.string; `created_by`: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } = UserRT; `owner`: `string` = rt.string; `pushed_at`: ``null`` \| `string` ; `pushed_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } ; `updated_at`: ``null`` \| `string` ; `updated_by`: ``null`` \| { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } } & { `id`: `string` = rt.string; `version`: `string` = rt.string }[] - -#### Inherited from - -CommentsResponse.comments - -___ - -### page - -• **page**: `number` = `rt.number` - -#### Inherited from - -CommentsResponse.page - -___ - -### per\_page - -• **per\_page**: `number` = `rt.number` - -#### Inherited from - -CommentsResponse.per\_page - -___ - -### total - -• **total**: `number` = `rt.number` - -#### Inherited from - -CommentsResponse.total diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionget.md b/x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionget.md deleted file mode 100644 index 8650aed9753f1..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionget.md +++ /dev/null @@ -1,25 +0,0 @@ -[Cases Client API Interface](../README.md) / [user\_actions/client](../modules/user_actions_client.md) / UserActionGet - -# Interface: UserActionGet - -[user_actions/client](../modules/user_actions_client.md).UserActionGet - -Parameters for retrieving user actions for a particular case - -## Table of contents - -### Properties - -- [caseId](user_actions_client.UserActionGet.md#caseid) - -## Properties - -### caseId - -• **caseId**: `string` - -The ID of the case - -#### Defined in - -[x-pack/plugins/cases/server/client/user_actions/client.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/user_actions/client.ts#L19) diff --git a/x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionssubclient.md b/x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionssubclient.md deleted file mode 100644 index 0cf541f5cc445..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/interfaces/user_actions_client.useractionssubclient.md +++ /dev/null @@ -1,35 +0,0 @@ -[Cases Client API Interface](../README.md) / [user\_actions/client](../modules/user_actions_client.md) / UserActionsSubClient - -# Interface: UserActionsSubClient - -[user_actions/client](../modules/user_actions_client.md).UserActionsSubClient - -API for interacting the actions performed by a user when interacting with the cases entities. - -## Table of contents - -### Methods - -- [getAll](user_actions_client.UserActionsSubClient.md#getall) - -## Methods - -### getAll - -▸ **getAll**(`clientArgs`): `Promise`<[`ICaseUserActionsResponse`](typedoc_interfaces.ICaseUserActionsResponse.md)\> - -Retrieves all user actions for a particular case. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `clientArgs` | [`UserActionGet`](user_actions_client.UserActionGet.md) | - -#### Returns - -`Promise`<[`ICaseUserActionsResponse`](typedoc_interfaces.ICaseUserActionsResponse.md)\> - -#### Defined in - -[x-pack/plugins/cases/server/client/user_actions/client.ts:29](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/user_actions/client.ts#L29) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/attachments_client._internal_namespace.md b/x-pack/plugins/cases/docs/cases_client/modules/attachments_client._internal_namespace.md deleted file mode 100644 index 953648379c08f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/attachments_client._internal_namespace.md +++ /dev/null @@ -1,18 +0,0 @@ -[Cases Client API Interface](../README.md) / [attachments/client](attachments_client.md) / \_internal\_namespace - -# Namespace: \_internal\_namespace - -[attachments/client](attachments_client.md)._internal_namespace - -## Table of contents - -### Interfaces - -- [AddArgs](../interfaces/attachments_client._internal_namespace.AddArgs.md) -- [DeleteAllArgs](../interfaces/attachments_client._internal_namespace.DeleteAllArgs.md) -- [DeleteArgs](../interfaces/attachments_client._internal_namespace.DeleteArgs.md) -- [FindArgs](../interfaces/attachments_client._internal_namespace.FindArgs.md) -- [GetAllAlertsAttachToCase](../interfaces/attachments_client._internal_namespace.GetAllAlertsAttachToCase.md) -- [GetAllArgs](../interfaces/attachments_client._internal_namespace.GetAllArgs.md) -- [GetArgs](../interfaces/attachments_client._internal_namespace.GetArgs.md) -- [UpdateArgs](../interfaces/attachments_client._internal_namespace.UpdateArgs.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/attachments_client.md b/x-pack/plugins/cases/docs/cases_client/modules/attachments_client.md deleted file mode 100644 index 2463e2c654e93..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/attachments_client.md +++ /dev/null @@ -1,13 +0,0 @@ -[Cases Client API Interface](../README.md) / attachments/client - -# Module: attachments/client - -## Table of contents - -### Namespaces - -- [\_internal\_namespace](attachments_client._internal_namespace.md) - -### Interfaces - -- [AttachmentsSubClient](../interfaces/attachments_client.AttachmentsSubClient.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/cases_client.md b/x-pack/plugins/cases/docs/cases_client/modules/cases_client.md deleted file mode 100644 index daf591f75c1f8..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/cases_client.md +++ /dev/null @@ -1,9 +0,0 @@ -[Cases Client API Interface](../README.md) / cases/client - -# Module: cases/client - -## Table of contents - -### Interfaces - -- [CasesSubClient](../interfaces/cases_client.CasesSubClient.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/cases_get._internal_namespace.md b/x-pack/plugins/cases/docs/cases_client/modules/cases_get._internal_namespace.md deleted file mode 100644 index a43b25f69372f..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/cases_get._internal_namespace.md +++ /dev/null @@ -1,35 +0,0 @@ -[Cases Client API Interface](../README.md) / [cases/get](cases_get.md) / \_internal\_namespace - -# Namespace: \_internal\_namespace - -[cases/get](cases_get.md)._internal_namespace - -## Table of contents - -### Type aliases - -- [User](cases_get._internal_namespace.md#user) - -### Variables - -- [UserRT](cases_get._internal_namespace.md#userrt) - -## Type aliases - -### User - -Ƭ **User**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/user.ts:18](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/user.ts#L18) - -## Variables - -### UserRT - -• **UserRT**: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/user.ts:10](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/user.ts#L10) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/cases_get.md b/x-pack/plugins/cases/docs/cases_client/modules/cases_get.md deleted file mode 100644 index 6dbf7bb10d0a3..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/cases_get.md +++ /dev/null @@ -1,93 +0,0 @@ -[Cases Client API Interface](../README.md) / cases/get - -# Module: cases/get - -## Table of contents - -### Namespaces - -- [\_internal\_namespace](cases_get._internal_namespace.md) - -### Interfaces - -- [CasesByAlertIDParams](../interfaces/cases_get.CasesByAlertIDParams.md) -- [GetParams](../interfaces/cases_get.GetParams.md) - -### Functions - -- [getReporters](cases_get.md#getreporters) -- [getTags](cases_get.md#gettags) -- [resolve](cases_get.md#resolve) - -## Functions - -### getReporters - -▸ **getReporters**(`params`, `clientArgs`): `Promise`<[`User`](cases_get._internal_namespace.md#user)[]\> - -Retrieves the reporters from all the cases. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Object` | -| `params.owner` | `undefined` \| `string` \| `string`[] | -| `clientArgs` | [`CasesClientArgs`](../interfaces/client._internal_namespace.CasesClientArgs.md) | - -#### Returns - -`Promise`<[`User`](cases_get._internal_namespace.md#user)[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:301](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L301) - -___ - -### getTags - -▸ **getTags**(`params`, `clientArgs`): `Promise`<`string`[]\> - -Retrieves the tags from all the cases. - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `Object` | -| `params.owner` | `undefined` \| `string` \| `string`[] | -| `clientArgs` | [`CasesClientArgs`](../interfaces/client._internal_namespace.CasesClientArgs.md) | - -#### Returns - -`Promise`<`string`[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:269](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L269) - -___ - -### resolve - -▸ `Const` **resolve**(`__namedParameters`, `clientArgs`): `Promise`<{ `case`: { description: string; status: CaseStatuses; tags: string[]; title: string; connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { ...; }) \| ... 4 more ... \| ({ ...; } & { ...; })); settings: { ...; }; owner: str... & { closed\_at: string \| null; closed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } \| null; created\_at: string; created\_by: { ...; }; external\_service: ({ ...; } & { ...; }) \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; totalComment: number; totalAlerts: number; version: string; } & { `comments`: `undefined` \| { comment: string; type: CommentType.user; owner: string; } & { created\_at: string; created\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; }; owner: string; pushed\_at: string \| null; pushed\_by: { ...; } \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; version: string; } & { type: CommentType.alert; alertId: string \| string[]; index: string \| string[]; rule: { id: string \| null; name: string \| null; }; owner: string; } & { created\_at: string; created\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; }; owner: string; pushed\_at: string \| null; pushed\_by: { ...; } \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; version: string; } & { type: CommentType.actions; comment: string; actions: { targets: { hostname: string; endpointId: string; }[]; type: string; }; owner: string; } & { created\_at: string; created\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; }; owner: string; pushed\_at: string \| null; pushed\_by: { ...; } \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; version: string; }[] } = CaseResponseRt; `outcome`: ``"exactMatch"`` \| ``"aliasMatch"`` \| ``"conflict"`` } & { `alias_target_id`: `undefined` \| `string` = rt.string }\> - -Retrieves a case resolving its ID and optionally loading its comments. - -**`experimental`** - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`GetParams`](../interfaces/cases_get.GetParams.md) | -| `clientArgs` | [`CasesClientArgs`](../interfaces/client._internal_namespace.CasesClientArgs.md) | - -#### Returns - -`Promise`<{ `case`: { description: string; status: CaseStatuses; tags: string[]; title: string; connector: { id: string; } & (({ type: ConnectorTypes.jira; fields: { issueType: string \| null; priority: string \| null; parent: string \| null; } \| null; } & { ...; }) \| ... 4 more ... \| ({ ...; } & { ...; })); settings: { ...; }; owner: str... & { closed\_at: string \| null; closed\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; } \| null; created\_at: string; created\_by: { ...; }; external\_service: ({ ...; } & { ...; }) \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; totalComment: number; totalAlerts: number; version: string; } & { `comments`: `undefined` \| { comment: string; type: CommentType.user; owner: string; } & { created\_at: string; created\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; }; owner: string; pushed\_at: string \| null; pushed\_by: { ...; } \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; version: string; } & { type: CommentType.alert; alertId: string \| string[]; index: string \| string[]; rule: { id: string \| null; name: string \| null; }; owner: string; } & { created\_at: string; created\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; }; owner: string; pushed\_at: string \| null; pushed\_by: { ...; } \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; version: string; } & { type: CommentType.actions; comment: string; actions: { targets: { hostname: string; endpointId: string; }[]; type: string; }; owner: string; } & { created\_at: string; created\_by: { email: string \| null \| undefined; full\_name: string \| null \| undefined; username: string \| null \| undefined; }; owner: string; pushed\_at: string \| null; pushed\_by: { ...; } \| null; updated\_at: string \| null; updated\_by: { ...; } \| null; } & { id: string; version: string; }[] } = CaseResponseRt; `outcome`: ``"exactMatch"`` \| ``"aliasMatch"`` \| ``"conflict"`` } & { `alias_target_id`: `undefined` \| `string` = rt.string }\> - -#### Defined in - -[x-pack/plugins/cases/server/client/cases/get.ts:208](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/cases/get.ts#L208) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/cases_push.md b/x-pack/plugins/cases/docs/cases_client/modules/cases_push.md deleted file mode 100644 index bb9667b3308db..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/cases_push.md +++ /dev/null @@ -1,9 +0,0 @@ -[Cases Client API Interface](../README.md) / cases/push - -# Module: cases/push - -## Table of contents - -### Interfaces - -- [PushParams](../interfaces/cases_push.PushParams.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/client._internal_namespace.md b/x-pack/plugins/cases/docs/cases_client/modules/client._internal_namespace.md deleted file mode 100644 index 4489106b370d1..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/client._internal_namespace.md +++ /dev/null @@ -1,2213 +0,0 @@ -[Cases Client API Interface](../README.md) / [client](client.md) / \_internal\_namespace - -# Namespace: \_internal\_namespace - -[client](client.md)._internal_namespace - -## Table of contents - -### Enumerations - -- [ActionExecutionSourceType](../enums/client._internal_namespace.ActionExecutionSourceType.md) -- [AuthorizationMode](../enums/client._internal_namespace.AuthorizationMode.md) -- [CaseStatuses](../enums/client._internal_namespace.CaseStatuses.md) -- [TaskStatus](../enums/client._internal_namespace.TaskStatus.md) -- [ViewMode](../enums/client._internal_namespace.ViewMode.md) - -### Enumeration members - -- [actions](client._internal_namespace.md#actions) -- [alert](client._internal_namespace.md#alert) -- [jira](client._internal_namespace.md#jira) -- [none](client._internal_namespace.md#none) -- [resilient](client._internal_namespace.md#resilient) -- [serviceNowITSM](client._internal_namespace.md#servicenowitsm) -- [serviceNowSIR](client._internal_namespace.md#servicenowsir) -- [swimlane](client._internal_namespace.md#swimlane) -- [user](client._internal_namespace.md#user) - -### Classes - -- [ActionExecutor](../classes/client._internal_namespace.ActionExecutor.md) -- [ActionTypeRegistry](../classes/client._internal_namespace.ActionTypeRegistry.md) -- [Actions](../classes/client._internal_namespace.Actions.md) -- [ActionsAuthorization](../classes/client._internal_namespace.ActionsAuthorization.md) -- [ActionsClient](../classes/client._internal_namespace.ActionsClient.md) -- [AlertService](../classes/client._internal_namespace.AlertService.md) -- [AlertingActions](../classes/client._internal_namespace.AlertingActions.md) -- [ApiActions](../classes/client._internal_namespace.ApiActions.md) -- [AppActions](../classes/client._internal_namespace.AppActions.md) -- [AttachmentService](../classes/client._internal_namespace.AttachmentService.md) -- [Authorization](../classes/client._internal_namespace.Authorization.md) -- [AuthorizationAuditLogger](../classes/client._internal_namespace.AuthorizationAuditLogger.md) -- [BasePath](../classes/client._internal_namespace.BasePath.md) -- [BuilderFactory](../classes/client._internal_namespace.BuilderFactory.md) -- [CaseConfigureService](../classes/client._internal_namespace.CaseConfigureService.md) -- [CaseUserActionService](../classes/client._internal_namespace.CaseUserActionService.md) -- [CasesActions](../classes/client._internal_namespace.CasesActions.md) -- [CasesClientInternal](../classes/client._internal_namespace.CasesClientInternal.md) -- [CasesService](../classes/client._internal_namespace.CasesService.md) -- [ConnectorMappingsService](../classes/client._internal_namespace.ConnectorMappingsService.md) -- [ConnectorTokenClient](../classes/client._internal_namespace.ConnectorTokenClient.md) -- [ElasticsearchFeature](../classes/client._internal_namespace.ElasticsearchFeature.md) -- [KibanaFeature](../classes/client._internal_namespace.KibanaFeature.md) -- [KibanaMigrator](../classes/client._internal_namespace.KibanaMigrator.md) -- [KibanaRequest](../classes/client._internal_namespace.KibanaRequest.md) -- [LicenseState](../classes/client._internal_namespace.LicenseState.md) -- [RouteValidationError](../classes/client._internal_namespace.RouteValidationError.md) -- [RouteValidator](../classes/client._internal_namespace.RouteValidator.md) -- [SavedObjectActions](../classes/client._internal_namespace.SavedObjectActions.md) -- [SavedObjectTypeRegistry](../classes/client._internal_namespace.SavedObjectTypeRegistry.md) -- [SavedObjectsClient](../classes/client._internal_namespace.SavedObjectsClient.md) -- [SavedObjectsErrorHelpers](../classes/client._internal_namespace.SavedObjectsErrorHelpers.md) -- [SavedObjectsRepository](../classes/client._internal_namespace.SavedObjectsRepository.md) -- [SpaceActions](../classes/client._internal_namespace.SpaceActions.md) -- [SubFeature](../classes/client._internal_namespace.SubFeature.md) -- [TaskRunnerFactory](../classes/client._internal_namespace.TaskRunnerFactory.md) -- [UIActions](../classes/client._internal_namespace.UIActions.md) -- [UserActionBuilder](../classes/client._internal_namespace.UserActionBuilder.md) - -### Interfaces - -- [Action](../interfaces/client._internal_namespace.Action.md) -- [ActionExecutionSource](../interfaces/client._internal_namespace.ActionExecutionSource.md) -- [ActionExecutorContext](../interfaces/client._internal_namespace.ActionExecutorContext.md) -- [ActionResult](../interfaces/client._internal_namespace.ActionResult.md) -- [ActionType](../interfaces/client._internal_namespace.ActionType.md) -- [ActionType](../interfaces/client._internal_namespace.ActionType-1.md) -- [ActionTypeExecutorOptions](../interfaces/client._internal_namespace.ActionTypeExecutorOptions.md) -- [ActionTypeExecutorResult](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md) -- [ActionTypeRegistryOpts](../interfaces/client._internal_namespace.ActionTypeRegistryOpts.md) -- [ActionUpdate](../interfaces/client._internal_namespace.ActionUpdate.md) -- [ActionsConfigurationUtilities](../interfaces/client._internal_namespace.ActionsConfigurationUtilities.md) -- [ActionsLicenseInformation](../interfaces/client._internal_namespace.ActionsLicenseInformation.md) -- [AggregationBuilder](../interfaces/client._internal_namespace.AggregationBuilder.md) -- [Alert](../interfaces/client._internal_namespace.Alert.md) -- [AlertIdIndex](../interfaces/client._internal_namespace.AlertIdIndex.md) -- [AlertInfo](../interfaces/client._internal_namespace.AlertInfo.md) -- [AlertsResponse](../interfaces/client._internal_namespace.AlertsResponse.md) -- [AppCategory](../interfaces/client._internal_namespace.AppCategory.md) -- [AttachedToCaseArgs](../interfaces/client._internal_namespace.AttachedToCaseArgs.md) -- [Attributes](../interfaces/client._internal_namespace.Attributes.md) -- [AuditEvent](../interfaces/client._internal_namespace.AuditEvent.md) -- [AuditLogger](../interfaces/client._internal_namespace.AuditLogger.md) -- [AuthFilterHelpers](../interfaces/client._internal_namespace.AuthFilterHelpers.md) -- [AuthenticatedUser](../interfaces/client._internal_namespace.AuthenticatedUser.md) -- [AuthenticationProvider](../interfaces/client._internal_namespace.AuthenticationProvider.md) -- [AuthorizationMode](../interfaces/client._internal_namespace.AuthorizationMode-1.md) -- [AuthorizationServiceSetup](../interfaces/client._internal_namespace.AuthorizationServiceSetup.md) -- [BeforeSaveContext](../interfaces/client._internal_namespace.BeforeSaveContext.md) -- [BuilderParameters](../interfaces/client._internal_namespace.BuilderParameters.md) -- [BuilderReturnValue](../interfaces/client._internal_namespace.BuilderReturnValue.md) -- [BulkCreateAttachmentDeletionUserAction](../interfaces/client._internal_namespace.BulkCreateAttachmentDeletionUserAction.md) -- [BulkCreateBulkUpdateCaseUserActions](../interfaces/client._internal_namespace.BulkCreateBulkUpdateCaseUserActions.md) -- [BulkCreateCaseDeletionUserAction](../interfaces/client._internal_namespace.BulkCreateCaseDeletionUserAction.md) -- [BulkUpdateAttachmentArgs](../interfaces/client._internal_namespace.BulkUpdateAttachmentArgs.md) -- [CancellableTask](../interfaces/client._internal_namespace.CancellableTask.md) -- [Capabilities](../interfaces/client._internal_namespace.Capabilities.md) -- [CaseCommentStats](../interfaces/client._internal_namespace.CaseCommentStats.md) -- [CasesClientArgs](../interfaces/client._internal_namespace.CasesClientArgs.md) -- [CasesMapWithPageInfo](../interfaces/client._internal_namespace.CasesMapWithPageInfo.md) -- [CheckPrivileges](../interfaces/client._internal_namespace.CheckPrivileges.md) -- [CheckPrivilegesOptions](../interfaces/client._internal_namespace.CheckPrivilegesOptions.md) -- [CheckPrivilegesPayload](../interfaces/client._internal_namespace.CheckPrivilegesPayload.md) -- [CheckPrivilegesResponse](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md) -- [ClientArgs](../interfaces/client._internal_namespace.ClientArgs.md) -- [ClientArgs](../interfaces/client._internal_namespace.ClientArgs-1.md) -- [ClientArgs](../interfaces/client._internal_namespace.ClientArgs-2.md) -- [CommonArguments](../interfaces/client._internal_namespace.CommonArguments.md) -- [ConcreteTaskInstance](../interfaces/client._internal_namespace.ConcreteTaskInstance.md) -- [ConnectorToken](../interfaces/client._internal_namespace.ConnectorToken.md) -- [ConstructorOptions](../interfaces/client._internal_namespace.ConstructorOptions.md) -- [ConstructorOptions](../interfaces/client._internal_namespace.ConstructorOptions-1.md) -- [ConstructorOptions](../interfaces/client._internal_namespace.ConstructorOptions-2.md) -- [CountActionsAttachedToCaseArgs](../interfaces/client._internal_namespace.CountActionsAttachedToCaseArgs.md) -- [CreateAttachmentArgs](../interfaces/client._internal_namespace.CreateAttachmentArgs.md) -- [CreateAuditMsgParams](../interfaces/client._internal_namespace.CreateAuditMsgParams.md) -- [CreateOptions](../interfaces/client._internal_namespace.CreateOptions.md) -- [CreateOptions](../interfaces/client._internal_namespace.CreateOptions-1.md) -- [CreateUserAction](../interfaces/client._internal_namespace.CreateUserAction.md) -- [CreateUserActionES](../interfaces/client._internal_namespace.CreateUserActionES.md) -- [DecoratedError](../interfaces/client._internal_namespace.DecoratedError.md) -- [ElasticsearchFeatureConfig](../interfaces/client._internal_namespace.ElasticsearchFeatureConfig.md) -- [EmbeddableRegistryDefinition](../interfaces/client._internal_namespace.EmbeddableRegistryDefinition.md) -- [EncryptedSavedObjectsClient](../interfaces/client._internal_namespace.EncryptedSavedObjectsClient.md) -- [ExecuteOptions](../interfaces/client._internal_namespace.ExecuteOptions.md) -- [ExecuteOptions](../interfaces/client._internal_namespace.ExecuteOptions-1.md) -- [FeatureElasticsearchPrivileges](../interfaces/client._internal_namespace.FeatureElasticsearchPrivileges.md) -- [FeatureKibanaPrivileges](../interfaces/client._internal_namespace.FeatureKibanaPrivileges.md) -- [FeatureUsageServiceSetup](../interfaces/client._internal_namespace.FeatureUsageServiceSetup.md) -- [FindActionResult](../interfaces/client._internal_namespace.FindActionResult.md) -- [FindCaseCommentsArgs](../interfaces/client._internal_namespace.FindCaseCommentsArgs.md) -- [FindCaseConfigureArgs](../interfaces/client._internal_namespace.FindCaseConfigureArgs.md) -- [FindCasesArgs](../interfaces/client._internal_namespace.FindCasesArgs.md) -- [FindCommentsArgs](../interfaces/client._internal_namespace.FindCommentsArgs.md) -- [FindConnectorMappingsArgs](../interfaces/client._internal_namespace.FindConnectorMappingsArgs.md) -- [GetAllSpacesOptions](../interfaces/client._internal_namespace.GetAllSpacesOptions.md) -- [GetAttachmentArgs](../interfaces/client._internal_namespace.GetAttachmentArgs.md) -- [GetCaseArgs](../interfaces/client._internal_namespace.GetCaseArgs.md) -- [GetCaseConfigureArgs](../interfaces/client._internal_namespace.GetCaseConfigureArgs.md) -- [GetCaseIdsByAlertIdArgs](../interfaces/client._internal_namespace.GetCaseIdsByAlertIdArgs.md) -- [GetCaseUserActionArgs](../interfaces/client._internal_namespace.GetCaseUserActionArgs.md) -- [GetCasesArgs](../interfaces/client._internal_namespace.GetCasesArgs.md) -- [GetReportersArgs](../interfaces/client._internal_namespace.GetReportersArgs.md) -- [GetSpaceResult](../interfaces/client._internal_namespace.GetSpaceResult.md) -- [GetTagsArgs](../interfaces/client._internal_namespace.GetTagsArgs.md) -- [GetUserActionItemByDifference](../interfaces/client._internal_namespace.GetUserActionItemByDifference.md) -- [GetUserArgs](../interfaces/client._internal_namespace.GetUserArgs.md) -- [IEventLogger](../interfaces/client._internal_namespace.IEventLogger.md) -- [IKibanaSocket](../interfaces/client._internal_namespace.IKibanaSocket.md) -- [ILicense](../interfaces/client._internal_namespace.ILicense.md) -- [ISavedObjectsPointInTimeFinder](../interfaces/client._internal_namespace.ISavedObjectsPointInTimeFinder.md) -- [IScopedClusterClient](../interfaces/client._internal_namespace.IScopedClusterClient.md) -- [ISpacesClient](../interfaces/client._internal_namespace.ISpacesClient.md) -- [IUsageCounter](../interfaces/client._internal_namespace.IUsageCounter.md) -- [IncrementCounterParams](../interfaces/client._internal_namespace.IncrementCounterParams.md) -- [IndexMapping](../interfaces/client._internal_namespace.IndexMapping.md) -- [IndexMappingMeta](../interfaces/client._internal_namespace.IndexMappingMeta.md) -- [IntervalSchedule](../interfaces/client._internal_namespace.IntervalSchedule.md) -- [KibanaFeatureConfig](../interfaces/client._internal_namespace.KibanaFeatureConfig.md) -- [KibanaMigratorOptions](../interfaces/client._internal_namespace.KibanaMigratorOptions.md) -- [KibanaMigratorStatus](../interfaces/client._internal_namespace.KibanaMigratorStatus.md) -- [KibanaRequestEvents](../interfaces/client._internal_namespace.KibanaRequestEvents.md) -- [LegacyUrlAliasTarget](../interfaces/client._internal_namespace.LegacyUrlAliasTarget.md) -- [LicenseCheck](../interfaces/client._internal_namespace.LicenseCheck.md) -- [LicenseFeature](../interfaces/client._internal_namespace.LicenseFeature.md) -- [LicensingPluginSetup](../interfaces/client._internal_namespace.LicensingPluginSetup.md) -- [Middleware](../interfaces/client._internal_namespace.Middleware.md) -- [OperationDetails](../interfaces/client._internal_namespace.OperationDetails.md) -- [OwnerEntity](../interfaces/client._internal_namespace.OwnerEntity.md) -- [PatchCase](../interfaces/client._internal_namespace.PatchCase.md) -- [PatchCaseConfigureArgs](../interfaces/client._internal_namespace.PatchCaseConfigureArgs.md) -- [PatchCasesArgs](../interfaces/client._internal_namespace.PatchCasesArgs.md) -- [PersistableState](../interfaces/client._internal_namespace.PersistableState.md) -- [PluginStartContract](../interfaces/client._internal_namespace.PluginStartContract.md) -- [PostCaseArgs](../interfaces/client._internal_namespace.PostCaseArgs.md) -- [PostCaseConfigureArgs](../interfaces/client._internal_namespace.PostCaseConfigureArgs.md) -- [PostCaseUserActionArgs](../interfaces/client._internal_namespace.PostCaseUserActionArgs.md) -- [PostConnectorMappingsArgs](../interfaces/client._internal_namespace.PostConnectorMappingsArgs.md) -- [PreConfiguredAction](../interfaces/client._internal_namespace.PreConfiguredAction.md) -- [ProxySettings](../interfaces/client._internal_namespace.ProxySettings.md) -- [PublicLicense](../interfaces/client._internal_namespace.PublicLicense.md) -- [PublicLicenseJSON](../interfaces/client._internal_namespace.PublicLicenseJSON.md) -- [PushedArgs](../interfaces/client._internal_namespace.PushedArgs.md) -- [Referencable](../interfaces/client._internal_namespace.Referencable.md) -- [ReservedKibanaPrivilege](../interfaces/client._internal_namespace.ReservedKibanaPrivilege.md) -- [ResponseSettings](../interfaces/client._internal_namespace.ResponseSettings.md) -- [RouteConfigOptions](../interfaces/client._internal_namespace.RouteConfigOptions.md) -- [RouteConfigOptionsBody](../interfaces/client._internal_namespace.RouteConfigOptionsBody.md) -- [RouteValidationResultFactory](../interfaces/client._internal_namespace.RouteValidationResultFactory.md) -- [RouteValidatorConfig](../interfaces/client._internal_namespace.RouteValidatorConfig.md) -- [RouteValidatorOptions](../interfaces/client._internal_namespace.RouteValidatorOptions.md) -- [RunContext](../interfaces/client._internal_namespace.RunContext.md) -- [RunNowResult](../interfaces/client._internal_namespace.RunNowResult.md) -- [SSLSettings](../interfaces/client._internal_namespace.SSLSettings.md) -- [SavedObject](../interfaces/client._internal_namespace.SavedObject.md) -- [SavedObjectAttributes](../interfaces/client._internal_namespace.SavedObjectAttributes.md) -- [SavedObjectDoc](../interfaces/client._internal_namespace.SavedObjectDoc.md) -- [SavedObjectError](../interfaces/client._internal_namespace.SavedObjectError.md) -- [SavedObjectMigrationContext](../interfaces/client._internal_namespace.SavedObjectMigrationContext.md) -- [SavedObjectMigrationMap](../interfaces/client._internal_namespace.SavedObjectMigrationMap.md) -- [SavedObjectReference](../interfaces/client._internal_namespace.SavedObjectReference.md) -- [SavedObjectReferenceWithContext](../interfaces/client._internal_namespace.SavedObjectReferenceWithContext.md) -- [SavedObjectsBaseOptions](../interfaces/client._internal_namespace.SavedObjectsBaseOptions.md) -- [SavedObjectsBulkCreateObject](../interfaces/client._internal_namespace.SavedObjectsBulkCreateObject.md) -- [SavedObjectsBulkGetObject](../interfaces/client._internal_namespace.SavedObjectsBulkGetObject.md) -- [SavedObjectsBulkResolveObject](../interfaces/client._internal_namespace.SavedObjectsBulkResolveObject.md) -- [SavedObjectsBulkResolveResponse](../interfaces/client._internal_namespace.SavedObjectsBulkResolveResponse.md) -- [SavedObjectsBulkResponse](../interfaces/client._internal_namespace.SavedObjectsBulkResponse.md) -- [SavedObjectsBulkUpdateObject](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateObject.md) -- [SavedObjectsBulkUpdateOptions](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateOptions.md) -- [SavedObjectsBulkUpdateResponse](../interfaces/client._internal_namespace.SavedObjectsBulkUpdateResponse.md) -- [SavedObjectsCheckConflictsObject](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsObject.md) -- [SavedObjectsCheckConflictsResponse](../interfaces/client._internal_namespace.SavedObjectsCheckConflictsResponse.md) -- [SavedObjectsClosePointInTimeResponse](../interfaces/client._internal_namespace.SavedObjectsClosePointInTimeResponse.md) -- [SavedObjectsCollectMultiNamespaceReferencesObject](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesObject.md) -- [SavedObjectsCollectMultiNamespaceReferencesOptions](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesOptions.md) -- [SavedObjectsCollectMultiNamespaceReferencesResponse](../interfaces/client._internal_namespace.SavedObjectsCollectMultiNamespaceReferencesResponse.md) -- [SavedObjectsCreateOptions](../interfaces/client._internal_namespace.SavedObjectsCreateOptions.md) -- [SavedObjectsCreatePointInTimeFinderDependencies](../interfaces/client._internal_namespace.SavedObjectsCreatePointInTimeFinderDependencies.md) -- [SavedObjectsDeleteByNamespaceOptions](../interfaces/client._internal_namespace.SavedObjectsDeleteByNamespaceOptions.md) -- [SavedObjectsDeleteOptions](../interfaces/client._internal_namespace.SavedObjectsDeleteOptions.md) -- [SavedObjectsExportTransformContext](../interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md) -- [SavedObjectsFindOptions](../interfaces/client._internal_namespace.SavedObjectsFindOptions.md) -- [SavedObjectsFindOptionsReference](../interfaces/client._internal_namespace.SavedObjectsFindOptionsReference.md) -- [SavedObjectsFindResponse](../interfaces/client._internal_namespace.SavedObjectsFindResponse.md) -- [SavedObjectsFindResult](../interfaces/client._internal_namespace.SavedObjectsFindResult.md) -- [SavedObjectsImportActionRequiredWarning](../interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md) -- [SavedObjectsImportHookResult](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md) -- [SavedObjectsImportSimpleWarning](../interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md) -- [SavedObjectsIncrementCounterField](../interfaces/client._internal_namespace.SavedObjectsIncrementCounterField.md) -- [SavedObjectsIncrementCounterOptions](../interfaces/client._internal_namespace.SavedObjectsIncrementCounterOptions.md) -- [SavedObjectsMappingProperties](../interfaces/client._internal_namespace.SavedObjectsMappingProperties.md) -- [SavedObjectsMigrationLogger](../interfaces/client._internal_namespace.SavedObjectsMigrationLogger.md) -- [SavedObjectsMigrationVersion](../interfaces/client._internal_namespace.SavedObjectsMigrationVersion.md) -- [SavedObjectsOpenPointInTimeOptions](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeOptions.md) -- [SavedObjectsOpenPointInTimeResponse](../interfaces/client._internal_namespace.SavedObjectsOpenPointInTimeResponse.md) -- [SavedObjectsPitParams](../interfaces/client._internal_namespace.SavedObjectsPitParams.md) -- [SavedObjectsRemoveReferencesToOptions](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToOptions.md) -- [SavedObjectsRemoveReferencesToResponse](../interfaces/client._internal_namespace.SavedObjectsRemoveReferencesToResponse.md) -- [SavedObjectsResolveResponse](../interfaces/client._internal_namespace.SavedObjectsResolveResponse.md) -- [SavedObjectsType](../interfaces/client._internal_namespace.SavedObjectsType.md) -- [SavedObjectsTypeManagementDefinition](../interfaces/client._internal_namespace.SavedObjectsTypeManagementDefinition.md) -- [SavedObjectsTypeMappingDefinition](../interfaces/client._internal_namespace.SavedObjectsTypeMappingDefinition.md) -- [SavedObjectsUpdateObjectsSpacesObject](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesObject.md) -- [SavedObjectsUpdateObjectsSpacesOptions](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesOptions.md) -- [SavedObjectsUpdateObjectsSpacesResponse](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponse.md) -- [SavedObjectsUpdateObjectsSpacesResponseObject](../interfaces/client._internal_namespace.SavedObjectsUpdateObjectsSpacesResponseObject.md) -- [SavedObjectsUpdateOptions](../interfaces/client._internal_namespace.SavedObjectsUpdateOptions.md) -- [SavedObjectsUpdateResponse](../interfaces/client._internal_namespace.SavedObjectsUpdateResponse.md) -- [SavedObjectsValidationMap](../interfaces/client._internal_namespace.SavedObjectsValidationMap.md) -- [Services](../interfaces/client._internal_namespace.Services.md) -- [Space](../interfaces/client._internal_namespace.Space.md) -- [SpacesServiceStart](../interfaces/client._internal_namespace.SpacesServiceStart.md) -- [SubFeatureConfig](../interfaces/client._internal_namespace.SubFeatureConfig.md) -- [SubFeaturePrivilegeConfig](../interfaces/client._internal_namespace.SubFeaturePrivilegeConfig.md) -- [SubFeaturePrivilegeGroupConfig](../interfaces/client._internal_namespace.SubFeaturePrivilegeGroupConfig.md) -- [TaskInfo](../interfaces/client._internal_namespace.TaskInfo.md) -- [TaskInstance](../interfaces/client._internal_namespace.TaskInstance.md) -- [TaskManagerSetupContract](../interfaces/client._internal_namespace.TaskManagerSetupContract.md) -- [TaskRegisterDefinition](../interfaces/client._internal_namespace.TaskRegisterDefinition.md) -- [TaskRunnerContext](../interfaces/client._internal_namespace.TaskRunnerContext.md) -- [TranslatedUpdateAlertRequest](../interfaces/client._internal_namespace.TranslatedUpdateAlertRequest.md) -- [UpdateAlertRequest](../interfaces/client._internal_namespace.UpdateAlertRequest.md) -- [UpdateArgs](../interfaces/client._internal_namespace.UpdateArgs.md) -- [UpdateConnectorMappingsArgs](../interfaces/client._internal_namespace.UpdateConnectorMappingsArgs.md) -- [UpdateOptions](../interfaces/client._internal_namespace.UpdateOptions.md) -- [UpdateOptions](../interfaces/client._internal_namespace.UpdateOptions-1.md) -- [User](../interfaces/client._internal_namespace.User.md) -- [UserRealm](../interfaces/client._internal_namespace.UserRealm.md) -- [ValidatorType](../interfaces/client._internal_namespace.ValidatorType.md) -- [Verbs](../interfaces/client._internal_namespace.Verbs.md) - -### Type aliases - -- [ActionExecutorContract](client._internal_namespace.md#actionexecutorcontract) -- [ActionTypeConfig](client._internal_namespace.md#actiontypeconfig) -- [ActionTypeParams](client._internal_namespace.md#actiontypeparams) -- [ActionTypeRegistryContract](client._internal_namespace.md#actiontyperegistrycontract) -- [ActionTypeSecrets](client._internal_namespace.md#actiontypesecrets) -- [ActionsClient](client._internal_namespace.md#actionsclient) -- [AggregationResponse](client._internal_namespace.md#aggregationresponse) -- [BeforeRunContextFunction](client._internal_namespace.md#beforeruncontextfunction) -- [BeforeSaveContextFunction](client._internal_namespace.md#beforesavecontextfunction) -- [CancelFunction](client._internal_namespace.md#cancelfunction) -- [CasesFindRequest](client._internal_namespace.md#casesfindrequest) -- [CheckPrivilegesDynamically](client._internal_namespace.md#checkprivilegesdynamically) -- [CheckPrivilegesDynamicallyWithRequest](client._internal_namespace.md#checkprivilegesdynamicallywithrequest) -- [CheckPrivilegesWithRequest](client._internal_namespace.md#checkprivilegeswithrequest) -- [CheckSavedObjectsPrivileges](client._internal_namespace.md#checksavedobjectsprivileges) -- [CheckSavedObjectsPrivilegesWithRequest](client._internal_namespace.md#checksavedobjectsprivilegeswithrequest) -- [CommonBuilderArguments](client._internal_namespace.md#commonbuilderarguments) -- [CommonUserActionArgs](client._internal_namespace.md#commonuseractionargs) -- [ConnectorTokenClientContract](client._internal_namespace.md#connectortokenclientcontract) -- [CreateUserActionClient](client._internal_namespace.md#createuseractionclient) -- [DeepPartial](client._internal_namespace.md#deeppartial) -- [DeepWriteable](client._internal_namespace.md#deepwriteable) -- [DestructiveRouteMethod](client._internal_namespace.md#destructiveroutemethod) -- [ElasticsearchClient](client._internal_namespace.md#elasticsearchclient) -- [EmbeddableInput](client._internal_namespace.md#embeddableinput) -- [EmbeddableStateWithType](client._internal_namespace.md#embeddablestatewithtype) -- [EnsureSOAuthCallback](client._internal_namespace.md#ensuresoauthcallback) -- [ExecutionEnqueuer](client._internal_namespace.md#executionenqueuer) -- [ExecutorType](client._internal_namespace.md#executortype) -- [FailedRunResult](client._internal_namespace.md#failedrunresult) -- [FindCaseOptions](client._internal_namespace.md#findcaseoptions) -- [GetAllSpacesPurpose](client._internal_namespace.md#getallspacespurpose) -- [GetMigrationFunctionObjectFn](client._internal_namespace.md#getmigrationfunctionobjectfn) -- [GetServicesFunction](client._internal_namespace.md#getservicesfunction) -- [GetSpaceFn](client._internal_namespace.md#getspacefn) -- [Headers](client._internal_namespace.md#headers) -- [IBasePath](client._internal_namespace.md#ibasepath) -- [IEvent](client._internal_namespace.md#ievent) -- [IKibanaMigrator](client._internal_namespace.md#ikibanamigrator) -- [ILicenseState](client._internal_namespace.md#ilicensestate) -- [ISavedObjectTypeRegistry](client._internal_namespace.md#isavedobjecttyperegistry) -- [ISavedObjectsRepository](client._internal_namespace.md#isavedobjectsrepository) -- [IValidatedEvent](client._internal_namespace.md#ivalidatedevent) -- [KibanaExecutionContext](client._internal_namespace.md#kibanaexecutioncontext) -- [KibanaRequestRouteOptions](client._internal_namespace.md#kibanarequestrouteoptions) -- [KnownHeaders](client._internal_namespace.md#knownheaders) -- [KnownKeys](client._internal_namespace.md#knownkeys) -- [LicenseCheckState](client._internal_namespace.md#licensecheckstate) -- [LicenseStatus](client._internal_namespace.md#licensestatus) -- [Mapper](client._internal_namespace.md#mapper) -- [MigrateFunction](client._internal_namespace.md#migratefunction) -- [MigrateFunctionsObject](client._internal_namespace.md#migratefunctionsobject) -- [MigrationResult](client._internal_namespace.md#migrationresult) -- [MigrationStatus](client._internal_namespace.md#migrationstatus) -- [MutatingOperationRefreshSetting](client._internal_namespace.md#mutatingoperationrefreshsetting) -- [PatchCaseArgs](client._internal_namespace.md#patchcaseargs) -- [PersistableStateDefinition](client._internal_namespace.md#persistablestatedefinition) -- [PublicFeatures](client._internal_namespace.md#publicfeatures) -- [RouteContentType](client._internal_namespace.md#routecontenttype) -- [RouteMethod](client._internal_namespace.md#routemethod) -- [RouteValidationFunction](client._internal_namespace.md#routevalidationfunction) -- [RouteValidationSpec](client._internal_namespace.md#routevalidationspec) -- [RouteValidatorFullConfig](client._internal_namespace.md#routevalidatorfullconfig) -- [RunFunction](client._internal_namespace.md#runfunction) -- [RunResult](client._internal_namespace.md#runresult) -- [SafeRouteMethod](client._internal_namespace.md#saferoutemethod) -- [SavedObjectAttribute](client._internal_namespace.md#savedobjectattribute) -- [SavedObjectAttributeSingle](client._internal_namespace.md#savedobjectattributesingle) -- [SavedObjectFindOptions](client._internal_namespace.md#savedobjectfindoptions) -- [SavedObjectFindOptionsKueryNode](client._internal_namespace.md#savedobjectfindoptionskuerynode) -- [SavedObjectMigrationFn](client._internal_namespace.md#savedobjectmigrationfn) -- [SavedObjectTypeExcludeFromUpgradeFilterHook](client._internal_namespace.md#savedobjecttypeexcludefromupgradefilterhook) -- [SavedObjectUnsanitizedDoc](client._internal_namespace.md#savedobjectunsanitizeddoc) -- [SavedObjectsClientContract](client._internal_namespace.md#savedobjectsclientcontract) -- [SavedObjectsCreatePointInTimeFinderOptions](client._internal_namespace.md#savedobjectscreatepointintimefinderoptions) -- [SavedObjectsExportTransform](client._internal_namespace.md#savedobjectsexporttransform) -- [SavedObjectsExportablePredicate](client._internal_namespace.md#savedobjectsexportablepredicate) -- [SavedObjectsFieldMapping](client._internal_namespace.md#savedobjectsfieldmapping) -- [SavedObjectsImportHook](client._internal_namespace.md#savedobjectsimporthook) -- [SavedObjectsImportWarning](client._internal_namespace.md#savedobjectsimportwarning) -- [SavedObjectsNamespaceType](client._internal_namespace.md#savedobjectsnamespacetype) -- [SavedObjectsValidationSpec](client._internal_namespace.md#savedobjectsvalidationspec) -- [SpaceIdToNamespaceFunction](client._internal_namespace.md#spaceidtonamespacefunction) -- [StringKeysAsVals](client._internal_namespace.md#stringkeysasvals) -- [SubFeaturePrivilegeGroupType](client._internal_namespace.md#subfeatureprivilegegrouptype) -- [SuccessfulRunResult](client._internal_namespace.md#successfulrunresult) -- [TaskDefinitionRegistry](client._internal_namespace.md#taskdefinitionregistry) -- [TaskRunCreatorFunction](client._internal_namespace.md#taskruncreatorfunction) -- [UpdateAttachmentArgs](client._internal_namespace.md#updateattachmentargs) -- [UserAction](client._internal_namespace.md#useraction) -- [UserActionParameters](client._internal_namespace.md#useractionparameters) -- [UserActionTypes](client._internal_namespace.md#useractiontypes) - -### Variables - -- [ActionTypesRt](client._internal_namespace.md#actiontypesrt) -- [ActionsRt](client._internal_namespace.md#actionsrt) -- [CasesFindRequestRt](client._internal_namespace.md#casesfindrequestrt) -- [EventSchema](client._internal_namespace.md#eventschema) -- [SavedObjectFindOptionsRt](client._internal_namespace.md#savedobjectfindoptionsrt) - -## Enumeration members - -### actions - -• **actions**: `Object` = `"actions"` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:26](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L26) - -___ - -### alert - -• **alert**: `Object` = `"alert"` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L25) - -___ - -### jira - -• **jira**: `Object` = `".jira"` - -#### Defined in - -[x-pack/plugins/cases/common/api/connectors/index.ts:36](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/connectors/index.ts#L36) - -___ - -### none - -• **none**: `Object` = `".none"` - -#### Defined in - -[x-pack/plugins/cases/common/api/connectors/index.ts:37](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/connectors/index.ts#L37) - -___ - -### resilient - -• **resilient**: `Object` = `".resilient"` - -#### Defined in - -[x-pack/plugins/cases/common/api/connectors/index.ts:38](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/connectors/index.ts#L38) - -___ - -### serviceNowITSM - -• **serviceNowITSM**: `Object` = `".servicenow"` - -#### Defined in - -[x-pack/plugins/cases/common/api/connectors/index.ts:39](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/connectors/index.ts#L39) - -___ - -### serviceNowSIR - -• **serviceNowSIR**: `Object` = `".servicenow-sir"` - -#### Defined in - -[x-pack/plugins/cases/common/api/connectors/index.ts:40](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/connectors/index.ts#L40) - -___ - -### swimlane - -• **swimlane**: `Object` = `".swimlane"` - -#### Defined in - -[x-pack/plugins/cases/common/api/connectors/index.ts:41](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/connectors/index.ts#L41) - -___ - -### user - -• **user**: `Object` = `"user"` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:24](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L24) - -## Type aliases - -### ActionExecutorContract - -Ƭ **ActionExecutorContract**: `PublicMethodsOf`<[`ActionExecutor`](../classes/client._internal_namespace.ActionExecutor.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/action_executor.d.ts:34 - -___ - -### ActionTypeConfig - -Ƭ **ActionTypeConfig**: `Record`<`string`, `unknown`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:19 - -___ - -### ActionTypeParams - -Ƭ **ActionTypeParams**: `Record`<`string`, `unknown`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:21 - -___ - -### ActionTypeRegistryContract - -Ƭ **ActionTypeRegistryContract**: `PublicMethodsOf`<[`ActionTypeRegistry`](../classes/client._internal_namespace.ActionTypeRegistry.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:17 - -___ - -### ActionTypeSecrets - -Ƭ **ActionTypeSecrets**: `Record`<`string`, `unknown`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:20 - -___ - -### ActionsClient - -Ƭ **ActionsClient**: `PublicMethodsOf`<[`ActionsClient`](../classes/client._internal_namespace.ActionsClient.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/index.d.ts:7 - -___ - -### AggregationResponse - -Ƭ **AggregationResponse**: `Record`<`string`, `estypes.AggregationsAggregate`\> \| `undefined` - -#### Defined in - -[x-pack/plugins/cases/server/client/metrics/types.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/metrics/types.ts#L25) - -___ - -### BeforeRunContextFunction - -Ƭ **BeforeRunContextFunction**: [`Mapper`](client._internal_namespace.md#mapper)<[`RunContext`](../interfaces/client._internal_namespace.RunContext.md)\> - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:7 - -___ - -### BeforeSaveContextFunction - -Ƭ **BeforeSaveContextFunction**: [`Mapper`](client._internal_namespace.md#mapper)<[`BeforeSaveContext`](../interfaces/client._internal_namespace.BeforeSaveContext.md)\> - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:6 - -___ - -### CancelFunction - -Ƭ **CancelFunction**: () => `Promise`<[`RunResult`](client._internal_namespace.md#runresult) \| `undefined` \| `void`\> - -#### Type declaration - -▸ (): `Promise`<[`RunResult`](client._internal_namespace.md#runresult) \| `undefined` \| `void`\> - -##### Returns - -`Promise`<[`RunResult`](client._internal_namespace.md#runresult) \| `undefined` \| `void`\> - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:65 - -___ - -### CasesFindRequest - -Ƭ **CasesFindRequest**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:284](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L284) - -___ - -### CheckPrivilegesDynamically - -Ƭ **CheckPrivilegesDynamically**: (`privileges`: [`CheckPrivilegesPayload`](../interfaces/client._internal_namespace.CheckPrivilegesPayload.md), `options?`: [`CheckPrivilegesOptions`](../interfaces/client._internal_namespace.CheckPrivilegesOptions.md)) => `Promise`<[`CheckPrivilegesResponse`](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Type declaration - -▸ (`privileges`, `options?`): `Promise`<[`CheckPrivilegesResponse`](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md)\> - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `privileges` | [`CheckPrivilegesPayload`](../interfaces/client._internal_namespace.CheckPrivilegesPayload.md) | -| `options?` | [`CheckPrivilegesOptions`](../interfaces/client._internal_namespace.CheckPrivilegesOptions.md) | - -##### Returns - -`Promise`<[`CheckPrivilegesResponse`](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/check_privileges_dynamically.d.ts:4 - -___ - -### CheckPrivilegesDynamicallyWithRequest - -Ƭ **CheckPrivilegesDynamicallyWithRequest**: (`request`: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)) => [`CheckPrivilegesDynamically`](client._internal_namespace.md#checkprivilegesdynamically) - -#### Type declaration - -▸ (`request`): [`CheckPrivilegesDynamically`](client._internal_namespace.md#checkprivilegesdynamically) - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md) | - -##### Returns - -[`CheckPrivilegesDynamically`](client._internal_namespace.md#checkprivilegesdynamically) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/check_privileges_dynamically.d.ts:5 - -___ - -### CheckPrivilegesWithRequest - -Ƭ **CheckPrivilegesWithRequest**: (`request`: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)) => [`CheckPrivileges`](../interfaces/client._internal_namespace.CheckPrivileges.md) - -#### Type declaration - -▸ (`request`): [`CheckPrivileges`](../interfaces/client._internal_namespace.CheckPrivileges.md) - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md) | - -##### Returns - -[`CheckPrivileges`](../interfaces/client._internal_namespace.CheckPrivileges.md) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/types.d.ts:59 - -___ - -### CheckSavedObjectsPrivileges - -Ƭ **CheckSavedObjectsPrivileges**: (`actions`: `string` \| `string`[], `namespaceOrNamespaces?`: `string` \| (`undefined` \| `string`)[]) => `Promise`<[`CheckPrivilegesResponse`](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Type declaration - -▸ (`actions`, `namespaceOrNamespaces?`): `Promise`<[`CheckPrivilegesResponse`](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md)\> - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `actions` | `string` \| `string`[] | -| `namespaceOrNamespaces?` | `string` \| (`undefined` \| `string`)[] | - -##### Returns - -`Promise`<[`CheckPrivilegesResponse`](../interfaces/client._internal_namespace.CheckPrivilegesResponse.md)\> - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/check_saved_objects_privileges.d.ts:5 - -___ - -### CheckSavedObjectsPrivilegesWithRequest - -Ƭ **CheckSavedObjectsPrivilegesWithRequest**: (`request`: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)) => [`CheckSavedObjectsPrivileges`](client._internal_namespace.md#checksavedobjectsprivileges) - -#### Type declaration - -▸ (`request`): [`CheckSavedObjectsPrivileges`](client._internal_namespace.md#checksavedobjectsprivileges) - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md) | - -##### Returns - -[`CheckSavedObjectsPrivileges`](client._internal_namespace.md#checksavedobjectsprivileges) - -#### Defined in - -x-pack/plugins/security/target/types/server/authorization/check_saved_objects_privileges.d.ts:4 - -___ - -### CommonBuilderArguments - -Ƭ **CommonBuilderArguments**: [`CommonArguments`](../interfaces/client._internal_namespace.CommonArguments.md) & { `action`: [`UserAction`](client._internal_namespace.md#useraction) ; `type`: [`UserActionTypes`](client._internal_namespace.md#useractiontypes) ; `value`: `unknown` ; `valueKey`: `string` } - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:97](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L97) - -___ - -### CommonUserActionArgs - -Ƭ **CommonUserActionArgs**: [`ClientArgs`](../interfaces/client._internal_namespace.ClientArgs-1.md) & [`CommonArguments`](../interfaces/client._internal_namespace.CommonArguments.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:75](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L75) - -___ - -### ConnectorTokenClientContract - -Ƭ **ConnectorTokenClientContract**: `PublicMethodsOf`<[`ConnectorTokenClient`](../classes/client._internal_namespace.ConnectorTokenClient.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:22 - -___ - -### CreateUserActionClient - -Ƭ **CreateUserActionClient**<`T`\>: [`CreateUserAction`](../interfaces/client._internal_namespace.CreateUserAction.md)<`T`\> & [`CommonUserActionArgs`](client._internal_namespace.md#commonuseractionargs) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | extends keyof [`BuilderParameters`](../interfaces/client._internal_namespace.BuilderParameters.md) | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/index.ts:98](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/index.ts#L98) - -___ - -### DeepPartial - -Ƭ **DeepPartial**<`T`\>: { [P in keyof T]?: T[P] extends infer U[] ? DeepPartial[] : DeepPartial } - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Defined in - -x-pack/plugins/event_log/target/types/generated/schemas.d.ts:5 - -___ - -### DeepWriteable - -Ƭ **DeepWriteable**<`T`\>: { -readonly [P in keyof T]: DeepWriteable } - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Defined in - -x-pack/plugins/event_log/target/types/generated/schemas.d.ts:2 - -___ - -### DestructiveRouteMethod - -Ƭ **DestructiveRouteMethod**: ``"post"`` \| ``"put"`` \| ``"delete"`` \| ``"patch"`` - -Set of HTTP methods changing the state of the server. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:7 - -___ - -### ElasticsearchClient - -Ƭ **ElasticsearchClient**: `Omit`<`KibanaClient`, ``"connectionPool"`` \| ``"transport"`` \| ``"serializer"`` \| ``"extend"`` \| ``"child"`` \| ``"close"`` \| ``"diagnostic"``\> & { `transport`: { `request`: (`params`: `TransportRequestParams`, `options?`: `TransportRequestOptions`) => `Promise`<`TransportResult`<`TResponse`, `unknown`\>\> } } - -Client used to query the elasticsearch cluster. - -#### Defined in - -src/core/target/types/server/elasticsearch/client/types.d.ts:8 - -___ - -### EmbeddableInput - -Ƭ **EmbeddableInput**: `Object` - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `disableTriggers?` | `boolean` | Whether this embeddable should not execute triggers. | -| `disabledActions?` | `string`[] | List of action IDs that this embeddable should not render. | -| `enhancements?` | `SerializableRecord` | Reserved key for enhancements added by other plugins. | -| `executionContext?` | [`KibanaExecutionContext`](client._internal_namespace.md#kibanaexecutioncontext) | - | -| `hidePanelTitles?` | `boolean` | - | -| `id` | `string` | Note this is not a saved object id. It is used to uniquely identify this Embeddable instance from others (e.g. inside a container). It's possible to have two Embeddables where everything else is the same but the id. | -| `lastReloadRequestTime?` | `number` | - | -| `searchSessionId?` | `string` | Search session id to group searches | -| `syncColors?` | `boolean` | Flag whether colors should be synced with other panels | -| `title?` | `string` | - | -| `viewMode?` | [`ViewMode`](../enums/client._internal_namespace.ViewMode.md) | - | - -#### Defined in - -src/plugins/embeddable/target/types/common/types.d.ts:10 - -___ - -### EmbeddableStateWithType - -Ƭ **EmbeddableStateWithType**: [`EmbeddableInput`](client._internal_namespace.md#embeddableinput) & { `type`: `string` } - -#### Defined in - -src/plugins/embeddable/target/types/common/types.d.ts:53 - -___ - -### EnsureSOAuthCallback - -Ƭ **EnsureSOAuthCallback**: (`entities`: [`OwnerEntity`](../interfaces/client._internal_namespace.OwnerEntity.md)[]) => `void` - -#### Type declaration - -▸ (`entities`): `void` - -Function callback for making sure the found saved objects are of the authorized owner - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `entities` | [`OwnerEntity`](../interfaces/client._internal_namespace.OwnerEntity.md)[] | - -##### Returns - -`void` - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:110](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L110) - -___ - -### ExecutionEnqueuer - -Ƭ **ExecutionEnqueuer**<`T`\>: (`unsecuredSavedObjectsClient`: [`SavedObjectsClientContract`](client._internal_namespace.md#savedobjectsclientcontract), `options`: [`ExecuteOptions`](../interfaces/client._internal_namespace.ExecuteOptions-1.md)) => `Promise`<`T`\> - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Type declaration - -▸ (`unsecuredSavedObjectsClient`, `options`): `Promise`<`T`\> - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `unsecuredSavedObjectsClient` | [`SavedObjectsClientContract`](client._internal_namespace.md#savedobjectsclientcontract) | -| `options` | [`ExecuteOptions`](../interfaces/client._internal_namespace.ExecuteOptions-1.md) | - -##### Returns - -`Promise`<`T`\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/create_execute_function.d.ts:19 - -___ - -### ExecutorType - -Ƭ **ExecutorType**<`Config`, `Secrets`, `Params`, `ResultData`\>: (`options`: [`ActionTypeExecutorOptions`](../interfaces/client._internal_namespace.ActionTypeExecutorOptions.md)<`Config`, `Secrets`, `Params`\>) => `Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`ResultData`\>\> - -#### Type parameters - -| Name | -| :------ | -| `Config` | -| `Secrets` | -| `Params` | -| `ResultData` | - -#### Type declaration - -▸ (`options`): `Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`ResultData`\>\> - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `options` | [`ActionTypeExecutorOptions`](../interfaces/client._internal_namespace.ActionTypeExecutorOptions.md)<`Config`, `Secrets`, `Params`\> | - -##### Returns - -`Promise`<[`ActionTypeExecutorResult`](../interfaces/client._internal_namespace.ActionTypeExecutorResult.md)<`ResultData`\>\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:62 - -___ - -### FailedRunResult - -Ƭ **FailedRunResult**: [`SuccessfulRunResult`](client._internal_namespace.md#successfulrunresult) & { `error`: `Error` } - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:52 - -___ - -### FindCaseOptions - -Ƭ **FindCaseOptions**: [`CasesFindRequest`](client._internal_namespace.md#casesfindrequest) & [`SavedObjectFindOptionsKueryNode`](client._internal_namespace.md#savedobjectfindoptionskuerynode) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:125](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L125) - -___ - -### GetAllSpacesPurpose - -Ƭ **GetAllSpacesPurpose**: ``"any"`` \| ``"copySavedObjectsIntoSpace"`` \| ``"findSavedObjects"`` \| ``"shareSavedObjectsIntoSpace"`` - -The set of purposes to retrieve spaces: -- `any`: retrieves all spaces the user is authorized to see. -- `copySavedObjectsIntoSpace`: retrieves all spaces the user is authorized to copy saved objects into. -- `findSavedObjects`: retrieves all spaces the user is authorized to search within. -- `shareSavedObjectsIntoSpace`: retrieves all spaces the user is authorized to share saved objects into. - -#### Defined in - -x-pack/plugins/spaces/target/types/common/types.d.ts:74 - -___ - -### GetMigrationFunctionObjectFn - -Ƭ **GetMigrationFunctionObjectFn**: () => [`MigrateFunctionsObject`](client._internal_namespace.md#migratefunctionsobject) - -#### Type declaration - -▸ (): [`MigrateFunctionsObject`](client._internal_namespace.md#migratefunctionsobject) - -##### Returns - -[`MigrateFunctionsObject`](client._internal_namespace.md#migratefunctionsobject) - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:77 - -___ - -### GetServicesFunction - -Ƭ **GetServicesFunction**: (`request`: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)) => [`Services`](../interfaces/client._internal_namespace.Services.md) - -#### Type declaration - -▸ (`request`): [`Services`](../interfaces/client._internal_namespace.Services.md) - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md) | - -##### Returns - -[`Services`](../interfaces/client._internal_namespace.Services.md) - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:16 - -___ - -### GetSpaceFn - -Ƭ **GetSpaceFn**: (`request`: [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md)) => `Promise`<[`Space`](../interfaces/client._internal_namespace.Space.md) \| `undefined`\> - -#### Type declaration - -▸ (`request`): `Promise`<[`Space`](../interfaces/client._internal_namespace.Space.md) \| `undefined`\> - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `request` | [`KibanaRequest`](../classes/client._internal_namespace.KibanaRequest.md) | - -##### Returns - -`Promise`<[`Space`](../interfaces/client._internal_namespace.Space.md) \| `undefined`\> - -#### Defined in - -[x-pack/plugins/cases/server/authorization/types.ts:21](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/authorization/types.ts#L21) - -___ - -### Headers - -Ƭ **Headers**: { [header in KnownHeaders]?: string \| string[] } & { [header: string]: `string` \| `string`[] \| `undefined`; } - -Http request headers to read. - -#### Defined in - -src/core/target/types/server/http/router/headers.d.ts:36 - -___ - -### IBasePath - -Ƭ **IBasePath**: `Pick`<[`BasePath`](../classes/client._internal_namespace.BasePath.md), keyof [`BasePath`](../classes/client._internal_namespace.BasePath.md)\> - -Access or manipulate the Kibana base path - -[BasePath](../classes/client._internal_namespace.BasePath.md) - -#### Defined in - -src/core/target/types/server/http/base_path_service.d.ts:50 - -___ - -### IEvent - -Ƭ **IEvent**: [`DeepPartial`](client._internal_namespace.md#deeppartial)<[`DeepWriteable`](client._internal_namespace.md#deepwriteable)<[`IValidatedEvent`](client._internal_namespace.md#ivalidatedevent)\>\> - -#### Defined in - -x-pack/plugins/event_log/target/types/generated/schemas.d.ts:10 - -___ - -### IKibanaMigrator - -Ƭ **IKibanaMigrator**: `Pick`<[`KibanaMigrator`](../classes/client._internal_namespace.KibanaMigrator.md), keyof [`KibanaMigrator`](../classes/client._internal_namespace.KibanaMigrator.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/kibana_migrator.d.ts:17 - -___ - -### ILicenseState - -Ƭ **ILicenseState**: `PublicMethodsOf`<[`LicenseState`](../classes/client._internal_namespace.LicenseState.md)\> - -#### Defined in - -x-pack/plugins/actions/target/types/server/lib/license_state.d.ts:6 - -___ - -### ISavedObjectTypeRegistry - -Ƭ **ISavedObjectTypeRegistry**: `Omit`<[`SavedObjectTypeRegistry`](../classes/client._internal_namespace.SavedObjectTypeRegistry.md), ``"registerType"``\> - -See [SavedObjectTypeRegistry](../classes/client._internal_namespace.SavedObjectTypeRegistry.md) for documentation. - -#### Defined in - -src/core/target/types/server/saved_objects/saved_objects_type_registry.d.ts:7 - -___ - -### ISavedObjectsRepository - -Ƭ **ISavedObjectsRepository**: `Pick`<[`SavedObjectsRepository`](../classes/client._internal_namespace.SavedObjectsRepository.md), keyof [`SavedObjectsRepository`](../classes/client._internal_namespace.SavedObjectsRepository.md)\> - -See [SavedObjectsRepository](../classes/client._internal_namespace.SavedObjectsRepository.md) - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/repository.d.ts:57 - -___ - -### IValidatedEvent - -Ƭ **IValidatedEvent**: `TypeOf` - -#### Defined in - -x-pack/plugins/event_log/target/types/generated/schemas.d.ts:9 - -___ - -### KibanaExecutionContext - -Ƭ **KibanaExecutionContext**: `Object` - -#### Type declaration - -| Name | Type | Description | -| :------ | :------ | :------ | -| `description` | `string` | human readable description. For example, a vis title, action name | -| `id` | `string` | unique value to identify the source | -| `name` | `string` | public name of a user-facing feature | -| `parent?` | [`KibanaExecutionContext`](client._internal_namespace.md#kibanaexecutioncontext) | a context that spawned the current context. | -| `type` | `string` | Kibana application initated an operation. | -| `url?` | `string` | in browser - url to navigate to a current page, on server - endpoint path, for task: task SO url | - -#### Defined in - -src/core/target/types/types/execution_context.d.ts:5 - -___ - -### KibanaRequestRouteOptions - -Ƭ **KibanaRequestRouteOptions**<`Method`\>: `Method` extends ``"get"`` \| ``"options"`` ? `Required`<`Omit`<[`RouteConfigOptions`](../interfaces/client._internal_namespace.RouteConfigOptions.md)<`Method`\>, ``"body"``\>\> : `Required`<[`RouteConfigOptions`](../interfaces/client._internal_namespace.RouteConfigOptions.md)<`Method`\>\> - -Route options: If 'GET' or 'OPTIONS' method, body options won't be returned. - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Method` | extends [`RouteMethod`](client._internal_namespace.md#routemethod) | - -#### Defined in - -src/core/target/types/server/http/router/request.d.ts:30 - -___ - -### KnownHeaders - -Ƭ **KnownHeaders**: [`KnownKeys`](client._internal_namespace.md#knownkeys)<`IncomingHttpHeaders`\> - -Set of well-known HTTP headers. - -#### Defined in - -src/core/target/types/server/http/router/headers.d.ts:31 - -___ - -### KnownKeys - -Ƭ **KnownKeys**<`T`\>: [`StringKeysAsVals`](client._internal_namespace.md#stringkeysasvals)<`T`\> extends { [\_ in keyof T]: infer U } ? `U` : `never` - -Creates a Union type of all known keys of a given interface. - -**`example`** -```ts -interface Person { - name: string; - age: number; - [attributes: string]: string | number; -} -type PersonKnownKeys = KnownKeys; // "age" | "name" -``` - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Defined in - -src/core/target/types/server/http/router/headers.d.ts:24 - -___ - -### LicenseCheckState - -Ƭ **LicenseCheckState**: ``"unavailable"`` \| ``"invalid"`` \| ``"valid"`` \| ``"expired"`` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:1 - -___ - -### LicenseStatus - -Ƭ **LicenseStatus**: ``"active"`` \| ``"invalid"`` \| ``"expired"`` - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:13 - -___ - -### Mapper - -Ƭ **Mapper**<`T`\>: (`params`: `T`) => `Promise`<`T`\> - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Type declaration - -▸ (`params`): `Promise`<`T`\> - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `params` | `T` | - -##### Returns - -`Promise`<`T`\> - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/lib/middleware.d.ts:2 - -___ - -### MigrateFunction - -Ƭ **MigrateFunction**<`FromVersion`, `ToVersion`\>: (`state`: `FromVersion`) => `ToVersion` - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `FromVersion` | extends `Serializable` = `SerializableRecord` | -| `ToVersion` | extends `Serializable` = `SerializableRecord` | - -#### Type declaration - -▸ (`state`): `ToVersion` - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `state` | `FromVersion` | - -##### Returns - -`ToVersion` - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:86 - -___ - -### MigrateFunctionsObject - -Ƭ **MigrateFunctionsObject**: `Object` - -Collection of migrations that a given type of persistable state object has -accumulated over time. Migration functions are keyed using semver version -of Kibana releases. - -#### Index signature - -▪ [semver: `string`]: [`MigrateFunction`](client._internal_namespace.md#migratefunction)<`any`, `any`\> - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:83 - -___ - -### MigrationResult - -Ƭ **MigrationResult**: { `status`: ``"skipped"`` } \| { `status`: ``"patched"`` } \| { `destIndex`: `string` ; `elapsedMs`: `number` ; `sourceIndex`: `string` ; `status`: ``"migrated"`` } - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/types.d.ts:2 - -___ - -### MigrationStatus - -Ƭ **MigrationStatus**: ``"waiting_to_start"`` \| ``"waiting_for_other_nodes"`` \| ``"running"`` \| ``"completed"`` - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/core/types.d.ts:1 - -___ - -### MutatingOperationRefreshSetting - -Ƭ **MutatingOperationRefreshSetting**: `boolean` \| ``"wait_for"`` - -Elasticsearch Refresh setting for mutating operation - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:132 - -___ - -### PatchCaseArgs - -Ƭ **PatchCaseArgs**: [`PatchCase`](../interfaces/client._internal_namespace.PatchCase.md) & [`ClientArgs`](../interfaces/client._internal_namespace.ClientArgs-1.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/cases/index.ts:103](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/cases/index.ts#L103) - -___ - -### PersistableStateDefinition - -Ƭ **PersistableStateDefinition**<`P`\>: `Partial`<[`PersistableState`](../interfaces/client._internal_namespace.PersistableState.md)<`P`\>\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `P` | extends `SerializableRecord` = `SerializableRecord` | - -#### Defined in - -src/plugins/kibana_utils/target/types/common/persistable_state/types.d.ts:93 - -___ - -### PublicFeatures - -Ƭ **PublicFeatures**: `Record`<`string`, [`LicenseFeature`](../interfaces/client._internal_namespace.LicenseFeature.md)\> - -Provides information about feature availability for the current license. - -#### Defined in - -x-pack/plugins/licensing/target/types/common/types.d.ts:51 - -___ - -### RouteContentType - -Ƭ **RouteContentType**: ``"application/json"`` \| ``"application/*+json"`` \| ``"application/octet-stream"`` \| ``"application/x-www-form-urlencoded"`` \| ``"multipart/form-data"`` \| ``"text/*"`` - -The set of supported parseable Content-Types - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:27 - -___ - -### RouteMethod - -Ƭ **RouteMethod**: [`SafeRouteMethod`](client._internal_namespace.md#saferoutemethod) \| [`DestructiveRouteMethod`](client._internal_namespace.md#destructiveroutemethod) - -The set of common HTTP methods supported by Kibana routing. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:17 - -___ - -### RouteValidationFunction - -Ƭ **RouteValidationFunction**<`T`\>: (`data`: `any`, `validationResult`: [`RouteValidationResultFactory`](../interfaces/client._internal_namespace.RouteValidationResultFactory.md)) => { `error?`: `never` ; `value`: `T` } \| { `error`: [`RouteValidationError`](../classes/client._internal_namespace.RouteValidationError.md) ; `value?`: `never` } - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Type declaration - -▸ (`data`, `validationResult`): { `error?`: `never` ; `value`: `T` } \| { `error`: [`RouteValidationError`](../classes/client._internal_namespace.RouteValidationError.md) ; `value?`: `never` } - -The custom validation function if @kbn/config-schema is not a valid solution for your specific plugin requirements. - -**`example`** - -The validation should look something like: -```typescript -interface MyExpectedBody { - bar: string; - baz: number; -} - -const myBodyValidation: RouteValidationFunction = (data, validationResult) => { - const { ok, badRequest } = validationResult; - const { bar, baz } = data || {}; - if (typeof bar === 'string' && typeof baz === 'number') { - return ok({ bar, baz }); - } else { - return badRequest('Wrong payload', ['body']); - } -} -``` - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `data` | `any` | -| `validationResult` | [`RouteValidationResultFactory`](../interfaces/client._internal_namespace.RouteValidationResultFactory.md) | - -##### Returns - -{ `error?`: `never` ; `value`: `T` } \| { `error`: [`RouteValidationError`](../classes/client._internal_namespace.RouteValidationError.md) ; `value?`: `never` } - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:43 - -___ - -### RouteValidationSpec - -Ƭ **RouteValidationSpec**<`T`\>: `ObjectType` \| `Type`<`T`\> \| [`RouteValidationFunction`](client._internal_namespace.md#routevalidationfunction)<`T`\> - -Allowed property validation options: either @kbn/config-schema validations or custom validation functions - -See [RouteValidationFunction](client._internal_namespace.md#routevalidationfunction) for custom validation. - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:57 - -___ - -### RouteValidatorFullConfig - -Ƭ **RouteValidatorFullConfig**<`P`, `Q`, `B`\>: [`RouteValidatorConfig`](../interfaces/client._internal_namespace.RouteValidatorConfig.md)<`P`, `Q`, `B`\> & [`RouteValidatorOptions`](../interfaces/client._internal_namespace.RouteValidatorOptions.md) - -Route validations config and options merged into one object - -#### Type parameters - -| Name | -| :------ | -| `P` | -| `Q` | -| `B` | - -#### Defined in - -src/core/target/types/server/http/router/validator/validator.d.ts:101 - -___ - -### RunFunction - -Ƭ **RunFunction**: () => `Promise`<[`RunResult`](client._internal_namespace.md#runresult) \| `undefined` \| `void`\> - -#### Type declaration - -▸ (): `Promise`<[`RunResult`](client._internal_namespace.md#runresult) \| `undefined` \| `void`\> - -##### Returns - -`Promise`<[`RunResult`](client._internal_namespace.md#runresult) \| `undefined` \| `void`\> - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:64 - -___ - -### RunResult - -Ƭ **RunResult**: [`FailedRunResult`](client._internal_namespace.md#failedrunresult) \| [`SuccessfulRunResult`](client._internal_namespace.md#successfulrunresult) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:59 - -___ - -### SafeRouteMethod - -Ƭ **SafeRouteMethod**: ``"get"`` \| ``"options"`` - -Set of HTTP methods not changing the state of the server. - -#### Defined in - -src/core/target/types/server/http/router/route.d.ts:12 - -___ - -### SavedObjectAttribute - -Ƭ **SavedObjectAttribute**: [`SavedObjectAttributeSingle`](client._internal_namespace.md#savedobjectattributesingle) \| [`SavedObjectAttributeSingle`](client._internal_namespace.md#savedobjectattributesingle)[] - -Type definition for a Saved Object attribute value - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:12 - -___ - -### SavedObjectAttributeSingle - -Ƭ **SavedObjectAttributeSingle**: `string` \| `number` \| `boolean` \| ``null`` \| `undefined` \| [`SavedObjectAttributes`](../interfaces/client._internal_namespace.SavedObjectAttributes.md) - -Don't use this type, it's simply a helper type for [SavedObjectAttribute](client._internal_namespace.md#savedobjectattribute) - -#### Defined in - -src/core/target/types/types/saved_objects.d.ts:6 - -___ - -### SavedObjectFindOptions - -Ƭ **SavedObjectFindOptions**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/saved_object.ts:72](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/saved_object.ts#L72) - -___ - -### SavedObjectFindOptionsKueryNode - -Ƭ **SavedObjectFindOptionsKueryNode**: `Omit`<[`SavedObjectFindOptions`](client._internal_namespace.md#savedobjectfindoptions), ``"filter"``\> & { `filter?`: `KueryNode` } - -#### Defined in - -[x-pack/plugins/cases/server/common/types.ts:19](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/common/types.ts#L19) - -___ - -### SavedObjectMigrationFn - -Ƭ **SavedObjectMigrationFn**<`InputAttributes`, `MigratedAttributes`\>: (`doc`: [`SavedObjectUnsanitizedDoc`](client._internal_namespace.md#savedobjectunsanitizeddoc)<`InputAttributes`\>, `context`: [`SavedObjectMigrationContext`](../interfaces/client._internal_namespace.SavedObjectMigrationContext.md)) => [`SavedObjectUnsanitizedDoc`](client._internal_namespace.md#savedobjectunsanitizeddoc)<`MigratedAttributes`\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `InputAttributes` | `unknown` | -| `MigratedAttributes` | `unknown` | - -#### Type declaration - -▸ (`doc`, `context`): [`SavedObjectUnsanitizedDoc`](client._internal_namespace.md#savedobjectunsanitizeddoc)<`MigratedAttributes`\> - -A migration function for a [saved object type](../interfaces/client._internal_namespace.SavedObjectsType.md) -used to migrate it to a given version - -**`example`** -```typescript -interface TypeV1Attributes { - someKey: string; - obsoleteProperty: number; -} - -interface TypeV2Attributes { - someKey: string; - newProperty: string; -} - -const migrateToV2: SavedObjectMigrationFn = (doc, { log }) => { - const { obsoleteProperty, ...otherAttributes } = doc.attributes; - // instead of mutating `doc` we make a shallow copy so that we can use separate types for the input - // and output attributes. We don't need to make a deep copy, we just need to ensure that obsolete - // attributes are not present on the returned doc. - return { - ...doc, - attributes: { - ...otherAttributes, - newProperty: migrate(obsoleteProperty), - }, - }; -}; -``` - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `doc` | [`SavedObjectUnsanitizedDoc`](client._internal_namespace.md#savedobjectunsanitizeddoc)<`InputAttributes`\> | -| `context` | [`SavedObjectMigrationContext`](../interfaces/client._internal_namespace.SavedObjectMigrationContext.md) | - -##### Returns - -[`SavedObjectUnsanitizedDoc`](client._internal_namespace.md#savedobjectunsanitizeddoc)<`MigratedAttributes`\> - -#### Defined in - -src/core/target/types/server/saved_objects/migrations/types.d.ts:39 - -___ - -### SavedObjectTypeExcludeFromUpgradeFilterHook - -Ƭ **SavedObjectTypeExcludeFromUpgradeFilterHook**: (`toolkit`: { `readonlyEsClient`: `Pick`<[`ElasticsearchClient`](client._internal_namespace.md#elasticsearchclient), ``"search"``\> }) => `estypes.QueryDslQueryContainer` \| `Promise`<`estypes.QueryDslQueryContainer`\> - -#### Type declaration - -▸ (`toolkit`): `estypes.QueryDslQueryContainer` \| `Promise`<`estypes.QueryDslQueryContainer`\> - -If defined, allows a type to run a search query and return a query filter that may match any documents which may -be excluded from the next migration upgrade process. Useful for cleaning up large numbers of old documents which -are no longer needed and may slow the migration process. - -If this hook fails, the migration will proceed without these documents having been filtered out, so this -should not be used as a guarantee that these documents have been deleted. - -**`alpha`** Experimental and subject to change - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `toolkit` | `Object` | -| `toolkit.readonlyEsClient` | `Pick`<[`ElasticsearchClient`](client._internal_namespace.md#elasticsearchclient), ``"search"``\> | - -##### Returns - -`estypes.QueryDslQueryContainer` \| `Promise`<`estypes.QueryDslQueryContainer`\> - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:479 - -___ - -### SavedObjectUnsanitizedDoc - -Ƭ **SavedObjectUnsanitizedDoc**<`T`\>: [`SavedObjectDoc`](../interfaces/client._internal_namespace.SavedObjectDoc.md)<`T`\> & `Partial`<[`Referencable`](../interfaces/client._internal_namespace.Referencable.md)\> - -Describes Saved Object documents from Kibana < 7.0.0 which don't have a -`references` root property defined. This type should only be used in -migrations. - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Defined in - -src/core/target/types/server/saved_objects/serialization/types.d.ts:49 - -___ - -### SavedObjectsClientContract - -Ƭ **SavedObjectsClientContract**: `Pick`<[`SavedObjectsClient`](../classes/client._internal_namespace.SavedObjectsClient.md), keyof [`SavedObjectsClient`](../classes/client._internal_namespace.SavedObjectsClient.md)\> - -Saved Objects is Kibana's data persisentence mechanism allowing plugins to -use Elasticsearch for storing plugin state. - -## SavedObjectsClient errors - -Since the SavedObjectsClient has its hands in everything we -are a little paranoid about the way we present errors back to -to application code. Ideally, all errors will be either: - - 1. Caused by bad implementation (ie. undefined is not a function) and - as such unpredictable - 2. An error that has been classified and decorated appropriately - by the decorators in [SavedObjectsErrorHelpers](../classes/client._internal_namespace.SavedObjectsErrorHelpers.md) - -Type 1 errors are inevitable, but since all expected/handle-able errors -should be Type 2 the `isXYZError()` helpers exposed at -`SavedObjectsErrorHelpers` should be used to understand and manage error -responses from the `SavedObjectsClient`. - -Type 2 errors are decorated versions of the source error, so if -the elasticsearch client threw an error it will be decorated based -on its type. That means that rather than looking for `error.body.error.type` or -doing substring checks on `error.body.error.reason`, just use the helpers to -understand the meaning of the error: - - ```js - if (SavedObjectsErrorHelpers.isNotFoundError(error)) { - // handle 404 - } - - if (SavedObjectsErrorHelpers.isNotAuthorizedError(error)) { - // 401 handling should be automatic, but in case you wanted to know - } - - // always rethrow the error unless you handle it - throw error; - ``` - -### 404s from missing index - -From the perspective of application code and APIs the SavedObjectsClient is -a black box that persists objects. One of the internal details that users have -no control over is that we use an elasticsearch index for persistence and that -index might be missing. - -At the time of writing we are in the process of transitioning away from the -operating assumption that the SavedObjects index is always available. Part of -this transition is handling errors resulting from an index missing. These used -to trigger a 500 error in most cases, and in others cause 404s with different -error messages. - -From my (Spencer) perspective, a 404 from the SavedObjectsApi is a 404; The -object the request/call was targeting could not be found. This is why #14141 -takes special care to ensure that 404 errors are generic and don't distinguish -between index missing or document missing. - -See [SavedObjectsClient](../classes/client._internal_namespace.SavedObjectsClient.md) -See [SavedObjectsErrorHelpers](../classes/client._internal_namespace.SavedObjectsErrorHelpers.md) - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:195 - -___ - -### SavedObjectsCreatePointInTimeFinderOptions - -Ƭ **SavedObjectsCreatePointInTimeFinderOptions**: `Omit`<[`SavedObjectsFindOptions`](../interfaces/client._internal_namespace.SavedObjectsFindOptions.md), ``"page"`` \| ``"pit"`` \| ``"searchAfter"``\> - -#### Defined in - -src/core/target/types/server/saved_objects/service/lib/point_in_time_finder.d.ts:7 - -___ - -### SavedObjectsExportTransform - -Ƭ **SavedObjectsExportTransform**<`T`\>: (`context`: [`SavedObjectsExportTransformContext`](../interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md), `objects`: [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>[]) => [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)[] \| `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)[]\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Type declaration - -▸ (`context`, `objects`): [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)[] \| `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)[]\> - -Transformation function used to mutate the exported objects of the associated type. - -A type's export transform function will be executed once per user-initiated export, -for all objects of that type. - -**`example`** -Registering a transform function changing the object's attributes during the export -```ts -// src/plugins/my_plugin/server/plugin.ts -import { myType } from './saved_objects'; - -export class Plugin() { - setup: (core: CoreSetup) => { - core.savedObjects.registerType({ - ...myType, - management: { - ...myType.management, - onExport: (ctx, objects) => { - return objects.map((obj) => ({ - ...obj, - attributes: { - ...obj.attributes, - enabled: false, - } - }) - } - }, - }); - } -} -``` - -**`example`** -Registering a transform function adding additional objects to the export -```ts -// src/plugins/my_plugin/server/plugin.ts -import { myType } from './saved_objects'; - -export class Plugin() { - setup: (core: CoreSetup) => { - const savedObjectStartContractPromise = getStartServices().then( - ([{ savedObjects: savedObjectsStart }]) => savedObjectsStart - ); - - core.savedObjects.registerType({ - ...myType, - management: { - ...myType.management, - onExport: async (ctx, objects) => { - const { getScopedClient } = await savedObjectStartContractPromise; - const client = getScopedClient(ctx.request); - - const depResponse = await client.find({ - type: 'my-nested-object', - hasReference: objs.map(({ id, type }) => ({ id, type })), - }); - - return [...objs, ...depResponse.saved_objects]; - } - }, - }); - } -} -``` - -**`remarks`** Trying to change an object's id or type during the transform will result in - a runtime error during the export process. - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `context` | [`SavedObjectsExportTransformContext`](../interfaces/client._internal_namespace.SavedObjectsExportTransformContext.md) | -| `objects` | [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>[] | - -##### Returns - -[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)[] \| `Promise`<[`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)[]\> - -#### Defined in - -src/core/target/types/server/saved_objects/export/types.d.ts:160 - -___ - -### SavedObjectsExportablePredicate - -Ƭ **SavedObjectsExportablePredicate**<`Attributes`\>: (`obj`: [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`Attributes`\>) => `boolean` - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `Attributes` | `unknown` | - -#### Type declaration - -▸ (`obj`): `boolean` - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `obj` | [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`Attributes`\> | - -##### Returns - -`boolean` - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:467 - -___ - -### SavedObjectsFieldMapping - -Ƭ **SavedObjectsFieldMapping**: `estypes.MappingProperty` & { `dynamic?`: ``false`` \| ``"strict"`` } - -Describe a [saved object type mapping](../interfaces/client._internal_namespace.SavedObjectsTypeMappingDefinition.md) field. - -Please refer to [elasticsearch documentation](https://www.elastic.co/guide/en/elasticsearch/reference/current/mapping-types.html) -For the mapping documentation - -#### Defined in - -src/core/target/types/server/saved_objects/mappings/types.d.ts:89 - -___ - -### SavedObjectsImportHook - -Ƭ **SavedObjectsImportHook**<`T`\>: (`objects`: [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>[]) => [`SavedObjectsImportHookResult`](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md) \| `Promise`<[`SavedObjectsImportHookResult`](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md)\> - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | `unknown` | - -#### Type declaration - -▸ (`objects`): [`SavedObjectsImportHookResult`](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md) \| `Promise`<[`SavedObjectsImportHookResult`](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md)\> - -A hook associated with a specific saved object type, that will be invoked during -the import process. The hook will have access to the objects of the registered type. - -Currently, the only supported feature for import hooks is to return warnings to be displayed -in the UI when the import succeeds. - -**`remark`** The only interactions the hook can have with the import process is via the hook's - response. Mutating the objects inside the hook's code will have no effect. - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `objects` | [`SavedObject`](../interfaces/client._internal_namespace.SavedObject.md)<`T`\>[] | - -##### Returns - -[`SavedObjectsImportHookResult`](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md) \| `Promise`<[`SavedObjectsImportHookResult`](../interfaces/client._internal_namespace.SavedObjectsImportHookResult.md)\> - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:227 - -___ - -### SavedObjectsImportWarning - -Ƭ **SavedObjectsImportWarning**: [`SavedObjectsImportSimpleWarning`](../interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md) \| [`SavedObjectsImportActionRequiredWarning`](../interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md) - -Composite type of all the possible types of import warnings. - -See [SavedObjectsImportSimpleWarning](../interfaces/client._internal_namespace.SavedObjectsImportSimpleWarning.md) and [SavedObjectsImportActionRequiredWarning](../interfaces/client._internal_namespace.SavedObjectsImportActionRequiredWarning.md) -for more details. - -#### Defined in - -src/core/target/types/server/saved_objects/import/types.d.ts:203 - -___ - -### SavedObjectsNamespaceType - -Ƭ **SavedObjectsNamespaceType**: ``"single"`` \| ``"multiple"`` \| ``"multiple-isolated"`` \| ``"agnostic"`` - -The namespace type dictates how a saved object can be interacted in relation to namespaces. Each type is mutually exclusive: - * single (default): This type of saved object is namespace-isolated, e.g., it exists in only one namespace. - * multiple: This type of saved object is shareable, e.g., it can exist in one or more namespaces. - * multiple-isolated: This type of saved object is namespace-isolated, e.g., it exists in only one namespace, but object IDs must be - unique across all namespaces. This is intended to be an intermediate step when objects with a "single" namespace type are being - converted to a "multiple" namespace type. In other words, objects with a "multiple-isolated" namespace type will be *share-capable*, - but will not actually be shareable until the namespace type is changed to "multiple". - * agnostic: This type of saved object is global. - -#### Defined in - -src/core/target/types/server/saved_objects/types.d.ts:208 - -___ - -### SavedObjectsValidationSpec - -Ƭ **SavedObjectsValidationSpec**: `ObjectType` - -Allows for validating properties using @kbn/config-schema validations. - -#### Defined in - -src/core/target/types/server/saved_objects/validation/types.d.ts:7 - -___ - -### SpaceIdToNamespaceFunction - -Ƭ **SpaceIdToNamespaceFunction**: (`spaceId?`: `string`) => `string` \| `undefined` - -#### Type declaration - -▸ (`spaceId?`): `string` \| `undefined` - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `spaceId?` | `string` | - -##### Returns - -`string` \| `undefined` - -#### Defined in - -x-pack/plugins/actions/target/types/server/types.d.ts:18 - -___ - -### StringKeysAsVals - -Ƭ **StringKeysAsVals**<`T`\>: { [K in keyof T]: string extends K ? never : number extends K ? never : K } - -Converts an object type to a new object type where each string -key is copied to the values of the object, and non string keys are -given a `never` value. This allows us to map over the values and -get the list of all string keys on a type in `KnownKeys` - -#### Type parameters - -| Name | -| :------ | -| `T` | - -#### Defined in - -src/core/target/types/server/http/router/headers.d.ts:9 - -___ - -### SubFeaturePrivilegeGroupType - -Ƭ **SubFeaturePrivilegeGroupType**: ``"mutually_exclusive"`` \| ``"independent"`` - -The type of privilege group. -- `mutually_exclusive`:: - Users will be able to select at most one privilege within this group. - Privileges must be specified in descending order of permissiveness (e.g. `All`, `Read`, not `Read`, `All) -- `independent`:: - Users will be able to select any combination of privileges within this group. - -#### Defined in - -x-pack/plugins/features/target/types/common/sub_feature.d.ts:21 - -___ - -### SuccessfulRunResult - -Ƭ **SuccessfulRunResult**: { `state`: `Record`<`string`, `unknown`\> } & { `runAt?`: `Date` ; `schedule?`: `never` } \| { `runAt?`: `never` ; `schedule?`: [`IntervalSchedule`](../interfaces/client._internal_namespace.IntervalSchedule.md) } - -The return value of a task's run function should be a promise of RunResult. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:28 - -___ - -### TaskDefinitionRegistry - -Ƭ **TaskDefinitionRegistry**: `Record`<`string`, [`TaskRegisterDefinition`](../interfaces/client._internal_namespace.TaskRegisterDefinition.md)\> - -A mapping of task type id to the task definition. - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task_type_dictionary.d.ts:52 - -___ - -### TaskRunCreatorFunction - -Ƭ **TaskRunCreatorFunction**: (`context`: [`RunContext`](../interfaces/client._internal_namespace.RunContext.md)) => [`CancellableTask`](../interfaces/client._internal_namespace.CancellableTask.md) - -#### Type declaration - -▸ (`context`): [`CancellableTask`](../interfaces/client._internal_namespace.CancellableTask.md) - -##### Parameters - -| Name | Type | -| :------ | :------ | -| `context` | [`RunContext`](../interfaces/client._internal_namespace.RunContext.md) | - -##### Returns - -[`CancellableTask`](../interfaces/client._internal_namespace.CancellableTask.md) - -#### Defined in - -x-pack/plugins/task_manager/target/types/server/task.d.ts:70 - -___ - -### UpdateAttachmentArgs - -Ƭ **UpdateAttachmentArgs**: [`UpdateArgs`](../interfaces/client._internal_namespace.UpdateArgs.md) & [`ClientArgs`](../interfaces/client._internal_namespace.ClientArgs-1.md) - -#### Defined in - -[x-pack/plugins/cases/server/services/attachments/index.ts:59](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/attachments/index.ts#L59) - -___ - -### UserAction - -Ƭ **UserAction**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/user_actions/index.ts:85](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/user_actions/index.ts#L85) - -___ - -### UserActionParameters - -Ƭ **UserActionParameters**<`T`\>: [`BuilderParameters`](../interfaces/client._internal_namespace.BuilderParameters.md)[`T`][``"parameters"``] & [`CommonArguments`](../interfaces/client._internal_namespace.CommonArguments.md) - -#### Type parameters - -| Name | Type | -| :------ | :------ | -| `T` | extends keyof [`BuilderParameters`](../interfaces/client._internal_namespace.BuilderParameters.md) | - -#### Defined in - -[x-pack/plugins/cases/server/services/user_actions/types.ts:71](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/services/user_actions/types.ts#L71) - -___ - -### UserActionTypes - -Ƭ **UserActionTypes**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/user_actions/index.ts:86](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/user_actions/index.ts#L86) - -## Variables - -### ActionTypesRt - -• **ActionTypesRt**: `KeyofC`<{ `comment`: ``"comment"`` = 'comment'; `connector`: ``"connector"`` = 'connector'; `create_case`: ``"create_case"`` = 'create\_case'; `delete_case`: ``"delete_case"`` = 'delete\_case'; `description`: ``"description"`` = 'description'; `pushed`: ``"pushed"`` = 'pushed'; `settings`: ``"settings"`` = 'settings'; `status`: ``"status"`` = 'status'; `tags`: ``"tags"`` = 'tags'; `title`: ``"title"`` = 'title' }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/user_actions/common.ts:35](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/user_actions/common.ts#L35) - -___ - -### ActionsRt - -• **ActionsRt**: `KeyofC`<{ `add`: ``"add"`` = 'add'; `create`: ``"create"`` = 'create'; `delete`: ``"delete"`` = 'delete'; `push_to_service`: ``"push_to_service"`` = 'push\_to\_service'; `update`: ``"update"`` = 'update' }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/user_actions/common.ts:36](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/user_actions/common.ts#L36) - -___ - -### CasesFindRequestRt - -• **CasesFindRequestRt**: `PartialC`<{ `defaultSearchOperator`: `UnionC`<[`LiteralC`<``"AND"``\>, `LiteralC`<``"OR"``\>]\> ; `fields`: `ArrayC`<`StringC`\> ; `owner`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `page`: `Type`<`number`, `string`, `unknown`\> = NumberFromString; `perPage`: `Type`<`number`, `string`, `unknown`\> = NumberFromString; `reporters`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `search`: `StringC` = rt.string; `searchFields`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `sortField`: `StringC` = rt.string; `sortOrder`: `UnionC`<[`LiteralC`<``"desc"``\>, `LiteralC`<``"asc"``\>]\> ; `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt; `tags`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:136](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L136) - -___ - -### EventSchema - -• **EventSchema**: `Type` - -#### Defined in - -x-pack/plugins/event_log/target/types/generated/schemas.d.ts:11 - -___ - -### SavedObjectFindOptionsRt - -• **SavedObjectFindOptionsRt**: `PartialC`<{ `defaultSearchOperator`: `UnionC`<[`LiteralC`<``"AND"``\>, `LiteralC`<``"OR"``\>]\> ; `fields`: `ArrayC`<`StringC`\> ; `filter`: `StringC` = rt.string; `hasReference`: `UnionC`<[`ArrayC`<`TypeC`<{ `id`: `StringC` = rt.string; `type`: `StringC` = rt.string }\>\>, `TypeC`<{ `id`: `StringC` = rt.string; `type`: `StringC` = rt.string }\>]\> ; `hasReferenceOperator`: `UnionC`<[`LiteralC`<``"AND"``\>, `LiteralC`<``"OR"``\>]\> ; `page`: `Type`<`number`, `string`, `unknown`\> = NumberFromString; `perPage`: `Type`<`number`, `string`, `unknown`\> = NumberFromString; `search`: `StringC` = rt.string; `searchFields`: `ArrayC`<`StringC`\> ; `sortField`: `StringC` = rt.string; `sortOrder`: `UnionC`<[`LiteralC`<``"desc"``\>, `LiteralC`<``"asc"``\>]\> }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/saved_object.ts:25](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/saved_object.ts#L25) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/client.md b/x-pack/plugins/cases/docs/cases_client/modules/client.md deleted file mode 100644 index b03a7ba7673bb..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/client.md +++ /dev/null @@ -1,13 +0,0 @@ -[Cases Client API Interface](../README.md) / client - -# Module: client - -## Table of contents - -### Namespaces - -- [\_internal\_namespace](client._internal_namespace.md) - -### Classes - -- [CasesClient](../classes/client.CasesClient.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/configure_client._internal_namespace.md b/x-pack/plugins/cases/docs/cases_client/modules/configure_client._internal_namespace.md deleted file mode 100644 index cb22acb5a298c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/configure_client._internal_namespace.md +++ /dev/null @@ -1,13 +0,0 @@ -[Cases Client API Interface](../README.md) / [configure/client](configure_client.md) / \_internal\_namespace - -# Namespace: \_internal\_namespace - -[configure/client](configure_client.md)._internal_namespace - -## Table of contents - -### Interfaces - -- [CreateMappingsArgs](../interfaces/configure_client._internal_namespace.CreateMappingsArgs.md) -- [MappingsArgs](../interfaces/configure_client._internal_namespace.MappingsArgs.md) -- [UpdateMappingsArgs](../interfaces/configure_client._internal_namespace.UpdateMappingsArgs.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/configure_client.md b/x-pack/plugins/cases/docs/cases_client/modules/configure_client.md deleted file mode 100644 index 690afd51a4f65..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/configure_client.md +++ /dev/null @@ -1,37 +0,0 @@ -[Cases Client API Interface](../README.md) / configure/client - -# Module: configure/client - -## Table of contents - -### Namespaces - -- [\_internal\_namespace](configure_client._internal_namespace.md) - -### Interfaces - -- [ConfigureSubClient](../interfaces/configure_client.ConfigureSubClient.md) - -### Functions - -- [getConnectors](configure_client.md#getconnectors) - -## Functions - -### getConnectors - -▸ **getConnectors**(`__namedParameters`): `Promise`<[`FindActionResult`](../interfaces/client._internal_namespace.FindActionResult.md)[]\> - -#### Parameters - -| Name | Type | -| :------ | :------ | -| `__namedParameters` | [`CasesClientArgs`](../interfaces/client._internal_namespace.CasesClientArgs.md) | - -#### Returns - -`Promise`<[`FindActionResult`](../interfaces/client._internal_namespace.FindActionResult.md)[]\> - -#### Defined in - -[x-pack/plugins/cases/server/client/configure/client.ts:206](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/server/client/configure/client.ts#L206) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/metrics_client._internal_namespace.md b/x-pack/plugins/cases/docs/cases_client/modules/metrics_client._internal_namespace.md deleted file mode 100644 index 318b517747494..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/metrics_client._internal_namespace.md +++ /dev/null @@ -1,11 +0,0 @@ -[Cases Client API Interface](../README.md) / [metrics/client](metrics_client.md) / \_internal\_namespace - -# Namespace: \_internal\_namespace - -[metrics/client](metrics_client.md)._internal_namespace - -## Table of contents - -### Interfaces - -- [CaseMetricsParams](../interfaces/metrics_client._internal_namespace.CaseMetricsParams.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/metrics_client.md b/x-pack/plugins/cases/docs/cases_client/modules/metrics_client.md deleted file mode 100644 index c4c7354ba5afe..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/metrics_client.md +++ /dev/null @@ -1,13 +0,0 @@ -[Cases Client API Interface](../README.md) / metrics/client - -# Module: metrics/client - -## Table of contents - -### Namespaces - -- [\_internal\_namespace](metrics_client._internal_namespace.md) - -### Interfaces - -- [MetricsSubClient](../interfaces/metrics_client.MetricsSubClient.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/stats_client.md b/x-pack/plugins/cases/docs/cases_client/modules/stats_client.md deleted file mode 100644 index f0632f6ca0069..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/stats_client.md +++ /dev/null @@ -1,9 +0,0 @@ -[Cases Client API Interface](../README.md) / stats/client - -# Module: stats/client - -## Table of contents - -### Interfaces - -- [StatsSubClient](../interfaces/stats_client.StatsSubClient.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces._internal_namespace.md b/x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces._internal_namespace.md deleted file mode 100644 index 38b2fc2ea5150..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces._internal_namespace.md +++ /dev/null @@ -1,277 +0,0 @@ -[Cases Client API Interface](../README.md) / [typedoc\_interfaces](typedoc_interfaces.md) / \_internal\_namespace - -# Namespace: \_internal\_namespace - -[typedoc_interfaces](typedoc_interfaces.md)._internal_namespace - -## Table of contents - -### Type aliases - -- [AllCommentsResponse](typedoc_interfaces._internal_namespace.md#allcommentsresponse) -- [CasePostRequest](typedoc_interfaces._internal_namespace.md#casepostrequest) -- [CaseResolveResponse](typedoc_interfaces._internal_namespace.md#caseresolveresponse) -- [CaseResponse](typedoc_interfaces._internal_namespace.md#caseresponse) -- [CaseUserActionsResponse](typedoc_interfaces._internal_namespace.md#caseuseractionsresponse) -- [CasesConfigurePatch](typedoc_interfaces._internal_namespace.md#casesconfigurepatch) -- [CasesConfigureRequest](typedoc_interfaces._internal_namespace.md#casesconfigurerequest) -- [CasesConfigureResponse](typedoc_interfaces._internal_namespace.md#casesconfigureresponse) -- [CasesFindResponse](typedoc_interfaces._internal_namespace.md#casesfindresponse) -- [CasesPatchRequest](typedoc_interfaces._internal_namespace.md#casespatchrequest) -- [CasesResponse](typedoc_interfaces._internal_namespace.md#casesresponse) -- [CommentsResponse](typedoc_interfaces._internal_namespace.md#commentsresponse) - -### Variables - -- [AllCommentsResponseRt](typedoc_interfaces._internal_namespace.md#allcommentsresponsert) -- [CaseConfigureResponseRt](typedoc_interfaces._internal_namespace.md#caseconfigureresponsert) -- [CasePostRequestRt](typedoc_interfaces._internal_namespace.md#casepostrequestrt) -- [CaseResolveResponseRt](typedoc_interfaces._internal_namespace.md#caseresolveresponsert) -- [CaseResponseRt](typedoc_interfaces._internal_namespace.md#caseresponsert) -- [CaseUserActionsResponseRt](typedoc_interfaces._internal_namespace.md#caseuseractionsresponsert) -- [CasesConfigurePatchRt](typedoc_interfaces._internal_namespace.md#casesconfigurepatchrt) -- [CasesConfigureRequestRt](typedoc_interfaces._internal_namespace.md#casesconfigurerequestrt) -- [CasesFindResponseRt](typedoc_interfaces._internal_namespace.md#casesfindresponsert) -- [CasesPatchRequestRt](typedoc_interfaces._internal_namespace.md#casespatchrequestrt) -- [CasesResponseRt](typedoc_interfaces._internal_namespace.md#casesresponsert) -- [CommentsResponseRt](typedoc_interfaces._internal_namespace.md#commentsresponsert) - -## Type aliases - -### AllCommentsResponse - -Ƭ **AllCommentsResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:166](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L166) - -___ - -### CasePostRequest - -Ƭ **CasePostRequest**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:280](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L280) - -___ - -### CaseResolveResponse - -Ƭ **CaseResolveResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:282](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L282) - -___ - -### CaseResponse - -Ƭ **CaseResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:281](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L281) - -___ - -### CaseUserActionsResponse - -Ƭ **CaseUserActionsResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/user_actions/index.ts:82](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/user_actions/index.ts#L82) - -___ - -### CasesConfigurePatch - -Ƭ **CasesConfigurePatch**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/configure.ts:81](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/configure.ts#L81) - -___ - -### CasesConfigureRequest - -Ƭ **CasesConfigureRequest**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/configure.ts:80](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/configure.ts#L80) - -___ - -### CasesConfigureResponse - -Ƭ **CasesConfigureResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/configure.ts:83](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/configure.ts#L83) - -___ - -### CasesFindResponse - -Ƭ **CasesFindResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:286](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L286) - -___ - -### CasesPatchRequest - -Ƭ **CasesPatchRequest**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:288](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L288) - -___ - -### CasesResponse - -Ƭ **CasesResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:283](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L283) - -___ - -### CommentsResponse - -Ƭ **CommentsResponse**: `rt.TypeOf` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:167](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L167) - -## Variables - -### AllCommentsResponseRt - -• **AllCommentsResponseRt**: `ArrayC`<`IntersectionC`<[`UnionC`<[`IntersectionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:150](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L150) - -___ - -### CaseConfigureResponseRt - -• **CaseConfigureResponseRt**: `IntersectionC`<[`IntersectionC`<[`IntersectionC`<[`TypeC`<{ `closure_type`: `UnionC`<[`LiteralC`<``"close-by-user"``\>, `LiteralC`<``"close-by-pushing"``\>]\> = ClosureTypeRT; `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt }\>, `TypeC`<{ `owner`: `StringC` = rt.string }\>]\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `TypeC`<{ `mappings`: `ArrayC`<`TypeC`<{ `action_type`: `UnionC`<[`LiteralC`<``"append"``\>, `LiteralC`<``"nothing"``\>, `LiteralC`<``"overwrite"``\>]\> = ActionTypeRT; `source`: `UnionC`<[`LiteralC`<``"title"``\>, `LiteralC`<``"description"``\>, `LiteralC`<``"comments"``\>]\> = CaseFieldRT; `target`: `UnionC`<[`StringC`, `LiteralC`<``"not_mapped"``\>]\> = ThirdPartyFieldRT }\>\> ; `owner`: `StringC` = rt.string }\>, `TypeC`<{ `error`: `UnionC`<[`StringC`, `NullC`]\> ; `id`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/configure.ts:53](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/configure.ts#L53) - -___ - -### CasePostRequestRt - -• **CasePostRequestRt**: `TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt; `description`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt; `tags`: `ArrayC`<`StringC`\> ; `title`: `StringC` = rt.string }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:108](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L108) - -___ - -### CaseResolveResponseRt - -• **CaseResolveResponseRt**: `IntersectionC`<[`TypeC`<{ `case`: `IntersectionC`<[`IntersectionC`<[`TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt; `description`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt; `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt; `tags`: `ArrayC`<`StringC`\> ; `title`: `StringC` = rt.string }\>, `TypeC`<{ `closed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `closed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `external_service`: `UnionC`<[`IntersectionC`<[`TypeC`<{ `connector_id`: `StringC` = rt.string }\>, `TypeC`<{ `connector_name`: `StringC` = rt.string; `external_id`: `StringC` = rt.string; `external_title`: `StringC` = rt.string; `external_url`: `StringC` = rt.string; `pushed_at`: `StringC` = rt.string; `pushed_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT }\>]\>, `NullC`]\> = CaseFullExternalServiceRt; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `totalAlerts`: `NumberC` = rt.number; `totalComment`: `NumberC` = rt.number; `version`: `StringC` = rt.string }\>, `PartialC`<{ `comments`: `ArrayC`<`IntersectionC`<[`UnionC`<[`IntersectionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> }\>]\> = CaseResponseRt; `outcome`: `UnionC`<[`LiteralC`<``"exactMatch"``\>, `LiteralC`<``"aliasMatch"``\>, `LiteralC`<``"conflict"``\>]\> }\>, `PartialC`<{ `alias_target_id`: `StringC` = rt.string }\>]\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:212](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L212) - -___ - -### CaseResponseRt - -• **CaseResponseRt**: `IntersectionC`<[`IntersectionC`<[`TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt; `description`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt; `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt; `tags`: `ArrayC`<`StringC`\> ; `title`: `StringC` = rt.string }\>, `TypeC`<{ `closed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `closed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `external_service`: `UnionC`<[`IntersectionC`<[`TypeC`<{ `connector_id`: `StringC` = rt.string }\>, `TypeC`<{ `connector_name`: `StringC` = rt.string; `external_id`: `StringC` = rt.string; `external_title`: `StringC` = rt.string; `external_url`: `StringC` = rt.string; `pushed_at`: `StringC` = rt.string; `pushed_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT }\>]\>, `NullC`]\> = CaseFullExternalServiceRt; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `totalAlerts`: `NumberC` = rt.number; `totalComment`: `NumberC` = rt.number; `version`: `StringC` = rt.string }\>, `PartialC`<{ `comments`: `ArrayC`<`IntersectionC`<[`UnionC`<[`IntersectionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> }\>]\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:199](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L199) - -___ - -### CaseUserActionsResponseRt - -• **CaseUserActionsResponseRt**: `ArrayC`<`IntersectionC`<[`IntersectionC`<[`UnionC`<[`UnionC`<[`TypeC`<{ `payload`: `TypeC`<{ `description`: `StringC` = rt.string }\> = DescriptionUserActionPayloadRt; `type`: `LiteralC`<``"description"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{ `comment`: `UnionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>]\> = CommentRequestRt }\> = CommentUserActionPayloadRt; `type`: `LiteralC`<``"comment"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{ `tags`: `ArrayC`<`StringC`\> }\> = TagsUserActionPayloadRt; `type`: `LiteralC`<``"tags"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{ `title`: `StringC` = rt.string }\> = TitleUserActionPayloadRt; `type`: `LiteralC`<``"title"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{ `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt }\> = SettingsUserActionPayloadRt; `type`: `LiteralC`<``"settings"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{ `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt }\> = StatusUserActionPayloadRt; `type`: `LiteralC`<``"status"``\> }\>]\>, `IntersectionC`<[`TypeC`<{ `type`: `LiteralC`<``"create_case"``\> }\>, `TypeC`<{ `payload`: `IntersectionC`<[`TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt }\>, `TypeC`<{ `description`: `StringC` = DescriptionUserActionPayloadRt.props.description; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsUserActionPayloadRt.props.settings; `status`: `StringC` = rt.string; `tags`: `ArrayC`<`StringC`\> = TagsUserActionPayloadRt.props.tags; `title`: `StringC` = TitleUserActionPayloadRt.props.title }\>]\> }\>]\>, `TypeC`<{ `payload`: `TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt }\> = ConnectorUserActionPayloadRt; `type`: `LiteralC`<``"connector"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{ `externalService`: `IntersectionC`<[`TypeC`<{ `connector_id`: `StringC` = rt.string }\>, `TypeC`<{ `connector_name`: `StringC` = rt.string; `external_id`: `StringC` = rt.string; `external_title`: `StringC` = rt.string; `external_url`: `StringC` = rt.string; `pushed_at`: `StringC` = rt.string; `pushed_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT }\>]\> = CaseExternalServiceBasicRt }\> = PushedUserActionPayloadRt; `type`: `LiteralC`<``"pushed"``\> }\>, `TypeC`<{ `payload`: `TypeC`<{}\> ; `type`: `LiteralC`<``"delete_case"``\> }\>]\>, `TypeC`<{ `action`: `KeyofC`<{ `add`: ``"add"`` = 'add'; `create`: ``"create"`` = 'create'; `delete`: ``"delete"`` = 'delete'; `push_to_service`: ``"push_to_service"`` = 'push\_to\_service'; `update`: ``"update"`` = 'update' }\> = ActionsRt; `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string }\>]\>, `TypeC`<{ `action_id`: `StringC` = rt.string; `case_id`: `StringC` = rt.string; `comment_id`: `UnionC`<[`StringC`, `NullC`]\> }\>]\>\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/user_actions/index.ts:76](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/user_actions/index.ts#L76) - -___ - -### CasesConfigurePatchRt - -• **CasesConfigurePatchRt**: `IntersectionC`<[`PartialC`<{ `closure_type`: `UnionC`<[`LiteralC`<``"close-by-user"``\>, `LiteralC`<``"close-by-pushing"``\>]\> = ClosureTypeRT; `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt }\>, `TypeC`<{ `version`: `StringC` = rt.string }\>]\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/configure.ts:38](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/configure.ts#L38) - -___ - -### CasesConfigureRequestRt - -• **CasesConfigureRequestRt**: `IntersectionC`<[`TypeC`<{ `closure_type`: `UnionC`<[`LiteralC`<``"close-by-user"``\>, `LiteralC`<``"close-by-pushing"``\>]\> = ClosureTypeRT; `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt }\>, `TypeC`<{ `owner`: `StringC` = rt.string }\>]\> = `CasesConfigureBasicRt` - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/configure.ts:37](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/configure.ts#L37) - -___ - -### CasesFindResponseRt - -• **CasesFindResponseRt**: `IntersectionC`<[`TypeC`<{ `cases`: `ArrayC`<`IntersectionC`<[`IntersectionC`<[`TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt; `description`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt; `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt; `tags`: `ArrayC`<`StringC`\> ; `title`: `StringC` = rt.string }\>, `TypeC`<{ `closed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `closed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `external_service`: `UnionC`<[`IntersectionC`<[`TypeC`<{ `connector_id`: `StringC` = rt.string }\>, `TypeC`<{ `connector_name`: `StringC` = rt.string; `external_id`: `StringC` = rt.string; `external_title`: `StringC` = rt.string; `external_url`: `StringC` = rt.string; `pushed_at`: `StringC` = rt.string; `pushed_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT }\>]\>, `NullC`]\> = CaseFullExternalServiceRt; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `totalAlerts`: `NumberC` = rt.number; `totalComment`: `NumberC` = rt.number; `version`: `StringC` = rt.string }\>, `PartialC`<{ `comments`: `ArrayC`<`IntersectionC`<[`UnionC`<[`IntersectionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> }\>]\>\> ; `page`: `NumberC` = rt.number; `per_page`: `NumberC` = rt.number; `total`: `NumberC` = rt.number }\>, `TypeC`<{ `count_closed_cases`: `NumberC` = rt.number; `count_in_progress_cases`: `NumberC` = rt.number; `count_open_cases`: `NumberC` = rt.number }\>]\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:222](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L222) - -___ - -### CasesPatchRequestRt - -• **CasesPatchRequestRt**: `TypeC`<{ `cases`: `ArrayC`<`IntersectionC`<[`PartialC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt; `description`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt; `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt; `tags`: `ArrayC`<`StringC`\> ; `title`: `StringC` = rt.string }\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:240](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L240) - -___ - -### CasesResponseRt - -• **CasesResponseRt**: `ArrayC`<`IntersectionC`<[`IntersectionC`<[`TypeC`<{ `connector`: `IntersectionC`<[`TypeC`<{ `id`: `StringC` = rt.string }\>, `UnionC`<[`IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `issueType`: `UnionC`<[`StringC`, `NullC`]\> ; `parent`: `UnionC`<[`StringC`, `NullC`]\> ; `priority`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`jira`](client._internal_namespace.md#jira)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `NullC` = rt.null; `type`: `LiteralC`<[`none`](client._internal_namespace.md#none)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>, `IntersectionC`<[`TypeC`<{ `fields`: `UnionC`<[`TypeC`<{ `incidentTypes`: `UnionC`<[`ArrayC`<`StringC`\>, `NullC`]\> ; `severityCode`: `UnionC`<[`StringC`, `NullC`]\> }\>, `NullC`]\> ; `type`: `LiteralC`<[`resilient`](client._internal_namespace.md#resilient)\> }\>, `TypeC`<{ `name`: `StringC` = rt.string }\>]\>]\>]\> = CaseConnectorRt; `description`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `settings`: `TypeC`<{ `syncAlerts`: `BooleanC` = rt.boolean }\> = SettingsRt; `status`: `UnionC`<[`LiteralC`<[`open`](../enums/client._internal_namespace.CaseStatuses.md#open)\>, `LiteralC`<`any`[`any`]\>, `LiteralC`<[`closed`](../enums/client._internal_namespace.CaseStatuses.md#closed)\>]\> = CaseStatusRt; `tags`: `ArrayC`<`StringC`\> ; `title`: `StringC` = rt.string }\>, `TypeC`<{ `closed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `closed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `external_service`: `UnionC`<[`IntersectionC`<[`TypeC`<{ `connector_id`: `StringC` = rt.string }\>, `TypeC`<{ `connector_name`: `StringC` = rt.string; `external_id`: `StringC` = rt.string; `external_title`: `StringC` = rt.string; `external_url`: `StringC` = rt.string; `pushed_at`: `StringC` = rt.string; `pushed_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT }\>]\>, `NullC`]\> = CaseFullExternalServiceRt; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `totalAlerts`: `NumberC` = rt.number; `totalComment`: `NumberC` = rt.number; `version`: `StringC` = rt.string }\>, `PartialC`<{ `comments`: `ArrayC`<`IntersectionC`<[`UnionC`<[`IntersectionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> }\>]\>\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/case.ts:241](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/case.ts#L241) - -___ - -### CommentsResponseRt - -• **CommentsResponseRt**: `TypeC`<{ `comments`: `ArrayC`<`IntersectionC`<[`UnionC`<[`IntersectionC`<[`TypeC`<{ `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`user`](client._internal_namespace.md#user)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `alertId`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `index`: `UnionC`<[`ArrayC`<`StringC`\>, `StringC`]\> ; `owner`: `StringC` = rt.string; `rule`: `TypeC`<{ `id`: `UnionC`<[`StringC`, `NullC`]\> ; `name`: `UnionC`<[`StringC`, `NullC`]\> }\> ; `type`: `LiteralC`<[`alert`](client._internal_namespace.md#alert)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>, `IntersectionC`<[`TypeC`<{ `actions`: `TypeC`<{ `targets`: `ArrayC`<`TypeC`<{ `endpointId`: `StringC` = rt.string; `hostname`: `StringC` = rt.string }\>\> ; `type`: `StringC` = rt.string }\> ; `comment`: `StringC` = rt.string; `owner`: `StringC` = rt.string; `type`: `LiteralC`<[`actions`](client._internal_namespace.md#actions)\> }\>, `TypeC`<{ `created_at`: `StringC` = rt.string; `created_by`: `TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\> = UserRT; `owner`: `StringC` = rt.string; `pushed_at`: `UnionC`<[`StringC`, `NullC`]\> ; `pushed_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> ; `updated_at`: `UnionC`<[`StringC`, `NullC`]\> ; `updated_by`: `UnionC`<[`TypeC`<{ `email`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `full_name`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> ; `username`: `UnionC`<[`UndefinedC`, `NullC`, `StringC`]\> }\>, `NullC`]\> }\>]\>]\>, `TypeC`<{ `id`: `StringC` = rt.string; `version`: `StringC` = rt.string }\>]\>\> ; `page`: `NumberC` = rt.number; `per_page`: `NumberC` = rt.number; `total`: `NumberC` = rt.number }\> - -#### Defined in - -[x-pack/plugins/cases/common/api/cases/comment.ts:143](https://github.com/elastic/kibana/blob/c427bf270ae/x-pack/plugins/cases/common/api/cases/comment.ts#L143) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces.md b/x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces.md deleted file mode 100644 index 9f9d1f9a8808c..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/typedoc_interfaces.md +++ /dev/null @@ -1,28 +0,0 @@ -[Cases Client API Interface](../README.md) / typedoc\_interfaces - -# Module: typedoc\_interfaces - -This file defines simpler types for typedoc. This helps reduce the type alias expansion for the io-ts types because it -can be very large. These types are equivalent to the io-ts aliases. - -## Table of contents - -### Namespaces - -- [\_internal\_namespace](typedoc_interfaces._internal_namespace.md) - -### Interfaces - -- [IAllCommentsResponse](../interfaces/typedoc_interfaces.IAllCommentsResponse.md) -- [ICasePostRequest](../interfaces/typedoc_interfaces.ICasePostRequest.md) -- [ICaseResolveResponse](../interfaces/typedoc_interfaces.ICaseResolveResponse.md) -- [ICaseResponse](../interfaces/typedoc_interfaces.ICaseResponse.md) -- [ICaseUserActionsResponse](../interfaces/typedoc_interfaces.ICaseUserActionsResponse.md) -- [ICasesConfigurePatch](../interfaces/typedoc_interfaces.ICasesConfigurePatch.md) -- [ICasesConfigureRequest](../interfaces/typedoc_interfaces.ICasesConfigureRequest.md) -- [ICasesConfigureResponse](../interfaces/typedoc_interfaces.ICasesConfigureResponse.md) -- [ICasesFindRequest](../interfaces/typedoc_interfaces.ICasesFindRequest.md) -- [ICasesFindResponse](../interfaces/typedoc_interfaces.ICasesFindResponse.md) -- [ICasesPatchRequest](../interfaces/typedoc_interfaces.ICasesPatchRequest.md) -- [ICasesResponse](../interfaces/typedoc_interfaces.ICasesResponse.md) -- [ICommentsResponse](../interfaces/typedoc_interfaces.ICommentsResponse.md) diff --git a/x-pack/plugins/cases/docs/cases_client/modules/user_actions_client.md b/x-pack/plugins/cases/docs/cases_client/modules/user_actions_client.md deleted file mode 100644 index 4ec27e0beee46..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client/modules/user_actions_client.md +++ /dev/null @@ -1,10 +0,0 @@ -[Cases Client API Interface](../README.md) / user\_actions/client - -# Module: user\_actions/client - -## Table of contents - -### Interfaces - -- [UserActionGet](../interfaces/user_actions_client.UserActionGet.md) -- [UserActionsSubClient](../interfaces/user_actions_client.UserActionsSubClient.md) diff --git a/x-pack/plugins/cases/docs/cases_client_typedoc.json b/x-pack/plugins/cases/docs/cases_client_typedoc.json deleted file mode 100644 index a5e1305196491..0000000000000 --- a/x-pack/plugins/cases/docs/cases_client_typedoc.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "entryPoints": [ - "../server/client/client.ts", - "../server/client/typedoc_interfaces.ts", - "../server/client/attachments/client.ts", - "../server/client/cases/client.ts", - "../server/client/cases/get.ts", - "../server/client/cases/push.ts", - "../server/client/configure/client.ts", - "../server/client/metrics/client.ts", - "../server/client/stats/client.ts", - "../server/client/user_actions/client.ts" - ], - "entryPointStrategy": "expand", - "exclude": [ - "**/mock.ts", - "../server/client/cases/+(mock.ts|utils.ts|utils.test.ts|types.ts)" - ], - "excludeExternals": true, - "out": "cases_client", - "theme": "markdown", - "internalNamespace": "_internal_namespace", - "plugin": ["typedoc-plugin-markdown", "typedoc-plugin-missing-exports"], - "readme": "none", - "name": "Cases Client API Interface", - "gitRemote": "upstream" -} From b1f920142cf77e1af35a604c33202aa1649416d9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cau=C3=AA=20Marcondes?= <55978943+cauemarcondes@users.noreply.github.com> Date: Mon, 28 Mar 2022 13:57:22 -0400 Subject: [PATCH 042/160] [APM] Disable fields when frozen property is set to true (#126497) * using frozen property to disable fields * removing isCloud since frozen must be enough --- .../create_apm_policy_form.tsx | 8 +---- .../apm_policy_form/edit_apm_policy_form.tsx | 9 +---- .../apm_policy_form/index.tsx | 15 +++----- .../agent_authorization_settings.test.ts | 34 +------------------ .../agent_authorization_settings.ts | 6 +--- .../settings_definition/apm_settings.test.ts | 29 +++------------- .../settings_definition/apm_settings.ts | 8 +---- .../settings_form/form_row_setting.tsx | 10 ++++-- .../apm_policy_form/settings_form/index.tsx | 9 +++-- .../apm_policy_form/typings.ts | 1 - 10 files changed, 27 insertions(+), 102 deletions(-) diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/create_apm_policy_form.tsx b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/create_apm_policy_form.tsx index 7354846aba64f..5757fdabd5d54 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/create_apm_policy_form.tsx +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/create_apm_policy_form.tsx @@ -30,11 +30,5 @@ export function CreateAPMPolicyForm({ newPolicy, onChange }: Props) { }, }); } - return ( - - ); + return ; } diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/edit_apm_policy_form.tsx b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/edit_apm_policy_form.tsx index e8d3b5d6940aa..be9c89601d4ab 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/edit_apm_policy_form.tsx +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/edit_apm_policy_form.tsx @@ -12,7 +12,6 @@ import { PackagePolicyEditExtensionComponentProps, PackagePolicyVars, } from './typings'; -import { POLICY_ELASTIC_AGENT_ON_CLOUD } from '../../../../common/fleet'; interface Props { policy: PackagePolicy; @@ -32,11 +31,5 @@ export function EditAPMPolicyForm({ newPolicy, onChange }: Props) { }, }); } - return ( - - ); + return ; } diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/index.tsx b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/index.tsx index bce1d5936a352..7f9ec6e069773 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/index.tsx +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/index.tsx @@ -30,14 +30,9 @@ import { useKibana } from '../../../../../../../src/plugins/kibana_react/public' interface Props { updateAPMPolicy: (newVars: PackagePolicyVars, isValid: boolean) => void; vars?: PackagePolicyVars; - isCloudPolicy: boolean; } -export function APMPolicyForm({ - vars = {}, - isCloudPolicy, - updateAPMPolicy, -}: Props) { +export function APMPolicyForm({ vars = {}, updateAPMPolicy }: Props) { const tailSamplingPoliciesDocsLink = useKibana().services.docLinks?.links.apm.tailSamplingPolicies; const { @@ -48,17 +43,15 @@ export function APMPolicyForm({ tailSamplingSettings, } = useMemo(() => { return { - apmSettings: getApmSettings({ isCloudPolicy }), + apmSettings: getApmSettings(), rumSettings: getRUMSettings(), tlsSettings: getTLSSettings(), - agentAuthorizationSettings: getAgentAuthorizationSettings({ - isCloudPolicy, - }), + agentAuthorizationSettings: getAgentAuthorizationSettings(), tailSamplingSettings: getTailSamplingSettings( tailSamplingPoliciesDocsLink ), }; - }, [isCloudPolicy, tailSamplingPoliciesDocsLink]); + }, [tailSamplingPoliciesDocsLink]); function handleFormChange(key: string, value: any) { // Merge new key/value with the rest of fields diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.test.ts b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.test.ts index ed3cf83962df4..533c053ba4294 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.test.ts +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.test.ts @@ -6,39 +6,9 @@ */ import { getAgentAuthorizationSettings } from './agent_authorization_settings'; -import { SettingsRow } from '../typings'; import { isSettingsFormValid } from '../settings_form/utils'; describe('apm-fleet-apm-integration', () => { - describe('getAgentAuthorizationSettings', () => { - function findSetting(key: string, settings: SettingsRow[]) { - return settings.find( - (setting) => setting.type !== 'advanced_setting' && setting.key === key - ); - } - it('returns read only secret token when on cloud', () => { - const settings = getAgentAuthorizationSettings({ isCloudPolicy: true }); - const secretToken = findSetting('secret_token', settings); - expect(secretToken).toEqual({ - type: 'text', - key: 'secret_token', - labelAppend: 'Optional', - label: 'Secret token', - }); - }); - it('returns secret token when NOT on cloud', () => { - const settings = getAgentAuthorizationSettings({ isCloudPolicy: false }); - const secretToken = findSetting('secret_token', settings); - - expect(secretToken).toEqual({ - type: 'text', - key: 'secret_token', - labelAppend: 'Optional', - label: 'Secret token', - }); - }); - }); - describe('isAgentAuthorizationFormValid', () => { describe('validates integer fields', () => { [ @@ -47,9 +17,7 @@ describe('apm-fleet-apm-integration', () => { 'anonymous_rate_limit_event_limit', ].map((key) => { it(`returns false when ${key} is lower than 1`, () => { - const settings = getAgentAuthorizationSettings({ - isCloudPolicy: true, - }); + const settings = getAgentAuthorizationSettings(); expect( isSettingsFormValid(settings, { [key]: { value: 0, type: 'integer' }, diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.ts b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.ts index dff95bbf1702c..c2a858b41e615 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.ts +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/agent_authorization_settings.ts @@ -10,11 +10,7 @@ import { getIntegerRt } from '../../../../../common/agent_configuration/runtime_ import { OPTIONAL_LABEL } from '../settings_form/utils'; import { SettingsRow } from '../typings'; -export function getAgentAuthorizationSettings({ - isCloudPolicy, -}: { - isCloudPolicy: boolean; -}): SettingsRow[] { +export function getAgentAuthorizationSettings(): SettingsRow[] { return [ { type: 'boolean', diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.test.ts b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.test.ts index 2d2acbcd37c55..effef056d6601 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.test.ts +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.test.ts @@ -6,35 +6,14 @@ */ import { getApmSettings } from './apm_settings'; -import { SettingsRow, BasicSettingRow } from '../typings'; import { isSettingsFormValid } from '../settings_form/utils'; describe('apm_settings', () => { - describe('getApmSettings', () => { - function findSetting(key: string, settings: SettingsRow[]) { - return settings.find( - (setting) => setting.type !== 'advanced_setting' && setting.key === key - ) as BasicSettingRow; - } - ['host', 'url'].map((key) => { - it(`returns read only ${key} when on cloud`, () => { - const settings = getApmSettings({ isCloudPolicy: true }); - const setting = findSetting(key, settings); - expect(setting.readOnly).toBeTruthy(); - }); - it(`returns ${key} when NOT on cloud`, () => { - const settings = getApmSettings({ isCloudPolicy: false }); - const setting = findSetting(key, settings); - expect(setting.readOnly).toBeFalsy(); - }); - }); - }); - describe('isAPMFormValid', () => { describe('validates integer fields', () => { ['max_header_bytes', 'max_event_bytes'].map((key) => { it(`returns false when ${key} is lower than 1`, () => { - const settings = getApmSettings({ isCloudPolicy: true }); + const settings = getApmSettings(); expect( isSettingsFormValid(settings, { [key]: { value: 0, type: 'integer' }, @@ -50,7 +29,7 @@ describe('apm_settings', () => { }); ['max_connections'].map((key) => { it(`returns false when ${key} is lower than 0`, () => { - const settings = getApmSettings({ isCloudPolicy: true }); + const settings = getApmSettings(); expect( isSettingsFormValid(settings, { [key]: { value: -1, type: 'integer' }, @@ -63,7 +42,7 @@ describe('apm_settings', () => { describe('validates required fields', () => { ['host', 'url'].map((key) => { it(`return false when ${key} is not defined`, () => { - const settings = getApmSettings({ isCloudPolicy: true }); + const settings = getApmSettings(); expect(isSettingsFormValid(settings, {})).toBeFalsy(); }); }); @@ -73,7 +52,7 @@ describe('apm_settings', () => { ['idle_timeout', 'read_timeout', 'shutdown_timeout', 'write_timeout'].map( (key) => { it(`return false when ${key} lower then 1ms`, () => { - const settings = getApmSettings({ isCloudPolicy: true }); + const settings = getApmSettings(); expect( isSettingsFormValid(settings, { [key]: { value: '0ms', type: 'text' }, diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.ts b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.ts index 8adda7b5983f1..03032a6160502 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.ts +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_definition/apm_settings.ts @@ -10,17 +10,12 @@ import { getIntegerRt } from '../../../../../common/agent_configuration/runtime_ import { OPTIONAL_LABEL, REQUIRED_LABEL } from '../settings_form/utils'; import { SettingsRow } from '../typings'; -export function getApmSettings({ - isCloudPolicy, -}: { - isCloudPolicy: boolean; -}): SettingsRow[] { +export function getApmSettings(): SettingsRow[] { return [ { type: 'text', key: 'host', labelAppend: REQUIRED_LABEL, - readOnly: isCloudPolicy, label: i18n.translate( 'xpack.apm.fleet_integration.settings.apm.hostLabel', { defaultMessage: 'Host' } @@ -43,7 +38,6 @@ export function getApmSettings({ type: 'text', key: 'url', labelAppend: REQUIRED_LABEL, - readOnly: isCloudPolicy, label: i18n.translate( 'xpack.apm.fleet_integration.settings.apm.urlLabel', { diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/form_row_setting.tsx b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/form_row_setting.tsx index 321440eeaeab7..56ba3c6d47eb5 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/form_row_setting.tsx +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/form_row_setting.tsx @@ -28,6 +28,7 @@ interface Props { row: SettingsRow; value?: any; onChange: FormRowOnChange; + isDisabled?: boolean; } const ENABLED_LABEL = i18n.translate( @@ -39,11 +40,12 @@ const DISABLED_LABEL = i18n.translate( { defaultMessage: 'Disabled' } ); -export function FormRowSetting({ row, value, onChange }: Props) { +export function FormRowSetting({ row, value, onChange, isDisabled }: Props) { switch (row.type) { case 'boolean': { return ( { @@ -56,9 +58,9 @@ export function FormRowSetting({ row, value, onChange }: Props) { case 'text': { return ( : undefined} + prepend={isDisabled ? : undefined} onChange={(e) => { onChange(row.key, e.target.value); }} @@ -68,6 +70,7 @@ export function FormRowSetting({ row, value, onChange }: Props) { case 'area': { return ( { onChange(row.key, e.target.value); @@ -79,6 +82,7 @@ export function FormRowSetting({ row, value, onChange }: Props) { case 'integer': { return ( { onChange(row.key, e.target.value); diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/index.tsx b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/index.tsx index 84b06e37b2ae2..a834c41098798 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/index.tsx +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/settings_form/index.tsx @@ -51,7 +51,7 @@ function FormRow({ if (!configEntry) { return null; } - const { value } = configEntry; + const { value, frozen } = configEntry; const { isValid, message } = validateSettingValue(row, value); return ( @@ -70,7 +70,12 @@ function FormRow({
} > - + {row.settings && diff --git a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/typings.ts b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/typings.ts index e7108e8910446..c25031efad5fd 100644 --- a/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/typings.ts +++ b/x-pack/plugins/apm/public/components/fleet_integration/apm_policy_form/typings.ts @@ -50,7 +50,6 @@ export interface BasicSettingRow { settings?: SettingsRow[]; validation?: SettingValidation; required?: boolean; - readOnly?: boolean; } export type SettingsRow = BasicSettingRow | AdvancedSettingRow; From a50e87cfa548c8e71ef080eaa66ff1d5a4827294 Mon Sep 17 00:00:00 2001 From: Oliver Gupte Date: Mon, 28 Mar 2022 14:11:43 -0400 Subject: [PATCH 043/160] [APM] Always uses the latest available apm package for the fleet migration UI (#128339) * [APM] Always uses the latest available apm package for the fleet migration UI (#123477) * fixes linting error Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/apm/common/fleet.ts | 59 +++- .../components/app/settings/schema/index.tsx | 2 + .../app/settings/schema/schema_overview.tsx | 5 +- .../public/tutorial/config_agent/index.tsx | 8 +- .../tutorial_fleet_instructions/index.tsx | 10 +- .../fleet/create_cloud_apm_package_policy.ts | 7 +- .../get_apm_package_policy_definition.ts | 296 +++--------------- .../routes/fleet/get_latest_apm_package.ts | 28 ++ .../get_unsupported_apm_server_schema.ts | 15 +- .../plugins/apm/server/routes/fleet/route.ts | 12 +- ... => translate_legacy_schema_paths.test.ts} | 4 +- .../fleet/translate_legacy_schema_paths.ts | 21 ++ 12 files changed, 177 insertions(+), 290 deletions(-) create mode 100644 x-pack/plugins/apm/server/routes/fleet/get_latest_apm_package.ts rename x-pack/plugins/apm/server/routes/fleet/{get_apm_package_policy_definition.test.ts => translate_legacy_schema_paths.test.ts} (91%) create mode 100644 x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.ts diff --git a/x-pack/plugins/apm/common/fleet.ts b/x-pack/plugins/apm/common/fleet.ts index 46ec9be784f43..ed148b2230011 100644 --- a/x-pack/plugins/apm/common/fleet.ts +++ b/x-pack/plugins/apm/common/fleet.ts @@ -4,14 +4,61 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import semverParse from 'semver/functions/parse'; - export const POLICY_ELASTIC_AGENT_ON_CLOUD = 'policy-elastic-agent-on-cloud'; -export const SUPPORTED_APM_PACKAGE_VERSION = '8.1.0'; +export const INPUT_VAR_NAME_TO_SCHEMA_PATH: Record = { + host: 'apm-server.host', + url: 'apm-server.url', + enable_rum: 'apm-server.rum.enabled', + default_service_environment: 'apm-server.default_service_environment', + rum_allow_origins: 'apm-server.rum.allow_origins', + rum_allow_headers: 'apm-server.rum.allow_headers', + rum_event_rate_limit: 'apm-server.rum.event_rate.limit', + rum_allow_service_names: 'apm-server.rum.allow_service_names', + rum_event_rate_lru_size: 'apm-server.rum.event_rate.lru_size', + rum_response_headers: 'apm-server.rum.response_headers', + rum_library_pattern: 'apm-server.rum.library_pattern', + rum_exclude_from_grouping: 'apm-server.rum.exclude_from_grouping', + max_event_bytes: 'apm-server.max_event_size', + capture_personal_data: 'apm-server.capture_personal_data', + max_header_bytes: 'apm-server.max_header_size', + idle_timeout: 'apm-server.idle_timeout', + read_timeout: 'apm-server.read_timeout', + shutdown_timeout: 'apm-server.shutdown_timeout', + write_timeout: 'apm-server.write_timeout', + max_connections: 'apm-server.max_connections', + response_headers: 'apm-server.response_headers', + expvar_enabled: 'apm-server.expvar.enabled', + tls_enabled: 'apm-server.ssl.enabled', + tls_certificate: 'apm-server.ssl.certificate', + tls_key: 'apm-server.ssl.key', + tls_supported_protocols: 'apm-server.ssl.supported_protocols', + tls_cipher_suites: 'apm-server.ssl.cipher_suites', + tls_curve_types: 'apm-server.ssl.curve_types', + secret_token: 'apm-server.auth.secret_token', + api_key_enabled: 'apm-server.auth.api_key.enabled', + api_key_limit: 'apm-server.auth.api_key.limit', + anonymous_enabled: 'apm-server.auth.anonymous.enabled', + anonymous_allow_agent: 'apm-server.auth.anonymous.allow_agent', + anonymous_allow_service: 'apm-server.auth.anonymous.allow_service', + anonymous_rate_limit_ip_limit: + 'apm-server.auth.anonymous.rate_limit.ip_limit', + anonymous_rate_limit_event_limit: + 'apm-server.auth.anonymous.rate_limit.event_limit', + tail_sampling_enabled: 'apm-server.sampling.tail.enabled', + tail_sampling_interval: 'apm-server.sampling.tail.interval', + tail_sampling_policies: 'apm-server.sampling.tail.policies', +}; -export function isPrereleaseVersion(version: string) { - return semverParse(version)?.prerelease?.length ?? 0 > 0; -} +export const LEGACY_TO_CURRENT_SCHEMA_PATHS: Record = { + 'apm-server.rum.event_rate.limit': + 'apm-server.auth.anonymous.rate_limit.event_limit', + 'apm-server.rum.event_rate.lru_size': + 'apm-server.auth.anonymous.rate_limit.ip_limit', + 'apm-server.rum.allow_service_names': + 'apm-server.auth.anonymous.allow_service', + 'apm-server.secret_token': 'apm-server.auth.secret_token', + 'apm-server.api_key.enabled': 'apm-server.auth.api_key.enabled', +}; export const ELASTIC_CLOUD_APM_AGENT_POLICY_ID = 'elastic-cloud-apm'; diff --git a/x-pack/plugins/apm/public/components/app/settings/schema/index.tsx b/x-pack/plugins/apm/public/components/app/settings/schema/index.tsx index 0ea03cb0614d4..41d99e4551cc0 100644 --- a/x-pack/plugins/apm/public/components/app/settings/schema/index.tsx +++ b/x-pack/plugins/apm/public/components/app/settings/schema/index.tsx @@ -56,6 +56,7 @@ export function Schema() { const cloudApmPackagePolicy = data.cloud_apm_package_policy; const hasCloudApmPackagePolicy = !!cloudApmPackagePolicy; const hasRequiredRole = !!data.has_required_role; + const latestApmPackageVersion = data.latest_apm_package_version; function updateLocalStorage(newStatus: FETCH_STATUS) { setApmDataStreamsMigrationStatus({ @@ -91,6 +92,7 @@ export function Schema() { hasCloudAgentPolicy={hasCloudAgentPolicy} hasRequiredRole={hasRequiredRole} cloudApmPackagePolicy={cloudApmPackagePolicy} + latestApmPackageVersion={latestApmPackageVersion} /> {isSwitchActive && ( {i18n.translate( 'xpack.apm.tutorial.apmServer.fleet.manageApmIntegration.button', diff --git a/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts b/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts index 34a6de753d910..797bce77facdb 100644 --- a/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts +++ b/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts @@ -9,6 +9,7 @@ import { ElasticsearchClient, SavedObjectsClientContract, Logger, + KibanaRequest, } from 'kibana/server'; import { PackagePolicy } from '../../../../fleet/common'; import { @@ -30,7 +31,7 @@ export async function createCloudApmPackgePolicy({ esClient, logger, setup, - kibanaVersion, + request, }: { cloudPluginSetup: APMPluginSetupDependencies['cloud']; fleetPluginStart: NonNullable; @@ -38,7 +39,7 @@ export async function createCloudApmPackgePolicy({ esClient: ElasticsearchClient; logger: Logger; setup: Setup; - kibanaVersion: string; + request: KibanaRequest; }): Promise { const { attributes } = await savedObjectsClient.get( APM_SERVER_SCHEMA_SAVED_OBJECT_TYPE, @@ -52,7 +53,7 @@ export async function createCloudApmPackgePolicy({ apmServerSchema, cloudPluginSetup, fleetPluginStart, - kibanaVersion, + request, }); const mergedAPMPackagePolicy = await mergePackagePolicyWithApm({ setup, diff --git a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts b/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts index 6d4af4e33ad5b..85ac03697019c 100644 --- a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts +++ b/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts @@ -5,29 +5,35 @@ * 2.0. */ +import { KibanaRequest } from 'kibana/server'; +import { RegistryVarsEntry } from '../../../../fleet/common'; import { - isPrereleaseVersion, POLICY_ELASTIC_AGENT_ON_CLOUD, - SUPPORTED_APM_PACKAGE_VERSION, + INPUT_VAR_NAME_TO_SCHEMA_PATH, ELASTIC_CLOUD_APM_AGENT_POLICY_ID, } from '../../../common/fleet'; import { APMPluginSetupDependencies, APMPluginStartDependencies, } from '../../types'; -import { APM_PACKAGE_NAME } from './get_cloud_apm_package_policy'; +import { getLatestApmPackage } from './get_latest_apm_package'; +import { translateLegacySchemaPaths } from './translate_legacy_schema_paths'; -interface GetApmPackagePolicyDefinitionOptions { +export async function getApmPackagePolicyDefinition({ + apmServerSchema, + cloudPluginSetup, + fleetPluginStart, + request, +}: { apmServerSchema: Record; cloudPluginSetup: APMPluginSetupDependencies['cloud']; - fleetPluginStart: APMPluginStartDependencies['fleet']; - kibanaVersion: string; -} -export async function getApmPackagePolicyDefinition( - options: GetApmPackagePolicyDefinitionOptions -) { - const { apmServerSchema, cloudPluginSetup, fleetPluginStart, kibanaVersion } = - options; + fleetPluginStart: NonNullable; + request: KibanaRequest; +}) { + const latestApmPackage = await getLatestApmPackage({ + fleetPluginStart, + request, + }); return { id: ELASTIC_CLOUD_APM_AGENT_POLICY_ID, @@ -42,255 +48,45 @@ export async function getApmPackagePolicyDefinition( enabled: true, streams: [], vars: getApmPackageInputVars({ + policyTemplateInputVars: latestApmPackage.policyTemplateInputVars, + apmServerSchema: translateLegacySchemaPaths(apmServerSchema), cloudPluginSetup, - fleetPluginStart, - apmServerSchema: preprocessLegacyFields({ apmServerSchema }), - kibanaVersion, }), }, ], package: { - name: APM_PACKAGE_NAME, - version: await getApmPackageVersion(fleetPluginStart, kibanaVersion), - title: 'Elastic APM', + name: latestApmPackage.package.name, + version: latestApmPackage.package.version, + title: latestApmPackage.package.title, }, }; } -async function getApmPackageVersion( - fleetPluginStart: APMPluginStartDependencies['fleet'], - kibanaVersion: string -) { - if (fleetPluginStart && isPrereleaseVersion(kibanaVersion)) { - try { - const latestApmPackage = - await fleetPluginStart.packageService.asInternalUser.fetchFindLatestPackage( - 'apm' - ); - return latestApmPackage.version; - } catch (error) { - return SUPPORTED_APM_PACKAGE_VERSION; - } - } - return SUPPORTED_APM_PACKAGE_VERSION; -} - -export function preprocessLegacyFields({ +function getApmPackageInputVars({ + policyTemplateInputVars, apmServerSchema, + cloudPluginSetup, }: { + policyTemplateInputVars: RegistryVarsEntry[]; apmServerSchema: Record; -}) { - const copyOfApmServerSchema = { ...apmServerSchema }; - [ - { - key: 'apm-server.auth.anonymous.rate_limit.event_limit', - legacyKey: 'apm-server.rum.event_rate.limit', - }, - { - key: 'apm-server.auth.anonymous.rate_limit.ip_limit', - legacyKey: 'apm-server.rum.event_rate.lru_size', - }, - { - key: 'apm-server.auth.anonymous.allow_service', - legacyKey: 'apm-server.rum.allow_service_names', - }, - { - key: 'apm-server.auth.secret_token', - legacyKey: 'apm-server.secret_token', - }, - { - key: 'apm-server.auth.api_key.enabled', - legacyKey: 'apm-server.api_key.enabled', - }, - ].forEach(({ key, legacyKey }) => { - if (!copyOfApmServerSchema[key]) { - copyOfApmServerSchema[key] = copyOfApmServerSchema[legacyKey]; - delete copyOfApmServerSchema[legacyKey]; - } - }); - return copyOfApmServerSchema; -} - -function getApmPackageInputVars(options: GetApmPackagePolicyDefinitionOptions) { - const { apmServerSchema } = options; - const apmServerConfigs = Object.entries(apmConfigMapping).map( - ([key, { name, type, getValue }]) => ({ key, name, type, getValue }) - ); + cloudPluginSetup: APMPluginSetupDependencies['cloud']; +}): Record { + const overrideValues: Record = { + url: cloudPluginSetup?.apm?.url, // overrides 'apm-server.url' to be the cloud APM host + }; - const inputVars: Record = - apmServerConfigs.reduce((acc, { key, name, type, getValue }) => { - const value = (getValue ? getValue(options) : apmServerSchema[key]) ?? ''; // defaults to an empty string to be edited in Fleet UI - return { - ...acc, - [name]: { type, value }, - }; - }, {}); - return inputVars; + return policyTemplateInputVars.reduce((acc, registryVarsEntry) => { + const { name, type, default: defaultValue } = registryVarsEntry; + return { + ...acc, + [name]: { + type, + value: + overrideValues[name] ?? + apmServerSchema[INPUT_VAR_NAME_TO_SCHEMA_PATH[name]] ?? + defaultValue ?? + '', + }, + }; + }, {}); } - -export const apmConfigMapping: Record< - string, - { - name: string; - type: string; - getValue?: (options: GetApmPackagePolicyDefinitionOptions) => any; - } -> = { - 'apm-server.host': { - name: 'host', - type: 'text', - }, - 'apm-server.url': { - name: 'url', - type: 'text', - getValue: ({ cloudPluginSetup }) => cloudPluginSetup?.apm?.url, - }, - 'apm-server.rum.enabled': { - name: 'enable_rum', - type: 'bool', - }, - 'apm-server.default_service_environment': { - name: 'default_service_environment', - type: 'text', - }, - 'apm-server.rum.allow_origins': { - name: 'rum_allow_origins', - type: 'text', - }, - 'apm-server.rum.allow_headers': { - name: 'rum_allow_headers', - type: 'text', - }, - 'apm-server.rum.event_rate.limit': { - name: 'rum_event_rate_limit', - type: 'integer', - }, - 'apm-server.rum.allow_service_names': { - name: 'rum_allow_service_names', - type: 'text', - }, - 'apm-server.rum.event_rate.lru_size': { - name: 'rum_event_rate_lru_size', - type: 'integer', - }, - 'apm-server.rum.response_headers': { - name: 'rum_response_headers', - type: 'yaml', - }, - 'apm-server.rum.library_pattern': { - name: 'rum_library_pattern', - type: 'text', - }, - 'apm-server.rum.exclude_from_grouping': { - name: 'rum_exclude_from_grouping', - type: 'text', - }, - 'apm-server.max_event_size': { - name: 'max_event_bytes', - type: 'integer', - }, - 'apm-server.capture_personal_data': { - name: 'capture_personal_data', - type: 'bool', - }, - 'apm-server.max_header_size': { - name: 'max_header_bytes', - type: 'integer', - }, - 'apm-server.idle_timeout': { - name: 'idle_timeout', - type: 'text', - }, - 'apm-server.read_timeout': { - name: 'read_timeout', - type: 'text', - }, - 'apm-server.shutdown_timeout': { - name: 'shutdown_timeout', - type: 'text', - }, - 'apm-server.write_timeout': { - name: 'write_timeout', - type: 'text', - }, - 'apm-server.max_connections': { - name: 'max_connections', - type: 'integer', - }, - 'apm-server.response_headers': { - name: 'response_headers', - type: 'yaml', - }, - 'apm-server.expvar.enabled': { - name: 'expvar_enabled', - type: 'bool', - }, - 'apm-server.ssl.enabled': { - name: 'tls_enabled', - type: 'bool', - }, - 'apm-server.ssl.certificate': { - name: 'tls_certificate', - type: 'text', - }, - 'apm-server.ssl.key': { - name: 'tls_key', - type: 'text', - }, - 'apm-server.ssl.supported_protocols': { - name: 'tls_supported_protocols', - type: 'text', - }, - 'apm-server.ssl.cipher_suites': { - name: 'tls_cipher_suites', - type: 'text', - }, - 'apm-server.ssl.curve_types': { - name: 'tls_curve_types', - type: 'text', - }, - 'apm-server.auth.secret_token': { - name: 'secret_token', - type: 'text', - }, - 'apm-server.auth.api_key.enabled': { - name: 'api_key_enabled', - type: 'bool', - }, - 'apm-server.auth.api_key.limit': { - name: 'api_key_limit', - type: 'bool', - }, - 'apm-server.auth.anonymous.enabled': { - name: 'anonymous_enabled', - type: 'bool', - }, - 'apm-server.auth.anonymous.allow_agent': { - name: 'anonymous_allow_agent', - type: 'text', - }, - 'apm-server.auth.anonymous.allow_service': { - name: 'anonymous_allow_service', - type: 'text', - }, - 'apm-server.auth.anonymous.rate_limit.ip_limit': { - name: 'anonymous_rate_limit_ip_limit', - type: 'integer', - }, - 'apm-server.auth.anonymous.rate_limit.event_limit': { - name: 'anonymous_rate_limit_event_limit', - type: 'integer', - }, - 'apm-server.sampling.tail.enabled': { - name: 'tail_sampling_enabled', - type: 'bool', - }, - 'apm-server.sampling.tail.interval': { - name: 'tail_sampling_interval', - type: 'text', - }, - 'apm-server.sampling.tail.policies': { - name: 'tail_sampling_policies', - type: 'yaml', - }, -}; diff --git a/x-pack/plugins/apm/server/routes/fleet/get_latest_apm_package.ts b/x-pack/plugins/apm/server/routes/fleet/get_latest_apm_package.ts new file mode 100644 index 0000000000000..ba5b9f4b919e9 --- /dev/null +++ b/x-pack/plugins/apm/server/routes/fleet/get_latest_apm_package.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { KibanaRequest } from 'kibana/server'; +import { APMPluginStartDependencies } from '../../types'; +import { APM_PACKAGE_NAME } from './get_cloud_apm_package_policy'; + +export async function getLatestApmPackage({ + fleetPluginStart, + request, +}: { + fleetPluginStart: NonNullable; + request: KibanaRequest; +}) { + const packageClient = fleetPluginStart.packageService.asScoped(request); + const { name, version } = await packageClient.fetchFindLatestPackage( + APM_PACKAGE_NAME + ); + const registryPackage = await packageClient.getRegistryPackage(name, version); + const { title, policy_templates: policyTemplates } = + registryPackage.packageInfo; + const policyTemplateInputVars = policyTemplates?.[0].inputs?.[0].vars ?? []; + return { package: { name, version, title }, policyTemplateInputVars }; +} diff --git a/x-pack/plugins/apm/server/routes/fleet/get_unsupported_apm_server_schema.ts b/x-pack/plugins/apm/server/routes/fleet/get_unsupported_apm_server_schema.ts index 2ced15245b593..fa2b4c585cb9d 100644 --- a/x-pack/plugins/apm/server/routes/fleet/get_unsupported_apm_server_schema.ts +++ b/x-pack/plugins/apm/server/routes/fleet/get_unsupported_apm_server_schema.ts @@ -6,14 +6,12 @@ */ import { SavedObjectsClientContract } from 'kibana/server'; +import { INPUT_VAR_NAME_TO_SCHEMA_PATH } from '../../../common/fleet'; import { APM_SERVER_SCHEMA_SAVED_OBJECT_TYPE, APM_SERVER_SCHEMA_SAVED_OBJECT_ID, } from '../../../common/apm_saved_object_constants'; -import { - apmConfigMapping, - preprocessLegacyFields, -} from './get_apm_package_policy_definition'; +import { translateLegacySchemaPaths } from './translate_legacy_schema_paths'; export async function getUnsupportedApmServerSchema({ savedObjectsClient, @@ -27,10 +25,9 @@ export async function getUnsupportedApmServerSchema({ const apmServerSchema: Record = JSON.parse( (attributes as { schemaJson: string }).schemaJson ); - const preprocessedApmServerSchema = preprocessLegacyFields({ - apmServerSchema, - }); - return Object.entries(preprocessedApmServerSchema) - .filter(([name]) => !(name in apmConfigMapping)) + const translatedApmServerSchema = translateLegacySchemaPaths(apmServerSchema); + const supportedSchemaPaths = Object.values(INPUT_VAR_NAME_TO_SCHEMA_PATH); + return Object.entries(translatedApmServerSchema) + .filter(([name]) => !supportedSchemaPaths.includes(name)) .map(([key, value]) => ({ key, value })); } diff --git a/x-pack/plugins/apm/server/routes/fleet/route.ts b/x-pack/plugins/apm/server/routes/fleet/route.ts index 97949dfc7d0c3..2b6412647641c 100644 --- a/x-pack/plugins/apm/server/routes/fleet/route.ts +++ b/x-pack/plugins/apm/server/routes/fleet/route.ts @@ -25,6 +25,7 @@ import { isSuperuser } from './is_superuser'; import { getInternalSavedObjectsClient } from '../../lib/helpers/get_internal_saved_objects_client'; import { setupRequest } from '../../lib/helpers/setup_request'; import { createApmServerRoute } from '../apm_routes/create_apm_server_route'; +import { getLatestApmPackage } from './get_latest_apm_package'; const hasFleetDataRoute = createApmServerRoute({ endpoint: 'GET /internal/apm/fleet/has_apm_policies', @@ -177,6 +178,7 @@ const getMigrationCheckRoute = createApmServerRoute({ | import('./../../../../fleet/common/index').PackagePolicy | undefined; has_apm_integrations: boolean; + latest_apm_package_version: string; }> => { const { core, plugins, context, config, request } = resources; const cloudApmMigrationEnabled = config.agent.migrations.enabled; @@ -200,6 +202,10 @@ const getMigrationCheckRoute = createApmServerRoute({ core, fleetPluginStart, }); + const latestApmPackage = await getLatestApmPackage({ + fleetPluginStart, + request, + }); return { has_cloud_agent_policy: !!cloudAgentPolicy, has_cloud_apm_package_policy: !!apmPackagePolicy, @@ -207,6 +213,7 @@ const getMigrationCheckRoute = createApmServerRoute({ has_required_role: hasRequiredRole, cloud_apm_package_policy: apmPackagePolicy, has_apm_integrations: packagePolicies.total > 0, + latest_apm_package_version: latestApmPackage.package.version, }; }, }); @@ -219,8 +226,7 @@ const createCloudApmPackagePolicyRoute = createApmServerRoute({ ): Promise<{ cloudApmPackagePolicy: import('./../../../../fleet/common/index').PackagePolicy; }> => { - const { plugins, context, config, request, logger, kibanaVersion } = - resources; + const { plugins, context, config, request, logger } = resources; const cloudApmMigrationEnabled = config.agent.migrations.enabled; if (!plugins.fleet || !plugins.security) { throw Boom.internal(FLEET_SECURITY_REQUIRED_MESSAGE); @@ -247,7 +253,7 @@ const createCloudApmPackagePolicyRoute = createApmServerRoute({ esClient, logger, setup, - kibanaVersion, + request, }); return { cloudApmPackagePolicy }; diff --git a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.test.ts b/x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.test.ts similarity index 91% rename from x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.test.ts rename to x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.test.ts index 805099d87e1c6..09cab871d3a5b 100644 --- a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.test.ts +++ b/x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.test.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { preprocessLegacyFields } from './get_apm_package_policy_definition'; +import { translateLegacySchemaPaths } from './translate_legacy_schema_paths'; const apmServerSchema = { 'apm-server.host': '0.0.0.0:8200', @@ -24,7 +24,7 @@ const apmServerSchema = { describe('get_apm_package_policy_definition', () => { describe('preprocessLegacyFields', () => { it('should replace legacy fields with supported fields', () => { - const result = preprocessLegacyFields({ apmServerSchema }); + const result = translateLegacySchemaPaths(apmServerSchema); expect(result).toMatchInlineSnapshot(` Object { "apm-server.auth.anonymous.allow_service": "opbeans-test", diff --git a/x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.ts b/x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.ts new file mode 100644 index 0000000000000..ca8de7d6e7a62 --- /dev/null +++ b/x-pack/plugins/apm/server/routes/fleet/translate_legacy_schema_paths.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { LEGACY_TO_CURRENT_SCHEMA_PATHS } from '../../../common/fleet'; + +export function translateLegacySchemaPaths( + apmServerSchema: Record +) { + return Object.keys(apmServerSchema).reduce((acc, apmServerSchemaKey) => { + const currentSchemaPath = + LEGACY_TO_CURRENT_SCHEMA_PATHS[apmServerSchemaKey] || apmServerSchemaKey; + return { + ...acc, + [currentSchemaPath]: apmServerSchema[apmServerSchemaKey], + }; + }, {}); +} From 8885b9fb57383fd98239dad4c7cc7388fb5b7a73 Mon Sep 17 00:00:00 2001 From: Ersin Erdal <92688503+ersin-erdal@users.noreply.github.com> Date: Mon, 28 Mar 2022 20:15:31 +0200 Subject: [PATCH 044/160] [Alerting] Keep the number_of_scheduled_actions in event log (#128438) * numberOfScheduledActions in event log --- x-pack/plugins/alerting/common/alert.ts | 1 + .../alerting/common/rule_task_instance.ts | 1 + .../server/lib/rule_execution_status.test.ts | 30 ++----- .../server/lib/rule_execution_status.ts | 6 +- .../create_execution_handler.test.ts | 3 + .../task_runner/create_execution_handler.ts | 2 + .../alerting/server/task_runner/fixtures.ts | 4 +- .../server/task_runner/task_runner.test.ts | 84 +++++++++++-------- .../server/task_runner/task_runner.ts | 8 +- .../task_runner/task_runner_cancel.test.ts | 7 +- .../alerting/server/task_runner/types.ts | 1 + x-pack/plugins/alerting/server/types.ts | 1 - .../plugins/event_log/generated/mappings.json | 3 + x-pack/plugins/event_log/generated/schemas.ts | 1 + x-pack/plugins/event_log/scripts/mappings.js | 3 + 15 files changed, 89 insertions(+), 66 deletions(-) diff --git a/x-pack/plugins/alerting/common/alert.ts b/x-pack/plugins/alerting/common/alert.ts index 1628abff7efc1..9e48acd523d22 100644 --- a/x-pack/plugins/alerting/common/alert.ts +++ b/x-pack/plugins/alerting/common/alert.ts @@ -49,6 +49,7 @@ export enum AlertExecutionStatusWarningReasons { export interface AlertExecutionStatus { status: AlertExecutionStatuses; numberOfTriggeredActions?: number; + numberOfScheduledActions?: number; metrics?: RuleExecutionMetrics; lastExecutionDate: Date; lastDuration?: number; diff --git a/x-pack/plugins/alerting/common/rule_task_instance.ts b/x-pack/plugins/alerting/common/rule_task_instance.ts index aa45618b33f24..54483babdfdd3 100644 --- a/x-pack/plugins/alerting/common/rule_task_instance.ts +++ b/x-pack/plugins/alerting/common/rule_task_instance.ts @@ -24,6 +24,7 @@ const ruleExecutionMetricsSchema = t.partial({ const alertExecutionStore = t.partial({ numberOfTriggeredActions: t.number, + numberOfScheduledActions: t.number, triggeredActionsStatus: t.string, }); diff --git a/x-pack/plugins/alerting/server/lib/rule_execution_status.test.ts b/x-pack/plugins/alerting/server/lib/rule_execution_status.test.ts index c6746ed0eac93..44a9e41c89052 100644 --- a/x-pack/plugins/alerting/server/lib/rule_execution_status.test.ts +++ b/x-pack/plugins/alerting/server/lib/rule_execution_status.test.ts @@ -34,11 +34,13 @@ describe('RuleExecutionStatus', () => { const status = executionStatusFromState({ alertExecutionStore: { numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, triggeredActionsStatus: ActionsCompletion.COMPLETE, }, } as RuleExecutionState); checkDateIsNearNow(status.lastExecutionDate); expect(status.numberOfTriggeredActions).toBe(0); + expect(status.numberOfScheduledActions).toBe(0); expect(status.status).toBe('ok'); expect(status.error).toBe(undefined); expect(status.warning).toBe(undefined); @@ -49,12 +51,14 @@ describe('RuleExecutionStatus', () => { alertInstances: {}, alertExecutionStore: { numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, triggeredActionsStatus: ActionsCompletion.COMPLETE, }, metrics, }); checkDateIsNearNow(status.lastExecutionDate); expect(status.numberOfTriggeredActions).toBe(0); + expect(status.numberOfScheduledActions).toBe(0); expect(status.status).toBe('ok'); expect(status.error).toBe(undefined); expect(status.warning).toBe(undefined); @@ -66,12 +70,14 @@ describe('RuleExecutionStatus', () => { alertInstances: { a: {} }, alertExecutionStore: { numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, triggeredActionsStatus: ActionsCompletion.COMPLETE, }, metrics, }); checkDateIsNearNow(status.lastExecutionDate); expect(status.numberOfTriggeredActions).toBe(0); + expect(status.numberOfScheduledActions).toBe(0); expect(status.status).toBe('active'); expect(status.error).toBe(undefined); expect(status.warning).toBe(undefined); @@ -82,6 +88,7 @@ describe('RuleExecutionStatus', () => { const status = executionStatusFromState({ alertExecutionStore: { numberOfTriggeredActions: 1, + numberOfScheduledActions: 2, triggeredActionsStatus: ActionsCompletion.COMPLETE, }, alertInstances: { a: {} }, @@ -89,6 +96,7 @@ describe('RuleExecutionStatus', () => { }); checkDateIsNearNow(status.lastExecutionDate); expect(status.numberOfTriggeredActions).toBe(1); + expect(status.numberOfScheduledActions).toBe(2); expect(status.status).toBe('active'); expect(status.error).toBe(undefined); expect(status.warning).toBe(undefined); @@ -313,28 +321,6 @@ describe('RuleExecutionStatus', () => { } `); }); - - test('valid status, date, error, duration and triggeredActions', () => { - const result = ruleExecutionStatusFromRaw(MockLogger, 'rule-id', { - status, - lastExecutionDate: date, - numberOfTriggeredActions: 5, - error, - lastDuration: 1234, - }); - expect(result).toMatchInlineSnapshot(` - Object { - "error": Object { - "message": "wops", - "reason": "execute", - }, - "lastDuration": 1234, - "lastExecutionDate": 2020-09-03T16:26:58.000Z, - "numberOfTriggeredActions": 5, - "status": "active", - } - `); - }); }); }); diff --git a/x-pack/plugins/alerting/server/lib/rule_execution_status.ts b/x-pack/plugins/alerting/server/lib/rule_execution_status.ts index 364975f37614d..9a446d2383c66 100644 --- a/x-pack/plugins/alerting/server/lib/rule_execution_status.ts +++ b/x-pack/plugins/alerting/server/lib/rule_execution_status.ts @@ -35,6 +35,7 @@ export function executionStatusFromState(state: RuleExecutionState): AlertExecut return { metrics: state.metrics, numberOfTriggeredActions: state.alertExecutionStore.numberOfTriggeredActions, + numberOfScheduledActions: state.alertExecutionStore.numberOfScheduledActions, lastExecutionDate: new Date(), status, ...(hasIncompleteAlertExecution && { @@ -84,7 +85,6 @@ export function ruleExecutionStatusFromRaw( const { lastExecutionDate, lastDuration, - numberOfTriggeredActions, status = 'unknown', error, warning, @@ -107,10 +107,6 @@ export function ruleExecutionStatusFromRaw( executionStatus.lastDuration = lastDuration; } - if (null != numberOfTriggeredActions) { - executionStatus.numberOfTriggeredActions = numberOfTriggeredActions; - } - if (error) { executionStatus.error = error; } diff --git a/x-pack/plugins/alerting/server/task_runner/create_execution_handler.test.ts b/x-pack/plugins/alerting/server/task_runner/create_execution_handler.test.ts index 7d02535566cac..8b97bf9266e9a 100644 --- a/x-pack/plugins/alerting/server/task_runner/create_execution_handler.test.ts +++ b/x-pack/plugins/alerting/server/task_runner/create_execution_handler.test.ts @@ -127,6 +127,7 @@ describe('Create Execution Handler', () => { ); alertExecutionStore = { numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, triggeredActionsStatus: ActionsCompletion.COMPLETE, }; }); @@ -512,6 +513,7 @@ describe('Create Execution Handler', () => { alertExecutionStore = { numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, triggeredActionsStatus: ActionsCompletion.COMPLETE, }; @@ -524,6 +526,7 @@ describe('Create Execution Handler', () => { }); expect(alertExecutionStore.numberOfTriggeredActions).toBe(2); + expect(alertExecutionStore.numberOfScheduledActions).toBe(3); expect(alertExecutionStore.triggeredActionsStatus).toBe(ActionsCompletion.PARTIAL); expect(actionsClient.enqueueExecution).toHaveBeenCalledTimes(2); }); diff --git a/x-pack/plugins/alerting/server/task_runner/create_execution_handler.ts b/x-pack/plugins/alerting/server/task_runner/create_execution_handler.ts index 253099957f8d3..56e1a25cb0655 100644 --- a/x-pack/plugins/alerting/server/task_runner/create_execution_handler.ts +++ b/x-pack/plugins/alerting/server/task_runner/create_execution_handler.ts @@ -112,6 +112,8 @@ export function createExecutionHandler< }), })); + alertExecutionStore.numberOfScheduledActions += actions.length; + const ruleLabel = `${ruleType.id}:${ruleId}: '${ruleName}'`; const actionsClient = await actionsPlugin.getActionsClientWithRequest(request); diff --git a/x-pack/plugins/alerting/server/task_runner/fixtures.ts b/x-pack/plugins/alerting/server/task_runner/fixtures.ts index 4e38be4834c86..d8db61cdddc0d 100644 --- a/x-pack/plugins/alerting/server/task_runner/fixtures.ts +++ b/x-pack/plugins/alerting/server/task_runner/fixtures.ts @@ -211,6 +211,7 @@ export const generateEventLog = ({ actionId, status, numberOfTriggeredActions, + numberOfScheduledActions, savedObjects = [generateAlertSO('1')], }: GeneratorParams = {}) => ({ ...(status === 'error' && { @@ -234,9 +235,10 @@ export const generateEventLog = ({ ...(consumer && { consumer }), execution: { uuid: '5f6aa57d-3e22-484e-bae8-cbed868f4d28', - ...(!isNil(numberOfTriggeredActions) && { + ...((!isNil(numberOfTriggeredActions) || !isNil(numberOfScheduledActions)) && { metrics: { number_of_triggered_actions: numberOfTriggeredActions, + number_of_scheduled_actions: numberOfScheduledActions, number_of_searches: 3, es_search_duration_ms: 33, total_search_duration_ms: 23423, diff --git a/x-pack/plugins/alerting/server/task_runner/task_runner.test.ts b/x-pack/plugins/alerting/server/task_runner/task_runner.test.ts index 2227a34dfa111..3eed02bb10e31 100644 --- a/x-pack/plugins/alerting/server/task_runner/task_runner.test.ts +++ b/x-pack/plugins/alerting/server/task_runner/task_runner.test.ts @@ -232,7 +232,7 @@ describe('Task Runner', () => { expect(logger.debug).nthCalledWith(1, 'executing rule test:1 at 1970-01-01T00:00:00.000Z'); expect(logger.debug).nthCalledWith( 2, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"ok"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"numberOfScheduledActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"ok"}' ); const eventLogger = taskRunnerFactoryInitializerParams.eventLogger; @@ -312,7 +312,7 @@ describe('Task Runner', () => { ); expect(logger.debug).nthCalledWith( 3, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":1,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":1,"numberOfScheduledActions":1,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' ); const eventLogger = customTaskRunnerFactoryInitializerParams.eventLogger; @@ -368,6 +368,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 1, + numberOfScheduledActions: 1, task: true, consumer: 'bar', }) @@ -419,7 +420,7 @@ describe('Task Runner', () => { ); expect(logger.debug).nthCalledWith( 4, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"numberOfScheduledActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' ); const eventLogger = taskRunnerFactoryInitializerParams.eventLogger; @@ -462,6 +463,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, consumer: 'bar', }) @@ -583,7 +585,7 @@ describe('Task Runner', () => { ); expect(logger.debug).nthCalledWith( 4, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":1,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":1,"numberOfScheduledActions":1,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' ); expect(mockUsageCounter.incrementCounter).not.toHaveBeenCalled(); } @@ -772,6 +774,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, consumer: 'bar', }) @@ -836,6 +839,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 1, + numberOfScheduledActions: 1, task: true, consumer: 'bar', }) @@ -909,6 +913,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 1, + numberOfScheduledActions: 1, task: true, consumer: 'bar', }) @@ -1026,6 +1031,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 1, + numberOfScheduledActions: 1, task: true, consumer: 'bar', }) @@ -1107,7 +1113,7 @@ describe('Task Runner', () => { ); expect(logger.debug).nthCalledWith( 4, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":2,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":2,"numberOfScheduledActions":2,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' ); const eventLogger = customTaskRunnerFactoryInitializerParams.eventLogger; @@ -1174,6 +1180,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 2, + numberOfScheduledActions: 2, task: true, consumer: 'bar', }) @@ -1247,7 +1254,7 @@ describe('Task Runner', () => { ); expect(logger.debug).nthCalledWith( 4, - `ruleExecutionStatus for test:${alertId}: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":2,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}` + `ruleExecutionStatus for test:${alertId}: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":2,"numberOfScheduledActions":2,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}` ); const eventLogger = customTaskRunnerFactoryInitializerParams.eventLogger; @@ -1435,6 +1442,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 0, + numberOfScheduledActions: 2, task: true, consumer: 'bar', }) @@ -2040,6 +2048,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, consumer: 'bar', }) @@ -2142,6 +2151,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'active', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, consumer: 'bar', }) @@ -2233,6 +2243,7 @@ describe('Task Runner', () => { status: 'active', consumer: 'bar', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, }) ); @@ -2322,6 +2333,7 @@ describe('Task Runner', () => { status: 'ok', consumer: 'bar', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, }) ); @@ -2407,6 +2419,7 @@ describe('Task Runner', () => { status: 'ok', consumer: 'bar', numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, task: true, }) ); @@ -2468,7 +2481,7 @@ describe('Task Runner', () => { expect(logger.debug).nthCalledWith(1, 'executing rule test:1 at 1970-01-01T00:00:00.000Z'); expect(logger.debug).nthCalledWith( 2, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"ok"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"numberOfScheduledActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"ok"}' ); const eventLogger = taskRunnerFactoryInitializerParams.eventLogger; @@ -2657,35 +2670,37 @@ describe('Task Runner', () => { } ); + const mockActions = [ + { + group: 'default', + id: '1', + actionTypeId: 'action', + }, + { + group: 'default', + id: '2', + actionTypeId: 'action', + }, + { + group: 'default', + id: '3', + actionTypeId: 'action', + }, + { + group: 'default', + id: '4', + actionTypeId: 'action', + }, + { + group: 'default', + id: '5', + actionTypeId: 'action', + }, + ]; + rulesClient.get.mockResolvedValue({ ...mockedRuleTypeSavedObject, - actions: [ - { - group: 'default', - id: '1', - actionTypeId: 'action', - }, - { - group: 'default', - id: '2', - actionTypeId: 'action', - }, - { - group: 'default', - id: '3', - actionTypeId: 'action', - }, - { - group: 'default', - id: '4', - actionTypeId: 'action', - }, - { - group: 'default', - id: '5', - actionTypeId: 'action', - }, - ], + actions: mockActions, } as jest.ResolvedValue); ruleTypeRegistry.get.mockReturnValue(ruleTypeWithConfig); encryptedSavedObjectsClient.getDecryptedAsInternalUser.mockResolvedValueOnce(SAVED_OBJECT); @@ -2801,6 +2816,7 @@ describe('Task Runner', () => { outcome: 'success', status: 'warning', numberOfTriggeredActions: ruleTypeWithConfig.config.execution.actions.max, + numberOfScheduledActions: mockActions.length, reason: AlertExecutionStatusWarningReasons.MAX_EXECUTABLE_ACTIONS, task: true, consumer: 'bar', diff --git a/x-pack/plugins/alerting/server/task_runner/task_runner.ts b/x-pack/plugins/alerting/server/task_runner/task_runner.ts index b7980f612e7b9..1ddca46d17418 100644 --- a/x-pack/plugins/alerting/server/task_runner/task_runner.ts +++ b/x-pack/plugins/alerting/server/task_runner/task_runner.ts @@ -492,6 +492,7 @@ export class TaskRunner< const alertExecutionStore: AlertExecutionStore = { numberOfTriggeredActions: 0, + numberOfScheduledActions: 0, triggeredActionsStatus: ActionsCompletion.COMPLETE, }; @@ -816,7 +817,12 @@ export class TaskRunner< set( event, 'kibana.alert.rule.execution.metrics.number_of_triggered_actions', - executionStatus.numberOfTriggeredActions ?? 0 + executionStatus.numberOfTriggeredActions + ); + set( + event, + 'kibana.alert.rule.execution.metrics.number_of_scheduled_actions', + executionStatus.numberOfScheduledActions ); } diff --git a/x-pack/plugins/alerting/server/task_runner/task_runner_cancel.test.ts b/x-pack/plugins/alerting/server/task_runner/task_runner_cancel.test.ts index e60e4e9295a5c..39d2aa8418394 100644 --- a/x-pack/plugins/alerting/server/task_runner/task_runner_cancel.test.ts +++ b/x-pack/plugins/alerting/server/task_runner/task_runner_cancel.test.ts @@ -330,6 +330,7 @@ describe('Task Runner Cancel', () => { metrics: { number_of_searches: 3, number_of_triggered_actions: 0, + number_of_scheduled_actions: 0, es_search_duration_ms: 33, total_search_duration_ms: 23423, }, @@ -519,7 +520,7 @@ describe('Task Runner Cancel', () => { ); expect(logger.debug).nthCalledWith( 7, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":0,"numberOfScheduledActions":0,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' ); const eventLogger = taskRunnerFactoryInitializerParams.eventLogger; @@ -613,6 +614,7 @@ describe('Task Runner Cancel', () => { metrics: { number_of_searches: 3, number_of_triggered_actions: 0, + number_of_scheduled_actions: 0, es_search_duration_ms: 33, total_search_duration_ms: 23423, }, @@ -678,7 +680,7 @@ describe('Task Runner Cancel', () => { ); expect(logger.debug).nthCalledWith( 6, - 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":1,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' + 'ruleExecutionStatus for test:1: {"metrics":{"numSearches":3,"esSearchDurationMs":33,"totalSearchDurationMs":23423},"numberOfTriggeredActions":1,"numberOfScheduledActions":1,"lastExecutionDate":"1970-01-01T00:00:00.000Z","status":"active"}' ); const eventLogger = taskRunnerFactoryInitializerParams.eventLogger; @@ -891,6 +893,7 @@ describe('Task Runner Cancel', () => { metrics: { number_of_searches: 3, number_of_triggered_actions: 1, + number_of_scheduled_actions: 1, es_search_duration_ms: 33, total_search_duration_ms: 23423, }, diff --git a/x-pack/plugins/alerting/server/task_runner/types.ts b/x-pack/plugins/alerting/server/task_runner/types.ts index 00878c2980a8c..d8483139a92b9 100644 --- a/x-pack/plugins/alerting/server/task_runner/types.ts +++ b/x-pack/plugins/alerting/server/task_runner/types.ts @@ -163,5 +163,6 @@ export enum ActionsCompletion { export interface AlertExecutionStore { numberOfTriggeredActions: number; + numberOfScheduledActions: number; triggeredActionsStatus: ActionsCompletion; } diff --git a/x-pack/plugins/alerting/server/types.ts b/x-pack/plugins/alerting/server/types.ts index 8dcc403613577..37df778b6185a 100644 --- a/x-pack/plugins/alerting/server/types.ts +++ b/x-pack/plugins/alerting/server/types.ts @@ -195,7 +195,6 @@ export interface AlertMeta extends SavedObjectAttributes { // delete any previous error if the current status has no error export interface RawRuleExecutionStatus extends SavedObjectAttributes { status: AlertExecutionStatuses; - numberOfTriggeredActions?: number; lastExecutionDate: string; lastDuration?: number; error: null | { diff --git a/x-pack/plugins/event_log/generated/mappings.json b/x-pack/plugins/event_log/generated/mappings.json index 3187423e91b29..f030f0d50b5e7 100644 --- a/x-pack/plugins/event_log/generated/mappings.json +++ b/x-pack/plugins/event_log/generated/mappings.json @@ -296,6 +296,9 @@ "number_of_triggered_actions": { "type": "long" }, + "number_of_scheduled_actions": { + "type": "long" + }, "number_of_searches": { "type": "long" }, diff --git a/x-pack/plugins/event_log/generated/schemas.ts b/x-pack/plugins/event_log/generated/schemas.ts index 5a26cb92c636c..817c545b45c56 100644 --- a/x-pack/plugins/event_log/generated/schemas.ts +++ b/x-pack/plugins/event_log/generated/schemas.ts @@ -130,6 +130,7 @@ export const EventSchema = schema.maybe( metrics: schema.maybe( schema.object({ number_of_triggered_actions: ecsNumber(), + number_of_scheduled_actions: ecsNumber(), number_of_searches: ecsNumber(), total_indexing_duration_ms: ecsNumber(), es_search_duration_ms: ecsNumber(), diff --git a/x-pack/plugins/event_log/scripts/mappings.js b/x-pack/plugins/event_log/scripts/mappings.js index cc255c2b15719..bf3f9c6b88009 100644 --- a/x-pack/plugins/event_log/scripts/mappings.js +++ b/x-pack/plugins/event_log/scripts/mappings.js @@ -78,6 +78,9 @@ exports.EcsCustomPropertyMappings = { number_of_triggered_actions: { type: 'long', }, + number_of_scheduled_actions: { + type: 'long', + }, number_of_searches: { type: 'long', }, From 7559f90c97135a1472287759074d8d80f9a9507a Mon Sep 17 00:00:00 2001 From: Stacey Gammon Date: Mon, 28 Mar 2022 14:24:55 -0400 Subject: [PATCH 045/160] Update api docs (#128663) --- api_docs/actions.devdocs.json | 51 +- api_docs/actions.mdx | 4 +- api_docs/advanced_settings.mdx | 2 +- api_docs/alerting.devdocs.json | 128 +- api_docs/alerting.mdx | 4 +- api_docs/apm.devdocs.json | 54 +- api_docs/apm.mdx | 2 +- api_docs/banners.mdx | 2 +- api_docs/bfetch.mdx | 2 +- api_docs/canvas.mdx | 2 +- api_docs/cases.devdocs.json | 8 +- api_docs/cases.mdx | 2 +- api_docs/charts.mdx | 2 +- api_docs/cloud.mdx | 2 +- api_docs/cloud_security_posture.devdocs.json | 109 +- api_docs/cloud_security_posture.mdx | 7 +- api_docs/console.mdx | 2 +- api_docs/controls.devdocs.json | 53 +- api_docs/controls.mdx | 7 +- api_docs/core.devdocs.json | 54 +- api_docs/core.mdx | 4 +- api_docs/core_application.devdocs.json | 47 + api_docs/core_application.mdx | 4 +- api_docs/core_chrome.devdocs.json | 5 +- api_docs/core_chrome.mdx | 4 +- api_docs/core_http.devdocs.json | 2 + api_docs/core_http.mdx | 4 +- api_docs/core_saved_objects.devdocs.json | 45 +- api_docs/core_saved_objects.mdx | 4 +- api_docs/custom_integrations.mdx | 2 +- api_docs/dashboard.devdocs.json | 54 +- api_docs/dashboard.mdx | 4 +- api_docs/dashboard_enhanced.mdx | 2 +- api_docs/data.devdocs.json | 6323 +++++++---------- api_docs/data.mdx | 4 +- api_docs/data_autocomplete.mdx | 4 +- api_docs/data_enhanced.mdx | 2 +- api_docs/data_query.mdx | 4 +- api_docs/data_search.devdocs.json | 183 +- api_docs/data_search.mdx | 4 +- api_docs/data_ui.mdx | 4 +- api_docs/data_view_editor.mdx | 2 +- api_docs/data_view_field_editor.mdx | 2 +- api_docs/data_view_management.mdx | 2 +- api_docs/data_views.devdocs.json | 5426 +++++++------- api_docs/data_views.mdx | 4 +- api_docs/data_visualizer.devdocs.json | 8 +- api_docs/data_visualizer.mdx | 2 +- api_docs/deprecations_by_api.mdx | 206 +- api_docs/deprecations_by_plugin.mdx | 421 +- api_docs/deprecations_by_team.mdx | 178 +- api_docs/dev_tools.mdx | 2 +- api_docs/discover.devdocs.json | 2 +- api_docs/discover.mdx | 2 +- api_docs/discover_enhanced.mdx | 2 +- api_docs/elastic_apm_synthtrace.mdx | 2 +- api_docs/elastic_datemath.mdx | 2 +- api_docs/embeddable.devdocs.json | 51 +- api_docs/embeddable.mdx | 4 +- api_docs/embeddable_enhanced.mdx | 2 +- api_docs/encrypted_saved_objects.mdx | 2 +- api_docs/enterprise_search.mdx | 2 +- api_docs/es_ui_shared.devdocs.json | 31 + api_docs/es_ui_shared.mdx | 4 +- api_docs/event_annotation.devdocs.json | 709 ++ api_docs/event_annotation.mdx | 47 + api_docs/event_log.devdocs.json | 6 +- api_docs/event_log.mdx | 2 +- api_docs/expression_error.mdx | 2 +- api_docs/expression_gauge.mdx | 2 +- api_docs/expression_heatmap.devdocs.json | 13 + api_docs/expression_heatmap.mdx | 4 +- api_docs/expression_image.mdx | 2 +- api_docs/expression_metric.mdx | 2 +- api_docs/expression_metric_vis.mdx | 2 +- api_docs/expression_partition_vis.mdx | 2 +- api_docs/expression_repeat_image.mdx | 2 +- api_docs/expression_reveal_image.mdx | 2 +- api_docs/expression_shape.mdx | 2 +- api_docs/expression_tagcloud.mdx | 2 +- api_docs/expressions.devdocs.json | 1262 +++- api_docs/expressions.mdx | 4 +- api_docs/features.devdocs.json | 151 +- api_docs/features.mdx | 4 +- api_docs/field_formats.mdx | 2 +- api_docs/file_upload.mdx | 2 +- api_docs/fleet.devdocs.json | 281 +- api_docs/fleet.mdx | 4 +- api_docs/global_search.mdx | 2 +- api_docs/home.devdocs.json | 1 + api_docs/home.mdx | 2 +- api_docs/index_lifecycle_management.mdx | 2 +- api_docs/index_management.mdx | 2 +- api_docs/infra.mdx | 2 +- api_docs/inspector.mdx | 2 +- api_docs/interactive_setup.mdx | 2 +- api_docs/kbn_ace.mdx | 2 +- api_docs/kbn_alerts.mdx | 2 +- api_docs/kbn_analytics.mdx | 2 +- api_docs/kbn_apm_config_loader.mdx | 2 +- api_docs/kbn_apm_utils.mdx | 2 +- api_docs/kbn_bazel_packages.devdocs.json | 19 +- api_docs/kbn_bazel_packages.mdx | 7 +- api_docs/kbn_cli_dev_mode.mdx | 2 +- api_docs/kbn_config.mdx | 2 +- api_docs/kbn_config_schema.mdx | 2 +- api_docs/kbn_crypto.mdx | 2 +- api_docs/kbn_dev_utils.mdx | 2 +- api_docs/kbn_doc_links.devdocs.json | 21 +- api_docs/kbn_doc_links.mdx | 4 +- api_docs/kbn_docs_utils.mdx | 2 +- api_docs/kbn_es_archiver.mdx | 2 +- api_docs/kbn_es_query.devdocs.json | 48 +- api_docs/kbn_es_query.mdx | 4 +- api_docs/kbn_field_types.mdx | 2 +- api_docs/kbn_generate.mdx | 2 +- api_docs/kbn_i18n.mdx | 2 +- api_docs/kbn_interpreter.mdx | 2 +- api_docs/kbn_io_ts_utils.mdx | 2 +- api_docs/kbn_logging.mdx | 2 +- api_docs/kbn_logging_mocks.mdx | 2 +- api_docs/kbn_mapbox_gl.mdx | 2 +- api_docs/kbn_monaco.mdx | 2 +- api_docs/kbn_optimizer.mdx | 2 +- api_docs/kbn_plugin_generator.mdx | 2 +- api_docs/kbn_plugin_helpers.mdx | 2 +- api_docs/kbn_pm.mdx | 2 +- api_docs/kbn_react_field.mdx | 2 +- api_docs/kbn_rule_data_utils.mdx | 2 +- .../kbn_securitysolution_autocomplete.mdx | 2 +- api_docs/kbn_securitysolution_es_utils.mdx | 2 +- api_docs/kbn_securitysolution_hook_utils.mdx | 2 +- ..._securitysolution_io_ts_alerting_types.mdx | 2 +- ...ritysolution_io_ts_list_types.devdocs.json | 29 +- .../kbn_securitysolution_io_ts_list_types.mdx | 4 +- api_docs/kbn_securitysolution_io_ts_types.mdx | 2 +- api_docs/kbn_securitysolution_io_ts_utils.mdx | 2 +- api_docs/kbn_securitysolution_list_api.mdx | 2 +- .../kbn_securitysolution_list_constants.mdx | 2 +- ...n_securitysolution_list_hooks.devdocs.json | 4 +- api_docs/kbn_securitysolution_list_hooks.mdx | 2 +- ...n_securitysolution_list_utils.devdocs.json | 93 +- api_docs/kbn_securitysolution_list_utils.mdx | 4 +- api_docs/kbn_securitysolution_rules.mdx | 2 +- api_docs/kbn_securitysolution_t_grid.mdx | 2 +- .../kbn_securitysolution_utils.devdocs.json | 116 +- api_docs/kbn_securitysolution_utils.mdx | 7 +- api_docs/kbn_server_http_tools.mdx | 2 +- api_docs/kbn_server_route_repository.mdx | 2 +- .../kbn_shared_ux_components.devdocs.json | 513 ++ api_docs/kbn_shared_ux_components.mdx | 27 + api_docs/kbn_shared_ux_services.devdocs.json | 1311 ++++ api_docs/kbn_shared_ux_services.mdx | 36 + api_docs/kbn_shared_ux_storybook.devdocs.json | 225 + api_docs/kbn_shared_ux_storybook.mdx | 27 + api_docs/kbn_shared_ux_utility.devdocs.json | 177 + api_docs/kbn_shared_ux_utility.mdx | 27 + api_docs/kbn_std.mdx | 2 +- api_docs/kbn_storybook.mdx | 2 +- api_docs/kbn_telemetry_tools.mdx | 2 +- api_docs/kbn_test.mdx | 2 +- api_docs/kbn_test_jest_helpers.mdx | 2 +- api_docs/kbn_type_summarizer.mdx | 2 +- api_docs/kbn_typed_react_router_config.mdx | 2 +- api_docs/kbn_ui_theme.devdocs.json | 8 +- api_docs/kbn_ui_theme.mdx | 2 +- api_docs/kbn_utility_types.mdx | 2 +- api_docs/kbn_utils.mdx | 2 +- api_docs/kibana_overview.mdx | 2 +- api_docs/kibana_react.devdocs.json | 363 +- api_docs/kibana_react.mdx | 2 +- api_docs/kibana_utils.mdx | 2 +- api_docs/lens.devdocs.json | 814 ++- api_docs/lens.mdx | 4 +- api_docs/license_api_guard.mdx | 2 +- api_docs/license_management.mdx | 2 +- api_docs/licensing.devdocs.json | 8 + api_docs/licensing.mdx | 2 +- api_docs/lists.mdx | 2 +- api_docs/management.mdx | 2 +- api_docs/maps.devdocs.json | 65 + api_docs/maps.mdx | 4 +- api_docs/maps_ems.devdocs.json | 2 +- api_docs/maps_ems.mdx | 2 +- api_docs/metrics_entities.mdx | 2 +- api_docs/ml.devdocs.json | 18 +- api_docs/ml.mdx | 2 +- api_docs/monitoring.mdx | 2 +- api_docs/monitoring_collection.devdocs.json | 100 +- api_docs/monitoring_collection.mdx | 7 +- api_docs/navigation.mdx | 2 +- api_docs/newsfeed.mdx | 2 +- api_docs/observability.devdocs.json | 331 +- api_docs/observability.mdx | 4 +- api_docs/osquery.devdocs.json | 38 + api_docs/osquery.mdx | 4 +- api_docs/plugin_directory.mdx | 79 +- api_docs/presentation_util.mdx | 2 +- api_docs/remote_clusters.mdx | 2 +- api_docs/reporting.mdx | 2 +- api_docs/rollup.mdx | 2 +- api_docs/rule_registry.devdocs.json | 34 +- api_docs/rule_registry.mdx | 4 +- api_docs/runtime_fields.mdx | 2 +- api_docs/saved_objects.devdocs.json | 20 + api_docs/saved_objects.mdx | 2 +- api_docs/saved_objects_management.mdx | 2 +- api_docs/saved_objects_tagging.mdx | 2 +- api_docs/saved_objects_tagging_oss.mdx | 2 +- api_docs/screenshot_mode.mdx | 2 +- api_docs/screenshotting.devdocs.json | 307 +- api_docs/screenshotting.mdx | 4 +- api_docs/security.mdx | 2 +- api_docs/security_solution.devdocs.json | 4 +- api_docs/security_solution.mdx | 2 +- api_docs/share.mdx | 2 +- api_docs/shared_u_x.devdocs.json | 183 +- api_docs/shared_u_x.mdx | 7 +- api_docs/snapshot_restore.mdx | 2 +- api_docs/spaces.devdocs.json | 101 +- api_docs/spaces.mdx | 4 +- api_docs/stack_alerts.mdx | 2 +- api_docs/task_manager.devdocs.json | 79 +- api_docs/task_manager.mdx | 7 +- api_docs/telemetry.devdocs.json | 44 +- api_docs/telemetry.mdx | 4 +- api_docs/telemetry_collection_manager.mdx | 2 +- api_docs/telemetry_collection_xpack.mdx | 2 +- api_docs/telemetry_management_section.mdx | 2 +- api_docs/timelines.mdx | 2 +- api_docs/transform.mdx | 2 +- api_docs/triggers_actions_ui.devdocs.json | 939 ++- api_docs/triggers_actions_ui.mdx | 10 +- api_docs/ui_actions.devdocs.json | 4 + api_docs/ui_actions.mdx | 2 +- api_docs/ui_actions_enhanced.mdx | 2 +- api_docs/url_forwarding.mdx | 2 +- api_docs/usage_collection.mdx | 2 +- api_docs/ux.mdx | 2 +- api_docs/vis_default_editor.devdocs.json | 31 + api_docs/vis_default_editor.mdx | 4 +- api_docs/vis_type_gauge.mdx | 2 +- api_docs/vis_type_heatmap.mdx | 2 +- api_docs/vis_type_pie.mdx | 2 +- api_docs/vis_type_table.mdx | 2 +- api_docs/vis_type_timelion.mdx | 2 +- api_docs/vis_type_timeseries.mdx | 2 +- api_docs/vis_type_vega.mdx | 2 +- api_docs/vis_type_vislib.mdx | 2 +- api_docs/vis_type_xy.mdx | 2 +- api_docs/visualizations.devdocs.json | 62 +- api_docs/visualizations.mdx | 4 +- 252 files changed, 14664 insertions(+), 8031 deletions(-) create mode 100644 api_docs/event_annotation.devdocs.json create mode 100644 api_docs/event_annotation.mdx create mode 100644 api_docs/kbn_shared_ux_components.devdocs.json create mode 100644 api_docs/kbn_shared_ux_components.mdx create mode 100644 api_docs/kbn_shared_ux_services.devdocs.json create mode 100644 api_docs/kbn_shared_ux_services.mdx create mode 100644 api_docs/kbn_shared_ux_storybook.devdocs.json create mode 100644 api_docs/kbn_shared_ux_storybook.mdx create mode 100644 api_docs/kbn_shared_ux_utility.devdocs.json create mode 100644 api_docs/kbn_shared_ux_utility.mdx diff --git a/api_docs/actions.devdocs.json b/api_docs/actions.devdocs.json index 703029e49ca4b..0afe38f88e46b 100644 --- a/api_docs/actions.devdocs.json +++ b/api_docs/actions.devdocs.json @@ -598,6 +598,49 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "actions", + "id": "def-server.FindActionResult", + "type": "Interface", + "tags": [], + "label": "FindActionResult", + "description": [], + "signature": [ + { + "pluginId": "actions", + "scope": "server", + "docId": "kibActionsPluginApi", + "section": "def-server.FindActionResult", + "text": "FindActionResult" + }, + " extends ", + { + "pluginId": "actions", + "scope": "server", + "docId": "kibActionsPluginApi", + "section": "def-server.ActionResult", + "text": "ActionResult" + }, + "<", + "ActionTypeConfig", + ">" + ], + "path": "x-pack/plugins/actions/server/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "actions", + "id": "def-server.FindActionResult.referencedByCount", + "type": "number", + "tags": [], + "label": "referencedByCount", + "description": [], + "path": "x-pack/plugins/actions/server/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "actions", "id": "def-server.PreConfiguredAction", @@ -866,7 +909,13 @@ "text": "ActionTypeExecutorResult" }, ">; getAll: () => Promise<", - "FindActionResult", + { + "pluginId": "actions", + "scope": "server", + "docId": "kibActionsPluginApi", + "section": "def-server.FindActionResult", + "text": "FindActionResult" + }, "[]>; getBulk: (ids: string[]) => Promise<", { "pluginId": "actions", diff --git a/api_docs/actions.mdx b/api_docs/actions.mdx index d2c9ee775d532..f4482b882e2e1 100644 --- a/api_docs/actions.mdx +++ b/api_docs/actions.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/actions title: "actions" image: https://source.unsplash.com/400x175/?github summary: API docs for the actions plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'actions'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Response Ops](https://github.com/orgs/elastic/teams/response-ops) for q | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 125 | 0 | 125 | 11 | +| 127 | 0 | 127 | 10 | ## Server diff --git a/api_docs/advanced_settings.mdx b/api_docs/advanced_settings.mdx index f2d44ad5ee853..6a905c58dd2d7 100644 --- a/api_docs/advanced_settings.mdx +++ b/api_docs/advanced_settings.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/advancedSettings title: "advancedSettings" image: https://source.unsplash.com/400x175/?github summary: API docs for the advancedSettings plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'advancedSettings'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/alerting.devdocs.json b/api_docs/alerting.devdocs.json index 3405c4e591615..1506b960286a9 100644 --- a/api_docs/alerting.devdocs.json +++ b/api_docs/alerting.devdocs.json @@ -57,7 +57,7 @@ "section": "def-common.AlertAction", "text": "AlertAction" }, - "[]; throttle: string | null; alertTypeId: string; consumer: string; schedule: ", + "[]; throttle: string | null; consumer: string; alertTypeId: string; schedule: ", { "pluginId": "alerting", "scope": "common", @@ -81,7 +81,7 @@ "section": "def-common.AlertExecutionStatus", "text": "AlertExecutionStatus" }, - "; }" + "; snoozeEndTime?: Date | null | undefined; }" ], "path": "x-pack/plugins/alerting/public/alert_navigation_registry/types.ts", "deprecated": false @@ -1904,8 +1904,8 @@ "pluginId": "alerting", "scope": "server", "docId": "kibAlertingPluginApi", - "section": "def-server.PublicAlertingConfig", - "text": "PublicAlertingConfig" + "section": "def-server.AlertingRulesConfig", + "text": "AlertingRulesConfig" } ], "path": "x-pack/plugins/alerting/server/plugin.ts", @@ -2433,6 +2433,20 @@ ], "path": "x-pack/plugins/alerting/server/types.ts", "deprecated": false + }, + { + "parentPluginId": "alerting", + "id": "def-server.RuleType.config", + "type": "Object", + "tags": [], + "label": "config", + "description": [], + "signature": [ + "RuleTypeConfig", + " | undefined" + ], + "path": "x-pack/plugins/alerting/server/types.ts", + "deprecated": false } ], "initialIsOpen": false @@ -2529,6 +2543,20 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "alerting", + "id": "def-server.AlertingRulesConfig", + "type": "Type", + "tags": [], + "label": "AlertingRulesConfig", + "description": [], + "signature": [ + "{ readonly minimumScheduleInterval: Readonly<{} & { value: string; enforce: boolean; }>; }" + ], + "path": "x-pack/plugins/alerting/server/config.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "alerting", "id": "def-server.AlertInstanceContext", @@ -2651,20 +2679,6 @@ "deprecated": false, "initialIsOpen": false }, - { - "parentPluginId": "alerting", - "id": "def-server.PublicAlertingConfig", - "type": "Type", - "tags": [], - "label": "PublicAlertingConfig", - "description": [], - "signature": [ - "{ readonly minimumScheduleInterval: string; }" - ], - "path": "x-pack/plugins/alerting/server/config.ts", - "deprecated": false, - "initialIsOpen": false - }, { "parentPluginId": "alerting", "id": "def-server.RulesClient", @@ -2775,7 +2789,11 @@ "section": "def-common.AlertSummary", "text": "AlertSummary" }, - ">; updateApiKey: ({ id }: { id: string; }) => Promise; unmuteAll: ({ id }: { id: string; }) => Promise; muteInstance: ({ alertId, alertInstanceId }: ", + ">; getExecutionLogForRule: ({ id, dateStart, dateEnd, filter, page, perPage, sort, }: ", + "GetExecutionLogByIdParams", + ") => Promise<", + "IExecutionLogResult", + ">; updateApiKey: ({ id }: { id: string; }) => Promise; snooze: ({ id, snoozeEndTime, }: { id: string; snoozeEndTime: string | -1; }) => Promise; unsnooze: ({ id }: { id: string; }) => Promise; unmuteAll: ({ id }: { id: string; }) => Promise; muteInstance: ({ alertId, alertInstanceId }: ", "MuteOptions", ") => Promise; unmuteInstance: ({ alertId, alertInstanceId }: ", "MuteOptions", @@ -3540,6 +3558,19 @@ ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false + }, + { + "parentPluginId": "alerting", + "id": "def-common.Alert.snoozeEndTime", + "type": "CompoundType", + "tags": [], + "label": "snoozeEndTime", + "description": [], + "signature": [ + "Date | null | undefined" + ], + "path": "x-pack/plugins/alerting/common/alert.ts", + "deprecated": false } ], "initialIsOpen": false @@ -3648,6 +3679,19 @@ ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false + }, + { + "parentPluginId": "alerting", + "id": "def-common.AlertAggregations.ruleSnoozedStatus", + "type": "Object", + "tags": [], + "label": "ruleSnoozedStatus", + "description": [], + "signature": [ + "{ snoozed: number; }" + ], + "path": "x-pack/plugins/alerting/common/alert.ts", + "deprecated": false } ], "initialIsOpen": false @@ -3670,7 +3714,7 @@ "label": "status", "description": [], "signature": [ - "\"error\" | \"unknown\" | \"pending\" | \"ok\" | \"active\"" + "\"error\" | \"unknown\" | \"warning\" | \"pending\" | \"ok\" | \"active\"" ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false @@ -3747,6 +3791,27 @@ ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false + }, + { + "parentPluginId": "alerting", + "id": "def-common.AlertExecutionStatus.warning", + "type": "Object", + "tags": [], + "label": "warning", + "description": [], + "signature": [ + "{ reason: ", + { + "pluginId": "alerting", + "scope": "common", + "docId": "kibAlertingPluginApi", + "section": "def-common.AlertExecutionStatusWarningReasons", + "text": "AlertExecutionStatusWarningReasons" + }, + "; message: string; } | undefined" + ], + "path": "x-pack/plugins/alerting/common/alert.ts", + "deprecated": false } ], "initialIsOpen": false @@ -4328,7 +4393,7 @@ "label": "state", "description": [], "signature": [ - "{ alertTypeState?: { [x: string]: unknown; } | undefined; alertInstances?: { [x: string]: { state?: { [x: string]: unknown; } | undefined; meta?: { lastScheduledActions?: ({ subgroup?: string | undefined; } & { group: string; date: Date; }) | undefined; } | undefined; }; } | undefined; previousStartedAt?: Date | null | undefined; } & { metrics: { numSearches?: number | undefined; totalSearchDurationMs?: number | undefined; esSearchDurationMs?: number | undefined; }; triggeredActions: { group?: string | undefined; id?: string | undefined; actionTypeId?: string | undefined; params?: { [x: string]: unknown; } | undefined; }[]; }" + "{ alertTypeState?: { [x: string]: unknown; } | undefined; alertInstances?: { [x: string]: { state?: { [x: string]: unknown; } | undefined; meta?: { lastScheduledActions?: ({ subgroup?: string | undefined; } & { group: string; date: Date; }) | undefined; } | undefined; }; } | undefined; previousStartedAt?: Date | null | undefined; } & { metrics: { numSearches?: number | undefined; totalSearchDurationMs?: number | undefined; esSearchDurationMs?: number | undefined; }; alertExecutionStore: { numberOfTriggeredActions?: number | undefined; triggeredActionsStatus?: string | undefined; }; }" ], "path": "x-pack/plugins/alerting/common/rule_task_instance.ts", "deprecated": false @@ -4777,12 +4842,23 @@ "label": "AlertExecutionStatuses", "description": [], "signature": [ - "\"error\" | \"unknown\" | \"pending\" | \"ok\" | \"active\"" + "\"error\" | \"unknown\" | \"warning\" | \"pending\" | \"ok\" | \"active\"" ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "alerting", + "id": "def-common.AlertExecutionStatusWarningReasons", + "type": "string", + "tags": [], + "label": "AlertExecutionStatusWarningReasons", + "description": [], + "path": "x-pack/plugins/alerting/common/alert.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "alerting", "id": "def-common.AlertInstanceContext", @@ -5108,7 +5184,7 @@ "label": "RuleExecutionState", "description": [], "signature": [ - "{ alertTypeState?: { [x: string]: unknown; } | undefined; alertInstances?: { [x: string]: { state?: { [x: string]: unknown; } | undefined; meta?: { lastScheduledActions?: ({ subgroup?: string | undefined; } & { group: string; date: Date; }) | undefined; } | undefined; }; } | undefined; previousStartedAt?: Date | null | undefined; } & { metrics: { numSearches?: number | undefined; totalSearchDurationMs?: number | undefined; esSearchDurationMs?: number | undefined; }; triggeredActions: { group?: string | undefined; id?: string | undefined; actionTypeId?: string | undefined; params?: { [x: string]: unknown; } | undefined; }[]; }" + "{ alertTypeState?: { [x: string]: unknown; } | undefined; alertInstances?: { [x: string]: { state?: { [x: string]: unknown; } | undefined; meta?: { lastScheduledActions?: ({ subgroup?: string | undefined; } & { group: string; date: Date; }) | undefined; } | undefined; }; } | undefined; previousStartedAt?: Date | null | undefined; } & { metrics: { numSearches?: number | undefined; totalSearchDurationMs?: number | undefined; esSearchDurationMs?: number | undefined; }; alertExecutionStore: { numberOfTriggeredActions?: number | undefined; triggeredActionsStatus?: string | undefined; }; }" ], "path": "x-pack/plugins/alerting/common/rule_task_instance.ts", "deprecated": false, @@ -5180,7 +5256,7 @@ "section": "def-common.AlertAction", "text": "AlertAction" }, - "[]; throttle: string | null; alertTypeId: string; consumer: string; schedule: ", + "[]; throttle: string | null; consumer: string; alertTypeId: string; schedule: ", { "pluginId": "alerting", "scope": "common", @@ -5204,7 +5280,7 @@ "section": "def-common.AlertExecutionStatus", "text": "AlertExecutionStatus" }, - "; }" + "; snoozeEndTime?: Date | null | undefined; }" ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false, @@ -5264,7 +5340,7 @@ "label": "AlertExecutionStatusValues", "description": [], "signature": [ - "readonly [\"ok\", \"active\", \"error\", \"pending\", \"unknown\"]" + "readonly [\"ok\", \"active\", \"error\", \"pending\", \"unknown\", \"warning\"]" ], "path": "x-pack/plugins/alerting/common/alert.ts", "deprecated": false, diff --git a/api_docs/alerting.mdx b/api_docs/alerting.mdx index c71dcab214ab5..3a8fa212dc877 100644 --- a/api_docs/alerting.mdx +++ b/api_docs/alerting.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/alerting title: "alerting" image: https://source.unsplash.com/400x175/?github summary: API docs for the alerting plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'alerting'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Response Ops](https://github.com/orgs/elastic/teams/response-ops) for q | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 296 | 0 | 288 | 18 | +| 301 | 0 | 293 | 21 | ## Client diff --git a/api_docs/apm.devdocs.json b/api_docs/apm.devdocs.json index 3ef7e8a739f00..fc375a9769982 100644 --- a/api_docs/apm.devdocs.json +++ b/api_docs/apm.devdocs.json @@ -731,7 +731,7 @@ "label": "APIEndpoint", "description": [], "signature": [ - "\"POST /internal/apm/data_view/static\" | \"GET /internal/apm/data_view/dynamic\" | \"GET /internal/apm/environments\" | \"GET /internal/apm/services/{serviceName}/errors/groups/main_statistics\" | \"GET /internal/apm/services/{serviceName}/errors/groups/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/errors/{groupId}\" | \"GET /internal/apm/services/{serviceName}/errors/distribution\" | \"POST /internal/apm/latency/overall_distribution\" | \"GET /internal/apm/services/{serviceName}/metrics/charts\" | \"GET /internal/apm/observability_overview\" | \"GET /internal/apm/observability_overview/has_data\" | \"GET /internal/apm/ux/client-metrics\" | \"GET /internal/apm/ux/page-load-distribution\" | \"GET /internal/apm/ux/page-load-distribution/breakdown\" | \"GET /internal/apm/ux/page-view-trends\" | \"GET /internal/apm/ux/services\" | \"GET /internal/apm/ux/visitor-breakdown\" | \"GET /internal/apm/ux/web-core-vitals\" | \"GET /internal/apm/ux/long-task-metrics\" | \"GET /internal/apm/ux/url-search\" | \"GET /internal/apm/ux/js-errors\" | \"GET /api/apm/observability_overview/has_rum_data\" | \"GET /internal/apm/service-map\" | \"GET /internal/apm/service-map/service/{serviceName}\" | \"GET /internal/apm/service-map/backend\" | \"GET /internal/apm/services/{serviceName}/serviceNodes\" | \"GET /internal/apm/services\" | \"GET /internal/apm/services/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/metadata/details\" | \"GET /internal/apm/services/{serviceName}/metadata/icons\" | \"GET /internal/apm/services/{serviceName}/agent\" | \"GET /internal/apm/services/{serviceName}/transaction_types\" | \"GET /internal/apm/services/{serviceName}/node/{serviceNodeName}/metadata\" | \"GET /api/apm/services/{serviceName}/annotation/search\" | \"POST /api/apm/services/{serviceName}/annotation\" | \"GET /internal/apm/services/{serviceName}/service_overview_instances/details/{serviceNodeName}\" | \"GET /internal/apm/services/{serviceName}/throughput\" | \"GET /internal/apm/services/{serviceName}/service_overview_instances/main_statistics\" | \"GET /internal/apm/services/{serviceName}/service_overview_instances/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/dependencies\" | \"GET /internal/apm/services/{serviceName}/dependencies/breakdown\" | \"GET /internal/apm/services/{serviceName}/profiling/timeline\" | \"GET /internal/apm/services/{serviceName}/profiling/statistics\" | \"GET /internal/apm/services/{serviceName}/alerts\" | \"GET /internal/apm/services/{serviceName}/infrastructure\" | \"GET /internal/apm/services/{serviceName}/anomaly_charts\" | \"GET /internal/apm/sorted_and_filtered_services\" | \"GET /internal/apm/service-groups\" | \"GET /internal/apm/service-group\" | \"POST /internal/apm/service-group\" | \"DELETE /internal/apm/service-group\" | \"GET /internal/apm/service-group/services\" | \"GET /internal/apm/suggestions\" | \"GET /internal/apm/traces/{traceId}\" | \"GET /internal/apm/traces\" | \"GET /internal/apm/traces/{traceId}/root_transaction\" | \"GET /internal/apm/transactions/{transactionId}\" | \"GET /internal/apm/services/{serviceName}/transactions/groups/main_statistics\" | \"GET /internal/apm/services/{serviceName}/transactions/groups/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/latency\" | \"GET /internal/apm/services/{serviceName}/transactions/traces/samples\" | \"GET /internal/apm/services/{serviceName}/transaction/charts/breakdown\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/error_rate\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/coldstart_rate\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/coldstart_rate_by_transaction_name\" | \"GET /internal/apm/alerts/chart_preview/transaction_error_rate\" | \"GET /internal/apm/alerts/chart_preview/transaction_duration\" | \"GET /internal/apm/alerts/chart_preview/transaction_error_count\" | \"GET /api/apm/settings/agent-configuration\" | \"GET /api/apm/settings/agent-configuration/view\" | \"DELETE /api/apm/settings/agent-configuration\" | \"PUT /api/apm/settings/agent-configuration\" | \"POST /api/apm/settings/agent-configuration/search\" | \"GET /api/apm/settings/agent-configuration/environments\" | \"GET /api/apm/settings/agent-configuration/agent_name\" | \"GET /internal/apm/settings/anomaly-detection/jobs\" | \"POST /internal/apm/settings/anomaly-detection/jobs\" | \"GET /internal/apm/settings/anomaly-detection/environments\" | \"POST /internal/apm/settings/anomaly-detection/update_to_v3\" | \"GET /internal/apm/settings/apm-index-settings\" | \"GET /internal/apm/settings/apm-indices\" | \"POST /internal/apm/settings/apm-indices/save\" | \"GET /internal/apm/settings/custom_links/transaction\" | \"GET /internal/apm/settings/custom_links\" | \"POST /internal/apm/settings/custom_links\" | \"PUT /internal/apm/settings/custom_links/{id}\" | \"DELETE /internal/apm/settings/custom_links/{id}\" | \"GET /api/apm/sourcemaps\" | \"POST /api/apm/sourcemaps\" | \"DELETE /api/apm/sourcemaps/{id}\" | \"GET /internal/apm/fleet/has_apm_policies\" | \"GET /internal/apm/fleet/agents\" | \"POST /api/apm/fleet/apm_server_schema\" | \"GET /internal/apm/fleet/apm_server_schema/unsupported\" | \"GET /internal/apm/fleet/migration_check\" | \"POST /internal/apm/fleet/cloud_apm_package_policy\" | \"GET /internal/apm/backends/top_backends\" | \"GET /internal/apm/backends/upstream_services\" | \"GET /internal/apm/backends/metadata\" | \"GET /internal/apm/backends/charts/latency\" | \"GET /internal/apm/backends/charts/throughput\" | \"GET /internal/apm/backends/charts/error_rate\" | \"POST /internal/apm/correlations/p_values\" | \"GET /internal/apm/correlations/field_candidates\" | \"POST /internal/apm/correlations/field_stats\" | \"GET /internal/apm/correlations/field_value_stats\" | \"POST /internal/apm/correlations/field_value_pairs\" | \"POST /internal/apm/correlations/significant_correlations\" | \"GET /internal/apm/fallback_to_transactions\" | \"GET /internal/apm/has_data\" | \"GET /internal/apm/event_metadata/{processorEvent}/{id}\" | \"GET /internal/apm/agent_keys\" | \"GET /internal/apm/agent_keys/privileges\" | \"POST /internal/apm/api_key/invalidate\" | \"POST /api/apm/agent_keys\"" + "\"POST /internal/apm/data_view/static\" | \"GET /internal/apm/data_view/dynamic\" | \"GET /internal/apm/environments\" | \"GET /internal/apm/services/{serviceName}/errors/groups/main_statistics\" | \"GET /internal/apm/services/{serviceName}/errors/groups/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/errors/{groupId}\" | \"GET /internal/apm/services/{serviceName}/errors/distribution\" | \"POST /internal/apm/latency/overall_distribution\" | \"GET /internal/apm/services/{serviceName}/metrics/charts\" | \"GET /internal/apm/observability_overview\" | \"GET /internal/apm/observability_overview/has_data\" | \"GET /internal/apm/ux/client-metrics\" | \"GET /internal/apm/ux/page-load-distribution\" | \"GET /internal/apm/ux/page-load-distribution/breakdown\" | \"GET /internal/apm/ux/page-view-trends\" | \"GET /internal/apm/ux/services\" | \"GET /internal/apm/ux/visitor-breakdown\" | \"GET /internal/apm/ux/web-core-vitals\" | \"GET /internal/apm/ux/long-task-metrics\" | \"GET /internal/apm/ux/url-search\" | \"GET /internal/apm/ux/js-errors\" | \"GET /api/apm/observability_overview/has_rum_data\" | \"GET /internal/apm/service-map\" | \"GET /internal/apm/service-map/service/{serviceName}\" | \"GET /internal/apm/service-map/backend\" | \"GET /internal/apm/services/{serviceName}/serviceNodes\" | \"GET /internal/apm/services\" | \"GET /internal/apm/services/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/metadata/details\" | \"GET /internal/apm/services/{serviceName}/metadata/icons\" | \"GET /internal/apm/services/{serviceName}/agent\" | \"GET /internal/apm/services/{serviceName}/transaction_types\" | \"GET /internal/apm/services/{serviceName}/node/{serviceNodeName}/metadata\" | \"GET /api/apm/services/{serviceName}/annotation/search\" | \"POST /api/apm/services/{serviceName}/annotation\" | \"GET /internal/apm/services/{serviceName}/service_overview_instances/details/{serviceNodeName}\" | \"GET /internal/apm/services/{serviceName}/throughput\" | \"GET /internal/apm/services/{serviceName}/service_overview_instances/main_statistics\" | \"GET /internal/apm/services/{serviceName}/service_overview_instances/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/dependencies\" | \"GET /internal/apm/services/{serviceName}/dependencies/breakdown\" | \"GET /internal/apm/services/{serviceName}/profiling/timeline\" | \"GET /internal/apm/services/{serviceName}/profiling/statistics\" | \"GET /internal/apm/services/{serviceName}/infrastructure\" | \"GET /internal/apm/services/{serviceName}/anomaly_charts\" | \"GET /internal/apm/sorted_and_filtered_services\" | \"GET /internal/apm/service-groups\" | \"GET /internal/apm/service-group\" | \"POST /internal/apm/service-group\" | \"DELETE /internal/apm/service-group\" | \"GET /internal/apm/service-group/services\" | \"GET /internal/apm/suggestions\" | \"GET /internal/apm/traces/{traceId}\" | \"GET /internal/apm/traces\" | \"GET /internal/apm/traces/{traceId}/root_transaction\" | \"GET /internal/apm/transactions/{transactionId}\" | \"GET /internal/apm/services/{serviceName}/transactions/groups/main_statistics\" | \"GET /internal/apm/services/{serviceName}/transactions/groups/detailed_statistics\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/latency\" | \"GET /internal/apm/services/{serviceName}/transactions/traces/samples\" | \"GET /internal/apm/services/{serviceName}/transaction/charts/breakdown\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/error_rate\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/coldstart_rate\" | \"GET /internal/apm/services/{serviceName}/transactions/charts/coldstart_rate_by_transaction_name\" | \"GET /internal/apm/alerts/chart_preview/transaction_error_rate\" | \"GET /internal/apm/alerts/chart_preview/transaction_duration\" | \"GET /internal/apm/alerts/chart_preview/transaction_error_count\" | \"GET /api/apm/settings/agent-configuration\" | \"GET /api/apm/settings/agent-configuration/view\" | \"DELETE /api/apm/settings/agent-configuration\" | \"PUT /api/apm/settings/agent-configuration\" | \"POST /api/apm/settings/agent-configuration/search\" | \"GET /api/apm/settings/agent-configuration/environments\" | \"GET /api/apm/settings/agent-configuration/agent_name\" | \"GET /internal/apm/settings/anomaly-detection/jobs\" | \"POST /internal/apm/settings/anomaly-detection/jobs\" | \"GET /internal/apm/settings/anomaly-detection/environments\" | \"POST /internal/apm/settings/anomaly-detection/update_to_v3\" | \"GET /internal/apm/settings/apm-index-settings\" | \"GET /internal/apm/settings/apm-indices\" | \"POST /internal/apm/settings/apm-indices/save\" | \"GET /internal/apm/settings/custom_links/transaction\" | \"GET /internal/apm/settings/custom_links\" | \"POST /internal/apm/settings/custom_links\" | \"PUT /internal/apm/settings/custom_links/{id}\" | \"DELETE /internal/apm/settings/custom_links/{id}\" | \"GET /api/apm/sourcemaps\" | \"POST /api/apm/sourcemaps\" | \"DELETE /api/apm/sourcemaps/{id}\" | \"GET /internal/apm/fleet/has_apm_policies\" | \"GET /internal/apm/fleet/agents\" | \"POST /api/apm/fleet/apm_server_schema\" | \"GET /internal/apm/fleet/apm_server_schema/unsupported\" | \"GET /internal/apm/fleet/migration_check\" | \"POST /internal/apm/fleet/cloud_apm_package_policy\" | \"GET /internal/apm/backends/top_backends\" | \"GET /internal/apm/backends/upstream_services\" | \"GET /internal/apm/backends/metadata\" | \"GET /internal/apm/backends/charts/latency\" | \"GET /internal/apm/backends/charts/throughput\" | \"GET /internal/apm/backends/charts/error_rate\" | \"POST /internal/apm/correlations/p_values\" | \"GET /internal/apm/correlations/field_candidates\" | \"POST /internal/apm/correlations/field_stats\" | \"GET /internal/apm/correlations/field_value_stats\" | \"POST /internal/apm/correlations/field_value_pairs\" | \"POST /internal/apm/correlations/significant_correlations\" | \"GET /internal/apm/fallback_to_transactions\" | \"GET /internal/apm/has_data\" | \"GET /internal/apm/event_metadata/{processorEvent}/{id}\" | \"GET /internal/apm/agent_keys\" | \"GET /internal/apm/agent_keys/privileges\" | \"POST /internal/apm/api_key/invalidate\" | \"POST /api/apm/agent_keys\"" ], "path": "x-pack/plugins/apm/server/routes/apm_routes/get_global_apm_server_route_repository.ts", "deprecated": false, @@ -1015,7 +1015,9 @@ }, ", { latencyCorrelations: ", "LatencyCorrelation", - "[]; ccsWarning: boolean; totalDocCount: number; }, ", + "[]; ccsWarning: boolean; totalDocCount: number; fallbackResult?: ", + "LatencyCorrelation", + " | undefined; }, ", "APMRouteCreateOptions", ">; \"POST /internal/apm/correlations/field_value_pairs\": ", "ServerRoute", @@ -1291,7 +1293,9 @@ }, ", { failedTransactionsCorrelations: ", "FailedTransactionsCorrelation", - "[]; ccsWarning: boolean; }, ", + "[]; ccsWarning: boolean; fallbackResult?: ", + "FailedTransactionsCorrelation", + " | undefined; }, ", "APMRouteCreateOptions", ">; \"GET /internal/apm/backends/charts/error_rate\": ", "ServerRoute", @@ -3295,50 +3299,6 @@ }, ", { serviceInfrastructure: { containerIds: string[]; hostNames: string[]; }; }, ", "APMRouteCreateOptions", - ">; \"GET /internal/apm/services/{serviceName}/alerts\": ", - "ServerRoute", - "<\"GET /internal/apm/services/{serviceName}/alerts\", ", - "TypeC", - "<{ path: ", - "TypeC", - "<{ serviceName: ", - "StringC", - "; }>; query: ", - "IntersectionC", - "<[", - "TypeC", - "<{ start: ", - "Type", - "; end: ", - "Type", - "; }>, ", - "TypeC", - "<{ environment: ", - "UnionC", - "<[", - "LiteralC", - "<\"ENVIRONMENT_NOT_DEFINED\">, ", - "LiteralC", - "<\"ENVIRONMENT_ALL\">, ", - "BrandC", - "<", - "StringC", - ", ", - "NonEmptyStringBrand", - ">]>; }>, ", - "TypeC", - "<{ transactionType: ", - "StringC", - "; }>]>; }>, ", - { - "pluginId": "apm", - "scope": "server", - "docId": "kibApmPluginApi", - "section": "def-server.APMRouteHandlerResources", - "text": "APMRouteHandlerResources" - }, - ", { alerts: Partial>[]; }, ", - "APMRouteCreateOptions", ">; \"GET /internal/apm/services/{serviceName}/profiling/statistics\": ", "ServerRoute", "<\"GET /internal/apm/services/{serviceName}/profiling/statistics\", ", diff --git a/api_docs/apm.mdx b/api_docs/apm.mdx index fc5090edb7bab..57311e701350e 100644 --- a/api_docs/apm.mdx +++ b/api_docs/apm.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/apm title: "apm" image: https://source.unsplash.com/400x175/?github summary: API docs for the apm plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'apm'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/banners.mdx b/api_docs/banners.mdx index d85129497e554..d264c99384935 100644 --- a/api_docs/banners.mdx +++ b/api_docs/banners.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/banners title: "banners" image: https://source.unsplash.com/400x175/?github summary: API docs for the banners plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'banners'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/bfetch.mdx b/api_docs/bfetch.mdx index 0e57f3dc2e63b..4e9f494e826d3 100644 --- a/api_docs/bfetch.mdx +++ b/api_docs/bfetch.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/bfetch title: "bfetch" image: https://source.unsplash.com/400x175/?github summary: API docs for the bfetch plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'bfetch'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/canvas.mdx b/api_docs/canvas.mdx index 174fea8e354c2..b4df6fb8b2f40 100644 --- a/api_docs/canvas.mdx +++ b/api_docs/canvas.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/canvas title: "canvas" image: https://source.unsplash.com/400x175/?github summary: API docs for the canvas plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'canvas'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/cases.devdocs.json b/api_docs/cases.devdocs.json index 115538ecfe5dd..853012159e20d 100644 --- a/api_docs/cases.devdocs.json +++ b/api_docs/cases.devdocs.json @@ -716,11 +716,7 @@ "label": "hooks", "description": [], "signature": [ - "{ getUseCasesAddToNewCaseFlyout: (props: ", - "CreateCaseFlyoutProps", - ") => { open: () => void; close: () => void; }; getUseCasesAddToExistingCaseModal: (props: ", - "AllCasesSelectorModalProps", - ") => { open: () => void; close: () => void; }; }" + "{ getUseCasesAddToNewCaseFlyout: (props: AddToNewCaseFlyoutProps) => { open: () => void; close: () => void; }; getUseCasesAddToExistingCaseModal: (props: AddToExistingFlyoutProps) => { open: () => void; close: () => void; }; }" ], "path": "x-pack/plugins/cases/public/types.ts", "deprecated": false @@ -1270,7 +1266,7 @@ "label": "CasesFeatures", "description": [], "signature": [ - "{ alerts?: { sync: boolean; } | undefined; metrics?: ", + "{ alerts?: { sync?: boolean | undefined; enabled?: boolean | undefined; } | undefined; metrics?: ", "CaseMetricsFeature", "[] | undefined; }" ], diff --git a/api_docs/cases.mdx b/api_docs/cases.mdx index b88fd72852246..8d6c10f212118 100644 --- a/api_docs/cases.mdx +++ b/api_docs/cases.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/cases title: "cases" image: https://source.unsplash.com/400x175/?github summary: API docs for the cases plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cases'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/charts.mdx b/api_docs/charts.mdx index e03cb4690762f..9b5f5c8a161ce 100644 --- a/api_docs/charts.mdx +++ b/api_docs/charts.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/charts title: "charts" image: https://source.unsplash.com/400x175/?github summary: API docs for the charts plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'charts'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/cloud.mdx b/api_docs/cloud.mdx index c56a338c3089c..7c59d31fb1ed5 100644 --- a/api_docs/cloud.mdx +++ b/api_docs/cloud.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/cloud title: "cloud" image: https://source.unsplash.com/400x175/?github summary: API docs for the cloud plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cloud'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/cloud_security_posture.devdocs.json b/api_docs/cloud_security_posture.devdocs.json index 5f991959da895..ceb52e2ee8fbf 100644 --- a/api_docs/cloud_security_posture.devdocs.json +++ b/api_docs/cloud_security_posture.devdocs.json @@ -40,7 +40,114 @@ "interfaces": [], "enums": [], "misc": [], - "objects": [], + "objects": [ + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType", + "type": "Object", + "tags": [], + "label": "cspRuleTemplateAssetType", + "description": [], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.name", + "type": "string", + "tags": [], + "label": "name", + "description": [], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false + }, + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.hidden", + "type": "boolean", + "tags": [], + "label": "hidden", + "description": [], + "signature": [ + "false" + ], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false + }, + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.management", + "type": "Object", + "tags": [], + "label": "management", + "description": [], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.management.importableAndExportable", + "type": "boolean", + "tags": [], + "label": "importableAndExportable", + "description": [], + "signature": [ + "true" + ], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false + }, + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.management.visibleInManagement", + "type": "boolean", + "tags": [], + "label": "visibleInManagement", + "description": [], + "signature": [ + "true" + ], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.namespaceType", + "type": "string", + "tags": [], + "label": "namespaceType", + "description": [], + "signature": [ + "\"agnostic\"" + ], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false + }, + { + "parentPluginId": "cloudSecurityPosture", + "id": "def-server.cspRuleTemplateAssetType.mappings", + "type": "Object", + "tags": [], + "label": "mappings", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "server", + "docId": "kibCoreSavedObjectsPluginApi", + "section": "def-server.SavedObjectsTypeMappingDefinition", + "text": "SavedObjectsTypeMappingDefinition" + } + ], + "path": "x-pack/plugins/cloud_security_posture/server/saved_objects/csp_rule_template.ts", + "deprecated": false + } + ], + "initialIsOpen": false + } + ], "setup": { "parentPluginId": "cloudSecurityPosture", "id": "def-server.CspServerPluginSetup", diff --git a/api_docs/cloud_security_posture.mdx b/api_docs/cloud_security_posture.mdx index 42098477a9bce..b51d2afeb767b 100644 --- a/api_docs/cloud_security_posture.mdx +++ b/api_docs/cloud_security_posture.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/cloudSecurityPosture title: "cloudSecurityPosture" image: https://source.unsplash.com/400x175/?github summary: API docs for the cloudSecurityPosture plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'cloudSecurityPosture'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Cloud Security Posture](https://github.com/orgs/elastic/teams/cloud-pos | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 6 | 0 | 6 | 0 | +| 14 | 0 | 14 | 0 | ## Client @@ -36,6 +36,9 @@ Contact [Cloud Security Posture](https://github.com/orgs/elastic/teams/cloud-pos ### Start +### Objects + + ## Common ### Consts, variables and types diff --git a/api_docs/console.mdx b/api_docs/console.mdx index 09eaf8b55bea6..38b6093b24747 100644 --- a/api_docs/console.mdx +++ b/api_docs/console.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/console title: "console" image: https://source.unsplash.com/400x175/?github summary: API docs for the console plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'console'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/controls.devdocs.json b/api_docs/controls.devdocs.json index 829bd4e8b7891..65ebe06c60961 100644 --- a/api_docs/controls.devdocs.json +++ b/api_docs/controls.devdocs.json @@ -1946,6 +1946,19 @@ "path": "src/plugins/controls/common/control_group/types.ts", "deprecated": false, "children": [ + { + "parentPluginId": "controls", + "id": "def-public.ControlGroupInput.chainingSystem", + "type": "CompoundType", + "tags": [], + "label": "chainingSystem", + "description": [], + "signature": [ + "\"HIERARCHICAL\" | \"NONE\"" + ], + "path": "src/plugins/controls/common/control_group/types.ts", + "deprecated": false + }, { "parentPluginId": "controls", "id": "def-public.ControlGroupInput.defaultControlWidth", @@ -2531,7 +2544,32 @@ }, "common": { "classes": [], - "functions": [], + "functions": [ + { + "parentPluginId": "controls", + "id": "def-common.getDefaultControlGroupInput", + "type": "Function", + "tags": [], + "label": "getDefaultControlGroupInput", + "description": [], + "signature": [ + "() => Omit<", + { + "pluginId": "controls", + "scope": "common", + "docId": "kibControlsPluginApi", + "section": "def-common.ControlGroupInput", + "text": "ControlGroupInput" + }, + ", \"id\">" + ], + "path": "src/plugins/controls/common/control_group/control_group_constants.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + } + ], "interfaces": [ { "parentPluginId": "controls", @@ -2562,6 +2600,19 @@ "path": "src/plugins/controls/common/control_group/types.ts", "deprecated": false, "children": [ + { + "parentPluginId": "controls", + "id": "def-common.ControlGroupInput.chainingSystem", + "type": "CompoundType", + "tags": [], + "label": "chainingSystem", + "description": [], + "signature": [ + "\"HIERARCHICAL\" | \"NONE\"" + ], + "path": "src/plugins/controls/common/control_group/types.ts", + "deprecated": false + }, { "parentPluginId": "controls", "id": "def-common.ControlGroupInput.defaultControlWidth", diff --git a/api_docs/controls.mdx b/api_docs/controls.mdx index 4ab5c0d8de442..ab0bdaa1562c8 100644 --- a/api_docs/controls.mdx +++ b/api_docs/controls.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/controls title: "controls" image: https://source.unsplash.com/400x175/?github summary: API docs for the controls plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'controls'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-prese | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 130 | 0 | 124 | 4 | +| 133 | 0 | 127 | 4 | ## Client @@ -36,6 +36,9 @@ Contact [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-prese ## Common +### Functions + + ### Interfaces diff --git a/api_docs/core.devdocs.json b/api_docs/core.devdocs.json index ef00b54e3d2dc..d3e55ebe7e392 100644 --- a/api_docs/core.devdocs.json +++ b/api_docs/core.devdocs.json @@ -965,6 +965,7 @@ ], "path": "src/core/public/index.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "visTypeVega", @@ -1322,6 +1323,7 @@ ], "path": "src/core/public/index.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "monitoring", @@ -1334,6 +1336,10 @@ { "plugin": "visTypeVega", "path": "src/plugins/vis_types/vega/public/plugin.ts" + }, + { + "plugin": "visTypeVega", + "path": "src/plugins/vis_types/vega/target/types/public/data_model/search_api.d.ts" } ] } @@ -5997,7 +6003,7 @@ "\nThe outcome for a successful `resolve` call is one of the following values:\n\n * `'exactMatch'` -- One document exactly matched the given ID.\n * `'aliasMatch'` -- One document with a legacy URL alias matched the given ID; in this case the `saved_object.id` field is different\n than the given ID.\n * `'conflict'` -- Two documents matched the given ID, one was an exact match and another with a legacy URL alias; in this case the\n `saved_object` object is the exact match, and the `saved_object.id` field is the same as the given ID." ], "signature": [ - "\"conflict\" | \"aliasMatch\" | \"exactMatch\"" + "\"exactMatch\" | \"aliasMatch\" | \"conflict\"" ], "path": "src/core/server/saved_objects/service/saved_objects_client.ts", "deprecated": false @@ -6009,13 +6015,28 @@ "tags": [], "label": "alias_target_id", "description": [ - "\nThe ID of the object that the legacy URL alias points to. This is only defined when the outcome is `'aliasMatch'` or `'conflict'`." + "\nThe ID of the object that the legacy URL alias points to.\n\n**Note:** this field is *only* included when an alias was found (in other words, when the outcome is `'aliasMatch'` or `'conflict'`)." ], "signature": [ "string | undefined" ], "path": "src/core/server/saved_objects/service/saved_objects_client.ts", "deprecated": false + }, + { + "parentPluginId": "core", + "id": "def-public.SavedObjectsResolveResponse.alias_purpose", + "type": "CompoundType", + "tags": [], + "label": "alias_purpose", + "description": [ + "\nThe reason this alias was created.\n\nCurrently this is used to determine whether or not a toast should be shown when a user is redirected from a legacy URL; if the alias\nwas created because of saved object conversion, then we will display a toast telling the user that the object has a new URL.\n\n**Note:** this field is *only* included when an alias was found (in other words, when the outcome is `'aliasMatch'` or `'conflict'`)." + ], + "signature": [ + "\"savedObjectConversion\" | \"savedObjectImport\" | undefined" + ], + "path": "src/core/server/saved_objects/service/saved_objects_client.ts", + "deprecated": false } ], "initialIsOpen": false @@ -7564,6 +7585,18 @@ "path": "src/core/server/elasticsearch/elasticsearch_config.ts", "deprecated": false }, + { + "parentPluginId": "core", + "id": "def-server.ElasticsearchConfig.maxSockets", + "type": "number", + "tags": [], + "label": "maxSockets", + "description": [ + "\nThe maximum number of sockets that can be used for communications with elasticsearch." + ], + "path": "src/core/server/elasticsearch/elasticsearch_config.ts", + "deprecated": false + }, { "parentPluginId": "core", "id": "def-server.ElasticsearchConfig.compression", @@ -7786,7 +7819,7 @@ "label": "rawConfig", "description": [], "signature": [ - "Readonly<{ username?: string | undefined; password?: string | undefined; serviceAccountToken?: string | undefined; } & { ssl: Readonly<{ key?: string | undefined; certificateAuthorities?: string | string[] | undefined; certificate?: string | undefined; keyPassphrase?: string | undefined; } & { verificationMode: \"none\" | \"full\" | \"certificate\"; keystore: Readonly<{ path?: string | undefined; password?: string | undefined; } & {}>; truststore: Readonly<{ path?: string | undefined; password?: string | undefined; } & {}>; alwaysPresentCertificate: boolean; }>; healthCheck: Readonly<{} & { delay: moment.Duration; }>; hosts: string | string[]; sniffOnStart: boolean; sniffInterval: false | moment.Duration; sniffOnConnectionFault: boolean; compression: boolean; requestHeadersWhitelist: string | string[]; customHeaders: Record; shardTimeout: moment.Duration; requestTimeout: moment.Duration; pingTimeout: moment.Duration; logQueries: boolean; apiVersion: string; ignoreVersionMismatch: boolean; skipStartupConnectionCheck: boolean; }>" + "Readonly<{ username?: string | undefined; password?: string | undefined; serviceAccountToken?: string | undefined; } & { ssl: Readonly<{ key?: string | undefined; certificateAuthorities?: string | string[] | undefined; certificate?: string | undefined; keyPassphrase?: string | undefined; } & { verificationMode: \"none\" | \"full\" | \"certificate\"; keystore: Readonly<{ path?: string | undefined; password?: string | undefined; } & {}>; truststore: Readonly<{ path?: string | undefined; password?: string | undefined; } & {}>; alwaysPresentCertificate: boolean; }>; healthCheck: Readonly<{} & { delay: moment.Duration; }>; hosts: string | string[]; sniffOnStart: boolean; sniffInterval: false | moment.Duration; sniffOnConnectionFault: boolean; maxSockets: number; compression: boolean; requestHeadersWhitelist: string | string[]; customHeaders: Record; shardTimeout: moment.Duration; requestTimeout: moment.Duration; pingTimeout: moment.Duration; logQueries: boolean; apiVersion: string; ignoreVersionMismatch: boolean; skipStartupConnectionCheck: boolean; }>" ], "path": "src/core/server/elasticsearch/elasticsearch_config.ts", "deprecated": false, @@ -8052,7 +8085,17 @@ ], "path": "src/core/server/plugins/types.ts", "deprecated": true, - "references": [], + "removeBy": "8.8.0", + "references": [ + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/target/types/server/plugin.d.ts" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/target/types/server/plugin.d.ts" + } + ], "children": [ { "parentPluginId": "core", @@ -17533,6 +17576,7 @@ ], "path": "src/core/server/metrics/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "monitoring", @@ -23284,7 +23328,7 @@ "section": "def-server.ElasticsearchConfig", "text": "ElasticsearchConfig" }, - ", \"username\" | \"hosts\" | \"password\" | \"sniffOnStart\" | \"sniffInterval\" | \"sniffOnConnectionFault\" | \"compression\" | \"serviceAccountToken\" | \"requestHeadersWhitelist\" | \"customHeaders\"> & { pingTimeout?: number | moment.Duration | undefined; requestTimeout?: number | moment.Duration | undefined; ssl?: Partial; truststore: Readonly<{ path?: string | undefined; password?: string | undefined; } & {}>; alwaysPresentCertificate: boolean; }>, \"key\" | \"verificationMode\" | \"certificate\" | \"keyPassphrase\" | \"alwaysPresentCertificate\"> & { certificateAuthorities?: string[] | undefined; }> | undefined; keepAlive?: boolean | undefined; caFingerprint?: string | undefined; }" + ", \"username\" | \"hosts\" | \"password\" | \"sniffOnStart\" | \"sniffInterval\" | \"sniffOnConnectionFault\" | \"maxSockets\" | \"compression\" | \"serviceAccountToken\" | \"requestHeadersWhitelist\" | \"customHeaders\"> & { pingTimeout?: number | moment.Duration | undefined; requestTimeout?: number | moment.Duration | undefined; ssl?: Partial; truststore: Readonly<{ path?: string | undefined; password?: string | undefined; } & {}>; alwaysPresentCertificate: boolean; }>, \"key\" | \"verificationMode\" | \"certificate\" | \"keyPassphrase\" | \"alwaysPresentCertificate\"> & { certificateAuthorities?: string[] | undefined; }> | undefined; keepAlive?: boolean | undefined; caFingerprint?: string | undefined; }" ], "path": "src/core/server/elasticsearch/client/client_config.ts", "deprecated": false, diff --git a/api_docs/core.mdx b/api_docs/core.mdx index ee8ea3e18f2d0..9c7cd4378271e 100644 --- a/api_docs/core.mdx +++ b/api_docs/core.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/core title: "core" image: https://source.unsplash.com/400x175/?github summary: API docs for the core plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'core'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) for que | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 2370 | 15 | 969 | 33 | +| 2374 | 15 | 969 | 33 | ## Client diff --git a/api_docs/core_application.devdocs.json b/api_docs/core_application.devdocs.json index cf597875b4937..481db4d605e5c 100644 --- a/api_docs/core_application.devdocs.json +++ b/api_docs/core_application.devdocs.json @@ -1371,6 +1371,7 @@ ], "path": "src/core/public/application/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "management", @@ -1384,9 +1385,21 @@ "plugin": "security", "path": "x-pack/plugins/security/public/authentication/logout/logout_app.test.ts" }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/target/types/public/applications/fleet/index.d.ts" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/target/types/public/applications/integrations/index.d.ts" + }, { "plugin": "kibanaOverview", "path": "src/plugins/kibana_overview/public/application.tsx" + }, + { + "plugin": "management", + "path": "src/plugins/management/target/types/public/application.d.ts" } ] }, @@ -1414,6 +1427,7 @@ ], "path": "src/core/public/application/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "visualizations", @@ -1475,9 +1489,41 @@ "plugin": "securitySolution", "path": "x-pack/plugins/security_solution/public/app/index.tsx" }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/render_app.d.ts" + }, { "plugin": "security", "path": "x-pack/plugins/security/public/authentication/logout/logout_app.test.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_page.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/types.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/visualize_app/app.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/visualize_app/index.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/visualize_app/components/visualize_editor_common.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/visualize_app/components/visualize_top_nav.d.ts" } ], "children": [ @@ -1889,6 +1935,7 @@ ], "path": "src/core/public/application/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "securitySolution", diff --git a/api_docs/core_application.mdx b/api_docs/core_application.mdx index 3bd1b91479ddd..dd9fd27275fdb 100644 --- a/api_docs/core_application.mdx +++ b/api_docs/core_application.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/core-application title: "core.application" image: https://source.unsplash.com/400x175/?github summary: API docs for the core.application plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'core.application'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) for que | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 2370 | 15 | 969 | 33 | +| 2374 | 15 | 969 | 33 | ## Client diff --git a/api_docs/core_chrome.devdocs.json b/api_docs/core_chrome.devdocs.json index 2ddd5f2792222..6d9e4df9f856b 100644 --- a/api_docs/core_chrome.devdocs.json +++ b/api_docs/core_chrome.devdocs.json @@ -1866,8 +1866,11 @@ "label": "ChromeBreadcrumb", "description": [], "signature": [ + "React.HTMLAttributes & ", "CommonProps", - " & { text: React.ReactNode; href?: string | undefined; onClick?: React.MouseEventHandler | undefined; truncate?: boolean | undefined; 'aria-current'?: boolean | \"date\" | \"page\" | \"time\" | \"true\" | \"false\" | \"step\" | \"location\" | undefined; }" + " & { href?: string | undefined; onClick?: React.MouseEventHandler | undefined; text: React.ReactNode; truncate?: boolean | undefined; color?: ", + "EuiLinkColor", + " | undefined; 'aria-current'?: boolean | \"date\" | \"page\" | \"time\" | \"true\" | \"false\" | \"step\" | \"location\" | undefined; }" ], "path": "src/core/public/chrome/types.ts", "deprecated": false, diff --git a/api_docs/core_chrome.mdx b/api_docs/core_chrome.mdx index fb42987c5b75e..be217167a8488 100644 --- a/api_docs/core_chrome.mdx +++ b/api_docs/core_chrome.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/core-chrome title: "core.chrome" image: https://source.unsplash.com/400x175/?github summary: API docs for the core.chrome plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'core.chrome'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) for que | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 2370 | 15 | 969 | 33 | +| 2374 | 15 | 969 | 33 | ## Client diff --git a/api_docs/core_http.devdocs.json b/api_docs/core_http.devdocs.json index 13ec591282a57..561de33cab4a3 100644 --- a/api_docs/core_http.devdocs.json +++ b/api_docs/core_http.devdocs.json @@ -1811,6 +1811,7 @@ ], "path": "src/core/public/http/types.ts", "deprecated": true, + "removeBy": "8.8.0\n\nNote to maintainers: when looking at usages, mind that typical use could be inside a `catch` block,\nso TS and code-reference navigation might not highlight them.", "references": [ { "plugin": "ml", @@ -1836,6 +1837,7 @@ ], "path": "src/core/public/http/types.ts", "deprecated": true, + "removeBy": "8.8.0\n\nNote to maintainers: when looking at usages, mind that typical use could be inside a `catch` block,\nso TS and code-reference navigation might not highlight them.", "references": [] }, { diff --git a/api_docs/core_http.mdx b/api_docs/core_http.mdx index 0720129750034..995f67b0810bd 100644 --- a/api_docs/core_http.mdx +++ b/api_docs/core_http.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/core-http title: "core.http" image: https://source.unsplash.com/400x175/?github summary: API docs for the core.http plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'core.http'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) for que | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 2370 | 15 | 969 | 33 | +| 2374 | 15 | 969 | 33 | ## Client diff --git a/api_docs/core_saved_objects.devdocs.json b/api_docs/core_saved_objects.devdocs.json index 27ca257aa9744..e84daeb0b7d4b 100644 --- a/api_docs/core_saved_objects.devdocs.json +++ b/api_docs/core_saved_objects.devdocs.json @@ -1068,7 +1068,7 @@ "\nThe outcome for a successful `resolve` call is one of the following values:\n\n * `'exactMatch'` -- One document exactly matched the given ID.\n * `'aliasMatch'` -- One document with a legacy URL alias matched the given ID; in this case the `saved_object.id` field is different\n than the given ID.\n * `'conflict'` -- Two documents matched the given ID, one was an exact match and another with a legacy URL alias; in this case the\n `saved_object` object is the exact match, and the `saved_object.id` field is the same as the given ID." ], "signature": [ - "\"conflict\" | \"aliasMatch\" | \"exactMatch\"" + "\"exactMatch\" | \"aliasMatch\" | \"conflict\"" ], "path": "src/core/public/saved_objects/types.ts", "deprecated": false @@ -1080,13 +1080,28 @@ "tags": [], "label": "alias_target_id", "description": [ - "\nThe ID of the object that the legacy URL alias points to. This is only defined when the outcome is `'aliasMatch'` or `'conflict'`." + "\nThe ID of the object that the legacy URL alias points to.\n\n**Note:** this field is *only* included when an alias was found (in other words, when the outcome is `'aliasMatch'` or `'conflict'`)." ], "signature": [ "string | undefined" ], "path": "src/core/public/saved_objects/types.ts", "deprecated": false + }, + { + "parentPluginId": "core", + "id": "def-public.ResolvedSimpleSavedObject.alias_purpose", + "type": "CompoundType", + "tags": [], + "label": "alias_purpose", + "description": [ + "\nThe reason this alias was created.\n\nCurrently this is used to determine whether or not a toast should be shown when a user is redirected from a legacy URL; if the alias\nwas created because of saved object conversion, then we will display a toast telling the user that the object has a new URL.\n\n**Note:** this field is *only* included when an alias was found (in other words, when the outcome is `'aliasMatch'` or `'conflict'`)." + ], + "signature": [ + "\"savedObjectConversion\" | \"savedObjectImport\" | undefined" + ], + "path": "src/core/public/saved_objects/types.ts", + "deprecated": false } ], "initialIsOpen": false @@ -8771,7 +8786,7 @@ "\nGiven a saved object type and id, generates the compound id that is stored in the raw document for its legacy URL alias.\n" ], "signature": [ - "(namespace: string, type: string, id: string) => string" + "(namespace: string | undefined, type: string, id: string) => string" ], "path": "src/core/server/saved_objects/serialization/serializer.ts", "deprecated": false, @@ -8786,11 +8801,11 @@ "- The namespace of the saved object" ], "signature": [ - "string" + "string | undefined" ], "path": "src/core/server/saved_objects/serialization/serializer.ts", "deprecated": false, - "isRequired": true + "isRequired": false }, { "parentPluginId": "core", @@ -13465,6 +13480,7 @@ ], "path": "src/core/server/saved_objects/migrations/core/migration_logger.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "lens", @@ -14143,7 +14159,7 @@ "\nThe outcome for a successful `resolve` call is one of the following values:\n\n * `'exactMatch'` -- One document exactly matched the given ID.\n * `'aliasMatch'` -- One document with a legacy URL alias matched the given ID; in this case the `saved_object.id` field is different\n than the given ID.\n * `'conflict'` -- Two documents matched the given ID, one was an exact match and another with a legacy URL alias; in this case the\n `saved_object` object is the exact match, and the `saved_object.id` field is the same as the given ID." ], "signature": [ - "\"conflict\" | \"aliasMatch\" | \"exactMatch\"" + "\"exactMatch\" | \"aliasMatch\" | \"conflict\"" ], "path": "src/core/server/saved_objects/service/saved_objects_client.ts", "deprecated": false @@ -14155,13 +14171,28 @@ "tags": [], "label": "alias_target_id", "description": [ - "\nThe ID of the object that the legacy URL alias points to. This is only defined when the outcome is `'aliasMatch'` or `'conflict'`." + "\nThe ID of the object that the legacy URL alias points to.\n\n**Note:** this field is *only* included when an alias was found (in other words, when the outcome is `'aliasMatch'` or `'conflict'`)." ], "signature": [ "string | undefined" ], "path": "src/core/server/saved_objects/service/saved_objects_client.ts", "deprecated": false + }, + { + "parentPluginId": "core", + "id": "def-server.SavedObjectsResolveResponse.alias_purpose", + "type": "CompoundType", + "tags": [], + "label": "alias_purpose", + "description": [ + "\nThe reason this alias was created.\n\nCurrently this is used to determine whether or not a toast should be shown when a user is redirected from a legacy URL; if the alias\nwas created because of saved object conversion, then we will display a toast telling the user that the object has a new URL.\n\n**Note:** this field is *only* included when an alias was found (in other words, when the outcome is `'aliasMatch'` or `'conflict'`)." + ], + "signature": [ + "\"savedObjectConversion\" | \"savedObjectImport\" | undefined" + ], + "path": "src/core/server/saved_objects/service/saved_objects_client.ts", + "deprecated": false } ], "initialIsOpen": false diff --git a/api_docs/core_saved_objects.mdx b/api_docs/core_saved_objects.mdx index 6e7d0356b0c1e..1fe4aa1869bd5 100644 --- a/api_docs/core_saved_objects.mdx +++ b/api_docs/core_saved_objects.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/core-savedObjects title: "core.savedObjects" image: https://source.unsplash.com/400x175/?github summary: API docs for the core.savedObjects plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'core.savedObjects'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) for que | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 2370 | 15 | 969 | 33 | +| 2374 | 15 | 969 | 33 | ## Client diff --git a/api_docs/custom_integrations.mdx b/api_docs/custom_integrations.mdx index dcf49061e7b41..3eafb18871dcc 100644 --- a/api_docs/custom_integrations.mdx +++ b/api_docs/custom_integrations.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/customIntegrations title: "customIntegrations" image: https://source.unsplash.com/400x175/?github summary: API docs for the customIntegrations plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'customIntegrations'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/dashboard.devdocs.json b/api_docs/dashboard.devdocs.json index 343582e8d5f91..a7a90e41d4b05 100644 --- a/api_docs/dashboard.devdocs.json +++ b/api_docs/dashboard.devdocs.json @@ -1219,7 +1219,7 @@ "label": "controlGroupInput", "description": [], "signature": [ - "DashboardControlGroupInput", + "DashboardContainerControlGroupInput", " | undefined" ], "path": "src/plugins/dashboard/public/types.ts", @@ -1907,12 +1907,12 @@ { "parentPluginId": "dashboard", "id": "def-public.DashboardSavedObject.outcome", - "type": "string", + "type": "CompoundType", "tags": [], "label": "outcome", "description": [], "signature": [ - "string | undefined" + "\"exactMatch\" | \"aliasMatch\" | \"conflict\" | undefined" ], "path": "src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts", "deprecated": false @@ -1930,6 +1930,19 @@ "path": "src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts", "deprecated": false }, + { + "parentPluginId": "dashboard", + "id": "def-public.DashboardSavedObject.aliasPurpose", + "type": "CompoundType", + "tags": [], + "label": "aliasPurpose", + "description": [], + "signature": [ + "\"savedObjectConversion\" | \"savedObjectImport\" | undefined" + ], + "path": "src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts", + "deprecated": false + }, { "parentPluginId": "dashboard", "id": "def-public.DashboardSavedObject.controlGroupInput", @@ -2434,9 +2447,8 @@ "section": "def-common.ControlGroupInput", "text": "ControlGroupInput" }, - ", \"id\">) => Omit<", - "RawControlGroupAttributes", - ", \"id\">" + ", \"id\">) => ", + "RawControlGroupAttributes" ], "path": "src/plugins/dashboard/common/embeddable/dashboard_control_group.ts", "deprecated": false, @@ -2475,14 +2487,20 @@ "label": "getDefaultDashboardControlGroupInput", "description": [], "signature": [ - "() => { controlStyle: ", - "ControlStyle", - "; panels: {}; }" + "() => Omit<", + { + "pluginId": "controls", + "scope": "common", + "docId": "kibControlsPluginApi", + "section": "def-common.ControlGroupInput", + "text": "ControlGroupInput" + }, + ", \"id\">" ], "path": "src/plugins/dashboard/common/embeddable/dashboard_control_group.ts", "deprecated": false, - "children": [], "returnComment": [], + "children": [], "initialIsOpen": false }, { @@ -2668,9 +2686,9 @@ "label": "rawAttributesToControlGroupInput", "description": [], "signature": [ - "(rawControlGroupAttributes: Omit<", + "(rawControlGroupAttributes: ", "RawControlGroupAttributes", - ", \"id\">) => Omit<", + ") => Omit<", { "pluginId": "controls", "scope": "common", @@ -2686,14 +2704,12 @@ { "parentPluginId": "dashboard", "id": "def-common.rawAttributesToControlGroupInput.$1", - "type": "Object", + "type": "CompoundType", "tags": [], "label": "rawControlGroupAttributes", "description": [], "signature": [ - "Omit<", - "RawControlGroupAttributes", - ", \"id\">" + "RawControlGroupAttributes" ], "path": "src/plugins/dashboard/common/embeddable/dashboard_control_group.ts", "deprecated": false, @@ -2747,11 +2763,11 @@ "label": "serializableToRawAttributes", "description": [], "signature": [ - "(controlGroupInput: ", + "(serializable: ", "SerializableRecord", ") => Omit<", "RawControlGroupAttributes", - ", \"id\">" + ", \"type\" | \"id\">" ], "path": "src/plugins/dashboard/common/embeddable/dashboard_control_group.ts", "deprecated": false, @@ -2761,7 +2777,7 @@ "id": "def-common.serializableToRawAttributes.$1", "type": "Object", "tags": [], - "label": "controlGroupInput", + "label": "serializable", "description": [], "signature": [ "SerializableRecord" diff --git a/api_docs/dashboard.mdx b/api_docs/dashboard.mdx index 6e2c76eca30a6..0c083d76e254d 100644 --- a/api_docs/dashboard.mdx +++ b/api_docs/dashboard.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dashboard title: "dashboard" image: https://source.unsplash.com/400x175/?github summary: API docs for the dashboard plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dashboard'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-prese | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 150 | 0 | 148 | 15 | +| 151 | 0 | 149 | 14 | ## Client diff --git a/api_docs/dashboard_enhanced.mdx b/api_docs/dashboard_enhanced.mdx index f50a19c8c27b3..658e0d1100ebf 100644 --- a/api_docs/dashboard_enhanced.mdx +++ b/api_docs/dashboard_enhanced.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dashboardEnhanced title: "dashboardEnhanced" image: https://source.unsplash.com/400x175/?github summary: API docs for the dashboardEnhanced plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dashboardEnhanced'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/data.devdocs.json b/api_docs/data.devdocs.json index 1e655838a7509..6b0ed841f0197 100644 --- a/api_docs/data.devdocs.json +++ b/api_docs/data.devdocs.json @@ -2664,136 +2664,28 @@ "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts" }, { "plugin": "ux", @@ -2804,60 +2696,28 @@ "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "ux", @@ -2879,10 +2739,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, { "plugin": "savedObjects", "path": "src/plugins/saved_objects/public/types.ts" @@ -2915,110 +2771,6 @@ "plugin": "dataViewEditor", "path": "src/plugins/data_view_editor/public/open_editor.tsx" }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" - }, { "plugin": "graph", "path": "x-pack/plugins/graph/public/types/app_state.ts" @@ -3107,70 +2859,6 @@ "plugin": "graph", "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, { "plugin": "uptime", "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" @@ -3219,6 +2907,22 @@ "plugin": "graph", "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" + }, { "plugin": "maps", "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" @@ -3229,171 +2933,275 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/utils/editor_config.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/utils/editor_config.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" + }, + { + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" + }, + { + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_select.tsx" + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts" }, { "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_select.tsx" + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts" }, { "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params.tsx" + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts" }, { "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params.tsx" + "path": "src/plugins/vis_default_editor/public/components/utils/editor_config.ts" }, { "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" + "path": "src/plugins/vis_default_editor/public/components/utils/editor_config.ts" }, { "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_select.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_select.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "dataViews", @@ -3449,76 +3257,32 @@ "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "dataViews", @@ -3714,344 +3478,420 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" - } - ], - "children": [], - "initialIsOpen": false - }, - { - "parentPluginId": "data", - "id": "def-public.IndexPatternsService", - "type": "Class", - "tags": [ - "deprecated" - ], - "label": "IndexPatternsService", - "description": [], - "signature": [ + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPatternsService", - "text": "IndexPatternsService" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, - " extends ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewsService", - "text": "DataViewsService" - } - ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", - "deprecated": true, - "references": [ + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" + }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "maps", - "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "maps", - "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" }, { "plugin": "dataViews", - "path": "src/plugins/data_views/public/index.ts" + "path": "src/plugins/data_views/common/data_views/data_view.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/data_view_field.test.ts" + } + ], + "children": [], + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.IndexPatternsService", + "type": "Class", + "tags": [ + "deprecated" + ], + "label": "IndexPatternsService", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IndexPatternsService", + "text": "IndexPatternsService" + }, + " extends ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewsService", + "text": "DataViewsService" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": true, + "references": [ + { + "plugin": "dataViews", + "path": "src/plugins/data_views/common/index.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/public/index.ts" } ], "children": [], @@ -5093,38 +4933,104 @@ "functions": [ { "parentPluginId": "data", - "id": "def-public.extractReferences", + "id": "def-public.calculateBounds", "type": "Function", "tags": [], - "label": "extractReferences", + "label": "calculateBounds", "description": [], "signature": [ - "(state: ", + "(timeRange: ", { "pluginId": "data", "scope": "common", - "docId": "kibDataSearchPluginApi", - "section": "def-common.SerializedSearchSourceFields", - "text": "SerializedSearchSourceFields" + "docId": "kibDataQueryPluginApi", + "section": "def-common.TimeRange", + "text": "TimeRange" }, - ") => [", + ", options: CalculateBoundsOptions) => ", { "pluginId": "data", "scope": "common", - "docId": "kibDataSearchPluginApi", - "section": "def-common.SerializedSearchSourceFields", - "text": "SerializedSearchSourceFields" - }, - ", ", - "SavedObjectReference", - "[]]" + "docId": "kibDataQueryPluginApi", + "section": "def-common.TimeRangeBounds", + "text": "TimeRangeBounds" + } ], - "path": "src/plugins/data/common/search/search_source/extract_references.ts", + "path": "src/plugins/data/common/query/timefilter/get_time.ts", "deprecated": false, "children": [ { "parentPluginId": "data", - "id": "def-public.extractReferences.$1", + "id": "def-public.calculateBounds.$1", + "type": "Object", + "tags": [], + "label": "timeRange", + "description": [], + "signature": [ + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataQueryPluginApi", + "section": "def-common.TimeRange", + "text": "TimeRange" + } + ], + "path": "src/plugins/data/common/query/timefilter/get_time.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "data", + "id": "def-public.calculateBounds.$2", + "type": "Object", + "tags": [], + "label": "options", + "description": [], + "signature": [ + "CalculateBoundsOptions" + ], + "path": "src/plugins/data/common/query/timefilter/get_time.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.extractReferences", + "type": "Function", + "tags": [], + "label": "extractReferences", + "description": [], + "signature": [ + "(state: ", + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.SerializedSearchSourceFields", + "text": "SerializedSearchSourceFields" + }, + ") => [", + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.SerializedSearchSourceFields", + "text": "SerializedSearchSourceFields" + }, + ", ", + "SavedObjectReference", + "[]]" + ], + "path": "src/plugins/data/common/search/search_source/extract_references.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "data", + "id": "def-public.extractReferences.$1", "type": "Object", "tags": [], "label": "state", @@ -5213,6 +5119,88 @@ "returnComment": [], "initialIsOpen": false }, + { + "parentPluginId": "data", + "id": "def-public.flattenHit", + "type": "Function", + "tags": [], + "label": "flattenHit", + "description": [ + "\nFlattens an individual hit (from an ES response) into an object. This will\ncreate flattened field names, like `user.name`.\n" + ], + "signature": [ + "(hit: Hit, indexPattern: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IndexPattern", + "text": "IndexPattern" + }, + " | undefined, params: TabifyDocsOptions | undefined) => Record" + ], + "path": "src/plugins/data/common/search/tabify/tabify_docs.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "data", + "id": "def-public.flattenHit.$1", + "type": "CompoundType", + "tags": [], + "label": "hit", + "description": [ + "The hit from an ES reponse's hits.hits[]" + ], + "signature": [ + "Hit" + ], + "path": "src/plugins/data/common/search/tabify/tabify_docs.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "data", + "id": "def-public.flattenHit.$2", + "type": "Object", + "tags": [], + "label": "indexPattern", + "description": [ + "The index pattern for the requested index if available." + ], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IndexPattern", + "text": "IndexPattern" + }, + " | undefined" + ], + "path": "src/plugins/data/common/search/tabify/tabify_docs.ts", + "deprecated": false, + "isRequired": false + }, + { + "parentPluginId": "data", + "id": "def-public.flattenHit.$3", + "type": "Object", + "tags": [], + "label": "params", + "description": [ + "Parameters how to flatten the hit" + ], + "signature": [ + "TabifyDocsOptions | undefined" + ], + "path": "src/plugins/data/common/search/tabify/tabify_docs.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "data", "id": "def-public.getEsQueryConfig", @@ -5817,6 +5805,92 @@ ], "returnComment": [], "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.tabifyAggResponse", + "type": "Function", + "tags": [], + "label": "tabifyAggResponse", + "description": [ + "\nSets up the ResponseWriter and kicks off bucket collection." + ], + "signature": [ + "(aggConfigs: ", + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.AggConfigs", + "text": "AggConfigs" + }, + ", esResponse: Record, respOpts: Partial<", + "TabbedResponseWriterOptions", + "> | undefined) => ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.Datatable", + "text": "Datatable" + } + ], + "path": "src/plugins/data/common/search/tabify/tabify.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "data", + "id": "def-public.tabifyAggResponse.$1", + "type": "Object", + "tags": [], + "label": "aggConfigs", + "description": [], + "signature": [ + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.AggConfigs", + "text": "AggConfigs" + } + ], + "path": "src/plugins/data/common/search/tabify/tabify.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "data", + "id": "def-public.tabifyAggResponse.$2", + "type": "Object", + "tags": [], + "label": "esResponse", + "description": [], + "signature": [ + "Record" + ], + "path": "src/plugins/data/common/search/tabify/tabify.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "data", + "id": "def-public.tabifyAggResponse.$3", + "type": "Object", + "tags": [], + "label": "respOpts", + "description": [], + "signature": [ + "Partial<", + "TabbedResponseWriterOptions", + "> | undefined" + ], + "path": "src/plugins/data/common/search/tabify/tabify.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [], + "initialIsOpen": false } ], "interfaces": [ @@ -8325,159 +8399,71 @@ }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/server/utils.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/server/utils.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/server/utils.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/utils.test.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/utils.test.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/fields.mocks.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/fields.mocks.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, + "plugin": "dataViews", + "path": "src/plugins/data_views/common/fields/fields.mocks.ts" + } + ], + "children": [ { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" + "parentPluginId": "data", + "id": "def-public.IFieldType.count", + "type": "number", + "tags": [], + "label": "count", + "description": [], + "signature": [ + "number | undefined" + ], + "path": "src/plugins/data_views/common/fields/types.ts", + "deprecated": false }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/server/utils.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/server/utils.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/server/utils.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/utils.test.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/utils.test.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/fields.mocks.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/fields.mocks.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/fields/fields.mocks.ts" - } - ], - "children": [ - { - "parentPluginId": "data", - "id": "def-public.IFieldType.count", - "type": "number", - "tags": [], - "label": "count", - "description": [], - "signature": [ - "number | undefined" - ], - "path": "src/plugins/data_views/common/fields/types.ts", - "deprecated": false - }, - { - "parentPluginId": "data", - "id": "def-public.IFieldType.esTypes", - "type": "Array", - "tags": [], - "label": "esTypes", - "description": [], - "signature": [ - "string[] | undefined" - ], - "path": "src/plugins/data_views/common/fields/types.ts", - "deprecated": false + "parentPluginId": "data", + "id": "def-public.IFieldType.esTypes", + "type": "Array", + "tags": [], + "label": "esTypes", + "description": [], + "signature": [ + "string[] | undefined" + ], + "path": "src/plugins/data_views/common/fields/types.ts", + "deprecated": false }, { "parentPluginId": "data", @@ -8780,64 +8766,20 @@ "path": "x-pack/plugins/monitoring/public/lib/kuery.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/services/es_index_service.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/services/es_index_service.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/server/routes/api/transforms.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/alerts/components/param_details_form/use_derived_index_pattern.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/server/routes/api/transforms.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/alerts/components/param_details_form/use_derived_index_pattern.d.ts" } ], "children": [ @@ -9599,150 +9541,327 @@ }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields", + "id": "def-public.SavedObject", "type": "Interface", "tags": [], - "label": "SearchSourceFields", - "description": [ - "\nsearch source fields" + "label": "SavedObject", + "description": [], + "signature": [ + "SavedObject", + "" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false, "children": [ { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.type", + "id": "def-public.SavedObject.id", "type": "string", "tags": [], - "label": "type", - "description": [], - "signature": [ - "string | undefined" + "label": "id", + "description": [ + "The ID of this Saved Object, guaranteed to be unique for all objects of the same `type`" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.query", - "type": "Object", + "id": "def-public.SavedObject.type", + "type": "string", "tags": [], - "label": "query", + "label": "type", "description": [ - "\n{@link Query}" - ], - "signature": [ - "Query", - " | undefined" + " The type of Saved Object. Each plugin can define it's own custom Saved Object types." ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.filter", - "type": "CompoundType", + "id": "def-public.SavedObject.version", + "type": "string", "tags": [], - "label": "filter", + "label": "version", "description": [ - "\n{@link Filter}" + "An opaque version number which changes on each successful write operation. Can be used for implementing optimistic concurrency control." ], "signature": [ - "Filter", - " | ", - "Filter", - "[] | (() => ", - "Filter", - " | ", - "Filter", - "[] | undefined) | undefined" + "string | undefined" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.sort", - "type": "CompoundType", + "id": "def-public.SavedObject.updated_at", + "type": "string", "tags": [], - "label": "sort", + "label": "updated_at", "description": [ - "\n{@link EsQuerySortValue}" + "Timestamp of the last time this document had been updated." ], "signature": [ - { - "pluginId": "data", - "scope": "common", - "docId": "kibDataSearchPluginApi", - "section": "def-common.EsQuerySortValue", - "text": "EsQuerySortValue" - }, - " | ", - { - "pluginId": "data", - "scope": "common", - "docId": "kibDataSearchPluginApi", - "section": "def-common.EsQuerySortValue", - "text": "EsQuerySortValue" - }, - "[] | undefined" + "string | undefined" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.highlight", - "type": "Any", + "id": "def-public.SavedObject.error", + "type": "Object", "tags": [], - "label": "highlight", + "label": "error", "description": [], "signature": [ - "any" + "SavedObjectError", + " | undefined" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.highlightAll", - "type": "CompoundType", + "id": "def-public.SavedObject.attributes", + "type": "Uncategorized", "tags": [], - "label": "highlightAll", - "description": [], + "label": "attributes", + "description": [ + "{@inheritdoc SavedObjectAttributes}" + ], "signature": [ - "boolean | undefined" + "T" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.trackTotalHits", - "type": "CompoundType", + "id": "def-public.SavedObject.references", + "type": "Array", "tags": [], - "label": "trackTotalHits", - "description": [], + "label": "references", + "description": [ + "{@inheritdoc SavedObjectReference}" + ], "signature": [ - "number | boolean | undefined" + "SavedObjectReference", + "[]" ], - "path": "src/plugins/data/common/search/search_source/types.ts", + "path": "src/core/types/saved_objects.ts", "deprecated": false }, { "parentPluginId": "data", - "id": "def-public.SearchSourceFields.aggs", - "type": "CompoundType", + "id": "def-public.SavedObject.migrationVersion", + "type": "Object", "tags": [], - "label": "aggs", + "label": "migrationVersion", "description": [ - "\n{@link AggConfigs}" + "{@inheritdoc SavedObjectsMigrationVersion}" ], "signature": [ - "object | ", - { - "pluginId": "data", - "scope": "common", + "SavedObjectsMigrationVersion", + " | undefined" + ], + "path": "src/core/types/saved_objects.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SavedObject.coreMigrationVersion", + "type": "string", + "tags": [], + "label": "coreMigrationVersion", + "description": [ + "A semver value that is used when upgrading objects between Kibana versions." + ], + "signature": [ + "string | undefined" + ], + "path": "src/core/types/saved_objects.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SavedObject.namespaces", + "type": "Array", + "tags": [], + "label": "namespaces", + "description": [ + "\nSpace(s) that this saved object exists in. This attribute is not used for \"global\" saved object types which are registered with\n`namespaceType: 'agnostic'`." + ], + "signature": [ + "string[] | undefined" + ], + "path": "src/core/types/saved_objects.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SavedObject.originId", + "type": "string", + "tags": [], + "label": "originId", + "description": [ + "\nThe ID of the saved object this originated from. This is set if this object's `id` was regenerated; that can happen during migration\nfrom a legacy single-namespace type, or during import. It is only set during migration or create operations. This is used during import\nto ensure that ID regeneration is deterministic, so saved objects will be overwritten if they are imported multiple times into a given\nspace." + ], + "signature": [ + "string | undefined" + ], + "path": "src/core/types/saved_objects.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields", + "type": "Interface", + "tags": [], + "label": "SearchSourceFields", + "description": [ + "\nsearch source fields" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.type", + "type": "string", + "tags": [], + "label": "type", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.query", + "type": "Object", + "tags": [], + "label": "query", + "description": [ + "\n{@link Query}" + ], + "signature": [ + "Query", + " | undefined" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.filter", + "type": "CompoundType", + "tags": [], + "label": "filter", + "description": [ + "\n{@link Filter}" + ], + "signature": [ + "Filter", + " | ", + "Filter", + "[] | (() => ", + "Filter", + " | ", + "Filter", + "[] | undefined) | undefined" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.sort", + "type": "CompoundType", + "tags": [], + "label": "sort", + "description": [ + "\n{@link EsQuerySortValue}" + ], + "signature": [ + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.EsQuerySortValue", + "text": "EsQuerySortValue" + }, + " | ", + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.EsQuerySortValue", + "text": "EsQuerySortValue" + }, + "[] | undefined" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.highlight", + "type": "Any", + "tags": [], + "label": "highlight", + "description": [], + "signature": [ + "any" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.highlightAll", + "type": "CompoundType", + "tags": [], + "label": "highlightAll", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.trackTotalHits", + "type": "CompoundType", + "tags": [], + "label": "trackTotalHits", + "description": [], + "signature": [ + "number | boolean | undefined" + ], + "path": "src/plugins/data/common/search/search_source/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.SearchSourceFields.aggs", + "type": "CompoundType", + "tags": [], + "label": "aggs", + "description": [ + "\n{@link AggConfigs}" + ], + "signature": [ + "object | ", + { + "pluginId": "data", + "scope": "common", "docId": "kibDataSearchPluginApi", "section": "def-common.AggConfigs", "text": "AggConfigs" @@ -10009,6 +10128,19 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "data", + "id": "def-public.FilterStateStore", + "type": "Enum", + "tags": [], + "label": "FilterStateStore", + "description": [ + "\r\n Filter,\r\nAn enum to denote whether a filter is specific to an application's context or whether it should be applied globally." + ], + "path": "node_modules/@types/kbn__es-query/index.d.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "data", "id": "def-public.KBN_FIELD_TYPES", @@ -10247,248 +10379,48 @@ "label": "DataViewsContract", "description": [], "signature": [ - "{ create: (spec: ", + "DataViewsServicePublic" + ], + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.ES_SEARCH_STRATEGY", + "type": "string", + "tags": [], + "label": "ES_SEARCH_STRATEGY", + "description": [], + "signature": [ + "\"es\"" + ], + "path": "src/plugins/data/common/search/strategies/es_search/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.EsaggsExpressionFunctionDefinition", + "type": "Type", + "tags": [], + "label": "EsaggsExpressionFunctionDefinition", + "description": [], + "signature": [ { - "pluginId": "dataViews", + "pluginId": "expressions", "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionFunctionDefinition", + "text": "ExpressionFunctionDefinition" }, - ", skipFetchFields?: boolean) => Promise<", + "<\"esaggs\", Input, Arguments, Output, ", { - "pluginId": "dataViews", + "pluginId": "expressions", "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; delete: (indexPatternId: string) => Promise<{}>; find: (search: string, size?: number) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - "[]>; get: (id: string) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; getCanSave: () => Promise; ensureDefaultDataView: ", - "EnsureDefaultDataView", - "; getIds: (refresh?: boolean) => Promise; getTitles: (refresh?: boolean) => Promise; getIdsWithTitle: (refresh?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewListItem", - "text": "DataViewListItem" - }, - "[]>; clearCache: (id?: string | undefined) => void; getCache: () => Promise<", - "SavedObject", - "<", - "IndexPatternSavedObjectAttrs", - ">[] | null | undefined>; getDefault: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getDefaultId: () => Promise; setDefault: (id: string | null, force?: boolean) => Promise; hasUserDataView: () => Promise; getFieldsForWildcard: (options: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - ") => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; getFieldsForIndexPattern: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", options?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - " | undefined) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; refreshFields: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ") => Promise; fieldArrayToMap: (fields: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[], fieldAttrs?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewFieldMap", - "text": "DataViewFieldMap" - }, - "; savedObjectToSpec: (savedObject: ", - "SavedObject", - "<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewAttributes", - "text": "DataViewAttributes" - }, - ">) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - "; createAndSave: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", override?: boolean, skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; createSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", override?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; updateSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", saveAttempts?: number, ignoreErrors?: boolean) => Promise; getDefaultDataView: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getCanSaveSync: () => boolean; }" - ], - "path": "src/plugins/data_views/public/types.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "data", - "id": "def-public.ES_SEARCH_STRATEGY", - "type": "string", - "tags": [], - "label": "ES_SEARCH_STRATEGY", - "description": [], - "signature": [ - "\"es\"" - ], - "path": "src/plugins/data/common/search/strategies/es_search/types.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "data", - "id": "def-public.EsaggsExpressionFunctionDefinition", - "type": "Type", - "tags": [], - "label": "EsaggsExpressionFunctionDefinition", - "description": [], - "signature": [ - { - "pluginId": "expressions", - "scope": "common", - "docId": "kibExpressionsPluginApi", - "section": "def-common.ExpressionFunctionDefinition", - "text": "ExpressionFunctionDefinition" - }, - "<\"esaggs\", Input, Arguments, Output, ", - { - "pluginId": "expressions", - "scope": "common", - "docId": "kibExpressionsPluginApi", - "section": "def-common.ExecutionContext", - "text": "ExecutionContext" + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExecutionContext", + "text": "ExecutionContext" }, "<", { @@ -10777,6 +10709,14 @@ "deprecated": true, "removeBy": "8.1", "references": [ + { + "plugin": "discover", + "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + }, { "plugin": "dashboard", "path": "src/plugins/dashboard/public/application/lib/filter_utils.ts" @@ -10894,12 +10834,12 @@ "path": "src/plugins/discover/public/application/context/services/context_state.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" }, { "plugin": "maps", @@ -10911,24 +10851,52 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "data", - "id": "def-public.IAggConfig", - "type": "Type", - "tags": [ - "name", - "description" - ], - "label": "IAggConfig", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-public.IAggConfig", + "type": "Type", + "tags": [ + "name", + "description" + ], + "label": "IAggConfig", "description": [], "signature": [ { @@ -11087,14 +11055,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" @@ -11106,34 +11066,6 @@ { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" } ], "initialIsOpen": false @@ -11400,38 +11332,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/public/lazy_load_bundle/index.ts" @@ -11448,65 +11348,29 @@ "plugin": "graph", "path": "x-pack/plugins/graph/public/application.tsx" }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" } ], "initialIsOpen": false @@ -11867,18 +11731,6 @@ "deprecated": true, "removeBy": "8.1", "references": [ - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/types.ts" @@ -11918,6 +11770,14 @@ { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/target/types/server/search/session/types.d.ts" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/target/types/server/search/session/types.d.ts" } ], "initialIsOpen": false @@ -13782,14 +13642,6 @@ { "plugin": "graph", "path": "x-pack/plugins/graph/public/components/search_bar.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" } ], "children": [ @@ -13948,16 +13800,7 @@ "path": "src/plugins/data/public/deprecated.ts", "deprecated": true, "removeBy": "8.1", - "references": [ - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - } - ], + "references": [], "children": [ { "parentPluginId": "data", @@ -15753,580 +15596,108 @@ "\ndata views service\n{@link DataViewsContract}" ], "signature": [ - "{ create: (spec: ", + "DataViewsServicePublic" + ], + "path": "src/plugins/data/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.DataPublicPluginStart.datatableUtilities", + "type": "Object", + "tags": [], + "label": "datatableUtilities", + "description": [ + "\nDatatable type utility functions." + ], + "signature": [ { - "pluginId": "dataViews", + "pluginId": "data", "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" + "docId": "kibDataPluginApi", + "section": "def-common.DatatableUtilitiesService", + "text": "DatatableUtilitiesService" + } + ], + "path": "src/plugins/data/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-public.DataPublicPluginStart.indexPatterns", + "type": "Object", + "tags": [ + "deprecated" + ], + "label": "indexPatterns", + "description": [ + "\nindex patterns service\n{@link DataViewsContract}" + ], + "signature": [ + "DataViewsServicePublic" + ], + "path": "src/plugins/data/public/types.ts", + "deprecated": true, + "references": [ + { + "plugin": "discover", + "path": "src/plugins/discover/public/plugin.tsx" }, - ", skipFetchFields?: boolean) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/kibana_services.ts" }, - ">; delete: (indexPatternId: string) => Promise<{}>; find: (search: string, size?: number) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "fileUpload", + "path": "x-pack/plugins/file_upload/public/kibana_services.ts" }, - "[]>; get: (id: string) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/pages/link_to/redirect_to_node_logs.tsx" }, - ">; getCanSave: () => Promise; ensureDefaultDataView: ", - "EnsureDefaultDataView", - "; getIds: (refresh?: boolean) => Promise; getTitles: (refresh?: boolean) => Promise; getIdsWithTitle: (refresh?: boolean) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewListItem", - "text": "DataViewListItem" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/alerting/log_threshold/components/expression_editor/editor.tsx" }, - "[]>; clearCache: (id?: string | undefined) => void; getCache: () => Promise<", - "SavedObject", - "<", - "IndexPatternSavedObjectAttrs", - ">[] | null | undefined>; getDefault: () => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/components/log_stream/log_stream.tsx" }, - " | null>; getDefaultId: () => Promise; setDefault: (id: string | null, force?: boolean) => Promise; hasUserDataView: () => Promise; getFieldsForWildcard: (options: ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/components/log_stream/log_stream.tsx" }, - ") => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/utils/logs_overview_fetchers.ts" }, - "[]>; getFieldsForIndexPattern: (indexPattern: ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/hooks/use_kibana_index_patterns.ts" }, - " | ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" + "plugin": "infra", + "path": "x-pack/plugins/infra/public/pages/logs/page_providers.tsx" }, - ", options?: ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/plugin.ts" }, - " | undefined) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx" }, - "[]>; refreshFields: (indexPattern: ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx" }, - ") => Promise; fieldArrayToMap: (fields: ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" + "plugin": "securitySolution", + "path": "x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/store/middleware.ts" }, - "[], fieldAttrs?: ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewFieldMap", - "text": "DataViewFieldMap" - }, - "; savedObjectToSpec: (savedObject: ", - "SavedObject", - "<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewAttributes", - "text": "DataViewAttributes" - }, - ">) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - "; createAndSave: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", override?: boolean, skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; createSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", override?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; updateSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", saveAttempts?: number, ignoreErrors?: boolean) => Promise; getDefaultDataView: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getCanSaveSync: () => boolean; }" - ], - "path": "src/plugins/data/public/types.ts", - "deprecated": false - }, - { - "parentPluginId": "data", - "id": "def-public.DataPublicPluginStart.datatableUtilities", - "type": "Object", - "tags": [], - "label": "datatableUtilities", - "description": [ - "\nDatatable type utility functions." - ], - "signature": [ - { - "pluginId": "data", - "scope": "common", - "docId": "kibDataPluginApi", - "section": "def-common.DatatableUtilitiesService", - "text": "DatatableUtilitiesService" - } - ], - "path": "src/plugins/data/public/types.ts", - "deprecated": false - }, - { - "parentPluginId": "data", - "id": "def-public.DataPublicPluginStart.indexPatterns", - "type": "Object", - "tags": [ - "deprecated" - ], - "label": "indexPatterns", - "description": [ - "\nindex patterns service\n{@link DataViewsContract}" - ], - "signature": [ - "{ create: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; delete: (indexPatternId: string) => Promise<{}>; find: (search: string, size?: number) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - "[]>; get: (id: string) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; getCanSave: () => Promise; ensureDefaultDataView: ", - "EnsureDefaultDataView", - "; getIds: (refresh?: boolean) => Promise; getTitles: (refresh?: boolean) => Promise; getIdsWithTitle: (refresh?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewListItem", - "text": "DataViewListItem" - }, - "[]>; clearCache: (id?: string | undefined) => void; getCache: () => Promise<", - "SavedObject", - "<", - "IndexPatternSavedObjectAttrs", - ">[] | null | undefined>; getDefault: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getDefaultId: () => Promise; setDefault: (id: string | null, force?: boolean) => Promise; hasUserDataView: () => Promise; getFieldsForWildcard: (options: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - ") => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; getFieldsForIndexPattern: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", options?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - " | undefined) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; refreshFields: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ") => Promise; fieldArrayToMap: (fields: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[], fieldAttrs?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewFieldMap", - "text": "DataViewFieldMap" - }, - "; savedObjectToSpec: (savedObject: ", - "SavedObject", - "<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewAttributes", - "text": "DataViewAttributes" - }, - ">) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - "; createAndSave: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", override?: boolean, skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; createSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", override?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; updateSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", saveAttempts?: number, ignoreErrors?: boolean) => Promise; getDefaultDataView: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getCanSaveSync: () => boolean; }" - ], - "path": "src/plugins/data/public/types.ts", - "deprecated": true, - "references": [ - { - "plugin": "discover", - "path": "src/plugins/discover/public/build_services.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/plugin.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/plugin.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/plugin.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/indexpattern.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/plugin.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/plugin.ts" - }, - { - "plugin": "maps", - "path": "x-pack/plugins/maps/public/kibana_services.ts" - }, - { - "plugin": "fileUpload", - "path": "x-pack/plugins/file_upload/public/kibana_services.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/file_data_visualizer/file_data_visualizer.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/index_data_visualizer.tsx" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/alerting/log_threshold/components/expression_editor/editor.tsx" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/components/log_stream/log_stream.tsx" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/components/log_stream/log_stream.tsx" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/utils/logs_overview_fetchers.ts" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/pages/link_to/redirect_to_node_logs.tsx" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/hooks/use_kibana_index_patterns.ts" - }, - { - "plugin": "infra", - "path": "x-pack/plugins/infra/public/pages/logs/page_providers.tsx" - }, - { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/plugin.ts" - }, - { - "plugin": "monitoring", - "path": "x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx" - }, - { - "plugin": "monitoring", - "path": "x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx" - }, - { - "plugin": "securitySolution", - "path": "x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/store/middleware.ts" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" }, { "plugin": "stackAlerts", @@ -16344,34 +15715,6 @@ "plugin": "stackAlerts", "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_create/step_create_form.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_details/step_details_form.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/use_search_items.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/transform_management/components/action_clone/use_clone_action.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/transform_management/components/action_discover/use_action_discover.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/transform_management/components/edit_transform_flyout/edit_transform_flyout_form.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/transform_management/components/action_edit/use_edit_action.tsx" - }, { "plugin": "uptime", "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" @@ -16388,66 +15731,6 @@ "plugin": "inputControlVis", "path": "src/plugins/input_control_vis/public/components/editor/controls_tab.tsx" }, - { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/lib/fetch_fields.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/query_bar_wrapper.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotation_row.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/timeseries_visualization.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" - }, - { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/data_model/search_api.ts" - }, - { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" - }, - { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/data_model/search_api.test.ts" - }, - { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/data_model/search_api.test.ts" - }, - { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/data_model/search_api.test.ts" - }, { "plugin": "infra", "path": "x-pack/plugins/infra/public/utils/logs_overview_fetches.test.ts" @@ -16463,10 +15746,6 @@ { "plugin": "savedObjects", "path": "src/plugins/saved_objects/public/saved_object/saved_object.test.ts" - }, - { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/vega_view/vega_map_view/view.test.ts" } ] }, @@ -16558,6 +15837,18 @@ "plugin": "visTypeVislib", "path": "src/plugins/vis_types/vislib/public/plugin.ts" }, + { + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" + }, + { + "plugin": "expressionPartitionVis", + "path": "src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts" + }, + { + "plugin": "expressionPartitionVis", + "path": "src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts" + }, { "plugin": "expressionPartitionVis", "path": "src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts" @@ -18538,158 +17829,50 @@ "signature": [ { "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" - }, - " extends ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - } - ], - "path": "src/plugins/data_views/common/data_views/data_view.ts", - "deprecated": true, - "references": [ - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IndexPattern", + "text": "IndexPattern" }, + " extends ", { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + } + ], + "path": "src/plugins/data_views/common/data_views/data_view.ts", + "deprecated": true, + "references": [ { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts" }, { "plugin": "ux", @@ -18700,60 +17883,28 @@ "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "ux", @@ -18775,10 +17926,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, { "plugin": "savedObjects", "path": "src/plugins/saved_objects/public/types.ts" @@ -18812,344 +17959,324 @@ "path": "src/plugins/data_view_editor/public/open_editor.tsx" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/types/app_state.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/types/app_state.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/persistence.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/persistence.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/types/app_state.ts" + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/types/app_state.ts" + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/persistence.ts" + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/persistence.ts" + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "visDefaultEditor", @@ -19204,92 +18331,64 @@ "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "dataViews", @@ -19345,76 +18444,32 @@ "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "dataViews", @@ -19608,6 +18663,122 @@ "plugin": "maps", "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" + }, { "plugin": "maps", "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" @@ -19620,6 +18791,98 @@ "plugin": "maps", "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" + }, { "plugin": "visDefaultEditor", "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" @@ -19689,68 +18952,44 @@ "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" - }, - { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" - }, - { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" - }, - { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" }, { "plugin": "dataViews", @@ -20137,54 +19376,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" @@ -20193,69 +19384,9 @@ "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" - }, { "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" } ], "children": [], @@ -20294,54 +19425,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" @@ -20350,69 +19433,9 @@ "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" - }, { "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" } ], "children": [], @@ -20889,127 +19912,39 @@ }, { "plugin": "dataViews", - "path": "src/plugins/data_views/common/types.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/types.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/types.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/types.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/index.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.ts" - }, - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.ts" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" + "path": "src/plugins/data_views/common/types.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/types.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/types.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/types.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.ts" }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "dataViews", @@ -21516,6 +20451,20 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "data", + "id": "def-server.DEFAULT_QUERY_LANGUAGE", + "type": "string", + "tags": [], + "label": "DEFAULT_QUERY_LANGUAGE", + "description": [], + "signature": [ + "\"kuery\"" + ], + "path": "src/plugins/data/common/constants.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "data", "id": "def-server.ES_SEARCH_STRATEGY", @@ -21571,6 +20520,14 @@ "deprecated": true, "removeBy": "8.1", "references": [ + { + "plugin": "discover", + "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + }, { "plugin": "dashboard", "path": "src/plugins/dashboard/public/application/lib/filter_utils.ts" @@ -21688,12 +20645,12 @@ "path": "src/plugins/discover/public/application/context/services/context_state.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" }, { "plugin": "maps", @@ -21705,11 +20662,39 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" } ], "initialIsOpen": false @@ -21764,14 +20749,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" @@ -21783,34 +20760,6 @@ { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" } ], "initialIsOpen": false @@ -21848,18 +20797,6 @@ "deprecated": true, "removeBy": "8.1", "references": [ - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/types.ts" @@ -21899,6 +20836,14 @@ { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/target/types/server/search/session/types.d.ts" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/target/types/server/search/session/types.d.ts" } ], "initialIsOpen": false @@ -23796,6 +22741,50 @@ ], "returnComment": [] }, + { + "parentPluginId": "data", + "id": "def-common.DatatableUtilitiesService.getTotalCount", + "type": "Function", + "tags": [], + "label": "getTotalCount", + "description": [], + "signature": [ + "(table: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.Datatable", + "text": "Datatable" + }, + ") => number | undefined" + ], + "path": "src/plugins/data/common/datatable_utilities/datatable_utilities_service.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "data", + "id": "def-common.DatatableUtilitiesService.getTotalCount.$1", + "type": "Object", + "tags": [], + "label": "table", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.Datatable", + "text": "Datatable" + } + ], + "path": "src/plugins/data/common/datatable_utilities/datatable_utilities_service.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, { "parentPluginId": "data", "id": "def-common.DatatableUtilitiesService.isFilterable", @@ -26111,18 +25100,6 @@ { "plugin": "dataViews", "path": "src/plugins/data_views/common/data_views/data_views.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/plugin.ts" - }, - { - "plugin": "dashboard", - "path": "src/plugins/dashboard/public/application/lib/load_saved_dashboard_state.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/plugin.ts" } ], "returnComment": [], @@ -27272,189 +26249,81 @@ "deprecated": false, "children": [ { - "parentPluginId": "data", - "id": "def-common.DuplicateDataViewError.Unnamed.$1", - "type": "string", - "tags": [], - "label": "message", - "description": [], - "signature": [ - "string" - ], - "path": "src/plugins/data_views/common/errors/duplicate_index_pattern.ts", - "deprecated": false, - "isRequired": true - } - ], - "returnComment": [] - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "data", - "id": "def-common.IndexPattern", - "type": "Class", - "tags": [ - "deprecated" - ], - "label": "IndexPattern", - "description": [], - "signature": [ - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" - }, - " extends ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - } - ], - "path": "src/plugins/data_views/common/data_views/data_view.ts", - "deprecated": true, - "references": [ - { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, + "parentPluginId": "data", + "id": "def-common.DuplicateDataViewError.Unnamed.$1", + "type": "string", + "tags": [], + "label": "message", + "description": [], + "signature": [ + "string" + ], + "path": "src/plugins/data_views/common/errors/duplicate_index_pattern.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-common.IndexPattern", + "type": "Class", + "tags": [ + "deprecated" + ], + "label": "IndexPattern", + "description": [], + "signature": [ { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IndexPattern", + "text": "IndexPattern" }, + " extends ", { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + } + ], + "path": "src/plugins/data_views/common/data_views/data_view.ts", + "deprecated": true, + "references": [ { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts" }, { "plugin": "ux", @@ -27465,60 +26334,28 @@ "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "ux", @@ -27540,10 +26377,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, { "plugin": "savedObjects", "path": "src/plugins/saved_objects/public/types.ts" @@ -27577,344 +26410,324 @@ "path": "src/plugins/data_view_editor/public/open_editor.tsx" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/types/app_state.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/types/app_state.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/persistence.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/persistence.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/types/app_state.ts" + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/types/app_state.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/persistence.ts" + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/persistence.ts" + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "visDefaultEditor", @@ -27969,92 +26782,64 @@ "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "dataViews", @@ -28110,280 +26895,444 @@ "path": "src/plugins/data_views/common/index.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" + }, + { + "plugin": "dataViews", + "path": "src/plugins/data_views/public/index.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/shared_imports.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/metrics_editor/metric_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/metrics_editor/metric_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/metrics_editor/metric_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/es_doc_field.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/es_doc_field.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/metrics_editor/metrics_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/metrics_editor/metrics_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_geo_grid_source/update_source_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_geo_grid_source/update_source_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/top_hits_form.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/top_hits_form.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/top_hits_form.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/update_source_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/update_source_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/update_source_editor.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/geo_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/components/geo_field_select.tsx" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/public/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/shared_imports.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/single_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/metrics_editor/metric_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/metrics_editor/metric_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/metrics_editor/metric_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/es_doc_field.ts" + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/es_doc_field.ts" + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/metrics_editor/metrics_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/metrics_editor/metrics_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_geo_grid_source/update_source_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_geo_grid_source/update_source_editor.tsx" + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/top_hits_form.tsx" + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/top_hits_form.tsx" + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/top_hits_form.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/update_source_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/update_source_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/top_hits/update_source_editor.tsx" + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/geo_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/components/geo_field_select.tsx" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.tsx" + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.tsx" + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.tsx" + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.tsx" + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/index_pattern_util.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { "plugin": "visDefaultEditor", @@ -28470,52 +27419,28 @@ "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" }, { "plugin": "dataViews", @@ -28594,54 +27519,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" @@ -28650,69 +27527,9 @@ "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" - }, { "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" } ], "children": [], @@ -32608,104 +31425,16 @@ "path": "src/plugins/data_views/common/data_views/data_view.ts" }, { - "plugin": "dataViews", - "path": "src/plugins/data_views/common/data_views/data_view.ts" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "plugin": "dataViews", + "path": "src/plugins/data_views/common/data_views/data_view.ts" }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "dataViews", @@ -33068,64 +31797,20 @@ "path": "x-pack/plugins/monitoring/public/lib/kuery.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/services/es_index_service.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/services/es_index_service.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/server/routes/api/transforms.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/alerts/components/param_details_form/use_derived_index_pattern.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/server/routes/api/transforms.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/alerts/components/param_details_form/use_derived_index_pattern.d.ts" } ], "children": [ @@ -35116,6 +33801,14 @@ "deprecated": true, "removeBy": "8.1", "references": [ + { + "plugin": "discover", + "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + }, { "plugin": "dashboard", "path": "src/plugins/dashboard/public/application/lib/filter_utils.ts" @@ -35233,12 +33926,12 @@ "path": "src/plugins/discover/public/application/context/services/context_state.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/embeddable/saved_search_embeddable.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" }, { "plugin": "maps", @@ -35250,11 +33943,39 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts" + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/context/services/context.d.ts" } ], "initialIsOpen": false @@ -35337,42 +34058,6 @@ { "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/timeseries_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/timeseries_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" } ], "initialIsOpen": false @@ -35402,14 +34087,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/common/index.ts" }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" @@ -35421,34 +34098,6 @@ { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" } ], "initialIsOpen": false @@ -35715,38 +34364,6 @@ "plugin": "dataViews", "path": "src/plugins/data_views/public/index.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/public/lazy_load_bundle/index.ts" @@ -35763,65 +34380,29 @@ "plugin": "graph", "path": "x-pack/plugins/graph/public/application.tsx" }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" } ], "initialIsOpen": false @@ -35853,18 +34434,6 @@ "deprecated": true, "removeBy": "8.1", "references": [ - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/types.ts" @@ -35904,6 +34473,14 @@ { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/target/types/server/search/session/types.d.ts" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/target/types/server/search/session/types.d.ts" } ], "initialIsOpen": false @@ -36190,29 +34767,10 @@ }, { "parentPluginId": "data", - "id": "def-common.FILTERS", - "type": "Object", - "tags": [ - "deprecated" - ], - "label": "FILTERS", - "description": [], - "signature": [ - "typeof ", - "FILTERS" - ], - "path": "src/plugins/data/common/es_query/index.ts", - "deprecated": true, - "removeBy": "8.1", - "references": [], - "initialIsOpen": false - }, - { - "parentPluginId": "data", - "id": "def-common.FLEET_ASSETS_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE", "type": "Object", "tags": [], - "label": "FLEET_ASSETS_TO_IGNORE", + "label": "DEFAULT_ASSETS_TO_IGNORE", "description": [ "\nUsed to determine if the instance has any user created index patterns by filtering index patterns\nthat are created and backed only by Fleet server data\nShould be revised after https://github.com/elastic/kibana/issues/82851 is fixed\nFor more background see: https://github.com/elastic/kibana/issues/107020" ], @@ -36221,7 +34779,7 @@ "children": [ { "parentPluginId": "data", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.LOGS_INDEX_PATTERN", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.LOGS_INDEX_PATTERN", "type": "string", "tags": [], "label": "LOGS_INDEX_PATTERN", @@ -36231,7 +34789,7 @@ }, { "parentPluginId": "data", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.METRICS_INDEX_PATTERN", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.METRICS_INDEX_PATTERN", "type": "string", "tags": [], "label": "METRICS_INDEX_PATTERN", @@ -36241,7 +34799,7 @@ }, { "parentPluginId": "data", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.LOGS_DATA_STREAM_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.LOGS_DATA_STREAM_TO_IGNORE", "type": "string", "tags": [], "label": "LOGS_DATA_STREAM_TO_IGNORE", @@ -36251,7 +34809,7 @@ }, { "parentPluginId": "data", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.METRICS_DATA_STREAM_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.METRICS_DATA_STREAM_TO_IGNORE", "type": "string", "tags": [], "label": "METRICS_DATA_STREAM_TO_IGNORE", @@ -36261,7 +34819,17 @@ }, { "parentPluginId": "data", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.METRICS_ENDPOINT_INDEX_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.ENT_SEARCH_LOGS_DATA_STREAM_TO_IGNORE", + "type": "string", + "tags": [], + "label": "ENT_SEARCH_LOGS_DATA_STREAM_TO_IGNORE", + "description": [], + "path": "src/plugins/data_views/common/constants.ts", + "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.METRICS_ENDPOINT_INDEX_TO_IGNORE", "type": "string", "tags": [], "label": "METRICS_ENDPOINT_INDEX_TO_IGNORE", @@ -36272,6 +34840,25 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "data", + "id": "def-common.FILTERS", + "type": "Object", + "tags": [ + "deprecated" + ], + "label": "FILTERS", + "description": [], + "signature": [ + "typeof ", + "FILTERS" + ], + "path": "src/plugins/data/common/es_query/index.ts", + "deprecated": true, + "removeBy": "8.1", + "references": [], + "initialIsOpen": false + }, { "parentPluginId": "data", "id": "def-common.nodeBuilder", @@ -36300,38 +34887,6 @@ "deprecated": true, "removeBy": "8.1", "references": [ - { - "plugin": "actions", - "path": "x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts" - }, - { - "plugin": "actions", - "path": "x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts" - }, - { - "plugin": "actions", - "path": "x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts" - }, - { - "plugin": "actions", - "path": "x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts" - }, - { - "plugin": "actions", - "path": "x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, - { - "plugin": "alerting", - "path": "x-pack/plugins/alerting/server/rules_client/rules_client.ts" - }, { "plugin": "dataEnhanced", "path": "x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts" diff --git a/api_docs/data.mdx b/api_docs/data.mdx index 2a2fb979ea977..9e7b7f168c494 100644 --- a/api_docs/data.mdx +++ b/api_docs/data.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/data title: "data" image: https://source.unsplash.com/400x175/?github summary: API docs for the data plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 3419 | 40 | 2822 | 27 | +| 3457 | 40 | 2844 | 27 | ## Client diff --git a/api_docs/data_autocomplete.mdx b/api_docs/data_autocomplete.mdx index 106298ac6e007..95abf32f9f316 100644 --- a/api_docs/data_autocomplete.mdx +++ b/api_docs/data_autocomplete.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/data-autocomplete title: "data.autocomplete" image: https://source.unsplash.com/400x175/?github summary: API docs for the data.autocomplete plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data.autocomplete'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 3419 | 40 | 2822 | 27 | +| 3457 | 40 | 2844 | 27 | ## Client diff --git a/api_docs/data_enhanced.mdx b/api_docs/data_enhanced.mdx index f3c765e56615e..e6bb1d274c201 100644 --- a/api_docs/data_enhanced.mdx +++ b/api_docs/data_enhanced.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dataEnhanced title: "dataEnhanced" image: https://source.unsplash.com/400x175/?github summary: API docs for the dataEnhanced plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataEnhanced'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/data_query.mdx b/api_docs/data_query.mdx index 648704c4de102..6f33e6164e9df 100644 --- a/api_docs/data_query.mdx +++ b/api_docs/data_query.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/data-query title: "data.query" image: https://source.unsplash.com/400x175/?github summary: API docs for the data.query plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data.query'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 3419 | 40 | 2822 | 27 | +| 3457 | 40 | 2844 | 27 | ## Client diff --git a/api_docs/data_search.devdocs.json b/api_docs/data_search.devdocs.json index cad0364fb7a37..eda3eb1958e37 100644 --- a/api_docs/data_search.devdocs.json +++ b/api_docs/data_search.devdocs.json @@ -16428,6 +16428,62 @@ "description": [], "path": "src/plugins/data/common/search/aggs/metrics/cardinality.ts", "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-common.AggParamsCardinality.emptyAsNull", + "type": "CompoundType", + "tags": [], + "label": "emptyAsNull", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data/common/search/aggs/metrics/cardinality.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-common.AggParamsCount", + "type": "Interface", + "tags": [], + "label": "AggParamsCount", + "description": [], + "signature": [ + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.AggParamsCount", + "text": "AggParamsCount" + }, + " extends ", + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.BaseAggParams", + "text": "BaseAggParams" + } + ], + "path": "src/plugins/data/common/search/aggs/metrics/count.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "data", + "id": "def-common.AggParamsCount.emptyAsNull", + "type": "CompoundType", + "tags": [], + "label": "emptyAsNull", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data/common/search/aggs/metrics/count.ts", + "deprecated": false } ], "initialIsOpen": false @@ -16707,6 +16763,19 @@ ], "path": "src/plugins/data/common/search/aggs/buckets/date_histogram.ts", "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-common.AggParamsDateHistogram.extendToTimeRange", + "type": "CompoundType", + "tags": [], + "label": "extendToTimeRange", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data/common/search/aggs/buckets/date_histogram.ts", + "deprecated": false } ], "initialIsOpen": false @@ -17503,6 +17572,19 @@ ], "path": "src/plugins/data/common/search/aggs/buckets/histogram.ts", "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-common.AggParamsHistogram.autoExtendBounds", + "type": "CompoundType", + "tags": [], + "label": "autoExtendBounds", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data/common/search/aggs/buckets/histogram.ts", + "deprecated": false } ], "initialIsOpen": false @@ -18591,6 +18673,19 @@ "description": [], "path": "src/plugins/data/common/search/aggs/metrics/sum.ts", "deprecated": false + }, + { + "parentPluginId": "data", + "id": "def-common.AggParamsSum.emptyAsNull", + "type": "CompoundType", + "tags": [], + "label": "emptyAsNull", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data/common/search/aggs/metrics/sum.ts", + "deprecated": false } ], "initialIsOpen": false @@ -27725,6 +27820,90 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "data", + "id": "def-common.SQL_SEARCH_STRATEGY", + "type": "string", + "tags": [], + "label": "SQL_SEARCH_STRATEGY", + "description": [], + "signature": [ + "\"sql\"" + ], + "path": "src/plugins/data/common/search/strategies/sql_search/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-common.SqlRequestParams", + "type": "Type", + "tags": [], + "label": "SqlRequestParams", + "description": [], + "signature": [ + "Omit<", + "SqlQueryRequest", + ", \"keep_alive\" | \"keep_on_completion\"> | Omit<", + "SqlGetAsyncRequest", + ", \"id\" | \"keep_alive\" | \"keep_on_completion\">" + ], + "path": "src/plugins/data/common/search/strategies/sql_search/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-common.SqlSearchStrategyRequest", + "type": "Type", + "tags": [], + "label": "SqlSearchStrategyRequest", + "description": [], + "signature": [ + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.IKibanaSearchRequest", + "text": "IKibanaSearchRequest" + }, + "<", + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.SqlRequestParams", + "text": "SqlRequestParams" + }, + ">" + ], + "path": "src/plugins/data/common/search/strategies/sql_search/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "data", + "id": "def-common.SqlSearchStrategyResponse", + "type": "Type", + "tags": [], + "label": "SqlSearchStrategyResponse", + "description": [], + "signature": [ + { + "pluginId": "data", + "scope": "common", + "docId": "kibDataSearchPluginApi", + "section": "def-common.IKibanaSearchResponse", + "text": "IKibanaSearchResponse" + }, + "<", + "SqlQueryResponse", + ">" + ], + "path": "src/plugins/data/common/search/strategies/sql_search/types.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "data", "id": "def-common.termsAggFilter", @@ -28229,7 +28408,7 @@ "section": "def-common.EqlRawResponse", "text": "EqlRawResponse" }, - ") => { type: string; meta: { type: string; source: string; }; columns: { id: string; name: string; meta: { type: \"string\" | \"number\" | \"bigint\" | \"boolean\" | \"symbol\" | \"undefined\" | \"object\" | \"function\"; field: string; params: {}; }; }[]; rows: any[]; }" + ") => { type: string; meta: { type: string; source: string; statistics: { totalCount: number; }; }; columns: { id: string; name: string; meta: { type: \"string\" | \"number\" | \"bigint\" | \"boolean\" | \"symbol\" | \"undefined\" | \"object\" | \"function\"; field: string; params: {}; }; }[]; rows: any[]; }" ], "path": "src/plugins/data/common/search/expressions/eql_raw_response.ts", "deprecated": false, @@ -28311,7 +28490,7 @@ "section": "def-common.EsRawResponse", "text": "EsRawResponse" }, - ") => { type: string; meta: { type: string; source: string; }; columns: { id: string; name: string; meta: { type: \"string\" | \"number\" | \"bigint\" | \"boolean\" | \"symbol\" | \"undefined\" | \"object\" | \"function\"; field: string; params: {}; }; }[]; rows: any[]; }" + ") => { type: string; meta: { type: string; source: string; statistics: { totalCount: number | undefined; }; }; columns: { id: string; name: string; meta: { type: \"string\" | \"number\" | \"bigint\" | \"boolean\" | \"symbol\" | \"undefined\" | \"object\" | \"function\"; field: string; params: {}; }; }[]; rows: any[]; }" ], "path": "src/plugins/data/common/search/expressions/es_raw_response.ts", "deprecated": false, diff --git a/api_docs/data_search.mdx b/api_docs/data_search.mdx index f6731389e145b..f6162ff2019eb 100644 --- a/api_docs/data_search.mdx +++ b/api_docs/data_search.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/data-search title: "data.search" image: https://source.unsplash.com/400x175/?github summary: API docs for the data.search plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data.search'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 3419 | 40 | 2822 | 27 | +| 3457 | 40 | 2844 | 27 | ## Client diff --git a/api_docs/data_ui.mdx b/api_docs/data_ui.mdx index 46922417897ba..c0ba389b9048c 100644 --- a/api_docs/data_ui.mdx +++ b/api_docs/data_ui.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/data-ui title: "data.ui" image: https://source.unsplash.com/400x175/?github summary: API docs for the data.ui plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'data.ui'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 3419 | 40 | 2822 | 27 | +| 3457 | 40 | 2844 | 27 | ## Client diff --git a/api_docs/data_view_editor.mdx b/api_docs/data_view_editor.mdx index 61c45effd9313..00c3b7b34f0ea 100644 --- a/api_docs/data_view_editor.mdx +++ b/api_docs/data_view_editor.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dataViewEditor title: "dataViewEditor" image: https://source.unsplash.com/400x175/?github summary: API docs for the dataViewEditor plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViewEditor'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/data_view_field_editor.mdx b/api_docs/data_view_field_editor.mdx index de03fc0bd21f7..3225daacfdec2 100644 --- a/api_docs/data_view_field_editor.mdx +++ b/api_docs/data_view_field_editor.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dataViewFieldEditor title: "dataViewFieldEditor" image: https://source.unsplash.com/400x175/?github summary: API docs for the dataViewFieldEditor plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViewFieldEditor'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/data_view_management.mdx b/api_docs/data_view_management.mdx index 2f68bdac8c32a..a1bab5c7ddf82 100644 --- a/api_docs/data_view_management.mdx +++ b/api_docs/data_view_management.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dataViewManagement title: "dataViewManagement" image: https://source.unsplash.com/400x175/?github summary: API docs for the dataViewManagement plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViewManagement'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/data_views.devdocs.json b/api_docs/data_views.devdocs.json index 1b452f280ef62..0eec355af5566 100644 --- a/api_docs/data_views.devdocs.json +++ b/api_docs/data_views.devdocs.json @@ -2223,6 +2223,59 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSavedObjectConflictError", + "type": "Class", + "tags": [], + "label": "DataViewSavedObjectConflictError", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSavedObjectConflictError", + "text": "DataViewSavedObjectConflictError" + }, + " extends Error" + ], + "path": "src/plugins/data_views/common/errors/data_view_saved_object_conflict.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSavedObjectConflictError.Unnamed", + "type": "Function", + "tags": [], + "label": "Constructor", + "description": [], + "signature": [ + "any" + ], + "path": "src/plugins/data_views/common/errors/data_view_saved_object_conflict.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSavedObjectConflictError.Unnamed.$1", + "type": "string", + "tags": [], + "label": "savedObjectId", + "description": [], + "signature": [ + "string" + ], + "path": "src/plugins/data_views/common/errors/data_view_saved_object_conflict.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + } + ], + "initialIsOpen": false + }, { "parentPluginId": "dataViews", "id": "def-public.DataViewsPublicPlugin", @@ -2255,13 +2308,7 @@ "text": "DataViewsPublicPluginSetup" }, ", ", - { - "pluginId": "dataViews", - "scope": "public", - "docId": "kibDataViewsPluginApi", - "section": "def-public.DataViewsPublicPluginStart", - "text": "DataViewsPublicPluginStart" - }, + "DataViewsServicePublic", ", ", "DataViewsPublicSetupDependencies", ", ", @@ -2290,13 +2337,7 @@ "<", "DataViewsPublicStartDependencies", ", ", - { - "pluginId": "dataViews", - "scope": "public", - "docId": "kibDataViewsPluginApi", - "section": "def-public.DataViewsPublicPluginStart", - "text": "DataViewsPublicPluginStart" - }, + "DataViewsServicePublic", ">, { expressions }: ", "DataViewsPublicSetupDependencies", ") => ", @@ -2329,13 +2370,7 @@ "<", "DataViewsPublicStartDependencies", ", ", - { - "pluginId": "dataViews", - "scope": "public", - "docId": "kibDataViewsPluginApi", - "section": "def-public.DataViewsPublicPluginStart", - "text": "DataViewsPublicPluginStart" - }, + "DataViewsServicePublic", ">" ], "path": "src/plugins/data_views/public/plugin.ts", @@ -2378,13 +2413,7 @@ ", { fieldFormats }: ", "DataViewsPublicStartDependencies", ") => ", - { - "pluginId": "dataViews", - "scope": "public", - "docId": "kibDataViewsPluginApi", - "section": "def-public.DataViewsPublicPluginStart", - "text": "DataViewsPublicPluginStart" - } + "DataViewsServicePublic" ], "path": "src/plugins/data_views/public/plugin.ts", "deprecated": false, @@ -2483,20 +2512,7 @@ ], "path": "src/plugins/data_views/common/data_views/data_views.ts", "deprecated": true, - "references": [ - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/plugin.ts" - }, - { - "plugin": "dashboard", - "path": "src/plugins/dashboard/public/application/lib/load_saved_dashboard_state.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/plugin.ts" - } - ], + "references": [], "returnComment": [], "children": [] }, @@ -3639,6 +3655,30 @@ "path": "src/plugins/data_views/common/data_views/data_view.ts", "deprecated": true, "references": [ + { + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts" + }, + { + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" + }, + { + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts" + }, { "plugin": "data", "path": "src/plugins/data/common/index.ts" @@ -3763,138 +3803,6 @@ "plugin": "data", "path": "src/plugins/data/server/index.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, { "plugin": "ux", "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" @@ -3904,60 +3812,28 @@ "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "data", @@ -4220,8 +4096,8 @@ "path": "src/plugins/data/public/index.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" + "plugin": "data", + "path": "src/plugins/data/target/types/common/search/aggs/agg_config.d.ts" }, { "plugin": "data", @@ -4276,344 +4152,324 @@ "path": "src/plugins/data_view_editor/public/open_editor.tsx" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/types/app_state.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/types/app_state.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/persistence.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/persistence.ts" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/search_bar.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/types/app_state.ts" + "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/types/app_state.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.sagas.ts" + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/persistence.ts" + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/persistence.ts" + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/search_bar.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/inspect_panel.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "visDefaultEditor", @@ -4668,92 +4524,64 @@ "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" } ], "children": [], @@ -4833,76 +4661,32 @@ "path": "src/plugins/data/server/index.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "data", @@ -5154,316 +4938,331 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" - } - ], - "children": [], - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.IndexPatternsService", - "type": "Class", - "tags": [ - "deprecated" - ], - "label": "IndexPatternsService", - "description": [], - "signature": [ - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPatternsService", - "text": "IndexPatternsService" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, - " extends ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewsService", - "text": "DataViewsService" - } - ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", - "deprecated": true, - "references": [ + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, { - "plugin": "data", - "path": "src/plugins/data/common/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "data", - "path": "src/plugins/data/server/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "data", - "path": "src/plugins/data/server/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { - "plugin": "data", - "path": "src/plugins/data/server/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" }, { - "plugin": "data", - "path": "src/plugins/data/public/index.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" } ], "children": [], @@ -5471,54 +5270,115 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.SavedObjectsClientPublicToCommon", + "id": "def-public.IndexPatternsService", "type": "Class", - "tags": [], - "label": "SavedObjectsClientPublicToCommon", + "tags": [ + "deprecated" + ], + "label": "IndexPatternsService", "description": [], "signature": [ { "pluginId": "dataViews", - "scope": "public", + "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-public.SavedObjectsClientPublicToCommon", - "text": "SavedObjectsClientPublicToCommon" + "section": "def-common.IndexPatternsService", + "text": "IndexPatternsService" }, - " implements ", + " extends ", { "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.SavedObjectsClientCommon", - "text": "SavedObjectsClientCommon" + "section": "def-common.DataViewsService", + "text": "DataViewsService" } ], - "path": "src/plugins/data_views/public/saved_objects_client_wrapper.ts", - "deprecated": false, - "children": [ + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": true, + "references": [ { - "parentPluginId": "dataViews", - "id": "def-public.SavedObjectsClientPublicToCommon.Unnamed", - "type": "Function", - "tags": [], - "label": "Constructor", - "description": [], - "signature": [ - "any" - ], - "path": "src/plugins/data_views/public/saved_objects_client_wrapper.ts", - "deprecated": false, - "children": [ - { - "parentPluginId": "dataViews", - "id": "def-public.SavedObjectsClientPublicToCommon.Unnamed.$1", - "type": "Object", - "tags": [], - "label": "savedObjectClient", - "description": [], - "signature": [ - "SOClient" - ], + "plugin": "data", + "path": "src/plugins/data/common/index.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/server/index.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/server/index.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/server/index.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/public/index.ts" + } + ], + "children": [], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.SavedObjectsClientPublicToCommon", + "type": "Class", + "tags": [], + "label": "SavedObjectsClientPublicToCommon", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "public", + "docId": "kibDataViewsPluginApi", + "section": "def-public.SavedObjectsClientPublicToCommon", + "text": "SavedObjectsClientPublicToCommon" + }, + " implements ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.SavedObjectsClientCommon", + "text": "SavedObjectsClientCommon" + } + ], + "path": "src/plugins/data_views/public/saved_objects_client_wrapper.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.SavedObjectsClientPublicToCommon.Unnamed", + "type": "Function", + "tags": [], + "label": "Constructor", + "description": [], + "signature": [ + "any" + ], + "path": "src/plugins/data_views/public/saved_objects_client_wrapper.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.SavedObjectsClientPublicToCommon.Unnamed.$1", + "type": "Object", + "tags": [], + "label": "savedObjectClient", + "description": [], + "signature": [ + "SOClient" + ], "path": "src/plugins/data_views/public/saved_objects_client_wrapper.ts", "deprecated": false, "isRequired": true @@ -5990,6 +5850,74 @@ } ], "functions": [ + { + "parentPluginId": "dataViews", + "id": "def-public.getFieldSubtypeMulti", + "type": "Function", + "tags": [], + "label": "getFieldSubtypeMulti", + "description": [], + "signature": [ + "(field: HasSubtype) => ", + "IFieldSubTypeMulti", + " | undefined" + ], + "path": "src/plugins/data_views/common/fields/utils.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.getFieldSubtypeMulti.$1", + "type": "Object", + "tags": [], + "label": "field", + "description": [], + "signature": [ + "{ subType?: ", + "IFieldSubType", + " | undefined; }" + ], + "path": "src/plugins/data_views/common/fields/utils.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.getFieldSubtypeNested", + "type": "Function", + "tags": [], + "label": "getFieldSubtypeNested", + "description": [], + "signature": [ + "(field: HasSubtype) => ", + "IFieldSubTypeNested", + " | undefined" + ], + "path": "src/plugins/data_views/common/fields/utils.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.getFieldSubtypeNested.$1", + "type": "Object", + "tags": [], + "label": "field", + "description": [], + "signature": [ + "{ subType?: ", + "IFieldSubType", + " | undefined; }" + ], + "path": "src/plugins/data_views/common/fields/utils.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "dataViews", "id": "def-public.onRedirectNoIndexPattern", @@ -6142,50 +6070,39 @@ "interfaces": [ { "parentPluginId": "dataViews", - "id": "def-public.DataViewListItem", + "id": "def-public.DataViewAttributes", "type": "Interface", "tags": [], - "label": "DataViewListItem", - "description": [], - "path": "src/plugins/data_views/common/data_views/data_views.ts", + "label": "DataViewAttributes", + "description": [ + "\nInterface for an index pattern saved object" + ], + "path": "src/plugins/data_views/common/types.ts", "deprecated": false, "children": [ { "parentPluginId": "dataViews", - "id": "def-public.DataViewListItem.id", + "id": "def-public.DataViewAttributes.fields", "type": "string", "tags": [], - "label": "id", - "description": [], - "path": "src/plugins/data_views/common/data_views/data_views.ts", - "deprecated": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.DataViewListItem.namespaces", - "type": "Array", - "tags": [], - "label": "namespaces", + "label": "fields", "description": [], - "signature": [ - "string[] | undefined" - ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", + "path": "src/plugins/data_views/common/types.ts", "deprecated": false }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewListItem.title", + "id": "def-public.DataViewAttributes.title", "type": "string", "tags": [], "label": "title", "description": [], - "path": "src/plugins/data_views/common/data_views/data_views.ts", + "path": "src/plugins/data_views/common/types.ts", "deprecated": false }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewListItem.type", + "id": "def-public.DataViewAttributes.type", "type": "string", "tags": [], "label": "type", @@ -6193,53 +6110,29 @@ "signature": [ "string | undefined" ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", + "path": "src/plugins/data_views/common/types.ts", "deprecated": false }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewListItem.typeMeta", - "type": "Object", + "id": "def-public.DataViewAttributes.typeMeta", + "type": "string", "tags": [], "label": "typeMeta", "description": [], "signature": [ - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.TypeMeta", - "text": "TypeMeta" - }, - " | undefined" + "string | undefined" ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", + "path": "src/plugins/data_views/common/types.ts", "deprecated": false - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec", - "type": "Interface", - "tags": [], - "label": "DataViewSpec", - "description": [ - "\nStatic index pattern format\nSerialized data object, representing index pattern attributes and state" - ], - "path": "src/plugins/data_views/common/types.ts", - "deprecated": false, - "children": [ + }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec.id", + "id": "def-public.DataViewAttributes.timeFieldName", "type": "string", "tags": [], - "label": "id", - "description": [ - "\nsaved object id" - ], + "label": "timeFieldName", + "description": [], "signature": [ "string | undefined" ], @@ -6248,13 +6141,11 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec.version", + "id": "def-public.DataViewAttributes.sourceFilters", "type": "string", "tags": [], - "label": "version", - "description": [ - "\nsaved object version string" - ], + "label": "sourceFilters", + "description": [], "signature": [ "string | undefined" ], @@ -6263,10 +6154,10 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec.title", + "id": "def-public.DataViewAttributes.fieldFormatMap", "type": "string", "tags": [], - "label": "title", + "label": "fieldFormatMap", "description": [], "signature": [ "string | undefined" @@ -6276,10 +6167,10 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec.timeFieldName", + "id": "def-public.DataViewAttributes.fieldAttrs", "type": "string", "tags": [], - "label": "timeFieldName", + "label": "fieldAttrs", "description": [], "signature": [ "string | undefined" @@ -6289,36 +6180,214 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec.sourceFilters", - "type": "Array", + "id": "def-public.DataViewAttributes.runtimeFieldMap", + "type": "string", "tags": [], - "label": "sourceFilters", + "label": "runtimeFieldMap", "description": [], "signature": [ - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.SourceFilter", - "text": "SourceFilter" - }, - "[] | undefined" + "string | undefined" ], "path": "src/plugins/data_views/common/types.ts", "deprecated": false }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewSpec.fields", - "type": "Object", + "id": "def-public.DataViewAttributes.allowNoIndex", + "type": "CompoundType", "tags": [], - "label": "fields", - "description": [], + "label": "allowNoIndex", + "description": [ + "\nprevents errors when index pattern exists before indices" + ], "signature": [ - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewListItem", + "type": "Interface", + "tags": [], + "label": "DataViewListItem", + "description": [], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewListItem.id", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewListItem.namespaces", + "type": "Array", + "tags": [], + "label": "namespaces", + "description": [], + "signature": [ + "string[] | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewListItem.title", + "type": "string", + "tags": [], + "label": "title", + "description": [], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewListItem.type", + "type": "string", + "tags": [], + "label": "type", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewListItem.typeMeta", + "type": "Object", + "tags": [], + "label": "typeMeta", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.TypeMeta", + "text": "TypeMeta" + }, + " | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec", + "type": "Interface", + "tags": [], + "label": "DataViewSpec", + "description": [ + "\nStatic index pattern format\nSerialized data object, representing index pattern attributes and state" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec.id", + "type": "string", + "tags": [], + "label": "id", + "description": [ + "\nsaved object id" + ], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec.version", + "type": "string", + "tags": [], + "label": "version", + "description": [ + "\nsaved object version string" + ], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec.title", + "type": "string", + "tags": [], + "label": "title", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec.timeFieldName", + "type": "string", + "tags": [], + "label": "timeFieldName", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec.sourceFilters", + "type": "Array", + "tags": [], + "label": "sourceFilters", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.SourceFilter", + "text": "SourceFilter" + }, + "[] | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewSpec.fields", + "type": "Object", + "tags": [], + "label": "fields", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", "section": "def-common.DataViewFieldMap", "text": "DataViewFieldMap" }, @@ -6461,59 +6530,290 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.IIndexPatternFieldList", + "id": "def-public.FieldSpec", "type": "Interface", "tags": [], - "label": "IIndexPatternFieldList", + "label": "FieldSpec", "description": [], "signature": [ { "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IIndexPatternFieldList", - "text": "IIndexPatternFieldList" + "section": "def-common.FieldSpec", + "text": "FieldSpec" }, " extends ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewField", - "text": "DataViewField" - }, - "[]" + "DataViewFieldBase" ], - "path": "src/plugins/data_views/common/fields/field_list.ts", + "path": "src/plugins/data_views/common/types.ts", "deprecated": false, "children": [ { "parentPluginId": "dataViews", - "id": "def-public.IIndexPatternFieldList.add", - "type": "Function", + "id": "def-public.FieldSpec.count", + "type": "number", "tags": [], - "label": "add", + "label": "count", + "description": [ + "\nPopularity count is used by discover" + ], + "signature": [ + "number | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.conflictDescriptions", + "type": "Object", + "tags": [], + "label": "conflictDescriptions", + "description": [], + "signature": [ + "Record | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.format", + "type": "Object", + "tags": [], + "label": "format", "description": [], "signature": [ - "(field: ", { - "pluginId": "dataViews", + "pluginId": "fieldFormats", "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" + "docId": "kibFieldFormatsPluginApi", + "section": "def-common.SerializedFieldFormat", + "text": "SerializedFieldFormat" }, - ") => ", + "<", { - "pluginId": "dataViews", + "pluginId": "fieldFormats", "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewField", - "text": "DataViewField" - } - ], - "path": "src/plugins/data_views/common/fields/field_list.ts", - "deprecated": false, + "docId": "kibFieldFormatsPluginApi", + "section": "def-common.FieldFormatParams", + "text": "FieldFormatParams" + }, + "> | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.esTypes", + "type": "Array", + "tags": [], + "label": "esTypes", + "description": [], + "signature": [ + "string[] | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.searchable", + "type": "boolean", + "tags": [], + "label": "searchable", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.aggregatable", + "type": "boolean", + "tags": [], + "label": "aggregatable", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.readFromDocValues", + "type": "CompoundType", + "tags": [], + "label": "readFromDocValues", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.indexed", + "type": "CompoundType", + "tags": [], + "label": "indexed", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.customLabel", + "type": "string", + "tags": [], + "label": "customLabel", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.runtimeField", + "type": "Object", + "tags": [], + "label": "runtimeField", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.RuntimeFieldSpec", + "text": "RuntimeFieldSpec" + }, + " | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.shortDotsEnable", + "type": "CompoundType", + "tags": [], + "label": "shortDotsEnable", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.FieldSpec.isMapped", + "type": "CompoundType", + "tags": [], + "label": "isMapped", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.HasDataViewsResponse", + "type": "Interface", + "tags": [], + "label": "HasDataViewsResponse", + "description": [], + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.HasDataViewsResponse.hasDataView", + "type": "boolean", + "tags": [], + "label": "hasDataView", + "description": [], + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.HasDataViewsResponse.hasUserDataView", + "type": "boolean", + "tags": [], + "label": "hasUserDataView", + "description": [], + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.IIndexPatternFieldList", + "type": "Interface", + "tags": [], + "label": "IIndexPatternFieldList", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IIndexPatternFieldList", + "text": "IIndexPatternFieldList" + }, + " extends ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewField", + "text": "DataViewField" + }, + "[]" + ], + "path": "src/plugins/data_views/common/fields/field_list.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.IIndexPatternFieldList.add", + "type": "Function", + "tags": [], + "label": "add", + "description": [], + "signature": [ + "(field: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldSpec", + "text": "FieldSpec" + }, + ") => ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewField", + "text": "DataViewField" + } + ], + "path": "src/plugins/data_views/common/fields/field_list.ts", + "deprecated": false, "children": [ { "parentPluginId": "dataViews", @@ -6902,69 +7202,162 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.TypeMeta", + "id": "def-public.IndicesResponse", "type": "Interface", "tags": [], - "label": "TypeMeta", + "label": "IndicesResponse", "description": [], - "path": "src/plugins/data_views/common/types.ts", + "path": "src/plugins/data_views/public/types.ts", "deprecated": false, "children": [ { "parentPluginId": "dataViews", - "id": "def-public.TypeMeta.aggs", - "type": "Object", + "id": "def-public.IndicesResponse.indices", + "type": "Array", "tags": [], - "label": "aggs", + "label": "indices", "description": [], "signature": [ - "Record | undefined" + "IndicesResponseItemIndex", + "[] | undefined" ], - "path": "src/plugins/data_views/common/types.ts", + "path": "src/plugins/data_views/public/types.ts", "deprecated": false }, { "parentPluginId": "dataViews", - "id": "def-public.TypeMeta.params", - "type": "Object", + "id": "def-public.IndicesResponse.aliases", + "type": "Array", "tags": [], - "label": "params", + "label": "aliases", "description": [], "signature": [ - "{ rollup_index: string; } | undefined" + "IndicesResponseItemAlias", + "[] | undefined" ], - "path": "src/plugins/data_views/common/types.ts", + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.IndicesResponse.data_streams", + "type": "Array", + "tags": [], + "label": "data_streams", + "description": [], + "signature": [ + "IndicesResponseItemDataStream", + "[] | undefined" + ], + "path": "src/plugins/data_views/public/types.ts", "deprecated": false } ], "initialIsOpen": false - } - ], - "enums": [ + }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewType", - "type": "Enum", + "id": "def-public.IndicesResponseModified", + "type": "Interface", "tags": [], - "label": "DataViewType", + "label": "IndicesResponseModified", "description": [], - "path": "src/plugins/data_views/common/types.ts", + "path": "src/plugins/data_views/public/types.ts", "deprecated": false, - "initialIsOpen": false - } - ], - "misc": [ - { - "parentPluginId": "dataViews", - "id": "def-public.CONTAINS_SPACES_KEY", + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.IndicesResponseModified.name", + "type": "string", + "tags": [], + "label": "name", + "description": [], + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.IndicesResponseModified.item", + "type": "Object", + "tags": [], + "label": "item", + "description": [], + "signature": [ + "{ name: string; backing_indices?: string[] | undefined; timestamp_field?: string | undefined; indices?: string[] | undefined; aliases?: string[] | undefined; attributes?: ", + "IndicesResponseItemIndexAttrs", + "[] | undefined; data_stream?: string | undefined; }" + ], + "path": "src/plugins/data_views/public/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.TypeMeta", + "type": "Interface", + "tags": [], + "label": "TypeMeta", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-public.TypeMeta.aggs", + "type": "Object", + "tags": [], + "label": "aggs", + "description": [], + "signature": [ + "Record | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.TypeMeta.params", + "type": "Object", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "{ rollup_index: string; } | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + } + ], + "enums": [ + { + "parentPluginId": "dataViews", + "id": "def-public.DataViewType", + "type": "Enum", + "tags": [], + "label": "DataViewType", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false, + "initialIsOpen": false + } + ], + "misc": [ + { + "parentPluginId": "dataViews", + "id": "def-public.CONTAINS_SPACES_KEY", "type": "string", "tags": [], "label": "CONTAINS_SPACES_KEY", @@ -6992,10 +7385,54 @@ }, { "parentPluginId": "dataViews", - "id": "def-public.DataViewsContract", - "type": "Type", + "id": "def-public.ILLEGAL_CHARACTERS", + "type": "Array", "tags": [], - "label": "DataViewsContract", + "label": "ILLEGAL_CHARACTERS", + "description": [], + "signature": [ + "string[]" + ], + "path": "src/plugins/data_views/common/lib/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.ILLEGAL_CHARACTERS_KEY", + "type": "string", + "tags": [], + "label": "ILLEGAL_CHARACTERS_KEY", + "description": [], + "signature": [ + "\"ILLEGAL_CHARACTERS\"" + ], + "path": "src/plugins/data_views/common/lib/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.ILLEGAL_CHARACTERS_VISIBLE", + "type": "Array", + "tags": [], + "label": "ILLEGAL_CHARACTERS_VISIBLE", + "description": [], + "signature": [ + "string[]" + ], + "path": "src/plugins/data_views/common/lib/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-public.IndexPatternsContract", + "type": "Type", + "tags": [ + "deprecated" + ], + "label": "IndexPatternsContract", "description": [], "signature": [ "{ create: (spec: ", @@ -7198,292 +7635,34 @@ "section": "def-common.DataView", "text": "DataView" }, - " | null>; getCanSaveSync: () => boolean; }" - ], - "path": "src/plugins/data_views/public/types.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.ILLEGAL_CHARACTERS", - "type": "Array", - "tags": [], - "label": "ILLEGAL_CHARACTERS", - "description": [], - "signature": [ - "string[]" - ], - "path": "src/plugins/data_views/common/lib/types.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.ILLEGAL_CHARACTERS_KEY", - "type": "string", - "tags": [], - "label": "ILLEGAL_CHARACTERS_KEY", - "description": [], - "signature": [ - "\"ILLEGAL_CHARACTERS\"" - ], - "path": "src/plugins/data_views/common/lib/types.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.ILLEGAL_CHARACTERS_VISIBLE", - "type": "Array", - "tags": [], - "label": "ILLEGAL_CHARACTERS_VISIBLE", - "description": [], - "signature": [ - "string[]" - ], - "path": "src/plugins/data_views/common/lib/types.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-public.IndexPatternsContract", - "type": "Type", - "tags": [ - "deprecated" + " | null>; }" ], - "label": "IndexPatternsContract", - "description": [], - "signature": [ - "{ create: (spec: ", + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": true, + "references": [ { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" + "plugin": "data", + "path": "src/plugins/data/common/index.ts" }, - ", skipFetchFields?: boolean) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "data", + "path": "src/plugins/data/common/search/search_source/create_search_source.ts" }, - ">; delete: (indexPatternId: string) => Promise<{}>; find: (search: string, size?: number) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "data", + "path": "src/plugins/data/common/search/search_source/create_search_source.ts" }, - "[]>; get: (id: string) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" + "plugin": "data", + "path": "src/plugins/data/common/search/search_source/search_source_service.ts" }, - ">; getCanSave: () => Promise; ensureDefaultDataView: ", - "EnsureDefaultDataView", - "; getIds: (refresh?: boolean) => Promise; getTitles: (refresh?: boolean) => Promise; getIdsWithTitle: (refresh?: boolean) => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewListItem", - "text": "DataViewListItem" + "plugin": "data", + "path": "src/plugins/data/common/search/search_source/search_source_service.ts" }, - "[]>; clearCache: (id?: string | undefined) => void; getCache: () => Promise<", - "SavedObject", - "<", - "IndexPatternSavedObjectAttrs", - ">[] | null | undefined>; getDefault: () => Promise<", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getDefaultId: () => Promise; setDefault: (id: string | null, force?: boolean) => Promise; hasUserDataView: () => Promise; getFieldsForWildcard: (options: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - ") => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; getFieldsForIndexPattern: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", options?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - " | undefined) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; refreshFields: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ") => Promise; fieldArrayToMap: (fields: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[], fieldAttrs?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewFieldMap", - "text": "DataViewFieldMap" - }, - "; savedObjectToSpec: (savedObject: ", - "SavedObject", - "<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewAttributes", - "text": "DataViewAttributes" - }, - ">) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - "; createAndSave: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", override?: boolean, skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; createSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", override?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; updateSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", saveAttempts?: number, ignoreErrors?: boolean) => Promise; getDefaultDataView: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; }" - ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", - "deprecated": true, - "references": [ - { - "plugin": "data", - "path": "src/plugins/data/common/index.ts" - }, - { - "plugin": "data", - "path": "src/plugins/data/common/search/search_source/create_search_source.ts" - }, - { - "plugin": "data", - "path": "src/plugins/data/common/search/search_source/create_search_source.ts" - }, - { - "plugin": "data", - "path": "src/plugins/data/common/search/search_source/search_source_service.ts" - }, - { - "plugin": "data", - "path": "src/plugins/data/common/search/search_source/search_source_service.ts" - }, - { - "plugin": "data", - "path": "src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts" + "plugin": "data", + "path": "src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts" }, { "plugin": "data", @@ -7585,38 +7764,6 @@ "plugin": "data", "path": "src/plugins/data/public/search/search_service.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/public/lazy_load_bundle/index.ts" @@ -7633,57 +7780,29 @@ "plugin": "graph", "path": "x-pack/plugins/graph/public/application.tsx" }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "data", @@ -7702,12 +7821,20 @@ "path": "src/plugins/data/public/actions/filters/create_filters_from_value_click.test.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/index_pattern_select.d.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/index_pattern_select.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/create_index_pattern_select.d.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/create_index_pattern_select.d.ts" } ], "initialIsOpen": false @@ -7759,215 +7886,13 @@ }, "start": { "parentPluginId": "dataViews", - "id": "def-public.DataViewsPublicPluginStart", + "id": "def-public.DataViewsContract", "type": "Type", "tags": [], - "label": "DataViewsPublicPluginStart", - "description": [ - "\nData views plugin public Start contract" - ], + "label": "DataViewsContract", + "description": [], "signature": [ - "{ create: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; delete: (indexPatternId: string) => Promise<{}>; find: (search: string, size?: number) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - "[]>; get: (id: string) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; getCanSave: () => Promise; ensureDefaultDataView: ", - "EnsureDefaultDataView", - "; getIds: (refresh?: boolean) => Promise; getTitles: (refresh?: boolean) => Promise; getIdsWithTitle: (refresh?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewListItem", - "text": "DataViewListItem" - }, - "[]>; clearCache: (id?: string | undefined) => void; getCache: () => Promise<", - "SavedObject", - "<", - "IndexPatternSavedObjectAttrs", - ">[] | null | undefined>; getDefault: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getDefaultId: () => Promise; setDefault: (id: string | null, force?: boolean) => Promise; hasUserDataView: () => Promise; getFieldsForWildcard: (options: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - ") => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; getFieldsForIndexPattern: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", options?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - " | undefined) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; refreshFields: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ") => Promise; fieldArrayToMap: (fields: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[], fieldAttrs?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewFieldMap", - "text": "DataViewFieldMap" - }, - "; savedObjectToSpec: (savedObject: ", - "SavedObject", - "<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewAttributes", - "text": "DataViewAttributes" - }, - ">) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - "; createAndSave: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", override?: boolean, skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; createSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", override?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; updateSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", saveAttempts?: number, ignoreErrors?: boolean) => Promise; getDefaultDataView: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getCanSaveSync: () => boolean; }" + "DataViewsServicePublic" ], "path": "src/plugins/data_views/public/types.ts", "deprecated": false, @@ -11077,14 +11002,6 @@ "plugin": "data", "path": "src/plugins/data/server/search/search_service.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" - }, { "plugin": "infra", "path": "x-pack/plugins/infra/server/lib/adapters/framework/kibana_framework_adapter.ts" @@ -11104,10 +11021,6 @@ { "plugin": "maps", "path": "x-pack/plugins/maps/server/data_indexing/indexing_routes.ts" - }, - { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/server/routes/run.ts" } ], "returnComment": [], @@ -14902,20 +14815,7 @@ ], "path": "src/plugins/data_views/common/data_views/data_views.ts", "deprecated": true, - "references": [ - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/plugin.ts" - }, - { - "plugin": "dashboard", - "path": "src/plugins/dashboard/public/application/lib/load_saved_dashboard_state.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/plugin.ts" - } - ], + "references": [], "returnComment": [], "children": [] }, @@ -16111,6 +16011,30 @@ "path": "src/plugins/data_views/common/data_views/data_view.ts", "deprecated": true, "references": [ + { + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts" + }, + { + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts" + }, + { + "plugin": "dashboard", + "path": "src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts" + }, { "plugin": "data", "path": "src/plugins/data/common/index.ts" @@ -16235,138 +16159,6 @@ "plugin": "data", "path": "src/plugins/data/server/index.ts" }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_pattern_management/index_pattern_management.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/lens_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/field_data_row/action_menu/actions.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/types/index.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/common/types/index_pattern.ts" - }, { "plugin": "ux", "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" @@ -16376,60 +16168,28 @@ "path": "x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/existing_fields.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/index_pattern_select.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts" }, { "plugin": "data", @@ -16692,8 +16452,8 @@ "path": "src/plugins/data/public/index.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" + "plugin": "data", + "path": "src/plugins/data/target/types/common/search/aggs/agg_config.d.ts" }, { "plugin": "data", @@ -16747,110 +16507,6 @@ "plugin": "dataViewEditor", "path": "src/plugins/data_view_editor/public/open_editor.tsx" }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/vis_types/types.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/full_time_range_selector/full_time_range_selector_service.ts" - }, { "plugin": "graph", "path": "x-pack/plugins/graph/public/types/app_state.ts" @@ -16940,132 +16596,132 @@ "path": "x-pack/plugins/graph/public/services/index_pattern_cache.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/mocks.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/common/request.ts" + "plugin": "graph", + "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/hooks/update_kuery_string.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "uptime", - "path": "x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/mocks.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/es_search_source.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/state_management/datasource.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { - "plugin": "graph", - "path": "x-pack/plugins/graph/public/services/persistence/deserialize.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts" + "path": "x-pack/plugins/maps/target/types/public/components/geo_index_pattern_select.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts" + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { "plugin": "maps", @@ -17073,19 +16729,103 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/count_agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/agg/agg_field.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/geo_line_form.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/filter_editor/filter_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/common.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/where_expression.d.ts" + }, + { + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" + }, + { + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "visDefaultEditor", @@ -17140,92 +16880,64 @@ "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.test.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/panel_config/types.ts" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/annotations_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/vis_editor.tsx" - }, - { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "dataViewFieldEditor", + "path": "src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/utils/editor_config.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeVega", - "path": "src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.ts" + "plugin": "inputControlVis", + "path": "src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" }, { "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/metrics_type.test.ts" + "path": "src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts" } ], "children": [], @@ -17305,76 +17017,32 @@ "path": "src/plugins/data/server/index.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" - }, - { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/server/routes/field_stats.ts" + "path": "x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts" }, { "plugin": "data", @@ -17626,316 +17294,392 @@ }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/fields/es_doc_field.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/update_source_editor.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "visDefaultEditor", - "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/index_pattern_util.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { - "plugin": "dataViewEditor", - "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/geo_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/single_field_select.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { - "plugin": "dataVisualizer", - "path": "x-pack/plugins/data_visualizer/public/application/common/components/top_values/top_values.tsx" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metrics_editor.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts" - } - ], - "children": [], - "initialIsOpen": false - }, - { - "parentPluginId": "dataViews", - "id": "def-common.IndexPatternsService", - "type": "Class", - "tags": [ - "deprecated" - ], - "label": "IndexPatternsService", - "description": [], - "signature": [ - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPatternsService", - "text": "IndexPatternsService" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/components/metrics_editor/metric_editor.d.ts" }, - " extends ", { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewsService", - "text": "DataViewsService" - } - ], - "path": "src/plugins/data_views/common/data_views/data_views.ts", - "deprecated": true, - "references": [ + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" + }, { - "plugin": "data", - "path": "src/plugins/data/common/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_geo_line_source/update_source_editor.d.ts" }, { - "plugin": "data", - "path": "src/plugins/data/server/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "data", - "path": "src/plugins/data/server/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/layers/wizards/choropleth_layer_wizard/layer_template.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/create_source_editor.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/classes/sources/es_search_source/top_hits/top_hits_form.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/types.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { - "plugin": "data", - "path": "src/plugins/data/server/index.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/join_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { "plugin": "maps", - "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + "path": "x-pack/plugins/maps/target/types/public/connected_components/edit_layer_panel/join_editor/resources/metrics_expression.d.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/fields_fetcher.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_param_props.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/plugin.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.test.ts" + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/controls/top_sort_field.tsx" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/public/components/agg_params_helper.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "dataViewEditor", + "path": "src/plugins/data_view_editor/public/lib/extract_time_fields.test.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/agg_param_props.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" + }, + { + "plugin": "visDefaultEditor", + "path": "src/plugins/vis_default_editor/target/types/public/components/controls/top_sort_field.d.ts" + } + ], + "children": [], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.IndexPatternsService", + "type": "Class", + "tags": [ + "deprecated" + ], + "label": "IndexPatternsService", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.IndexPatternsService", + "text": "IndexPatternsService" + }, + " extends ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewsService", + "text": "DataViewsService" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": true, + "references": [ + { + "plugin": "data", + "path": "src/plugins/data/common/index.ts" }, { "plugin": "data", - "path": "src/plugins/data/public/index.ts" + "path": "src/plugins/data/server/index.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" + "plugin": "data", + "path": "src/plugins/data/server/index.ts" }, { - "plugin": "visTypeTimeseries", - "path": "src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx" + "plugin": "data", + "path": "src/plugins/data/server/index.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + }, + { + "plugin": "maps", + "path": "x-pack/plugins/maps/server/data_indexing/create_doc_source.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/public/index.ts" } ], "children": [], @@ -18576,99 +18320,1143 @@ }, { "parentPluginId": "dataViews", - "id": "def-common.DataViewSpec.fieldFormats", - "type": "Object", + "id": "def-common.DataViewSpec.fieldFormats", + "type": "Object", + "tags": [], + "label": "fieldFormats", + "description": [], + "signature": [ + "Record> | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewSpec.runtimeFieldMap", + "type": "Object", + "tags": [], + "label": "runtimeFieldMap", + "description": [], + "signature": [ + "Record | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewSpec.fieldAttrs", + "type": "Object", + "tags": [], + "label": "fieldAttrs", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldAttrs", + "text": "FieldAttrs" + }, + " | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewSpec.allowNoIndex", + "type": "CompoundType", + "tags": [], + "label": "allowNoIndex", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewSpec.namespaces", + "type": "Array", + "tags": [], + "label": "namespaces", + "description": [], + "signature": [ + "string[] | undefined" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods", + "type": "Interface", + "tags": [], + "label": "DataViewsServicePublicMethods", + "description": [], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.clearCache", + "type": "Function", + "tags": [], + "label": "clearCache", + "description": [], + "signature": [ + "(id?: string | undefined) => void" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.clearCache.$1", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.create", + "type": "Function", + "tags": [], + "label": "create", + "description": [], + "signature": [ + "(spec: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + }, + ", skipFetchFields?: boolean | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + ">" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.create.$1", + "type": "Object", + "tags": [], + "label": "spec", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.create.$2", + "type": "CompoundType", + "tags": [], + "label": "skipFetchFields", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createAndSave", + "type": "Function", + "tags": [], + "label": "createAndSave", + "description": [], + "signature": [ + "(spec: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + }, + ", override?: boolean | undefined, skipFetchFields?: boolean | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + ">" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createAndSave.$1", + "type": "Object", + "tags": [], + "label": "spec", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createAndSave.$2", + "type": "CompoundType", + "tags": [], + "label": "override", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createAndSave.$3", + "type": "CompoundType", + "tags": [], + "label": "skipFetchFields", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createSavedObject", + "type": "Function", + "tags": [], + "label": "createSavedObject", + "description": [], + "signature": [ + "(indexPattern: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + ", override?: boolean | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + ">" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createSavedObject.$1", + "type": "Object", + "tags": [], + "label": "indexPattern", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.createSavedObject.$2", + "type": "CompoundType", + "tags": [], + "label": "override", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.delete", + "type": "Function", + "tags": [], + "label": "delete", + "description": [], + "signature": [ + "(indexPatternId: string) => Promise<{}>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.delete.$1", + "type": "string", + "tags": [], + "label": "indexPatternId", + "description": [], + "signature": [ + "string" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.ensureDefaultDataView", + "type": "Function", + "tags": [], + "label": "ensureDefaultDataView", + "description": [], + "signature": [ + "() => Promise | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "returnComment": [], + "children": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.fieldArrayToMap", + "type": "Function", + "tags": [], + "label": "fieldArrayToMap", + "description": [], + "signature": [ + "(fields: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldSpec", + "text": "FieldSpec" + }, + "[], fieldAttrs?: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldAttrs", + "text": "FieldAttrs" + }, + " | undefined) => ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewFieldMap", + "text": "DataViewFieldMap" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.fieldArrayToMap.$1", + "type": "Array", + "tags": [], + "label": "fields", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldSpec", + "text": "FieldSpec" + }, + "[]" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.fieldArrayToMap.$2", + "type": "Object", + "tags": [], + "label": "fieldAttrs", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldAttrs", + "text": "FieldAttrs" + }, + " | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.find", + "type": "Function", + "tags": [], + "label": "find", + "description": [], + "signature": [ + "(search: string, size?: number | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + "[]>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.find.$1", + "type": "string", + "tags": [], + "label": "search", + "description": [], + "signature": [ + "string" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.find.$2", + "type": "number", + "tags": [], + "label": "size", + "description": [], + "signature": [ + "number | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.get", + "type": "Function", + "tags": [], + "label": "get", + "description": [], + "signature": [ + "(id: string) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + ">" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.get.$1", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "signature": [ + "string" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getCache", + "type": "Function", + "tags": [], + "label": "getCache", + "description": [], + "signature": [ + "() => Promise<", + "SavedObject", + "<", + "IndexPatternSavedObjectAttrs", + ">[] | null | undefined>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getCanSave", + "type": "Function", + "tags": [], + "label": "getCanSave", + "description": [], + "signature": [ + "() => Promise" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getDefault", + "type": "Function", + "tags": [], + "label": "getDefault", + "description": [], + "signature": [ + "() => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + " | null>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getDefaultId", + "type": "Function", + "tags": [], + "label": "getDefaultId", + "description": [], + "signature": [ + "() => Promise" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getDefaultDataView", + "type": "Function", + "tags": [], + "label": "getDefaultDataView", + "description": [], + "signature": [ + "() => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + " | null>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getFieldsForIndexPattern", + "type": "Function", + "tags": [], + "label": "getFieldsForIndexPattern", + "description": [], + "signature": [ + "(indexPattern: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + " | ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + }, + ", options?: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.GetFieldsOptions", + "text": "GetFieldsOptions" + }, + " | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldSpec", + "text": "FieldSpec" + }, + "[]>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getFieldsForIndexPattern.$1", + "type": "CompoundType", + "tags": [], + "label": "indexPattern", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + " | ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getFieldsForIndexPattern.$2", + "type": "Object", + "tags": [], + "label": "options", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.GetFieldsOptions", + "text": "GetFieldsOptions" + }, + " | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getFieldsForWildcard", + "type": "Function", + "tags": [], + "label": "getFieldsForWildcard", + "description": [], + "signature": [ + "(options: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.GetFieldsOptions", + "text": "GetFieldsOptions" + }, + ") => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.FieldSpec", + "text": "FieldSpec" + }, + "[]>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getFieldsForWildcard.$1", + "type": "Object", + "tags": [], + "label": "options", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.GetFieldsOptions", + "text": "GetFieldsOptions" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getIds", + "type": "Function", + "tags": [], + "label": "getIds", + "description": [], + "signature": [ + "(refresh?: boolean | undefined) => Promise" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getIds.$1", + "type": "CompoundType", + "tags": [], + "label": "refresh", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getIdsWithTitle", + "type": "Function", + "tags": [], + "label": "getIdsWithTitle", + "description": [], + "signature": [ + "(refresh?: boolean | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewListItem", + "text": "DataViewListItem" + }, + "[]>" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getIdsWithTitle.$1", + "type": "CompoundType", + "tags": [], + "label": "refresh", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getTitles", + "type": "Function", + "tags": [], + "label": "getTitles", + "description": [], + "signature": [ + "(refresh?: boolean | undefined) => Promise" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.getTitles.$1", + "type": "CompoundType", + "tags": [], + "label": "refresh", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.hasUserDataView", + "type": "Function", + "tags": [], + "label": "hasUserDataView", + "description": [], + "signature": [ + "() => Promise" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.refreshFields", + "type": "Function", "tags": [], - "label": "fieldFormats", + "label": "refreshFields", "description": [], "signature": [ - "Record Promise" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ { - "pluginId": "fieldFormats", - "scope": "common", - "docId": "kibFieldFormatsPluginApi", - "section": "def-common.FieldFormatParams", - "text": "FieldFormatParams" - }, - ">> | undefined" + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.refreshFields.$1", + "type": "Object", + "tags": [], + "label": "indexPattern", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + } ], - "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "returnComment": [] }, { "parentPluginId": "dataViews", - "id": "def-common.DataViewSpec.runtimeFieldMap", - "type": "Object", + "id": "def-common.DataViewsServicePublicMethods.savedObjectToSpec", + "type": "Function", "tags": [], - "label": "runtimeFieldMap", + "label": "savedObjectToSpec", "description": [], "signature": [ - "Record | undefined" - ], - "path": "src/plugins/data_views/common/types.ts", - "deprecated": false - }, - { - "parentPluginId": "dataViews", - "id": "def-common.DataViewSpec.fieldAttrs", - "type": "Object", - "tags": [], - "label": "fieldAttrs", - "description": [], - "signature": [ + ">) => ", { "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined" + "section": "def-common.DataViewSpec", + "text": "DataViewSpec" + } ], - "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.savedObjectToSpec.$1", + "type": "Object", + "tags": [], + "label": "savedObject", + "description": [], + "signature": [ + "SavedObject", + "<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataViewAttributes", + "text": "DataViewAttributes" + }, + ">" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] }, { "parentPluginId": "dataViews", - "id": "def-common.DataViewSpec.allowNoIndex", - "type": "CompoundType", + "id": "def-common.DataViewsServicePublicMethods.setDefault", + "type": "Function", "tags": [], - "label": "allowNoIndex", + "label": "setDefault", "description": [], "signature": [ - "boolean | undefined" + "(id: string | null, force?: boolean | undefined) => Promise" ], - "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.setDefault.$1", + "type": "CompoundType", + "tags": [], + "label": "id", + "description": [], + "signature": [ + "string | null" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.setDefault.$2", + "type": "CompoundType", + "tags": [], + "label": "force", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] }, { "parentPluginId": "dataViews", - "id": "def-common.DataViewSpec.namespaces", - "type": "Array", + "id": "def-common.DataViewsServicePublicMethods.updateSavedObject", + "type": "Function", "tags": [], - "label": "namespaces", + "label": "updateSavedObject", "description": [], "signature": [ - "string[] | undefined" + "(indexPattern: ", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + ", saveAttempts?: number | undefined, ignoreErrors?: boolean | undefined) => Promise" ], - "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.updateSavedObject.$1", + "type": "Object", + "tags": [], + "label": "indexPattern", + "description": [], + "signature": [ + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + } + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.updateSavedObject.$2", + "type": "number", + "tags": [], + "label": "saveAttempts", + "description": [], + "signature": [ + "number | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DataViewsServicePublicMethods.updateSavedObject.$3", + "type": "CompoundType", + "tags": [], + "label": "ignoreErrors", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/data_views/common/data_views/data_views.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] } ], "initialIsOpen": false @@ -19275,36 +20063,94 @@ }, { "parentPluginId": "dataViews", - "id": "def-common.GetFieldsOptionsTimePattern.metaFields", - "type": "Array", + "id": "def-common.GetFieldsOptionsTimePattern.metaFields", + "type": "Array", + "tags": [], + "label": "metaFields", + "description": [], + "signature": [ + "string[]" + ], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.GetFieldsOptionsTimePattern.lookBack", + "type": "number", + "tags": [], + "label": "lookBack", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.GetFieldsOptionsTimePattern.interval", + "type": "string", + "tags": [], + "label": "interval", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.HasDataService", + "type": "Interface", + "tags": [], + "label": "HasDataService", + "description": [], + "path": "src/plugins/data_views/common/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "dataViews", + "id": "def-common.HasDataService.hasESData", + "type": "Function", "tags": [], - "label": "metaFields", + "label": "hasESData", "description": [], "signature": [ - "string[]" + "() => Promise" ], "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "deprecated": false, + "children": [], + "returnComment": [] }, { "parentPluginId": "dataViews", - "id": "def-common.GetFieldsOptionsTimePattern.lookBack", - "type": "number", + "id": "def-common.HasDataService.hasUserDataView", + "type": "Function", "tags": [], - "label": "lookBack", + "label": "hasUserDataView", "description": [], + "signature": [ + "() => Promise" + ], "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "deprecated": false, + "children": [], + "returnComment": [] }, { "parentPluginId": "dataViews", - "id": "def-common.GetFieldsOptionsTimePattern.interval", - "type": "string", + "id": "def-common.HasDataService.hasDataView", + "type": "Function", "tags": [], - "label": "interval", + "label": "hasDataView", "description": [], + "signature": [ + "() => Promise" + ], "path": "src/plugins/data_views/common/types.ts", - "deprecated": false + "deprecated": false, + "children": [], + "returnComment": [] } ], "initialIsOpen": false @@ -19587,35 +20433,11 @@ }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx" + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts" }, { "plugin": "data", @@ -19645,70 +20467,6 @@ "plugin": "data", "path": "src/plugins/data/server/index.ts" }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_by_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, { "plugin": "data", "path": "src/plugins/data/public/query/timefilter/lib/extract_time_filter.test.ts" @@ -20306,64 +21064,20 @@ "path": "x-pack/plugins/monitoring/public/lib/kuery.ts" }, { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/services/es_index_service.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/services/es_index_service.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/server/routes/api/transforms.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/alerts/components/param_details_form/use_derived_index_pattern.d.ts" }, { - "plugin": "transform", - "path": "x-pack/plugins/transform/server/routes/api/transforms.ts" + "plugin": "monitoring", + "path": "x-pack/plugins/monitoring/target/types/public/alerts/components/param_details_form/use_derived_index_pattern.d.ts" }, { "plugin": "data", @@ -22382,42 +23096,6 @@ { "plugin": "data", "path": "src/plugins/data/common/index.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/timeseries_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/public/utils/saved_visualization_references/timeseries_references.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" - }, - { - "plugin": "visualizations", - "path": "src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts" } ], "initialIsOpen": false @@ -22451,14 +23129,6 @@ "plugin": "data", "path": "src/plugins/data/public/index.ts" }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, { "plugin": "canvas", "path": "x-pack/plugins/canvas/public/lib/es_service.ts" @@ -22474,34 +23144,6 @@ { "plugin": "data", "path": "src/plugins/data/server/index.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/components/layout/types.ts" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_app.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" - }, - { - "plugin": "discover", - "path": "src/plugins/discover/public/application/main/discover_main_route.tsx" } ], "initialIsOpen": false @@ -22884,38 +23526,6 @@ "plugin": "data", "path": "src/plugins/data/public/search/search_service.ts" }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable.tsx" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/utils.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/embeddable/embeddable_factory.ts" - }, { "plugin": "maps", "path": "x-pack/plugins/maps/public/lazy_load_bundle/index.ts" @@ -22932,57 +23542,29 @@ "plugin": "graph", "path": "x-pack/plugins/graph/public/application.tsx" }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "stackAlerts", - "path": "x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "transform", - "path": "x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, - { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" - }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "path": "x-pack/plugins/lens/target/types/public/utils.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "lens", - "path": "x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts" + "plugin": "maps", + "path": "x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/helpers/plugin_services.ts" + "plugin": "stackAlerts", + "path": "x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts" }, { "plugin": "data", @@ -23001,12 +23583,20 @@ "path": "src/plugins/data/public/actions/filters/create_filters_from_value_click.test.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/index_pattern_select.d.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/index_pattern_select.d.ts" }, { - "plugin": "visTypeTimelion", - "path": "src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts" + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/create_index_pattern_select.d.ts" + }, + { + "plugin": "data", + "path": "src/plugins/data/target/types/public/ui/index_pattern_select/create_index_pattern_select.d.ts" } ], "initialIsOpen": false @@ -23156,10 +23746,10 @@ "objects": [ { "parentPluginId": "dataViews", - "id": "def-common.FLEET_ASSETS_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE", "type": "Object", "tags": [], - "label": "FLEET_ASSETS_TO_IGNORE", + "label": "DEFAULT_ASSETS_TO_IGNORE", "description": [ "\nUsed to determine if the instance has any user created index patterns by filtering index patterns\nthat are created and backed only by Fleet server data\nShould be revised after https://github.com/elastic/kibana/issues/82851 is fixed\nFor more background see: https://github.com/elastic/kibana/issues/107020" ], @@ -23168,7 +23758,7 @@ "children": [ { "parentPluginId": "dataViews", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.LOGS_INDEX_PATTERN", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.LOGS_INDEX_PATTERN", "type": "string", "tags": [], "label": "LOGS_INDEX_PATTERN", @@ -23178,7 +23768,7 @@ }, { "parentPluginId": "dataViews", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.METRICS_INDEX_PATTERN", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.METRICS_INDEX_PATTERN", "type": "string", "tags": [], "label": "METRICS_INDEX_PATTERN", @@ -23188,7 +23778,7 @@ }, { "parentPluginId": "dataViews", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.LOGS_DATA_STREAM_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.LOGS_DATA_STREAM_TO_IGNORE", "type": "string", "tags": [], "label": "LOGS_DATA_STREAM_TO_IGNORE", @@ -23198,7 +23788,7 @@ }, { "parentPluginId": "dataViews", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.METRICS_DATA_STREAM_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.METRICS_DATA_STREAM_TO_IGNORE", "type": "string", "tags": [], "label": "METRICS_DATA_STREAM_TO_IGNORE", @@ -23208,7 +23798,17 @@ }, { "parentPluginId": "dataViews", - "id": "def-common.FLEET_ASSETS_TO_IGNORE.METRICS_ENDPOINT_INDEX_TO_IGNORE", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.ENT_SEARCH_LOGS_DATA_STREAM_TO_IGNORE", + "type": "string", + "tags": [], + "label": "ENT_SEARCH_LOGS_DATA_STREAM_TO_IGNORE", + "description": [], + "path": "src/plugins/data_views/common/constants.ts", + "deprecated": false + }, + { + "parentPluginId": "dataViews", + "id": "def-common.DEFAULT_ASSETS_TO_IGNORE.METRICS_ENDPOINT_INDEX_TO_IGNORE", "type": "string", "tags": [], "label": "METRICS_ENDPOINT_INDEX_TO_IGNORE", diff --git a/api_docs/data_views.mdx b/api_docs/data_views.mdx index 02a74e15cdf55..4c71562979145 100644 --- a/api_docs/data_views.mdx +++ b/api_docs/data_views.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dataViews title: "dataViews" image: https://source.unsplash.com/400x175/?github summary: API docs for the dataViews plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataViews'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 765 | 3 | 616 | 10 | +| 863 | 3 | 711 | 15 | ## Client diff --git a/api_docs/data_visualizer.devdocs.json b/api_docs/data_visualizer.devdocs.json index 8bdc2a75d8605..f1872077f3338 100644 --- a/api_docs/data_visualizer.devdocs.json +++ b/api_docs/data_visualizer.devdocs.json @@ -16,18 +16,18 @@ "children": [ { "parentPluginId": "dataVisualizer", - "id": "def-public.IndexDataVisualizerViewProps.currentIndexPattern", + "id": "def-public.IndexDataVisualizerViewProps.currentDataView", "type": "Object", "tags": [], - "label": "currentIndexPattern", + "label": "currentDataView", "description": [], "signature": [ { "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" + "section": "def-common.DataView", + "text": "DataView" } ], "path": "x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/index_data_visualizer_view/index_data_visualizer_view.tsx", diff --git a/api_docs/data_visualizer.mdx b/api_docs/data_visualizer.mdx index f74403095f857..0ca7eaa1ebd7a 100644 --- a/api_docs/data_visualizer.mdx +++ b/api_docs/data_visualizer.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/dataVisualizer title: "dataVisualizer" image: https://source.unsplash.com/400x175/?github summary: API docs for the dataVisualizer plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'dataVisualizer'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/deprecations_by_api.mdx b/api_docs/deprecations_by_api.mdx index 4236c0599f5fd..4443dcb6ff4b0 100644 --- a/api_docs/deprecations_by_api.mdx +++ b/api_docs/deprecations_by_api.mdx @@ -3,7 +3,7 @@ id: kibDevDocsDeprecationsByApi slug: /kibana-dev-docs/api-meta/deprecated-api-list-by-api title: Deprecated API usage by API summary: A list of deprecated APIs, which plugins are still referencing them, and when they need to be removed by. -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. --- @@ -13,54 +13,45 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Referencing plugin(s) | Remove By | | ---------------|-----------|-----------| -| | dataViews, visTypeTimeseries, maps, data | - | -| | dataViews, lens, maps, graph, stackAlerts, transform, visTypeTimelion, data | - | -| | dataViews, visTypeTimeseries, dataVisualizer, transform, ux, lens, savedObjects, dataViewEditor, visualizations, graph, stackAlerts, uptime, maps, visDefaultEditor, visTypeVega, data | - | -| | dataViews, dataVisualizer, lens, dataViewEditor, maps, visDefaultEditor, visTypeTimeseries, discover, data | - | -| | dataViews, monitoring, stackAlerts, transform | - | -| | dataViews, transform, canvas, discover | - | -| | dataViews, monitoring, stackAlerts, transform, data | - | -| | dataViews, transform, canvas, discover, data | - | -| | dataViews, lens, maps, graph, stackAlerts, transform, visTypeTimelion, data | - | -| | dataViews, visualizations, data | - | -| | dataViews, dataVisualizer, lens, dataViewEditor, maps, visDefaultEditor, visTypeTimeseries, discover, data | - | -| | dataViews, visTypeTimeseries, maps, data | - | -| | dataViews, visualizations, dashboard, lens | - | -| | dataViews, visTypeTimeseries, dataVisualizer, transform, ux, lens, savedObjects, dataViewEditor, visualizations, graph, stackAlerts, uptime, maps, visDefaultEditor, visTypeVega, data | - | +| | dataViews, maps, data | - | +| | dataViews, maps, graph, lens, stackAlerts, data | - | +| | dataViews, upgradeAssistant, dashboard, visualizations, discover, ux, maps, savedObjects, dataViewEditor, graph, uptime, lens, stackAlerts, visDefaultEditor, dataViewFieldEditor, inputControlVis, visTypeTimeseries, data | - | +| | dataViews, maps, lens, dataViewEditor, visDefaultEditor, data | - | +| | dataViews, monitoring | - | +| | dataViews, canvas | - | +| | dataViews, monitoring, data | - | +| | dataViews, canvas, data | - | +| | dataViews, maps, graph, lens, stackAlerts, data | - | +| | dataViews, data | - | +| | dataViews, maps, lens, dataViewEditor, visDefaultEditor, data | - | +| | dataViews, maps, data | - | +| | dataViews | - | +| | dataViews, upgradeAssistant, dashboard, visualizations, discover, ux, maps, savedObjects, dataViewEditor, graph, uptime, lens, stackAlerts, visDefaultEditor, dataViewFieldEditor, inputControlVis, visTypeTimeseries, data | - | | | dataViews, maps | - | | | dataViewManagement, dataViews | - | | | visTypeTimeseries, graph, dataViewManagement, dataViews | - | | | dataViews, dataViewManagement | - | -| | dataViews, transform, canvas, discover | - | -| | dataViews, dataVisualizer, lens, dataViewEditor, maps, visDefaultEditor, visTypeTimeseries, discover | - | -| | dataViews, visTypeTimeseries, dataVisualizer, transform, ux, lens, savedObjects, dataViewEditor, visualizations, graph, stackAlerts, uptime, maps, visDefaultEditor, visTypeVega | - | -| | dataViews, visTypeTimeseries, maps | - | +| | dataViews, canvas | - | +| | dataViews, maps, lens, dataViewEditor, visDefaultEditor | - | +| | dataViews, upgradeAssistant, dashboard, visualizations, discover, ux, maps, savedObjects, dataViewEditor, graph, uptime, lens, stackAlerts, visDefaultEditor, dataViewFieldEditor, inputControlVis, visTypeTimeseries | - | +| | dataViews, maps | - | | | dataViews, maps | - | | | dataViewManagement, dataViews | - | | | visTypeTimeseries, graph, dataViewManagement, dataViews | - | | | dataViews, dataViewManagement | - | -| | discover, visualizations, lens, maps, fileUpload, dataVisualizer, infra, graph, monitoring, securitySolution, stackAlerts, transform, uptime, inputControlVis, visTypeTimelion, visTypeTimeseries, visTypeVega, savedObjects | - | -| | discover, dashboard, lens, stackAlerts, visTypeTable, visTypeTimeseries, visTypeXy, visTypeVislib, expressionPartitionVis | - | -| | visTypeTimeseries | - | -| | visTypeTimeseries, graph, dataViewManagement | - | -| | data, lens, visTypeTimeseries, infra, maps, visTypeTimelion | - | +| | discover, maps, fileUpload, infra, graph, monitoring, securitySolution, stackAlerts, uptime, inputControlVis, savedObjects | - | | | maps | - | +| | data, infra, maps | - | | | dashboard, maps | - | -| | visualizations, dashboard, maps, graph | - | -| | visualizations, dashboard, lens, maps, ml, securitySolution, security | - | -| | lens, dashboard, maps | - | -| | visualizations, dashboard, lens | - | -| | savedObjectsTaggingOss, visualizations, dashboard, lens | - | -| | embeddable, presentationUtil, discover, dashboard, graph | - | -| | spaces, security, actions, alerting, ml, remoteClusters, graph, indexLifecycleManagement, mapsEms, painlessLab, rollup, searchprofiler, snapshotRestore, transform, upgradeAssistant | - | -| | visTypeVega | - | -| | monitoring, visTypeVega | - | +| | visTypeTimeseries, graph, dataViewManagement | - | +| | discover, dashboard, lens, stackAlerts, visTypeTable, visTypeTimeseries, visTypeXy, visTypeVislib, dataViewFieldEditor, expressionPartitionVis | - | +| | esUiShared, home, spaces, fleet, visualizations, lens, observability, dataEnhanced, ml, apm, cloudSecurityPosture, indexLifecycleManagement, upgradeAssistant, uptime, ux, kibanaOverview, savedObjectsManagement | - | | | discover | - | | | discover | - | | | data, discover, embeddable | - | | | advancedSettings, discover | - | | | advancedSettings, discover | - | -| | monitoring, kibanaUsageCollection | - | +| | visTypeTimeseries | - | | | canvas, visTypeXy | - | | | canvas | - | | | canvas | - | @@ -71,48 +62,68 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | canvas | - | | | canvas | - | | | canvas, visTypeXy | - | -| | apm, security, securitySolution | - | -| | apm, security, securitySolution | - | | | encryptedSavedObjects, actions, cloud, ml, dataEnhanced, logstash, securitySolution | - | -| | securitySolution | - | -| | dashboard | - | -| | actions, alerting | - | -| | cloud, apm | - | -| | security, licenseManagement, ml, apm, crossClusterReplication, logstash, painlessLab, searchprofiler, watcher | - | | | dataViewManagement | - | | | dataViewManagement | - | +| | spaces, savedObjectsManagement | - | +| | spaces, savedObjectsManagement | - | | | actions, ml, enterpriseSearch, savedObjectsTagging | - | | | visTypeGauge | - | | | visTypePie | - | | | visTypePie | - | -| | security, fleet | - | -| | security | - | -| | security, fleet | - | -| | security, fleet | - | -| | security | - | -| | management, fleet, security, kibanaOverview | - | -| | ml | - | -| | spaces, savedObjectsManagement | - | -| | spaces, savedObjectsManagement | - | -| | mapsEms | - | +| | actions, alerting | - | | | console | - | | | discover, maps, inputControlVis | 8.1 | | | discover, discoverEnhanced, maps | 8.1 | -| | dashboard, discoverEnhanced, urlDrilldown, discover, maps | 8.1 | -| | dashboard, discoverEnhanced, urlDrilldown, discover, maps | 8.1 | +| | discover, dashboard, discoverEnhanced, urlDrilldown, maps | 8.1 | +| | discover, dashboard, discoverEnhanced, urlDrilldown, maps | 8.1 | | | discover, maps, inputControlVis | 8.1 | -| | dashboard, discoverEnhanced, urlDrilldown, discover, maps | 8.1 | -| | apm, graph, stackAlerts | 8.1 | -| | stackAlerts | 8.1 | +| | discover, dashboard, discoverEnhanced, urlDrilldown, maps | 8.1 | +| | apm, graph | 8.1 | | | discoverEnhanced | 8.1 | | | discoverEnhanced | 8.1 | -| | alerting, dataEnhanced | 8.1 | -| | alerting, dataEnhanced | 8.1 | -| | actions, alerting, dataEnhanced | 8.1 | -| | alerting, dataEnhanced | 8.1 | +| | dataEnhanced | 8.1 | +| | dataEnhanced | 8.1 | +| | dataEnhanced | 8.1 | +| | dataEnhanced | 8.1 | | | dataViews, stackAlerts | 8.2 | | | dataViews, stackAlerts, data | 8.2 | | | dataViews, stackAlerts | 8.2 | +| | visualizations, dashboard, maps, graph | 8.8.0 | +| | visualizations, dashboard, lens, maps, ml, securitySolution, security | 8.8.0 | +| | lens, dashboard, maps | 8.8.0 | +| | embeddable, presentationUtil, discover, dashboard, graph | 8.8.0 | +| | spaces, security, actions, alerting, ml, remoteClusters, graph, indexLifecycleManagement, mapsEms, painlessLab, rollup, searchprofiler, snapshotRestore, transform, upgradeAssistant | 8.8.0 | +| | savedObjectsTaggingOss, visualizations, dashboard, lens | 8.8.0 | +| | dashboard | 8.8.0 | +| | monitoring, visTypeVega | 8.8.0 | +| | monitoring, kibanaUsageCollection | 8.8.0 | +| | apm, security, securitySolution | 8.8.0 | +| | apm, security, securitySolution | 8.8.0 | +| | securitySolution | 8.8.0 | +| | cloud, apm | 8.8.0 | +| | security, licenseManagement, ml, apm, crossClusterReplication, logstash, painlessLab, searchprofiler, watcher | 8.8.0 | +| | spaces, security, alerting | 8.8.0 | +| | security, fleet | 8.8.0 | +| | security, fleet | 8.8.0 | +| | security, fleet | 8.8.0 | +| | management, fleet, security, kibanaOverview | 8.8.0 | +| | fleet | 8.8.0 | +| | security | 8.8.0 | +| | mapsEms | 8.8.0 | +| | visTypeVega | 8.8.0 | +| | ml | 8.8.0 + +Note to maintainers: when looking at usages, mind that typical use could be inside a `catch` block, +so TS and code-reference navigation might not highlight them. | +| | security | 8.8.0 + +This is relied on by the reporting feature, and should be removed once reporting +migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 | +| | security | 8.8.0 + +This is relied on by the reporting feature, and should be removed once reporting +migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 | ## Unreferenced deprecated APIs @@ -129,63 +140,69 @@ Safe to remove. | | data | | | data | | | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | +| | data | +| | data | +| | data | +| | data | +| | data | +| | data | +| | data | | | data | -| | data | -| | data | +| | data | +| | data | +| | data | | | data | | | data | -| | data | -| | data | | | data | -| | data | +| | data | +| | data | +| | data | +| | data | | | data | -| | data | -| | data | +| | data | | | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | -| | data | +| | data | +| | data | +| | data | +| | data | | | data | -| | data | +| | data | +| | data | +| | data | +| | data | +| | data | +| | data | | | data | +| | data | +| | data | +| | data | +| | data | | | data | +| | data | +| | data | +| | data | +| | data | +| | data | +| | data | | | data | | | data | | | data | | | data | +| | dataViews | +| | dataViews | | | expressions | | | expressions | | | expressions | +| | expressions | | | expressions | | | expressions | +| | expressions | | | expressions | | | expressions | | | expressions | | | expressions | | | expressions | +| | expressions | | | licensing | | | licensing | | | licensing | @@ -195,5 +212,4 @@ Safe to remove. | | reporting | | | taskManager | | | core | -| | core | | | core | \ No newline at end of file diff --git a/api_docs/deprecations_by_plugin.mdx b/api_docs/deprecations_by_plugin.mdx index e226f7c46d494..1a9c18eec9eac 100644 --- a/api_docs/deprecations_by_plugin.mdx +++ b/api_docs/deprecations_by_plugin.mdx @@ -3,7 +3,7 @@ id: kibDevDocsDeprecationsByPlugin slug: /kibana-dev-docs/api-meta/deprecated-api-list-by-plugin title: Deprecated API usage by plugin summary: A list of deprecated APIs, which plugins are still referencing them, and when they need to be removed by. -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. --- @@ -13,8 +13,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder) | 8.1 | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/lib/license_state.test.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/lib/license_state.test.ts#:~:text=license%24) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/lib/license_state.test.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/lib/license_state.test.ts#:~:text=license%24) | 8.8.0 | | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=authc) | - | | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=authz) | - | | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=index), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=index) | - | @@ -34,11 +33,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode) | 8.1 | -| | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode) | 8.1 | -| | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=nodeBuilder), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=nodeBuilder), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=nodeBuilder) | 8.1 | -| | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode) | 8.1 | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/plugin.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/lib/license_state.test.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/lib/license_state.test.ts#:~:text=license%24) | - | +| | [plugin.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/plugin.test.ts#:~:text=getKibanaFeatures) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/plugin.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/lib/license_state.test.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/lib/license_state.test.ts#:~:text=license%24) | 8.8.0 | | | [task.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/usage/task.ts#:~:text=index) | - | @@ -48,10 +44,11 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/shared/kuery_bar/index.tsx#:~:text=esKuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/shared/kuery_bar/index.tsx#:~:text=esKuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/shared/kuery_bar/index.tsx#:~:text=esKuery) | 8.1 | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/plugin.ts#:~:text=environment) | - | -| | [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode)+ 2 more | - | -| | [license_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/context/license/license_context.tsx#:~:text=license%24) | - | -| | [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode)+ 2 more | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/plugin.ts#:~:text=environment) | 8.8.0 | +| | [app_root.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/routing/app_root.tsx#:~:text=RedirectAppLinks), [app_root.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/routing/app_root.tsx#:~:text=RedirectAppLinks), [app_root.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/routing/app_root.tsx#:~:text=RedirectAppLinks) | - | +| | [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode)+ 2 more | 8.8.0 | +| | [license_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/context/license/license_context.tsx#:~:text=license%24) | 8.8.0 | +| | [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode)+ 2 more | 8.8.0 | @@ -66,7 +63,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [setup_expressions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/setup_expressions.ts#:~:text=getFunction) | - | | | [application.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/application.tsx#:~:text=getFunctions), [functions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.ts#:~:text=getFunctions), [functions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.ts#:~:text=getFunctions), [functions.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.test.ts#:~:text=getFunctions) | - | | | [setup_expressions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/setup_expressions.ts#:~:text=getTypes), [application.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/application.tsx#:~:text=getTypes), [functions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.ts#:~:text=getTypes) | - | -| | [state.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/types/state.ts#:~:text=Render), [state.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/types/state.ts#:~:text=Render), [markdown.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/markdown.ts#:~:text=Render), [markdown.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/markdown.ts#:~:text=Render), [timefilterControl.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/common/timefilterControl.ts#:~:text=Render), [timefilterControl.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/common/timefilterControl.ts#:~:text=Render), [pie.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/functions/pie.ts#:~:text=Render), [pie.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/functions/pie.ts#:~:text=Render), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/functions/plot/index.ts#:~:text=Render), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/functions/plot/index.ts#:~:text=Render)+ 2 more | - | +| | [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/target/types/public/functions/index.d.ts#:~:text=Render), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/target/types/public/functions/index.d.ts#:~:text=Render), [state.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/types/state.ts#:~:text=Render), [state.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/types/state.ts#:~:text=Render), [state.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/target/types/types/state.d.ts#:~:text=Render), [state.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/target/types/types/state.d.ts#:~:text=Render), [markdown.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/markdown.ts#:~:text=Render), [markdown.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/markdown.ts#:~:text=Render), [timefilterControl.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/common/timefilterControl.ts#:~:text=Render), [timefilterControl.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/common/timefilterControl.ts#:~:text=Render)+ 8 more | - | | | [embeddable.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/external/embeddable.ts#:~:text=context), [filters.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/common/functions/filters.ts#:~:text=context), [escount.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/escount.ts#:~:text=context), [esdocs.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/esdocs.ts#:~:text=context), [essql.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/browser/essql.ts#:~:text=context), [neq.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/common/neq.ts#:~:text=context), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/server/pointseries/index.ts#:~:text=context), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/canvas_plugin_src/functions/server/demodata/index.ts#:~:text=context) | - | | | [setup_expressions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/setup_expressions.ts#:~:text=getFunction) | - | | | [application.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/public/application.tsx#:~:text=getFunctions), [functions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.ts#:~:text=getFunctions), [functions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.ts#:~:text=getFunctions), [functions.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/canvas/server/routes/functions/functions.test.ts#:~:text=getFunctions) | - | @@ -79,11 +76,19 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud/public/plugin.tsx#:~:text=environment) | - | +| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud/public/plugin.tsx#:~:text=environment) | 8.8.0 | | | [chat.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud/server/routes/chat.ts#:~:text=authc) | - | +## cloudSecurityPosture + +| Deprecated API | Reference location(s) | Remove By | +| ---------------|-----------|-----------| +| | [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud_security_posture/public/application/app.tsx#:~:text=RedirectAppLinks), [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud_security_posture/public/application/app.tsx#:~:text=RedirectAppLinks), [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud_security_posture/public/application/app.tsx#:~:text=RedirectAppLinks) | - | + + + ## console | Deprecated API | Reference location(s) | Remove By | @@ -96,7 +101,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cross_cluster_replication/public/plugin.ts#:~:text=license%24) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cross_cluster_replication/public/plugin.ts#:~:text=license%24) | 8.8.0 | @@ -104,19 +109,20 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| +| | [load_saved_dashboard_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts#:~:text=IndexPattern), [use_dashboard_app_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts#:~:text=IndexPattern), [load_saved_dashboard_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts#:~:text=IndexPattern), [use_dashboard_app_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts#:~:text=IndexPattern) | - | | | [export_csv_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/export_csv_action.tsx#:~:text=fieldFormats) | - | | | [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter)+ 5 more | 8.1 | -| | [load_saved_dashboard_state.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/load_saved_dashboard_state.ts#:~:text=ensureDefaultDataView), [load_saved_dashboard_state.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/load_saved_dashboard_state.ts#:~:text=ensureDefaultDataView) | - | | | [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter)+ 5 more | 8.1 | +| | [load_saved_dashboard_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts#:~:text=IndexPattern), [use_dashboard_app_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts#:~:text=IndexPattern), [load_saved_dashboard_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts#:~:text=IndexPattern), [use_dashboard_app_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts#:~:text=IndexPattern) | - | +| | [load_saved_dashboard_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/lib/load_saved_dashboard_state.d.ts#:~:text=IndexPattern), [use_dashboard_app_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/application/hooks/use_dashboard_app_state.d.ts#:~:text=IndexPattern) | - | | | [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter)+ 5 more | 8.1 | -| | [load_saved_dashboard_state.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/load_saved_dashboard_state.ts#:~:text=ensureDefaultDataView) | - | | | [kibana_react.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/kibana_react.ts#:~:text=ExitFullScreenButton), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/plugin.tsx#:~:text=ExitFullScreenButton), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/plugin.tsx#:~:text=ExitFullScreenButton), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/plugin.tsx#:~:text=ExitFullScreenButton) | - | -| | [saved_objects.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_objects.ts#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/top_nav/save_modal.tsx#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/top_nav/save_modal.tsx#:~:text=SavedObjectSaveModal) | - | -| | [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_objects.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_objects.ts#:~:text=SavedObject), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObject), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObject), [dashboard_tagging.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/dashboard_tagging.ts#:~:text=SavedObject), [dashboard_tagging.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/dashboard_tagging.ts#:~:text=SavedObject), [clone_panel_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/clone_panel_action.tsx#:~:text=SavedObject), [clone_panel_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/clone_panel_action.tsx#:~:text=SavedObject)+ 1 more | - | -| | [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObjectClass) | - | -| | [dashboard_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/listing/dashboard_listing.tsx#:~:text=settings), [dashboard_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/listing/dashboard_listing.tsx#:~:text=settings) | - | -| | [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/types.ts#:~:text=onAppLeave), [dashboard_router.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/dashboard_router.tsx#:~:text=onAppLeave), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/plugin.tsx#:~:text=onAppLeave) | - | -| | [migrations_730.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/server/saved_objects/migrations_730.ts#:~:text=warning), [migrations_730.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/server/saved_objects/migrations_730.ts#:~:text=warning) | - | +| | [saved_objects.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_objects.ts#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/top_nav/save_modal.tsx#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/top_nav/save_modal.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | +| | [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_objects.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_objects.ts#:~:text=SavedObject), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObject), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObject), [dashboard_tagging.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/dashboard_tagging.ts#:~:text=SavedObject), [dashboard_tagging.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/dashboard_tagging.ts#:~:text=SavedObject), [clone_panel_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/clone_panel_action.tsx#:~:text=SavedObject), [clone_panel_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/clone_panel_action.tsx#:~:text=SavedObject)+ 1 more | 8.8.0 | +| | [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObjectClass) | 8.8.0 | +| | [dashboard_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/listing/dashboard_listing.tsx#:~:text=settings), [dashboard_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/listing/dashboard_listing.tsx#:~:text=settings) | 8.8.0 | +| | [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/types.ts#:~:text=onAppLeave), [dashboard_router.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/dashboard_router.tsx#:~:text=onAppLeave), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/plugin.tsx#:~:text=onAppLeave), [types.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/types.d.ts#:~:text=onAppLeave) | 8.8.0 | +| | [migrations_730.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/server/saved_objects/migrations_730.ts#:~:text=warning), [migrations_730.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/server/saved_objects/migrations_730.ts#:~:text=warning) | 8.8.0 | @@ -125,17 +131,17 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| | | [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternField), [kibana_context_type.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/kibana_context_type.ts#:~:text=IndexPatternField), [kibana_context_type.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/kibana_context_type.ts#:~:text=IndexPatternField), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPatternField), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPatternField), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPatternField)+ 16 more | - | -| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [create_search_source.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.test.ts#:~:text=IndexPatternsContract)+ 25 more | - | +| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [create_search_source.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.test.ts#:~:text=IndexPatternsContract)+ 29 more | - | | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/index.ts#:~:text=IndexPatternsService) | - | -| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern)+ 89 more | - | +| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern)+ 90 more | - | | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE) | - | | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IFieldType), [date_histogram.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/buckets/date_histogram.ts#:~:text=IFieldType), [date_histogram.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/buckets/date_histogram.ts#:~:text=IFieldType), [filter_editor_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts#:~:text=IFieldType), [filter_editor_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts#:~:text=IFieldType), [filter_editor_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts#:~:text=IFieldType), [filter_editor_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/ui/filter_bar/filter_editor/lib/filter_editor_utils.ts#:~:text=IFieldType), [generate_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/query/filter_manager/lib/generate_filters.ts#:~:text=IFieldType), [generate_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/query/filter_manager/lib/generate_filters.ts#:~:text=IFieldType), [generate_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/query/filter_manager/lib/generate_filters.ts#:~:text=IFieldType)+ 43 more | 8.2 | | | [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/aggs/param_types/field.ts#:~:text=IndexPatternField), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternField), [kibana_context_type.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/kibana_context_type.ts#:~:text=IndexPatternField), [kibana_context_type.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/kibana_context_type.ts#:~:text=IndexPatternField), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPatternField), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPatternField), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPatternField)+ 16 more | - | | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IIndexPattern), [get_time.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/query/timefilter/get_time.ts#:~:text=IIndexPattern), [get_time.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/query/timefilter/get_time.ts#:~:text=IIndexPattern), [get_time.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/query/timefilter/get_time.ts#:~:text=IIndexPattern), [get_time.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/query/timefilter/get_time.ts#:~:text=IIndexPattern), [normalize_sort_request.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/normalize_sort_request.ts#:~:text=IIndexPattern), [normalize_sort_request.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/normalize_sort_request.ts#:~:text=IIndexPattern), [normalize_sort_request.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/normalize_sort_request.ts#:~:text=IIndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IIndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IIndexPattern)+ 64 more | - | | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternAttributes), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/index.ts#:~:text=IndexPatternAttributes), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternAttributes) | - | -| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [create_search_source.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.test.ts#:~:text=IndexPatternsContract)+ 25 more | - | +| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [create_search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [search_source_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source_service.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [esaggs_fn.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/expressions/esaggs/esaggs_fn.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/search/types.ts#:~:text=IndexPatternsContract), [create_search_source.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/create_search_source.test.ts#:~:text=IndexPatternsContract)+ 29 more | - | | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/index.ts#:~:text=IndexPatternsService), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/index.ts#:~:text=IndexPatternsService) | - | -| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern)+ 89 more | - | +| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/index.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/types.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [search_source.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/search_source/search_source.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern), [tabify_docs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/common/search/tabify/tabify_docs.ts#:~:text=IndexPattern)+ 90 more | - | | | [aggs_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/search/aggs/aggs_service.ts#:~:text=indexPatternsServiceFactory), [esaggs.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/search/expressions/esaggs.ts#:~:text=indexPatternsServiceFactory), [search_service.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data/server/search/search_service.ts#:~:text=indexPatternsServiceFactory) | - | | | [data_table.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/utils/table_inspector_view/components/data_table.tsx#:~:text=executeTriggerActions), [data_table.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/data/public/utils/table_inspector_view/components/data_table.tsx#:~:text=executeTriggerActions) | - | @@ -145,10 +151,11 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode) | 8.1 | -| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode) | 8.1 | +| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode)+ 2 more | 8.1 | | | [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=nodeBuilder), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder)+ 2 more | 8.1 | -| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode) | 8.1 | +| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode)+ 2 more | 8.1 | +| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode)+ 2 more | 8.1 | +| | [get_columns.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/lib/get_columns.tsx#:~:text=RedirectAppLinks), [get_columns.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/lib/get_columns.tsx#:~:text=RedirectAppLinks), [get_columns.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/lib/get_columns.tsx#:~:text=RedirectAppLinks), [connected_search_session_indicator.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/public/search/ui/connected_search_session_indicator/connected_search_session_indicator.tsx#:~:text=RedirectAppLinks), [connected_search_session_indicator.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/public/search/ui/connected_search_session_indicator/connected_search_session_indicator.tsx#:~:text=RedirectAppLinks), [connected_search_session_indicator.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/public/search/ui/connected_search_session_indicator/connected_search_session_indicator.tsx#:~:text=RedirectAppLinks) | - | | | [session_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/session_service.ts#:~:text=authc) | - | @@ -166,6 +173,17 @@ warning: This document is auto-generated and is meant to be viewed inside our ex +## dataViewFieldEditor + +| Deprecated API | Reference location(s) | Remove By | +| ---------------|-----------|-----------| +| | [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern) | - | +| | [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=fieldFormats) | - | +| | [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern) | - | +| | [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern), [field_format_editor.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_view_field_editor/target/types/public/components/field_format_editor/field_format_editor.d.ts#:~:text=IndexPattern) | - | + + + ## dataViewManagement | Deprecated API | Reference location(s) | Remove By | @@ -218,42 +236,25 @@ warning: This document is auto-generated and is meant to be viewed inside our ex -## dataVisualizer - -| Deprecated API | Reference location(s) | Remove By | -| ---------------|-----------|-----------| -| | [geo_point_content_with_map.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx#:~:text=IndexPattern), [geo_point_content_with_map.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx#:~:text=IndexPattern), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPattern), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPattern), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPattern), [actions_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx#:~:text=IndexPattern)+ 44 more | - | -| | [field_data_row.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts#:~:text=IndexPatternField), [field_data_row.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts#:~:text=IndexPatternField), [field_types_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts#:~:text=IndexPatternField), [field_types_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts#:~:text=IndexPatternField), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPatternField), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPatternField), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPatternField), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPatternField), [grid_embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx#:~:text=IndexPatternField), [grid_embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx#:~:text=IndexPatternField)+ 20 more | - | -| | [file_data_visualizer.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/file_data_visualizer/file_data_visualizer.tsx#:~:text=indexPatterns), [index_data_visualizer.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/index_data_visualizer.tsx#:~:text=indexPatterns) | - | -| | [field_data_row.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts#:~:text=IndexPatternField), [field_data_row.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts#:~:text=IndexPatternField), [field_types_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts#:~:text=IndexPatternField), [field_types_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts#:~:text=IndexPatternField), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPatternField), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPatternField), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPatternField), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPatternField), [grid_embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx#:~:text=IndexPatternField), [grid_embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx#:~:text=IndexPatternField)+ 20 more | - | -| | [geo_point_content_with_map.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx#:~:text=IndexPattern), [geo_point_content_with_map.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx#:~:text=IndexPattern), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPattern), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPattern), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPattern), [actions_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx#:~:text=IndexPattern)+ 44 more | - | -| | [field_data_row.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts#:~:text=IndexPatternField), [field_data_row.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/stats_table/types/field_data_row.ts#:~:text=IndexPatternField), [field_types_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts#:~:text=IndexPatternField), [field_types_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/util/field_types_utils.ts#:~:text=IndexPatternField), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPatternField), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPatternField), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPatternField), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPatternField), [grid_embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx#:~:text=IndexPatternField), [grid_embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/embeddables/grid_embeddable/grid_embeddable.tsx#:~:text=IndexPatternField)+ 5 more | - | -| | [geo_point_content_with_map.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx#:~:text=IndexPattern), [geo_point_content_with_map.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/geo_point_content_with_map/geo_point_content_with_map.tsx#:~:text=IndexPattern), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPattern), [index_based_expanded_row.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/common/components/expanded_row/index_based_expanded_row.tsx#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [saved_search_utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/utils/saved_search_utils.ts#:~:text=IndexPattern), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPattern), [search_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/search_panel/search_panel.tsx#:~:text=IndexPattern), [actions_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_visualizer/public/application/index_data_visualizer/components/actions_panel/actions_panel.tsx#:~:text=IndexPattern)+ 17 more | - | - - - ## discover | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField) | - | -| | [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes) | - | +| | [use_discover_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts#:~:text=IndexPattern), [use_discover_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts#:~:text=IndexPattern) | - | | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=create), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=create) | - | | | [anchor.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/anchor.ts#:~:text=fetch), [fetch_hits_in_interval.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/utils/fetch_hits_in_interval.ts#:~:text=fetch) | 8.1 | -| | [build_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/build_services.ts#:~:text=indexPatterns), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=indexPatterns), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=indexPatterns), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/plugin.tsx#:~:text=indexPatterns) | - | +| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/plugin.tsx#:~:text=indexPatterns) | - | | | [histogram.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/chart/histogram.tsx#:~:text=fieldFormats) | - | | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=esFilters), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=esFilters) | 8.1 | -| | [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter) | 8.1 | -| | [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes)+ 4 more | - | -| | [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField) | - | -| | [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter) | 8.1 | +| | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter) | 8.1 | +| | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter) | 8.1 | +| | [use_discover_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts#:~:text=IndexPattern), [use_discover_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts#:~:text=IndexPattern) | - | | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=create), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=create) | - | | | [anchor.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/anchor.ts#:~:text=fetch), [fetch_hits_in_interval.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/utils/fetch_hits_in_interval.ts#:~:text=fetch) | 8.1 | -| | [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/layout/types.ts#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes), [discover_main_app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_app.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes), [discover_main_route.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/discover_main_route.tsx#:~:text=IndexPatternAttributes) | - | -| | [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [discover_field_visualize_inner.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/discover_field_visualize_inner.tsx#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField), [fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/sidebar/__stories__/fields.ts#:~:text=IndexPatternField) | - | -| | [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter) | 8.1 | -| | [on_save_search.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/top_nav/on_save_search.tsx#:~:text=SavedObjectSaveModal), [on_save_search.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/top_nav/on_save_search.tsx#:~:text=SavedObjectSaveModal) | - | -| | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=executeTriggerActions), [search_embeddable_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/search_embeddable_factory.ts#:~:text=executeTriggerActions), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/plugin.tsx#:~:text=executeTriggerActions) | - | +| | [use_discover_state.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/main/utils/use_discover_state.d.ts#:~:text=IndexPattern) | - | +| | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter) | 8.1 | +| | [on_save_search.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/top_nav/on_save_search.tsx#:~:text=SavedObjectSaveModal), [on_save_search.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/top_nav/on_save_search.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | +| | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=executeTriggerActions), [search_embeddable_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/search_embeddable_factory.ts#:~:text=executeTriggerActions), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/plugin.tsx#:~:text=executeTriggerActions), [search_embeddable_factory.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/embeddable/search_embeddable_factory.d.ts#:~:text=executeTriggerActions) | - | | | [ui_settings.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/server/ui_settings.ts#:~:text=metric), [ui_settings.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/server/ui_settings.ts#:~:text=metric), [ui_settings.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/server/ui_settings.ts#:~:text=metric) | - | | | [ui_settings.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/server/ui_settings.ts#:~:text=metric), [ui_settings.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/server/ui_settings.ts#:~:text=metric), [ui_settings.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/server/ui_settings.ts#:~:text=metric) | - | @@ -276,7 +277,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [attribute_service.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/lib/attribute_service/attribute_service.tsx#:~:text=SavedObjectSaveModal), [attribute_service.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/lib/attribute_service/attribute_service.tsx#:~:text=SavedObjectSaveModal) | - | +| | [attribute_service.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/lib/attribute_service/attribute_service.tsx#:~:text=SavedObjectSaveModal), [attribute_service.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/lib/attribute_service/attribute_service.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | | | [container.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/tests/container.test.ts#:~:text=executeTriggerActions), [container.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/tests/container.test.ts#:~:text=executeTriggerActions), [container.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/tests/container.test.ts#:~:text=executeTriggerActions), [container.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/tests/container.test.ts#:~:text=executeTriggerActions), [explicit_input.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/tests/explicit_input.test.ts#:~:text=executeTriggerActions) | - | @@ -297,11 +298,19 @@ warning: This document is auto-generated and is meant to be viewed inside our ex +## esUiShared + +| Deprecated API | Reference location(s) | Remove By | +| ---------------|-----------|-----------| +| | [view_api_request_flyout.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx#:~:text=RedirectAppLinks), [view_api_request_flyout.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx#:~:text=RedirectAppLinks), [view_api_request_flyout.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx#:~:text=RedirectAppLinks) | - | + + + ## expressionPartitionVis | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats) | - | +| | [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats), [get_layers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/chart_expressions/expression_partition_vis/public/utils/layers/get_layers.test.ts#:~:text=fieldFormats) | - | @@ -317,10 +326,12 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | - | -| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/integrations/index.tsx#:~:text=appBasePath) | - | +| | [tutorial_directory_header_link.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/components/home_integration/tutorial_directory_header_link.tsx#:~:text=RedirectAppLinks), [tutorial_directory_header_link.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/components/home_integration/tutorial_directory_header_link.tsx#:~:text=RedirectAppLinks), [tutorial_directory_header_link.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/components/home_integration/tutorial_directory_header_link.tsx#:~:text=RedirectAppLinks), [custom_assets_accordion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/components/custom_assets_accordion.tsx#:~:text=RedirectAppLinks), [custom_assets_accordion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/components/custom_assets_accordion.tsx#:~:text=RedirectAppLinks), [custom_assets_accordion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/components/custom_assets_accordion.tsx#:~:text=RedirectAppLinks), [agent_logs.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/fleet/sections/agents/agent_details_page/components/agent_logs/agent_logs.tsx#:~:text=RedirectAppLinks), [agent_logs.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/fleet/sections/agents/agent_details_page/components/agent_logs/agent_logs.tsx#:~:text=RedirectAppLinks), [agent_logs.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/fleet/sections/agents/agent_details_page/components/agent_logs/agent_logs.tsx#:~:text=RedirectAppLinks), [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/integrations/app.tsx#:~:text=RedirectAppLinks)+ 5 more | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | 8.8.0 | +| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/integrations/index.tsx#:~:text=appBasePath), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/public/applications/fleet/index.d.ts#:~:text=appBasePath), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/public/applications/integrations/index.d.ts#:~:text=appBasePath) | 8.8.0 | +| | [plugin.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/server/plugin.d.ts#:~:text=AsyncPlugin), [plugin.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/server/plugin.d.ts#:~:text=AsyncPlugin) | 8.8.0 | @@ -338,9 +349,17 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [app_state.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/types/app_state.ts#:~:text=IndexPattern), [app_state.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/types/app_state.ts#:~:text=IndexPattern), [deserialize.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.ts#:~:text=IndexPattern), [deserialize.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.ts#:~:text=IndexPattern), [deserialize.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.ts#:~:text=IndexPattern), [deserialize.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.ts#:~:text=IndexPattern), [datasource.sagas.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/state_management/datasource.sagas.ts#:~:text=IndexPattern), [datasource.sagas.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/state_management/datasource.sagas.ts#:~:text=IndexPattern), [persistence.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/state_management/persistence.ts#:~:text=IndexPattern), [persistence.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/state_management/persistence.ts#:~:text=IndexPattern)+ 19 more | - | | | [deserialize.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.ts#:~:text=getNonScriptedFields), [datasource.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/state_management/datasource.test.ts#:~:text=getNonScriptedFields), [deserialize.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts#:~:text=getNonScriptedFields), [deserialize.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts#:~:text=getNonScriptedFields) | - | | | [deserialize.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.ts#:~:text=getNonScriptedFields), [datasource.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/state_management/datasource.test.ts#:~:text=getNonScriptedFields), [deserialize.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts#:~:text=getNonScriptedFields), [deserialize.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts#:~:text=getNonScriptedFields) | - | -| | [save_modal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/save_modal.tsx#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/save_modal.tsx#:~:text=SavedObjectSaveModal) | - | -| | [listing_route.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/apps/listing_route.tsx#:~:text=settings), [listing_route.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/apps/listing_route.tsx#:~:text=settings) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/server/plugin.ts#:~:text=license%24) | - | +| | [save_modal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/save_modal.tsx#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/save_modal.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | +| | [listing_route.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/apps/listing_route.tsx#:~:text=settings), [listing_route.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/apps/listing_route.tsx#:~:text=settings) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/server/plugin.ts#:~:text=license%24) | 8.8.0 | + + + +## home + +| Deprecated API | Reference location(s) | Remove By | +| ---------------|-----------|-----------| +| | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/home/public/application/application.tsx#:~:text=RedirectAppLinks), [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/home/public/application/application.tsx#:~:text=RedirectAppLinks), [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/home/public/application/application.tsx#:~:text=RedirectAppLinks), [add_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/home/public/application/components/add_data/add_data.tsx#:~:text=RedirectAppLinks), [add_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/home/public/application/components/add_data/add_data.tsx#:~:text=RedirectAppLinks), [add_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/home/public/application/components/add_data/add_data.tsx#:~:text=RedirectAppLinks) | - | @@ -348,7 +367,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/server/services/license.ts#:~:text=license%24) | - | +| | [shared_imports.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/public/shared_imports.ts#:~:text=RedirectAppLinks), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/public/application/index.tsx#:~:text=RedirectAppLinks), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/public/application/index.tsx#:~:text=RedirectAppLinks), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/public/application/index.tsx#:~:text=RedirectAppLinks) | - | +| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/server/services/license.ts#:~:text=license%24) | 8.8.0 | @@ -356,7 +376,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [editor.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/alerting/log_threshold/components/expression_editor/editor.tsx#:~:text=indexPatterns), [log_stream.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/components/log_stream/log_stream.tsx#:~:text=indexPatterns), [log_stream.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/components/log_stream/log_stream.tsx#:~:text=indexPatterns), [logs_overview_fetchers.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/utils/logs_overview_fetchers.ts#:~:text=indexPatterns), [redirect_to_node_logs.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/pages/link_to/redirect_to_node_logs.tsx#:~:text=indexPatterns), [use_kibana_index_patterns.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/hooks/use_kibana_index_patterns.ts#:~:text=indexPatterns), [page_providers.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/pages/logs/page_providers.tsx#:~:text=indexPatterns), [logs_overview_fetches.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/utils/logs_overview_fetches.test.ts#:~:text=indexPatterns) | - | +| | [redirect_to_node_logs.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/pages/link_to/redirect_to_node_logs.tsx#:~:text=indexPatterns), [editor.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/alerting/log_threshold/components/expression_editor/editor.tsx#:~:text=indexPatterns), [log_stream.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/components/log_stream/log_stream.tsx#:~:text=indexPatterns), [log_stream.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/components/log_stream/log_stream.tsx#:~:text=indexPatterns), [logs_overview_fetchers.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/utils/logs_overview_fetchers.ts#:~:text=indexPatterns), [use_kibana_index_patterns.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/hooks/use_kibana_index_patterns.ts#:~:text=indexPatterns), [page_providers.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/pages/logs/page_providers.tsx#:~:text=indexPatterns), [logs_overview_fetches.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/public/utils/logs_overview_fetches.test.ts#:~:text=indexPatterns) | - | | | [kibana_framework_adapter.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/server/lib/adapters/framework/kibana_framework_adapter.ts#:~:text=indexPatternsServiceFactory), [log_entries_search_strategy.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/server/services/log_entries/log_entries_search_strategy.ts#:~:text=indexPatternsServiceFactory), [log_entry_search_strategy.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/infra/server/services/log_entries/log_entry_search_strategy.ts#:~:text=indexPatternsServiceFactory) | - | @@ -365,9 +385,12 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| +| | [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [controls_tab.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts#:~:text=IndexPattern), [controls_tab.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern)+ 2 more | - | | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=fetch), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=fetch) | 8.1 | | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=indexPatterns), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=indexPatterns), [controls_tab.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/components/editor/controls_tab.tsx#:~:text=indexPatterns) | - | +| | [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [controls_tab.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts#:~:text=IndexPattern), [controls_tab.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern)+ 2 more | - | | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=fetch), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=fetch) | 8.1 | +| | [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [create_search_source.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/control/create_search_source.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [get_index_pattern_mock.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/test_utils/get_index_pattern_mock.d.ts#:~:text=IndexPattern), [controls_tab.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts#:~:text=IndexPattern), [controls_tab.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/target/types/public/components/editor/controls_tab.d.ts#:~:text=IndexPattern) | - | @@ -375,7 +398,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/application.tsx#:~:text=appBasePath) | - | +| | [add_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/add_data/add_data.tsx#:~:text=RedirectAppLinks), [add_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/add_data/add_data.tsx#:~:text=RedirectAppLinks), [add_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/add_data/add_data.tsx#:~:text=RedirectAppLinks), [manage_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/manage_data/manage_data.tsx#:~:text=RedirectAppLinks), [manage_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/manage_data/manage_data.tsx#:~:text=RedirectAppLinks), [manage_data.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/manage_data/manage_data.tsx#:~:text=RedirectAppLinks), [overview.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/overview/overview.tsx#:~:text=RedirectAppLinks), [overview.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/overview/overview.tsx#:~:text=RedirectAppLinks), [overview.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/overview/overview.tsx#:~:text=RedirectAppLinks), [overview.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/components/overview/overview.tsx#:~:text=RedirectAppLinks)+ 1 more | - | +| | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/application.tsx#:~:text=appBasePath) | 8.8.0 | @@ -383,7 +407,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [ops_stats_collector.ts](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_usage_collection/server/collectors/ops_stats/ops_stats_collector.ts#:~:text=process) | - | +| | [ops_stats_collector.ts](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_usage_collection/server/collectors/ops_stats/ops_stats_collector.ts#:~:text=process) | 8.8.0 | @@ -391,22 +415,19 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPatternsContract), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPatternsContract), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPatternsContract), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPatternsContract), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPatternsContract), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPatternsContract), [embeddable_factory.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts#:~:text=IndexPatternsContract), [embeddable_factory.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts#:~:text=IndexPatternsContract), [loader.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts#:~:text=IndexPatternsContract), [loader.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts#:~:text=IndexPatternsContract)+ 18 more | - | -| | [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPattern)+ 22 more | - | -| | [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField) | - | -| | [datapanel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx#:~:text=indexPatterns), [datapanel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx#:~:text=indexPatterns), [datapanel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx#:~:text=indexPatterns), [datapanel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/datapanel.tsx#:~:text=indexPatterns), [indexpattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/indexpattern.tsx#:~:text=indexPatterns), [lens_top_nav.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx#:~:text=indexPatterns), [lens_top_nav.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx#:~:text=indexPatterns), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/plugin.ts#:~:text=indexPatterns), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/plugin.ts#:~:text=indexPatterns) | - | +| | [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract) | - | +| | [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern) | - | +| | [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField) | - | | | [ranges.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/ranges/ranges.tsx#:~:text=fieldFormats), [droppable.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/dimension_panel/droppable/droppable.test.ts#:~:text=fieldFormats) | - | -| | [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPatternsContract), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPatternsContract), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPatternsContract), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPatternsContract), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPatternsContract), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPatternsContract), [embeddable_factory.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts#:~:text=IndexPatternsContract), [embeddable_factory.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable_factory.ts#:~:text=IndexPatternsContract), [loader.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts#:~:text=IndexPatternsContract), [loader.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.test.ts#:~:text=IndexPatternsContract)+ 18 more | - | -| | [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/plugin.ts#:~:text=ensureDefaultDataView), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/plugin.ts#:~:text=ensureDefaultDataView) | - | -| | [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPattern)+ 22 more | - | -| | [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField), [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=IndexPatternField) | - | -| | [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [existing_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/existing_fields.test.ts#:~:text=IndexPattern), [loader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/indexpattern_datasource/loader.ts#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [embeddable.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/embeddable/embeddable.tsx#:~:text=IndexPattern), [utils.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/utils.ts#:~:text=IndexPattern)+ 6 more | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/plugin.ts#:~:text=ensureDefaultDataView) | - | -| | [field_stats.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/routes/field_stats.ts#:~:text=indexPatternsServiceFactory) | - | -| | [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject) | - | -| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/types.ts#:~:text=onAppLeave), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/types.ts#:~:text=onAppLeave), [mounter.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/mounter.tsx#:~:text=onAppLeave) | - | -| | [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/migrations/saved_object_migrations.ts#:~:text=warning), [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/migrations/saved_object_migrations.ts#:~:text=warning) | - | +| | [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPatternsContract) | - | +| | [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField) | - | +| | [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern) | - | +| | [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField), [field_stats.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/server/routes/field_stats.d.ts#:~:text=IndexPatternField) | - | +| | [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [embeddable.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/embeddable/embeddable.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern), [utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/utils.d.ts#:~:text=IndexPattern) | - | +| | [workspace_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx#:~:text=RedirectAppLinks), [workspace_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx#:~:text=RedirectAppLinks), [workspace_panel.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx#:~:text=RedirectAppLinks) | - | +| | [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/check_for_duplicate_title.d.ts#:~:text=SavedObject), [check_for_duplicate_title.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/check_for_duplicate_title.d.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.d.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.d.ts#:~:text=SavedObject) | 8.8.0 | +| | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/types.ts#:~:text=onAppLeave), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/types.ts#:~:text=onAppLeave), [mounter.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/mounter.tsx#:~:text=onAppLeave) | 8.8.0 | +| | [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/migrations/saved_object_migrations.ts#:~:text=warning), [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/migrations/saved_object_migrations.ts#:~:text=warning) | 8.8.0 | @@ -414,7 +435,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/license_management/public/plugin.ts#:~:text=license%24) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/license_management/public/plugin.ts#:~:text=license%24) | 8.8.0 | @@ -422,7 +443,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/logstash/public/plugin.ts#:~:text=license%24) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/logstash/public/plugin.ts#:~:text=license%24) | 8.8.0 | | | [save.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/logstash/server/routes/pipeline/save.ts#:~:text=authc) | - | @@ -431,7 +452,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/management/public/application.tsx#:~:text=appBasePath) | - | +| | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/management/public/application.tsx#:~:text=appBasePath), [application.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/management/target/types/public/application.d.ts#:~:text=appBasePath) | 8.8.0 | @@ -440,31 +461,31 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| | | [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService) | - | -| | [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract) | - | -| | [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern)+ 4 more | - | -| | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField)+ 84 more | - | +| | [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract) | - | +| | [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPattern), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPattern), [percentile_agg_field.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts#:~:text=IndexPattern), [percentile_agg_field.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts#:~:text=IndexPattern), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=IndexPattern), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_source.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts#:~:text=IndexPattern), [es_source.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts#:~:text=IndexPattern)+ 82 more | - | +| | [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField)+ 194 more | - | | | [es_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_source/es_source.ts#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch) | 8.1 | | | [kibana_services.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/kibana_services.ts#:~:text=indexPatterns) | - | | | [locators.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/locators.test.ts#:~:text=esFilters), [locators.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/locators.test.ts#:~:text=esFilters) | 8.1 | -| | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter) | 8.1 | -| | [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract) | - | -| | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField)+ 84 more | - | +| | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter) | 8.1 | +| | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter) | 8.1 | +| | [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/lazy_load_bundle/index.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/lazy_load_bundle/index.d.ts#:~:text=IndexPatternsContract) | - | +| | [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField)+ 194 more | - | | | [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService) | - | -| | [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern)+ 4 more | - | +| | [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPattern), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPattern), [percentile_agg_field.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts#:~:text=IndexPattern), [percentile_agg_field.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts#:~:text=IndexPattern), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=IndexPattern), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_source.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts#:~:text=IndexPattern), [es_source.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts#:~:text=IndexPattern)+ 82 more | - | | | [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit) | - | -| | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter) | 8.1 | | | [es_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_source/es_source.ts#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch) | 8.1 | -| | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField)+ 37 more | - | -| | [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern), [percentile_agg_field.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/fields/agg/percentile_agg_field.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern), [get_docvalue_source_fields.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/util/get_docvalue_source_fields.test.ts#:~:text=IndexPattern) | - | +| | [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/components/single_field_select.tsx#:~:text=IndexPatternField)+ 92 more | - | +| | [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPattern), [es_agg_utils.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/common/elasticsearch_util/es_agg_utils.d.ts#:~:text=IndexPattern), [percentile_agg_field.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts#:~:text=IndexPattern), [percentile_agg_field.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/fields/agg/percentile_agg_field.d.ts#:~:text=IndexPattern), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=IndexPattern), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_tooltip_property.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.test.ts#:~:text=IndexPattern), [es_source.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts#:~:text=IndexPattern), [es_source.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/classes/sources/es_source/es_source.d.ts#:~:text=IndexPattern)+ 36 more | - | | | [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService), [create_doc_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/create_doc_source.ts#:~:text=IndexPatternsService) | - | | | [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit) | - | -| | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter) | 8.1 | +| | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter) | 8.1 | | | [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=flattenHit) | - | | | [kibana_server_services.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/kibana_server_services.ts#:~:text=indexPatternsServiceFactory), [indexing_routes.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/data_indexing/indexing_routes.ts#:~:text=indexPatternsServiceFactory) | - | | | [map_container.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/connected_components/map_container/map_container.tsx#:~:text=ExitFullScreenButton), [map_container.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/connected_components/map_container/map_container.tsx#:~:text=ExitFullScreenButton) | - | -| | [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings), [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings), [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings) | - | -| | [render_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/render_app.tsx#:~:text=onAppLeave), [map_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/map_page/map_app/map_app.tsx#:~:text=onAppLeave), [map_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/map_page/map_page.tsx#:~:text=onAppLeave) | - | -| | [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/saved_objects/saved_object_migrations.ts#:~:text=warning) | - | +| | [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings), [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings), [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings) | 8.8.0 | +| | [render_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/render_app.tsx#:~:text=onAppLeave), [map_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/map_page/map_app/map_app.tsx#:~:text=onAppLeave), [map_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/map_page/map_page.tsx#:~:text=onAppLeave), [render_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/render_app.d.ts#:~:text=onAppLeave), [map_page.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_page.d.ts#:~:text=onAppLeave), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=onAppLeave) | 8.8.0 | +| | [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/saved_objects/saved_object_migrations.ts#:~:text=warning) | 8.8.0 | @@ -472,8 +493,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/maps_ems/server/index.ts#:~:text=license%24) | - | -| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/maps_ems/server/index.ts#:~:text=refresh) | - | +| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/maps_ems/server/index.ts#:~:text=license%24) | 8.8.0 | +| | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/maps_ems/server/index.ts#:~:text=refresh) | 8.8.0 | @@ -481,12 +502,16 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [check_license.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/license/check_license.tsx#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/plugin.ts#:~:text=license%24) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=license%24) | - | +| | [ml_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/components/ml_page/ml_page.tsx#:~:text=RedirectAppLinks), [ml_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/components/ml_page/ml_page.tsx#:~:text=RedirectAppLinks), [ml_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/components/ml_page/ml_page.tsx#:~:text=RedirectAppLinks), [jobs_list_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx#:~:text=RedirectAppLinks), [jobs_list_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx#:~:text=RedirectAppLinks), [jobs_list_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx#:~:text=RedirectAppLinks) | - | +| | [check_license.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/license/check_license.tsx#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/plugin.ts#:~:text=license%24) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=license%24) | 8.8.0 | | | [annotations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/routes/annotations.ts#:~:text=authc) | - | | | [initialization.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/saved_objects/initialization/initialization.ts#:~:text=authz), [sync_task.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/saved_objects/sync_task.ts#:~:text=authz), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=authz), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=authz) | - | -| | [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/app.tsx#:~:text=onAppLeave) | - | -| | [errors.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/common/util/errors/errors.test.ts#:~:text=req), [errors.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/common/util/errors/errors.test.ts#:~:text=req) | - | +| | [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/app.tsx#:~:text=onAppLeave) | 8.8.0 | +| | [errors.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/common/util/errors/errors.test.ts#:~:text=req), [errors.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/common/util/errors/errors.test.ts#:~:text=req) | 8.8.0 + +Note to maintainers: when looking at usages, mind that typical use could be inside a `catch` block, +so TS and code-reference navigation might not highlight them. | @@ -494,11 +519,19 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern) | - | +| | [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [with_kuery_autocompletion.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts#:~:text=IIndexPattern), [with_kuery_autocompletion.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts#:~:text=IIndexPattern)+ 2 more | - | | | [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=indexPatterns), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=indexPatterns) | - | -| | [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern)+ 6 more | - | -| | [legacy_shims.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/legacy_shims.ts#:~:text=injectedMetadata) | - | -| | [bulk_uploader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/server/kibana_monitoring/bulk_uploader.ts#:~:text=process) | - | +| | [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [use_derived_index_pattern.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/alerts/components/param_details_form/use_derived_index_pattern.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [with_kuery_autocompletion.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/with_kuery_autocompletion.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/components/kuery_bar/index.tsx#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [kuery.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/lib/kuery.ts#:~:text=IIndexPattern), [with_kuery_autocompletion.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts#:~:text=IIndexPattern), [with_kuery_autocompletion.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/target/types/public/components/kuery_bar/with_kuery_autocompletion.d.ts#:~:text=IIndexPattern)+ 14 more | - | +| | [legacy_shims.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/legacy_shims.ts#:~:text=injectedMetadata) | 8.8.0 | +| | [bulk_uploader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/server/kibana_monitoring/bulk_uploader.ts#:~:text=process) | 8.8.0 | + + + +## observability + +| Deprecated API | Reference location(s) | Remove By | +| ---------------|-----------|-----------| +| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/observability/public/application/index.tsx#:~:text=RedirectAppLinks), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/observability/public/application/index.tsx#:~:text=RedirectAppLinks), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/observability/public/application/index.tsx#:~:text=RedirectAppLinks) | - | @@ -506,8 +539,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/public/plugin.tsx#:~:text=license%24), [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/public/plugin.tsx#:~:text=license%24) | - | -| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/server/services/license.ts#:~:text=license%24) | - | +| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/public/plugin.tsx#:~:text=license%24), [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/public/plugin.tsx#:~:text=license%24) | 8.8.0 | +| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/server/services/license.ts#:~:text=license%24) | 8.8.0 | @@ -515,7 +548,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [saved_object_save_modal_dashboard.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/presentation_util/public/components/saved_object_save_modal_dashboard.tsx#:~:text=SavedObjectSaveModal), [saved_object_save_modal_dashboard.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/presentation_util/public/components/saved_object_save_modal_dashboard.tsx#:~:text=SavedObjectSaveModal) | - | +| | [saved_object_save_modal_dashboard.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/presentation_util/public/components/saved_object_save_modal_dashboard.tsx#:~:text=SavedObjectSaveModal), [saved_object_save_modal_dashboard.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/presentation_util/public/components/saved_object_save_modal_dashboard.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | @@ -523,7 +556,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/remote_clusters/server/plugin.ts#:~:text=license%24) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/remote_clusters/server/plugin.ts#:~:text=license%24) | 8.8.0 | @@ -531,7 +564,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/rollup/server/services/license.ts#:~:text=license%24) | - | +| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/rollup/server/services/license.ts#:~:text=license%24) | 8.8.0 | @@ -550,6 +583,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| +| | [saved_objects_edition_page.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/management_section/saved_objects_edition_page.tsx#:~:text=RedirectAppLinks), [saved_objects_edition_page.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/management_section/saved_objects_edition_page.tsx#:~:text=RedirectAppLinks), [saved_objects_edition_page.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/management_section/saved_objects_edition_page.tsx#:~:text=RedirectAppLinks), [saved_objects_table.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/management_section/objects_table/saved_objects_table.tsx#:~:text=RedirectAppLinks), [saved_objects_table.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/management_section/objects_table/saved_objects_table.tsx#:~:text=RedirectAppLinks), [saved_objects_table.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/management_section/objects_table/saved_objects_table.tsx#:~:text=RedirectAppLinks) | - | | | [resolve_import_errors.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/lib/resolve_import_errors.ts#:~:text=createNewCopy) | - | | | [resolve_import_errors.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_management/public/lib/resolve_import_errors.ts#:~:text=createNewCopy) | - | @@ -567,7 +601,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/decorator/types.ts#:~:text=SavedObject), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/decorator/types.ts#:~:text=SavedObject), [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject), [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject) | - | +| | [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/decorator/types.ts#:~:text=SavedObject), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/decorator/types.ts#:~:text=SavedObject), [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject), [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject) | 8.8.0 | @@ -575,8 +609,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/public/plugin.ts#:~:text=license%24) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/server/plugin.ts#:~:text=license%24) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/public/plugin.ts#:~:text=license%24) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/server/plugin.ts#:~:text=license%24) | 8.8.0 | @@ -584,17 +618,25 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | - | -| | [disable_ui_capabilities.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/disable_ui_capabilities.ts#:~:text=requiredRoles) | - | -| | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | - | -| | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | - | -| | [disable_ui_capabilities.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/disable_ui_capabilities.ts#:~:text=requiredRoles) | - | -| | [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode), [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode) | - | -| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/plugin.tsx#:~:text=license%24) | - | -| | [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode), [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/plugin.ts#:~:text=license%24) | - | -| | [logout_app.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/authentication/logout/logout_app.test.ts#:~:text=appBasePath) | - | -| | [logout_app.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/authentication/logout/logout_app.test.ts#:~:text=onAppLeave) | - | +| | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | 8.8.0 | +| | [disable_ui_capabilities.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/disable_ui_capabilities.ts#:~:text=requiredRoles) | 8.8.0 + +This is relied on by the reporting feature, and should be removed once reporting +migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 | +| | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | 8.8.0 | +| | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | 8.8.0 | +| | [disable_ui_capabilities.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/disable_ui_capabilities.ts#:~:text=requiredRoles) | 8.8.0 + +This is relied on by the reporting feature, and should be removed once reporting +migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 | +| | [app_authorization.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/app_authorization.ts#:~:text=getKibanaFeatures), [privileges.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.ts#:~:text=getKibanaFeatures), [authorization_service.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/authorization_service.tsx#:~:text=getKibanaFeatures), [app_authorization.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/app_authorization.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures)+ 14 more | 8.8.0 | +| | [authorization_service.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/authorization_service.tsx#:~:text=getElasticsearchFeatures) | 8.8.0 | +| | [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode), [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode) | 8.8.0 | +| | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/plugin.tsx#:~:text=license%24) | 8.8.0 | +| | [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode), [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode) | 8.8.0 | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/plugin.ts#:~:text=license%24) | 8.8.0 | +| | [logout_app.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/authentication/logout/logout_app.test.ts#:~:text=appBasePath) | 8.8.0 | +| | [logout_app.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/authentication/logout/logout_app.test.ts#:~:text=onAppLeave) | 8.8.0 | @@ -603,11 +645,11 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| | | [middleware.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/store/middleware.ts#:~:text=indexPatterns), [dependencies_start_mock.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/common/mock/endpoint/dependencies_start_mock.ts#:~:text=indexPatterns) | - | -| | [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode)+ 2 more | - | -| | [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode)+ 2 more | - | +| | [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode)+ 2 more | 8.8.0 | +| | [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode)+ 2 more | 8.8.0 | | | [request_context_factory.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/request_context_factory.ts#:~:text=authc), [request_context_factory.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/request_context_factory.ts#:~:text=authc), [create_signals_migration_route.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/lib/detection_engine/routes/signals/create_signals_migration_route.ts#:~:text=authc), [delete_signals_migration_route.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/lib/detection_engine/routes/signals/delete_signals_migration_route.ts#:~:text=authc), [finalize_signals_migration_route.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/lib/detection_engine/routes/signals/finalize_signals_migration_route.ts#:~:text=authc), [open_close_signals_route.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/lib/detection_engine/routes/signals/open_close_signals_route.ts#:~:text=authc), [preview_rules_route.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/preview_rules_route.ts#:~:text=authc), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/lib/timeline/utils/common.ts#:~:text=authc) | - | -| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/index.tsx#:~:text=onAppLeave) | - | -| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/timelines/components/flyout/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/timelines/components/flyout/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/bottom_bar/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/bottom_bar/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/index.tsx#:~:text=AppLeaveHandler), [routes.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/routes.tsx#:~:text=AppLeaveHandler), [routes.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/routes.tsx#:~:text=AppLeaveHandler)+ 3 more | - | +| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/index.tsx#:~:text=onAppLeave) | 8.8.0 | +| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/timelines/components/flyout/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/timelines/components/flyout/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/bottom_bar/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/bottom_bar/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/index.tsx#:~:text=AppLeaveHandler), [routes.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/routes.tsx#:~:text=AppLeaveHandler), [routes.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/routes.tsx#:~:text=AppLeaveHandler)+ 3 more | 8.8.0 | @@ -615,7 +657,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/snapshot_restore/server/services/license.ts#:~:text=license%24) | - | +| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/snapshot_restore/server/services/license.ts#:~:text=license%24) | 8.8.0 | @@ -623,7 +665,9 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [spaces_usage_collector.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/plugin.ts#:~:text=license%24), [spaces_usage_collector.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.test.ts#:~:text=license%24) | - | +| | [spaces_management_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/public/management/spaces_management_app.tsx#:~:text=RedirectAppLinks), [spaces_management_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/public/management/spaces_management_app.tsx#:~:text=RedirectAppLinks), [spaces_management_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/public/management/spaces_management_app.tsx#:~:text=RedirectAppLinks) | - | +| | [on_post_auth_interceptor.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/lib/request_interceptors/on_post_auth_interceptor.ts#:~:text=getKibanaFeatures), [spaces_usage_collector.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.ts#:~:text=getKibanaFeatures), [on_post_auth_interceptor.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/lib/request_interceptors/on_post_auth_interceptor.test.ts#:~:text=getKibanaFeatures) | 8.8.0 | +| | [spaces_usage_collector.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/plugin.ts#:~:text=license%24), [spaces_usage_collector.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.test.ts#:~:text=license%24) | 8.8.0 | | | [copy_to_space_flyout_internal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/public/copy_saved_objects_to_space/components/copy_to_space_flyout_internal.tsx#:~:text=createNewCopy) | - | | | [copy_to_space_flyout_internal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/public/copy_saved_objects_to_space/components/copy_to_space_flyout_internal.tsx#:~:text=createNewCopy) | - | @@ -633,20 +677,16 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract) | - | -| | [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern) | - | -| | [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IIndexPattern), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IIndexPattern), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IIndexPattern), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=IIndexPattern), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=IIndexPattern), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern)+ 1 more | - | -| | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType)+ 14 more | 8.2 | +| | [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract) | - | +| | [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern) | - | +| | [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType) | 8.2 | | | [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=indexPatterns), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=indexPatterns), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=indexPatterns), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=indexPatterns), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=indexPatterns) | - | | | [expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/threshold/expression.tsx#:~:text=fieldFormats) | - | -| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esKuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esKuery) | 8.1 | -| | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esQuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esQuery) | 8.1 | -| | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType)+ 38 more | 8.2 | -| | [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IIndexPattern), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IIndexPattern), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IIndexPattern), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=IIndexPattern), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=IIndexPattern), [boundary_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/boundary_index_expression.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=IIndexPattern)+ 12 more | - | -| | [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPatternsContract) | - | -| | [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern) | - | -| | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType)+ 14 more | 8.2 | -| | [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern), [geo_index_pattern_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.tsx#:~:text=IndexPattern) | - | +| | [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType) | 8.2 | +| | [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPatternsContract) | - | +| | [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern) | - | +| | [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType) | 8.2 | +| | [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern), [geo_index_pattern_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/geo_index_pattern_select.d.ts#:~:text=IndexPattern) | - | @@ -654,18 +694,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract) | - | -| | [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [wizard.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx#:~:text=IndexPattern), [wizard.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx#:~:text=IndexPattern), [get_pivot_dropdown_options.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts#:~:text=IndexPattern), [get_pivot_dropdown_options.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts#:~:text=IndexPattern), [filter_agg_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx#:~:text=IndexPattern), [filter_agg_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx#:~:text=IndexPattern)+ 30 more | - | -| | [es_index_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/services/es_index_service.ts#:~:text=IIndexPattern), [es_index_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/services/es_index_service.ts#:~:text=IIndexPattern), [transforms.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/routes/api/transforms.ts#:~:text=IIndexPattern), [transforms.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/routes/api/transforms.ts#:~:text=IIndexPattern) | - | -| | [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes) | - | -| | [step_create_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_create/step_create_form.tsx#:~:text=indexPatterns), [step_details_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_details/step_details_form.tsx#:~:text=indexPatterns), [use_search_items.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/use_search_items.ts#:~:text=indexPatterns), [use_clone_action.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/transform_management/components/action_clone/use_clone_action.tsx#:~:text=indexPatterns), [use_action_discover.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/transform_management/components/action_discover/use_action_discover.tsx#:~:text=indexPatterns), [edit_transform_flyout_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/transform_management/components/edit_transform_flyout/edit_transform_flyout_form.tsx#:~:text=indexPatterns), [use_edit_action.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/transform_management/components/action_edit/use_edit_action.tsx#:~:text=indexPatterns) | - | -| | [es_index_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/services/es_index_service.ts#:~:text=IIndexPattern), [es_index_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/services/es_index_service.ts#:~:text=IIndexPattern), [transforms.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/routes/api/transforms.ts#:~:text=IIndexPattern), [transforms.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/routes/api/transforms.ts#:~:text=IIndexPattern), [es_index_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/services/es_index_service.ts#:~:text=IIndexPattern), [es_index_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/services/es_index_service.ts#:~:text=IIndexPattern), [transforms.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/routes/api/transforms.ts#:~:text=IIndexPattern), [transforms.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/routes/api/transforms.ts#:~:text=IIndexPattern) | - | -| | [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes) | - | -| | [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternsContract) | - | -| | [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [wizard.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx#:~:text=IndexPattern), [wizard.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx#:~:text=IndexPattern), [get_pivot_dropdown_options.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts#:~:text=IndexPattern), [get_pivot_dropdown_options.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts#:~:text=IndexPattern), [filter_agg_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx#:~:text=IndexPattern), [filter_agg_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx#:~:text=IndexPattern)+ 30 more | - | -| | [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes), [common.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/hooks/use_search_items/common.ts#:~:text=IndexPatternAttributes) | - | -| | [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [index_pattern.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/common/types/index_pattern.ts#:~:text=IndexPattern), [wizard.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx#:~:text=IndexPattern), [wizard.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/wizard/wizard.tsx#:~:text=IndexPattern), [get_pivot_dropdown_options.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts#:~:text=IndexPattern), [get_pivot_dropdown_options.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/get_pivot_dropdown_options.ts#:~:text=IndexPattern), [filter_agg_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx#:~:text=IndexPattern), [filter_agg_form.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/public/app/sections/create_transform/components/step_define/common/filter_agg/components/filter_agg_form.tsx#:~:text=IndexPattern)+ 10 more | - | -| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/services/license.ts#:~:text=license%24) | - | +| | [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/services/license.ts#:~:text=license%24) | 8.8.0 | @@ -673,7 +702,11 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [reindex_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.ts#:~:text=license%24), [reindex_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.test.ts#:~:text=license%24), [reindex_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.test.ts#:~:text=license%24) | - | +| | [app_context.mock.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts#:~:text=IndexPattern), [app_context.mock.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts#:~:text=IndexPattern) | - | +| | [app_context.mock.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts#:~:text=IndexPattern), [app_context.mock.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts#:~:text=IndexPattern) | - | +| | [app_context.mock.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/target/types/__jest__/client_integration/helpers/app_context.mock.d.ts#:~:text=IndexPattern) | - | +| | [shared_imports.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/public/shared_imports.ts#:~:text=RedirectAppLinks), [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/public/application/app.tsx#:~:text=RedirectAppLinks), [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/public/application/app.tsx#:~:text=RedirectAppLinks), [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/public/application/app.tsx#:~:text=RedirectAppLinks) | - | +| | [reindex_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.ts#:~:text=license%24), [reindex_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.test.ts#:~:text=license%24), [reindex_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.test.ts#:~:text=license%24) | 8.8.0 | @@ -685,6 +718,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=indexPatterns) | - | | | [update_kuery_string.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/hooks/update_kuery_string.ts#:~:text=IndexPattern), [update_kuery_string.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/hooks/update_kuery_string.ts#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [update_kuery_string.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/hooks/update_kuery_string.ts#:~:text=IndexPattern), [update_kuery_string.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/hooks/update_kuery_string.ts#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern) | - | | | [update_kuery_string.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/hooks/update_kuery_string.ts#:~:text=IndexPattern), [update_kuery_string.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/hooks/update_kuery_string.ts#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern), [uptime_index_pattern_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/contexts/uptime_index_pattern_context.tsx#:~:text=IndexPattern) | - | +| | [alert_messages.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/lib/alert_types/alert_messages.tsx#:~:text=RedirectAppLinks), [alert_messages.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/lib/alert_types/alert_messages.tsx#:~:text=RedirectAppLinks), [alert_messages.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/lib/alert_types/alert_messages.tsx#:~:text=RedirectAppLinks), [uptime_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/apps/uptime_app.tsx#:~:text=RedirectAppLinks), [uptime_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/apps/uptime_app.tsx#:~:text=RedirectAppLinks), [uptime_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/uptime/public/apps/uptime_app.tsx#:~:text=RedirectAppLinks) | - | @@ -705,6 +739,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern) | - | | | [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern) | - | | | [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_filters.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_filters.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern), [selected_wildcards.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/components/app/rum_dashboard/local_uifilters/selected_wildcards.tsx#:~:text=IndexPattern) | - | +| | [ux_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/application/ux_app.tsx#:~:text=RedirectAppLinks), [ux_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/application/ux_app.tsx#:~:text=RedirectAppLinks), [ux_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ux/public/application/ux_app.tsx#:~:text=RedirectAppLinks) | - | @@ -712,12 +747,12 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_params.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params.tsx#:~:text=IndexPattern)+ 16 more | - | -| | [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [top_field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/top_field.tsx#:~:text=IndexPatternField)+ 26 more | - | -| | [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [top_field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/top_field.tsx#:~:text=IndexPatternField)+ 26 more | - | -| | [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_params.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params.tsx#:~:text=IndexPattern)+ 16 more | - | -| | [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [top_field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/top_field.tsx#:~:text=IndexPatternField)+ 8 more | - | -| | [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_params.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params.tsx#:~:text=IndexPattern)+ 3 more | - | +| | [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_params.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params.tsx#:~:text=IndexPattern)+ 24 more | - | +| | [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [top_field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/top_field.tsx#:~:text=IndexPatternField)+ 38 more | - | +| | [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [top_field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/top_field.tsx#:~:text=IndexPatternField)+ 38 more | - | +| | [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_params.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params.tsx#:~:text=IndexPattern)+ 24 more | - | +| | [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_type_field_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_field_filters.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [agg_param_props.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_param_props.ts#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/field.tsx#:~:text=IndexPatternField), [top_field.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/controls/top_field.tsx#:~:text=IndexPatternField)+ 14 more | - | +| | [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [agg_type_filters.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/agg_filters/agg_type_filters.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [editor_config.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/utils/editor_config.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_params_helper.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params_helper.ts#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_select.tsx#:~:text=IndexPattern), [agg_params.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_default_editor/public/components/agg_params.tsx#:~:text=IndexPattern)+ 7 more | - | @@ -746,37 +781,18 @@ warning: This document is auto-generated and is meant to be viewed inside our ex -## visTypeTimelion - -| Deprecated API | Reference location(s) | Remove By | -| ---------------|-----------|-----------| -| | [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract), [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/plugin.ts#:~:text=indexPatterns) | - | -| | [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract), [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [plugin_services.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/helpers/plugin_services.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract), [timelion_expression_input_helpers.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/public/components/timelion_expression_input_helpers.test.ts#:~:text=IndexPatternsContract) | - | -| | [run.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timelion/server/routes/run.ts#:~:text=indexPatternsServiceFactory) | - | - - - ## visTypeTimeseries | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=IndexPatternsService), [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=IndexPatternsService), [default_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts#:~:text=IndexPatternsService), [default_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts#:~:text=IndexPatternsService), [cached_index_pattern_fetcher.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts#:~:text=IndexPatternsService), [cached_index_pattern_fetcher.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts#:~:text=IndexPatternsService), [rollup_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts#:~:text=IndexPatternsService), [rollup_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts#:~:text=IndexPatternsService), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/types.ts#:~:text=IndexPatternsService), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/types.ts#:~:text=IndexPatternsService)+ 44 more | - | -| | [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/types/index.ts#:~:text=IndexPattern), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/types/index.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern)+ 56 more | - | -| | [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField)+ 2 more | - | -| | [fetch_fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/lib/fetch_fields.ts#:~:text=indexPatterns), [combo_box_select.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/index_pattern_select/combo_box_select.tsx#:~:text=indexPatterns), [query_bar_wrapper.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/query_bar_wrapper.tsx#:~:text=indexPatterns), [annotation_row.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/annotation_row.tsx#:~:text=indexPatterns), [metrics_type.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/metrics_type.ts#:~:text=indexPatterns), [metrics_type.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/metrics_type.ts#:~:text=indexPatterns), [convert_series_to_datatable.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.ts#:~:text=indexPatterns), [timeseries_visualization.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/timeseries_visualization.tsx#:~:text=indexPatterns), [metrics_type.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/metrics_type.test.ts#:~:text=indexPatterns) | - | +| | [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern) | - | | | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/plugin.ts#:~:text=fieldFormats) | - | -| | [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField)+ 2 more | - | -| | [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=IndexPatternsService), [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=IndexPatternsService), [default_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts#:~:text=IndexPatternsService), [default_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts#:~:text=IndexPatternsService), [cached_index_pattern_fetcher.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts#:~:text=IndexPatternsService), [cached_index_pattern_fetcher.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts#:~:text=IndexPatternsService), [rollup_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts#:~:text=IndexPatternsService), [rollup_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts#:~:text=IndexPatternsService), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/types.ts#:~:text=IndexPatternsService), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/types.ts#:~:text=IndexPatternsService)+ 44 more | - | -| | [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/types/index.ts#:~:text=IndexPattern), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/types/index.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern)+ 56 more | - | +| | [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern) | - | | | [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=getNonScriptedFields), [fetch_fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/lib/fetch_fields.ts#:~:text=getNonScriptedFields), [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=getNonScriptedFields), [fetch_fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/lib/fetch_fields.ts#:~:text=getNonScriptedFields) | - | -| | [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField), [convert_series_to_datatable.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/components/lib/convert_series_to_datatable.test.ts#:~:text=IndexPatternField) | - | -| | [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [cached_index_pattern_fetcher.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.test.ts#:~:text=IndexPattern), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/types/index.ts#:~:text=IndexPattern), [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/types/index.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern), [index_patterns_utils.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/common/index_patterns_utils.test.ts#:~:text=IndexPattern)+ 23 more | - | -| | [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=IndexPatternsService), [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=IndexPatternsService), [default_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts#:~:text=IndexPatternsService), [default_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/default_search_strategy.ts#:~:text=IndexPatternsService), [cached_index_pattern_fetcher.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts#:~:text=IndexPatternsService), [cached_index_pattern_fetcher.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/lib/cached_index_pattern_fetcher.ts#:~:text=IndexPatternsService), [rollup_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts#:~:text=IndexPatternsService), [rollup_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/rollup_search_strategy.ts#:~:text=IndexPatternsService), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/types.ts#:~:text=IndexPatternsService), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/types.ts#:~:text=IndexPatternsService)+ 44 more | - | +| | [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern), [convert_series_to_datatable.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/target/types/public/application/components/lib/convert_series_to_datatable.d.ts#:~:text=IndexPattern) | - | | | [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=getNonScriptedFields), [fetch_fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/lib/fetch_fields.ts#:~:text=getNonScriptedFields) | - | | | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/plugin.ts#:~:text=fieldFormats) | - | | | [abstract_search_strategy.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/lib/search_strategies/strategies/abstract_search_strategy.ts#:~:text=getNonScriptedFields), [fetch_fields.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/public/application/lib/fetch_fields.ts#:~:text=getNonScriptedFields) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/timeseries/server/plugin.ts#:~:text=indexPatternsServiceFactory) | - | @@ -784,12 +800,8 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern) | - | -| | [search_api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.ts#:~:text=indexPatterns), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=indexPatterns), [search_api.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.test.ts#:~:text=indexPatterns), [search_api.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.test.ts#:~:text=indexPatterns), [search_api.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.test.ts#:~:text=indexPatterns), [view.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/vega_view/vega_map_view/view.test.ts#:~:text=indexPatterns) | - | -| | [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern) | - | -| | [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern), [extract_index_pattern.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/lib/extract_index_pattern.ts#:~:text=IndexPattern) | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/plugin.ts#:~:text=injectedMetadata) | - | -| | [search_api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.ts#:~:text=injectedMetadata), [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/plugin.ts#:~:text=injectedMetadata) | - | +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/plugin.ts#:~:text=injectedMetadata) | 8.8.0 | +| | [search_api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.ts#:~:text=injectedMetadata), [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/plugin.ts#:~:text=injectedMetadata), [search_api.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/target/types/public/data_model/search_api.d.ts#:~:text=injectedMetadata) | 8.8.0 | @@ -817,16 +829,13 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [vis.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis.ts#:~:text=IndexPattern), [vis.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [create_vis_embeddable_from_object.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts#:~:text=IndexPattern), [create_vis_embeddable_from_object.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern)+ 16 more | - | -| | [visualize_top_nav.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx#:~:text=indexPatterns), [visualize_top_nav.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx#:~:text=indexPatterns), [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/plugin.ts#:~:text=indexPatterns), [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/plugin.ts#:~:text=indexPatterns) | - | -| | [controls_references.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [controls_references.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [timeseries_references.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_visualization_references/timeseries_references.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [timeseries_references.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_visualization_references/timeseries_references.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [visualization_saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [visualization_saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [visualization_saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [visualization_saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [visualization_saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/server/migrations/visualization_saved_object_migrations.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE), [controls_references.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_visualization_references/controls_references.ts#:~:text=INDEX_PATTERN_SAVED_OBJECT_TYPE)+ 8 more | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/plugin.ts#:~:text=ensureDefaultDataView), [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/plugin.ts#:~:text=ensureDefaultDataView) | - | -| | [vis.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis.ts#:~:text=IndexPattern), [vis.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [create_vis_embeddable_from_object.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts#:~:text=IndexPattern), [create_vis_embeddable_from_object.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern)+ 16 more | - | -| | [vis.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis.ts#:~:text=IndexPattern), [vis.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/vis_types/types.ts#:~:text=IndexPattern), [create_vis_embeddable_from_object.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts#:~:text=IndexPattern), [create_vis_embeddable_from_object.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/create_vis_embeddable_from_object.ts#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern), [visualize_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/embeddable/visualize_embeddable.tsx#:~:text=IndexPattern)+ 3 more | - | -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/plugin.ts#:~:text=ensureDefaultDataView) | - | -| | [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject) | - | -| | [visualize_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_listing.tsx#:~:text=settings), [visualize_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_listing.tsx#:~:text=settings) | - | -| | [visualize_top_nav.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx#:~:text=onAppLeave), [visualize_editor_common.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_editor_common.tsx#:~:text=onAppLeave), [app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/app.tsx#:~:text=onAppLeave), [index.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/index.tsx#:~:text=onAppLeave) | - | +| | [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern) | - | +| | [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern) | - | +| | [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern), [base_vis_type.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/vis_types/base_vis_type.d.ts#:~:text=IndexPattern) | - | +| | [get_table_columns.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/utils/get_table_columns.tsx#:~:text=RedirectAppLinks), [get_table_columns.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/utils/get_table_columns.tsx#:~:text=RedirectAppLinks), [get_table_columns.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/utils/get_table_columns.tsx#:~:text=RedirectAppLinks) | - | +| | [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject) | 8.8.0 | +| | [visualize_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_listing.tsx#:~:text=settings), [visualize_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_listing.tsx#:~:text=settings) | 8.8.0 | +| | [visualize_top_nav.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx#:~:text=onAppLeave), [visualize_editor_common.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_editor_common.tsx#:~:text=onAppLeave), [app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/app.tsx#:~:text=onAppLeave), [index.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/index.tsx#:~:text=onAppLeave), [app.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/app.d.ts#:~:text=onAppLeave), [index.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/index.d.ts#:~:text=onAppLeave), [visualize_editor_common.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/components/visualize_editor_common.d.ts#:~:text=onAppLeave), [visualize_top_nav.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/components/visualize_top_nav.d.ts#:~:text=onAppLeave) | 8.8.0 | @@ -834,4 +843,4 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Deprecated API | Reference location(s) | Remove By | | ---------------|-----------|-----------| -| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/watcher/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/watcher/public/plugin.ts#:~:text=license%24) | - | \ No newline at end of file +| | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/watcher/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/watcher/public/plugin.ts#:~:text=license%24) | 8.8.0 | \ No newline at end of file diff --git a/api_docs/deprecations_by_team.mdx b/api_docs/deprecations_by_team.mdx index c7bd86aaca030..eab23cbf89f85 100644 --- a/api_docs/deprecations_by_team.mdx +++ b/api_docs/deprecations_by_team.mdx @@ -3,7 +3,7 @@ id: kibDevDocsDeprecationsDueByTeam slug: /kibana-dev-docs/api-meta/deprecations-due-by-team title: Deprecated APIs due to be removed, by team summary: Lists the teams that are referencing deprecated APIs with a remove by date. -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. --- @@ -14,6 +14,10 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Plugin | Deprecated API | Reference location(s) | Remove By | | --------|-------|-----------|-----------| | apm | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/shared/kuery_bar/index.tsx#:~:text=esKuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/shared/kuery_bar/index.tsx#:~:text=esKuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/components/shared/kuery_bar/index.tsx#:~:text=esKuery) | 8.1 | +| apm | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/plugin.ts#:~:text=environment) | 8.8.0 | +| apm | | [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode)+ 2 more | 8.8.0 | +| apm | | [license_context.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/public/context/license/license_context.tsx#:~:text=license%24) | 8.8.0 | +| apm | | [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode), [license_check.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/apm/common/license_check.test.ts#:~:text=mode)+ 2 more | 8.8.0 | @@ -24,13 +28,14 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | dataViews | | [utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/utils.ts#:~:text=IFieldType), [utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/utils.ts#:~:text=IFieldType), [data_view_field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/data_view_field.ts#:~:text=IFieldType), [data_view_field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/data_view_field.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/types.ts#:~:text=IFieldType), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/types.ts#:~:text=IFieldType)+ 13 more | 8.2 | | dataViews | | [utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/utils.ts#:~:text=IFieldType), [utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/utils.ts#:~:text=IFieldType), [data_view_field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/data_view_field.ts#:~:text=IFieldType), [data_view_field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/data_view_field.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/types.ts#:~:text=IFieldType), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/types.ts#:~:text=IFieldType)+ 66 more | 8.2 | | dataViews | | [utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/utils.ts#:~:text=IFieldType), [utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/utils.ts#:~:text=IFieldType), [data_view_field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/data_view_field.ts#:~:text=IFieldType), [data_view_field.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/data_view_field.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [field_list.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/fields/field_list.ts#:~:text=IFieldType), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/types.ts#:~:text=IFieldType), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/data_views/common/types.ts#:~:text=IFieldType)+ 13 more | 8.2 | -| dataEnhanced | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode) | 8.1 | -| dataEnhanced | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode) | 8.1 | +| dataEnhanced | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode)+ 2 more | 8.1 | | dataEnhanced | | [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=nodeBuilder), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=nodeBuilder), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=nodeBuilder)+ 2 more | 8.1 | -| dataEnhanced | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode) | 8.1 | +| dataEnhanced | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode)+ 2 more | 8.1 | +| dataEnhanced | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/types.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [get_search_session_page.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/get_search_session_page.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [check_non_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/check_non_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode), [expire_persisted_sessions.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/data_enhanced/server/search/session/expire_persisted_sessions.ts#:~:text=KueryNode)+ 2 more | 8.1 | | urlDrilldown | | [context_variables.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/variables/context_variables.ts#:~:text=Filter), [context_variables.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/variables/context_variables.ts#:~:text=Filter), [url_drilldown.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/url_drilldown.tsx#:~:text=Filter), [url_drilldown.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/url_drilldown.tsx#:~:text=Filter), [data.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/test/data.ts#:~:text=Filter), [data.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/test/data.ts#:~:text=Filter) | 8.1 | | urlDrilldown | | [context_variables.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/variables/context_variables.ts#:~:text=Filter), [context_variables.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/variables/context_variables.ts#:~:text=Filter), [url_drilldown.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/url_drilldown.tsx#:~:text=Filter), [url_drilldown.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/url_drilldown.tsx#:~:text=Filter), [data.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/test/data.ts#:~:text=Filter), [data.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/test/data.ts#:~:text=Filter) | 8.1 | | urlDrilldown | | [context_variables.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/variables/context_variables.ts#:~:text=Filter), [context_variables.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/variables/context_variables.ts#:~:text=Filter), [url_drilldown.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/url_drilldown.tsx#:~:text=Filter), [url_drilldown.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/url_drilldown.tsx#:~:text=Filter), [data.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/test/data.ts#:~:text=Filter), [data.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/drilldowns/url_drilldown/public/lib/test/data.ts#:~:text=Filter) | 8.1 | +| embeddable | | [attribute_service.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/lib/attribute_service/attribute_service.tsx#:~:text=SavedObjectSaveModal), [attribute_service.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/embeddable/public/lib/attribute_service/attribute_service.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | @@ -39,27 +44,57 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Plugin | Deprecated API | Reference location(s) | Remove By | | --------|-------|-----------|-----------| | graph | | [search_bar.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/search_bar.tsx#:~:text=esKuery), [search_bar.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/search_bar.tsx#:~:text=esKuery), [search_bar.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/search_bar.tsx#:~:text=esKuery) | 8.1 | +| graph | | [save_modal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/save_modal.tsx#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/components/save_modal.tsx#:~:text=SavedObjectSaveModal), [on_save_search.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/top_nav/on_save_search.tsx#:~:text=SavedObjectSaveModal), [on_save_search.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/main/components/top_nav/on_save_search.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | +| graph | | [listing_route.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/apps/listing_route.tsx#:~:text=settings), [listing_route.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/public/apps/listing_route.tsx#:~:text=settings) | 8.8.0 | +| graph | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/graph/server/plugin.ts#:~:text=license%24) | 8.8.0 | | discover | | [anchor.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/anchor.ts#:~:text=fetch), [fetch_hits_in_interval.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/utils/fetch_hits_in_interval.ts#:~:text=fetch) | 8.1 | | discover | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=esFilters), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=esFilters), [explore_data_chart_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.ts#:~:text=esFilters), [explore_data_chart_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.ts#:~:text=esFilters) | 8.1 | -| discover | | [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter) | 8.1 | -| discover | | [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter) | 8.1 | +| discover | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter)+ 4 more | 8.1 | +| discover | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter)+ 4 more | 8.1 | | discover | | [anchor.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/anchor.ts#:~:text=fetch), [fetch_hits_in_interval.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/utils/fetch_hits_in_interval.ts#:~:text=fetch) | 8.1 | -| discover | | [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=Filter) | 8.1 | +| discover | | [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [saved_search_embeddable.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context_state.test.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/public/application/context/services/context_state.test.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [context.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/discover/target/types/public/application/context/services/context.d.ts#:~:text=Filter), [explore_data_context_menu_action.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts#:~:text=Filter)+ 4 more | 8.1 | | discoverEnhanced | | [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=RangeFilter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=RangeFilter) | 8.1 | | discoverEnhanced | | [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=RangeFilter), [explore_data_chart_action.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts#:~:text=RangeFilter) | 8.1 | +## Fleet + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| fleet | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | 8.8.0 | +| fleet | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | 8.8.0 | +| fleet | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/server/plugin.ts#:~:text=disabled) | 8.8.0 | +| fleet | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/public/applications/integrations/index.tsx#:~:text=appBasePath), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/public/applications/fleet/index.d.ts#:~:text=appBasePath), [index.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/public/applications/integrations/index.d.ts#:~:text=appBasePath) | 8.8.0 | +| fleet | | [plugin.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/server/plugin.d.ts#:~:text=AsyncPlugin), [plugin.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/fleet/target/types/server/plugin.d.ts#:~:text=AsyncPlugin) | 8.8.0 | + + + ## GIS | Plugin | Deprecated API | Reference location(s) | Remove By | | --------|-------|-----------|-----------| | maps | | [es_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_source/es_source.ts#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch) | 8.1 | | maps | | [locators.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/locators.test.ts#:~:text=esFilters), [locators.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/locators.test.ts#:~:text=esFilters) | 8.1 | -| maps | | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter) | 8.1 | -| maps | | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter) | 8.1 | +| maps | | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter) | 8.1 | +| maps | | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter) | 8.1 | | maps | | [es_source.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_source/es_source.ts#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch), [es_search_source.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/sources/es_search_source/es_search_source.tsx#:~:text=fetch) | 8.1 | -| maps | | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter) | 8.1 | +| maps | | [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [can_skip_fetch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/classes/util/can_skip_fetch.test.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=Filter) | 8.1 | +| maps | | [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings), [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings), [maps_list_view.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/list_page/maps_list_view.tsx#:~:text=settings) | 8.8.0 | +| maps | | [render_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/render_app.tsx#:~:text=onAppLeave), [map_app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/map_page/map_app/map_app.tsx#:~:text=onAppLeave), [map_page.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/public/routes/map_page/map_page.tsx#:~:text=onAppLeave), [render_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/render_app.d.ts#:~:text=onAppLeave), [map_page.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_page.d.ts#:~:text=onAppLeave), [map_app.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/target/types/public/routes/map_page/map_app/map_app.d.ts#:~:text=onAppLeave) | 8.8.0 | +| maps | | [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/maps/server/saved_objects/saved_object_migrations.ts#:~:text=warning) | 8.8.0 | +| mapsEms | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/maps_ems/server/index.ts#:~:text=license%24) | 8.8.0 | +| mapsEms | | [index.ts](https://github.com/elastic/kibana/tree/master/src/plugins/maps_ems/server/index.ts#:~:text=refresh) | 8.8.0 | + + + +## Kibana Core + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| cloud | | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cloud/public/plugin.tsx#:~:text=environment) | 8.8.0 | +| kibanaOverview | | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_overview/public/application.tsx#:~:text=appBasePath) | 8.8.0 | +| savedObjectsTaggingOss | | [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/decorator/types.ts#:~:text=SavedObject), [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/decorator/types.ts#:~:text=SavedObject), [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject), [api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/saved_objects_tagging_oss/public/api.ts#:~:text=SavedObject) | 8.8.0 | @@ -67,11 +102,73 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Plugin | Deprecated API | Reference location(s) | Remove By | | --------|-------|-----------|-----------| -| inputControlVis | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=fetch), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=fetch) | 8.1 | -| inputControlVis | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=fetch), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=fetch) | 8.1 | | dashboard | | [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter)+ 5 more | 8.1 | | dashboard | | [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter)+ 5 more | 8.1 | | dashboard | | [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [filter_utils.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/filter_utils.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter), [dashboard_state_slice.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/state/dashboard_state_slice.ts#:~:text=Filter)+ 5 more | 8.1 | +| dashboard | | [saved_objects.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_objects.ts#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/top_nav/save_modal.tsx#:~:text=SavedObjectSaveModal), [save_modal.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/top_nav/save_modal.tsx#:~:text=SavedObjectSaveModal), [saved_object_save_modal_dashboard.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/presentation_util/public/components/saved_object_save_modal_dashboard.tsx#:~:text=SavedObjectSaveModal), [saved_object_save_modal_dashboard.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/presentation_util/public/components/saved_object_save_modal_dashboard.tsx#:~:text=SavedObjectSaveModal) | 8.8.0 | +| dashboard | | [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_object_loader.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_object_loader.ts#:~:text=SavedObject), [saved_objects.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/services/saved_objects.ts#:~:text=SavedObject), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObject), [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObject), [dashboard_tagging.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/dashboard_tagging.ts#:~:text=SavedObject), [dashboard_tagging.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/lib/dashboard_tagging.ts#:~:text=SavedObject), [clone_panel_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/clone_panel_action.tsx#:~:text=SavedObject), [clone_panel_action.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/actions/clone_panel_action.tsx#:~:text=SavedObject)+ 1 more | 8.8.0 | +| dashboard | | [saved_dashboard.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/saved_dashboards/saved_dashboard.ts#:~:text=SavedObjectClass) | 8.8.0 | +| dashboard | | [dashboard_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/listing/dashboard_listing.tsx#:~:text=settings), [dashboard_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/listing/dashboard_listing.tsx#:~:text=settings) | 8.8.0 | +| dashboard | | [types.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/types.ts#:~:text=onAppLeave), [dashboard_router.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/application/dashboard_router.tsx#:~:text=onAppLeave), [plugin.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/public/plugin.tsx#:~:text=onAppLeave), [types.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/target/types/public/types.d.ts#:~:text=onAppLeave) | 8.8.0 | +| dashboard | | [migrations_730.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/server/saved_objects/migrations_730.ts#:~:text=warning), [migrations_730.ts](https://github.com/elastic/kibana/tree/master/src/plugins/dashboard/server/saved_objects/migrations_730.ts#:~:text=warning) | 8.8.0 | +| inputControlVis | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=fetch), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=fetch) | 8.1 | +| inputControlVis | | [list_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/list_control_factory.ts#:~:text=fetch), [range_control_factory.ts](https://github.com/elastic/kibana/tree/master/src/plugins/input_control_vis/public/control/range_control_factory.ts#:~:text=fetch) | 8.1 | + + + +## Kibana Telemetry + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| kibanaUsageCollection | | [ops_stats_collector.ts](https://github.com/elastic/kibana/tree/master/src/plugins/kibana_usage_collection/server/collectors/ops_stats/ops_stats_collector.ts#:~:text=process) | 8.8.0 | + + + +## Logstash + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| logstash | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/logstash/public/plugin.ts#:~:text=license%24) | 8.8.0 | + + + +## Machine Learning UI + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| ml | | [check_license.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/license/check_license.tsx#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/plugin.ts#:~:text=license%24) | 8.8.0 | +| ml | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/server/plugin.ts#:~:text=license%24), [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/transform/server/services/license.ts#:~:text=license%24) | 8.8.0 | +| ml | | [app.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/public/application/app.tsx#:~:text=onAppLeave) | 8.8.0 | +| ml | | [errors.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/common/util/errors/errors.test.ts#:~:text=req), [errors.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/ml/common/util/errors/errors.test.ts#:~:text=req) | 8.8.0 + +Note to maintainers: when looking at usages, mind that typical use could be inside a `catch` block, +so TS and code-reference navigation might not highlight them. | + + + +## Platform Security + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| spaces | | [on_post_auth_interceptor.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/lib/request_interceptors/on_post_auth_interceptor.ts#:~:text=getKibanaFeatures), [spaces_usage_collector.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.ts#:~:text=getKibanaFeatures), [on_post_auth_interceptor.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/lib/request_interceptors/on_post_auth_interceptor.test.ts#:~:text=getKibanaFeatures), [app_authorization.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/app_authorization.ts#:~:text=getKibanaFeatures), [privileges.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.ts#:~:text=getKibanaFeatures), [authorization_service.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/authorization_service.tsx#:~:text=getKibanaFeatures), [app_authorization.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/app_authorization.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures), [privileges.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/privileges/privileges.test.ts#:~:text=getKibanaFeatures)+ 17 more | 8.8.0 | +| spaces | | [spaces_usage_collector.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/plugin.ts#:~:text=license%24), [spaces_usage_collector.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.test.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/plugin.ts#:~:text=license%24) | 8.8.0 | +| security | | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | 8.8.0 | +| security | | [disable_ui_capabilities.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/disable_ui_capabilities.ts#:~:text=requiredRoles) | 8.8.0 + +This is relied on by the reporting feature, and should be removed once reporting +migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 | +| security | | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | 8.8.0 | +| security | | [elasticsearch_role.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [put_payload.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.ts#:~:text=disabled), [primary_feature_privilege.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/model/primary_feature_privilege.ts#:~:text=disabled), [elasticsearch_role.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/roles/elasticsearch_role.test.ts#:~:text=disabled), [kibana_features.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/management/roles/__fixtures__/kibana_features.ts#:~:text=disabled), [put.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/put.test.ts#:~:text=disabled), [put_payload.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/routes/authorization/roles/model/put_payload.test.ts#:~:text=disabled) | 8.8.0 | +| security | | [disable_ui_capabilities.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/disable_ui_capabilities.ts#:~:text=requiredRoles) | 8.8.0 + +This is relied on by the reporting feature, and should be removed once reporting +migrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914 | +| security | | [authorization_service.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/server/authorization/authorization_service.tsx#:~:text=getElasticsearchFeatures) | 8.8.0 | +| security | | [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode), [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode) | 8.8.0 | +| security | | [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/plugin.tsx#:~:text=license%24) | 8.8.0 | +| security | | [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode), [license_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/common/licensing/license_service.test.ts#:~:text=mode) | 8.8.0 | +| security | | [logout_app.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/authentication/logout/logout_app.test.ts#:~:text=appBasePath) | 8.8.0 | +| security | | [logout_app.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security/public/authentication/logout/logout_app.test.ts#:~:text=onAppLeave) | 8.8.0 | @@ -79,12 +176,51 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Plugin | Deprecated API | Reference location(s) | Remove By | | --------|-------|-----------|-----------| -| stackAlerts | | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType)+ 14 more | 8.2 | -| stackAlerts | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esKuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esKuery) | 8.1 | -| stackAlerts | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esQuery), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/index.tsx#:~:text=esQuery) | 8.1 | -| stackAlerts | | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType)+ 38 more | 8.2 | -| stackAlerts | | [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [single_field_select.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/util_components/single_field_select.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType), [entity_index_expression.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/public/alert_types/geo_containment/query_builder/expressions/entity_index_expression.tsx#:~:text=IFieldType)+ 14 more | 8.2 | -| alerting | | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode) | 8.1 | -| alerting | | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode) | 8.1 | -| alerting | | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=nodeBuilder), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=nodeBuilder), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder), [find_and_cleanup_tasks.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/cleanup_failed_executions/find_and_cleanup_tasks.ts#:~:text=nodeBuilder) | 8.1 | -| alerting | | [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode), [rules_client.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/rules_client/rules_client.ts#:~:text=KueryNode) | 8.1 | \ No newline at end of file +| stackAlerts | | [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType) | 8.2 | +| stackAlerts | | [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType) | 8.2 | +| stackAlerts | | [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType), [single_field_select.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/stack_alerts/target/types/public/alert_types/geo_containment/query_builder/util_components/single_field_select.d.ts#:~:text=IFieldType) | 8.2 | +| alerting | | [plugin.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/plugin.test.ts#:~:text=getKibanaFeatures) | 8.8.0 | +| alerting | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/plugin.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/lib/license_state.test.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/alerting/server/lib/license_state.test.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/plugin.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/lib/license_state.test.ts#:~:text=license%24), [license_state.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/actions/server/lib/license_state.test.ts#:~:text=license%24) | 8.8.0 | + + + +## Security solution + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| securitySolution | | [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode)+ 2 more | 8.8.0 | +| securitySolution | | [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [policy_config.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/common/license/policy_config.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [fleet_integration.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/fleet_integration/fleet_integration.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [license_watch.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/lib/policy/license_watch.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode), [isolation.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/server/endpoint/routes/actions/isolation.test.ts#:~:text=mode)+ 2 more | 8.8.0 | +| securitySolution | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/index.tsx#:~:text=onAppLeave) | 8.8.0 | +| securitySolution | | [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/timelines/components/flyout/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/timelines/components/flyout/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/bottom_bar/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/bottom_bar/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/template_wrapper/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/index.tsx#:~:text=AppLeaveHandler), [index.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/home/index.tsx#:~:text=AppLeaveHandler), [routes.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/routes.tsx#:~:text=AppLeaveHandler), [routes.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/security_solution/public/app/routes.tsx#:~:text=AppLeaveHandler)+ 3 more | 8.8.0 | + + + +## Stack Management + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| upgradeAssistant | | [reindex_service.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.ts#:~:text=license%24), [reindex_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.test.ts#:~:text=license%24), [reindex_service.test.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/upgrade_assistant/server/lib/reindexing/reindex_service.test.ts#:~:text=license%24), [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/index_lifecycle_management/server/services/license.ts#:~:text=license%24), [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/server/services/license.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/server/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/remote_clusters/server/plugin.ts#:~:text=license%24), [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/rollup/server/services/license.ts#:~:text=license%24), [license.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/snapshot_restore/server/services/license.ts#:~:text=license%24) | 8.8.0 | +| licenseManagement | | [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/license_management/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/cross_cluster_replication/public/plugin.ts#:~:text=license%24), [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/public/plugin.tsx#:~:text=license%24), [plugin.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/painless_lab/public/plugin.tsx#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/searchprofiler/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/watcher/public/plugin.ts#:~:text=license%24), [plugin.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/watcher/public/plugin.ts#:~:text=license%24) | 8.8.0 | + + + +## Stack Monitoring + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| monitoring | | [legacy_shims.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/public/legacy_shims.ts#:~:text=injectedMetadata) | 8.8.0 | +| monitoring | | [bulk_uploader.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/monitoring/server/kibana_monitoring/bulk_uploader.ts#:~:text=process) | 8.8.0 | + + + +## Vis Editors + +| Plugin | Deprecated API | Reference location(s) | Remove By | +| --------|-------|-----------|-----------| +| lens | | [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts#:~:text=SavedObject), [check_for_duplicate_title.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/check_for_duplicate_title.d.ts#:~:text=SavedObject), [check_for_duplicate_title.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/check_for_duplicate_title.d.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.d.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.d.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.d.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject), [display_duplicate_title_confirm_modal.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/utils/saved_objects_utils/display_duplicate_title_confirm_modal.ts#:~:text=SavedObject)+ 2 more | 8.8.0 | +| lens | | [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/types.ts#:~:text=onAppLeave), [types.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/types.ts#:~:text=onAppLeave), [mounter.tsx](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/public/app_plugin/mounter.tsx#:~:text=onAppLeave), [visualize_top_nav.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_top_nav.tsx#:~:text=onAppLeave), [visualize_editor_common.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_editor_common.tsx#:~:text=onAppLeave), [app.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/app.tsx#:~:text=onAppLeave), [index.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/index.tsx#:~:text=onAppLeave), [app.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/app.d.ts#:~:text=onAppLeave), [index.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/index.d.ts#:~:text=onAppLeave), [visualize_editor_common.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/target/types/public/visualize_app/components/visualize_editor_common.d.ts#:~:text=onAppLeave)+ 1 more | 8.8.0 | +| lens | | [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/migrations/saved_object_migrations.ts#:~:text=warning), [saved_object_migrations.ts](https://github.com/elastic/kibana/tree/master/x-pack/plugins/lens/server/migrations/saved_object_migrations.ts#:~:text=warning) | 8.8.0 | +| visualizations | | [visualize_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_listing.tsx#:~:text=settings), [visualize_listing.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/visualizations/public/visualize_app/components/visualize_listing.tsx#:~:text=settings) | 8.8.0 | +| management | | [application.tsx](https://github.com/elastic/kibana/tree/master/src/plugins/management/public/application.tsx#:~:text=appBasePath), [application.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/management/target/types/public/application.d.ts#:~:text=appBasePath) | 8.8.0 | +| visTypeVega | | [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/plugin.ts#:~:text=injectedMetadata) | 8.8.0 | +| visTypeVega | | [search_api.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/data_model/search_api.ts#:~:text=injectedMetadata), [plugin.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/public/plugin.ts#:~:text=injectedMetadata), [search_api.d.ts](https://github.com/elastic/kibana/tree/master/src/plugins/vis_types/vega/target/types/public/data_model/search_api.d.ts#:~:text=injectedMetadata) | 8.8.0 | \ No newline at end of file diff --git a/api_docs/dev_tools.mdx b/api_docs/dev_tools.mdx index eee8b46fce45d..fcec20c8c9ba2 100644 --- a/api_docs/dev_tools.mdx +++ b/api_docs/dev_tools.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/devTools title: "devTools" image: https://source.unsplash.com/400x175/?github summary: API docs for the devTools plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'devTools'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/discover.devdocs.json b/api_docs/discover.devdocs.json index 37bf36e243699..4f5f940b63275 100644 --- a/api_docs/discover.devdocs.json +++ b/api_docs/discover.devdocs.json @@ -884,7 +884,7 @@ "label": "sharingSavedObjectProps", "description": [], "signature": [ - "{ outcome?: \"conflict\" | \"aliasMatch\" | \"exactMatch\" | undefined; aliasTargetId?: string | undefined; errorJSON?: string | undefined; } | undefined" + "{ outcome?: \"exactMatch\" | \"aliasMatch\" | \"conflict\" | undefined; aliasTargetId?: string | undefined; aliasPurpose?: \"savedObjectConversion\" | \"savedObjectImport\" | undefined; errorJSON?: string | undefined; } | undefined" ], "path": "src/plugins/discover/public/services/saved_searches/types.ts", "deprecated": false diff --git a/api_docs/discover.mdx b/api_docs/discover.mdx index 369c5b190c11d..e09a657d79b33 100644 --- a/api_docs/discover.mdx +++ b/api_docs/discover.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/discover title: "discover" image: https://source.unsplash.com/400x175/?github summary: API docs for the discover plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'discover'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/discover_enhanced.mdx b/api_docs/discover_enhanced.mdx index 80651eb7cc7cc..c22a1a2bbca20 100644 --- a/api_docs/discover_enhanced.mdx +++ b/api_docs/discover_enhanced.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/discoverEnhanced title: "discoverEnhanced" image: https://source.unsplash.com/400x175/?github summary: API docs for the discoverEnhanced plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'discoverEnhanced'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/elastic_apm_synthtrace.mdx b/api_docs/elastic_apm_synthtrace.mdx index 2d28734152a8c..4620947c33e95 100644 --- a/api_docs/elastic_apm_synthtrace.mdx +++ b/api_docs/elastic_apm_synthtrace.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/elastic-apm-synthtrace title: "@elastic/apm-synthtrace" image: https://source.unsplash.com/400x175/?github summary: API docs for the @elastic/apm-synthtrace plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@elastic/apm-synthtrace'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/elastic_datemath.mdx b/api_docs/elastic_datemath.mdx index aba803d48c795..b4776e2692e2d 100644 --- a/api_docs/elastic_datemath.mdx +++ b/api_docs/elastic_datemath.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/elastic-datemath title: "@elastic/datemath" image: https://source.unsplash.com/400x175/?github summary: API docs for the @elastic/datemath plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@elastic/datemath'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/embeddable.devdocs.json b/api_docs/embeddable.devdocs.json index 612ce94547c24..f6bbd0035ca40 100644 --- a/api_docs/embeddable.devdocs.json +++ b/api_docs/embeddable.devdocs.json @@ -1008,7 +1008,13 @@ "label": "settings", "description": [], "signature": [ - "EmbeddableContainerSettings", + { + "pluginId": "embeddable", + "scope": "public", + "docId": "kibEmbeddablePluginApi", + "section": "def-public.EmbeddableContainerSettings", + "text": "EmbeddableContainerSettings" + }, " | undefined" ], "path": "src/plugins/embeddable/public/lib/containers/container.ts", @@ -6023,6 +6029,49 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "embeddable", + "id": "def-public.EmbeddableContainerSettings", + "type": "Interface", + "tags": [], + "label": "EmbeddableContainerSettings", + "description": [], + "path": "src/plugins/embeddable/public/lib/containers/i_container.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "embeddable", + "id": "def-public.EmbeddableContainerSettings.initializeSequentially", + "type": "CompoundType", + "tags": [], + "label": "initializeSequentially", + "description": [ + "\nIf true, the container will wait for each embeddable to load after creation before loading the next embeddable." + ], + "signature": [ + "boolean | undefined" + ], + "path": "src/plugins/embeddable/public/lib/containers/i_container.ts", + "deprecated": false + }, + { + "parentPluginId": "embeddable", + "id": "def-public.EmbeddableContainerSettings.childIdInitializeOrder", + "type": "Array", + "tags": [], + "label": "childIdInitializeOrder", + "description": [ + "\nInitialise children in the order specified. If an ID does not match it will be skipped and if a child is not included it will be initialized in the default order after the list of provided IDs." + ], + "signature": [ + "string[] | undefined" + ], + "path": "src/plugins/embeddable/public/lib/containers/i_container.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "embeddable", "id": "def-public.EmbeddableContext", diff --git a/api_docs/embeddable.mdx b/api_docs/embeddable.mdx index 931f0b5966e84..624934540cabb 100644 --- a/api_docs/embeddable.mdx +++ b/api_docs/embeddable.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/embeddable title: "embeddable" image: https://source.unsplash.com/400x175/?github summary: API docs for the embeddable plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'embeddable'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 471 | 0 | 384 | 5 | +| 474 | 0 | 385 | 4 | ## Client diff --git a/api_docs/embeddable_enhanced.mdx b/api_docs/embeddable_enhanced.mdx index 182867976fb2a..bb6a0292ce768 100644 --- a/api_docs/embeddable_enhanced.mdx +++ b/api_docs/embeddable_enhanced.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/embeddableEnhanced title: "embeddableEnhanced" image: https://source.unsplash.com/400x175/?github summary: API docs for the embeddableEnhanced plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'embeddableEnhanced'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/encrypted_saved_objects.mdx b/api_docs/encrypted_saved_objects.mdx index b813fc580f5ca..8b4e95d4a1a28 100644 --- a/api_docs/encrypted_saved_objects.mdx +++ b/api_docs/encrypted_saved_objects.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/encryptedSavedObjects title: "encryptedSavedObjects" image: https://source.unsplash.com/400x175/?github summary: API docs for the encryptedSavedObjects plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'encryptedSavedObjects'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/enterprise_search.mdx b/api_docs/enterprise_search.mdx index cb4a1b99de487..fafa78ee311f4 100644 --- a/api_docs/enterprise_search.mdx +++ b/api_docs/enterprise_search.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/enterpriseSearch title: "enterpriseSearch" image: https://source.unsplash.com/400x175/?github summary: API docs for the enterpriseSearch plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'enterpriseSearch'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/es_ui_shared.devdocs.json b/api_docs/es_ui_shared.devdocs.json index 3a1d9cad05010..16fd42fccb948 100644 --- a/api_docs/es_ui_shared.devdocs.json +++ b/api_docs/es_ui_shared.devdocs.json @@ -700,6 +700,37 @@ "returnComment": [], "initialIsOpen": false }, + { + "parentPluginId": "esUiShared", + "id": "def-public.ViewApiRequestFlyout", + "type": "Function", + "tags": [], + "label": "ViewApiRequestFlyout", + "description": [], + "signature": [ + "(props: ViewApiRequestFlyoutProps) => JSX.Element" + ], + "path": "src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "esUiShared", + "id": "def-public.ViewApiRequestFlyout.$1", + "type": "Object", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "ViewApiRequestFlyoutProps" + ], + "path": "src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "esUiShared", "id": "def-public.WithPrivileges", diff --git a/api_docs/es_ui_shared.mdx b/api_docs/es_ui_shared.mdx index 4edf831301386..ad34313432e51 100644 --- a/api_docs/es_ui_shared.mdx +++ b/api_docs/es_ui_shared.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/esUiShared title: "esUiShared" image: https://source.unsplash.com/400x175/?github summary: API docs for the esUiShared plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'esUiShared'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-ma | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 110 | 3 | 106 | 3 | +| 112 | 3 | 108 | 3 | ## Client diff --git a/api_docs/event_annotation.devdocs.json b/api_docs/event_annotation.devdocs.json new file mode 100644 index 0000000000000..681635d96de86 --- /dev/null +++ b/api_docs/event_annotation.devdocs.json @@ -0,0 +1,709 @@ +{ + "id": "eventAnnotation", + "client": { + "classes": [], + "functions": [], + "interfaces": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-public.EventAnnotationServiceType", + "type": "Interface", + "tags": [], + "label": "EventAnnotationServiceType", + "description": [], + "path": "src/plugins/event_annotation/public/event_annotation_service/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-public.EventAnnotationServiceType.toExpression", + "type": "Function", + "tags": [], + "label": "toExpression", + "description": [], + "signature": [ + "(props: ", + { + "pluginId": "eventAnnotation", + "scope": "common", + "docId": "kibEventAnnotationPluginApi", + "section": "def-common.EventAnnotationArgs", + "text": "EventAnnotationArgs" + }, + ") => ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/event_annotation/public/event_annotation_service/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-public.EventAnnotationServiceType.toExpression.$1", + "type": "CompoundType", + "tags": [], + "label": "props", + "description": [], + "signature": [ + { + "pluginId": "eventAnnotation", + "scope": "common", + "docId": "kibEventAnnotationPluginApi", + "section": "def-common.EventAnnotationArgs", + "text": "EventAnnotationArgs" + } + ], + "path": "src/plugins/event_annotation/public/event_annotation_service/types.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + } + ], + "initialIsOpen": false + } + ], + "enums": [], + "misc": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-public.defaultAnnotationColor", + "type": "string", + "tags": [], + "label": "defaultAnnotationColor", + "description": [], + "path": "src/plugins/event_annotation/public/event_annotation_service/helpers.ts", + "deprecated": false, + "initialIsOpen": false + } + ], + "objects": [], + "start": { + "parentPluginId": "eventAnnotation", + "id": "def-public.EventAnnotationService", + "type": "Class", + "tags": [], + "label": "EventAnnotationService", + "description": [], + "path": "src/plugins/event_annotation/public/event_annotation_service/index.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-public.EventAnnotationService.getService", + "type": "Function", + "tags": [], + "label": "getService", + "description": [], + "signature": [ + "() => Promise<", + { + "pluginId": "eventAnnotation", + "scope": "public", + "docId": "kibEventAnnotationPluginApi", + "section": "def-public.EventAnnotationServiceType", + "text": "EventAnnotationServiceType" + }, + ">" + ], + "path": "src/plugins/event_annotation/public/event_annotation_service/index.tsx", + "deprecated": false, + "children": [], + "returnComment": [] + } + ], + "lifecycle": "start", + "initialIsOpen": true + } + }, + "server": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "common": { + "classes": [], + "functions": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.eventAnnotationGroup", + "type": "Function", + "tags": [], + "label": "eventAnnotationGroup", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionFunctionDefinition", + "text": "ExpressionFunctionDefinition" + }, + "<\"event_annotation_group\", null, ", + { + "pluginId": "eventAnnotation", + "scope": "common", + "docId": "kibEventAnnotationPluginApi", + "section": "def-common.EventAnnotationGroupArgs", + "text": "EventAnnotationGroupArgs" + }, + ", ", + "EventAnnotationGroupOutput", + ", ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExecutionContext", + "text": "ExecutionContext" + }, + "<", + { + "pluginId": "inspector", + "scope": "common", + "docId": "kibInspectorPluginApi", + "section": "def-common.Adapters", + "text": "Adapters" + }, + ", ", + "SerializableRecord", + ">>" + ], + "path": "src/plugins/event_annotation/common/event_annotation_group/index.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + } + ], + "interfaces": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.EventAnnotationGroupArgs", + "type": "Interface", + "tags": [], + "label": "EventAnnotationGroupArgs", + "description": [], + "path": "src/plugins/event_annotation/common/event_annotation_group/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.EventAnnotationGroupArgs.annotations", + "type": "Array", + "tags": [], + "label": "annotations", + "description": [], + "signature": [ + { + "pluginId": "eventAnnotation", + "scope": "common", + "docId": "kibEventAnnotationPluginApi", + "section": "def-common.EventAnnotationOutput", + "text": "EventAnnotationOutput" + }, + "[]" + ], + "path": "src/plugins/event_annotation/common/event_annotation_group/index.ts", + "deprecated": false + } + ], + "initialIsOpen": false + } + ], + "enums": [], + "misc": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.EventAnnotationArgs", + "type": "Type", + "tags": [], + "label": "EventAnnotationArgs", + "description": [], + "signature": [ + "{ time: string; } & ", + "StyleProps" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.EventAnnotationConfig", + "type": "Type", + "tags": [], + "label": "EventAnnotationConfig", + "description": [], + "signature": [ + "{ id: string; key: { type: \"point_in_time\"; timestamp: string; }; } & ", + "StyleProps" + ], + "path": "src/plugins/event_annotation/common/types.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.EventAnnotationOutput", + "type": "Type", + "tags": [], + "label": "EventAnnotationOutput", + "description": [], + "signature": [ + "{ time: string; } & ", + "StyleProps", + " & { type: \"manual_event_annotation\"; }" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/types.ts", + "deprecated": false, + "initialIsOpen": false + } + ], + "objects": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation", + "type": "Object", + "tags": [], + "label": "manualEventAnnotation", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.name", + "type": "string", + "tags": [], + "label": "name", + "description": [], + "signature": [ + "\"manual_event_annotation\"" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.aliases", + "type": "Array", + "tags": [], + "label": "aliases", + "description": [], + "signature": [ + "never[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.type", + "type": "string", + "tags": [], + "label": "type", + "description": [], + "signature": [ + "\"manual_event_annotation\"" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.inputTypes", + "type": "Array", + "tags": [], + "label": "inputTypes", + "description": [], + "signature": [ + "\"null\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args", + "type": "Object", + "tags": [], + "label": "args", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.time", + "type": "Object", + "tags": [], + "label": "time", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.time.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"string\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.time.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.label", + "type": "Object", + "tags": [], + "label": "label", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.label.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"string\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.label.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.color", + "type": "Object", + "tags": [], + "label": "color", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.color.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"string\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.color.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineStyle", + "type": "Object", + "tags": [], + "label": "lineStyle", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineStyle.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"string\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineStyle.options", + "type": "Array", + "tags": [], + "label": "options", + "description": [], + "signature": [ + "(\"solid\" | \"dashed\" | \"dotted\")[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineStyle.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineWidth", + "type": "Object", + "tags": [], + "label": "lineWidth", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineWidth.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"number\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.lineWidth.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.icon", + "type": "Object", + "tags": [], + "label": "icon", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.icon.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"string\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.icon.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.textVisibility", + "type": "Object", + "tags": [], + "label": "textVisibility", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.textVisibility.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"boolean\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.textVisibility.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.isHidden", + "type": "Object", + "tags": [], + "label": "isHidden", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.isHidden.types", + "type": "Array", + "tags": [], + "label": "types", + "description": [], + "signature": [ + "\"boolean\"[]" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.args.isHidden.help", + "type": "string", + "tags": [], + "label": "help", + "description": [], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + } + ] + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.fn", + "type": "Function", + "tags": [], + "label": "fn", + "description": [], + "signature": [ + "(input: unknown, args: ", + { + "pluginId": "eventAnnotation", + "scope": "common", + "docId": "kibEventAnnotationPluginApi", + "section": "def-common.EventAnnotationArgs", + "text": "EventAnnotationArgs" + }, + ") => { time: string; label: string; color?: string | undefined; icon?: string | undefined; lineWidth?: number | undefined; lineStyle?: ", + "LineStyle", + " | undefined; textVisibility?: boolean | undefined; isHidden?: boolean | undefined; type: \"manual_event_annotation\"; }" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.fn.$1", + "type": "Unknown", + "tags": [], + "label": "input", + "description": [], + "signature": [ + "unknown" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + }, + { + "parentPluginId": "eventAnnotation", + "id": "def-common.manualEventAnnotation.fn.$2", + "type": "CompoundType", + "tags": [], + "label": "args", + "description": [], + "signature": [ + "{ time: string; } & ", + "StyleProps" + ], + "path": "src/plugins/event_annotation/common/manual_event_annotation/index.ts", + "deprecated": false + } + ] + } + ], + "initialIsOpen": false + } + ] + } +} \ No newline at end of file diff --git a/api_docs/event_annotation.mdx b/api_docs/event_annotation.mdx new file mode 100644 index 0000000000000..e980e894ec9c8 --- /dev/null +++ b/api_docs/event_annotation.mdx @@ -0,0 +1,47 @@ +--- +id: kibEventAnnotationPluginApi +slug: /kibana-dev-docs/api/eventAnnotation +title: "eventAnnotation" +image: https://source.unsplash.com/400x175/?github +summary: API docs for the eventAnnotation plugin +date: 2022-03-28 +tags: ['contributor', 'dev', 'apidocs', 'kibana', 'eventAnnotation'] +warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. +--- +import eventAnnotationObj from './event_annotation.devdocs.json'; + +The Event Annotation service contains expressions for event annotations + +Contact [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) for questions regarding this plugin. + +**Code health stats** + +| Public API count | Any count | Items lacking comments | Missing exports | +|-------------------|-----------|------------------------|-----------------| +| 49 | 0 | 49 | 3 | + +## Client + +### Start + + +### Interfaces + + +### Consts, variables and types + + +## Common + +### Objects + + +### Functions + + +### Interfaces + + +### Consts, variables and types + + diff --git a/api_docs/event_log.devdocs.json b/api_docs/event_log.devdocs.json index 6b29890edb5ad..5bed6025a0b48 100644 --- a/api_docs/event_log.devdocs.json +++ b/api_docs/event_log.devdocs.json @@ -1047,7 +1047,7 @@ "label": "data", "description": [], "signature": [ - "(Readonly<{ user?: Readonly<{ name?: string | undefined; } & {}> | undefined; message?: string | undefined; error?: Readonly<{ message?: string | undefined; type?: string | undefined; id?: string | undefined; code?: string | undefined; stack_trace?: string | undefined; } & {}> | undefined; tags?: string[] | undefined; kibana?: Readonly<{ alert?: Readonly<{ rule?: Readonly<{ execution?: Readonly<{ status?: string | undefined; metrics?: Readonly<{ number_of_triggered_actions?: number | undefined; number_of_searches?: number | undefined; total_indexing_duration_ms?: number | undefined; es_search_duration_ms?: number | undefined; total_search_duration_ms?: number | undefined; execution_gap_duration_s?: number | undefined; } & {}> | undefined; uuid?: string | undefined; status_order?: number | undefined; } & {}> | undefined; } & {}> | undefined; } & {}> | undefined; version?: string | undefined; saved_objects?: Readonly<{ type?: string | undefined; id?: string | undefined; rel?: string | undefined; namespace?: string | undefined; type_id?: string | undefined; } & {}>[] | undefined; alerting?: Readonly<{ status?: string | undefined; instance_id?: string | undefined; action_group_id?: string | undefined; action_subgroup?: string | undefined; } & {}> | undefined; server_uuid?: string | undefined; task?: Readonly<{ id?: string | undefined; scheduled?: string | undefined; schedule_delay?: number | undefined; } & {}> | undefined; space_ids?: string[] | undefined; } & {}> | undefined; log?: Readonly<{ logger?: string | undefined; level?: string | undefined; } & {}> | undefined; ecs?: Readonly<{ version?: string | undefined; } & {}> | undefined; rule?: Readonly<{ id?: string | undefined; description?: string | undefined; name?: string | undefined; version?: string | undefined; license?: string | undefined; category?: string | undefined; reference?: string | undefined; author?: string[] | undefined; ruleset?: string | undefined; uuid?: string | undefined; } & {}> | undefined; event?: Readonly<{ start?: string | undefined; type?: string[] | undefined; id?: string | undefined; end?: string | undefined; category?: string[] | undefined; outcome?: string | undefined; url?: string | undefined; original?: string | undefined; duration?: number | undefined; code?: string | undefined; action?: string | undefined; kind?: string | undefined; hash?: string | undefined; dataset?: string | undefined; severity?: number | undefined; created?: string | undefined; ingested?: string | undefined; module?: string | undefined; provider?: string | undefined; reason?: string | undefined; reference?: string | undefined; risk_score?: number | undefined; risk_score_norm?: number | undefined; sequence?: number | undefined; timezone?: string | undefined; } & {}> | undefined; '@timestamp'?: string | undefined; } & {}> | undefined)[]" + "(Readonly<{ user?: Readonly<{ name?: string | undefined; } & {}> | undefined; message?: string | undefined; error?: Readonly<{ message?: string | undefined; type?: string | undefined; id?: string | undefined; code?: string | undefined; stack_trace?: string | undefined; } & {}> | undefined; tags?: string[] | undefined; kibana?: Readonly<{ alert?: Readonly<{ rule?: Readonly<{ consumer?: string | undefined; execution?: Readonly<{ status?: string | undefined; metrics?: Readonly<{ number_of_triggered_actions?: number | undefined; number_of_searches?: number | undefined; total_indexing_duration_ms?: number | undefined; es_search_duration_ms?: number | undefined; total_search_duration_ms?: number | undefined; execution_gap_duration_s?: number | undefined; } & {}> | undefined; uuid?: string | undefined; status_order?: number | undefined; } & {}> | undefined; rule_type_id?: string | undefined; } & {}> | undefined; } & {}> | undefined; version?: string | undefined; saved_objects?: Readonly<{ type?: string | undefined; id?: string | undefined; namespace?: string | undefined; rel?: string | undefined; type_id?: string | undefined; } & {}>[] | undefined; alerting?: Readonly<{ status?: string | undefined; instance_id?: string | undefined; action_group_id?: string | undefined; action_subgroup?: string | undefined; } & {}> | undefined; server_uuid?: string | undefined; task?: Readonly<{ id?: string | undefined; scheduled?: string | undefined; schedule_delay?: number | undefined; } & {}> | undefined; space_ids?: string[] | undefined; } & {}> | undefined; log?: Readonly<{ logger?: string | undefined; level?: string | undefined; } & {}> | undefined; ecs?: Readonly<{ version?: string | undefined; } & {}> | undefined; rule?: Readonly<{ id?: string | undefined; description?: string | undefined; name?: string | undefined; version?: string | undefined; license?: string | undefined; category?: string | undefined; reference?: string | undefined; author?: string[] | undefined; ruleset?: string | undefined; uuid?: string | undefined; } & {}> | undefined; event?: Readonly<{ start?: string | undefined; type?: string[] | undefined; id?: string | undefined; outcome?: string | undefined; end?: string | undefined; category?: string[] | undefined; url?: string | undefined; original?: string | undefined; duration?: number | undefined; code?: string | undefined; action?: string | undefined; kind?: string | undefined; hash?: string | undefined; dataset?: string | undefined; severity?: number | undefined; created?: string | undefined; ingested?: string | undefined; module?: string | undefined; provider?: string | undefined; reason?: string | undefined; reference?: string | undefined; risk_score?: number | undefined; risk_score_norm?: number | undefined; sequence?: number | undefined; timezone?: string | undefined; } & {}> | undefined; '@timestamp'?: string | undefined; } & {}> | undefined)[]" ], "path": "x-pack/plugins/event_log/server/es/cluster_client_adapter.ts", "deprecated": false @@ -1066,7 +1066,7 @@ "label": "IEvent", "description": [], "signature": [ - "DeepPartial | undefined; message?: string | undefined; error?: Readonly<{ message?: string | undefined; type?: string | undefined; id?: string | undefined; code?: string | undefined; stack_trace?: string | undefined; } & {}> | undefined; tags?: string[] | undefined; kibana?: Readonly<{ alert?: Readonly<{ rule?: Readonly<{ execution?: Readonly<{ status?: string | undefined; metrics?: Readonly<{ number_of_triggered_actions?: number | undefined; number_of_searches?: number | undefined; total_indexing_duration_ms?: number | undefined; es_search_duration_ms?: number | undefined; total_search_duration_ms?: number | undefined; execution_gap_duration_s?: number | undefined; } & {}> | undefined; uuid?: string | undefined; status_order?: number | undefined; } & {}> | undefined; } & {}> | undefined; } & {}> | undefined; version?: string | undefined; saved_objects?: Readonly<{ type?: string | undefined; id?: string | undefined; rel?: string | undefined; namespace?: string | undefined; type_id?: string | undefined; } & {}>[] | undefined; alerting?: Readonly<{ status?: string | undefined; instance_id?: string | undefined; action_group_id?: string | undefined; action_subgroup?: string | undefined; } & {}> | undefined; server_uuid?: string | undefined; task?: Readonly<{ id?: string | undefined; scheduled?: string | undefined; schedule_delay?: number | undefined; } & {}> | undefined; space_ids?: string[] | undefined; } & {}> | undefined; log?: Readonly<{ logger?: string | undefined; level?: string | undefined; } & {}> | undefined; ecs?: Readonly<{ version?: string | undefined; } & {}> | undefined; rule?: Readonly<{ id?: string | undefined; description?: string | undefined; name?: string | undefined; version?: string | undefined; license?: string | undefined; category?: string | undefined; reference?: string | undefined; author?: string[] | undefined; ruleset?: string | undefined; uuid?: string | undefined; } & {}> | undefined; event?: Readonly<{ start?: string | undefined; type?: string[] | undefined; id?: string | undefined; end?: string | undefined; category?: string[] | undefined; outcome?: string | undefined; url?: string | undefined; original?: string | undefined; duration?: number | undefined; code?: string | undefined; action?: string | undefined; kind?: string | undefined; hash?: string | undefined; dataset?: string | undefined; severity?: number | undefined; created?: string | undefined; ingested?: string | undefined; module?: string | undefined; provider?: string | undefined; reason?: string | undefined; reference?: string | undefined; risk_score?: number | undefined; risk_score_norm?: number | undefined; sequence?: number | undefined; timezone?: string | undefined; } & {}> | undefined; '@timestamp'?: string | undefined; } & {}>>> | undefined" + "DeepPartial | undefined; message?: string | undefined; error?: Readonly<{ message?: string | undefined; type?: string | undefined; id?: string | undefined; code?: string | undefined; stack_trace?: string | undefined; } & {}> | undefined; tags?: string[] | undefined; kibana?: Readonly<{ alert?: Readonly<{ rule?: Readonly<{ consumer?: string | undefined; execution?: Readonly<{ status?: string | undefined; metrics?: Readonly<{ number_of_triggered_actions?: number | undefined; number_of_searches?: number | undefined; total_indexing_duration_ms?: number | undefined; es_search_duration_ms?: number | undefined; total_search_duration_ms?: number | undefined; execution_gap_duration_s?: number | undefined; } & {}> | undefined; uuid?: string | undefined; status_order?: number | undefined; } & {}> | undefined; rule_type_id?: string | undefined; } & {}> | undefined; } & {}> | undefined; version?: string | undefined; saved_objects?: Readonly<{ type?: string | undefined; id?: string | undefined; namespace?: string | undefined; rel?: string | undefined; type_id?: string | undefined; } & {}>[] | undefined; alerting?: Readonly<{ status?: string | undefined; instance_id?: string | undefined; action_group_id?: string | undefined; action_subgroup?: string | undefined; } & {}> | undefined; server_uuid?: string | undefined; task?: Readonly<{ id?: string | undefined; scheduled?: string | undefined; schedule_delay?: number | undefined; } & {}> | undefined; space_ids?: string[] | undefined; } & {}> | undefined; log?: Readonly<{ logger?: string | undefined; level?: string | undefined; } & {}> | undefined; ecs?: Readonly<{ version?: string | undefined; } & {}> | undefined; rule?: Readonly<{ id?: string | undefined; description?: string | undefined; name?: string | undefined; version?: string | undefined; license?: string | undefined; category?: string | undefined; reference?: string | undefined; author?: string[] | undefined; ruleset?: string | undefined; uuid?: string | undefined; } & {}> | undefined; event?: Readonly<{ start?: string | undefined; type?: string[] | undefined; id?: string | undefined; outcome?: string | undefined; end?: string | undefined; category?: string[] | undefined; url?: string | undefined; original?: string | undefined; duration?: number | undefined; code?: string | undefined; action?: string | undefined; kind?: string | undefined; hash?: string | undefined; dataset?: string | undefined; severity?: number | undefined; created?: string | undefined; ingested?: string | undefined; module?: string | undefined; provider?: string | undefined; reason?: string | undefined; reference?: string | undefined; risk_score?: number | undefined; risk_score_norm?: number | undefined; sequence?: number | undefined; timezone?: string | undefined; } & {}> | undefined; '@timestamp'?: string | undefined; } & {}>>> | undefined" ], "path": "x-pack/plugins/event_log/generated/schemas.ts", "deprecated": false, @@ -1080,7 +1080,7 @@ "label": "IValidatedEvent", "description": [], "signature": [ - "Readonly<{ user?: Readonly<{ name?: string | undefined; } & {}> | undefined; message?: string | undefined; error?: Readonly<{ message?: string | undefined; type?: string | undefined; id?: string | undefined; code?: string | undefined; stack_trace?: string | undefined; } & {}> | undefined; tags?: string[] | undefined; kibana?: Readonly<{ alert?: Readonly<{ rule?: Readonly<{ execution?: Readonly<{ status?: string | undefined; metrics?: Readonly<{ number_of_triggered_actions?: number | undefined; number_of_searches?: number | undefined; total_indexing_duration_ms?: number | undefined; es_search_duration_ms?: number | undefined; total_search_duration_ms?: number | undefined; execution_gap_duration_s?: number | undefined; } & {}> | undefined; uuid?: string | undefined; status_order?: number | undefined; } & {}> | undefined; } & {}> | undefined; } & {}> | undefined; version?: string | undefined; saved_objects?: Readonly<{ type?: string | undefined; id?: string | undefined; rel?: string | undefined; namespace?: string | undefined; type_id?: string | undefined; } & {}>[] | undefined; alerting?: Readonly<{ status?: string | undefined; instance_id?: string | undefined; action_group_id?: string | undefined; action_subgroup?: string | undefined; } & {}> | undefined; server_uuid?: string | undefined; task?: Readonly<{ id?: string | undefined; scheduled?: string | undefined; schedule_delay?: number | undefined; } & {}> | undefined; space_ids?: string[] | undefined; } & {}> | undefined; log?: Readonly<{ logger?: string | undefined; level?: string | undefined; } & {}> | undefined; ecs?: Readonly<{ version?: string | undefined; } & {}> | undefined; rule?: Readonly<{ id?: string | undefined; description?: string | undefined; name?: string | undefined; version?: string | undefined; license?: string | undefined; category?: string | undefined; reference?: string | undefined; author?: string[] | undefined; ruleset?: string | undefined; uuid?: string | undefined; } & {}> | undefined; event?: Readonly<{ start?: string | undefined; type?: string[] | undefined; id?: string | undefined; end?: string | undefined; category?: string[] | undefined; outcome?: string | undefined; url?: string | undefined; original?: string | undefined; duration?: number | undefined; code?: string | undefined; action?: string | undefined; kind?: string | undefined; hash?: string | undefined; dataset?: string | undefined; severity?: number | undefined; created?: string | undefined; ingested?: string | undefined; module?: string | undefined; provider?: string | undefined; reason?: string | undefined; reference?: string | undefined; risk_score?: number | undefined; risk_score_norm?: number | undefined; sequence?: number | undefined; timezone?: string | undefined; } & {}> | undefined; '@timestamp'?: string | undefined; } & {}> | undefined" + "Readonly<{ user?: Readonly<{ name?: string | undefined; } & {}> | undefined; message?: string | undefined; error?: Readonly<{ message?: string | undefined; type?: string | undefined; id?: string | undefined; code?: string | undefined; stack_trace?: string | undefined; } & {}> | undefined; tags?: string[] | undefined; kibana?: Readonly<{ alert?: Readonly<{ rule?: Readonly<{ consumer?: string | undefined; execution?: Readonly<{ status?: string | undefined; metrics?: Readonly<{ number_of_triggered_actions?: number | undefined; number_of_searches?: number | undefined; total_indexing_duration_ms?: number | undefined; es_search_duration_ms?: number | undefined; total_search_duration_ms?: number | undefined; execution_gap_duration_s?: number | undefined; } & {}> | undefined; uuid?: string | undefined; status_order?: number | undefined; } & {}> | undefined; rule_type_id?: string | undefined; } & {}> | undefined; } & {}> | undefined; version?: string | undefined; saved_objects?: Readonly<{ type?: string | undefined; id?: string | undefined; namespace?: string | undefined; rel?: string | undefined; type_id?: string | undefined; } & {}>[] | undefined; alerting?: Readonly<{ status?: string | undefined; instance_id?: string | undefined; action_group_id?: string | undefined; action_subgroup?: string | undefined; } & {}> | undefined; server_uuid?: string | undefined; task?: Readonly<{ id?: string | undefined; scheduled?: string | undefined; schedule_delay?: number | undefined; } & {}> | undefined; space_ids?: string[] | undefined; } & {}> | undefined; log?: Readonly<{ logger?: string | undefined; level?: string | undefined; } & {}> | undefined; ecs?: Readonly<{ version?: string | undefined; } & {}> | undefined; rule?: Readonly<{ id?: string | undefined; description?: string | undefined; name?: string | undefined; version?: string | undefined; license?: string | undefined; category?: string | undefined; reference?: string | undefined; author?: string[] | undefined; ruleset?: string | undefined; uuid?: string | undefined; } & {}> | undefined; event?: Readonly<{ start?: string | undefined; type?: string[] | undefined; id?: string | undefined; outcome?: string | undefined; end?: string | undefined; category?: string[] | undefined; url?: string | undefined; original?: string | undefined; duration?: number | undefined; code?: string | undefined; action?: string | undefined; kind?: string | undefined; hash?: string | undefined; dataset?: string | undefined; severity?: number | undefined; created?: string | undefined; ingested?: string | undefined; module?: string | undefined; provider?: string | undefined; reason?: string | undefined; reference?: string | undefined; risk_score?: number | undefined; risk_score_norm?: number | undefined; sequence?: number | undefined; timezone?: string | undefined; } & {}> | undefined; '@timestamp'?: string | undefined; } & {}> | undefined" ], "path": "x-pack/plugins/event_log/generated/schemas.ts", "deprecated": false, diff --git a/api_docs/event_log.mdx b/api_docs/event_log.mdx index caa7e2bf068b8..ac70e7c4b98ea 100644 --- a/api_docs/event_log.mdx +++ b/api_docs/event_log.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/eventLog title: "eventLog" image: https://source.unsplash.com/400x175/?github summary: API docs for the eventLog plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'eventLog'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_error.mdx b/api_docs/expression_error.mdx index c41a1112ad868..6698e7e0748a5 100644 --- a/api_docs/expression_error.mdx +++ b/api_docs/expression_error.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionError title: "expressionError" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionError plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionError'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_gauge.mdx b/api_docs/expression_gauge.mdx index 48f91bc43d724..ffa8059222d85 100644 --- a/api_docs/expression_gauge.mdx +++ b/api_docs/expression_gauge.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionGauge title: "expressionGauge" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionGauge plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionGauge'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_heatmap.devdocs.json b/api_docs/expression_heatmap.devdocs.json index f8ec7c01c72ab..fa4e095495ed6 100644 --- a/api_docs/expression_heatmap.devdocs.json +++ b/api_docs/expression_heatmap.devdocs.json @@ -1569,6 +1569,19 @@ "description": [], "path": "src/plugins/chart_expressions/expression_heatmap/common/expression_functions/heatmap_legend.ts", "deprecated": false + }, + { + "parentPluginId": "expressionHeatmap", + "id": "def-common.heatmapLegendConfig.args.position.strict", + "type": "boolean", + "tags": [], + "label": "strict", + "description": [], + "signature": [ + "true" + ], + "path": "src/plugins/chart_expressions/expression_heatmap/common/expression_functions/heatmap_legend.ts", + "deprecated": false } ] }, diff --git a/api_docs/expression_heatmap.mdx b/api_docs/expression_heatmap.mdx index 643d6e2c4c30a..a179e30c2028c 100644 --- a/api_docs/expression_heatmap.mdx +++ b/api_docs/expression_heatmap.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionHeatmap title: "expressionHeatmap" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionHeatmap plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionHeatmap'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 118 | 0 | 114 | 3 | +| 119 | 0 | 115 | 3 | ## Client diff --git a/api_docs/expression_image.mdx b/api_docs/expression_image.mdx index 954db0076b811..c370278a9b1dc 100644 --- a/api_docs/expression_image.mdx +++ b/api_docs/expression_image.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionImage title: "expressionImage" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionImage plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionImage'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_metric.mdx b/api_docs/expression_metric.mdx index a8079a360284b..e726fd7e4095b 100644 --- a/api_docs/expression_metric.mdx +++ b/api_docs/expression_metric.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionMetric title: "expressionMetric" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionMetric plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionMetric'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_metric_vis.mdx b/api_docs/expression_metric_vis.mdx index 84acf907e10a6..695ec7a869fbc 100644 --- a/api_docs/expression_metric_vis.mdx +++ b/api_docs/expression_metric_vis.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionMetricVis title: "expressionMetricVis" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionMetricVis plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionMetricVis'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_partition_vis.mdx b/api_docs/expression_partition_vis.mdx index deaa8982478da..d19a7f17a29cc 100644 --- a/api_docs/expression_partition_vis.mdx +++ b/api_docs/expression_partition_vis.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionPartitionVis title: "expressionPartitionVis" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionPartitionVis plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionPartitionVis'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_repeat_image.mdx b/api_docs/expression_repeat_image.mdx index 205d304740e19..f3e79c480bd66 100644 --- a/api_docs/expression_repeat_image.mdx +++ b/api_docs/expression_repeat_image.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionRepeatImage title: "expressionRepeatImage" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionRepeatImage plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionRepeatImage'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_reveal_image.mdx b/api_docs/expression_reveal_image.mdx index a2ccaf9b28f40..46a20f6dd4b4a 100644 --- a/api_docs/expression_reveal_image.mdx +++ b/api_docs/expression_reveal_image.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionRevealImage title: "expressionRevealImage" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionRevealImage plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionRevealImage'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_shape.mdx b/api_docs/expression_shape.mdx index e5fc14d99910d..8e959ae059b84 100644 --- a/api_docs/expression_shape.mdx +++ b/api_docs/expression_shape.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionShape title: "expressionShape" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionShape plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionShape'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expression_tagcloud.mdx b/api_docs/expression_tagcloud.mdx index 8e8b938b633d9..f9c489faed9ea 100644 --- a/api_docs/expression_tagcloud.mdx +++ b/api_docs/expression_tagcloud.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressionTagcloud title: "expressionTagcloud" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressionTagcloud plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressionTagcloud'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/expressions.devdocs.json b/api_docs/expressions.devdocs.json index 8d0cb94b73488..9749191d88602 100644 --- a/api_docs/expressions.devdocs.json +++ b/api_docs/expressions.devdocs.json @@ -1244,7 +1244,7 @@ "label": "getFunction", "description": [], "signature": [ - "(name: string) => ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -1270,6 +1270,20 @@ "path": "src/plugins/expressions/common/executor/executor.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-public.Executor.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/executor/executor.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -1282,7 +1296,7 @@ "label": "getFunctions", "description": [], "signature": [ - "() => Record Record ", + "(name: string, namespace: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -3934,6 +4005,20 @@ "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsService.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -3946,7 +4031,7 @@ "label": "getFunctions", "description": [], "signature": [ - "() => Record Record ", - { - "pluginId": "expressions", - "scope": "common", - "docId": "kibExpressionsPluginApi", - "section": "def-common.ExpressionsService", - "text": "ExpressionsService" - } + "(name: string) => ", + "ExpressionsServiceFork" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, @@ -4294,11 +4388,11 @@ "label": "name", "description": [], "signature": [ - "string | undefined" + "string" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, - "isRequired": false + "isRequired": true } ], "returnComment": [] @@ -4898,6 +4992,19 @@ "path": "src/plugins/expressions/common/expression_types/expression_type.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionType.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_types/expression_type.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-public.ExpressionType.help", @@ -5594,6 +5701,21 @@ ], "returnComment": [] }, + { + "parentPluginId": "expressions", + "id": "def-public.TablesAdapter.reset", + "type": "Function", + "tags": [], + "label": "reset", + "description": [], + "signature": [ + "() => void" + ], + "path": "src/plugins/expressions/common/util/tables_adapter.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, { "parentPluginId": "expressions", "id": "def-public.TablesAdapter.tables", @@ -6324,6 +6446,20 @@ "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-public.Datatable.meta", + "type": "Object", + "tags": [], + "label": "meta", + "description": [], + "signature": [ + "DatatableMeta", + " | undefined" + ], + "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-public.Datatable.rows", @@ -7539,6 +7675,19 @@ "path": "src/plugins/expressions/common/expression_functions/types.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionFunctionDefinition.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_functions/types.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-public.ExpressionFunctionDefinition.type", @@ -8314,6 +8463,19 @@ "path": "src/plugins/expressions/common/expression_renderers/types.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionRenderDefinition.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_renderers/types.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-public.ExpressionRenderDefinition.displayName", @@ -8521,7 +8683,7 @@ "\nGet a registered `ExpressionFunction` by its name, which was registered\nusing the `registerFunction` method. The returned `ExpressionFunction`\ninstance is an internal representation of the function in Expressions\nservice - do not mutate that object." ], "signature": [ - "(name: string) => ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -8547,6 +8709,20 @@ "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -8561,7 +8737,7 @@ "\nReturns POJO map of all registered expression functions, where keys are\nnames of the functions and values are `ExpressionFunction` instances." ], "signature": [ - "() => Record Record { state: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + }, + "; references: ", + "SavedObjectReference", + "[]; }" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.extract.$1", + "type": "CompoundType", + "tags": [], + "label": "state", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.inject", + "type": "Function", + "tags": [], + "label": "inject", + "description": [], + "signature": [ + "(state: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + }, + ", references: ", + "SavedObjectReference", + "[]) => ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.inject.$1", + "type": "CompoundType", + "tags": [], + "label": "state", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.inject.$2", + "type": "Array", + "tags": [], + "label": "references", + "description": [], + "signature": [ + "SavedObjectReference", + "[]" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.telemetry", + "type": "Function", + "tags": [], + "label": "telemetry", + "description": [], + "signature": [ + "(state: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + }, + ", telemetryData: Record) => Record" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.telemetry.$1", + "type": "CompoundType", + "tags": [], + "label": "state", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.telemetry.$2", + "type": "Object", + "tags": [], + "label": "telemetryData", + "description": [], + "signature": [ + "Record" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceStart.getAllMigrations", + "type": "Function", + "tags": [], + "label": "getAllMigrations", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "kibanaUtils", + "scope": "common", + "docId": "kibKibanaUtilsPluginApi", + "section": "def-common.MigrateFunctionsObject", + "text": "MigrateFunctionsObject" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [], + "returnComment": [] } ], "initialIsOpen": false @@ -8950,6 +9343,19 @@ "path": "src/plugins/expressions/common/expression_types/types.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionTypeDefinition.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_types/types.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-public.ExpressionTypeDefinition.validate", @@ -10267,7 +10673,7 @@ "\nThis type represents the `type` of any `DatatableColumn` in a `Datatable`.\nits duplicated from KBN_FIELD_TYPES" ], "signature": [ - "\"string\" | \"number\" | \"boolean\" | \"object\" | \"ip\" | \"nested\" | \"_source\" | \"attachment\" | \"date\" | \"geo_point\" | \"geo_shape\" | \"murmur3\" | \"unknown\" | \"conflict\" | \"histogram\" | \"null\"" + "\"string\" | \"number\" | \"boolean\" | \"object\" | \"ip\" | \"nested\" | \"conflict\" | \"_source\" | \"attachment\" | \"date\" | \"geo_point\" | \"geo_shape\" | \"murmur3\" | \"unknown\" | \"histogram\" | \"null\"" ], "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false, @@ -11075,7 +11481,7 @@ "\nGet a registered `ExpressionFunction` by its name, which was registered\nusing the `registerFunction` method. The returned `ExpressionFunction`\ninstance is an internal representation of the function in Expressions\nservice - do not mutate that object." ], "signature": [ - "(name: string) => ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -11107,6 +11513,20 @@ "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceSetup.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -11123,7 +11543,7 @@ "\nReturns POJO map of all registered expression functions, where keys are\nnames of the functions and values are `ExpressionFunction` instances." ], "signature": [ - "() => Record Record ", - { - "pluginId": "expressions", - "scope": "common", - "docId": "kibExpressionsPluginApi", - "section": "def-common.ExpressionsService", - "text": "ExpressionsService" - } + "(namespace: string) => ", + "ExpressionsServiceFork" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, @@ -11224,16 +11653,14 @@ "id": "def-public.ExpressionsServiceSetup.fork.$1", "type": "string", "tags": [], - "label": "name", - "description": [ - "A fork name that can be used to get fork instance later." - ], + "label": "namespace", + "description": [], "signature": [ - "string | undefined" + "string" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, - "isRequired": false + "isRequired": true } ], "returnComment": [] @@ -11422,6 +11849,28 @@ } ], "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-public.ExpressionsServiceSetup.getAllMigrations", + "type": "Function", + "tags": [], + "label": "getAllMigrations", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "kibanaUtils", + "scope": "common", + "docId": "kibKibanaUtilsPluginApi", + "section": "def-common.MigrateFunctionsObject", + "text": "MigrateFunctionsObject" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [], + "returnComment": [] } ], "lifecycle": "setup", @@ -12699,7 +13148,7 @@ "label": "getFunction", "description": [], "signature": [ - "(name: string) => ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -12725,6 +13174,20 @@ "path": "src/plugins/expressions/common/executor/executor.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-server.Executor.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/executor/executor.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -12737,7 +13200,7 @@ "label": "getFunctions", "description": [], "signature": [ - "() => Record Record ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -21106,6 +21692,20 @@ "path": "src/plugins/expressions/common/executor/executor.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.Executor.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/executor/executor.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -21118,7 +21718,7 @@ "label": "getFunctions", "description": [], "signature": [ - "() => Record Record ", + "(name: string, namespace: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -23082,6 +23739,20 @@ "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsService.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -23094,7 +23765,7 @@ "label": "getFunctions", "description": [], "signature": [ - "() => Record Record ", - { - "pluginId": "expressions", - "scope": "common", - "docId": "kibExpressionsPluginApi", - "section": "def-common.ExpressionsService", - "text": "ExpressionsService" - } + "(name: string) => ", + "ExpressionsServiceFork" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, @@ -23442,11 +24122,11 @@ "label": "name", "description": [], "signature": [ - "string | undefined" + "string" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, - "isRequired": false + "isRequired": true } ], "returnComment": [] @@ -24046,6 +24726,19 @@ "path": "src/plugins/expressions/common/expression_types/expression_type.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionType.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_types/expression_type.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-common.ExpressionType.help", @@ -24742,6 +25435,21 @@ ], "returnComment": [] }, + { + "parentPluginId": "expressions", + "id": "def-common.TablesAdapter.reset", + "type": "Function", + "tags": [], + "label": "reset", + "description": [], + "signature": [ + "() => void" + ], + "path": "src/plugins/expressions/common/util/tables_adapter.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, { "parentPluginId": "expressions", "id": "def-common.TablesAdapter.tables", @@ -25747,11 +26455,9 @@ "type": "Function", "tags": [], "label": "getByAlias", - "description": [ - "\nThis is used for looking up function/argument definitions. It looks through\nthe given object/array for a case-insensitive match, which could be either the\n`name` itself, or something under the `aliases` property." - ], + "description": [], "signature": [ - "(node: T[] | Record, nodeName: string) => T | undefined" + "(node: T[] | Record, nodeName: string, nodeNamespace: string | undefined) => T | undefined" ], "path": "src/plugins/expressions/common/util/get_by_alias.ts", "deprecated": false, @@ -25783,6 +26489,20 @@ "path": "src/plugins/expressions/common/util/get_by_alias.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.getByAlias.$3", + "type": "string", + "tags": [], + "label": "nodeNamespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/util/get_by_alias.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [], @@ -26637,6 +27357,20 @@ "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-common.Datatable.meta", + "type": "Object", + "tags": [], + "label": "meta", + "description": [], + "signature": [ + "DatatableMeta", + " | undefined" + ], + "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-common.Datatable.rows", @@ -26734,7 +27468,7 @@ "label": "type", "description": [], "signature": [ - "\"string\" | \"number\" | \"boolean\" | \"object\" | \"ip\" | \"nested\" | \"_source\" | \"attachment\" | \"date\" | \"geo_point\" | \"geo_shape\" | \"murmur3\" | \"unknown\" | \"conflict\" | \"histogram\" | \"null\"" + "\"string\" | \"number\" | \"boolean\" | \"object\" | \"ip\" | \"nested\" | \"conflict\" | \"_source\" | \"attachment\" | \"date\" | \"geo_point\" | \"geo_shape\" | \"murmur3\" | \"unknown\" | \"histogram\" | \"null\"" ], "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false @@ -28714,6 +29448,19 @@ ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionExecutionParams.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false } ], "initialIsOpen": false @@ -28786,6 +29533,19 @@ "path": "src/plugins/expressions/common/expression_functions/types.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionFunctionDefinition.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_functions/types.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-common.ExpressionFunctionDefinition.type", @@ -29561,6 +30321,19 @@ "path": "src/plugins/expressions/common/expression_renderers/types.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionRenderDefinition.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_renderers/types.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-common.ExpressionRenderDefinition.displayName", @@ -29774,7 +30547,7 @@ "\nGet a registered `ExpressionFunction` by its name, which was registered\nusing the `registerFunction` method. The returned `ExpressionFunction`\ninstance is an internal representation of the function in Expressions\nservice - do not mutate that object." ], "signature": [ - "(name: string) => ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -29806,6 +30579,20 @@ "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceSetup.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -29822,7 +30609,7 @@ "\nReturns POJO map of all registered expression functions, where keys are\nnames of the functions and values are `ExpressionFunction` instances." ], "signature": [ - "() => Record Record ", - { - "pluginId": "expressions", - "scope": "common", - "docId": "kibExpressionsPluginApi", - "section": "def-common.ExpressionsService", - "text": "ExpressionsService" - } + "(namespace: string) => ", + "ExpressionsServiceFork" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, @@ -29923,16 +30719,14 @@ "id": "def-common.ExpressionsServiceSetup.fork.$1", "type": "string", "tags": [], - "label": "name", - "description": [ - "A fork name that can be used to get fork instance later." - ], + "label": "namespace", + "description": [], "signature": [ - "string | undefined" + "string" ], "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, - "isRequired": false + "isRequired": true } ], "returnComment": [] @@ -30121,6 +30915,28 @@ } ], "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceSetup.getAllMigrations", + "type": "Function", + "tags": [], + "label": "getAllMigrations", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "kibanaUtils", + "scope": "common", + "docId": "kibKibanaUtilsPluginApi", + "section": "def-common.MigrateFunctionsObject", + "text": "MigrateFunctionsObject" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [], + "returnComment": [] } ], "initialIsOpen": false @@ -30147,7 +30963,7 @@ "\nGet a registered `ExpressionFunction` by its name, which was registered\nusing the `registerFunction` method. The returned `ExpressionFunction`\ninstance is an internal representation of the function in Expressions\nservice - do not mutate that object." ], "signature": [ - "(name: string) => ", + "(name: string, namespace?: string | undefined) => ", { "pluginId": "expressions", "scope": "common", @@ -30173,6 +30989,20 @@ "path": "src/plugins/expressions/common/service/expressions_services.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.getFunction.$2", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": false } ], "returnComment": [] @@ -30187,7 +31017,7 @@ "\nReturns POJO map of all registered expression functions, where keys are\nnames of the functions and values are `ExpressionFunction` instances." ], "signature": [ - "() => Record Record { state: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + }, + "; references: ", + "SavedObjectReference", + "[]; }" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.extract.$1", + "type": "CompoundType", + "tags": [], + "label": "state", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.inject", + "type": "Function", + "tags": [], + "label": "inject", + "description": [], + "signature": [ + "(state: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + }, + ", references: ", + "SavedObjectReference", + "[]) => ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.inject.$1", + "type": "CompoundType", + "tags": [], + "label": "state", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.inject.$2", + "type": "Array", + "tags": [], + "label": "references", + "description": [], + "signature": [ + "SavedObjectReference", + "[]" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.telemetry", + "type": "Function", + "tags": [], + "label": "telemetry", + "description": [], + "signature": [ + "(state: ", + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + }, + ", telemetryData: Record) => Record" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.telemetry.$1", + "type": "CompoundType", + "tags": [], + "label": "state", + "description": [], + "signature": [ + { + "pluginId": "expressions", + "scope": "common", + "docId": "kibExpressionsPluginApi", + "section": "def-common.ExpressionAstExpression", + "text": "ExpressionAstExpression" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.telemetry.$2", + "type": "Object", + "tags": [], + "label": "telemetryData", + "description": [], + "signature": [ + "Record" + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionsServiceStart.getAllMigrations", + "type": "Function", + "tags": [], + "label": "getAllMigrations", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "kibanaUtils", + "scope": "common", + "docId": "kibKibanaUtilsPluginApi", + "section": "def-common.MigrateFunctionsObject", + "text": "MigrateFunctionsObject" + } + ], + "path": "src/plugins/expressions/common/service/expressions_services.ts", + "deprecated": false, + "children": [], + "returnComment": [] } ], "initialIsOpen": false @@ -30576,6 +31623,19 @@ "path": "src/plugins/expressions/common/expression_types/types.ts", "deprecated": false }, + { + "parentPluginId": "expressions", + "id": "def-common.ExpressionTypeDefinition.namespace", + "type": "string", + "tags": [], + "label": "namespace", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "src/plugins/expressions/common/expression_types/types.ts", + "deprecated": false + }, { "parentPluginId": "expressions", "id": "def-common.ExpressionTypeDefinition.validate", @@ -32071,7 +33131,7 @@ "\nThis type represents the `type` of any `DatatableColumn` in a `Datatable`.\nits duplicated from KBN_FIELD_TYPES" ], "signature": [ - "\"string\" | \"number\" | \"boolean\" | \"object\" | \"ip\" | \"nested\" | \"_source\" | \"attachment\" | \"date\" | \"geo_point\" | \"geo_shape\" | \"murmur3\" | \"unknown\" | \"conflict\" | \"histogram\" | \"null\"" + "\"string\" | \"number\" | \"boolean\" | \"object\" | \"ip\" | \"nested\" | \"conflict\" | \"_source\" | \"attachment\" | \"date\" | \"geo_point\" | \"geo_shape\" | \"murmur3\" | \"unknown\" | \"histogram\" | \"null\"" ], "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false, @@ -33306,6 +34366,14 @@ "path": "src/plugins/expressions/common/expression_types/specs/render.ts", "deprecated": true, "references": [ + { + "plugin": "canvas", + "path": "x-pack/plugins/canvas/target/types/public/functions/index.d.ts" + }, + { + "plugin": "canvas", + "path": "x-pack/plugins/canvas/target/types/public/functions/index.d.ts" + }, { "plugin": "canvas", "path": "x-pack/plugins/canvas/types/state.ts" @@ -33314,6 +34382,14 @@ "plugin": "canvas", "path": "x-pack/plugins/canvas/types/state.ts" }, + { + "plugin": "canvas", + "path": "x-pack/plugins/canvas/target/types/types/state.d.ts" + }, + { + "plugin": "canvas", + "path": "x-pack/plugins/canvas/target/types/types/state.d.ts" + }, { "plugin": "canvas", "path": "x-pack/plugins/canvas/canvas_plugin_src/functions/browser/markdown.ts" @@ -33354,6 +34430,14 @@ "plugin": "canvas", "path": "x-pack/plugins/canvas/canvas_plugin_src/functions/common/table.ts" }, + { + "plugin": "canvas", + "path": "x-pack/plugins/canvas/target/types/canvas_plugin_src/functions/browser/markdown.d.ts" + }, + { + "plugin": "canvas", + "path": "x-pack/plugins/canvas/target/types/canvas_plugin_src/functions/browser/markdown.d.ts" + }, { "plugin": "visTypeXy", "path": "src/plugins/vis_types/xy/public/expression_functions/xy_vis_fn.ts" @@ -34658,7 +35742,9 @@ "section": "def-common.DatatableColumn", "text": "DatatableColumn" }, - "[]; }" + "[]; meta?: ", + "DatatableMeta", + " | undefined; }" ], "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false, @@ -34710,7 +35796,9 @@ "section": "def-common.DatatableColumn", "text": "DatatableColumn" }, - "[]; }" + "[]; meta?: ", + "DatatableMeta", + " | undefined; }" ], "path": "src/plugins/expressions/common/expression_types/specs/datatable.ts", "deprecated": false, @@ -36942,7 +38030,9 @@ "section": "def-common.DatatableRow", "text": "DatatableRow" }, - "[]; type: \"datatable\"; }>" + "[]; type: \"datatable\"; meta?: ", + "DatatableMeta", + " | undefined; }>" ], "path": "src/plugins/expressions/common/expression_functions/specs/map_column.ts", "deprecated": false, diff --git a/api_docs/expressions.mdx b/api_docs/expressions.mdx index fc75339e0c3e3..9101e4139b50b 100644 --- a/api_docs/expressions.mdx +++ b/api_docs/expressions.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/expressions title: "expressions" image: https://source.unsplash.com/400x175/?github summary: API docs for the expressions plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'expressions'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [App Services](https://github.com/orgs/elastic/teams/kibana-app-services | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 2079 | 17 | 1632 | 4 | +| 2145 | 17 | 1701 | 6 | ## Client diff --git a/api_docs/features.devdocs.json b/api_docs/features.devdocs.json index 736522f08e897..c0459cd78c0a6 100644 --- a/api_docs/features.devdocs.json +++ b/api_docs/features.devdocs.json @@ -316,6 +316,7 @@ ], "path": "x-pack/plugins/features/common/feature_kibana_privileges.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "security", @@ -1463,6 +1464,7 @@ ], "path": "x-pack/plugins/features/common/feature_elasticsearch_privileges.ts", "deprecated": true, + "removeBy": "8.8.0\n\nThis is relied on by the reporting feature, and should be removed once reporting\nmigrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914", "references": [ { "plugin": "security", @@ -1548,6 +1550,7 @@ ], "path": "x-pack/plugins/features/common/feature_kibana_privileges.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "security", @@ -2080,9 +2083,13 @@ "parentPluginId": "features", "id": "def-server.PluginSetupContract.getKibanaFeatures", "type": "Function", - "tags": [], + "tags": [ + "deprecated" + ], "label": "getKibanaFeatures", - "description": [], + "description": [ + "\nCalling this function during setup will crash Kibana.\nUse start contract instead." + ], "signature": [ "() => ", { @@ -2095,7 +2102,122 @@ "[]" ], "path": "x-pack/plugins/features/server/plugin.ts", - "deprecated": false, + "deprecated": true, + "removeBy": "8.8.0", + "references": [ + { + "plugin": "spaces", + "path": "x-pack/plugins/spaces/server/lib/request_interceptors/on_post_auth_interceptor.ts" + }, + { + "plugin": "spaces", + "path": "x-pack/plugins/spaces/server/usage_collection/spaces_usage_collector.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/app_authorization.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/authorization_service.tsx" + }, + { + "plugin": "alerting", + "path": "x-pack/plugins/alerting/server/plugin.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/app_authorization.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/privileges/privileges.test.ts" + }, + { + "plugin": "spaces", + "path": "x-pack/plugins/spaces/server/lib/request_interceptors/on_post_auth_interceptor.test.ts" + }, + { + "plugin": "security", + "path": "x-pack/plugins/security/public/management/roles/__fixtures__/kibana_privileges.ts" + } + ], "children": [], "returnComment": [] }, @@ -2103,9 +2225,13 @@ "parentPluginId": "features", "id": "def-server.PluginSetupContract.getElasticsearchFeatures", "type": "Function", - "tags": [], + "tags": [ + "deprecated" + ], "label": "getElasticsearchFeatures", - "description": [], + "description": [ + "\nCalling this function during setup will crash Kibana.\nUse start contract instead." + ], "signature": [ "() => ", { @@ -2118,7 +2244,14 @@ "[]" ], "path": "x-pack/plugins/features/server/plugin.ts", - "deprecated": false, + "deprecated": true, + "removeBy": "8.8.0", + "references": [ + { + "plugin": "security", + "path": "x-pack/plugins/security/server/authorization/authorization_service.tsx" + } + ], "children": [], "returnComment": [] }, @@ -2144,7 +2277,9 @@ "type": "Function", "tags": [], "label": "enableReportingUiCapabilities", - "description": [], + "description": [ + "\nIn the future, OSS features should register their own subfeature\nprivileges. This can be done when parts of Reporting are moved to\nsrc/plugins. For now, this method exists for `reporting` to tell\n`features` to include Reporting when registering OSS features." + ], "signature": [ "() => void" ], @@ -3029,6 +3164,7 @@ ], "path": "x-pack/plugins/features/common/feature_elasticsearch_privileges.ts", "deprecated": true, + "removeBy": "8.8.0\n\nThis is relied on by the reporting feature, and should be removed once reporting\nmigrates to using the Kibana Privilege model: https://github.com/elastic/kibana/issues/19914", "references": [ { "plugin": "security", @@ -3114,6 +3250,7 @@ ], "path": "x-pack/plugins/features/common/feature_kibana_privileges.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "security", diff --git a/api_docs/features.mdx b/api_docs/features.mdx index 099d00563c1a2..c7f90ce7dbdcf 100644 --- a/api_docs/features.mdx +++ b/api_docs/features.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/features title: "features" image: https://source.unsplash.com/400x175/?github summary: API docs for the features plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'features'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) for que | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 222 | 0 | 98 | 2 | +| 222 | 0 | 95 | 2 | ## Client diff --git a/api_docs/field_formats.mdx b/api_docs/field_formats.mdx index 51d47a52bfcca..002c4678ca62d 100644 --- a/api_docs/field_formats.mdx +++ b/api_docs/field_formats.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/fieldFormats title: "fieldFormats" image: https://source.unsplash.com/400x175/?github summary: API docs for the fieldFormats plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fieldFormats'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/file_upload.mdx b/api_docs/file_upload.mdx index 7e3a73da89071..ef5c437ae1ed8 100644 --- a/api_docs/file_upload.mdx +++ b/api_docs/file_upload.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/fileUpload title: "fileUpload" image: https://source.unsplash.com/400x175/?github summary: API docs for the fileUpload plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fileUpload'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/fleet.devdocs.json b/api_docs/fleet.devdocs.json index 26d8654660bea..fa373cd16c7bb 100644 --- a/api_docs/fleet.devdocs.json +++ b/api_docs/fleet.devdocs.json @@ -8897,74 +8897,6 @@ "returnComment": [], "initialIsOpen": false }, - { - "parentPluginId": "fleet", - "id": "def-common.storedPackagePoliciesToAgentInputs", - "type": "Function", - "tags": [], - "label": "storedPackagePoliciesToAgentInputs", - "description": [], - "signature": [ - "(packagePolicies: ", - { - "pluginId": "fleet", - "scope": "common", - "docId": "kibFleetPluginApi", - "section": "def-common.PackagePolicy", - "text": "PackagePolicy" - }, - "[], outputId?: string) => ", - { - "pluginId": "fleet", - "scope": "common", - "docId": "kibFleetPluginApi", - "section": "def-common.FullAgentPolicyInput", - "text": "FullAgentPolicyInput" - }, - "[]" - ], - "path": "x-pack/plugins/fleet/common/services/package_policies_to_agent_inputs.ts", - "deprecated": false, - "children": [ - { - "parentPluginId": "fleet", - "id": "def-common.storedPackagePoliciesToAgentInputs.$1", - "type": "Array", - "tags": [], - "label": "packagePolicies", - "description": [], - "signature": [ - { - "pluginId": "fleet", - "scope": "common", - "docId": "kibFleetPluginApi", - "section": "def-common.PackagePolicy", - "text": "PackagePolicy" - }, - "[]" - ], - "path": "x-pack/plugins/fleet/common/services/package_policies_to_agent_inputs.ts", - "deprecated": false, - "isRequired": true - }, - { - "parentPluginId": "fleet", - "id": "def-common.storedPackagePoliciesToAgentInputs.$2", - "type": "string", - "tags": [], - "label": "outputId", - "description": [], - "signature": [ - "string" - ], - "path": "x-pack/plugins/fleet/common/services/package_policies_to_agent_inputs.ts", - "deprecated": false, - "isRequired": true - } - ], - "returnComment": [], - "initialIsOpen": false - }, { "parentPluginId": "fleet", "id": "def-common.validatePackagePolicy", @@ -12424,6 +12356,65 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "fleet", + "id": "def-common.GetAgentIncomingDataRequest", + "type": "Interface", + "tags": [], + "label": "GetAgentIncomingDataRequest", + "description": [], + "path": "x-pack/plugins/fleet/common/types/rest_spec/agent.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "fleet", + "id": "def-common.GetAgentIncomingDataRequest.query", + "type": "Object", + "tags": [], + "label": "query", + "description": [], + "signature": [ + "{ agentsIds: string[]; }" + ], + "path": "x-pack/plugins/fleet/common/types/rest_spec/agent.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "fleet", + "id": "def-common.GetAgentIncomingDataResponse", + "type": "Interface", + "tags": [], + "label": "GetAgentIncomingDataResponse", + "description": [], + "path": "x-pack/plugins/fleet/common/types/rest_spec/agent.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "fleet", + "id": "def-common.GetAgentIncomingDataResponse.items", + "type": "Array", + "tags": [], + "label": "items", + "description": [], + "signature": [ + { + "pluginId": "fleet", + "scope": "common", + "docId": "kibFleetPluginApi", + "section": "def-common.IncomingDataList", + "text": "IncomingDataList" + }, + "[]" + ], + "path": "x-pack/plugins/fleet/common/types/rest_spec/agent.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "fleet", "id": "def-common.GetAgentPoliciesRequest", @@ -13594,6 +13585,32 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "fleet", + "id": "def-common.IncomingDataList", + "type": "Interface", + "tags": [], + "label": "IncomingDataList", + "description": [], + "path": "x-pack/plugins/fleet/common/types/rest_spec/agent.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "fleet", + "id": "def-common.IncomingDataList.Unnamed", + "type": "IndexSignature", + "tags": [], + "label": "[key: string]: { data: boolean; }", + "description": [], + "signature": [ + "[key: string]: { data: boolean; }" + ], + "path": "x-pack/plugins/fleet/common/types/rest_spec/agent.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "fleet", "id": "def-common.IndexTemplate", @@ -18041,6 +18058,27 @@ ], "path": "x-pack/plugins/fleet/common/types/rest_spec/package_policy.ts", "deprecated": false + }, + { + "parentPluginId": "fleet", + "id": "def-common.UpgradePackagePolicyDryRunResponseItem.agent_diff", + "type": "Object", + "tags": [], + "label": "agent_diff", + "description": [], + "signature": [ + "[", + { + "pluginId": "fleet", + "scope": "common", + "docId": "kibFleetPluginApi", + "section": "def-common.FullAgentPolicyInput", + "text": "FullAgentPolicyInput" + }, + "[]] | undefined" + ], + "path": "x-pack/plugins/fleet/common/types/rest_spec/package_policy.ts", + "deprecated": false } ], "initialIsOpen": false @@ -18505,7 +18543,7 @@ "section": "def-common.ValueOf", "text": "ValueOf" }, - "<{ readonly Active: \"active\"; readonly Inactive: \"inactive\"; }>; description?: string | undefined; name: string; updated_at: string; updated_by: string; namespace: string; is_default?: boolean | undefined; is_default_fleet_server?: boolean | undefined; has_fleet_server?: boolean | undefined; is_managed: boolean; monitoring_enabled?: (\"metrics\" | \"logs\")[] | undefined; unenroll_timeout?: number | undefined; is_preconfigured?: boolean | undefined; data_output_id?: string | null | undefined; monitoring_output_id?: string | null | undefined; package_policies: string[] | ", + "<{ readonly Active: \"active\"; readonly Inactive: \"inactive\"; }>; description?: string | undefined; name: string; namespace: string; updated_at: string; updated_by: string; is_default?: boolean | undefined; is_default_fleet_server?: boolean | undefined; has_fleet_server?: boolean | undefined; is_managed: boolean; monitoring_enabled?: (\"metrics\" | \"logs\")[] | undefined; unenroll_timeout?: number | undefined; is_preconfigured?: boolean | undefined; data_output_id?: string | null | undefined; monitoring_output_id?: string | null | undefined; package_policies: string[] | ", { "pluginId": "fleet", "scope": "common", @@ -19188,6 +19226,20 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "fleet", + "id": "def-common.FLEET_ELASTIC_AGENT_DETAILS_DASHBOARD_ID", + "type": "string", + "tags": [], + "label": "FLEET_ELASTIC_AGENT_DETAILS_DASHBOARD_ID", + "description": [], + "signature": [ + "\"elastic_agent-f47f18cc-9c7d-4278-b2ea-a6dee816d395\"" + ], + "path": "x-pack/plugins/fleet/common/constants/epm.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "fleet", "id": "def-common.FLEET_ELASTIC_AGENT_PACKAGE", @@ -19936,6 +19988,14 @@ "section": "def-common.KibanaAssetParts", "text": "KibanaAssetParts" }, + "[]; csp_rule_template: ", + { + "pluginId": "fleet", + "scope": "common", + "docId": "kibFleetPluginApi", + "section": "def-common.KibanaAssetParts", + "text": "KibanaAssetParts" + }, "[]; ml_module: ", { "pluginId": "fleet", @@ -19952,26 +20012,20 @@ "section": "def-common.KibanaAssetParts", "text": "KibanaAssetParts" }, + "[]; osquery_pack_asset: ", + { + "pluginId": "fleet", + "scope": "common", + "docId": "kibFleetPluginApi", + "section": "def-common.KibanaAssetParts", + "text": "KibanaAssetParts" + }, "[]; }" ], "path": "x-pack/plugins/fleet/common/types/models/epm.ts", "deprecated": false, "initialIsOpen": false }, - { - "parentPluginId": "fleet", - "id": "def-common.KUBERNETES_RUN_INSTRUCTIONS", - "type": "string", - "tags": [], - "label": "KUBERNETES_RUN_INSTRUCTIONS", - "description": [], - "signature": [ - "\"kubectl apply -f elastic-agent-standalone-kubernetes.yaml\"" - ], - "path": "x-pack/plugins/fleet/common/constants/epm.ts", - "deprecated": false, - "initialIsOpen": false - }, { "parentPluginId": "fleet", "id": "def-common.LICENCE_FOR_PER_POLICY_OUTPUT", @@ -20359,7 +20413,7 @@ "section": "def-common.PackagePolicyPackage", "text": "PackagePolicyPackage" }, - " | undefined; description?: string | undefined; name: string; enabled: boolean; updated_at: string; created_at: string; created_by: string; updated_by: string; namespace: string; inputs: ", + " | undefined; description?: string | undefined; name: string; enabled: boolean; namespace: string; updated_at: string; created_at: string; created_by: string; updated_by: string; inputs: ", { "pluginId": "fleet", "scope": "common", @@ -20872,34 +20926,6 @@ "deprecated": false, "initialIsOpen": false }, - { - "parentPluginId": "fleet", - "id": "def-common.STANDALONE_RUN_INSTRUCTIONS_LINUXMAC", - "type": "string", - "tags": [], - "label": "STANDALONE_RUN_INSTRUCTIONS_LINUXMAC", - "description": [], - "signature": [ - "\"sudo ./elastic-agent install\"" - ], - "path": "x-pack/plugins/fleet/common/constants/epm.ts", - "deprecated": false, - "initialIsOpen": false - }, - { - "parentPluginId": "fleet", - "id": "def-common.STANDALONE_RUN_INSTRUCTIONS_WINDOWS", - "type": "string", - "tags": [], - "label": "STANDALONE_RUN_INSTRUCTIONS_WINDOWS", - "description": [], - "signature": [ - "\".\\\\elastic-agent.exe install\"" - ], - "path": "x-pack/plugins/fleet/common/constants/epm.ts", - "deprecated": false, - "initialIsOpen": false - }, { "parentPluginId": "fleet", "id": "def-common.TemplateMap", @@ -21204,6 +21230,16 @@ "path": "x-pack/plugins/fleet/common/constants/routes.ts", "deprecated": false }, + { + "parentPluginId": "fleet", + "id": "def-common.AGENT_API_ROUTES.DATA_PATTERN", + "type": "string", + "tags": [], + "label": "DATA_PATTERN", + "description": [], + "path": "x-pack/plugins/fleet/common/constants/routes.ts", + "deprecated": false + }, { "parentPluginId": "fleet", "id": "def-common.AGENT_API_ROUTES.STATUS_PATTERN_DEPRECATED", @@ -21803,6 +21839,21 @@ "children": [], "returnComment": [] }, + { + "parentPluginId": "fleet", + "id": "def-common.agentRouteService.getIncomingDataPath", + "type": "Function", + "tags": [], + "label": "getIncomingDataPath", + "description": [], + "signature": [ + "() => string" + ], + "path": "x-pack/plugins/fleet/common/services/routes.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, { "parentPluginId": "fleet", "id": "def-common.agentRouteService.getCreateActionPath", @@ -22516,7 +22567,7 @@ "label": "getInfoPath", "description": [], "signature": [ - "(pkgName: string, pkgVersion: string) => string" + "(pkgName: string, pkgVersion?: string | undefined) => string" ], "path": "x-pack/plugins/fleet/common/services/routes.ts", "deprecated": false, @@ -22543,11 +22594,11 @@ "label": "pkgVersion", "description": [], "signature": [ - "string" + "string | undefined" ], "path": "x-pack/plugins/fleet/common/services/routes.ts", "deprecated": false, - "isRequired": true + "isRequired": false } ], "returnComment": [] diff --git a/api_docs/fleet.mdx b/api_docs/fleet.mdx index f5aded9b08da5..1cb4779cf05ac 100644 --- a/api_docs/fleet.mdx +++ b/api_docs/fleet.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/fleet title: "fleet" image: https://source.unsplash.com/400x175/?github summary: API docs for the fleet plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'fleet'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Fleet](https://github.com/orgs/elastic/teams/fleet) for questions regar | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 1367 | 8 | 1250 | 9 | +| 1371 | 8 | 1254 | 9 | ## Client diff --git a/api_docs/global_search.mdx b/api_docs/global_search.mdx index bec26cfffe7fd..460a8f1f99c7e 100644 --- a/api_docs/global_search.mdx +++ b/api_docs/global_search.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/globalSearch title: "globalSearch" image: https://source.unsplash.com/400x175/?github summary: API docs for the globalSearch plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'globalSearch'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/home.devdocs.json b/api_docs/home.devdocs.json index a54f173409219..56a7ef14f9710 100644 --- a/api_docs/home.devdocs.json +++ b/api_docs/home.devdocs.json @@ -1222,6 +1222,7 @@ ], "path": "src/plugins/home/public/plugin.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "cloud", diff --git a/api_docs/home.mdx b/api_docs/home.mdx index e873c4f033622..e66141c5d0ea4 100644 --- a/api_docs/home.mdx +++ b/api_docs/home.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/home title: "home" image: https://source.unsplash.com/400x175/?github summary: API docs for the home plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'home'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/index_lifecycle_management.mdx b/api_docs/index_lifecycle_management.mdx index 2d8ae90d25ddf..735d7c86b1d77 100644 --- a/api_docs/index_lifecycle_management.mdx +++ b/api_docs/index_lifecycle_management.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/indexLifecycleManagement title: "indexLifecycleManagement" image: https://source.unsplash.com/400x175/?github summary: API docs for the indexLifecycleManagement plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'indexLifecycleManagement'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/index_management.mdx b/api_docs/index_management.mdx index 8049c990d9cde..68d525f2967e5 100644 --- a/api_docs/index_management.mdx +++ b/api_docs/index_management.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/indexManagement title: "indexManagement" image: https://source.unsplash.com/400x175/?github summary: API docs for the indexManagement plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'indexManagement'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/infra.mdx b/api_docs/infra.mdx index d0e6bed7ddc21..3c7d240b135bb 100644 --- a/api_docs/infra.mdx +++ b/api_docs/infra.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/infra title: "infra" image: https://source.unsplash.com/400x175/?github summary: API docs for the infra plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'infra'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/inspector.mdx b/api_docs/inspector.mdx index 993c9417fc367..67ef909de820a 100644 --- a/api_docs/inspector.mdx +++ b/api_docs/inspector.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/inspector title: "inspector" image: https://source.unsplash.com/400x175/?github summary: API docs for the inspector plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'inspector'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/interactive_setup.mdx b/api_docs/interactive_setup.mdx index 99309a8be0640..7b6e04383eabc 100644 --- a/api_docs/interactive_setup.mdx +++ b/api_docs/interactive_setup.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/interactiveSetup title: "interactiveSetup" image: https://source.unsplash.com/400x175/?github summary: API docs for the interactiveSetup plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'interactiveSetup'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_ace.mdx b/api_docs/kbn_ace.mdx index 4f2951d348d80..81eaf8db3ac71 100644 --- a/api_docs/kbn_ace.mdx +++ b/api_docs/kbn_ace.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-ace title: "@kbn/ace" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/ace plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ace'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_alerts.mdx b/api_docs/kbn_alerts.mdx index cd5ca2617fda5..9c49f7f420cba 100644 --- a/api_docs/kbn_alerts.mdx +++ b/api_docs/kbn_alerts.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-alerts title: "@kbn/alerts" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/alerts plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/alerts'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_analytics.mdx b/api_docs/kbn_analytics.mdx index ba6045fefb9c4..196faa8fa3bd0 100644 --- a/api_docs/kbn_analytics.mdx +++ b/api_docs/kbn_analytics.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-analytics title: "@kbn/analytics" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/analytics plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/analytics'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_apm_config_loader.mdx b/api_docs/kbn_apm_config_loader.mdx index 496fbc8578fde..0249c5f880e94 100644 --- a/api_docs/kbn_apm_config_loader.mdx +++ b/api_docs/kbn_apm_config_loader.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-apm-config-loader title: "@kbn/apm-config-loader" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/apm-config-loader plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-config-loader'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_apm_utils.mdx b/api_docs/kbn_apm_utils.mdx index 703e9859cabaf..0c7bcc25456e5 100644 --- a/api_docs/kbn_apm_utils.mdx +++ b/api_docs/kbn_apm_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-apm-utils title: "@kbn/apm-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/apm-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/apm-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_bazel_packages.devdocs.json b/api_docs/kbn_bazel_packages.devdocs.json index d55a84daa74b0..babc54a49973c 100644 --- a/api_docs/kbn_bazel_packages.devdocs.json +++ b/api_docs/kbn_bazel_packages.devdocs.json @@ -205,7 +205,24 @@ ], "interfaces": [], "enums": [], - "misc": [], + "misc": [ + { + "parentPluginId": "@kbn/bazel-packages", + "id": "def-server.BAZEL_PACKAGE_DIRS", + "type": "Array", + "tags": [], + "label": "BAZEL_PACKAGE_DIRS", + "description": [ + "\nThis is a list of repo-relative paths to directories containing packages. Do not\ninclude `**` in these, one or two `*` segments is acceptable, we need this search\nto be super fast so please avoid deep recursive searching.\n\n eg. src/vis-editors => would find a package at src/vis-editors/foo/package.json\n src/vis-editors/* => would find a package at src/vis-editors/foo/bar/package.json" + ], + "signature": [ + "string[]" + ], + "path": "packages/kbn-bazel-packages/src/bazel_package_dirs.ts", + "deprecated": false, + "initialIsOpen": false + } + ], "objects": [] }, "common": { diff --git a/api_docs/kbn_bazel_packages.mdx b/api_docs/kbn_bazel_packages.mdx index 6bf92a041cf71..b52570b5e5d7f 100644 --- a/api_docs/kbn_bazel_packages.mdx +++ b/api_docs/kbn_bazel_packages.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-bazel-packages title: "@kbn/bazel-packages" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/bazel-packages plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/bazel-packages'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Owner missing] for questions regarding this plugin. | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 11 | 0 | 5 | 1 | +| 12 | 0 | 5 | 1 | ## Server @@ -28,3 +28,6 @@ Contact [Owner missing] for questions regarding this plugin. ### Classes +### Consts, variables and types + + diff --git a/api_docs/kbn_cli_dev_mode.mdx b/api_docs/kbn_cli_dev_mode.mdx index 92c13f83f3af6..8e334c0d762c1 100644 --- a/api_docs/kbn_cli_dev_mode.mdx +++ b/api_docs/kbn_cli_dev_mode.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-cli-dev-mode title: "@kbn/cli-dev-mode" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/cli-dev-mode plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/cli-dev-mode'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_config.mdx b/api_docs/kbn_config.mdx index eeb2675144773..a5af39a8a0872 100644 --- a/api_docs/kbn_config.mdx +++ b/api_docs/kbn_config.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-config title: "@kbn/config" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/config plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/config'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_config_schema.mdx b/api_docs/kbn_config_schema.mdx index 1cb53128a84f6..a7df7613cc2f5 100644 --- a/api_docs/kbn_config_schema.mdx +++ b/api_docs/kbn_config_schema.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-config-schema title: "@kbn/config-schema" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/config-schema plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/config-schema'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_crypto.mdx b/api_docs/kbn_crypto.mdx index 9a25ed1ad7ede..e48252de8fb60 100644 --- a/api_docs/kbn_crypto.mdx +++ b/api_docs/kbn_crypto.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-crypto title: "@kbn/crypto" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/crypto plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/crypto'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_dev_utils.mdx b/api_docs/kbn_dev_utils.mdx index 9964ddb0344df..714481f98e1f5 100644 --- a/api_docs/kbn_dev_utils.mdx +++ b/api_docs/kbn_dev_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-dev-utils title: "@kbn/dev-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/dev-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/dev-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_doc_links.devdocs.json b/api_docs/kbn_doc_links.devdocs.json index d1ca28c919752..7dc816e6d0513 100644 --- a/api_docs/kbn_doc_links.devdocs.json +++ b/api_docs/kbn_doc_links.devdocs.json @@ -144,7 +144,7 @@ "label": "apm", "description": [], "signature": [ - "{ readonly kibanaSettings: string; readonly supportedServiceMaps: string; readonly customLinks: string; readonly droppedTransactionSpans: string; readonly upgrading: string; readonly metaData: string; }" + "{ readonly kibanaSettings: string; readonly supportedServiceMaps: string; readonly customLinks: string; readonly droppedTransactionSpans: string; readonly upgrading: string; readonly metaData: string; readonly overview: string; readonly tailSamplingPolicies: string; }" ], "path": "packages/kbn-doc-links/src/types.ts", "deprecated": false @@ -274,7 +274,7 @@ "label": "enterpriseSearch", "description": [], "signature": [ - "{ readonly configuration: string; readonly licenseManagement: string; readonly mailService: string; readonly usersAccess: string; }" + "{ readonly configuration: string; readonly licenseManagement: string; readonly mailService: string; readonly troubleshootSetup: string; readonly usersAccess: string; }" ], "path": "packages/kbn-doc-links/src/types.ts", "deprecated": false @@ -287,7 +287,7 @@ "label": "workplaceSearch", "description": [], "signature": [ - "{ readonly apiKeys: string; readonly box: string; readonly confluenceCloud: string; readonly confluenceServer: string; readonly customSources: string; readonly customSourcePermissions: string; readonly documentPermissions: string; readonly dropbox: string; readonly externalIdentities: string; readonly gitHub: string; readonly gettingStarted: string; readonly gmail: string; readonly googleDrive: string; readonly indexingSchedule: string; readonly jiraCloud: string; readonly jiraServer: string; readonly oneDrive: string; readonly permissions: string; readonly salesforce: string; readonly security: string; readonly serviceNow: string; readonly sharePoint: string; readonly slack: string; readonly synch: string; readonly zendesk: string; }" + "{ readonly apiKeys: string; readonly box: string; readonly confluenceCloud: string; readonly confluenceServer: string; readonly customSources: string; readonly customSourcePermissions: string; readonly documentPermissions: string; readonly dropbox: string; readonly externalSharePointOnline: string; readonly externalIdentities: string; readonly gitHub: string; readonly gettingStarted: string; readonly gmail: string; readonly googleDrive: string; readonly indexingSchedule: string; readonly jiraCloud: string; readonly jiraServer: string; readonly oneDrive: string; readonly permissions: string; readonly salesforce: string; readonly security: string; readonly serviceNow: string; readonly sharePoint: string; readonly sharePointServer: string; readonly slack: string; readonly synch: string; readonly zendesk: string; }" ], "path": "packages/kbn-doc-links/src/types.ts", "deprecated": false @@ -606,7 +606,7 @@ "label": "observability", "description": [], "signature": [ - "{ readonly guide: string; readonly infrastructureThreshold: string; readonly logsThreshold: string; readonly metricsThreshold: string; readonly monitorStatus: string; readonly monitorUptime: string; readonly tlsCertificate: string; readonly uptimeDurationAnomaly: string; }" + "{ readonly guide: string; readonly infrastructureThreshold: string; readonly logsThreshold: string; readonly metricsThreshold: string; readonly monitorStatus: string; readonly monitorUptime: string; readonly tlsCertificate: string; readonly uptimeDurationAnomaly: string; readonly monitorLogs: string; readonly analyzeMetrics: string; readonly monitorUptimeSynthetics: string; readonly userExperience: string; readonly createAlerts: string; }" ], "path": "packages/kbn-doc-links/src/types.ts", "deprecated": false @@ -792,6 +792,19 @@ ], "path": "packages/kbn-doc-links/src/types.ts", "deprecated": false + }, + { + "parentPluginId": "@kbn/doc-links", + "id": "def-server.DocLinks.legal", + "type": "Object", + "tags": [], + "label": "legal", + "description": [], + "signature": [ + "{ readonly privacyStatement: string; }" + ], + "path": "packages/kbn-doc-links/src/types.ts", + "deprecated": false } ], "initialIsOpen": false diff --git a/api_docs/kbn_doc_links.mdx b/api_docs/kbn_doc_links.mdx index 5e3147e18f993..5ce426161bc6a 100644 --- a/api_docs/kbn_doc_links.mdx +++ b/api_docs/kbn_doc_links.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-doc-links title: "@kbn/doc-links" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/doc-links plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/doc-links'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Owner missing] for questions regarding this plugin. | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 62 | 0 | 62 | 2 | +| 63 | 0 | 63 | 2 | ## Server diff --git a/api_docs/kbn_docs_utils.mdx b/api_docs/kbn_docs_utils.mdx index 224ada7d252fc..fea8212043478 100644 --- a/api_docs/kbn_docs_utils.mdx +++ b/api_docs/kbn_docs_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-docs-utils title: "@kbn/docs-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/docs-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/docs-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_es_archiver.mdx b/api_docs/kbn_es_archiver.mdx index ab6e2616383c4..c5e9759b2102a 100644 --- a/api_docs/kbn_es_archiver.mdx +++ b/api_docs/kbn_es_archiver.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-es-archiver title: "@kbn/es-archiver" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/es-archiver plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es-archiver'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_es_query.devdocs.json b/api_docs/kbn_es_query.devdocs.json index eac92f395ff74..3383877678249 100644 --- a/api_docs/kbn_es_query.devdocs.json +++ b/api_docs/kbn_es_query.devdocs.json @@ -1663,6 +1663,38 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "@kbn/es-query", + "id": "def-common.escapeKuery", + "type": "Function", + "tags": [], + "label": "escapeKuery", + "description": [ + "\nEscapes a Kuery node value to ensure that special characters, operators, and whitespace do not result in a parsing error or unintended\nbehavior when using the value as an argument for the `buildNode` function." + ], + "signature": [ + "(str: string) => string" + ], + "path": "packages/kbn-es-query/src/kuery/utils/escape_kuery.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/es-query", + "id": "def-common.escapeKuery.$1", + "type": "Uncategorized", + "tags": [], + "label": "args", + "description": [], + "signature": [ + "A" + ], + "path": "node_modules/@types/lodash/ts3.1/common/util.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "@kbn/es-query", "id": "def-common.fromKueryExpression", @@ -3885,14 +3917,6 @@ "text": "ExistsFilter" }, " | ", - { - "pluginId": "@kbn/es-query", - "scope": "common", - "docId": "kibKbnEsQueryPluginApi", - "section": "def-common.MatchAllFilter", - "text": "MatchAllFilter" - }, - " | ", { "pluginId": "@kbn/es-query", "scope": "common", @@ -3915,6 +3939,14 @@ "docId": "kibKbnEsQueryPluginApi", "section": "def-common.RangeFilter", "text": "RangeFilter" + }, + " | ", + { + "pluginId": "@kbn/es-query", + "scope": "common", + "docId": "kibKbnEsQueryPluginApi", + "section": "def-common.MatchAllFilter", + "text": "MatchAllFilter" } ], "path": "packages/kbn-es-query/src/filters/build_filters/types.ts", diff --git a/api_docs/kbn_es_query.mdx b/api_docs/kbn_es_query.mdx index 40ac4a99797a9..1f320394b82ec 100644 --- a/api_docs/kbn_es_query.mdx +++ b/api_docs/kbn_es_query.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-es-query title: "@kbn/es-query" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/es-query plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/es-query'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Owner missing] for questions regarding this plugin. | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 211 | 1 | 159 | 11 | +| 213 | 1 | 159 | 11 | ## Common diff --git a/api_docs/kbn_field_types.mdx b/api_docs/kbn_field_types.mdx index 7c9752cc3b155..a3ab0aa04405d 100644 --- a/api_docs/kbn_field_types.mdx +++ b/api_docs/kbn_field_types.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-field-types title: "@kbn/field-types" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/field-types plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/field-types'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_generate.mdx b/api_docs/kbn_generate.mdx index 05e1805262f1e..a52a057fb8818 100644 --- a/api_docs/kbn_generate.mdx +++ b/api_docs/kbn_generate.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-generate title: "@kbn/generate" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/generate plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/generate'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_i18n.mdx b/api_docs/kbn_i18n.mdx index c018ebb9f95ab..31dd855bb20b0 100644 --- a/api_docs/kbn_i18n.mdx +++ b/api_docs/kbn_i18n.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-i18n title: "@kbn/i18n" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/i18n plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/i18n'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_interpreter.mdx b/api_docs/kbn_interpreter.mdx index cb705c79bd28d..6eb04eb6b44db 100644 --- a/api_docs/kbn_interpreter.mdx +++ b/api_docs/kbn_interpreter.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-interpreter title: "@kbn/interpreter" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/interpreter plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/interpreter'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_io_ts_utils.mdx b/api_docs/kbn_io_ts_utils.mdx index 6491602316c63..92cfaddd7425c 100644 --- a/api_docs/kbn_io_ts_utils.mdx +++ b/api_docs/kbn_io_ts_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-io-ts-utils title: "@kbn/io-ts-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/io-ts-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/io-ts-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_logging.mdx b/api_docs/kbn_logging.mdx index 1b6b8212af7fe..fe1fc4865c53d 100644 --- a/api_docs/kbn_logging.mdx +++ b/api_docs/kbn_logging.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-logging title: "@kbn/logging" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/logging plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/logging'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_logging_mocks.mdx b/api_docs/kbn_logging_mocks.mdx index 6d4dcb7aca783..47feddb9ee96e 100644 --- a/api_docs/kbn_logging_mocks.mdx +++ b/api_docs/kbn_logging_mocks.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-logging-mocks title: "@kbn/logging-mocks" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/logging-mocks plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/logging-mocks'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_mapbox_gl.mdx b/api_docs/kbn_mapbox_gl.mdx index 0c458eabb1c9a..f30d5b3005c9f 100644 --- a/api_docs/kbn_mapbox_gl.mdx +++ b/api_docs/kbn_mapbox_gl.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-mapbox-gl title: "@kbn/mapbox-gl" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/mapbox-gl plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/mapbox-gl'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_monaco.mdx b/api_docs/kbn_monaco.mdx index c2a68dd755361..131e0dca0813a 100644 --- a/api_docs/kbn_monaco.mdx +++ b/api_docs/kbn_monaco.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-monaco title: "@kbn/monaco" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/monaco plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/monaco'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_optimizer.mdx b/api_docs/kbn_optimizer.mdx index 354283a4a4639..aea6c086a5d32 100644 --- a/api_docs/kbn_optimizer.mdx +++ b/api_docs/kbn_optimizer.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-optimizer title: "@kbn/optimizer" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/optimizer plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/optimizer'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_plugin_generator.mdx b/api_docs/kbn_plugin_generator.mdx index fb8d5a0d1f7c5..722c46b010fa3 100644 --- a/api_docs/kbn_plugin_generator.mdx +++ b/api_docs/kbn_plugin_generator.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-plugin-generator title: "@kbn/plugin-generator" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/plugin-generator plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/plugin-generator'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_plugin_helpers.mdx b/api_docs/kbn_plugin_helpers.mdx index 126fef811d46c..9c8b329b18bb8 100644 --- a/api_docs/kbn_plugin_helpers.mdx +++ b/api_docs/kbn_plugin_helpers.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-plugin-helpers title: "@kbn/plugin-helpers" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/plugin-helpers plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/plugin-helpers'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_pm.mdx b/api_docs/kbn_pm.mdx index bcd856831bc10..c2bcf85b20483 100644 --- a/api_docs/kbn_pm.mdx +++ b/api_docs/kbn_pm.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-pm title: "@kbn/pm" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/pm plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/pm'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_react_field.mdx b/api_docs/kbn_react_field.mdx index b3bd0d109f59d..267c495badc04 100644 --- a/api_docs/kbn_react_field.mdx +++ b/api_docs/kbn_react_field.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-react-field title: "@kbn/react-field" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/react-field plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/react-field'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_rule_data_utils.mdx b/api_docs/kbn_rule_data_utils.mdx index e81dcfabacb3f..fbfbfa631b4b2 100644 --- a/api_docs/kbn_rule_data_utils.mdx +++ b/api_docs/kbn_rule_data_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-rule-data-utils title: "@kbn/rule-data-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/rule-data-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/rule-data-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_autocomplete.mdx b/api_docs/kbn_securitysolution_autocomplete.mdx index ce3960c8fd011..448c389482300 100644 --- a/api_docs/kbn_securitysolution_autocomplete.mdx +++ b/api_docs/kbn_securitysolution_autocomplete.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-autocomplete title: "@kbn/securitysolution-autocomplete" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-autocomplete plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-autocomplete'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_es_utils.mdx b/api_docs/kbn_securitysolution_es_utils.mdx index 0df1e12c36d1e..f22924e2220f8 100644 --- a/api_docs/kbn_securitysolution_es_utils.mdx +++ b/api_docs/kbn_securitysolution_es_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-es-utils title: "@kbn/securitysolution-es-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-es-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-es-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_hook_utils.mdx b/api_docs/kbn_securitysolution_hook_utils.mdx index 5c23a621d0379..5635ccfc7132c 100644 --- a/api_docs/kbn_securitysolution_hook_utils.mdx +++ b/api_docs/kbn_securitysolution_hook_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-hook-utils title: "@kbn/securitysolution-hook-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-hook-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-hook-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx b/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx index 0bdb0cb846908..9381b63fd7ca4 100644 --- a/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx +++ b/api_docs/kbn_securitysolution_io_ts_alerting_types.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-alerting-types title: "@kbn/securitysolution-io-ts-alerting-types" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-io-ts-alerting-types plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-alerting-types'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_io_ts_list_types.devdocs.json b/api_docs/kbn_securitysolution_io_ts_list_types.devdocs.json index 944c66acef02e..512f130f72ef4 100644 --- a/api_docs/kbn_securitysolution_io_ts_list_types.devdocs.json +++ b/api_docs/kbn_securitysolution_io_ts_list_types.devdocs.json @@ -1625,31 +1625,14 @@ }, { "parentPluginId": "@kbn/securitysolution-io-ts-list-types", - "id": "def-common.UseExceptionListsProps.showTrustedApps", - "type": "boolean", - "tags": [], - "label": "showTrustedApps", - "description": [], - "path": "packages/kbn-securitysolution-io-ts-list-types/src/typescript_types/index.ts", - "deprecated": false - }, - { - "parentPluginId": "@kbn/securitysolution-io-ts-list-types", - "id": "def-common.UseExceptionListsProps.showEventFilters", - "type": "boolean", - "tags": [], - "label": "showEventFilters", - "description": [], - "path": "packages/kbn-securitysolution-io-ts-list-types/src/typescript_types/index.ts", - "deprecated": false - }, - { - "parentPluginId": "@kbn/securitysolution-io-ts-list-types", - "id": "def-common.UseExceptionListsProps.showHostIsolationExceptions", - "type": "boolean", + "id": "def-common.UseExceptionListsProps.hideLists", + "type": "Object", "tags": [], - "label": "showHostIsolationExceptions", + "label": "hideLists", "description": [], + "signature": [ + "readonly string[] | undefined" + ], "path": "packages/kbn-securitysolution-io-ts-list-types/src/typescript_types/index.ts", "deprecated": false } diff --git a/api_docs/kbn_securitysolution_io_ts_list_types.mdx b/api_docs/kbn_securitysolution_io_ts_list_types.mdx index ee1e10b57abbf..f33e0b3da3ca4 100644 --- a/api_docs/kbn_securitysolution_io_ts_list_types.mdx +++ b/api_docs/kbn_securitysolution_io_ts_list_types.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-list-types title: "@kbn/securitysolution-io-ts-list-types" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-io-ts-list-types plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-list-types'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Owner missing] for questions regarding this plugin. | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 460 | 1 | 448 | 0 | +| 458 | 1 | 446 | 0 | ## Common diff --git a/api_docs/kbn_securitysolution_io_ts_types.mdx b/api_docs/kbn_securitysolution_io_ts_types.mdx index 13a458eed5239..9d2d7372004c5 100644 --- a/api_docs/kbn_securitysolution_io_ts_types.mdx +++ b/api_docs/kbn_securitysolution_io_ts_types.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-types title: "@kbn/securitysolution-io-ts-types" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-io-ts-types plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-types'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_io_ts_utils.mdx b/api_docs/kbn_securitysolution_io_ts_utils.mdx index 406013a5b1ce8..da8ec9ab69e35 100644 --- a/api_docs/kbn_securitysolution_io_ts_utils.mdx +++ b/api_docs/kbn_securitysolution_io_ts_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-io-ts-utils title: "@kbn/securitysolution-io-ts-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-io-ts-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-io-ts-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_list_api.mdx b/api_docs/kbn_securitysolution_list_api.mdx index 4aba5e62963cb..0516c6a5db34d 100644 --- a/api_docs/kbn_securitysolution_list_api.mdx +++ b/api_docs/kbn_securitysolution_list_api.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-api title: "@kbn/securitysolution-list-api" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-list-api plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-api'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_list_constants.mdx b/api_docs/kbn_securitysolution_list_constants.mdx index e3acd1c60b123..1b6ba111ea8ce 100644 --- a/api_docs/kbn_securitysolution_list_constants.mdx +++ b/api_docs/kbn_securitysolution_list_constants.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-constants title: "@kbn/securitysolution-list-constants" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-list-constants plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-constants'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_list_hooks.devdocs.json b/api_docs/kbn_securitysolution_list_hooks.devdocs.json index 56a6c1616eb21..588e4a302b4e6 100644 --- a/api_docs/kbn_securitysolution_list_hooks.devdocs.json +++ b/api_docs/kbn_securitysolution_list_hooks.devdocs.json @@ -377,7 +377,7 @@ "\nHook for fetching ExceptionLists\n" ], "signature": [ - "({ errorMessage, http, initialPagination, filterOptions, namespaceTypes, notifications, showTrustedApps, showEventFilters, showHostIsolationExceptions, }: ", + "({ errorMessage, http, initialPagination, filterOptions, namespaceTypes, notifications, hideLists, }: ", "UseExceptionListsProps", ") => ", { @@ -396,7 +396,7 @@ "id": "def-common.useExceptionLists.$1", "type": "Object", "tags": [], - "label": "{\n errorMessage,\n http,\n initialPagination = DEFAULT_PAGINATION,\n filterOptions = {},\n namespaceTypes,\n notifications,\n showTrustedApps = false,\n showEventFilters = false,\n showHostIsolationExceptions = false,\n}", + "label": "{\n errorMessage,\n http,\n initialPagination = DEFAULT_PAGINATION,\n filterOptions = {},\n namespaceTypes,\n notifications,\n hideLists = [],\n}", "description": [], "signature": [ "UseExceptionListsProps" diff --git a/api_docs/kbn_securitysolution_list_hooks.mdx b/api_docs/kbn_securitysolution_list_hooks.mdx index 1b6d1163b1524..8c57af3b5a867 100644 --- a/api_docs/kbn_securitysolution_list_hooks.mdx +++ b/api_docs/kbn_securitysolution_list_hooks.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-hooks title: "@kbn/securitysolution-list-hooks" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-list-hooks plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-hooks'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_list_utils.devdocs.json b/api_docs/kbn_securitysolution_list_utils.devdocs.json index 1b91981be43f3..a5fa0a4c4b648 100644 --- a/api_docs/kbn_securitysolution_list_utils.devdocs.json +++ b/api_docs/kbn_securitysolution_list_utils.devdocs.json @@ -1717,7 +1717,7 @@ "label": "getFilters", "description": [], "signature": [ - "({ filters, namespaceTypes, showTrustedApps, showEventFilters, showHostIsolationExceptions, }: ", + "({ filters, namespaceTypes, hideLists }: ", { "pluginId": "@kbn/securitysolution-list-utils", "scope": "common", @@ -1735,7 +1735,7 @@ "id": "def-common.getFilters.$1", "type": "Object", "tags": [], - "label": "{\n filters,\n namespaceTypes,\n showTrustedApps,\n showEventFilters,\n showHostIsolationExceptions,\n}", + "label": "{ filters, namespaceTypes, hideLists }", "description": [], "signature": [ { @@ -2424,66 +2424,6 @@ "returnComment": [], "initialIsOpen": false }, - { - "parentPluginId": "@kbn/securitysolution-list-utils", - "id": "def-common.getTrustedAppsFilter", - "type": "Function", - "tags": [], - "label": "getTrustedAppsFilter", - "description": [], - "signature": [ - "(showTrustedApps: boolean, namespaceTypes: ", - { - "pluginId": "@kbn/securitysolution-list-utils", - "scope": "common", - "docId": "kibKbnSecuritysolutionListUtilsPluginApi", - "section": "def-common.SavedObjectType", - "text": "SavedObjectType" - }, - "[]) => string" - ], - "path": "packages/kbn-securitysolution-list-utils/src/get_trusted_apps_filter/index.ts", - "deprecated": false, - "children": [ - { - "parentPluginId": "@kbn/securitysolution-list-utils", - "id": "def-common.getTrustedAppsFilter.$1", - "type": "boolean", - "tags": [], - "label": "showTrustedApps", - "description": [], - "signature": [ - "boolean" - ], - "path": "packages/kbn-securitysolution-list-utils/src/get_trusted_apps_filter/index.ts", - "deprecated": false, - "isRequired": true - }, - { - "parentPluginId": "@kbn/securitysolution-list-utils", - "id": "def-common.getTrustedAppsFilter.$2", - "type": "Array", - "tags": [], - "label": "namespaceTypes", - "description": [], - "signature": [ - { - "pluginId": "@kbn/securitysolution-list-utils", - "scope": "common", - "docId": "kibKbnSecuritysolutionListUtilsPluginApi", - "section": "def-common.SavedObjectType", - "text": "SavedObjectType" - }, - "[]" - ], - "path": "packages/kbn-securitysolution-list-utils/src/get_trusted_apps_filter/index.ts", - "deprecated": false, - "isRequired": true - } - ], - "returnComment": [], - "initialIsOpen": false - }, { "parentPluginId": "@kbn/securitysolution-list-utils", "id": "def-common.getUpdatedEntriesOnDelete", @@ -3107,31 +3047,14 @@ }, { "parentPluginId": "@kbn/securitysolution-list-utils", - "id": "def-common.GetFiltersParams.showTrustedApps", - "type": "boolean", - "tags": [], - "label": "showTrustedApps", - "description": [], - "path": "packages/kbn-securitysolution-list-utils/src/get_filters/index.ts", - "deprecated": false - }, - { - "parentPluginId": "@kbn/securitysolution-list-utils", - "id": "def-common.GetFiltersParams.showEventFilters", - "type": "boolean", - "tags": [], - "label": "showEventFilters", - "description": [], - "path": "packages/kbn-securitysolution-list-utils/src/get_filters/index.ts", - "deprecated": false - }, - { - "parentPluginId": "@kbn/securitysolution-list-utils", - "id": "def-common.GetFiltersParams.showHostIsolationExceptions", - "type": "boolean", + "id": "def-common.GetFiltersParams.hideLists", + "type": "Object", "tags": [], - "label": "showHostIsolationExceptions", + "label": "hideLists", "description": [], + "signature": [ + "readonly string[]" + ], "path": "packages/kbn-securitysolution-list-utils/src/get_filters/index.ts", "deprecated": false } diff --git a/api_docs/kbn_securitysolution_list_utils.mdx b/api_docs/kbn_securitysolution_list_utils.mdx index b048021bb5fa1..17c04cc6a5a63 100644 --- a/api_docs/kbn_securitysolution_list_utils.mdx +++ b/api_docs/kbn_securitysolution_list_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-list-utils title: "@kbn/securitysolution-list-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-list-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-list-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Owner missing] for questions regarding this plugin. | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 231 | 0 | 183 | 0 | +| 226 | 0 | 178 | 0 | ## Common diff --git a/api_docs/kbn_securitysolution_rules.mdx b/api_docs/kbn_securitysolution_rules.mdx index 22364ff1ce723..c39b406357f73 100644 --- a/api_docs/kbn_securitysolution_rules.mdx +++ b/api_docs/kbn_securitysolution_rules.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-rules title: "@kbn/securitysolution-rules" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-rules plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-rules'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_t_grid.mdx b/api_docs/kbn_securitysolution_t_grid.mdx index 6568f71dafd4c..93b4fab165f4f 100644 --- a/api_docs/kbn_securitysolution_t_grid.mdx +++ b/api_docs/kbn_securitysolution_t_grid.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-t-grid title: "@kbn/securitysolution-t-grid" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-t-grid plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-t-grid'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_securitysolution_utils.devdocs.json b/api_docs/kbn_securitysolution_utils.devdocs.json index 477e2877d7528..b312c9d9d3ca9 100644 --- a/api_docs/kbn_securitysolution_utils.devdocs.json +++ b/api_docs/kbn_securitysolution_utils.devdocs.json @@ -63,10 +63,10 @@ "pluginId": "@kbn/securitysolution-utils", "scope": "server", "docId": "kibKbnSecuritysolutionUtilsPluginApi", - "section": "def-server.TrustedAppEntryTypes", - "text": "TrustedAppEntryTypes" + "section": "def-server.EntryTypes", + "text": "EntryTypes" }, - "; value: string; }) => boolean" + "; value: string; }) => boolean | undefined" ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false, @@ -108,7 +108,7 @@ "label": "type", "description": [], "signature": [ - "\"match\" | \"wildcard\"" + "\"match\" | \"wildcard\" | \"match_any\"" ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false @@ -150,16 +150,16 @@ "pluginId": "@kbn/securitysolution-utils", "scope": "server", "docId": "kibKbnSecuritysolutionUtilsPluginApi", - "section": "def-server.ConditionEntryField", - "text": "ConditionEntryField" + "section": "def-server.AllConditionEntryFields", + "text": "AllConditionEntryFields" }, "; type: ", { "pluginId": "@kbn/securitysolution-utils", "scope": "server", "docId": "kibKbnSecuritysolutionUtilsPluginApi", - "section": "def-server.TrustedAppEntryTypes", - "text": "TrustedAppEntryTypes" + "section": "def-server.EntryTypes", + "text": "EntryTypes" }, "; value: string; }) => boolean" ], @@ -208,8 +208,8 @@ "pluginId": "@kbn/securitysolution-utils", "scope": "server", "docId": "kibKbnSecuritysolutionUtilsPluginApi", - "section": "def-server.ConditionEntryField", - "text": "ConditionEntryField" + "section": "def-server.AllConditionEntryFields", + "text": "AllConditionEntryFields" } ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", @@ -223,7 +223,7 @@ "label": "type", "description": [], "signature": [ - "\"match\" | \"wildcard\"" + "\"match\" | \"wildcard\" | \"match_any\"" ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false @@ -393,6 +393,17 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "@kbn/securitysolution-utils", + "id": "def-server.EntryFieldType", + "type": "Enum", + "tags": [], + "label": "EntryFieldType", + "description": [], + "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "@kbn/securitysolution-utils", "id": "def-server.OperatingSystem", @@ -408,51 +419,91 @@ "misc": [ { "parentPluginId": "@kbn/securitysolution-utils", - "id": "def-server.FILENAME_WILDCARD_WARNING", - "type": "string", + "id": "def-server.AllConditionEntryFields", + "type": "Type", "tags": [], - "label": "FILENAME_WILDCARD_WARNING", + "label": "AllConditionEntryFields", "description": [], + "signature": [ + { + "pluginId": "@kbn/securitysolution-utils", + "scope": "server", + "docId": "kibKbnSecuritysolutionUtilsPluginApi", + "section": "def-server.TrustedAppConditionEntryField", + "text": "TrustedAppConditionEntryField" + }, + " | ", + { + "pluginId": "@kbn/securitysolution-utils", + "scope": "server", + "docId": "kibKbnSecuritysolutionUtilsPluginApi", + "section": "def-server.BlocklistConditionEntryField", + "text": "BlocklistConditionEntryField" + } + ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false, "initialIsOpen": false }, { "parentPluginId": "@kbn/securitysolution-utils", - "id": "def-server.FILEPATH_WARNING", - "type": "string", + "id": "def-server.BlocklistConditionEntryField", + "type": "Type", "tags": [], - "label": "FILEPATH_WARNING", + "label": "BlocklistConditionEntryField", "description": [], + "signature": [ + "\"file.path\" | \"file.hash.*\" | \"file.Ext.code_signature\"" + ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false, "initialIsOpen": false }, { "parentPluginId": "@kbn/securitysolution-utils", - "id": "def-server.TrustedAppEntryTypes", + "id": "def-server.EntryTypes", "type": "Type", "tags": [], - "label": "TrustedAppEntryTypes", + "label": "EntryTypes", "description": [], "signature": [ - "\"match\" | \"wildcard\"" + "\"match\" | \"wildcard\" | \"match_any\"" ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false, "initialIsOpen": false - } - ], - "objects": [ + }, { "parentPluginId": "@kbn/securitysolution-utils", - "id": "def-server.UNIX_EXEC_PATH", - "type": "Object", + "id": "def-server.FILENAME_WILDCARD_WARNING", + "type": "string", "tags": [], - "label": "UNIX_EXEC_PATH", + "label": "FILENAME_WILDCARD_WARNING", + "description": [], + "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/securitysolution-utils", + "id": "def-server.FILEPATH_WARNING", + "type": "string", + "tags": [], + "label": "FILEPATH_WARNING", + "description": [], + "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/securitysolution-utils", + "id": "def-server.TrustedAppConditionEntryField", + "type": "Type", + "tags": [], + "label": "TrustedAppConditionEntryField", "description": [], "signature": [ - "RegExp" + "\"process.hash.*\" | \"process.executable.caseless\" | \"process.Ext.code_signature\"" ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false, @@ -460,19 +511,20 @@ }, { "parentPluginId": "@kbn/securitysolution-utils", - "id": "def-server.WIN_EXEC_PATH", - "type": "Object", + "id": "def-server.TrustedAppEntryTypes", + "type": "Type", "tags": [], - "label": "WIN_EXEC_PATH", + "label": "TrustedAppEntryTypes", "description": [], "signature": [ - "RegExp" + "\"match\" | \"wildcard\"" ], "path": "packages/kbn-securitysolution-utils/src/path_validations/index.ts", "deprecated": false, "initialIsOpen": false } - ] + ], + "objects": [] }, "common": { "classes": [], diff --git a/api_docs/kbn_securitysolution_utils.mdx b/api_docs/kbn_securitysolution_utils.mdx index 2514f8a9eec34..6ca1d3b071818 100644 --- a/api_docs/kbn_securitysolution_utils.mdx +++ b/api_docs/kbn_securitysolution_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-securitysolution-utils title: "@kbn/securitysolution-utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/securitysolution-utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/securitysolution-utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,13 +18,10 @@ Contact [Owner missing] for questions regarding this plugin. | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 28 | 0 | 26 | 0 | +| 31 | 0 | 29 | 0 | ## Server -### Objects - - ### Functions diff --git a/api_docs/kbn_server_http_tools.mdx b/api_docs/kbn_server_http_tools.mdx index 7beff881ac4cb..1ab1301c4d1cb 100644 --- a/api_docs/kbn_server_http_tools.mdx +++ b/api_docs/kbn_server_http_tools.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-server-http-tools title: "@kbn/server-http-tools" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/server-http-tools plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/server-http-tools'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_server_route_repository.mdx b/api_docs/kbn_server_route_repository.mdx index 6a1ff8daa4770..d46b5bd6e4f1b 100644 --- a/api_docs/kbn_server_route_repository.mdx +++ b/api_docs/kbn_server_route_repository.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-server-route-repository title: "@kbn/server-route-repository" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/server-route-repository plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/server-route-repository'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_shared_ux_components.devdocs.json b/api_docs/kbn_shared_ux_components.devdocs.json new file mode 100644 index 0000000000000..dcccffd398f13 --- /dev/null +++ b/api_docs/kbn_shared_ux_components.devdocs.json @@ -0,0 +1,513 @@ +{ + "id": "@kbn/shared-ux-components", + "client": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "server": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "common": { + "classes": [], + "functions": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.AddFromLibraryButton", + "type": "Function", + "tags": [], + "label": "AddFromLibraryButton", + "description": [], + "signature": [ + "({ onClick, ...rest }: ", + "Props", + ") => JSX.Element" + ], + "path": "packages/kbn-shared-ux-components/src/toolbar/buttons/add_from_library/add_from_library.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.AddFromLibraryButton.$1", + "type": "Object", + "tags": [], + "label": "{ onClick, ...rest }", + "description": [], + "signature": [ + "Props" + ], + "path": "packages/kbn-shared-ux-components/src/toolbar/buttons/add_from_library/add_from_library.tsx", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.ExitFullScreenButton", + "type": "Function", + "tags": [], + "label": "ExitFullScreenButton", + "description": [ + "\nA `ExitFullScreenButton` component that is wrapped by the `withSuspense` HOC. This component can\nbe used directly by consumers and will load the `LazyExitFullScreenButton` component lazily with\na predefined fallback and error boundary." + ], + "signature": [ + "React.ForwardRefExoticComponent<", + "Props", + " & React.RefAttributes<{}>>" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.ExitFullScreenButton.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.IconButtonGroup", + "type": "Function", + "tags": [], + "label": "IconButtonGroup", + "description": [ + "\nThe IconButtonGroup component that is wrapped by the `withSuspence` HOC." + ], + "signature": [ + "React.ForwardRefExoticComponent<", + "Props", + " & React.RefAttributes<{}>>" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.IconButtonGroup.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.KibanaSolutionAvatar", + "type": "Function", + "tags": [], + "label": "KibanaSolutionAvatar", + "description": [ + "\nA `KibanaSolutionAvatar` component that is wrapped by the `withSuspense` HOC. This component can\nbe used directly by consumers and will load the `KibanaPageTemplateSolutionNavAvatarLazy` component lazily with\na predefined fallback and error boundary." + ], + "signature": [ + "React.ForwardRefExoticComponent<", + "KibanaSolutionAvatarProps", + " & React.RefAttributes<{}>>" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.KibanaSolutionAvatar.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.KibanaSolutionAvatarLazy", + "type": "Function", + "tags": [], + "label": "KibanaSolutionAvatarLazy", + "description": [ + "\nThe Lazily-loaded `KibanaSolutionAvatar` component. Consumers should use `React.Suspense` or\nthe withSuspense` HOC to load this component." + ], + "signature": [ + "React.ExoticComponent<", + "KibanaSolutionAvatarProps", + "> & { readonly _result: ({ className, size, ...rest }: ", + "KibanaSolutionAvatarProps", + ") => JSX.Element; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.KibanaSolutionAvatarLazy.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyExitFullScreenButton", + "type": "Function", + "tags": [], + "label": "LazyExitFullScreenButton", + "description": [ + "\nThe Lazily-loaded `ExitFullScreenButton` component. Consumers should use `React.Suspennse` or the\n`withSuspense` HOC to load this component." + ], + "signature": [ + "React.ExoticComponent<", + "Props", + "> & { readonly _result: ({ onExit, toggleChrome }: ", + "Props", + ") => JSX.Element; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyExitFullScreenButton.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyIconButtonGroup", + "type": "Function", + "tags": [], + "label": "LazyIconButtonGroup", + "description": [ + "\nThe Lazily-loaded `IconButtonGroup` component. Consumers should use `React.Suspennse` or the\n`withSuspense` HOC to load this component." + ], + "signature": [ + "React.ExoticComponent<", + "Props", + "> & { readonly _result: ({ buttons, legend }: ", + "Props", + ") => JSX.Element; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyIconButtonGroup.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyNoDataViews", + "type": "Function", + "tags": [], + "label": "LazyNoDataViews", + "description": [ + "\nThe Lazily-loaded `NoDataViews` component. Consumers should use `React.Suspennse` or the\n`withSuspense` HOC to load this component." + ], + "signature": [ + "React.ExoticComponent<", + "Props", + "> & { readonly _result: ({ onDataViewCreated }: ", + "Props", + ") => JSX.Element; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyNoDataViews.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyNoDataViewsComponent", + "type": "Function", + "tags": [], + "label": "LazyNoDataViewsComponent", + "description": [ + "\nA pure `NoDataViews` component, with no services hooks. Consumers should use `React.Suspennse` or the\n`withSuspense` HOC to load this component." + ], + "signature": [ + "React.ExoticComponent<", + "Props", + "> & { readonly _result: ({ onClickCreate, canCreateNewDataView, dataViewsDocLink, emptyPromptColor, }: ", + "Props", + ") => JSX.Element; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyNoDataViewsComponent.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyToolbarButton", + "type": "Function", + "tags": [], + "label": "LazyToolbarButton", + "description": [], + "signature": [ + "React.ExoticComponent<", + "Props", + "> & { readonly _result: ({ label, ...rest }: ", + "Props", + ") => JSX.Element; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.LazyToolbarButton.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.NoDataViews", + "type": "Function", + "tags": [], + "label": "NoDataViews", + "description": [ + "\nA `NoDataViews` component that is wrapped by the `withSuspense` HOC. This component can\nbe used directly by consumers and will load the `LazyNoDataViews` component lazily with\na predefined fallback and error boundary." + ], + "signature": [ + "React.ForwardRefExoticComponent<", + "Props", + " & React.RefAttributes<{}>>" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.NoDataViews.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.NoDataViewsComponent", + "type": "Function", + "tags": [], + "label": "NoDataViewsComponent", + "description": [ + "\nA pure `NoDataViews` component, with no services hooks. The component is wrapped by the `withSuspense` HOC.\nThis component can be used directly by consumers and will load the `LazyNoDataViewsComponent` lazily with\na predefined fallback and error boundary." + ], + "signature": [ + "React.ForwardRefExoticComponent<", + "Props", + " & React.RefAttributes<{}>>" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.NoDataViewsComponent.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.RedirectAppLinks", + "type": "Function", + "tags": [], + "label": "RedirectAppLinks", + "description": [], + "signature": [ + "React.ExoticComponent & { ref?: React.RefObject | ((instance: HTMLDivElement | null) => void) | null | undefined; }> & { readonly _result: React.FC<", + "RedirectAppLinksProps", + ">; }" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.RedirectAppLinks.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.ToolbarButton", + "type": "Function", + "tags": [], + "label": "ToolbarButton", + "description": [ + "\nA `ToolbarButton` component that is wrapped by the `withSuspense` HOC. This component can\nbe used directly by consumers and will load the `LazyToolbarButton` component lazily with\na predefined fallback and error boundary." + ], + "signature": [ + "React.ForwardRefExoticComponent<", + "Props", + " & React.RefAttributes<{}>>" + ], + "path": "packages/kbn-shared-ux-components/src/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-components", + "id": "def-common.ToolbarButton.$1", + "type": "Uncategorized", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + } + ], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + } +} \ No newline at end of file diff --git a/api_docs/kbn_shared_ux_components.mdx b/api_docs/kbn_shared_ux_components.mdx new file mode 100644 index 0000000000000..e471398dde3a1 --- /dev/null +++ b/api_docs/kbn_shared_ux_components.mdx @@ -0,0 +1,27 @@ +--- +id: kibKbnSharedUxComponentsPluginApi +slug: /kibana-dev-docs/api/kbn-shared-ux-components +title: "@kbn/shared-ux-components" +image: https://source.unsplash.com/400x175/?github +summary: API docs for the @kbn/shared-ux-components plugin +date: 2022-03-28 +tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-components'] +warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. +--- +import kbnSharedUxComponentsObj from './kbn_shared_ux_components.devdocs.json'; + + + +Contact [Owner missing] for questions regarding this plugin. + +**Code health stats** + +| Public API count | Any count | Items lacking comments | Missing exports | +|-------------------|-----------|------------------------|-----------------| +| 28 | 0 | 4 | 3 | + +## Common + +### Functions + + diff --git a/api_docs/kbn_shared_ux_services.devdocs.json b/api_docs/kbn_shared_ux_services.devdocs.json new file mode 100644 index 0000000000000..08bfb4e4053c7 --- /dev/null +++ b/api_docs/kbn_shared_ux_services.devdocs.json @@ -0,0 +1,1311 @@ +{ + "id": "@kbn/shared-ux-services", + "client": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "server": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "common": { + "classes": [], + "functions": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServicesFactory", + "type": "Function", + "tags": [], + "label": "mockServicesFactory", + "description": [ + "\nA factory function for creating a Jest-based implementation of `SharedUxServices`." + ], + "signature": [ + "() => { application: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxApplicationService", + "text": "SharedUxApplicationService" + }, + "; docLinks: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxDocLinksService", + "text": "SharedUxDocLinksService" + }, + "; editors: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxEditorsService", + "text": "SharedUxEditorsService" + }, + "; http: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxHttpService", + "text": "SharedUxHttpService" + }, + "; permissions: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxUserPermissionsService", + "text": "SharedUxUserPermissionsService" + }, + "; platform: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxPlatformService", + "text": "SharedUxPlatformService" + }, + "; }" + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServicesProvider", + "type": "Function", + "tags": [], + "label": "SharedUxServicesProvider", + "description": [ + "\nThe `React.Context` Provider component for the `SharedUxServices` context. Any\nplugin or environment that consumes SharedUX components needs to wrap their React\ntree with this provider.\n\nWithin a plugin, you can use use the Shared UX plugin and retrieve a fully-configured\ncontext from the `start` contract." + ], + "signature": [ + "({ children, ...services }: React.PropsWithChildren<", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxServices", + "text": "SharedUxServices" + }, + ">) => JSX.Element" + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServicesProvider.$1", + "type": "CompoundType", + "tags": [], + "label": "{ children, ...services }", + "description": [], + "signature": [ + "React.PropsWithChildren<", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxServices", + "text": "SharedUxServices" + }, + ">" + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServicesFactory", + "type": "Function", + "tags": [], + "label": "stubServicesFactory", + "description": [ + "\nA factory function for creating simple stubbed implementations of all `SharedUxServices`." + ], + "signature": [ + "() => { application: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxApplicationService", + "text": "SharedUxApplicationService" + }, + "; docLinks: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxDocLinksService", + "text": "SharedUxDocLinksService" + }, + "; editors: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxEditorsService", + "text": "SharedUxEditorsService" + }, + "; http: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxHttpService", + "text": "SharedUxHttpService" + }, + "; permissions: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxUserPermissionsService", + "text": "SharedUxUserPermissionsService" + }, + "; platform: ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxPlatformService", + "text": "SharedUxPlatformService" + }, + "; }" + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.useApplication", + "type": "Function", + "tags": [], + "label": "useApplication", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxApplicationService", + "text": "SharedUxApplicationService" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.useDocLinks", + "type": "Function", + "tags": [], + "label": "useDocLinks", + "description": [ + "\nReact hook for accessing the pre-wired `SharedUxDocLinksService`." + ], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxDocLinksService", + "text": "SharedUxDocLinksService" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.useEditors", + "type": "Function", + "tags": [], + "label": "useEditors", + "description": [ + "\nReact hook for accessing the pre-wired `SharedUxEditorsService`." + ], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxEditorsService", + "text": "SharedUxEditorsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.useHttp", + "type": "Function", + "tags": [], + "label": "useHttp", + "description": [], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxHttpService", + "text": "SharedUxHttpService" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.usePermissions", + "type": "Function", + "tags": [], + "label": "usePermissions", + "description": [ + "\nReact hook for accessing the pre-wired `SharedUxPermissionsService`." + ], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxUserPermissionsService", + "text": "SharedUxUserPermissionsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.usePlatformService", + "type": "Function", + "tags": [], + "label": "usePlatformService", + "description": [ + "\nReact hook for accessing the pre-wired `SharedUxPlatformService`." + ], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxPlatformService", + "text": "SharedUxPlatformService" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.useSharedUxServices", + "type": "Function", + "tags": [], + "label": "useSharedUxServices", + "description": [ + "\nReact hook for accessing pre-wired `SharedUxServices`." + ], + "signature": [ + "() => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxServices", + "text": "SharedUxServices" + } + ], + "path": "packages/kbn-shared-ux-services/src/context.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + } + ], + "interfaces": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxApplicationService", + "type": "Interface", + "tags": [], + "label": "SharedUxApplicationService", + "description": [], + "path": "packages/kbn-shared-ux-services/src/services/application.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxApplicationService.navigateToUrl", + "type": "Function", + "tags": [], + "label": "navigateToUrl", + "description": [], + "signature": [ + "(url: string) => Promise" + ], + "path": "packages/kbn-shared-ux-services/src/services/application.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxApplicationService.navigateToUrl.$1", + "type": "string", + "tags": [], + "label": "url", + "description": [], + "signature": [ + "string" + ], + "path": "packages/kbn-shared-ux-services/src/services/application.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxApplicationService.currentAppId$", + "type": "Object", + "tags": [], + "label": "currentAppId$", + "description": [], + "signature": [ + "Observable", + "" + ], + "path": "packages/kbn-shared-ux-services/src/services/application.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxDocLinksService", + "type": "Interface", + "tags": [], + "label": "SharedUxDocLinksService", + "description": [ + "\nA service providing links to documentation about various features in Kibana." + ], + "path": "packages/kbn-shared-ux-services/src/services/doc_links.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxDocLinksService.dataViewsDocLink", + "type": "string", + "tags": [], + "label": "dataViewsDocLink", + "description": [ + "A link to information about Data Views in Kibana" + ], + "path": "packages/kbn-shared-ux-services/src/services/doc_links.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxEditorsService", + "type": "Interface", + "tags": [], + "label": "SharedUxEditorsService", + "description": [ + "\nA service providing methods to invoke and interact with various editors provided\nin Kibana." + ], + "path": "packages/kbn-shared-ux-services/src/services/editors.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxEditorsService.openDataViewEditor", + "type": "Function", + "tags": [], + "label": "openDataViewEditor", + "description": [ + "A method to open the Data View Editor flow." + ], + "signature": [ + "(options: DataViewEditorOptions) => () => void" + ], + "path": "packages/kbn-shared-ux-services/src/services/editors.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxEditorsService.openDataViewEditor.$1", + "type": "Object", + "tags": [], + "label": "options", + "description": [], + "signature": [ + "DataViewEditorOptions" + ], + "path": "packages/kbn-shared-ux-services/src/services/editors.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxHttpService", + "type": "Interface", + "tags": [], + "label": "SharedUxHttpService", + "description": [], + "path": "packages/kbn-shared-ux-services/src/services/http.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxHttpService.addBasePath", + "type": "Function", + "tags": [], + "label": "addBasePath", + "description": [], + "signature": [ + "(url: string) => string" + ], + "path": "packages/kbn-shared-ux-services/src/services/http.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxHttpService.addBasePath.$1", + "type": "string", + "tags": [], + "label": "url", + "description": [], + "signature": [ + "string" + ], + "path": "packages/kbn-shared-ux-services/src/services/http.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxPlatformService", + "type": "Interface", + "tags": [], + "label": "SharedUxPlatformService", + "description": [ + "\nA service providing methods to interact with the platform in which this code is\nrunning, (almost always Kibana).\n\nRather than provide the entire `CoreStart` contract to components, we provide simplified\nabstractions around a use case specific to Shared UX. This way, we know exactly how the\n`CoreStart` and other plugins are used. This makes mocking and refactoring easier when\n upstream dependencies change." + ], + "path": "packages/kbn-shared-ux-services/src/services/platform.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxPlatformService.setIsFullscreen", + "type": "Function", + "tags": [], + "label": "setIsFullscreen", + "description": [ + "\nSets the fullscreen state of the chrome." + ], + "signature": [ + "(isFullscreen: boolean) => void" + ], + "path": "packages/kbn-shared-ux-services/src/services/platform.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxPlatformService.setIsFullscreen.$1", + "type": "boolean", + "tags": [], + "label": "isFullscreen", + "description": [ + "True if the chrome should be fullscreen, false otherwise." + ], + "signature": [ + "boolean" + ], + "path": "packages/kbn-shared-ux-services/src/services/platform.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices", + "type": "Interface", + "tags": [], + "label": "SharedUxServices", + "description": [ + "\nA collection of services utilized by SharedUX. This serves as a thin\nabstraction layer between services provided by Kibana and other plugins\nwhile allowing this plugin to be developed independently of those contracts.\n\nIt also allows us to \"swap out\" differenct implementations of these services\nfor different environments, (e.g. Jest, Storybook, etc.)" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices.application", + "type": "Object", + "tags": [], + "label": "application", + "description": [], + "signature": [ + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxApplicationService", + "text": "SharedUxApplicationService" + } + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices.docLinks", + "type": "Object", + "tags": [], + "label": "docLinks", + "description": [], + "signature": [ + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxDocLinksService", + "text": "SharedUxDocLinksService" + } + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices.editors", + "type": "Object", + "tags": [], + "label": "editors", + "description": [], + "signature": [ + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxEditorsService", + "text": "SharedUxEditorsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices.http", + "type": "Object", + "tags": [], + "label": "http", + "description": [], + "signature": [ + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxHttpService", + "text": "SharedUxHttpService" + } + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices.permissions", + "type": "Object", + "tags": [], + "label": "permissions", + "description": [], + "signature": [ + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxUserPermissionsService", + "text": "SharedUxUserPermissionsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServices.platform", + "type": "Object", + "tags": [], + "label": "platform", + "description": [], + "signature": [ + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxPlatformService", + "text": "SharedUxPlatformService" + } + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxUserPermissionsService", + "type": "Interface", + "tags": [], + "label": "SharedUxUserPermissionsService", + "description": [ + "\nA service providing permissions information, typically for the current user." + ], + "path": "packages/kbn-shared-ux-services/src/services/permissions.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxUserPermissionsService.canCreateNewDataView", + "type": "boolean", + "tags": [], + "label": "canCreateNewDataView", + "description": [ + "True if the user has permission to create a new Data View, false otherwise." + ], + "path": "packages/kbn-shared-ux-services/src/services/permissions.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxUserPermissionsService.canAccessFleet", + "type": "boolean", + "tags": [], + "label": "canAccessFleet", + "description": [], + "path": "packages/kbn-shared-ux-services/src/services/permissions.ts", + "deprecated": false + } + ], + "initialIsOpen": false + } + ], + "enums": [], + "misc": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.ServiceFactory", + "type": "Type", + "tags": [], + "label": "ServiceFactory", + "description": [ + "\nA factory function for creating one or more services.\n\nThe `S` generic determines the shape of the API being produced.\nThe `Parameters` generic determines what parameters are expected to\ncreate the service." + ], + "signature": [ + "(params: Parameters) => S" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.ServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServicesContext", + "type": "Type", + "tags": [], + "label": "SharedUxServicesContext", + "description": [ + "\nA type representing a component that provides the `SharedUxServices` through a\nReact Context." + ], + "signature": [ + "React.FunctionComponent<{}>" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServicesContext.$1", + "type": "CompoundType", + "tags": [], + "label": "props", + "description": [], + "signature": [ + "P & { children?: React.ReactNode; }" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.SharedUxServicesContext.$2", + "type": "Any", + "tags": [], + "label": "context", + "description": [], + "signature": [ + "any" + ], + "path": "node_modules/@types/react/index.d.ts", + "deprecated": false + } + ], + "initialIsOpen": false + } + ], + "objects": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories", + "type": "Object", + "tags": [], + "label": "mockServiceFactories", + "description": [ + "\nA collection of mock Service Factories." + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.applicationServiceFactory", + "type": "Function", + "tags": [], + "label": "applicationServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxApplicationService", + "text": "SharedUxApplicationService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.applicationServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.docLinksServiceFactory", + "type": "Function", + "tags": [], + "label": "docLinksServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxDocLinksService", + "text": "SharedUxDocLinksService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.docLinksServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.editorsServiceFactory", + "type": "Function", + "tags": [], + "label": "editorsServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxEditorsService", + "text": "SharedUxEditorsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.editorsServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.httpServiceFactory", + "type": "Function", + "tags": [], + "label": "httpServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxHttpService", + "text": "SharedUxHttpService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.httpServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.platformServiceFactory", + "type": "Function", + "tags": [], + "label": "platformServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxPlatformService", + "text": "SharedUxPlatformService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.platformServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.userPermissionsServiceFactory", + "type": "Function", + "tags": [], + "label": "userPermissionsServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxUserPermissionsService", + "text": "SharedUxUserPermissionsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/mock/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.mockServiceFactories.userPermissionsServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories", + "type": "Object", + "tags": [], + "label": "stubServiceFactories", + "description": [ + "\nA collection of stubbed service factories." + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.applicationServiceFactory", + "type": "Function", + "tags": [], + "label": "applicationServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxApplicationService", + "text": "SharedUxApplicationService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.applicationServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.docLinksServiceFactory", + "type": "Function", + "tags": [], + "label": "docLinksServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxDocLinksService", + "text": "SharedUxDocLinksService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.docLinksServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.editorsServiceFactory", + "type": "Function", + "tags": [], + "label": "editorsServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxEditorsService", + "text": "SharedUxEditorsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.editorsServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.httpServiceFactory", + "type": "Function", + "tags": [], + "label": "httpServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxHttpService", + "text": "SharedUxHttpService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.httpServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.platformServiceFactory", + "type": "Function", + "tags": [], + "label": "platformServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxPlatformService", + "text": "SharedUxPlatformService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.platformServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + }, + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.userPermissionsServiceFactory", + "type": "Function", + "tags": [], + "label": "userPermissionsServiceFactory", + "description": [], + "signature": [ + "(params: void) => ", + { + "pluginId": "@kbn/shared-ux-services", + "scope": "common", + "docId": "kibKbnSharedUxServicesPluginApi", + "section": "def-common.SharedUxUserPermissionsService", + "text": "SharedUxUserPermissionsService" + } + ], + "path": "packages/kbn-shared-ux-services/src/services/stub/index.ts", + "deprecated": false, + "returnComment": [], + "children": [ + { + "parentPluginId": "@kbn/shared-ux-services", + "id": "def-common.stubServiceFactories.userPermissionsServiceFactory.$1", + "type": "Uncategorized", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "Parameters" + ], + "path": "packages/kbn-shared-ux-services/src/types.ts", + "deprecated": false + } + ] + } + ], + "initialIsOpen": false + } + ] + } +} \ No newline at end of file diff --git a/api_docs/kbn_shared_ux_services.mdx b/api_docs/kbn_shared_ux_services.mdx new file mode 100644 index 0000000000000..4bb6c71c93903 --- /dev/null +++ b/api_docs/kbn_shared_ux_services.mdx @@ -0,0 +1,36 @@ +--- +id: kibKbnSharedUxServicesPluginApi +slug: /kibana-dev-docs/api/kbn-shared-ux-services +title: "@kbn/shared-ux-services" +image: https://source.unsplash.com/400x175/?github +summary: API docs for the @kbn/shared-ux-services plugin +date: 2022-03-28 +tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-services'] +warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. +--- +import kbnSharedUxServicesObj from './kbn_shared_ux_services.devdocs.json'; + + + +Contact [Owner missing] for questions regarding this plugin. + +**Code health stats** + +| Public API count | Any count | Items lacking comments | Missing exports | +|-------------------|-----------|------------------------|-----------------| +| 67 | 0 | 43 | 0 | + +## Common + +### Objects + + +### Functions + + +### Interfaces + + +### Consts, variables and types + + diff --git a/api_docs/kbn_shared_ux_storybook.devdocs.json b/api_docs/kbn_shared_ux_storybook.devdocs.json new file mode 100644 index 0000000000000..8904597032cd4 --- /dev/null +++ b/api_docs/kbn_shared_ux_storybook.devdocs.json @@ -0,0 +1,225 @@ +{ + "id": "@kbn/shared-ux-storybook", + "client": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "server": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "common": { + "classes": [], + "functions": [ + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.applicationServiceFactory", + "type": "Function", + "tags": [], + "label": "applicationServiceFactory", + "description": [ + "\nA factory function for creating for creating a storybook implementation of `SharedUXApplicationService`." + ], + "signature": [ + "() => { navigateToUrl: () => Promise; currentAppId$: ", + "BehaviorSubject", + "; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/application.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.docLinksServiceFactory", + "type": "Function", + "tags": [], + "label": "docLinksServiceFactory", + "description": [ + "\nA factory function for creating a Storybook implementation of `SharedUxDocLinksService`." + ], + "signature": [ + "() => { dataViewsDocLink: string; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/doc_links.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.editorsServiceFactory", + "type": "Function", + "tags": [], + "label": "editorsServiceFactory", + "description": [ + "\nA factory function for creating a Storybook implementation of `SharedUxEditorsService`." + ], + "signature": [ + "() => { openDataViewEditor: (options: DataViewEditorOptions) => () => void; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/editors.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.httpServiceFactory", + "type": "Function", + "tags": [], + "label": "httpServiceFactory", + "description": [ + "\nA factory function for creating a Storybook-based implementation of `SharedUXHttpService`." + ], + "signature": [ + "() => { addBasePath: (url: string) => string; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/http.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.platformServiceFactory", + "type": "Function", + "tags": [], + "label": "platformServiceFactory", + "description": [ + "\nA factory function for creating a Storybook implementation of `SharedUxPlatformService`." + ], + "signature": [ + "() => { setIsFullscreen: ", + "HandlerFunction", + "; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/platform.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.servicesDecorator", + "type": "Function", + "tags": [], + "label": "servicesDecorator", + "description": [ + "\nA Storybook decorator that provides the Shared UX `ServicesProvider` with Storybook-specific\nimplementations to stories." + ], + "signature": [ + "(storyFn: ", + "PartialStoryFn", + "<", + "StoryFnReactReturnType", + ">) => JSX.Element" + ], + "path": "packages/kbn-shared-ux-storybook/src/decorators.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.servicesDecorator.$1", + "type": "Function", + "tags": [], + "label": "storyFn", + "description": [], + "signature": [ + "PartialStoryFn", + "<", + "StoryFnReactReturnType", + ">" + ], + "path": "packages/kbn-shared-ux-storybook/src/decorators.tsx", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.servicesFactory", + "type": "Function", + "tags": [], + "label": "servicesFactory", + "description": [ + "\nA factory function for creating a Storybook implementation of `SharedUxServices`." + ], + "signature": [ + "(params: {}) => { application: ", + "SharedUxApplicationService", + "; docLinks: ", + "SharedUxDocLinksService", + "; editors: ", + "SharedUxEditorsService", + "; http: ", + "SharedUxHttpService", + "; permissions: ", + "SharedUxUserPermissionsService", + "; platform: ", + "SharedUxPlatformService", + "; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.servicesFactory.$1", + "type": "Object", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "{}" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/index.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-storybook", + "id": "def-common.userPermissionsServiceFactory", + "type": "Function", + "tags": [], + "label": "userPermissionsServiceFactory", + "description": [ + "\nA factory function for creating a Storybook implementation of `SharedUxUserPermissionsService`." + ], + "signature": [ + "() => { canCreateNewDataView: true; canAccessFleet: true; }" + ], + "path": "packages/kbn-shared-ux-storybook/src/services/permissions.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + } + ], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + } +} \ No newline at end of file diff --git a/api_docs/kbn_shared_ux_storybook.mdx b/api_docs/kbn_shared_ux_storybook.mdx new file mode 100644 index 0000000000000..77b1cdff6f792 --- /dev/null +++ b/api_docs/kbn_shared_ux_storybook.mdx @@ -0,0 +1,27 @@ +--- +id: kibKbnSharedUxStorybookPluginApi +slug: /kibana-dev-docs/api/kbn-shared-ux-storybook +title: "@kbn/shared-ux-storybook" +image: https://source.unsplash.com/400x175/?github +summary: API docs for the @kbn/shared-ux-storybook plugin +date: 2022-03-28 +tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-storybook'] +warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. +--- +import kbnSharedUxStorybookObj from './kbn_shared_ux_storybook.devdocs.json'; + + + +Contact [Owner missing] for questions regarding this plugin. + +**Code health stats** + +| Public API count | Any count | Items lacking comments | Missing exports | +|-------------------|-----------|------------------------|-----------------| +| 10 | 0 | 2 | 0 | + +## Common + +### Functions + + diff --git a/api_docs/kbn_shared_ux_utility.devdocs.json b/api_docs/kbn_shared_ux_utility.devdocs.json new file mode 100644 index 0000000000000..09a0ce6dedea5 --- /dev/null +++ b/api_docs/kbn_shared_ux_utility.devdocs.json @@ -0,0 +1,177 @@ +{ + "id": "@kbn/shared-ux-utility", + "client": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "server": { + "classes": [], + "functions": [], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + }, + "common": { + "classes": [], + "functions": [ + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.Fallback", + "type": "Function", + "tags": [], + "label": "Fallback", + "description": [ + "\nA simple implementation of `React.Suspense.fallback` that renders a loading spinner." + ], + "signature": [ + "() => JSX.Element" + ], + "path": "packages/kbn-shared-ux-utility/src/fallback.tsx", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.getClosestLink", + "type": "Function", + "tags": [], + "label": "getClosestLink", + "description": [ + "\nReturns the closest anchor (``) element in the element parents (self included) up\nto the given container (excluded), or undefined if none is found." + ], + "signature": [ + "(element: HTMLElement | null | undefined, container?: HTMLElement | undefined) => HTMLAnchorElement | undefined" + ], + "path": "packages/kbn-shared-ux-utility/src/utils.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.getClosestLink.$1", + "type": "CompoundType", + "tags": [], + "label": "element", + "description": [], + "signature": [ + "HTMLElement | null | undefined" + ], + "path": "packages/kbn-shared-ux-utility/src/utils.ts", + "deprecated": false, + "isRequired": false + }, + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.getClosestLink.$2", + "type": "Object", + "tags": [], + "label": "container", + "description": [], + "signature": [ + "HTMLElement | undefined" + ], + "path": "packages/kbn-shared-ux-utility/src/utils.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.hasActiveModifierKey", + "type": "Function", + "tags": [], + "label": "hasActiveModifierKey", + "description": [ + "\nReturns true if any modifier key is active on the event, false otherwise." + ], + "signature": [ + "(event: React.MouseEvent) => boolean" + ], + "path": "packages/kbn-shared-ux-utility/src/utils.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.hasActiveModifierKey.$1", + "type": "Object", + "tags": [], + "label": "event", + "description": [], + "signature": [ + "React.MouseEvent" + ], + "path": "packages/kbn-shared-ux-utility/src/utils.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.withSuspense", + "type": "Function", + "tags": [], + "label": "withSuspense", + "description": [ + "\nA HOC which supplies React.Suspense with a fallback component, and a `EuiErrorBoundary` to contain errors." + ], + "signature": [ + "

(Component: React.ComponentType

, fallback?: React.ReactElement> | null) => React.ForwardRefExoticComponent & React.RefAttributes>" + ], + "path": "packages/kbn-shared-ux-utility/src/with_suspense.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.withSuspense.$1", + "type": "CompoundType", + "tags": [], + "label": "Component", + "description": [ + "A component deferred by `React.lazy`" + ], + "signature": [ + "React.ComponentType

" + ], + "path": "packages/kbn-shared-ux-utility/src/with_suspense.tsx", + "deprecated": false, + "isRequired": true + }, + { + "parentPluginId": "@kbn/shared-ux-utility", + "id": "def-common.withSuspense.$2", + "type": "CompoundType", + "tags": [], + "label": "fallback", + "description": [ + "A fallback component to render while things load; default is `Fallback` from SharedUX." + ], + "signature": [ + "React.ReactElement> | null" + ], + "path": "packages/kbn-shared-ux-utility/src/with_suspense.tsx", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [], + "initialIsOpen": false + } + ], + "interfaces": [], + "enums": [], + "misc": [], + "objects": [] + } +} \ No newline at end of file diff --git a/api_docs/kbn_shared_ux_utility.mdx b/api_docs/kbn_shared_ux_utility.mdx new file mode 100644 index 0000000000000..1fecde17298f4 --- /dev/null +++ b/api_docs/kbn_shared_ux_utility.mdx @@ -0,0 +1,27 @@ +--- +id: kibKbnSharedUxUtilityPluginApi +slug: /kibana-dev-docs/api/kbn-shared-ux-utility +title: "@kbn/shared-ux-utility" +image: https://source.unsplash.com/400x175/?github +summary: API docs for the @kbn/shared-ux-utility plugin +date: 2022-03-28 +tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/shared-ux-utility'] +warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. +--- +import kbnSharedUxUtilityObj from './kbn_shared_ux_utility.devdocs.json'; + + + +Contact [Owner missing] for questions regarding this plugin. + +**Code health stats** + +| Public API count | Any count | Items lacking comments | Missing exports | +|-------------------|-----------|------------------------|-----------------| +| 9 | 0 | 3 | 0 | + +## Common + +### Functions + + diff --git a/api_docs/kbn_std.mdx b/api_docs/kbn_std.mdx index 4a1399f881199..4ab53cd7f51a8 100644 --- a/api_docs/kbn_std.mdx +++ b/api_docs/kbn_std.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-std title: "@kbn/std" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/std plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/std'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_storybook.mdx b/api_docs/kbn_storybook.mdx index b1a53c30d5ab2..eea5a68825cec 100644 --- a/api_docs/kbn_storybook.mdx +++ b/api_docs/kbn_storybook.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-storybook title: "@kbn/storybook" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/storybook plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/storybook'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_telemetry_tools.mdx b/api_docs/kbn_telemetry_tools.mdx index facf413cece8e..e96ae96c8f655 100644 --- a/api_docs/kbn_telemetry_tools.mdx +++ b/api_docs/kbn_telemetry_tools.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-telemetry-tools title: "@kbn/telemetry-tools" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/telemetry-tools plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/telemetry-tools'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_test.mdx b/api_docs/kbn_test.mdx index 78b8a6981b8d3..dd0a8212b5b9a 100644 --- a/api_docs/kbn_test.mdx +++ b/api_docs/kbn_test.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-test title: "@kbn/test" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/test plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/test'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_test_jest_helpers.mdx b/api_docs/kbn_test_jest_helpers.mdx index a1b7f3bd45fe9..f131a92f41b9f 100644 --- a/api_docs/kbn_test_jest_helpers.mdx +++ b/api_docs/kbn_test_jest_helpers.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-test-jest-helpers title: "@kbn/test-jest-helpers" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/test-jest-helpers plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/test-jest-helpers'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_type_summarizer.mdx b/api_docs/kbn_type_summarizer.mdx index 762c5411ab821..15191f8cf6640 100644 --- a/api_docs/kbn_type_summarizer.mdx +++ b/api_docs/kbn_type_summarizer.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-type-summarizer title: "@kbn/type-summarizer" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/type-summarizer plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/type-summarizer'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_typed_react_router_config.mdx b/api_docs/kbn_typed_react_router_config.mdx index 87a0fc5a32084..18a40d6fe9c84 100644 --- a/api_docs/kbn_typed_react_router_config.mdx +++ b/api_docs/kbn_typed_react_router_config.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-typed-react-router-config title: "@kbn/typed-react-router-config" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/typed-react-router-config plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/typed-react-router-config'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_ui_theme.devdocs.json b/api_docs/kbn_ui_theme.devdocs.json index 48f661a45c775..c4272d206e8bd 100644 --- a/api_docs/kbn_ui_theme.devdocs.json +++ b/api_docs/kbn_ui_theme.devdocs.json @@ -52,7 +52,7 @@ "label": "Theme", "description": [], "signature": [ - "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" + "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiLoadingSpinnerSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" ], "path": "packages/kbn-ui-theme/src/theme.ts", "deprecated": false, @@ -82,7 +82,7 @@ "label": "euiDarkVars", "description": [], "signature": [ - "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" + "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiLoadingSpinnerSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" ], "path": "packages/kbn-ui-theme/src/theme.ts", "deprecated": false, @@ -96,7 +96,7 @@ "label": "euiLightVars", "description": [], "signature": [ - "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" + "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiLoadingSpinnerSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" ], "path": "packages/kbn-ui-theme/src/theme.ts", "deprecated": false, @@ -112,7 +112,7 @@ "\nEUI Theme vars that automatically adjust to light/dark theme" ], "signature": [ - "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" + "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiLoadingSpinnerSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" ], "path": "packages/kbn-ui-theme/src/theme.ts", "deprecated": false, diff --git a/api_docs/kbn_ui_theme.mdx b/api_docs/kbn_ui_theme.mdx index cd20c8c3e249b..f1279e3cafe37 100644 --- a/api_docs/kbn_ui_theme.mdx +++ b/api_docs/kbn_ui_theme.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-ui-theme title: "@kbn/ui-theme" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/ui-theme plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/ui-theme'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_utility_types.mdx b/api_docs/kbn_utility_types.mdx index f541ca219791b..8f705b6e81cdd 100644 --- a/api_docs/kbn_utility_types.mdx +++ b/api_docs/kbn_utility_types.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-utility-types title: "@kbn/utility-types" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/utility-types plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/utility-types'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kbn_utils.mdx b/api_docs/kbn_utils.mdx index dcc983235d211..1781ed53aff90 100644 --- a/api_docs/kbn_utils.mdx +++ b/api_docs/kbn_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kbn-utils title: "@kbn/utils" image: https://source.unsplash.com/400x175/?github summary: API docs for the @kbn/utils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', '@kbn/utils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kibana_overview.mdx b/api_docs/kibana_overview.mdx index c0aa1cde1c4c1..be09d0dd97ec4 100644 --- a/api_docs/kibana_overview.mdx +++ b/api_docs/kibana_overview.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kibanaOverview title: "kibanaOverview" image: https://source.unsplash.com/400x175/?github summary: API docs for the kibanaOverview plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kibanaOverview'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kibana_react.devdocs.json b/api_docs/kibana_react.devdocs.json index 58de4a6f21bcf..74f669998457e 100644 --- a/api_docs/kibana_react.devdocs.json +++ b/api_docs/kibana_react.devdocs.json @@ -1454,7 +1454,10 @@ "parentPluginId": "kibanaReact", "id": "def-public.RedirectAppLinks", "type": "Function", - "tags": [], + "tags": [ + "deprecated", + "kbn-shared-ux-components" + ], "label": "RedirectAppLinks", "description": [ "\nUtility component that will intercept click events on children anchor (``) elements to call\n`application.navigateToUrl` with the link's href. This will trigger SPA friendly navigation\nwhen the link points to a valid Kibana app.\n" @@ -1463,7 +1466,361 @@ "({ application, children, className, ...otherProps }: React.PropsWithChildren) => JSX.Element" ], "path": "src/plugins/kibana_react/public/app_links/redirect_app_link.tsx", - "deprecated": false, + "deprecated": true, + "references": [ + { + "plugin": "esUiShared", + "path": "src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx" + }, + { + "plugin": "esUiShared", + "path": "src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx" + }, + { + "plugin": "esUiShared", + "path": "src/plugins/es_ui_shared/public/components/view_api_request_flyout/view_api_request_flyout.tsx" + }, + { + "plugin": "home", + "path": "src/plugins/home/public/application/application.tsx" + }, + { + "plugin": "home", + "path": "src/plugins/home/public/application/application.tsx" + }, + { + "plugin": "home", + "path": "src/plugins/home/public/application/application.tsx" + }, + { + "plugin": "spaces", + "path": "x-pack/plugins/spaces/public/management/spaces_management_app.tsx" + }, + { + "plugin": "spaces", + "path": "x-pack/plugins/spaces/public/management/spaces_management_app.tsx" + }, + { + "plugin": "spaces", + "path": "x-pack/plugins/spaces/public/management/spaces_management_app.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/components/home_integration/tutorial_directory_header_link.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/components/home_integration/tutorial_directory_header_link.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/components/home_integration/tutorial_directory_header_link.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/components/custom_assets_accordion.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/components/custom_assets_accordion.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/components/custom_assets_accordion.tsx" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/public/visualize_app/utils/get_table_columns.tsx" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/public/visualize_app/utils/get_table_columns.tsx" + }, + { + "plugin": "visualizations", + "path": "src/plugins/visualizations/public/visualize_app/utils/get_table_columns.tsx" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx" + }, + { + "plugin": "observability", + "path": "x-pack/plugins/observability/public/application/index.tsx" + }, + { + "plugin": "observability", + "path": "x-pack/plugins/observability/public/application/index.tsx" + }, + { + "plugin": "observability", + "path": "x-pack/plugins/observability/public/application/index.tsx" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/public/search/sessions_mgmt/lib/get_columns.tsx" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/public/search/sessions_mgmt/lib/get_columns.tsx" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/public/search/sessions_mgmt/lib/get_columns.tsx" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/public/search/ui/connected_search_session_indicator/connected_search_session_indicator.tsx" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/public/search/ui/connected_search_session_indicator/connected_search_session_indicator.tsx" + }, + { + "plugin": "dataEnhanced", + "path": "x-pack/plugins/data_enhanced/public/search/ui/connected_search_session_indicator/connected_search_session_indicator.tsx" + }, + { + "plugin": "ml", + "path": "x-pack/plugins/ml/public/application/components/ml_page/ml_page.tsx" + }, + { + "plugin": "ml", + "path": "x-pack/plugins/ml/public/application/components/ml_page/ml_page.tsx" + }, + { + "plugin": "ml", + "path": "x-pack/plugins/ml/public/application/components/ml_page/ml_page.tsx" + }, + { + "plugin": "ml", + "path": "x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx" + }, + { + "plugin": "ml", + "path": "x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx" + }, + { + "plugin": "ml", + "path": "x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/fleet/sections/agents/agent_details_page/components/agent_logs/agent_logs.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/fleet/sections/agents/agent_details_page/components/agent_logs/agent_logs.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/fleet/sections/agents/agent_details_page/components/agent_logs/agent_logs.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/integrations/app.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/integrations/app.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/integrations/app.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/fleet/app.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/fleet/app.tsx" + }, + { + "plugin": "fleet", + "path": "x-pack/plugins/fleet/public/applications/fleet/app.tsx" + }, + { + "plugin": "apm", + "path": "x-pack/plugins/apm/public/components/routing/app_root.tsx" + }, + { + "plugin": "apm", + "path": "x-pack/plugins/apm/public/components/routing/app_root.tsx" + }, + { + "plugin": "apm", + "path": "x-pack/plugins/apm/public/components/routing/app_root.tsx" + }, + { + "plugin": "cloudSecurityPosture", + "path": "x-pack/plugins/cloud_security_posture/public/application/app.tsx" + }, + { + "plugin": "cloudSecurityPosture", + "path": "x-pack/plugins/cloud_security_posture/public/application/app.tsx" + }, + { + "plugin": "cloudSecurityPosture", + "path": "x-pack/plugins/cloud_security_posture/public/application/app.tsx" + }, + { + "plugin": "indexLifecycleManagement", + "path": "x-pack/plugins/index_lifecycle_management/public/shared_imports.ts" + }, + { + "plugin": "indexLifecycleManagement", + "path": "x-pack/plugins/index_lifecycle_management/public/application/index.tsx" + }, + { + "plugin": "indexLifecycleManagement", + "path": "x-pack/plugins/index_lifecycle_management/public/application/index.tsx" + }, + { + "plugin": "indexLifecycleManagement", + "path": "x-pack/plugins/index_lifecycle_management/public/application/index.tsx" + }, + { + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/public/shared_imports.ts" + }, + { + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/public/application/app.tsx" + }, + { + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/public/application/app.tsx" + }, + { + "plugin": "upgradeAssistant", + "path": "x-pack/plugins/upgrade_assistant/public/application/app.tsx" + }, + { + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/lib/alert_types/alert_messages.tsx" + }, + { + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/lib/alert_types/alert_messages.tsx" + }, + { + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/lib/alert_types/alert_messages.tsx" + }, + { + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/apps/uptime_app.tsx" + }, + { + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/apps/uptime_app.tsx" + }, + { + "plugin": "uptime", + "path": "x-pack/plugins/uptime/public/apps/uptime_app.tsx" + }, + { + "plugin": "ux", + "path": "x-pack/plugins/ux/public/application/ux_app.tsx" + }, + { + "plugin": "ux", + "path": "x-pack/plugins/ux/public/application/ux_app.tsx" + }, + { + "plugin": "ux", + "path": "x-pack/plugins/ux/public/application/ux_app.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/add_data/add_data.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/add_data/add_data.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/add_data/add_data.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/manage_data/manage_data.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/manage_data/manage_data.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/manage_data/manage_data.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/overview/overview.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/overview/overview.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/overview/overview.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/overview/overview.tsx" + }, + { + "plugin": "kibanaOverview", + "path": "src/plugins/kibana_overview/public/components/overview/overview.tsx" + }, + { + "plugin": "savedObjectsManagement", + "path": "src/plugins/saved_objects_management/public/management_section/saved_objects_edition_page.tsx" + }, + { + "plugin": "savedObjectsManagement", + "path": "src/plugins/saved_objects_management/public/management_section/saved_objects_edition_page.tsx" + }, + { + "plugin": "savedObjectsManagement", + "path": "src/plugins/saved_objects_management/public/management_section/saved_objects_edition_page.tsx" + }, + { + "plugin": "savedObjectsManagement", + "path": "src/plugins/saved_objects_management/public/management_section/objects_table/saved_objects_table.tsx" + }, + { + "plugin": "savedObjectsManagement", + "path": "src/plugins/saved_objects_management/public/management_section/objects_table/saved_objects_table.tsx" + }, + { + "plugin": "savedObjectsManagement", + "path": "src/plugins/saved_objects_management/public/management_section/objects_table/saved_objects_table.tsx" + }, + { + "plugin": "home", + "path": "src/plugins/home/public/application/components/add_data/add_data.tsx" + }, + { + "plugin": "home", + "path": "src/plugins/home/public/application/components/add_data/add_data.tsx" + }, + { + "plugin": "home", + "path": "src/plugins/home/public/application/components/add_data/add_data.tsx" + } + ], "children": [ { "parentPluginId": "kibanaReact", @@ -4428,7 +4785,7 @@ "label": "eui", "description": [], "signature": [ - "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" + "{ paddingSizes: { xs: string; s: string; m: string; l: string; xl: string; }; avatarSizing: { s: { size: string; 'font-size': string; }; m: { size: string; 'font-size': string; }; l: { size: string; 'font-size': string; }; xl: { size: string; 'font-size': string; }; }; euiBadgeGroupGutterTypes: { gutterExtraSmall: string; gutterSmall: string; }; euiBreadcrumbSpacing: string; euiBreadcrumbTruncateWidth: string; euiButtonEmptyTypes: { primary: string; danger: string; disabled: string; ghost: string; text: string; success: string; warning: string; }; euiCallOutTypes: { primary: string; success: string; warning: string; danger: string; }; euiCardSpacing: string; euiCardBottomNodeHeight: string; euiCardSelectButtonBorders: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardSelectButtonBackgrounds: { text: string; primary: string; success: string; danger: string; ghost: string; }; euiCardPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCheckableCardPadding: string; euiCodeBlockPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiCollapsibleNavGroupLightBackgroundColor: string; euiCollapsibleNavGroupDarkBackgroundColor: string; euiCollapsibleNavGroupDarkHighContrastColor: string; euiColorPickerValueRange0: string; euiColorPickerValueRange1: string; euiColorPickerSaturationRange0: string; euiColorPickerSaturationRange1: string; euiColorPickerIndicatorSize: string; euiColorPickerWidth: string; euiColorPaletteDisplaySizes: { sizeExtraSmall: string; sizeSmall: string; sizeMedium: string; }; euiContextMenuWidth: string; euiControlBarBackground: string; euiControlBarText: string; euiControlBarBorderColor: string; euiControlBarInitialHeight: string; euiControlBarMaxHeight: string; euiControlBarHeights: { s: string; m: string; l: string; }; euiDataGridPrefix: string; euiDataGridStyles: string; euiZDataGrid: number; euiZHeaderBelowDataGrid: number; euiZDataGridCellPopover: number; euiDataGridColumnResizerWidth: string; euiDataGridPopoverMaxHeight: string; euiDataGridCellPaddingS: string; euiDataGridCellPaddingM: string; euiDataGridCellPaddingL: string; euiDataGridVerticalBorder: string; euiSuperDatePickerWidth: string; euiSuperDatePickerButtonWidth: string; euiDragAndDropSpacing: { s: string; m: string; l: string; }; euiExpressionColors: { subdued: string; primary: string; success: string; warning: string; danger: string; accent: string; }; euiFacetGutterSizes: { gutterNone: number; gutterSmall: string; gutterMedium: string; gutterLarge: string; }; gutterTypes: { gutterExtraSmall: string; gutterSmall: string; gutterMedium: string; gutterLarge: string; gutterExtraLarge: string; }; fractions: { fourths: { percentage: string; count: number; }; thirds: { percentage: string; count: number; }; halves: { percentage: string; count: number; }; single: { percentage: string; count: number; }; }; flyoutSizes: { small: { min: string; width: string; max: string; }; medium: { min: string; width: string; max: string; }; large: { min: string; width: string; max: string; }; }; euiFlyoutBorder: string; euiFlyoutPaddingModifiers: { paddingNone: number; paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiFilePickerTallHeight: string; euiRangeLevelColors: { primary: string; success: string; warning: string; danger: string; }; textareaResizing: { vertical: string; horizontal: string; both: string; none: string; }; euiHeaderLinksGutterSizes: { gutterXS: string; gutterS: string; gutterM: string; gutterL: string; }; ruleMargins: { marginXSmall: string; marginSmall: string; marginMedium: string; marginLarge: string; marginXLarge: string; marginXXLarge: string; }; euiIconLoadingOpacity: number; euiIconColors: { accent: string; danger: string; ghost: string; primary: string; success: string; subdued: string; text: string; warning: string; inherit: string; }; euiIconSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiKeyPadMenuSize: string; euiKeyPadMenuMarginSize: string; euiLinkColors: { subdued: string; primary: string; success: string; accent: string; warning: string; danger: string; text: string; ghost: string; }; euiListGroupItemHoverBackground: string; euiListGroupItemHoverBackgroundGhost: string; euiListGroupGutterTypes: { gutterSmall: string; gutterMedium: string; }; euiListGroupItemColorTypes: { primary: string; text: string; subdued: string; ghost: string; }; euiListGroupItemSizeTypes: { xSmall: string; small: string; medium: string; large: string; }; euiGradientStartStop: string; euiGradientMiddle: string; euiLoadingSpinnerSizes: { small: string; medium: string; large: string; xLarge: string; xxLarge: string; }; euiMarkdownEditorMinHeight: string; euiPopoverArrowSize: string; euiPopoverTranslateDistance: string; euiProgressSizes: { xs: string; s: string; m: string; l: string; }; euiProgressColors: { primary: string; success: string; warning: string; danger: string; accent: string; subdued: string; vis0: string; vis1: string; vis2: string; vis3: string; vis4: string; vis5: string; vis6: string; vis7: string; vis8: string; vis9: string; customColor: string; }; euiResizableButtonTransitionSpeed: string; euiResizableButtonSize: string; euiSelectableListItemBorder: string; euiSelectableListItemPadding: string; euiSelectableTemplateSitewideTypes: { application: { color: string; 'font-weight': number; }; deployment: { color: string; 'font-weight': number; }; article: { color: string; 'font-weight': number; }; case: { color: string; 'font-weight': number; }; platform: { color: string; 'font-weight': number; }; }; euiSideNavEmphasizedBackgroundColor: string; euiSideNavRootTextcolor: string; euiSideNavBranchTextcolor: string; euiSideNavSelectedTextcolor: string; euiSideNavDisabledTextcolor: string; spacerSizes: { xs: string; s: string; m: string; l: string; xl: string; xxl: string; }; euiStepNumberSize: string; euiStepNumberSmallSize: string; euiStepNumberMargin: string; euiStepStatusColorsToFade: { warning: string; danger: string; disabled: string; incomplete: string; }; euiSuggestItemColors: { tint0: string; tint1: string; tint2: string; tint3: string; tint4: string; tint5: string; tint6: string; tint7: string; tint8: string; tint9: string; tint10: string; }; euiTableCellContentPadding: string; euiTableCellContentPaddingCompressed: string; euiTableCellCheckboxWidth: string; euiTableActionsAreaWidth: string; euiTableHoverColor: string; euiTableSelectedColor: string; euiTableHoverSelectedColor: string; euiTableActionsBorderColor: string; euiTableHoverClickableColor: string; euiTableFocusClickableColor: string; euiTextColors: { default: string; subdued: string; success: string; accent: string; warning: string; danger: string; ghost: string; inherit: string; }; euiTextConstrainedMaxWidth: string; euiToastWidth: string; euiToastTypes: { primary: string; success: string; warning: string; danger: string; }; euiTokenGrayColor: string; euiTokenTypes: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; gray: { graphic: string; behindText: string; }; }; euiTokenTypeKeys: string; euiContrastRatioText: number; euiContrastRatioGraphic: number; euiContrastRatioDisabled: number; euiAnimSlightBounce: string; euiAnimSlightResistance: string; euiAnimSpeedExtraFast: string; euiAnimSpeedFast: string; euiAnimSpeedNormal: string; euiAnimSpeedSlow: string; euiAnimSpeedExtraSlow: string; euiBorderWidthThin: string; euiBorderWidthThick: string; euiBorderColor: string; euiBorderRadius: string; euiBorderRadiusSmall: string; euiBorderThick: string; euiBorderThin: string; euiBorderEditable: string; euiButtonHeight: string; euiButtonHeightSmall: string; euiButtonHeightXSmall: string; euiButtonColorDisabled: string; euiButtonColorDisabledText: string; euiButtonColorGhostDisabled: string; euiButtonTypes: { primary: string; accent: string; success: string; warning: string; danger: string; subdued: string; ghost: string; text: string; }; euiCodeBlockBackgroundColor: string; euiCodeBlockColor: string; euiCodeBlockSelectedBackgroundColor: string; euiCodeBlockCommentColor: string; euiCodeBlockSelectorTagColor: string; euiCodeBlockStringColor: string; euiCodeBlockTagColor: string; euiCodeBlockNameColor: string; euiCodeBlockNumberColor: string; euiCodeBlockKeywordColor: string; euiCodeBlockFunctionTitleColor: string; euiCodeBlockTypeColor: string; euiCodeBlockAttributeColor: string; euiCodeBlockSymbolColor: string; euiCodeBlockParamsColor: string; euiCodeBlockMetaColor: string; euiCodeBlockTitleColor: string; euiCodeBlockSectionColor: string; euiCodeBlockAdditionColor: string; euiCodeBlockDeletionColor: string; euiCodeBlockSelectorClassColor: string; euiCodeBlockSelectorIdColor: string; euiPaletteColorBlind: { euiColorVis0: { graphic: string; behindText: string; }; euiColorVis1: { graphic: string; behindText: string; }; euiColorVis2: { graphic: string; behindText: string; }; euiColorVis3: { graphic: string; behindText: string; }; euiColorVis4: { graphic: string; behindText: string; }; euiColorVis5: { graphic: string; behindText: string; }; euiColorVis6: { graphic: string; behindText: string; }; euiColorVis7: { graphic: string; behindText: string; }; euiColorVis8: { graphic: string; behindText: string; }; euiColorVis9: { graphic: string; behindText: string; }; }; euiPaletteColorBlindKeys: string; euiColorVis0: string; euiColorVis1: string; euiColorVis2: string; euiColorVis3: string; euiColorVis4: string; euiColorVis5: string; euiColorVis6: string; euiColorVis7: string; euiColorVis8: string; euiColorVis9: string; euiColorVis0_behindText: string; euiColorVis1_behindText: string; euiColorVis2_behindText: string; euiColorVis3_behindText: string; euiColorVis4_behindText: string; euiColorVis5_behindText: string; euiColorVis6_behindText: string; euiColorVis7_behindText: string; euiColorVis8_behindText: string; euiColorVis9_behindText: string; euiFontWeightLight: number; euiFontWeightRegular: number; euiFontWeightMedium: number; euiFontWeightSemiBold: number; euiFontWeightBold: number; euiCodeFontWeightRegular: number; euiCodeFontWeightBold: number; euiFormMaxWidth: string; euiFormControlHeight: string; euiFormControlCompressedHeight: string; euiFormControlPadding: string; euiFormControlCompressedPadding: string; euiFormControlBorderRadius: string; euiFormControlCompressedBorderRadius: string; euiRadioSize: string; euiCheckBoxSize: string; euiCheckboxBorderRadius: string; euiSwitchHeight: string; euiSwitchWidth: string; euiSwitchThumbSize: string; euiSwitchIconHeight: string; euiSwitchHeightCompressed: string; euiSwitchWidthCompressed: string; euiSwitchThumbSizeCompressed: string; euiSwitchHeightMini: string; euiSwitchWidthMini: string; euiSwitchThumbSizeMini: string; euiFormBackgroundColor: string; euiFormBackgroundDisabledColor: string; euiFormBackgroundReadOnlyColor: string; euiFormBorderOpaqueColor: string; euiFormBorderColor: string; euiFormBorderDisabledColor: string; euiFormCustomControlDisabledIconColor: string; euiFormCustomControlBorderColor: string; euiFormControlDisabledColor: string; euiFormControlBoxShadow: string; euiFormControlPlaceholderText: string; euiFormInputGroupLabelBackground: string; euiFormInputGroupBorder: string; euiSwitchOffColor: string; euiFormControlLayoutGroupInputHeight: string; euiFormControlLayoutGroupInputCompressedHeight: string; euiFormControlLayoutGroupInputCompressedBorderRadius: string; euiRangeTrackColor: string; euiRangeThumbRadius: string; euiRangeThumbHeight: string; euiRangeThumbWidth: string; euiRangeThumbBorderColor: string; euiRangeTrackWidth: string; euiRangeTrackHeight: string; euiRangeTrackBorderWidth: number; euiRangeTrackBorderColor: string; euiRangeTrackRadius: string; euiRangeDisabledOpacity: number; euiRangeHighlightHeight: string; euiHeaderBackgroundColor: string; euiHeaderDarkBackgroundColor: string; euiHeaderBorderColor: string; euiHeaderBreadcrumbColor: string; euiHeaderHeight: string; euiHeaderChildSize: string; euiHeaderHeightCompensation: string; euiPageDefaultMaxWidth: string; euiPageSidebarMinWidth: string; euiPanelPaddingModifiers: { paddingSmall: string; paddingMedium: string; paddingLarge: string; }; euiPanelBorderRadiusModifiers: { borderRadiusNone: number; borderRadiusMedium: string; }; euiPanelBackgroundColorModifiers: { transparent: string; plain: string; subdued: string; accent: string; primary: string; success: string; warning: string; danger: string; }; euiBreakpoints: { xs: number; s: string; m: string; l: string; xl: string; }; euiBreakpointKeys: string; euiShadowColor: string; euiShadowColorLarge: string; euiSize: string; euiSizeXS: string; euiSizeS: string; euiSizeM: string; euiSizeL: string; euiSizeXL: string; euiSizeXXL: string; euiButtonMinWidth: string; euiScrollBar: string; euiScrollBarCorner: string; euiScrollBarCornerThin: string; euiFocusRingColor: string; euiFocusRingAnimStartColor: string; euiFocusRingAnimStartSize: string; euiFocusRingAnimStartSizeLarge: string; euiFocusRingSizeLarge: string; euiFocusRingSize: string; euiFocusTransparency: number; euiFocusTransparencyPercent: string; euiFocusBackgroundColor: string; euiTooltipBackgroundColor: string; euiTooltipBorderColor: string; euiTooltipAnimations: { top: string; left: string; bottom: string; right: string; }; euiFontFamily: string; euiCodeFontFamily: string; euiFontFeatureSettings: string; euiTextScale: string; euiFontSize: string; euiFontSizeXS: string; euiFontSizeS: string; euiFontSizeM: string; euiFontSizeL: string; euiFontSizeXL: string; euiFontSizeXXL: string; euiLineHeight: number; euiBodyLineHeight: number; euiTitles: { xxxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xxs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; xs: { 'font-size': string; 'line-height': string; 'font-weight': number; }; s: { 'font-size': string; 'line-height': string; 'font-weight': number; }; m: { 'font-size': string; 'line-height': string; 'font-weight': number; }; l: { 'font-size': string; 'line-height': string; 'font-weight': number; }; }; euiZLevel0: number; euiZLevel1: number; euiZLevel2: number; euiZLevel3: number; euiZLevel4: number; euiZLevel5: number; euiZLevel6: number; euiZLevel7: number; euiZLevel8: number; euiZLevel9: number; euiZToastList: number; euiZModal: number; euiZMask: number; euiZNavigation: number; euiZContentMenu: number; euiZHeader: number; euiZFlyout: number; euiZMaskBelowHeader: number; euiZContent: number; euiColorGhost: string; euiColorInk: string; euiColorPrimary: string; euiColorAccent: string; euiColorSuccess: string; euiColorWarning: string; euiColorDanger: string; euiColorEmptyShade: string; euiColorLightestShade: string; euiColorLightShade: string; euiColorMediumShade: string; euiColorDarkShade: string; euiColorDarkestShade: string; euiColorFullShade: string; euiPageBackgroundColor: string; euiColorHighlight: string; euiTextColor: string; euiTitleColor: string; euiTextSubduedColor: string; euiColorDisabled: string; euiColorPrimaryText: string; euiColorSuccessText: string; euiColorAccentText: string; euiColorWarningText: string; euiColorDangerText: string; euiColorDisabledText: string; euiLinkColor: string; euiColorChartLines: string; euiColorChartBand: string; euiDatePickerCalendarWidth: string; euiDatePickerPadding: string; euiDatePickerGap: string; euiDatePickerCalendarColumns: number; euiDatePickerButtonSize: string; euiDatePickerMinControlWidth: string; euiDatePickerMaxControlWidth: string; euiButtonDefaultTransparency: number; euiButtonFontWeight: number; euiRangeHighlightColor: string; euiRangeThumbBackgroundColor: string; euiRangeTrackCompressedHeight: string; euiRangeHighlightCompressedHeight: string; euiRangeHeight: string; euiRangeCompressedHeight: string; euiStepStatusColors: { default: string; complete: string; warning: string; danger: string; }; }" ], "path": "src/plugins/kibana_react/common/eui_styled_components.tsx", "deprecated": false diff --git a/api_docs/kibana_react.mdx b/api_docs/kibana_react.mdx index 2fa182ff2a311..cacc37e34cc65 100644 --- a/api_docs/kibana_react.mdx +++ b/api_docs/kibana_react.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kibanaReact title: "kibanaReact" image: https://source.unsplash.com/400x175/?github summary: API docs for the kibanaReact plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kibanaReact'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/kibana_utils.mdx b/api_docs/kibana_utils.mdx index bac689f56b11c..11bf23492a84b 100644 --- a/api_docs/kibana_utils.mdx +++ b/api_docs/kibana_utils.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/kibanaUtils title: "kibanaUtils" image: https://source.unsplash.com/400x175/?github summary: API docs for the kibanaUtils plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'kibanaUtils'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/lens.devdocs.json b/api_docs/lens.devdocs.json index 3b82fc075430c..8fdad5c360c6d 100644 --- a/api_docs/lens.devdocs.json +++ b/api_docs/lens.devdocs.json @@ -63,8 +63,6 @@ "text": "CardinalityIndexPatternColumn" }, " extends ", - "FormattedIndexPatternColumn", - ",", { "pluginId": "lens", "scope": "public", @@ -88,6 +86,179 @@ ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/cardinality.tsx", "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.CardinalityIndexPatternColumn.params", + "type": "Object", + "tags": [], + "label": "params", + "description": [], + "signature": [ + "{ emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined" + ], + "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/cardinality.tsx", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI", + "type": "Interface", + "tags": [], + "label": "DatasourcePublicAPI", + "description": [ + "\nThis is an API provided to visualizations by the frame, which calls the publicAPI on the datasource" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.datasourceId", + "type": "string", + "tags": [], + "label": "datasourceId", + "description": [], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getTableSpec", + "type": "Function", + "tags": [], + "label": "getTableSpec", + "description": [], + "signature": [ + "() => { columnId: string; fields: string[]; }[]" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getOperationForColumnId", + "type": "Function", + "tags": [], + "label": "getOperationForColumnId", + "description": [], + "signature": [ + "(columnId: string) => ", + "OperationDescriptor", + " | null" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getOperationForColumnId.$1", + "type": "string", + "tags": [], + "label": "columnId", + "description": [], + "signature": [ + "string" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getVisualDefaults", + "type": "Function", + "tags": [], + "label": "getVisualDefaults", + "description": [ + "\nCollect all default visual values given the current state" + ], + "signature": [ + "() => Record>" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getSourceId", + "type": "Function", + "tags": [], + "label": "getSourceId", + "description": [ + "\nRetrieve the specific source id for the current state" + ], + "signature": [ + "() => string | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [], + "returnComment": [] + }, + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getFilters", + "type": "Function", + "tags": [], + "label": "getFilters", + "description": [ + "\nCollect all defined filters from all the operations in the layer" + ], + "signature": [ + "(activeData?: Record | undefined) => Record<\"enabled\" | \"disabled\", { kuery: ", + "Query", + "[][]; lucene: ", + "Query", + "[][]; }>" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.DatasourcePublicAPI.getFilters.$1", + "type": "Object", + "tags": [], + "label": "activeData", + "description": [], + "signature": [ + "Record | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "isRequired": false + } + ], + "returnComment": [] } ], "initialIsOpen": false @@ -134,7 +305,7 @@ "label": "layerType", "description": [], "signature": [ - "\"data\" | \"referenceLine\"" + "\"data\" | \"annotations\" | \"referenceLine\"" ], "path": "x-pack/plugins/lens/public/datatable_visualization/visualization.tsx", "deprecated": false @@ -166,6 +337,19 @@ "path": "x-pack/plugins/lens/public/datatable_visualization/visualization.tsx", "deprecated": false }, + { + "parentPluginId": "lens", + "id": "def-public.DatatableVisualizationState.headerRowHeight", + "type": "CompoundType", + "tags": [], + "label": "headerRowHeight", + "description": [], + "signature": [ + "\"custom\" | \"auto\" | \"single\" | undefined" + ], + "path": "x-pack/plugins/lens/public/datatable_visualization/visualization.tsx", + "deprecated": false + }, { "parentPluginId": "lens", "id": "def-public.DatatableVisualizationState.rowHeightLines", @@ -179,6 +363,19 @@ "path": "x-pack/plugins/lens/public/datatable_visualization/visualization.tsx", "deprecated": false }, + { + "parentPluginId": "lens", + "id": "def-public.DatatableVisualizationState.headerRowHeightLines", + "type": "number", + "tags": [], + "label": "headerRowHeightLines", + "description": [], + "signature": [ + "number | undefined" + ], + "path": "x-pack/plugins/lens/public/datatable_visualization/visualization.tsx", + "deprecated": false + }, { "parentPluginId": "lens", "id": "def-public.DatatableVisualizationState.paging", @@ -244,7 +441,7 @@ "label": "params", "description": [], "signature": [ - "{ interval: string; ignoreTimeRange?: boolean | undefined; dropPartials?: boolean | undefined; }" + "{ interval: string; ignoreTimeRange?: boolean | undefined; includeEmptyRows?: boolean | undefined; dropPartials?: boolean | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/date_histogram.tsx", "deprecated": false @@ -653,7 +850,7 @@ "label": "params", "description": [], "signature": [ - "{ sortField: string; format?: { id: string; params?: { decimals: number; } | undefined; } | undefined; }" + "{ sortField: string; showArrayValues: boolean; format?: { id: string; params?: { decimals: number; } | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/last_value.tsx", "deprecated": false @@ -1456,7 +1653,7 @@ "MODES_TYPES", "; maxBars: number | \"auto\"; ranges: ", "RangeTypeLens", - "[]; format?: { id: string; params?: { decimals: number; } | undefined; } | undefined; parentFormat?: { id: string; params?: { id?: string | undefined; template?: string | undefined; replaceInfinity?: boolean | undefined; } | undefined; } | undefined; }" + "[]; format?: { id: string; params?: { decimals: number; } | undefined; } | undefined; includeEmptyRows?: boolean | undefined; parentFormat?: { id: string; params?: { id?: string | undefined; template?: string | undefined; replaceInfinity?: boolean | undefined; } | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/ranges/ranges.tsx", "deprecated": false @@ -1686,12 +1883,242 @@ "id": "def-public.StaticValueIndexPatternColumn.params", "type": "Object", "tags": [], - "label": "params", - "description": [], + "label": "params", + "description": [], + "signature": [ + "{ value?: string | undefined; format?: { id: string; params?: { decimals: number; } | undefined; } | undefined; }" + ], + "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/static_value.tsx", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest", + "type": "Interface", + "tags": [], + "label": "SuggestionRequest", + "description": [ + "\nObject passed to `getSuggestions` of a visualization.\nIt contains a possible table the current datasource could\nprovide and the state of the visualization if it is currently active.\n\nIf the current datasource suggests multiple tables, `getSuggestions`\nis called multiple times with separate `SuggestionRequest` objects." + ], + "signature": [ + { + "pluginId": "lens", + "scope": "public", + "docId": "kibLensPluginApi", + "section": "def-public.SuggestionRequest", + "text": "SuggestionRequest" + }, + "" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.table", + "type": "Object", + "tags": [], + "label": "table", + "description": [ + "\nA table configuration the datasource could provide." + ], + "signature": [ + { + "pluginId": "lens", + "scope": "public", + "docId": "kibLensPluginApi", + "section": "def-public.TableSuggestion", + "text": "TableSuggestion" + } + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.state", + "type": "Uncategorized", + "tags": [], + "label": "state", + "description": [ + "\nState is only passed if the visualization is active." + ], + "signature": [ + "T | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.mainPalette", + "type": "Object", + "tags": [], + "label": "mainPalette", + "description": [], + "signature": [ + { + "pluginId": "charts", + "scope": "common", + "docId": "kibChartsPluginApi", + "section": "def-common.PaletteOutput", + "text": "PaletteOutput" + }, + "<{ [key: string]: unknown; }> | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.isFromContext", + "type": "CompoundType", + "tags": [], + "label": "isFromContext", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.keptLayerIds", + "type": "Array", + "tags": [], + "label": "keptLayerIds", + "description": [ + "\nThe visualization needs to know which table is being suggested" + ], + "signature": [ + "string[]" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.subVisualizationId", + "type": "string", + "tags": [], + "label": "subVisualizationId", + "description": [ + "\nDifferent suggestions can be generated for each subtype of the visualization" + ], + "signature": [ + "string | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.SuggestionRequest.activeData", + "type": "Object", + "tags": [], + "label": "activeData", + "description": [], + "signature": [ + "Record | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "lens", + "id": "def-public.TableSuggestion", + "type": "Interface", + "tags": [], + "label": "TableSuggestion", + "description": [ + "\nA possible table a datasource can create. This object is passed to the visualization\nwhich tries to build a meaningful visualization given the shape of the table. If this\nis possible, the visualization returns a `VisualizationSuggestion` object" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.TableSuggestion.isMultiRow", + "type": "boolean", + "tags": [], + "label": "isMultiRow", + "description": [ + "\nFlag indicating whether the table will include more than one column.\nThis is not the case for example for a single metric aggregation" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.TableSuggestion.columns", + "type": "Array", + "tags": [], + "label": "columns", + "description": [ + "\nThe columns of the table. Each column has to be mapped to a dimension in a chart. If a visualization\ncan't use all columns of a suggestion, it should not return a `VisualizationSuggestion` based on it\nbecause there would be unreferenced columns" + ], + "signature": [ + "TableSuggestionColumn", + "[]" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.TableSuggestion.layerId", + "type": "string", + "tags": [], + "label": "layerId", + "description": [ + "\nThe layer this table will replace. This is only relevant if the visualization this suggestion is passed\nis currently active and has multiple layers configured. If this suggestion is applied, the table of this\nlayer will be replaced by the columns specified in this suggestion" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.TableSuggestion.label", + "type": "string", + "tags": [], + "label": "label", + "description": [ + "\nA label describing the table. This can be used to provide a title for the `VisualizationSuggestion`,\nbut the visualization can also decide to overwrite it." + ], + "signature": [ + "string | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.TableSuggestion.changeType", + "type": "CompoundType", + "tags": [], + "label": "changeType", + "description": [ + "\nThe change type indicates what was changed in this table compared to the currently active table of this layer." + ], "signature": [ - "{ value?: string | undefined; format?: { id: string; params?: { decimals: number; } | undefined; } | undefined; }" + "\"layers\" | \"initial\" | \"unchanged\" | \"reduced\" | \"extended\" | \"reorder\"" ], - "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/static_value.tsx", + "path": "x-pack/plugins/lens/public/types.ts", "deprecated": false } ], @@ -2251,7 +2678,7 @@ "signature": [ "(state?: T | undefined, frame?: Pick<", "FramePublicAPI", - ", \"datasourceLayers\" | \"activeData\"> | undefined) => { type: ", + ", \"activeData\" | \"datasourceLayers\"> | undefined) => { type: ", { "pluginId": "lens", "scope": "common", @@ -2261,7 +2688,7 @@ }, "; label: string; icon?: ", "IconType", - " | undefined; disabled?: boolean | undefined; toolTipContent?: string | undefined; initialDimensions?: { groupId: string; columnId: string; dataType: string; label: string; staticValue: unknown; }[] | undefined; }[]" + " | undefined; noDatasource?: boolean | undefined; disabled?: boolean | undefined; toolTipContent?: string | undefined; initialDimensions?: { columnId: string; groupId: string; staticValue?: unknown; }[] | undefined; }[]" ], "path": "x-pack/plugins/lens/public/types.ts", "deprecated": false, @@ -2290,7 +2717,7 @@ "signature": [ "Pick<", "FramePublicAPI", - ", \"datasourceLayers\" | \"activeData\"> | undefined" + ", \"activeData\" | \"datasourceLayers\"> | undefined" ], "path": "x-pack/plugins/lens/public/types.ts", "deprecated": false, @@ -2709,6 +3136,127 @@ ], "returnComment": [] }, + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger", + "type": "Function", + "tags": [], + "label": "renderDimensionTrigger", + "description": [ + "\nRenders dimension trigger. Used only for noDatasource layers" + ], + "signature": [ + "((props: { columnId: string; label: string; hideTooltip?: boolean | undefined; invalid?: boolean | undefined; invalidMessage?: string | undefined; }) => JSX.Element | null) | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger.$1", + "type": "Object", + "tags": [], + "label": "props", + "description": [], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger.$1.columnId", + "type": "string", + "tags": [], + "label": "columnId", + "description": [], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger.$1.label", + "type": "string", + "tags": [], + "label": "label", + "description": [], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger.$1.hideTooltip", + "type": "CompoundType", + "tags": [], + "label": "hideTooltip", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger.$1.invalid", + "type": "CompoundType", + "tags": [], + "label": "invalid", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.Visualization.renderDimensionTrigger.$1.invalidMessage", + "type": "string", + "tags": [], + "label": "invalidMessage", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [] + }, + { + "parentPluginId": "lens", + "id": "def-public.Visualization.getUniqueLabels", + "type": "Function", + "tags": [], + "label": "getUniqueLabels", + "description": [ + "\nCreates map of columns ids and unique lables. Used only for noDatasource layers" + ], + "signature": [ + "((state: T) => Record) | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.Visualization.getUniqueLabels.$1", + "type": "Uncategorized", + "tags": [], + "label": "state", + "description": [], + "signature": [ + "T" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, { "parentPluginId": "lens", "id": "def-public.Visualization.getSuggestions", @@ -2720,9 +3268,21 @@ ], "signature": [ "(context: ", - "SuggestionRequest", + { + "pluginId": "lens", + "scope": "public", + "docId": "kibLensPluginApi", + "section": "def-public.SuggestionRequest", + "text": "SuggestionRequest" + }, ") => ", - "VisualizationSuggestion", + { + "pluginId": "lens", + "scope": "public", + "docId": "kibLensPluginApi", + "section": "def-public.VisualizationSuggestion", + "text": "VisualizationSuggestion" + }, "[]" ], "path": "x-pack/plugins/lens/public/types.ts", @@ -2736,7 +3296,13 @@ "label": "context", "description": [], "signature": [ - "SuggestionRequest", + { + "pluginId": "lens", + "scope": "public", + "docId": "kibLensPluginApi", + "section": "def-public.SuggestionRequest", + "text": "SuggestionRequest" + }, "" ], "path": "x-pack/plugins/lens/public/types.ts", @@ -2755,7 +3321,13 @@ "description": [], "signature": [ "(state: T, datasourceLayers: Record, attributes?: Partial<{ title: string; description: string; }> | undefined) => string | ", { "pluginId": "expressions", @@ -2792,7 +3364,13 @@ "description": [], "signature": [ "Record" ], "path": "x-pack/plugins/lens/public/types.ts", @@ -2827,7 +3405,13 @@ ], "signature": [ "((state: T, datasourceLayers: Record) => string | ", { "pluginId": "expressions", @@ -2864,7 +3448,13 @@ "description": [], "signature": [ "Record" ], "path": "x-pack/plugins/lens/public/types.ts", @@ -2885,7 +3475,13 @@ ], "signature": [ "(state: T, datasourceLayers?: Record | undefined) => { shortMessage: string; longMessage: React.ReactNode; }[] | undefined" ], "path": "x-pack/plugins/lens/public/types.ts", @@ -2914,7 +3510,13 @@ "description": [], "signature": [ "Record | undefined" ], "path": "x-pack/plugins/lens/public/types.ts", @@ -3028,6 +3630,100 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "lens", + "id": "def-public.VisualizationSuggestion", + "type": "Interface", + "tags": [], + "label": "VisualizationSuggestion", + "description": [ + "\nA possible configuration of a given visualization. It is based on a `TableSuggestion`.\nSuggestion might be shown in the UI to be chosen by the user directly, but they are\nalso applied directly under some circumstances (dragging in the first field from the data\npanel or switching to another visualization in the chart switcher)." + ], + "signature": [ + { + "pluginId": "lens", + "scope": "public", + "docId": "kibLensPluginApi", + "section": "def-public.VisualizationSuggestion", + "text": "VisualizationSuggestion" + }, + "" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "lens", + "id": "def-public.VisualizationSuggestion.score", + "type": "number", + "tags": [], + "label": "score", + "description": [ + "\nThe score of a suggestion should indicate how valuable the suggestion is. It is used\nto rank multiple suggestions of multiple visualizations. The number should be between 0 and 1" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.VisualizationSuggestion.hide", + "type": "CompoundType", + "tags": [], + "label": "hide", + "description": [ + "\nFlag indicating whether this suggestion should not be advertised to the user. It is still\nconsidered in scenarios where the available suggestion with the highest suggestion is applied\ndirectly." + ], + "signature": [ + "boolean | undefined" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.VisualizationSuggestion.title", + "type": "string", + "tags": [], + "label": "title", + "description": [ + "\nDescriptive title of the suggestion. Should be as short as possible. This title is shown if\nthe suggestion is advertised to the user and will also show either the `previewExpression` or\nthe `previewIcon`" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.VisualizationSuggestion.state", + "type": "Uncategorized", + "tags": [], + "label": "state", + "description": [ + "\nThe new state of the visualization if this suggestion is applied." + ], + "signature": [ + "T" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.VisualizationSuggestion.previewIcon", + "type": "CompoundType", + "tags": [], + "label": "previewIcon", + "description": [ + "\nAn EUI icon type shown instead of the preview expression." + ], + "signature": [ + "string | React.ComponentType<{}>" + ], + "path": "x-pack/plugins/lens/public/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "lens", "id": "def-public.XYState", @@ -3097,6 +3793,32 @@ "path": "x-pack/plugins/lens/public/xy_visualization/types.ts", "deprecated": false }, + { + "parentPluginId": "lens", + "id": "def-public.XYState.emphasizeFitting", + "type": "CompoundType", + "tags": [], + "label": "emphasizeFitting", + "description": [], + "signature": [ + "boolean | undefined" + ], + "path": "x-pack/plugins/lens/public/xy_visualization/types.ts", + "deprecated": false + }, + { + "parentPluginId": "lens", + "id": "def-public.XYState.endValue", + "type": "CompoundType", + "tags": [], + "label": "endValue", + "description": [], + "signature": [ + "\"None\" | \"Zero\" | \"Nearest\" | undefined" + ], + "path": "x-pack/plugins/lens/public/xy_visualization/types.ts", + "deprecated": false + }, { "parentPluginId": "lens", "id": "def-public.XYState.yLeftExtent", @@ -3432,8 +4154,6 @@ "label": "AvgIndexPatternColumn", "description": [], "signature": [ - "FormattedIndexPatternColumn", - " & ", { "pluginId": "lens", "scope": "public", @@ -3441,7 +4161,9 @@ "section": "def-public.FieldBasedIndexPatternColumn", "text": "FieldBasedIndexPatternColumn" }, - " & { operationType: \"average\"; }" + " & { operationType: \"average\"; params?: { emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx", "deprecated": false, @@ -3472,8 +4194,6 @@ "label": "CountIndexPatternColumn", "description": [], "signature": [ - "FormattedIndexPatternColumn", - " & ", { "pluginId": "lens", "scope": "public", @@ -3481,7 +4201,9 @@ "section": "def-public.FieldBasedIndexPatternColumn", "text": "FieldBasedIndexPatternColumn" }, - " & { operationType: \"count\"; }" + " & { operationType: \"count\"; params?: { emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/count.tsx", "deprecated": false, @@ -3677,8 +4399,6 @@ "label": "MaxIndexPatternColumn", "description": [], "signature": [ - "FormattedIndexPatternColumn", - " & ", { "pluginId": "lens", "scope": "public", @@ -3686,7 +4406,9 @@ "section": "def-public.FieldBasedIndexPatternColumn", "text": "FieldBasedIndexPatternColumn" }, - " & { operationType: \"max\"; }" + " & { operationType: \"max\"; params?: { emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx", "deprecated": false, @@ -3700,8 +4422,6 @@ "label": "MedianIndexPatternColumn", "description": [], "signature": [ - "FormattedIndexPatternColumn", - " & ", { "pluginId": "lens", "scope": "public", @@ -3709,7 +4429,9 @@ "section": "def-public.FieldBasedIndexPatternColumn", "text": "FieldBasedIndexPatternColumn" }, - " & { operationType: \"median\"; }" + " & { operationType: \"median\"; params?: { emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx", "deprecated": false, @@ -3723,8 +4445,6 @@ "label": "MinIndexPatternColumn", "description": [], "signature": [ - "FormattedIndexPatternColumn", - " & ", { "pluginId": "lens", "scope": "public", @@ -3732,7 +4452,9 @@ "section": "def-public.FieldBasedIndexPatternColumn", "text": "FieldBasedIndexPatternColumn" }, - " & { operationType: \"min\"; }" + " & { operationType: \"min\"; params?: { emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx", "deprecated": false, @@ -3869,8 +4591,6 @@ "label": "SumIndexPatternColumn", "description": [], "signature": [ - "FormattedIndexPatternColumn", - " & ", { "pluginId": "lens", "scope": "public", @@ -3878,7 +4598,9 @@ "section": "def-public.FieldBasedIndexPatternColumn", "text": "FieldBasedIndexPatternColumn" }, - " & { operationType: \"sum\"; }" + " & { operationType: \"sum\"; params?: { emptyAsNull?: boolean | undefined; format?: ", + "FormatParams", + " | undefined; } | undefined; }" ], "path": "x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/metrics.tsx", "deprecated": false, @@ -3988,7 +4710,9 @@ "signature": [ "XYDataLayerConfig", " | ", - "XYReferenceLineLayerConfig" + "XYReferenceLineLayerConfig", + " | ", + "XYAnnotationLayerConfig" ], "path": "x-pack/plugins/lens/common/expressions/xy_chart/layer_config/index.ts", "deprecated": false, @@ -4018,7 +4742,7 @@ "label": "layerTypes", "description": [], "signature": [ - "{ readonly DATA: \"data\"; readonly REFERENCELINE: \"referenceLine\"; }" + "{ readonly DATA: \"data\"; readonly REFERENCELINE: \"referenceLine\"; readonly ANNOTATIONS: \"annotations\"; }" ], "path": "x-pack/plugins/lens/common/constants.ts", "deprecated": false, @@ -5832,7 +6556,7 @@ "label": "layerType", "description": [], "signature": [ - "\"data\" | \"referenceLine\"" + "\"data\" | \"annotations\" | \"referenceLine\"" ], "path": "x-pack/plugins/lens/common/types.ts", "deprecated": false @@ -6544,7 +7268,7 @@ "label": "LayerType", "description": [], "signature": [ - "\"data\" | \"referenceLine\"" + "\"data\" | \"annotations\" | \"referenceLine\"" ], "path": "x-pack/plugins/lens/common/types.ts", "deprecated": false, @@ -6751,7 +7475,7 @@ "label": "layerTypes", "description": [], "signature": [ - "{ readonly DATA: \"data\"; readonly REFERENCELINE: \"referenceLine\"; }" + "{ readonly DATA: \"data\"; readonly REFERENCELINE: \"referenceLine\"; readonly ANNOTATIONS: \"annotations\"; }" ], "path": "x-pack/plugins/lens/common/constants.ts", "deprecated": false, diff --git a/api_docs/lens.mdx b/api_docs/lens.mdx index 8a3765c99f537..84a89dd791f66 100644 --- a/api_docs/lens.mdx +++ b/api_docs/lens.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/lens title: "lens" image: https://source.unsplash.com/400x175/?github summary: API docs for the lens plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'lens'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 395 | 0 | 343 | 43 | +| 438 | 0 | 363 | 44 | ## Client diff --git a/api_docs/license_api_guard.mdx b/api_docs/license_api_guard.mdx index 28fdba4aa9a8b..256fef726f354 100644 --- a/api_docs/license_api_guard.mdx +++ b/api_docs/license_api_guard.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/licenseApiGuard title: "licenseApiGuard" image: https://source.unsplash.com/400x175/?github summary: API docs for the licenseApiGuard plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'licenseApiGuard'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/license_management.mdx b/api_docs/license_management.mdx index d97318c583676..54f934702c0ee 100644 --- a/api_docs/license_management.mdx +++ b/api_docs/license_management.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/licenseManagement title: "licenseManagement" image: https://source.unsplash.com/400x175/?github summary: API docs for the licenseManagement plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'licenseManagement'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/licensing.devdocs.json b/api_docs/licensing.devdocs.json index 40e6f7874ec34..7d63612c554c2 100644 --- a/api_docs/licensing.devdocs.json +++ b/api_docs/licensing.devdocs.json @@ -103,6 +103,7 @@ ], "path": "x-pack/plugins/licensing/common/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [] }, { @@ -460,6 +461,7 @@ ], "path": "x-pack/plugins/licensing/common/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "apm", @@ -717,6 +719,7 @@ ], "path": "x-pack/plugins/licensing/public/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "security", @@ -790,6 +793,7 @@ ], "path": "x-pack/plugins/licensing/public/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [], "children": [], "returnComment": [] @@ -1789,6 +1793,7 @@ ], "path": "x-pack/plugins/licensing/common/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [] }, { @@ -2193,6 +2198,7 @@ ], "path": "x-pack/plugins/licensing/common/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "apm", @@ -2494,6 +2500,7 @@ ], "path": "x-pack/plugins/licensing/server/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "spaces", @@ -2615,6 +2622,7 @@ ], "path": "x-pack/plugins/licensing/server/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "mapsEms", diff --git a/api_docs/licensing.mdx b/api_docs/licensing.mdx index 203b61694c4ab..be18c4a645fa2 100644 --- a/api_docs/licensing.mdx +++ b/api_docs/licensing.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/licensing title: "licensing" image: https://source.unsplash.com/400x175/?github summary: API docs for the licensing plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'licensing'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/lists.mdx b/api_docs/lists.mdx index d1e5cffc60801..85a40eb0e3f3b 100644 --- a/api_docs/lists.mdx +++ b/api_docs/lists.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/lists title: "lists" image: https://source.unsplash.com/400x175/?github summary: API docs for the lists plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'lists'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/management.mdx b/api_docs/management.mdx index 541281ded0c0f..a662b63d61731 100644 --- a/api_docs/management.mdx +++ b/api_docs/management.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/management title: "management" image: https://source.unsplash.com/400x175/?github summary: API docs for the management plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'management'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/maps.devdocs.json b/api_docs/maps.devdocs.json index c6b9ab0d2b279..157684b198652 100644 --- a/api_docs/maps.devdocs.json +++ b/api_docs/maps.devdocs.json @@ -812,6 +812,50 @@ ], "returnComment": [] }, + { + "parentPluginId": "maps", + "id": "def-public.MapEmbeddable.updateLayerById", + "type": "Function", + "tags": [], + "label": "updateLayerById", + "description": [], + "signature": [ + "(layerDescriptor: ", + { + "pluginId": "maps", + "scope": "common", + "docId": "kibMapsPluginApi", + "section": "def-common.LayerDescriptor", + "text": "LayerDescriptor" + }, + ") => void" + ], + "path": "x-pack/plugins/maps/public/embeddable/map_embeddable.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "maps", + "id": "def-public.MapEmbeddable.updateLayerById.$1", + "type": "Object", + "tags": [], + "label": "layerDescriptor", + "description": [], + "signature": [ + { + "pluginId": "maps", + "scope": "common", + "docId": "kibMapsPluginApi", + "section": "def-common.LayerDescriptor", + "text": "LayerDescriptor" + } + ], + "path": "x-pack/plugins/maps/public/embeddable/map_embeddable.tsx", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] + }, { "parentPluginId": "maps", "id": "def-public.MapEmbeddable.onSingleValueTrigger", @@ -1177,6 +1221,16 @@ "description": [], "path": "x-pack/plugins/maps/public/ems_autosuggest/ems_autosuggest.ts", "deprecated": false + }, + { + "parentPluginId": "maps", + "id": "def-public.EMSTermJoinConfig.displayName", + "type": "string", + "tags": [], + "label": "displayName", + "description": [], + "path": "x-pack/plugins/maps/public/ems_autosuggest/ems_autosuggest.ts", + "deprecated": false } ], "initialIsOpen": false @@ -3344,6 +3398,17 @@ "path": "x-pack/plugins/maps/common/constants.ts", "deprecated": false, "initialIsOpen": false + }, + { + "parentPluginId": "maps", + "id": "def-common.VECTOR_STYLES", + "type": "Enum", + "tags": [], + "label": "VECTOR_STYLES", + "description": [], + "path": "x-pack/plugins/maps/common/constants.ts", + "deprecated": false, + "initialIsOpen": false } ], "misc": [ diff --git a/api_docs/maps.mdx b/api_docs/maps.mdx index 70190edd4f35c..1ea8654c4245f 100644 --- a/api_docs/maps.mdx +++ b/api_docs/maps.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/maps title: "maps" image: https://source.unsplash.com/400x175/?github summary: API docs for the maps plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'maps'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [GIS](https://github.com/orgs/elastic/teams/kibana-gis) for questions re | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 216 | 0 | 215 | 27 | +| 220 | 0 | 219 | 27 | ## Client diff --git a/api_docs/maps_ems.devdocs.json b/api_docs/maps_ems.devdocs.json index 87808d88def77..18ef0a3cf340b 100644 --- a/api_docs/maps_ems.devdocs.json +++ b/api_docs/maps_ems.devdocs.json @@ -953,7 +953,7 @@ "label": "DEFAULT_EMS_LANDING_PAGE_URL", "description": [], "signature": [ - "\"https://maps.elastic.co/v8.1\"" + "\"https://maps.elastic.co/v8.2\"" ], "path": "src/plugins/maps_ems/common/ems_defaults.ts", "deprecated": false, diff --git a/api_docs/maps_ems.mdx b/api_docs/maps_ems.mdx index 260a2fdf6dded..9c1b685711d4b 100644 --- a/api_docs/maps_ems.mdx +++ b/api_docs/maps_ems.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/mapsEms title: "mapsEms" image: https://source.unsplash.com/400x175/?github summary: API docs for the mapsEms plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'mapsEms'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/metrics_entities.mdx b/api_docs/metrics_entities.mdx index b760e1c32b85c..758efed1b5f32 100644 --- a/api_docs/metrics_entities.mdx +++ b/api_docs/metrics_entities.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/metricsEntities title: "metricsEntities" image: https://source.unsplash.com/400x175/?github summary: API docs for the metricsEntities plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'metricsEntities'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/ml.devdocs.json b/api_docs/ml.devdocs.json index c5e7ee6d09069..bfcdfea604043 100644 --- a/api_docs/ml.devdocs.json +++ b/api_docs/ml.devdocs.json @@ -1256,8 +1256,8 @@ "description": [], "signature": [ "({ rowIndex, columnId, setCellProps, }: { rowIndex: number; columnId: string; setCellProps: (props: ", - "CommonProps", - " & React.HTMLAttributes) => void; }) => any" + "EuiDataGridSetCellProps", + ") => void; }) => any" ], "path": "x-pack/plugins/ml/public/application/components/data_grid/types.ts", "deprecated": false, @@ -1272,8 +1272,8 @@ "description": [], "signature": [ "{ rowIndex: number; columnId: string; setCellProps: (props: ", - "CommonProps", - " & React.HTMLAttributes) => void; }" + "EuiDataGridSetCellProps", + ") => void; }" ], "path": "x-pack/plugins/ml/public/application/components/data_grid/types.ts", "deprecated": false @@ -1425,8 +1425,8 @@ "description": [], "signature": [ "({ rowIndex, columnId, setCellProps, }: { rowIndex: number; columnId: string; setCellProps: (props: ", - "CommonProps", - " & React.HTMLAttributes) => void; }) => any" + "EuiDataGridSetCellProps", + ") => void; }) => any" ], "path": "x-pack/plugins/ml/public/application/components/data_grid/types.ts", "deprecated": false, @@ -1441,8 +1441,8 @@ "description": [], "signature": [ "{ rowIndex: number; columnId: string; setCellProps: (props: ", - "CommonProps", - " & React.HTMLAttributes) => void; }" + "EuiDataGridSetCellProps", + ") => void; }" ], "path": "x-pack/plugins/ml/public/application/components/data_grid/types.ts", "deprecated": false @@ -1478,7 +1478,7 @@ "label": "ML_PAGES", "description": [], "signature": [ - "{ readonly ANOMALY_DETECTION_JOBS_MANAGE: \"jobs\"; readonly ANOMALY_EXPLORER: \"explorer\"; readonly SINGLE_METRIC_VIEWER: \"timeseriesexplorer\"; readonly DATA_FRAME_ANALYTICS_JOBS_MANAGE: \"data_frame_analytics\"; readonly DATA_FRAME_ANALYTICS_CREATE_JOB: \"data_frame_analytics/new_job\"; readonly TRAINED_MODELS_MANAGE: \"trained_models\"; readonly TRAINED_MODELS_NODES: \"trained_models/nodes\"; readonly DATA_FRAME_ANALYTICS_EXPLORATION: \"data_frame_analytics/exploration\"; readonly DATA_FRAME_ANALYTICS_MAP: \"data_frame_analytics/map\"; readonly DATA_VISUALIZER: \"datavisualizer\"; readonly DATA_VISUALIZER_INDEX_SELECT: \"datavisualizer_index_select\"; readonly DATA_VISUALIZER_FILE: \"filedatavisualizer\"; readonly DATA_VISUALIZER_INDEX_VIEWER: \"jobs/new_job/datavisualizer\"; readonly ANOMALY_DETECTION_CREATE_JOB: \"jobs/new_job\"; readonly ANOMALY_DETECTION_CREATE_JOB_ADVANCED: \"jobs/new_job/advanced\"; readonly ANOMALY_DETECTION_CREATE_JOB_SELECT_TYPE: \"jobs/new_job/step/job_type\"; readonly ANOMALY_DETECTION_CREATE_JOB_SELECT_INDEX: \"jobs/new_job/step/index_or_search\"; readonly SETTINGS: \"settings\"; readonly CALENDARS_MANAGE: \"settings/calendars_list\"; readonly CALENDARS_NEW: \"settings/calendars_list/new_calendar\"; readonly CALENDARS_EDIT: \"settings/calendars_list/edit_calendar\"; readonly FILTER_LISTS_MANAGE: \"settings/filter_lists\"; readonly FILTER_LISTS_NEW: \"settings/filter_lists/new_filter_list\"; readonly FILTER_LISTS_EDIT: \"settings/filter_lists/edit_filter_list\"; readonly ACCESS_DENIED: \"access-denied\"; readonly OVERVIEW: \"overview\"; }" + "{ readonly ANOMALY_DETECTION_JOBS_MANAGE: \"jobs\"; readonly ANOMALY_EXPLORER: \"explorer\"; readonly SINGLE_METRIC_VIEWER: \"timeseriesexplorer\"; readonly DATA_FRAME_ANALYTICS_JOBS_MANAGE: \"data_frame_analytics\"; readonly DATA_FRAME_ANALYTICS_SOURCE_SELECTION: \"data_frame_analytics/source_selection\"; readonly DATA_FRAME_ANALYTICS_CREATE_JOB: \"data_frame_analytics/new_job\"; readonly TRAINED_MODELS_MANAGE: \"trained_models\"; readonly TRAINED_MODELS_NODES: \"trained_models/nodes\"; readonly DATA_FRAME_ANALYTICS_EXPLORATION: \"data_frame_analytics/exploration\"; readonly DATA_FRAME_ANALYTICS_MAP: \"data_frame_analytics/map\"; readonly DATA_VISUALIZER: \"datavisualizer\"; readonly DATA_VISUALIZER_INDEX_SELECT: \"datavisualizer_index_select\"; readonly DATA_VISUALIZER_FILE: \"filedatavisualizer\"; readonly DATA_VISUALIZER_INDEX_VIEWER: \"jobs/new_job/datavisualizer\"; readonly ANOMALY_DETECTION_CREATE_JOB: \"jobs/new_job\"; readonly ANOMALY_DETECTION_CREATE_JOB_ADVANCED: \"jobs/new_job/advanced\"; readonly ANOMALY_DETECTION_CREATE_JOB_SELECT_TYPE: \"jobs/new_job/step/job_type\"; readonly ANOMALY_DETECTION_CREATE_JOB_SELECT_INDEX: \"jobs/new_job/step/index_or_search\"; readonly SETTINGS: \"settings\"; readonly CALENDARS_MANAGE: \"settings/calendars_list\"; readonly CALENDARS_NEW: \"settings/calendars_list/new_calendar\"; readonly CALENDARS_EDIT: \"settings/calendars_list/edit_calendar\"; readonly FILTER_LISTS_MANAGE: \"settings/filter_lists\"; readonly FILTER_LISTS_NEW: \"settings/filter_lists/new_filter_list\"; readonly FILTER_LISTS_EDIT: \"settings/filter_lists/edit_filter_list\"; readonly ACCESS_DENIED: \"access-denied\"; readonly OVERVIEW: \"overview\"; }" ], "path": "x-pack/plugins/ml/common/constants/locator.ts", "deprecated": false, diff --git a/api_docs/ml.mdx b/api_docs/ml.mdx index 6302338bcab5b..4f8c7d8db29da 100644 --- a/api_docs/ml.mdx +++ b/api_docs/ml.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/ml title: "ml" image: https://source.unsplash.com/400x175/?github summary: API docs for the ml plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ml'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/monitoring.mdx b/api_docs/monitoring.mdx index f6c27fd9d0788..909e1991311ef 100644 --- a/api_docs/monitoring.mdx +++ b/api_docs/monitoring.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/monitoring title: "monitoring" image: https://source.unsplash.com/400x175/?github summary: API docs for the monitoring plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'monitoring'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/monitoring_collection.devdocs.json b/api_docs/monitoring_collection.devdocs.json index 84e1cad4b16a0..bca169a38e523 100644 --- a/api_docs/monitoring_collection.devdocs.json +++ b/api_docs/monitoring_collection.devdocs.json @@ -11,7 +11,89 @@ "server": { "classes": [], "functions": [], - "interfaces": [], + "interfaces": [ + { + "parentPluginId": "monitoringCollection", + "id": "def-server.Metric", + "type": "Interface", + "tags": [], + "label": "Metric", + "description": [], + "signature": [ + { + "pluginId": "monitoringCollection", + "scope": "server", + "docId": "kibMonitoringCollectionPluginApi", + "section": "def-server.Metric", + "text": "Metric" + }, + "" + ], + "path": "x-pack/plugins/monitoring_collection/server/plugin.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "monitoringCollection", + "id": "def-server.Metric.type", + "type": "string", + "tags": [], + "label": "type", + "description": [], + "path": "x-pack/plugins/monitoring_collection/server/plugin.ts", + "deprecated": false + }, + { + "parentPluginId": "monitoringCollection", + "id": "def-server.Metric.schema", + "type": "Object", + "tags": [], + "label": "schema", + "description": [], + "signature": [ + "{ [Key in keyof Required]: Required[Key] extends (infer U)[] ? { type: \"array\"; items: ", + "RecursiveMakeSchemaFrom", + "; } : ", + "RecursiveMakeSchemaFrom", + "[Key]>; }" + ], + "path": "x-pack/plugins/monitoring_collection/server/plugin.ts", + "deprecated": false + }, + { + "parentPluginId": "monitoringCollection", + "id": "def-server.Metric.fetch", + "type": "Function", + "tags": [], + "label": "fetch", + "description": [], + "signature": [ + "() => Promise<", + { + "pluginId": "monitoringCollection", + "scope": "server", + "docId": "kibMonitoringCollectionPluginApi", + "section": "def-server.MetricResult", + "text": "MetricResult" + }, + " | ", + { + "pluginId": "monitoringCollection", + "scope": "server", + "docId": "kibMonitoringCollectionPluginApi", + "section": "def-server.MetricResult", + "text": "MetricResult" + }, + "[]>" + ], + "path": "x-pack/plugins/monitoring_collection/server/plugin.ts", + "deprecated": false, + "children": [], + "returnComment": [] + } + ], + "initialIsOpen": false + } + ], "enums": [], "misc": [ { @@ -64,7 +146,13 @@ "description": [], "signature": [ "(metric: ", - "Metric", + { + "pluginId": "monitoringCollection", + "scope": "server", + "docId": "kibMonitoringCollectionPluginApi", + "section": "def-server.Metric", + "text": "Metric" + }, ") => void" ], "path": "x-pack/plugins/monitoring_collection/server/plugin.ts", @@ -78,7 +166,13 @@ "label": "metric", "description": [], "signature": [ - "Metric", + { + "pluginId": "monitoringCollection", + "scope": "server", + "docId": "kibMonitoringCollectionPluginApi", + "section": "def-server.Metric", + "text": "Metric" + }, "" ], "path": "x-pack/plugins/monitoring_collection/server/plugin.ts", diff --git a/api_docs/monitoring_collection.mdx b/api_docs/monitoring_collection.mdx index 86ad88a64974b..65e04e6bcb35a 100644 --- a/api_docs/monitoring_collection.mdx +++ b/api_docs/monitoring_collection.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/monitoringCollection title: "monitoringCollection" image: https://source.unsplash.com/400x175/?github summary: API docs for the monitoringCollection plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'monitoringCollection'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,13 +18,16 @@ Contact [Stack Monitoring](https://github.com/orgs/elastic/teams/stack-monitorin | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 5 | 0 | 5 | 1 | +| 9 | 0 | 9 | 0 | ## Server ### Setup +### Interfaces + + ### Consts, variables and types diff --git a/api_docs/navigation.mdx b/api_docs/navigation.mdx index f904cba6cbbec..8220e61a22c8b 100644 --- a/api_docs/navigation.mdx +++ b/api_docs/navigation.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/navigation title: "navigation" image: https://source.unsplash.com/400x175/?github summary: API docs for the navigation plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'navigation'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/newsfeed.mdx b/api_docs/newsfeed.mdx index 1a77153508648..2b3ab879f7dbc 100644 --- a/api_docs/newsfeed.mdx +++ b/api_docs/newsfeed.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/newsfeed title: "newsfeed" image: https://source.unsplash.com/400x175/?github summary: API docs for the newsfeed plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'newsfeed'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/observability.devdocs.json b/api_docs/observability.devdocs.json index 049c3f8e3f5ea..92b1a82e29de6 100644 --- a/api_docs/observability.devdocs.json +++ b/api_docs/observability.devdocs.json @@ -280,6 +280,48 @@ "returnComment": [], "initialIsOpen": false }, + { + "parentPluginId": "observability", + "id": "def-public.DatePickerContextProvider", + "type": "Function", + "tags": [], + "label": "DatePickerContextProvider", + "description": [], + "signature": [ + "({ children }: { children: React.ReactElement>; }) => JSX.Element" + ], + "path": "x-pack/plugins/observability/public/context/date_picker_context.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "observability", + "id": "def-public.DatePickerContextProvider.$1", + "type": "Object", + "tags": [], + "label": "{ children }", + "description": [], + "path": "x-pack/plugins/observability/public/context/date_picker_context.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "observability", + "id": "def-public.DatePickerContextProvider.$1.children", + "type": "Object", + "tags": [], + "label": "children", + "description": [], + "signature": [ + "React.ReactElement>" + ], + "path": "x-pack/plugins/observability/public/context/date_picker_context.tsx", + "deprecated": false + } + ] + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "observability", "id": "def-public.ExploratoryView", @@ -2311,6 +2353,39 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "observability", + "id": "def-public.InfraLogsHasDataResponse", + "type": "Interface", + "tags": [], + "label": "InfraLogsHasDataResponse", + "description": [], + "path": "x-pack/plugins/observability/public/typings/fetch_overview_data/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "observability", + "id": "def-public.InfraLogsHasDataResponse.hasData", + "type": "boolean", + "tags": [], + "label": "hasData", + "description": [], + "path": "x-pack/plugins/observability/public/typings/fetch_overview_data/index.ts", + "deprecated": false + }, + { + "parentPluginId": "observability", + "id": "def-public.InfraLogsHasDataResponse.indices", + "type": "string", + "tags": [], + "label": "indices", + "description": [], + "path": "x-pack/plugins/observability/public/typings/fetch_overview_data/index.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "observability", "id": "def-public.InfraMetricsHasDataResponse", @@ -2932,10 +3007,19 @@ { "parentPluginId": "observability", "id": "def-public.ObservabilityHasDataResponse.infra_logs", - "type": "boolean", + "type": "Object", "tags": [], "label": "infra_logs", "description": [], + "signature": [ + { + "pluginId": "observability", + "scope": "public", + "docId": "kibObservabilityPluginApi", + "section": "def-public.InfraLogsHasDataResponse", + "text": "InfraLogsHasDataResponse" + } + ], "path": "x-pack/plugins/observability/public/typings/fetch_overview_data/index.ts", "deprecated": false }, @@ -3165,207 +3249,7 @@ "label": "dataViews", "description": [], "signature": [ - "{ create: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; delete: (indexPatternId: string) => Promise<{}>; find: (search: string, size?: number) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - "[]>; get: (id: string) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; getCanSave: () => Promise; ensureDefaultDataView: ", - "EnsureDefaultDataView", - "; getIds: (refresh?: boolean) => Promise; getTitles: (refresh?: boolean) => Promise; getIdsWithTitle: (refresh?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewListItem", - "text": "DataViewListItem" - }, - "[]>; clearCache: (id?: string | undefined) => void; getCache: () => Promise<", - "SavedObject", - "<", - "IndexPatternSavedObjectAttrs", - ">[] | null | undefined>; getDefault: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getDefaultId: () => Promise; setDefault: (id: string | null, force?: boolean) => Promise; hasUserDataView: () => Promise; getFieldsForWildcard: (options: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - ") => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; getFieldsForIndexPattern: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", options?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.GetFieldsOptions", - "text": "GetFieldsOptions" - }, - " | undefined) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[]>; refreshFields: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ") => Promise; fieldArrayToMap: (fields: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldSpec", - "text": "FieldSpec" - }, - "[], fieldAttrs?: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.FieldAttrs", - "text": "FieldAttrs" - }, - " | undefined) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewFieldMap", - "text": "DataViewFieldMap" - }, - "; savedObjectToSpec: (savedObject: ", - "SavedObject", - "<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewAttributes", - "text": "DataViewAttributes" - }, - ">) => ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - "; createAndSave: (spec: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataViewSpec", - "text": "DataViewSpec" - }, - ", override?: boolean, skipFetchFields?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; createSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", override?: boolean) => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ">; updateSavedObject: (indexPattern: ", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - ", saveAttempts?: number, ignoreErrors?: boolean) => Promise; getDefaultDataView: () => Promise<", - { - "pluginId": "dataViews", - "scope": "common", - "docId": "kibDataViewsPluginApi", - "section": "def-common.DataView", - "text": "DataView" - }, - " | null>; getCanSaveSync: () => boolean; }" + "DataViewsServicePublic" ], "path": "x-pack/plugins/observability/public/plugin.ts", "deprecated": false @@ -3688,6 +3572,19 @@ "path": "x-pack/plugins/observability/public/components/shared/exploratory_view/types.ts", "deprecated": false }, + { + "parentPluginId": "observability", + "id": "def-public.SeriesConfig.textDefinitionFields", + "type": "Array", + "tags": [], + "label": "textDefinitionFields", + "description": [], + "signature": [ + "string[] | undefined" + ], + "path": "x-pack/plugins/observability/public/components/shared/exploratory_view/types.ts", + "deprecated": false + }, { "parentPluginId": "observability", "id": "def-public.SeriesConfig.metricOptions", @@ -3883,7 +3780,7 @@ "label": "dataType", "description": [], "signature": [ - "\"mobile\" | \"apm\" | \"synthetics\" | \"infra_metrics\" | \"infra_logs\" | \"ux\"" + "\"mobile\" | \"apm\" | \"synthetics\" | \"ux\" | \"infra_logs\" | \"infra_metrics\"" ], "path": "x-pack/plugins/observability/public/components/shared/exploratory_view/types.ts", "deprecated": false @@ -3902,6 +3799,20 @@ "path": "x-pack/plugins/observability/public/components/shared/exploratory_view/types.ts", "deprecated": false }, + { + "parentPluginId": "observability", + "id": "def-public.SeriesUrl.textReportDefinitions", + "type": "Object", + "tags": [], + "label": "textReportDefinitions", + "description": [], + "signature": [ + "URLTextReportDefinition", + " | undefined" + ], + "path": "x-pack/plugins/observability/public/components/shared/exploratory_view/types.ts", + "deprecated": false + }, { "parentPluginId": "observability", "id": "def-public.SeriesUrl.selectedMetricField", @@ -4681,7 +4592,7 @@ "label": "ObservabilityFetchDataPlugins", "description": [], "signature": [ - "\"apm\" | \"synthetics\" | \"infra_metrics\" | \"infra_logs\" | \"ux\"" + "\"apm\" | \"synthetics\" | \"ux\" | \"infra_logs\" | \"infra_metrics\"" ], "path": "x-pack/plugins/observability/public/typings/fetch_overview_data/index.ts", "deprecated": false, @@ -4991,7 +4902,17 @@ "section": "def-public.AllSeries", "text": "AllSeries" }, - "; }, baseHref?: string, appId?: string) => string; ExploratoryViewEmbeddable: (props: ", + "; }, baseHref?: string, appId?: string) => string; getAppDataView: (appId: ", + "AppDataType", + ", indexPattern?: string | undefined) => Promise<", + { + "pluginId": "dataViews", + "scope": "common", + "docId": "kibDataViewsPluginApi", + "section": "def-common.DataView", + "text": "DataView" + }, + " | null | undefined>; ExploratoryViewEmbeddable: (props: ", { "pluginId": "observability", "scope": "public", diff --git a/api_docs/observability.mdx b/api_docs/observability.mdx index c83029e20587a..5bd4eccae8623 100644 --- a/api_docs/observability.mdx +++ b/api_docs/observability.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/observability title: "observability" image: https://source.unsplash.com/400x175/?github summary: API docs for the observability plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'observability'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Observability UI](https://github.com/orgs/elastic/teams/observability-u | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 358 | 2 | 355 | 30 | +| 366 | 2 | 363 | 31 | ## Client diff --git a/api_docs/osquery.devdocs.json b/api_docs/osquery.devdocs.json index e46ce01c80e29..43ce59b764ca8 100644 --- a/api_docs/osquery.devdocs.json +++ b/api_docs/osquery.devdocs.json @@ -42,6 +42,44 @@ ], "path": "x-pack/plugins/osquery/public/types.ts", "deprecated": false + }, + { + "parentPluginId": "osquery", + "id": "def-public.OsqueryPluginStart.isOsqueryAvailable", + "type": "Function", + "tags": [], + "label": "isOsqueryAvailable", + "description": [], + "signature": [ + "(props: { agentId: string; }) => boolean" + ], + "path": "x-pack/plugins/osquery/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "osquery", + "id": "def-public.OsqueryPluginStart.isOsqueryAvailable.$1", + "type": "Object", + "tags": [], + "label": "props", + "description": [], + "path": "x-pack/plugins/osquery/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "osquery", + "id": "def-public.OsqueryPluginStart.isOsqueryAvailable.$1.agentId", + "type": "string", + "tags": [], + "label": "agentId", + "description": [], + "path": "x-pack/plugins/osquery/public/types.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [] } ], "lifecycle": "start", diff --git a/api_docs/osquery.mdx b/api_docs/osquery.mdx index c23e08e789e91..b5fb6eb0b4e5f 100644 --- a/api_docs/osquery.mdx +++ b/api_docs/osquery.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/osquery title: "osquery" image: https://source.unsplash.com/400x175/?github summary: API docs for the osquery plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'osquery'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Security asset management](https://github.com/orgs/elastic/teams/securi | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 10 | 0 | 10 | 0 | +| 13 | 0 | 13 | 0 | ## Client diff --git a/api_docs/plugin_directory.mdx b/api_docs/plugin_directory.mdx index fd475352277ed..074b16f3f28ae 100644 --- a/api_docs/plugin_directory.mdx +++ b/api_docs/plugin_directory.mdx @@ -3,7 +3,7 @@ id: kibDevDocsPluginDirectory slug: /kibana-dev-docs/api-meta/plugin-api-directory title: Directory summary: Directory of public APIs available through plugins or packages. -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -12,21 +12,21 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | Count | Plugins or Packages with a
public API | Number of teams | |--------------|----------|------------------------| -| 221 | 176 | 34 | +| 248 | 181 | 42 | ### Public API health stats | API Count | Any Count | Missing comments | Missing exports | |--------------|----------|-----------------|--------| -| 24101 | 168 | 18338 | 1107 | +| 24620 | 168 | 18747 | 1131 | ## Plugin Directory | Plugin name           | Maintaining team | Description | API Cnt | Any Cnt | Missing
comments | Missing
exports | |--------------|----------------|-----------|--------------|----------|---------------|--------| -| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 125 | 0 | 125 | 11 | +| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 127 | 0 | 127 | 10 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 23 | 0 | 19 | 1 | -| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 296 | 0 | 288 | 18 | +| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 301 | 0 | 293 | 21 | | | [APM UI](https://github.com/orgs/elastic/teams/apm-ui) | The user interface for Elastic APM | 40 | 0 | 40 | 50 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 9 | 0 | 9 | 0 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Considering using bfetch capabilities when fetching large amounts of data. This services supports batching HTTP requests and streaming responses back. | 78 | 1 | 69 | 2 | @@ -34,33 +34,34 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [ResponseOps](https://github.com/orgs/elastic/teams/response-ops) | The Case management system in Kibana | 71 | 0 | 58 | 19 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | - | 321 | 2 | 288 | 4 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 28 | 0 | 23 | 0 | -| | [Cloud Security Posture](https://github.com/orgs/elastic/teams/cloud-posture-security) | The cloud security posture plugin | 6 | 0 | 6 | 0 | +| | [Cloud Security Posture](https://github.com/orgs/elastic/teams/cloud-posture-security) | The cloud security posture plugin | 14 | 0 | 14 | 0 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 13 | 0 | 13 | 1 | -| | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | The Controls Plugin contains embeddable components intended to create a simple query interface for end users, and a powerful editing suite that allows dashboard authors to build controls | 130 | 0 | 124 | 4 | -| | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 2370 | 15 | 969 | 33 | +| | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | The Controls Plugin contains embeddable components intended to create a simple query interface for end users, and a powerful editing suite that allows dashboard authors to build controls | 133 | 0 | 127 | 4 | +| | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 2374 | 15 | 969 | 33 | | crossClusterReplication | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 0 | 0 | 0 | 0 | | | [Fleet](https://github.com/orgs/elastic/teams/fleet) | Add custom data integrations so they can be displayed in the Fleet integrations app | 98 | 0 | 79 | 1 | -| | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds the Dashboard app to Kibana | 150 | 0 | 148 | 15 | +| | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds the Dashboard app to Kibana | 151 | 0 | 149 | 14 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | - | 52 | 0 | 51 | 0 | -| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Data services are useful for searching and querying data from Elasticsearch. Helpful utilities include: a re-usable react query bar, KQL autocomplete, async search, Data Views (Index Patterns) and field formatters. | 3419 | 40 | 2822 | 27 | +| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Data services are useful for searching and querying data from Elasticsearch. Helpful utilities include: a re-usable react query bar, KQL autocomplete, async search, Data Views (Index Patterns) and field formatters. | 3457 | 40 | 2844 | 27 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Enhanced data plugin. (See src/plugins/data.) Enhances the main data plugin with a search session management UI. Includes a reusable search session indicator component to use in other applications. Exposes routes for managing search sessions. Includes a service that monitors, updates, and cleans up search session saved objects. | 16 | 0 | 16 | 2 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | This plugin provides the ability to create data views via a modal flyout from any kibana app | 13 | 0 | 7 | 0 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Reusable data view field editor across Kibana | 42 | 0 | 37 | 3 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Data view management app | 2 | 0 | 2 | 0 | -| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Data services are useful for searching and querying data from Elasticsearch. Helpful utilities include: a re-usable react query bar, KQL autocomplete, async search, Data Views (Index Patterns) and field formatters. | 765 | 3 | 616 | 10 | +| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Data services are useful for searching and querying data from Elasticsearch. Helpful utilities include: a re-usable react query bar, KQL autocomplete, async search, Data Views (Index Patterns) and field formatters. | 863 | 3 | 711 | 15 | | | [Machine Learning UI](https://github.com/orgs/elastic/teams/ml-ui) | The Data Visualizer tools help you understand your data, by analyzing the metrics and fields in a log file or an existing Elasticsearch index. | 23 | 2 | 19 | 1 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 10 | 0 | 8 | 2 | | | [Data Discovery](https://github.com/orgs/elastic/teams/kibana-data-discovery) | This plugin contains the Discover application and the saved search embeddable. | 77 | 0 | 61 | 7 | | | [Data Discovery](https://github.com/orgs/elastic/teams/kibana-data-discovery) | - | 37 | 0 | 35 | 2 | -| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Adds embeddables service to Kibana | 471 | 0 | 384 | 5 | +| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Adds embeddables service to Kibana | 474 | 0 | 385 | 4 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Extends embeddable plugin with more functionality | 14 | 0 | 14 | 0 | | | [Platform Security](https://github.com/orgs/elastic/teams/kibana-security) | This plugin provides encryption and decryption utilities for saved objects containing sensitive information. | 48 | 0 | 44 | 0 | | | [Enterprise Search](https://github.com/orgs/elastic/teams/enterprise-search-frontend) | Adds dashboards for discovering and managing Enterprise Search products. | 2 | 0 | 2 | 0 | -| | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 110 | 3 | 106 | 3 | +| | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 112 | 3 | 108 | 3 | +| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | The Event Annotation service contains expressions for event annotations | 49 | 0 | 49 | 3 | | | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 91 | 0 | 91 | 9 | | | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds 'error' renderer to expressions | 17 | 0 | 15 | 2 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Expression Gauge plugin adds a `gauge` renderer and function to the expression plugin. The renderer will display the `gauge` chart. | 70 | 0 | 70 | 2 | -| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Expression Heatmap plugin adds a `heatmap` renderer and function to the expression plugin. The renderer will display the `heatmap` chart. | 118 | 0 | 114 | 3 | +| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Expression Heatmap plugin adds a `heatmap` renderer and function to the expression plugin. The renderer will display the `heatmap` chart. | 119 | 0 | 115 | 3 | | | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds 'image' function and renderer to expressions | 26 | 0 | 26 | 0 | | | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds 'metric' function and renderer to expressions | 32 | 0 | 27 | 0 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Expression MetricVis plugin adds a `metric` renderer and function to the expression plugin. The renderer will display the `metric` chart. | 46 | 0 | 46 | 1 | @@ -69,11 +70,11 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds 'revealImage' function and renderer to expressions | 14 | 0 | 14 | 3 | | | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds 'shape' function and renderer to expressions | 148 | 0 | 146 | 0 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Expression Tagcloud plugin adds a `tagcloud` renderer and function to the expression plugin. The renderer will display the `Wordcloud` chart. | 7 | 0 | 7 | 0 | -| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Adds expression runtime to Kibana | 2079 | 17 | 1632 | 4 | -| | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 222 | 0 | 98 | 2 | +| | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Adds expression runtime to Kibana | 2145 | 17 | 1701 | 6 | +| | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 222 | 0 | 95 | 2 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Index pattern fields and ambiguous values formatters | 286 | 6 | 247 | 3 | | | [Machine Learning UI](https://github.com/orgs/elastic/teams/ml-ui) | The file upload plugin contains components and services for uploading a file, analyzing its data, and then importing the data into an Elasticsearch index. Supported file types include CSV, TSV, newline-delimited JSON and GeoJSON. | 62 | 0 | 62 | 2 | -| | [Fleet](https://github.com/orgs/elastic/teams/fleet) | - | 1367 | 8 | 1250 | 9 | +| | [Fleet](https://github.com/orgs/elastic/teams/fleet) | - | 1371 | 8 | 1254 | 9 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 68 | 0 | 14 | 5 | | globalSearchBar | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 0 | 0 | 0 | 0 | | globalSearchProviders | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 0 | 0 | 0 | 0 | @@ -91,54 +92,54 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | - | 239 | 0 | 203 | 5 | | kibanaUsageCollection | [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetry) | - | 0 | 0 | 0 | 0 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | - | 615 | 3 | 420 | 9 | -| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Visualization editor allowing to quickly and easily configure compelling visualizations to use on dashboards and canvas workpads. Exposes components to embed visualizations and link into the Lens editor from within other apps in Kibana. | 395 | 0 | 343 | 43 | +| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Visualization editor allowing to quickly and easily configure compelling visualizations to use on dashboards and canvas workpads. Exposes components to embed visualizations and link into the Lens editor from within other apps in Kibana. | 438 | 0 | 363 | 44 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 8 | 0 | 8 | 0 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 3 | 0 | 3 | 0 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 117 | 0 | 42 | 10 | | | [Security detections response](https://github.com/orgs/elastic/teams/security-detections-response) | - | 198 | 0 | 162 | 49 | | logstash | [Logstash](https://github.com/orgs/elastic/teams/logstash) | - | 0 | 0 | 0 | 0 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | - | 41 | 0 | 41 | 6 | -| | [GIS](https://github.com/orgs/elastic/teams/kibana-gis) | - | 216 | 0 | 215 | 27 | +| | [GIS](https://github.com/orgs/elastic/teams/kibana-gis) | - | 220 | 0 | 219 | 27 | | | [GIS](https://github.com/orgs/elastic/teams/kibana-gis) | - | 67 | 0 | 67 | 0 | | | [Security solution](https://github.com/orgs/elastic/teams/security-solution) | - | 4 | 0 | 4 | 1 | | | [Machine Learning UI](https://github.com/orgs/elastic/teams/ml-ui) | This plugin provides access to the machine learning features provided by Elastic. | 196 | 8 | 79 | 30 | | | [Stack Monitoring](https://github.com/orgs/elastic/teams/stack-monitoring-ui) | - | 11 | 0 | 9 | 1 | -| | [Stack Monitoring](https://github.com/orgs/elastic/teams/stack-monitoring-ui) | - | 5 | 0 | 5 | 1 | +| | [Stack Monitoring](https://github.com/orgs/elastic/teams/stack-monitoring-ui) | - | 9 | 0 | 9 | 0 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | - | 34 | 0 | 34 | 2 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 17 | 0 | 17 | 0 | -| | [Observability UI](https://github.com/orgs/elastic/teams/observability-ui) | - | 358 | 2 | 355 | 30 | -| | [Security asset management](https://github.com/orgs/elastic/teams/security-asset-management) | - | 10 | 0 | 10 | 0 | +| | [Observability UI](https://github.com/orgs/elastic/teams/observability-ui) | - | 366 | 2 | 363 | 31 | +| | [Security asset management](https://github.com/orgs/elastic/teams/security-asset-management) | - | 13 | 0 | 13 | 0 | | painlessLab | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 0 | 0 | 0 | 0 | | | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | The Presentation Utility Plugin is a set of common, shared components and toolkits for solutions within the Presentation space, (e.g. Dashboards, Canvas). | 228 | 2 | 177 | 11 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 4 | 0 | 4 | 0 | | | [Kibana Reporting Services](https://github.com/orgs/elastic/teams/kibana-reporting-services) | Reporting Services enables applications to feature reports that the user can automate with Watcher and download later. | 36 | 0 | 16 | 0 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 21 | 0 | 21 | 0 | -| | [RAC](https://github.com/orgs/elastic/teams/rac) | - | 189 | 0 | 162 | 8 | +| | [RAC](https://github.com/orgs/elastic/teams/rac) | - | 191 | 0 | 164 | 8 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | - | 24 | 0 | 19 | 2 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 192 | 2 | 151 | 5 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 103 | 0 | 90 | 0 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 54 | 0 | 50 | 0 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 90 | 0 | 45 | 0 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | - | 33 | 0 | 14 | 0 | -| | [Kibana Reporting Services](https://github.com/orgs/elastic/teams/kibana-reporting-services) | Kibana Screenshotting Plugin | 18 | 0 | 8 | 5 | +| | [Kibana Reporting Services](https://github.com/orgs/elastic/teams/kibana-reporting-services) | Kibana Screenshotting Plugin | 24 | 0 | 12 | 5 | | searchprofiler | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 0 | 0 | 0 | 0 | | | [Platform Security](https://github.com/orgs/elastic/teams/kibana-security) | This plugin provides authentication and authorization features, and exposes functionality to understand the capabilities of the currently authenticated user. | 183 | 0 | 103 | 0 | | | [Security solution](https://github.com/orgs/elastic/teams/security-solution) | - | 45 | 0 | 45 | 18 | | sessionView | [Security Team](https://github.com/orgs/elastic/teams/security-team) | - | 0 | 0 | 0 | 0 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Adds URL Service and sharing capabilities to Kibana | 113 | 0 | 54 | 10 | -| | [Shared UX](https://github.com/orgs/elastic/teams/shared-ux) | A plugin providing components and services for shared user experiences in Kibana. | 14 | 0 | 0 | 1 | +| | [Shared UX](https://github.com/orgs/elastic/teams/shared-ux) | A plugin providing components and services for shared user experiences in Kibana. | 4 | 0 | 0 | 0 | | | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 21 | 1 | 21 | 1 | -| | [Platform Security](https://github.com/orgs/elastic/teams/kibana-security) | This plugin provides the Spaces feature, which allows saved objects to be organized into meaningful categories. | 256 | 0 | 63 | 0 | +| | [Platform Security](https://github.com/orgs/elastic/teams/kibana-security) | This plugin provides the Spaces feature, which allows saved objects to be organized into meaningful categories. | 259 | 0 | 64 | 0 | | | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 4 | 0 | 4 | 0 | -| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 71 | 0 | 33 | 7 | -| | [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetry) | - | 41 | 0 | 0 | 0 | +| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 77 | 0 | 39 | 7 | +| | [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetry) | - | 43 | 0 | 1 | 0 | | | [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetry) | - | 32 | 0 | 32 | 6 | | | [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetry) | - | 1 | 0 | 1 | 0 | | | [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetry) | - | 11 | 0 | 10 | 0 | | | [Security solution](https://github.com/orgs/elastic/teams/security-solution) | - | 435 | 1 | 331 | 35 | | | [Machine Learning UI](https://github.com/orgs/elastic/teams/ml-ui) | This plugin provides access to the transforms features provided by Elastic. Transforms enable you to convert existing Elasticsearch indices into summarized indices, which provide opportunities for new insights and analytics. | 4 | 0 | 4 | 1 | | translations | [Kibana Localization](https://github.com/orgs/elastic/teams/kibana-localization) | - | 0 | 0 | 0 | 0 | -| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 254 | 0 | 242 | 22 | +| | [Response Ops](https://github.com/orgs/elastic/teams/response-ops) | - | 300 | 0 | 286 | 22 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Adds UI Actions service to Kibana | 130 | 0 | 91 | 11 | | | [App Services](https://github.com/orgs/elastic/teams/kibana-app-services) | Extends UI Actions plugin with more functionality | 203 | 0 | 141 | 9 | | upgradeAssistant | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 0 | 0 | 0 | 0 | @@ -147,7 +148,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | - | 12 | 0 | 12 | 0 | | | [Kibana Core](https://github.com/orgs/elastic/teams/kibana-core) | - | 58 | 0 | 15 | 1 | | | [Uptime](https://github.com/orgs/elastic/teams/uptime) | - | 2 | 0 | 2 | 0 | -| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | The default editor used in most aggregation-based visualizations. | 57 | 0 | 50 | 3 | +| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | The default editor used in most aggregation-based visualizations. | 59 | 0 | 52 | 3 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Contains the gauge chart implementation using the elastic-charts library. The goal is to eventually deprecate the old implementation and keep only this. Until then, the library used is defined by the Legacy charts library advanced setting. | 7 | 0 | 7 | 2 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Contains the heatmap implementation using the elastic-charts library. The goal is to eventually deprecate the old implementation and keep only this. Until then, the library used is defined by the Legacy heatmap charts library advanced setting. | 3 | 0 | 3 | 2 | | visTypeMarkdown | [Kibana Presentation](https://github.com/orgs/elastic/teams/kibana-presentation) | Adds a markdown visualization type | 0 | 0 | 0 | 0 | @@ -160,7 +161,7 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Registers the vega visualization. Is the elastic version of vega and vega-lite libraries. | 2 | 0 | 2 | 0 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Contains the vislib visualizations. These are the classical area/line/bar, pie, gauge/goal and heatmap charts. We want to replace them with elastic-charts. | 26 | 0 | 25 | 1 | | | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Contains the new xy-axis chart using the elastic-charts library, which will eventually replace the vislib xy-axis charts including bar, area, and line. | 57 | 0 | 51 | 5 | -| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Contains the shared architecture among all the legacy visualizations, e.g. the visualization type registry or the visualization embeddable. | 361 | 12 | 340 | 14 | +| | [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Contains the shared architecture among all the legacy visualizations, e.g. the visualization type registry or the visualization embeddable. | 363 | 12 | 342 | 14 | | watcher | [Stack Management](https://github.com/orgs/elastic/teams/kibana-stack-management) | - | 0 | 0 | 0 | 0 | ## Package Directory @@ -174,16 +175,16 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | Ahmad Bamieh ahmadbamieh@gmail.com | Kibana Analytics tool | 69 | 0 | 69 | 2 | | | [Owner missing] | - | 16 | 0 | 16 | 0 | | | [Owner missing] | - | 11 | 0 | 11 | 0 | -| | [Owner missing] | - | 11 | 0 | 5 | 1 | +| | [Owner missing] | - | 12 | 0 | 5 | 1 | | | [Owner missing] | - | 2 | 0 | 2 | 0 | | | [Owner missing] | - | 66 | 0 | 46 | 2 | | | [Owner missing] | - | 125 | 3 | 123 | 17 | | | [Owner missing] | - | 13 | 0 | 7 | 0 | | | [Owner missing] | - | 286 | 3 | 207 | 1 | -| | [Owner missing] | - | 62 | 0 | 62 | 2 | +| | [Owner missing] | - | 63 | 0 | 63 | 2 | | | [Owner missing] | - | 1 | 0 | 1 | 0 | | | [Owner missing] | - | 27 | 0 | 14 | 1 | -| | [Owner missing] | - | 211 | 1 | 159 | 11 | +| | [Owner missing] | - | 213 | 1 | 159 | 11 | | | [Owner missing] | - | 20 | 0 | 16 | 0 | | | [Owner missing] | - | 1 | 0 | 0 | 0 | | | [Owner missing] | - | 51 | 0 | 48 | 0 | @@ -203,18 +204,22 @@ warning: This document is auto-generated and is meant to be viewed inside our ex | | [Owner missing] | security solution elastic search utilities to use across plugins such lists, security_solution, cases, etc... | 57 | 0 | 51 | 1 | | | [Owner missing] | Security Solution utilities for React hooks | 14 | 0 | 6 | 0 | | | [Owner missing] | io ts utilities and types to be shared with plugins from the security solution project | 148 | 0 | 129 | 0 | -| | [Owner missing] | io ts utilities and types to be shared with plugins from the security solution project | 460 | 1 | 448 | 0 | +| | [Owner missing] | io ts utilities and types to be shared with plugins from the security solution project | 458 | 1 | 446 | 0 | | | [Owner missing] | io ts utilities and types to be shared with plugins from the security solution project | 48 | 0 | 26 | 0 | | | [Owner missing] | io ts utilities and types to be shared with plugins from the security solution project | 28 | 0 | 21 | 0 | | | [Owner missing] | security solution list REST API | 59 | 0 | 58 | 0 | | | [Owner missing] | security solution list constants to use across plugins such lists, security_solution, cases, etc... | 26 | 0 | 12 | 0 | | | [Owner missing] | Security solution list ReactJS hooks | 56 | 0 | 44 | 0 | -| | [Owner missing] | security solution list utilities | 231 | 0 | 183 | 0 | +| | [Owner missing] | security solution list utilities | 226 | 0 | 178 | 0 | | | [Owner missing] | security solution rule utilities to use across plugins | 23 | 0 | 21 | 0 | | | [Owner missing] | security solution t-grid packages will allow sharing components between timelines and security_solution plugin until we transfer all functionality to timelines plugin | 120 | 0 | 116 | 0 | -| | [Owner missing] | security solution utilities to use across plugins such lists, security_solution, cases, etc... | 28 | 0 | 26 | 0 | +| | [Owner missing] | security solution utilities to use across plugins such lists, security_solution, cases, etc... | 31 | 0 | 29 | 0 | | | [Owner missing] | - | 53 | 0 | 50 | 1 | | | [Owner missing] | - | 25 | 0 | 24 | 1 | +| | [Owner missing] | - | 28 | 0 | 4 | 3 | +| | [Owner missing] | - | 67 | 0 | 43 | 0 | +| | [Owner missing] | - | 10 | 0 | 2 | 0 | +| | [Owner missing] | - | 9 | 0 | 3 | 0 | | | [Owner missing] | - | 96 | 1 | 63 | 2 | | | Operations | - | 22 | 2 | 21 | 0 | | | [Owner missing] | - | 2 | 0 | 2 | 0 | diff --git a/api_docs/presentation_util.mdx b/api_docs/presentation_util.mdx index 8ebe67f2f956b..4691da30a8ce6 100644 --- a/api_docs/presentation_util.mdx +++ b/api_docs/presentation_util.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/presentationUtil title: "presentationUtil" image: https://source.unsplash.com/400x175/?github summary: API docs for the presentationUtil plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'presentationUtil'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/remote_clusters.mdx b/api_docs/remote_clusters.mdx index 172b83224345d..b171535c6cddb 100644 --- a/api_docs/remote_clusters.mdx +++ b/api_docs/remote_clusters.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/remoteClusters title: "remoteClusters" image: https://source.unsplash.com/400x175/?github summary: API docs for the remoteClusters plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'remoteClusters'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/reporting.mdx b/api_docs/reporting.mdx index 0b4efacba2d98..a52845024c365 100644 --- a/api_docs/reporting.mdx +++ b/api_docs/reporting.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/reporting title: "reporting" image: https://source.unsplash.com/400x175/?github summary: API docs for the reporting plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'reporting'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/rollup.mdx b/api_docs/rollup.mdx index e865bf44b80f0..234a4b339feb4 100644 --- a/api_docs/rollup.mdx +++ b/api_docs/rollup.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/rollup title: "rollup" image: https://source.unsplash.com/400x175/?github summary: API docs for the rollup plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'rollup'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/rule_registry.devdocs.json b/api_docs/rule_registry.devdocs.json index d686c661579cd..5e68447c67923 100644 --- a/api_docs/rule_registry.devdocs.json +++ b/api_docs/rule_registry.devdocs.json @@ -1376,7 +1376,9 @@ }, ">) => Promise; id: string; name: string; validate?: { params?: ", "AlertTypeParamsValidator", - " | undefined; } | undefined; cancelAlertsOnRuleTimeout?: boolean | undefined; actionGroups: ", + " | undefined; } | undefined; cancelAlertsOnRuleTimeout?: boolean | undefined; config?: ", + "RuleTypeConfig", + " | undefined; actionGroups: ", { "pluginId": "alerting", "scope": "common", @@ -2484,6 +2486,36 @@ "deprecated": false } ] + }, + { + "parentPluginId": "ruleRegistry", + "id": "def-server.LifecycleAlertServices.getAlertStartedDate", + "type": "Function", + "tags": [], + "label": "getAlertStartedDate", + "description": [], + "signature": [ + "(alertId: string) => string | null" + ], + "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "ruleRegistry", + "id": "def-server.LifecycleAlertServices.getAlertStartedDate.$1", + "type": "string", + "tags": [], + "label": "alertId", + "description": [], + "signature": [ + "string" + ], + "path": "x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [] } ], "initialIsOpen": false diff --git a/api_docs/rule_registry.mdx b/api_docs/rule_registry.mdx index 21985f094b1ae..8307927128bb8 100644 --- a/api_docs/rule_registry.mdx +++ b/api_docs/rule_registry.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/ruleRegistry title: "ruleRegistry" image: https://source.unsplash.com/400x175/?github summary: API docs for the ruleRegistry plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ruleRegistry'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [RAC](https://github.com/orgs/elastic/teams/rac) for questions regarding | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 189 | 0 | 162 | 8 | +| 191 | 0 | 164 | 8 | ## Server diff --git a/api_docs/runtime_fields.mdx b/api_docs/runtime_fields.mdx index 91300db15bb8d..c625a3279da82 100644 --- a/api_docs/runtime_fields.mdx +++ b/api_docs/runtime_fields.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/runtimeFields title: "runtimeFields" image: https://source.unsplash.com/400x175/?github summary: API docs for the runtimeFields plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'runtimeFields'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/saved_objects.devdocs.json b/api_docs/saved_objects.devdocs.json index 976a464e0d987..91e85dae14f9c 100644 --- a/api_docs/saved_objects.devdocs.json +++ b/api_docs/saved_objects.devdocs.json @@ -577,6 +577,7 @@ ], "path": "src/plugins/saved_objects/public/save_modal/saved_object_save_modal.tsx", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "embeddable", @@ -1600,6 +1601,7 @@ "description": [], "path": "src/plugins/saved_objects/public/types.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "savedObjectsTaggingOss", @@ -1696,6 +1698,22 @@ { "plugin": "lens", "path": "x-pack/plugins/lens/public/persistence/saved_objects_utils/check_for_duplicate_title.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/check_for_duplicate_title.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/check_for_duplicate_title.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.d.ts" + }, + { + "plugin": "lens", + "path": "x-pack/plugins/lens/target/types/public/persistence/saved_objects_utils/display_duplicate_title_confirm_modal.d.ts" } ], "children": [ @@ -3166,6 +3184,7 @@ ], "path": "src/plugins/saved_objects/public/plugin.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "dashboard", @@ -3187,6 +3206,7 @@ ], "path": "src/plugins/saved_objects/public/plugin.ts", "deprecated": true, + "removeBy": "8.8.0", "references": [ { "plugin": "visualizations", diff --git a/api_docs/saved_objects.mdx b/api_docs/saved_objects.mdx index 8a2a6f5580d79..878c4ded28868 100644 --- a/api_docs/saved_objects.mdx +++ b/api_docs/saved_objects.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/savedObjects title: "savedObjects" image: https://source.unsplash.com/400x175/?github summary: API docs for the savedObjects plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjects'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/saved_objects_management.mdx b/api_docs/saved_objects_management.mdx index ddfd6ad386ffd..e6d074c598a41 100644 --- a/api_docs/saved_objects_management.mdx +++ b/api_docs/saved_objects_management.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/savedObjectsManagement title: "savedObjectsManagement" image: https://source.unsplash.com/400x175/?github summary: API docs for the savedObjectsManagement plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsManagement'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/saved_objects_tagging.mdx b/api_docs/saved_objects_tagging.mdx index 10904ca8cd0c3..e8968e608d2fd 100644 --- a/api_docs/saved_objects_tagging.mdx +++ b/api_docs/saved_objects_tagging.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/savedObjectsTagging title: "savedObjectsTagging" image: https://source.unsplash.com/400x175/?github summary: API docs for the savedObjectsTagging plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsTagging'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/saved_objects_tagging_oss.mdx b/api_docs/saved_objects_tagging_oss.mdx index f78ee85a89bb0..fb164203bf100 100644 --- a/api_docs/saved_objects_tagging_oss.mdx +++ b/api_docs/saved_objects_tagging_oss.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/savedObjectsTaggingOss title: "savedObjectsTaggingOss" image: https://source.unsplash.com/400x175/?github summary: API docs for the savedObjectsTaggingOss plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'savedObjectsTaggingOss'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/screenshot_mode.mdx b/api_docs/screenshot_mode.mdx index 19fc50c00a669..857f4433fc48d 100644 --- a/api_docs/screenshot_mode.mdx +++ b/api_docs/screenshot_mode.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/screenshotMode title: "screenshotMode" image: https://source.unsplash.com/400x175/?github summary: API docs for the screenshotMode plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'screenshotMode'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/screenshotting.devdocs.json b/api_docs/screenshotting.devdocs.json index 686b42fa6fcfa..fe79cd45375c2 100644 --- a/api_docs/screenshotting.devdocs.json +++ b/api_docs/screenshotting.devdocs.json @@ -14,60 +14,69 @@ "interfaces": [ { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotOptions", + "id": "def-server.PdfScreenshotOptions", "type": "Interface", "tags": [], - "label": "ScreenshotOptions", - "description": [], + "label": "PdfScreenshotOptions", + "description": [ + "\nOptions that should be provided to a PDF screenshot request." + ], "signature": [ { "pluginId": "screenshotting", "scope": "server", "docId": "kibScreenshottingPluginApi", - "section": "def-server.ScreenshotOptions", - "text": "ScreenshotOptions" + "section": "def-server.PdfScreenshotOptions", + "text": "PdfScreenshotOptions" }, " extends ", - "ScreenshotObservableOptions" + "ScreenshotOptions", + "<\"pdf\">" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", "deprecated": false, "children": [ { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotOptions.layout", - "type": "Object", + "id": "def-server.PdfScreenshotOptions.title", + "type": "string", "tags": [], - "label": "layout", + "label": "title", "description": [], "signature": [ - "{ id?: string | undefined; dimensions?: { width: number; height: number; } | undefined; selectors?: Partial<", - "LayoutSelectorDictionary", - "> | undefined; zoom?: number | undefined; }" + "string | undefined" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", "deprecated": false }, { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotOptions.request", + "id": "def-server.PdfScreenshotOptions.logo", + "type": "string", + "tags": [], + "label": "logo", + "description": [], + "signature": [ + "string | undefined" + ], + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", + "deprecated": false + }, + { + "parentPluginId": "screenshotting", + "id": "def-server.PdfScreenshotOptions.layout", "type": "Object", "tags": [], - "label": "request", + "label": "layout", "description": [ - "\nSource Kibana request object from where the headers will be extracted." + "\nWe default to the \"print\" layout if no ID is specified for the layout" ], "signature": [ - { - "pluginId": "core", - "scope": "server", - "docId": "kibCoreHttpPluginApi", - "section": "def-server.KibanaRequest", - "text": "KibanaRequest" - }, - " | undefined" + "{ id?: \"canvas\" | \"print\" | \"preserve_layout\" | undefined; dimensions?: { width: number; height: number; } | undefined; selectors?: Partial<", + "LayoutSelectorDictionary", + "> | undefined; zoom?: number | undefined; }" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", "deprecated": false } ], @@ -75,60 +84,146 @@ }, { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotResult", + "id": "def-server.PdfScreenshotResult", "type": "Interface", "tags": [], - "label": "ScreenshotResult", - "description": [], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "label": "PdfScreenshotResult", + "description": [ + "\nFinal, formatted PDF result" + ], + "signature": [ + { + "pluginId": "screenshotting", + "scope": "server", + "docId": "kibScreenshottingPluginApi", + "section": "def-server.PdfScreenshotResult", + "text": "PdfScreenshotResult" + }, + " extends Omit<", + { + "pluginId": "screenshotting", + "scope": "server", + "docId": "kibScreenshottingPluginApi", + "section": "def-server.FormattedScreenshotResult", + "text": "FormattedScreenshotResult" + }, + ", \"results\">" + ], + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", "deprecated": false, "children": [ { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotResult.layout", + "id": "def-server.PdfScreenshotResult.metrics", "type": "CompoundType", "tags": [], - "label": "layout", - "description": [ - "\nUsed layout instance constructed from the given options." - ], + "label": "metrics", + "description": [], "signature": [ - "BaseLayout", - " & LayoutSelectors & Partial<{ width: number; height: number; }>" + "PerformanceMetrics", + " & { pageCount: number; }" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", "deprecated": false }, { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotResult.metrics", + "id": "def-server.PdfScreenshotResult.result", "type": "Object", "tags": [], - "label": "metrics", - "description": [ - "\nCollected performance metrics during the screenshotting session." - ], + "label": "result", + "description": [], "signature": [ - "PerformanceMetrics", - " | undefined" + "{ data: Buffer; errors: Error[]; renderErrors: string[]; }" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "path": "x-pack/plugins/screenshotting/server/formats/pdf/index.ts", "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "screenshotting", + "id": "def-server.PngScreenshotOptions", + "type": "Interface", + "tags": [], + "label": "PngScreenshotOptions", + "description": [ + "\nOptions that should be provided to a screenshot PNG request" + ], + "signature": [ + { + "pluginId": "screenshotting", + "scope": "server", + "docId": "kibScreenshottingPluginApi", + "section": "def-server.PngScreenshotOptions", + "text": "PngScreenshotOptions" }, + " extends ", + "ScreenshotOptions", + "<\"png\">" + ], + "path": "x-pack/plugins/screenshotting/server/formats/png.ts", + "deprecated": false, + "children": [ { "parentPluginId": "screenshotting", - "id": "def-server.ScreenshotResult.results", - "type": "Array", + "id": "def-server.PngScreenshotOptions.layout", + "type": "Object", "tags": [], - "label": "results", - "description": [ - "\nScreenshotting results." + "label": "layout", + "description": [], + "signature": [ + "{ id?: \"preserve_layout\" | undefined; dimensions?: { width: number; height: number; } | undefined; selectors?: Partial<", + "LayoutSelectorDictionary", + "> | undefined; zoom?: number | undefined; }" ], + "path": "x-pack/plugins/screenshotting/server/formats/png.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "screenshotting", + "id": "def-server.PngScreenshotResult", + "type": "Interface", + "tags": [], + "label": "PngScreenshotResult", + "description": [ + "\nThe final output of a PNG screenshot" + ], + "signature": [ + { + "pluginId": "screenshotting", + "scope": "server", + "docId": "kibScreenshottingPluginApi", + "section": "def-server.PngScreenshotResult", + "text": "PngScreenshotResult" + }, + " extends ", + { + "pluginId": "screenshotting", + "scope": "server", + "docId": "kibScreenshottingPluginApi", + "section": "def-server.FormattedScreenshotResult", + "text": "FormattedScreenshotResult" + } + ], + "path": "x-pack/plugins/screenshotting/server/formats/png.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "screenshotting", + "id": "def-server.PngScreenshotResult.metadata", + "type": "Uncategorized", + "tags": [], + "label": "metadata", + "description": [], "signature": [ - "ScreenshotObservableResult", - "[]" + "undefined" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", + "path": "x-pack/plugins/screenshotting/server/formats/png.ts", "deprecated": false } ], @@ -137,6 +232,26 @@ ], "enums": [], "misc": [ + { + "parentPluginId": "screenshotting", + "id": "def-server.FormattedScreenshotResult", + "type": "Type", + "tags": [], + "label": "FormattedScreenshotResult", + "description": [ + "\nA general, overridable type of screenshot result\n\nPDF or PNG screenshots should extend this and convert the output to a type\nthat best suits their use cases.\n\nThis type documents what might appear on any given output type" + ], + "signature": [ + "{ metrics?: ", + "PerformanceMetrics", + " | undefined; results: ", + "ScreenshotObservableResult", + "[]; }" + ], + "path": "x-pack/plugins/screenshotting/server/formats/types.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "screenshotting", "id": "def-server.Layout", @@ -151,6 +266,20 @@ "path": "x-pack/plugins/screenshotting/server/layouts/index.ts", "deprecated": false, "initialIsOpen": false + }, + { + "parentPluginId": "screenshotting", + "id": "def-server.UrlOrUrlWithContext", + "type": "Type", + "tags": [], + "label": "UrlOrUrlWithContext", + "description": [], + "signature": [ + "string | UrlWithContext" + ], + "path": "x-pack/plugins/screenshotting/server/screenshots/observable.ts", + "deprecated": false, + "initialIsOpen": false } ], "objects": [], @@ -211,53 +340,64 @@ "\nTakes screenshots of multiple pages." ], "signature": [ - "(options: ", + " ", + " | ", + { + "pluginId": "screenshotting", + "scope": "server", + "docId": "kibScreenshottingPluginApi", + "section": "def-server.PngScreenshotOptions", + "text": "PngScreenshotOptions" + }, + ">(options: O) => ", "Observable", - "<", + "" ], "path": "x-pack/plugins/screenshotting/server/plugin.ts", "deprecated": false, - "returnComment": [ - "Observable with screenshotting results." - ], "children": [ { "parentPluginId": "screenshotting", "id": "def-server.ScreenshottingStart.getScreenshots.$1", - "type": "Object", + "type": "Uncategorized", "tags": [], "label": "options", "description": [ "Screenshots session options." ], "signature": [ - { - "pluginId": "screenshotting", - "scope": "server", - "docId": "kibScreenshottingPluginApi", - "section": "def-server.ScreenshotOptions", - "text": "ScreenshotOptions" - } + "O" ], - "path": "x-pack/plugins/screenshotting/server/screenshots/index.ts", - "deprecated": false + "path": "x-pack/plugins/screenshotting/server/plugin.ts", + "deprecated": false, + "isRequired": true } + ], + "returnComment": [ + "Observable with screenshotting results." ] } ], @@ -281,9 +421,15 @@ "\nScreenshot layout parameters." ], "signature": [ - "{ id?: string | undefined; dimensions?: { width: number; height: number; } | undefined; selectors?: Partial<", + "{ id?: ID | undefined; dimensions?: { width: number; height: number; } | undefined; selectors?: Partial<", + "LayoutSelectorDictionary", + "> | undefined; zoom?: number | undefined; } extends ", + "SerializableRecord", + " ? ", + "SerializableRecord", + " & { id?: ID | undefined; dimensions?: { width: number; height: number; } | undefined; selectors?: Partial<", "LayoutSelectorDictionary", - "> | undefined; zoom?: number | undefined; }" + "> | undefined; zoom?: number | undefined; } : never" ], "path": "x-pack/plugins/screenshotting/common/layout.ts", "deprecated": false, @@ -310,6 +456,9 @@ "tags": [], "label": "PRESERVE_LAYOUT", "description": [], + "signature": [ + "\"preserve_layout\"" + ], "path": "x-pack/plugins/screenshotting/common/layout.ts", "deprecated": false }, @@ -320,6 +469,9 @@ "tags": [], "label": "PRINT", "description": [], + "signature": [ + "\"print\"" + ], "path": "x-pack/plugins/screenshotting/common/layout.ts", "deprecated": false }, @@ -330,6 +482,9 @@ "tags": [], "label": "CANVAS", "description": [], + "signature": [ + "\"canvas\"" + ], "path": "x-pack/plugins/screenshotting/common/layout.ts", "deprecated": false } diff --git a/api_docs/screenshotting.mdx b/api_docs/screenshotting.mdx index c6382079375f3..bdfe8f9e3a3fd 100644 --- a/api_docs/screenshotting.mdx +++ b/api_docs/screenshotting.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/screenshotting title: "screenshotting" image: https://source.unsplash.com/400x175/?github summary: API docs for the screenshotting plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'screenshotting'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Reporting Services](https://github.com/orgs/elastic/teams/kibana | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 18 | 0 | 8 | 5 | +| 24 | 0 | 12 | 5 | ## Server diff --git a/api_docs/security.mdx b/api_docs/security.mdx index 75510a73fe6c5..3e9f3bdb1286b 100644 --- a/api_docs/security.mdx +++ b/api_docs/security.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/security title: "security" image: https://source.unsplash.com/400x175/?github summary: API docs for the security plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'security'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/security_solution.devdocs.json b/api_docs/security_solution.devdocs.json index 21a9c7aa21836..706ef53c378e9 100644 --- a/api_docs/security_solution.devdocs.json +++ b/api_docs/security_solution.devdocs.json @@ -62,7 +62,7 @@ "label": "experimentalFeatures", "description": [], "signature": [ - "{ readonly metricsEntitiesEnabled: boolean; readonly ruleRegistryEnabled: boolean; readonly tGridEnabled: boolean; readonly tGridEventRenderedViewEnabled: boolean; readonly excludePoliciesInFilterEnabled: boolean; readonly usersEnabled: boolean; readonly disableIsolationUIPendingStatuses: boolean; readonly riskyHostsEnabled: boolean; readonly securityRulesCancelEnabled: boolean; readonly pendingActionResponsesWithAck: boolean; readonly policyListEnabled: boolean; readonly previewTelemetryUrlEnabled: boolean; }" + "{ readonly metricsEntitiesEnabled: boolean; readonly ruleRegistryEnabled: boolean; readonly tGridEnabled: boolean; readonly tGridEventRenderedViewEnabled: boolean; readonly excludePoliciesInFilterEnabled: boolean; readonly usersEnabled: boolean; readonly detectionResponseEnabled: boolean; readonly disableIsolationUIPendingStatuses: boolean; readonly riskyHostsEnabled: boolean; readonly riskyUsersEnabled: boolean; readonly securityRulesCancelEnabled: boolean; readonly pendingActionResponsesWithAck: boolean; readonly policyListEnabled: boolean; readonly previewTelemetryUrlEnabled: boolean; readonly responseActionsConsoleEnabled: boolean; }" ], "path": "x-pack/plugins/security_solution/public/plugin.tsx", "deprecated": false @@ -887,7 +887,7 @@ "label": "ConfigType", "description": [], "signature": [ - "Readonly<{} & { signalsIndex: string; maxRuleImportExportSize: number; maxRuleImportPayloadBytes: number; maxTimelineImportExportSize: number; maxTimelineImportPayloadBytes: number; alertMergeStrategy: \"allFields\" | \"missingFields\" | \"noFields\"; alertIgnoreFields: string[]; enableExperimental: string[]; packagerTaskInterval: string; prebuiltRulesFromFileSystem: boolean; prebuiltRulesFromSavedObjects: boolean; }> & { experimentalFeatures: Readonly<{ metricsEntitiesEnabled: boolean; ruleRegistryEnabled: boolean; tGridEnabled: boolean; tGridEventRenderedViewEnabled: boolean; excludePoliciesInFilterEnabled: boolean; usersEnabled: boolean; disableIsolationUIPendingStatuses: boolean; riskyHostsEnabled: boolean; securityRulesCancelEnabled: boolean; pendingActionResponsesWithAck: boolean; policyListEnabled: boolean; previewTelemetryUrlEnabled: boolean; }>; }" + "Readonly<{} & { signalsIndex: string; maxRuleImportExportSize: number; maxRuleImportPayloadBytes: number; maxTimelineImportExportSize: number; maxTimelineImportPayloadBytes: number; alertMergeStrategy: \"allFields\" | \"missingFields\" | \"noFields\"; alertIgnoreFields: string[]; enableExperimental: string[]; packagerTaskInterval: string; prebuiltRulesFromFileSystem: boolean; prebuiltRulesFromSavedObjects: boolean; }> & { experimentalFeatures: Readonly<{ metricsEntitiesEnabled: boolean; ruleRegistryEnabled: boolean; tGridEnabled: boolean; tGridEventRenderedViewEnabled: boolean; excludePoliciesInFilterEnabled: boolean; usersEnabled: boolean; detectionResponseEnabled: boolean; disableIsolationUIPendingStatuses: boolean; riskyHostsEnabled: boolean; riskyUsersEnabled: boolean; securityRulesCancelEnabled: boolean; pendingActionResponsesWithAck: boolean; policyListEnabled: boolean; previewTelemetryUrlEnabled: boolean; responseActionsConsoleEnabled: boolean; }>; }" ], "path": "x-pack/plugins/security_solution/server/config.ts", "deprecated": false, diff --git a/api_docs/security_solution.mdx b/api_docs/security_solution.mdx index 51f4c27031529..49d1378275f3f 100644 --- a/api_docs/security_solution.mdx +++ b/api_docs/security_solution.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/securitySolution title: "securitySolution" image: https://source.unsplash.com/400x175/?github summary: API docs for the securitySolution plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'securitySolution'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/share.mdx b/api_docs/share.mdx index d655e7f08a1d3..c37fd16141cea 100644 --- a/api_docs/share.mdx +++ b/api_docs/share.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/share title: "share" image: https://source.unsplash.com/400x175/?github summary: API docs for the share plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'share'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/shared_u_x.devdocs.json b/api_docs/shared_u_x.devdocs.json index dbcd1b5d825c5..948d6b212ebf8 100644 --- a/api_docs/shared_u_x.devdocs.json +++ b/api_docs/shared_u_x.devdocs.json @@ -2,148 +2,7 @@ "id": "sharedUX", "client": { "classes": [], - "functions": [ - { - "parentPluginId": "sharedUX", - "id": "def-public.ExitFullScreenButton", - "type": "Function", - "tags": [], - "label": "ExitFullScreenButton", - "description": [ - "\nA `ExitFullScreenButton` component that is wrapped by the `withSuspense` HOC. This component can\nbe used directly by consumers and will load the `LazyExitFullScreenButton` component lazily with\na predefined fallback and error boundary." - ], - "signature": [ - "React.ForwardRefExoticComponent<", - "Props", - " & React.RefAttributes<{}>>" - ], - "path": "src/plugins/shared_ux/public/components/index.ts", - "deprecated": false, - "returnComment": [], - "children": [ - { - "parentPluginId": "sharedUX", - "id": "def-public.ExitFullScreenButton.$1", - "type": "Uncategorized", - "tags": [], - "label": "props", - "description": [], - "signature": [ - "P" - ], - "path": "node_modules/@types/react/index.d.ts", - "deprecated": false - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "sharedUX", - "id": "def-public.LazyExitFullScreenButton", - "type": "Function", - "tags": [], - "label": "LazyExitFullScreenButton", - "description": [ - "\nThe Lazily-loaded `ExitFullScreenButton` component. Consumers should use `React.Suspennse` or the\n`withSuspense` HOC to load this component." - ], - "signature": [ - "React.ExoticComponent<", - "Props", - "> & { readonly _result: ({ onExit, toggleChrome }: ", - "Props", - ") => JSX.Element; }" - ], - "path": "src/plugins/shared_ux/public/components/index.ts", - "deprecated": false, - "returnComment": [], - "children": [ - { - "parentPluginId": "sharedUX", - "id": "def-public.LazyExitFullScreenButton.$1", - "type": "Uncategorized", - "tags": [], - "label": "props", - "description": [], - "signature": [ - "P" - ], - "path": "node_modules/@types/react/index.d.ts", - "deprecated": false - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "sharedUX", - "id": "def-public.LazyNoDataViewsPage", - "type": "Function", - "tags": [], - "label": "LazyNoDataViewsPage", - "description": [ - "\nThe Lazily-loaded `NoDataViews` component. Consumers should use `React.Suspennse` or the\n`withSuspense` HOC to load this component." - ], - "signature": [ - "React.ExoticComponent<", - "Props", - "> & { readonly _result: ({ onDataViewCreated, dataViewsDocLink }: ", - "Props", - ") => JSX.Element; }" - ], - "path": "src/plugins/shared_ux/public/components/index.ts", - "deprecated": false, - "returnComment": [], - "children": [ - { - "parentPluginId": "sharedUX", - "id": "def-public.LazyNoDataViewsPage.$1", - "type": "Uncategorized", - "tags": [], - "label": "props", - "description": [], - "signature": [ - "P" - ], - "path": "node_modules/@types/react/index.d.ts", - "deprecated": false - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "sharedUX", - "id": "def-public.NoDataViewsPage", - "type": "Function", - "tags": [], - "label": "NoDataViewsPage", - "description": [ - "\nA `NoDataViewsPage` component that is wrapped by the `withSuspense` HOC. This component can\nbe used directly by consumers and will load the `LazyNoDataViewsPage` component lazily with\na predefined fallback and error boundary." - ], - "signature": [ - "React.ForwardRefExoticComponent<", - "Props", - " & React.RefAttributes<{}>>" - ], - "path": "src/plugins/shared_ux/public/components/index.ts", - "deprecated": false, - "returnComment": [], - "children": [ - { - "parentPluginId": "sharedUX", - "id": "def-public.NoDataViewsPage.$1", - "type": "Uncategorized", - "tags": [], - "label": "props", - "description": [], - "signature": [ - "P" - ], - "path": "node_modules/@types/react/index.d.ts", - "deprecated": false - } - ], - "initialIsOpen": false - } - ], + "functions": [], "interfaces": [], "enums": [], "misc": [], @@ -162,47 +21,21 @@ "children": [ { "parentPluginId": "sharedUX", - "id": "def-public.SharedUXPluginStart.ServicesContext", + "id": "def-public.SharedUXPluginStart.getContextServices", "type": "Function", "tags": [], - "label": "ServicesContext", + "label": "getContextServices", "description": [ - "\nA React component that provides a pre-wired `React.Context` which connects components to Shared UX services." + "\nA set of pre-wired services for use with `SharedUxServicesProvider`.\n\n```\nimport { SharedUxServicesProvider } from '@kbn/shared-ux-services';\n\npublic start(coreStart: CoreStart, startPlugins: MyPluginStartDeps): MyPluginStart {\n const services = startPlugins.sharedUX.getContextServices();\n return {\n ServicesContext: ({ children }) => {children},\n };\n}\n```\n\nor\n\n```\nimport { SharedUxServicesProvider } from '@kbn/shared-ux-services';\n\npublic setup(coreSetup: CoreSetup, setupPlugins: MyPluginSetupDeps): MyPluginSetup {\n const [coreStart, startPlugins] = await coreSetup.getStartServices();\n coreSetup.application.register({\n mount: async (params: AppMountParameters) => {\n ReactDOM.render(\n \n \n ,\n params.element\n );\n }\n );\n}\n```" ], "signature": [ - "React.FunctionComponent<{}>" + "() => ", + "SharedUxServices" ], "path": "src/plugins/shared_ux/public/types/index.ts", "deprecated": false, - "returnComment": [], - "children": [ - { - "parentPluginId": "sharedUX", - "id": "def-public.SharedUXPluginStart.ServicesContext.$1", - "type": "CompoundType", - "tags": [], - "label": "props", - "description": [], - "signature": [ - "P & { children?: React.ReactNode; }" - ], - "path": "node_modules/@types/react/index.d.ts", - "deprecated": false - }, - { - "parentPluginId": "sharedUX", - "id": "def-public.SharedUXPluginStart.ServicesContext.$2", - "type": "Any", - "tags": [], - "label": "context", - "description": [], - "signature": [ - "any" - ], - "path": "node_modules/@types/react/index.d.ts", - "deprecated": false - } - ] + "children": [], + "returnComment": [] } ], "lifecycle": "start", diff --git a/api_docs/shared_u_x.mdx b/api_docs/shared_u_x.mdx index 4da4b7a356cef..7646bb835d30f 100644 --- a/api_docs/shared_u_x.mdx +++ b/api_docs/shared_u_x.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/sharedUX title: "sharedUX" image: https://source.unsplash.com/400x175/?github summary: API docs for the sharedUX plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'sharedUX'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,16 +18,13 @@ Contact [Shared UX](https://github.com/orgs/elastic/teams/shared-ux) for questio | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 14 | 0 | 0 | 1 | +| 4 | 0 | 0 | 0 | ## Client ### Start -### Functions - - ## Common ### Consts, variables and types diff --git a/api_docs/snapshot_restore.mdx b/api_docs/snapshot_restore.mdx index 6cfe040b28e67..25cf5d3b0cf56 100644 --- a/api_docs/snapshot_restore.mdx +++ b/api_docs/snapshot_restore.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/snapshotRestore title: "snapshotRestore" image: https://source.unsplash.com/400x175/?github summary: API docs for the snapshotRestore plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'snapshotRestore'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/spaces.devdocs.json b/api_docs/spaces.devdocs.json index 3d1f4cd9ee260..2474be31bef20 100644 --- a/api_docs/spaces.devdocs.json +++ b/api_docs/spaces.devdocs.json @@ -1180,6 +1180,63 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "spaces", + "id": "def-public.RedirectLegacyUrlParams", + "type": "Interface", + "tags": [], + "label": "RedirectLegacyUrlParams", + "description": [ + "\nParameters for the redirectLegacyUrl function." + ], + "path": "x-pack/plugins/spaces/public/legacy_urls/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "spaces", + "id": "def-public.RedirectLegacyUrlParams.path", + "type": "string", + "tags": [], + "label": "path", + "description": [ + "\nThe path to use for the new URL, optionally including `search` and/or `hash` URL components." + ], + "path": "x-pack/plugins/spaces/public/legacy_urls/types.ts", + "deprecated": false + }, + { + "parentPluginId": "spaces", + "id": "def-public.RedirectLegacyUrlParams.aliasPurpose", + "type": "CompoundType", + "tags": [], + "label": "aliasPurpose", + "description": [ + "\nThe reason the resolved alias was created.\n\nThis is used to determine whether or not a toast should be shown when a user is redirected from a legacy URL; if the alias was created\nbecause of saved object conversion, then we will display a toast telling the user that the object has a new URL." + ], + "signature": [ + "\"savedObjectConversion\" | \"savedObjectImport\" | undefined" + ], + "path": "x-pack/plugins/spaces/public/legacy_urls/types.ts", + "deprecated": false + }, + { + "parentPluginId": "spaces", + "id": "def-public.RedirectLegacyUrlParams.objectNoun", + "type": "string", + "tags": [], + "label": "objectNoun", + "description": [ + "\nThe string that is used to describe the object in the toast, e.g., _The **object** you're looking for has a new location_.\nDefault value is 'object'." + ], + "signature": [ + "string | undefined" + ], + "path": "x-pack/plugins/spaces/public/legacy_urls/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, { "parentPluginId": "spaces", "id": "def-public.ShareToSpaceFlyoutProps", @@ -1916,10 +1973,18 @@ "tags": [], "label": "redirectLegacyUrl", "description": [ - "\nRedirect the user from a legacy URL to a new URL. This needs to be used if a call to `SavedObjectsClient.resolve()` results in an\n`\"aliasMatch\"` outcome, which indicates that the user has loaded the page using a legacy URL. Calling this function will trigger a\nclient-side redirect to the new URL, and it will display a toast to the user.\n\nConsumers need to determine the local path for the new URL on their own, based on the object ID that was used to call\n`SavedObjectsClient.resolve()` (old ID) and the object ID in the result (new ID). For example...\n\nThe old object ID is `workpad-123` and the new object ID is `workpad-e08b9bdb-ec14-4339-94c4-063bddfd610e`.\n\nFull legacy URL: `https://localhost:5601/app/canvas#/workpad/workpad-123/page/1`\n\nNew URL path: `#/workpad/workpad-e08b9bdb-ec14-4339-94c4-063bddfd610e/page/1`\n\nThe protocol, hostname, port, base path, and app path are automatically included.\n" + "\nRedirect the user from a legacy URL to a new URL. This needs to be used if a call to `SavedObjectsClient.resolve()` results in an\n`\"aliasMatch\"` outcome, which indicates that the user has loaded the page using a legacy URL. Calling this function will trigger a\nclient-side redirect to the new URL, and it will display a toast to the user.\n\nConsumers need to determine the local path for the new URL on their own, based on the object ID that was used to call\n`SavedObjectsClient.resolve()` (old ID) and the object ID in the result (new ID). For example...\n\nThe old object ID is `workpad-123` and the new object ID is `workpad-e08b9bdb-ec14-4339-94c4-063bddfd610e`.\n\nFull legacy URL: `https://localhost:5601/app/canvas#/workpad/workpad-123/page/1`\n\nNew URL path: `#/workpad/workpad-e08b9bdb-ec14-4339-94c4-063bddfd610e/page/1`\n\nThe protocol, hostname, port, base path, and app path are automatically included." ], "signature": [ - "(path: string, objectNoun?: string | undefined) => Promise" + "(params: ", + { + "pluginId": "spaces", + "scope": "public", + "docId": "kibSpacesPluginApi", + "section": "def-public.RedirectLegacyUrlParams", + "text": "RedirectLegacyUrlParams" + }, + ") => Promise" ], "path": "x-pack/plugins/spaces/public/ui_api/types.ts", "deprecated": false, @@ -1927,34 +1992,22 @@ { "parentPluginId": "spaces", "id": "def-public.SpacesApiUi.redirectLegacyUrl.$1", - "type": "string", + "type": "Object", "tags": [], - "label": "path", - "description": [ - "The path to use for the new URL, optionally including `search` and/or `hash` URL components." - ], + "label": "params", + "description": [], "signature": [ - "string" + { + "pluginId": "spaces", + "scope": "public", + "docId": "kibSpacesPluginApi", + "section": "def-public.RedirectLegacyUrlParams", + "text": "RedirectLegacyUrlParams" + } ], "path": "x-pack/plugins/spaces/public/ui_api/types.ts", "deprecated": false, "isRequired": true - }, - { - "parentPluginId": "spaces", - "id": "def-public.SpacesApiUi.redirectLegacyUrl.$2", - "type": "string", - "tags": [], - "label": "objectNoun", - "description": [ - "The string that is used to describe the object in the toast, e.g., _The **object** you're looking for has a new\nlocation_. Default value is 'object'." - ], - "signature": [ - "string | undefined" - ], - "path": "x-pack/plugins/spaces/public/ui_api/types.ts", - "deprecated": false, - "isRequired": false } ], "returnComment": [] diff --git a/api_docs/spaces.mdx b/api_docs/spaces.mdx index 9ec06434b6df9..34612eea43396 100644 --- a/api_docs/spaces.mdx +++ b/api_docs/spaces.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/spaces title: "spaces" image: https://source.unsplash.com/400x175/?github summary: API docs for the spaces plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'spaces'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Platform Security](https://github.com/orgs/elastic/teams/kibana-securit | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 256 | 0 | 63 | 0 | +| 259 | 0 | 64 | 0 | ## Client diff --git a/api_docs/stack_alerts.mdx b/api_docs/stack_alerts.mdx index 4b1945020f425..121383562c498 100644 --- a/api_docs/stack_alerts.mdx +++ b/api_docs/stack_alerts.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/stackAlerts title: "stackAlerts" image: https://source.unsplash.com/400x175/?github summary: API docs for the stackAlerts plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'stackAlerts'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/task_manager.devdocs.json b/api_docs/task_manager.devdocs.json index 791fb94b6ffac..2782bb48ff857 100644 --- a/api_docs/task_manager.devdocs.json +++ b/api_docs/task_manager.devdocs.json @@ -1130,7 +1130,84 @@ "initialIsOpen": false } ], - "objects": [], + "objects": [ + { + "parentPluginId": "taskManager", + "id": "def-server.IdleTaskWithExpiredRunAt", + "type": "Object", + "tags": [], + "label": "IdleTaskWithExpiredRunAt", + "description": [], + "path": "x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "taskManager", + "id": "def-server.IdleTaskWithExpiredRunAt.bool", + "type": "Object", + "tags": [], + "label": "bool", + "description": [], + "path": "x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "taskManager", + "id": "def-server.IdleTaskWithExpiredRunAt.bool.must", + "type": "Array", + "tags": [], + "label": "must", + "description": [], + "signature": [ + "({ term: { 'task.status': string; }; } | { range: { 'task.runAt': { lte: string; }; }; })[]" + ], + "path": "x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts", + "deprecated": false + } + ] + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "taskManager", + "id": "def-server.RunningOrClaimingTaskWithExpiredRetryAt", + "type": "Object", + "tags": [], + "label": "RunningOrClaimingTaskWithExpiredRetryAt", + "description": [], + "path": "x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "taskManager", + "id": "def-server.RunningOrClaimingTaskWithExpiredRetryAt.bool", + "type": "Object", + "tags": [], + "label": "bool", + "description": [], + "path": "x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "taskManager", + "id": "def-server.RunningOrClaimingTaskWithExpiredRetryAt.bool.must", + "type": "Array", + "tags": [], + "label": "must", + "description": [], + "signature": [ + "({ bool: { should: { term: { 'task.status': string; }; }[]; }; } | { range: { 'task.retryAt': { lte: string; }; }; })[]" + ], + "path": "x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts", + "deprecated": false + } + ] + } + ], + "initialIsOpen": false + } + ], "setup": { "parentPluginId": "taskManager", "id": "def-server.TaskManagerSetupContract", diff --git a/api_docs/task_manager.mdx b/api_docs/task_manager.mdx index 9e8058aab1bf7..d25c4da817e6f 100644 --- a/api_docs/task_manager.mdx +++ b/api_docs/task_manager.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/taskManager title: "taskManager" image: https://source.unsplash.com/400x175/?github summary: API docs for the taskManager plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'taskManager'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Response Ops](https://github.com/orgs/elastic/teams/response-ops) for q | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 71 | 0 | 33 | 7 | +| 77 | 0 | 39 | 7 | ## Server @@ -28,6 +28,9 @@ Contact [Response Ops](https://github.com/orgs/elastic/teams/response-ops) for q ### Start +### Objects + + ### Functions diff --git a/api_docs/telemetry.devdocs.json b/api_docs/telemetry.devdocs.json index f11cd70523645..33ac6a757d48f 100644 --- a/api_docs/telemetry.devdocs.json +++ b/api_docs/telemetry.devdocs.json @@ -4,6 +4,38 @@ "classes": [], "functions": [], "interfaces": [ + { + "parentPluginId": "telemetry", + "id": "def-public.TelemetryConstants", + "type": "Interface", + "tags": [], + "label": "TelemetryConstants", + "description": [ + "\nPublic's start exposed APIs by the telemetry plugin" + ], + "path": "src/plugins/telemetry/public/plugin.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "telemetry", + "id": "def-public.TelemetryConstants.getPrivacyStatementUrl", + "type": "Function", + "tags": [], + "label": "getPrivacyStatementUrl", + "description": [ + "Elastic's privacy statement url" + ], + "signature": [ + "() => string" + ], + "path": "src/plugins/telemetry/public/plugin.ts", + "deprecated": false, + "children": [], + "returnComment": [] + } + ], + "initialIsOpen": false + }, { "parentPluginId": "telemetry", "id": "def-public.TelemetryPluginConfig", @@ -269,9 +301,7 @@ "type": "Interface", "tags": [], "label": "TelemetryPluginStart", - "description": [ - "\nPublic's start exposed APIs by the telemetry plugin" - ], + "description": [], "path": "src/plugins/telemetry/public/plugin.ts", "deprecated": false, "children": [ @@ -321,7 +351,13 @@ "Set of publicly exposed telemetry constants" ], "signature": [ - "{ getPrivacyStatementUrl: () => string; }" + { + "pluginId": "telemetry", + "scope": "public", + "docId": "kibTelemetryPluginApi", + "section": "def-public.TelemetryConstants", + "text": "TelemetryConstants" + } ], "path": "src/plugins/telemetry/public/plugin.ts", "deprecated": false diff --git a/api_docs/telemetry.mdx b/api_docs/telemetry.mdx index 9f2bf68b728bb..416652d7757e3 100644 --- a/api_docs/telemetry.mdx +++ b/api_docs/telemetry.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/telemetry title: "telemetry" image: https://source.unsplash.com/400x175/?github summary: API docs for the telemetry plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetry'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Kibana Telemetry](https://github.com/orgs/elastic/teams/kibana-telemetr | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 41 | 0 | 0 | 0 | +| 43 | 0 | 1 | 0 | ## Client diff --git a/api_docs/telemetry_collection_manager.mdx b/api_docs/telemetry_collection_manager.mdx index 9ac19c1156fb5..9cb2118638de7 100644 --- a/api_docs/telemetry_collection_manager.mdx +++ b/api_docs/telemetry_collection_manager.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/telemetryCollectionManager title: "telemetryCollectionManager" image: https://source.unsplash.com/400x175/?github summary: API docs for the telemetryCollectionManager plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetryCollectionManager'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/telemetry_collection_xpack.mdx b/api_docs/telemetry_collection_xpack.mdx index 97bd93a1b481b..63e017a0ecba9 100644 --- a/api_docs/telemetry_collection_xpack.mdx +++ b/api_docs/telemetry_collection_xpack.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/telemetryCollectionXpack title: "telemetryCollectionXpack" image: https://source.unsplash.com/400x175/?github summary: API docs for the telemetryCollectionXpack plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetryCollectionXpack'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/telemetry_management_section.mdx b/api_docs/telemetry_management_section.mdx index 05fefbb5efd32..a3b33a115f576 100644 --- a/api_docs/telemetry_management_section.mdx +++ b/api_docs/telemetry_management_section.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/telemetryManagementSection title: "telemetryManagementSection" image: https://source.unsplash.com/400x175/?github summary: API docs for the telemetryManagementSection plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'telemetryManagementSection'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/timelines.mdx b/api_docs/timelines.mdx index 95127f842b366..2d10c70b8c02b 100644 --- a/api_docs/timelines.mdx +++ b/api_docs/timelines.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/timelines title: "timelines" image: https://source.unsplash.com/400x175/?github summary: API docs for the timelines plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'timelines'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/transform.mdx b/api_docs/transform.mdx index ecce2a27fc8e9..37168131c88eb 100644 --- a/api_docs/transform.mdx +++ b/api_docs/transform.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/transform title: "transform" image: https://source.unsplash.com/400x175/?github summary: API docs for the transform plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'transform'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/triggers_actions_ui.devdocs.json b/api_docs/triggers_actions_ui.devdocs.json index 4f6ad8125e34c..121f164fb040d 100644 --- a/api_docs/triggers_actions_ui.devdocs.json +++ b/api_docs/triggers_actions_ui.devdocs.json @@ -46,6 +46,19 @@ "path": "x-pack/plugins/triggers_actions_ui/public/plugin.ts", "deprecated": false, "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.Plugin.experimentalFeatures", + "type": "Object", + "tags": [], + "label": "experimentalFeatures", + "description": [], + "signature": [ + "{ readonly rulesListDatagrid: boolean; readonly rulesDetailLogs: boolean; }" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/plugin.ts", + "deprecated": false + }, { "parentPluginId": "triggersActionsUi", "id": "def-public.Plugin.Unnamed", @@ -58,7 +71,29 @@ ], "path": "x-pack/plugins/triggers_actions_ui/public/plugin.ts", "deprecated": false, - "children": [], + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.Plugin.Unnamed.$1", + "type": "Object", + "tags": [], + "label": "ctx", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "public", + "docId": "kibCorePluginApi", + "section": "def-public.PluginInitializerContext", + "text": "PluginInitializerContext" + }, + "" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/plugin.ts", + "deprecated": false, + "isRequired": true + } + ], "returnComment": [] }, { @@ -341,6 +376,207 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.deleteRules", + "type": "Function", + "tags": [], + "label": "deleteRules", + "description": [], + "signature": [ + "({\n ids,\n http,\n}: { ids: string[]; http: ", + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + }, + "; }) => Promise<{ successes: string[]; errors: string[]; }>" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/delete.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.deleteRules.$1", + "type": "Object", + "tags": [], + "label": "{\n ids,\n http,\n}", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/delete.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.deleteRules.$1.ids", + "type": "Array", + "tags": [], + "label": "ids", + "description": [], + "signature": [ + "string[]" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/delete.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.deleteRules.$1.http", + "type": "Object", + "tags": [], + "label": "http", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + } + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/delete.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.disableRule", + "type": "Function", + "tags": [], + "label": "disableRule", + "description": [], + "signature": [ + "({ id, http }: { id: string; http: ", + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + }, + "; }) => Promise" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/disable.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.disableRule.$1", + "type": "Object", + "tags": [], + "label": "{ id, http }", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/disable.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.disableRule.$1.id", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/disable.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.disableRule.$1.http", + "type": "Object", + "tags": [], + "label": "http", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + } + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/disable.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.enableRule", + "type": "Function", + "tags": [], + "label": "enableRule", + "description": [], + "signature": [ + "({ id, http }: { id: string; http: ", + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + }, + "; }) => Promise" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/enable.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.enableRule.$1", + "type": "Object", + "tags": [], + "label": "{ id, http }", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/enable.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.enableRule.$1.id", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/enable.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.enableRule.$1.http", + "type": "Object", + "tags": [], + "label": "http", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + } + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/enable.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "triggersActionsUi", "id": "def-public.ForLastExpression", @@ -989,6 +1225,72 @@ "returnComment": [], "initialIsOpen": false }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.muteRule", + "type": "Function", + "tags": [], + "label": "muteRule", + "description": [], + "signature": [ + "({ id, http }: { id: string; http: ", + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + }, + "; }) => Promise" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/mute.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.muteRule.$1", + "type": "Object", + "tags": [], + "label": "{ id, http }", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/mute.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.muteRule.$1.id", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/mute.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.muteRule.$1.http", + "type": "Object", + "tags": [], + "label": "http", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + } + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/mute.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "triggersActionsUi", "id": "def-public.OfExpression", @@ -1053,6 +1355,119 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.unmuteRule", + "type": "Function", + "tags": [], + "label": "unmuteRule", + "description": [], + "signature": [ + "({ id, http }: { id: string; http: ", + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + }, + "; }) => Promise" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/unmute.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.unmuteRule.$1", + "type": "Object", + "tags": [], + "label": "{ id, http }", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/unmute.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.unmuteRule.$1.id", + "type": "string", + "tags": [], + "label": "id", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/unmute.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.unmuteRule.$1.http", + "type": "Object", + "tags": [], + "label": "http", + "description": [], + "signature": [ + { + "pluginId": "core", + "scope": "public", + "docId": "kibCoreHttpPluginApi", + "section": "def-public.HttpSetup", + "text": "HttpSetup" + } + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/unmute.ts", + "deprecated": false + } + ] + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.useLoadRuleTypes", + "type": "Function", + "tags": [], + "label": "useLoadRuleTypes", + "description": [], + "signature": [ + "({ filteredSolutions }: RuleTypesProps) => { ruleTypes: ", + { + "pluginId": "triggersActionsUi", + "scope": "public", + "docId": "kibTriggersActionsUiPluginApi", + "section": "def-public.RuleType", + "text": "RuleType" + }, + "[]; error: string | null; ruleTypeIndex: ", + { + "pluginId": "triggersActionsUi", + "scope": "public", + "docId": "kibTriggersActionsUiPluginApi", + "section": "def-public.RuleTypeIndex", + "text": "RuleTypeIndex" + }, + "; }" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/hooks/use_load_rule_types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.useLoadRuleTypes.$1", + "type": "Object", + "tags": [], + "label": "{ filteredSolutions }", + "description": [], + "signature": [ + "RuleTypesProps" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/application/hooks/use_load_rule_types.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "triggersActionsUi", "id": "def-public.ValueExpression", @@ -1319,88 +1734,259 @@ "children": [ { "parentPluginId": "triggersActionsUi", - "id": "def-public.Comparator.text", + "id": "def-public.Comparator.text", + "type": "string", + "tags": [], + "label": "text", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.Comparator.value", + "type": "string", + "tags": [], + "label": "value", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.Comparator.requiredValues", + "type": "number", + "tags": [], + "label": "requiredValues", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.GroupByType", + "type": "Interface", + "tags": [], + "label": "GroupByType", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.GroupByType.text", + "type": "string", + "tags": [], + "label": "text", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.GroupByType.sizeRequired", + "type": "boolean", + "tags": [], + "label": "sizeRequired", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.GroupByType.value", + "type": "string", + "tags": [], + "label": "value", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.GroupByType.validNormalizedTypes", + "type": "Array", + "tags": [], + "label": "validNormalizedTypes", + "description": [], + "signature": [ + "string[]" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.IErrorObject", + "type": "Interface", + "tags": [], + "label": "IErrorObject", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.IErrorObject.Unnamed", + "type": "IndexSignature", + "tags": [], + "label": "[key: string]: string | string[] | IErrorObject", + "description": [], + "signature": [ + "[key: string]: string | string[] | ", + { + "pluginId": "triggersActionsUi", + "scope": "public", + "docId": "kibTriggersActionsUiPluginApi", + "section": "def-public.IErrorObject", + "text": "IErrorObject" + } + ], + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.IOption", + "type": "Interface", + "tags": [], + "label": "IOption", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/index_controls/index.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.IOption.label", + "type": "string", + "tags": [], + "label": "label", + "description": [], + "path": "x-pack/plugins/triggers_actions_ui/public/common/index_controls/index.ts", + "deprecated": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.IOption.options", + "type": "Array", + "tags": [], + "label": "options", + "description": [], + "signature": [ + "{ value: string; label: string; }[]" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/common/index_controls/index.ts", + "deprecated": false + } + ], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.RuleTableItem", + "type": "Interface", + "tags": [], + "label": "RuleTableItem", + "description": [], + "signature": [ + { + "pluginId": "triggersActionsUi", + "scope": "public", + "docId": "kibTriggersActionsUiPluginApi", + "section": "def-public.RuleTableItem", + "text": "RuleTableItem" + }, + " extends ", + { + "pluginId": "triggersActionsUi", + "scope": "public", + "docId": "kibTriggersActionsUiPluginApi", + "section": "def-public.Rule", + "text": "Rule" + }, + "<", + { + "pluginId": "alerting", + "scope": "common", + "docId": "kibAlertingPluginApi", + "section": "def-common.AlertTypeParams", + "text": "AlertTypeParams" + }, + ">" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.RuleTableItem.ruleType", "type": "string", "tags": [], - "label": "text", + "label": "ruleType", "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.Comparator.value", - "type": "string", + "id": "def-public.RuleTableItem.index", + "type": "number", "tags": [], - "label": "value", + "label": "index", "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.Comparator.requiredValues", + "id": "def-public.RuleTableItem.actionsCount", "type": "number", "tags": [], - "label": "requiredValues", - "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", - "deprecated": false - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "triggersActionsUi", - "id": "def-public.GroupByType", - "type": "Interface", - "tags": [], - "label": "GroupByType", - "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", - "deprecated": false, - "children": [ - { - "parentPluginId": "triggersActionsUi", - "id": "def-public.GroupByType.text", - "type": "string", - "tags": [], - "label": "text", + "label": "actionsCount", "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.GroupByType.sizeRequired", + "id": "def-public.RuleTableItem.isEditable", "type": "boolean", "tags": [], - "label": "sizeRequired", + "label": "isEditable", "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.GroupByType.value", - "type": "string", + "id": "def-public.RuleTableItem.enabledInLicense", + "type": "boolean", "tags": [], - "label": "value", + "label": "enabledInLicense", "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.GroupByType.validNormalizedTypes", - "type": "Array", + "id": "def-public.RuleTableItem.showIntervalWarning", + "type": "CompoundType", "tags": [], - "label": "validNormalizedTypes", + "label": "showIntervalWarning", "description": [], "signature": [ - "string[]" + "boolean | undefined" ], - "path": "x-pack/plugins/triggers_actions_ui/public/common/types.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false } ], @@ -1408,68 +1994,66 @@ }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.IErrorObject", + "id": "def-public.RuleType", "type": "Interface", "tags": [], - "label": "IErrorObject", + "label": "RuleType", "description": [], + "signature": [ + { + "pluginId": "triggersActionsUi", + "scope": "public", + "docId": "kibTriggersActionsUiPluginApi", + "section": "def-public.RuleType", + "text": "RuleType" + }, + " extends Pick<", + { + "pluginId": "alerting", + "scope": "common", + "docId": "kibAlertingPluginApi", + "section": "def-common.RuleType", + "text": "RuleType" + }, + ", \"id\" | \"name\" | \"actionGroups\" | \"defaultActionGroupId\" | \"recoveryActionGroup\" | \"producer\" | \"minimumLicenseRequired\" | \"defaultScheduleInterval\" | \"ruleTaskTimeout\" | \"doesSetRecoveryContext\">" + ], "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false, "children": [ { "parentPluginId": "triggersActionsUi", - "id": "def-public.IErrorObject.Unnamed", - "type": "IndexSignature", + "id": "def-public.RuleType.actionVariables", + "type": "CompoundType", "tags": [], - "label": "[key: string]: string | string[] | IErrorObject", + "label": "actionVariables", "description": [], "signature": [ - "[key: string]: string | string[] | ", - { - "pluginId": "triggersActionsUi", - "scope": "public", - "docId": "kibTriggersActionsUiPluginApi", - "section": "def-public.IErrorObject", - "text": "IErrorObject" - } + "AsActionVariables<\"params\"> & Partial>" ], "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false - } - ], - "initialIsOpen": false - }, - { - "parentPluginId": "triggersActionsUi", - "id": "def-public.IOption", - "type": "Interface", - "tags": [], - "label": "IOption", - "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/index_controls/index.ts", - "deprecated": false, - "children": [ + }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.IOption.label", - "type": "string", + "id": "def-public.RuleType.authorizedConsumers", + "type": "Object", "tags": [], - "label": "label", + "label": "authorizedConsumers", "description": [], - "path": "x-pack/plugins/triggers_actions_ui/public/common/index_controls/index.ts", + "signature": [ + "{ [x: string]: { read: boolean; all: boolean; }; }" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false }, { "parentPluginId": "triggersActionsUi", - "id": "def-public.IOption.options", - "type": "Array", + "id": "def-public.RuleType.enabledInLicense", + "type": "boolean", "tags": [], - "label": "options", + "label": "enabledInLicense", "description": [], - "signature": [ - "{ value: string; label: string; }[]" - ], - "path": "x-pack/plugins/triggers_actions_ui/public/common/index_controls/index.ts", + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", "deprecated": false } ], @@ -1764,7 +2348,7 @@ "label": "setRuleProperty", "description": [], "signature": [ - "(key: Prop, value: ", + "(key: Prop, value: ", "SanitizedRule", "[Prop] | null) => void" ], @@ -2445,6 +3029,28 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-public.RuleTypeIndex", + "type": "Type", + "tags": [], + "label": "RuleTypeIndex", + "description": [], + "signature": [ + "Map>" + ], + "path": "x-pack/plugins/triggers_actions_ui/public/types.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "triggersActionsUi", "id": "def-public.RuleTypeRegistryContract", @@ -3890,7 +4496,121 @@ }, "common": { "classes": [], - "functions": [], + "functions": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.getExperimentalAllowedValues", + "type": "Function", + "tags": [], + "label": "getExperimentalAllowedValues", + "description": [], + "signature": [ + "() => string[]" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "children": [], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.isValidExperimentalValue", + "type": "Function", + "tags": [], + "label": "isValidExperimentalValue", + "description": [], + "signature": [ + "(value: string) => boolean" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.isValidExperimentalValue.$1", + "type": "string", + "tags": [], + "label": "value", + "description": [], + "signature": [ + "string" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.parseExperimentalConfigValue", + "type": "Function", + "tags": [ + "throws" + ], + "label": "parseExperimentalConfigValue", + "description": [ + "\nParses the string value used in `xpack.triggersActionsUi.enableExperimental` kibana configuration,\nwhich should be a string of values delimited by a comma (`,`)\n" + ], + "signature": [ + "(configValue: string[]) => Readonly<{ rulesListDatagrid: boolean; rulesDetailLogs: boolean; }>" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.parseExperimentalConfigValue.$1", + "type": "Array", + "tags": [], + "label": "configValue", + "description": [], + "signature": [ + "string[]" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.parseInterval", + "type": "Function", + "tags": [], + "label": "parseInterval", + "description": [], + "signature": [ + "(intervalString: string) => { value: number; unit: string; }" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/parse_interval.ts", + "deprecated": false, + "children": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.parseInterval.$1", + "type": "string", + "tags": [], + "label": "intervalString", + "description": [], + "signature": [ + "string" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/parse_interval.ts", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + } + ], "interfaces": [ { "parentPluginId": "triggersActionsUi", @@ -3985,6 +4705,20 @@ "deprecated": false, "initialIsOpen": false }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.ExperimentalFeatures", + "type": "Type", + "tags": [], + "label": "ExperimentalFeatures", + "description": [], + "signature": [ + "{ readonly rulesListDatagrid: boolean; readonly rulesDetailLogs: boolean; }" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "initialIsOpen": false + }, { "parentPluginId": "triggersActionsUi", "id": "def-common.MetricResult", @@ -4000,6 +4734,37 @@ "initialIsOpen": false } ], - "objects": [] + "objects": [ + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.allowedExperimentalValues", + "type": "Object", + "tags": [], + "label": "allowedExperimentalValues", + "description": [ + "\nA list of allowed values that can be used in `xpack.triggersActionsUi.enableExperimental`.\nThis object is then used to validate and parse the value entered." + ], + "signature": [ + "{ readonly rulesListDatagrid: boolean; readonly rulesDetailLogs: boolean; }" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/experimental_features.ts", + "deprecated": false, + "initialIsOpen": false + }, + { + "parentPluginId": "triggersActionsUi", + "id": "def-common.INTERVAL_STRING_RE", + "type": "Object", + "tags": [], + "label": "INTERVAL_STRING_RE", + "description": [], + "signature": [ + "RegExp" + ], + "path": "x-pack/plugins/triggers_actions_ui/common/parse_interval.ts", + "deprecated": false, + "initialIsOpen": false + } + ] } } \ No newline at end of file diff --git a/api_docs/triggers_actions_ui.mdx b/api_docs/triggers_actions_ui.mdx index ca4b28f3644fc..b8aac1303ac8d 100644 --- a/api_docs/triggers_actions_ui.mdx +++ b/api_docs/triggers_actions_ui.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/triggersActionsUi title: "triggersActionsUi" image: https://source.unsplash.com/400x175/?github summary: API docs for the triggersActionsUi plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'triggersActionsUi'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Response Ops](https://github.com/orgs/elastic/teams/response-ops) for q | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 254 | 0 | 242 | 22 | +| 300 | 0 | 286 | 22 | ## Client @@ -62,6 +62,12 @@ Contact [Response Ops](https://github.com/orgs/elastic/teams/response-ops) for q ## Common +### Objects + + +### Functions + + ### Interfaces diff --git a/api_docs/ui_actions.devdocs.json b/api_docs/ui_actions.devdocs.json index 51c99237e0909..925dfa5a64c1a 100644 --- a/api_docs/ui_actions.devdocs.json +++ b/api_docs/ui_actions.devdocs.json @@ -685,6 +685,10 @@ { "plugin": "embeddable", "path": "src/plugins/embeddable/public/tests/explicit_input.test.ts" + }, + { + "plugin": "discover", + "path": "src/plugins/discover/target/types/public/embeddable/search_embeddable_factory.d.ts" } ], "children": [ diff --git a/api_docs/ui_actions.mdx b/api_docs/ui_actions.mdx index a96aca857757e..e2a861f53c4d1 100644 --- a/api_docs/ui_actions.mdx +++ b/api_docs/ui_actions.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/uiActions title: "uiActions" image: https://source.unsplash.com/400x175/?github summary: API docs for the uiActions plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'uiActions'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/ui_actions_enhanced.mdx b/api_docs/ui_actions_enhanced.mdx index 9dc29447217c5..48a419e4e2841 100644 --- a/api_docs/ui_actions_enhanced.mdx +++ b/api_docs/ui_actions_enhanced.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/uiActionsEnhanced title: "uiActionsEnhanced" image: https://source.unsplash.com/400x175/?github summary: API docs for the uiActionsEnhanced plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'uiActionsEnhanced'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/url_forwarding.mdx b/api_docs/url_forwarding.mdx index 5fa7035e7f8a2..775a66736f19d 100644 --- a/api_docs/url_forwarding.mdx +++ b/api_docs/url_forwarding.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/urlForwarding title: "urlForwarding" image: https://source.unsplash.com/400x175/?github summary: API docs for the urlForwarding plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'urlForwarding'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/usage_collection.mdx b/api_docs/usage_collection.mdx index d61831e2db521..a4c064a44905a 100644 --- a/api_docs/usage_collection.mdx +++ b/api_docs/usage_collection.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/usageCollection title: "usageCollection" image: https://source.unsplash.com/400x175/?github summary: API docs for the usageCollection plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'usageCollection'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/ux.mdx b/api_docs/ux.mdx index 6548986fb52c7..001e652bfd190 100644 --- a/api_docs/ux.mdx +++ b/api_docs/ux.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/ux title: "ux" image: https://source.unsplash.com/400x175/?github summary: API docs for the ux plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'ux'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_default_editor.devdocs.json b/api_docs/vis_default_editor.devdocs.json index f073badd0ffd1..31fe2478171c1 100644 --- a/api_docs/vis_default_editor.devdocs.json +++ b/api_docs/vis_default_editor.devdocs.json @@ -430,6 +430,37 @@ ], "initialIsOpen": false }, + { + "parentPluginId": "visDefaultEditor", + "id": "def-public.LegendSizeSettings", + "type": "Function", + "tags": [], + "label": "LegendSizeSettings", + "description": [], + "signature": [ + "({ legendSize, onLegendSizeChange, isVerticalLegend, }: LegendSizeSettingsProps) => JSX.Element" + ], + "path": "src/plugins/vis_default_editor/public/components/options/legend_size_settings.tsx", + "deprecated": false, + "children": [ + { + "parentPluginId": "visDefaultEditor", + "id": "def-public.LegendSizeSettings.$1", + "type": "Object", + "tags": [], + "label": "{\n legendSize,\n onLegendSizeChange,\n isVerticalLegend,\n}", + "description": [], + "signature": [ + "LegendSizeSettingsProps" + ], + "path": "src/plugins/vis_default_editor/public/components/options/legend_size_settings.tsx", + "deprecated": false, + "isRequired": true + } + ], + "returnComment": [], + "initialIsOpen": false + }, { "parentPluginId": "visDefaultEditor", "id": "def-public.LongLegendOptions", diff --git a/api_docs/vis_default_editor.mdx b/api_docs/vis_default_editor.mdx index 72157baf87189..92aca2d65f47d 100644 --- a/api_docs/vis_default_editor.mdx +++ b/api_docs/vis_default_editor.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visDefaultEditor title: "visDefaultEditor" image: https://source.unsplash.com/400x175/?github summary: API docs for the visDefaultEditor plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visDefaultEditor'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 57 | 0 | 50 | 3 | +| 59 | 0 | 52 | 3 | ## Client diff --git a/api_docs/vis_type_gauge.mdx b/api_docs/vis_type_gauge.mdx index 31540c950b00f..05737040dd35e 100644 --- a/api_docs/vis_type_gauge.mdx +++ b/api_docs/vis_type_gauge.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeGauge title: "visTypeGauge" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeGauge plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeGauge'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_heatmap.mdx b/api_docs/vis_type_heatmap.mdx index b8ce1d142b4a0..ae82999310286 100644 --- a/api_docs/vis_type_heatmap.mdx +++ b/api_docs/vis_type_heatmap.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeHeatmap title: "visTypeHeatmap" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeHeatmap plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeHeatmap'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_pie.mdx b/api_docs/vis_type_pie.mdx index 954746c6c0955..71f55f6c12403 100644 --- a/api_docs/vis_type_pie.mdx +++ b/api_docs/vis_type_pie.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypePie title: "visTypePie" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypePie plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypePie'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_table.mdx b/api_docs/vis_type_table.mdx index 4bd021990cb71..9b76ee3081a07 100644 --- a/api_docs/vis_type_table.mdx +++ b/api_docs/vis_type_table.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeTable title: "visTypeTable" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeTable plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeTable'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_timelion.mdx b/api_docs/vis_type_timelion.mdx index 0e38b472141cb..2c1b45b1a9561 100644 --- a/api_docs/vis_type_timelion.mdx +++ b/api_docs/vis_type_timelion.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeTimelion title: "visTypeTimelion" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeTimelion plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeTimelion'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_timeseries.mdx b/api_docs/vis_type_timeseries.mdx index 1462af010e66a..f0db6193a0678 100644 --- a/api_docs/vis_type_timeseries.mdx +++ b/api_docs/vis_type_timeseries.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeTimeseries title: "visTypeTimeseries" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeTimeseries plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeTimeseries'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_vega.mdx b/api_docs/vis_type_vega.mdx index 0f3d2d7cc1729..8954d4256c605 100644 --- a/api_docs/vis_type_vega.mdx +++ b/api_docs/vis_type_vega.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeVega title: "visTypeVega" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeVega plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeVega'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_vislib.mdx b/api_docs/vis_type_vislib.mdx index 45f074545e8f6..d7a00a728cb19 100644 --- a/api_docs/vis_type_vislib.mdx +++ b/api_docs/vis_type_vislib.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeVislib title: "visTypeVislib" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeVislib plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeVislib'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/vis_type_xy.mdx b/api_docs/vis_type_xy.mdx index 507a6a1d96a5a..93013f5c62201 100644 --- a/api_docs/vis_type_xy.mdx +++ b/api_docs/vis_type_xy.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visTypeXy title: "visTypeXy" image: https://source.unsplash.com/400x175/?github summary: API docs for the visTypeXy plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visTypeXy'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- diff --git a/api_docs/visualizations.devdocs.json b/api_docs/visualizations.devdocs.json index f7b0988824623..a6f758e30e8a4 100644 --- a/api_docs/visualizations.devdocs.json +++ b/api_docs/visualizations.devdocs.json @@ -303,16 +303,16 @@ "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" + "section": "def-common.DataView", + "text": "DataView" }, "[] | Promise<", { "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" + "section": "def-common.DataView", + "text": "DataView" }, "[]>) | undefined" ], @@ -1257,7 +1257,7 @@ "section": "def-common.Dimension", "text": "Dimension" }, - "[]) => { columns: { meta: { dimensionName: string | undefined; type: ", + "[], removeUnmappedColumns?: boolean) => { columns: { meta: { dimensionName: string | undefined; type: ", { "pluginId": "expressions", "scope": "common", @@ -1283,7 +1283,9 @@ }, "> | undefined; source?: string | undefined; sourceParams?: ", "SerializableRecord", - " | undefined; }; id: string; name: string; }[]; type: \"datatable\"; rows: ", + " | undefined; }; id: string; name: string; }[]; type: \"datatable\"; meta?: ", + "DatatableMeta", + " | undefined; rows: ", { "pluginId": "expressions", "scope": "common", @@ -1336,6 +1338,20 @@ "path": "src/plugins/visualizations/common/utils/prepare_log_table.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "visualizations", + "id": "def-public.prepareLogTable.$3", + "type": "boolean", + "tags": [], + "label": "removeUnmappedColumns", + "description": [], + "signature": [ + "boolean" + ], + "path": "src/plugins/visualizations/common/utils/prepare_log_table.ts", + "deprecated": false, + "isRequired": true } ], "returnComment": [], @@ -2009,7 +2025,7 @@ "label": "sharingSavedObjectProps", "description": [], "signature": [ - "{ outcome?: \"conflict\" | \"aliasMatch\" | \"exactMatch\" | undefined; aliasTargetId?: string | undefined; errorJSON?: string | undefined; } | undefined" + "{ outcome?: \"exactMatch\" | \"aliasMatch\" | \"conflict\" | undefined; aliasTargetId?: string | undefined; aliasPurpose?: \"savedObjectConversion\" | \"savedObjectImport\" | undefined; errorJSON?: string | undefined; } | undefined" ], "path": "src/plugins/visualizations/public/types.ts", "deprecated": false @@ -2688,8 +2704,8 @@ "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" + "section": "def-common.DataView", + "text": "DataView" }, " | undefined" ], @@ -3659,16 +3675,16 @@ "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" + "section": "def-common.DataView", + "text": "DataView" }, "[] | Promise<", { "pluginId": "dataViews", "scope": "common", "docId": "kibDataViewsPluginApi", - "section": "def-common.IndexPattern", - "text": "IndexPattern" + "section": "def-common.DataView", + "text": "DataView" }, "[]>) | undefined" ], @@ -6091,7 +6107,7 @@ "section": "def-common.Dimension", "text": "Dimension" }, - "[]) => { columns: { meta: { dimensionName: string | undefined; type: ", + "[], removeUnmappedColumns?: boolean) => { columns: { meta: { dimensionName: string | undefined; type: ", { "pluginId": "expressions", "scope": "common", @@ -6117,7 +6133,9 @@ }, "> | undefined; source?: string | undefined; sourceParams?: ", "SerializableRecord", - " | undefined; }; id: string; name: string; }[]; type: \"datatable\"; rows: ", + " | undefined; }; id: string; name: string; }[]; type: \"datatable\"; meta?: ", + "DatatableMeta", + " | undefined; rows: ", { "pluginId": "expressions", "scope": "common", @@ -6170,6 +6188,20 @@ "path": "src/plugins/visualizations/common/utils/prepare_log_table.ts", "deprecated": false, "isRequired": true + }, + { + "parentPluginId": "visualizations", + "id": "def-common.prepareLogTable.$3", + "type": "boolean", + "tags": [], + "label": "removeUnmappedColumns", + "description": [], + "signature": [ + "boolean" + ], + "path": "src/plugins/visualizations/common/utils/prepare_log_table.ts", + "deprecated": false, + "isRequired": true } ], "returnComment": [], diff --git a/api_docs/visualizations.mdx b/api_docs/visualizations.mdx index 91c05270d676a..2adf19201ea08 100644 --- a/api_docs/visualizations.mdx +++ b/api_docs/visualizations.mdx @@ -4,7 +4,7 @@ slug: /kibana-dev-docs/api/visualizations title: "visualizations" image: https://source.unsplash.com/400x175/?github summary: API docs for the visualizations plugin -date: 2022-03-15 +date: 2022-03-28 tags: ['contributor', 'dev', 'apidocs', 'kibana', 'visualizations'] warning: This document is auto-generated and is meant to be viewed inside our experimental, new docs system. Reach out in #docs-engineering for more info. --- @@ -18,7 +18,7 @@ Contact [Vis Editors](https://github.com/orgs/elastic/teams/kibana-vis-editors) | Public API count | Any count | Items lacking comments | Missing exports | |-------------------|-----------|------------------------|-----------------| -| 361 | 12 | 340 | 14 | +| 363 | 12 | 342 | 14 | ## Client From 7f4735f4d375f4ea136effaf625edc16cb5d88b4 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Mon, 28 Mar 2022 19:33:52 +0100 Subject: [PATCH 046/160] fix(NA): use a single step for yarn kbn bootstrap (#128657) * fix(NA): use a single step for yarn kbn bootstrap * chore(NA): additional error message to warn around new integration * chore(NA): additional error message to warn around new integration --- .buildkite/scripts/bootstrap.sh | 2 +- packages/kbn-pm/dist/index.js | 22 +++---------------- packages/kbn-pm/src/commands/bootstrap.ts | 14 +++--------- packages/kbn-pm/src/utils/bazel/run.ts | 3 +++ .../kbn-pm/src/utils/bazel/yarn_integrity.ts | 16 -------------- 5 files changed, 10 insertions(+), 47 deletions(-) diff --git a/.buildkite/scripts/bootstrap.sh b/.buildkite/scripts/bootstrap.sh index 413c56e2e8109..34461ca6db194 100755 --- a/.buildkite/scripts/bootstrap.sh +++ b/.buildkite/scripts/bootstrap.sh @@ -15,7 +15,7 @@ if ! yarn kbn bootstrap; then rm -rf node_modules echo "--- yarn install and bootstrap, attempt 2" - yarn kbn bootstrap + yarn kbn bootstrap --force-install fi if [[ "$DISABLE_BOOTSTRAP_VALIDATION" != "true" ]]; then diff --git a/packages/kbn-pm/dist/index.js b/packages/kbn-pm/dist/index.js index b086f398faea4..5c1403494e944 100644 --- a/packages/kbn-pm/dist/index.js +++ b/packages/kbn-pm/dist/index.js @@ -8921,11 +8921,10 @@ const BootstrapCommand = { ms: Date.now() - start }); } - }; // Force install is set in case a flag is passed into yarn kbn bootstrap or if the `.yarn-integrity` - // file is not found which will be indicated by the return of yarnIntegrityFileExists. + }; // Force install is set in case a flag is passed into yarn kbn bootstrap - const forceInstall = !!options && options['force-install'] === true || !(await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["yarnIntegrityFileExists"])(Object(path__WEBPACK_IMPORTED_MODULE_0__["resolve"])(kibanaProjectPath, 'node_modules'))); // Install bazel machinery tools if needed + const forceInstall = !!options && options['force-install'] === true; // Install bazel machinery tools if needed await Object(_utils_bazel__WEBPACK_IMPORTED_MODULE_9__["installBazelTools"])(rootPath); // Setup remote cache settings in .bazelrc.cache if needed @@ -52669,8 +52668,6 @@ __webpack_require__.r(__webpack_exports__); /* harmony import */ var _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(527); /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "removeYarnIntegrityFileIfExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__["removeYarnIntegrityFileIfExists"]; }); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "yarnIntegrityFileExists", function() { return _yarn_integrity__WEBPACK_IMPORTED_MODULE_3__["yarnIntegrityFileExists"]; }); - /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License @@ -52896,6 +52893,7 @@ async function runBazelCommandWithRunner(bazelCommandRunner, bazelArgs, offline try { await bazelProc; } catch { + _log__WEBPACK_IMPORTED_MODULE_5__["log"].error('HINT: If experiencing problems with node_modules try `yarn kbn bootstrap --force-install` or as last resort `yarn kbn reset && yarn kbn bootstrap`'); throw new _errors__WEBPACK_IMPORTED_MODULE_6__["CliError"](`The bazel command that was running failed to complete.`); } @@ -59103,7 +59101,6 @@ function observeReadable(readable) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeYarnIntegrityFileIfExists", function() { return removeYarnIntegrityFileIfExists; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "yarnIntegrityFileExists", function() { return yarnIntegrityFileExists; }); /* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4); /* harmony import */ var path__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _fs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(231); @@ -59127,19 +59124,6 @@ async function removeYarnIntegrityFileIfExists(nodeModulesPath) { } catch {// no-op } } -async function yarnIntegrityFileExists(nodeModulesPath) { - try { - const nodeModulesRealPath = await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["tryRealpath"])(nodeModulesPath); - const yarnIntegrityFilePath = Object(path__WEBPACK_IMPORTED_MODULE_0__["join"])(nodeModulesRealPath, '.yarn-integrity'); // check if the file already exists - - if (await Object(_fs__WEBPACK_IMPORTED_MODULE_1__["isFile"])(yarnIntegrityFilePath)) { - return true; - } - } catch {// no-op - } - - return false; -} /***/ }), /* 528 */ diff --git a/packages/kbn-pm/src/commands/bootstrap.ts b/packages/kbn-pm/src/commands/bootstrap.ts index 7b5c8c2b6b37d..51577df6c3b87 100644 --- a/packages/kbn-pm/src/commands/bootstrap.ts +++ b/packages/kbn-pm/src/commands/bootstrap.ts @@ -17,12 +17,7 @@ import { ICommand } from './'; import { readYarnLock } from '../utils/yarn_lock'; import { sortPackageJson } from '../utils/sort_package_json'; import { validateDependencies } from '../utils/validate_dependencies'; -import { - installBazelTools, - removeYarnIntegrityFileIfExists, - runBazel, - yarnIntegrityFileExists, -} from '../utils/bazel'; +import { installBazelTools, removeYarnIntegrityFileIfExists, runBazel } from '../utils/bazel'; import { setupRemoteCache } from '../utils/bazel/setup_remote_cache'; export const BootstrapCommand: ICommand = { @@ -54,11 +49,8 @@ export const BootstrapCommand: ICommand = { } }; - // Force install is set in case a flag is passed into yarn kbn bootstrap or if the `.yarn-integrity` - // file is not found which will be indicated by the return of yarnIntegrityFileExists. - const forceInstall = - (!!options && options['force-install'] === true) || - !(await yarnIntegrityFileExists(resolve(kibanaProjectPath, 'node_modules'))); + // Force install is set in case a flag is passed into yarn kbn bootstrap + const forceInstall = !!options && options['force-install'] === true; // Install bazel machinery tools if needed await installBazelTools(rootPath); diff --git a/packages/kbn-pm/src/utils/bazel/run.ts b/packages/kbn-pm/src/utils/bazel/run.ts index c030081e53daa..18a6cacdf6d2a 100644 --- a/packages/kbn-pm/src/utils/bazel/run.ts +++ b/packages/kbn-pm/src/utils/bazel/run.ts @@ -52,6 +52,9 @@ async function runBazelCommandWithRunner( try { await bazelProc; } catch { + log.error( + 'HINT: If experiencing problems with node_modules try `yarn kbn bootstrap --force-install` or as last resort `yarn kbn reset && yarn kbn bootstrap`' + ); throw new CliError(`The bazel command that was running failed to complete.`); } await bazelLogs$.toPromise(); diff --git a/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts b/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts index 76910786898aa..1ac9bfeba1e3b 100644 --- a/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts +++ b/packages/kbn-pm/src/utils/bazel/yarn_integrity.ts @@ -22,19 +22,3 @@ export async function removeYarnIntegrityFileIfExists(nodeModulesPath: string) { // no-op } } - -export async function yarnIntegrityFileExists(nodeModulesPath: string) { - try { - const nodeModulesRealPath = await tryRealpath(nodeModulesPath); - const yarnIntegrityFilePath = join(nodeModulesRealPath, '.yarn-integrity'); - - // check if the file already exists - if (await isFile(yarnIntegrityFilePath)) { - return true; - } - } catch { - // no-op - } - - return false; -} From 68a2b7f27d0ee7f113c4e34e162103e635ef87a9 Mon Sep 17 00:00:00 2001 From: Jonathan Budzenski Date: Mon, 28 Mar 2022 13:39:18 -0500 Subject: [PATCH 047/160] [ci] bump memory for webpack bundle reports (#128667) * [ci] bump memory for webpack bundle reports We're seeing intermittent out of memory errors when building platform plugins. This instance is comparatively undersized with other jobs that build platform plugins. This resizes the instance to add more memory. The higher core count will be utilized by the build plugin task and decrease build time. * use c2 --- .buildkite/pipelines/pull_request/base.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.buildkite/pipelines/pull_request/base.yml b/.buildkite/pipelines/pull_request/base.yml index 894f4c4368a3d..4aa9a7a49fe23 100644 --- a/.buildkite/pipelines/pull_request/base.yml +++ b/.buildkite/pipelines/pull_request/base.yml @@ -173,6 +173,6 @@ steps: - command: .buildkite/scripts/steps/webpack_bundle_analyzer/build_and_upload.sh label: 'Build Webpack Bundle Analyzer reports' agents: - queue: n2-2 + queue: c2-4 key: webpack_bundle_analyzer timeout_in_minutes: 60 From 649457160e2e625bd5fa11d004d44833f1a4b8aa Mon Sep 17 00:00:00 2001 From: liza-mae Date: Mon, 28 Mar 2022 13:42:39 -0600 Subject: [PATCH 048/160] Add env var opt to es security (#128516) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- test/functional/config.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/functional/config.js b/test/functional/config.js index bfd2da7518fb7..9221bef808e01 100644 --- a/test/functional/config.js +++ b/test/functional/config.js @@ -34,7 +34,7 @@ export default async function ({ readConfigFile }) { esTestCluster: { ...commonConfig.get('esTestCluster'), - serverArgs: ['xpack.security.enabled=false'], + serverArgs: [`xpack.security.enabled=${process.env.ES_SECURITY_ENABLED ? 'true' : 'false'}`], }, kbnTestServer: { From 45948d5d81875368f4df90fbc3769d4c90610f64 Mon Sep 17 00:00:00 2001 From: Dominique Clarke Date: Mon, 28 Mar 2022 15:53:10 -0400 Subject: [PATCH 049/160] [Uptime] implement encrypted saved objects for monitor management (#127348) * uptime - synthetics - implement encrypted saved objects for synthetics monitors Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../common/constants/monitor_management.ts | 91 +++++++++++ .../monitor_management/config_key.ts | 66 +------- .../monitor_management/monitor_types.ts | 143 +++++++++++++++--- .../uptime/common/types/synthetics_monitor.ts | 8 +- .../uptime/e2e/tasks/uptime_monitor.ndjson | 4 +- .../monitor_list/monitor_enabled.tsx | 4 +- .../monitor_list/monitor_list.tsx | 18 +-- .../pages/monitor_management/edit_monitor.tsx | 6 +- .../public/state/api/monitor_management.ts | 14 +- .../uptime/server/lib/requests/get_monitor.ts | 28 +++- .../server/lib/saved_objects/saved_objects.ts | 15 ++ .../lib/saved_objects/synthetics_monitor.ts | 3 + .../hydrate_saved_object.test.ts | 6 +- .../hydrate_saved_object.ts | 8 +- .../synthetics_service/synthetics_service.ts | 44 ++++-- .../lib/synthetics_service/utils/secrets.ts | 35 +++++ .../rest_api/monitors/monitor_status.ts | 8 +- .../synthetics_service/add_monitor.ts | 22 ++- .../synthetics_service/delete_monitor.ts | 43 ++++-- .../synthetics_service/edit_monitor.ts | 74 ++++++--- .../synthetics_service/get_monitor.ts | 16 +- .../telemetry/monitor_upgrade_sender.ts | 22 +-- .../apis/uptime/rest/add_monitor.ts | 4 +- .../apis/uptime/rest/edit_monitor.ts | 12 +- .../apis/uptime/rest/get_monitor.ts | 9 +- 25 files changed, 518 insertions(+), 185 deletions(-) create mode 100644 x-pack/plugins/uptime/common/constants/monitor_management.ts create mode 100644 x-pack/plugins/uptime/server/lib/synthetics_service/utils/secrets.ts diff --git a/x-pack/plugins/uptime/common/constants/monitor_management.ts b/x-pack/plugins/uptime/common/constants/monitor_management.ts new file mode 100644 index 0000000000000..c306d939c7128 --- /dev/null +++ b/x-pack/plugins/uptime/common/constants/monitor_management.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +// values must match keys in the integration package +export enum ConfigKey { + APM_SERVICE_NAME = 'service.name', + ENABLED = 'enabled', + HOSTS = 'hosts', + IGNORE_HTTPS_ERRORS = 'ignore_https_errors', + JOURNEY_FILTERS_MATCH = 'filter_journeys.match', + JOURNEY_FILTERS_TAGS = 'filter_journeys.tags', + MAX_REDIRECTS = 'max_redirects', + METADATA = '__ui', + MONITOR_TYPE = 'type', + NAME = 'name', + NAMESPACE = 'namespace', + LOCATIONS = 'locations', + PARAMS = 'params', + PASSWORD = 'password', + PROXY_URL = 'proxy_url', + PROXY_USE_LOCAL_RESOLVER = 'proxy_use_local_resolver', + RESPONSE_BODY_CHECK_NEGATIVE = 'check.response.body.negative', + RESPONSE_BODY_CHECK_POSITIVE = 'check.response.body.positive', + RESPONSE_BODY_INDEX = 'response.include_body', + RESPONSE_HEADERS_CHECK = 'check.response.headers', + RESPONSE_HEADERS_INDEX = 'response.include_headers', + RESPONSE_RECEIVE_CHECK = 'check.receive', + RESPONSE_STATUS_CHECK = 'check.response.status', + REQUEST_BODY_CHECK = 'check.request.body', + REQUEST_HEADERS_CHECK = 'check.request.headers', + REQUEST_METHOD_CHECK = 'check.request.method', + REQUEST_SEND_CHECK = 'check.send', + REVISION = 'revision', + SCHEDULE = 'schedule', + SCREENSHOTS = 'screenshots', + SOURCE_INLINE = 'source.inline.script', + SOURCE_ZIP_URL = 'source.zip_url.url', + SOURCE_ZIP_USERNAME = 'source.zip_url.username', + SOURCE_ZIP_PASSWORD = 'source.zip_url.password', + SOURCE_ZIP_FOLDER = 'source.zip_url.folder', + SOURCE_ZIP_PROXY_URL = 'source.zip_url.proxy_url', + SYNTHETICS_ARGS = 'synthetics_args', + TLS_CERTIFICATE_AUTHORITIES = 'ssl.certificate_authorities', + TLS_CERTIFICATE = 'ssl.certificate', + TLS_KEY = 'ssl.key', + TLS_KEY_PASSPHRASE = 'ssl.key_passphrase', + TLS_VERIFICATION_MODE = 'ssl.verification_mode', + TLS_VERSION = 'ssl.supported_protocols', + TAGS = 'tags', + TIMEOUT = 'timeout', + THROTTLING_CONFIG = 'throttling.config', + IS_THROTTLING_ENABLED = 'throttling.is_enabled', + DOWNLOAD_SPEED = 'throttling.download_speed', + UPLOAD_SPEED = 'throttling.upload_speed', + LATENCY = 'throttling.latency', + URLS = 'urls', + PORT = 'url.port', + USERNAME = 'username', + WAIT = 'wait', + ZIP_URL_TLS_CERTIFICATE_AUTHORITIES = 'source.zip_url.ssl.certificate_authorities', + ZIP_URL_TLS_CERTIFICATE = 'source.zip_url.ssl.certificate', + ZIP_URL_TLS_KEY = 'source.zip_url.ssl.key', + ZIP_URL_TLS_KEY_PASSPHRASE = 'source.zip_url.ssl.key_passphrase', + ZIP_URL_TLS_VERIFICATION_MODE = 'source.zip_url.ssl.verification_mode', + ZIP_URL_TLS_VERSION = 'source.zip_url.ssl.supported_protocols', +} + +export const secretKeys = [ + ConfigKey.PARAMS, + ConfigKey.PASSWORD, + ConfigKey.REQUEST_BODY_CHECK, + ConfigKey.REQUEST_HEADERS_CHECK, + ConfigKey.REQUEST_SEND_CHECK, + ConfigKey.RESPONSE_BODY_CHECK_NEGATIVE, + ConfigKey.RESPONSE_BODY_CHECK_POSITIVE, + ConfigKey.RESPONSE_HEADERS_CHECK, + ConfigKey.RESPONSE_RECEIVE_CHECK, + ConfigKey.SOURCE_INLINE, + ConfigKey.SOURCE_ZIP_USERNAME, + ConfigKey.SOURCE_ZIP_PASSWORD, + ConfigKey.SYNTHETICS_ARGS, + ConfigKey.TLS_KEY, + ConfigKey.TLS_KEY_PASSPHRASE, + ConfigKey.USERNAME, + ConfigKey.ZIP_URL_TLS_KEY, + ConfigKey.ZIP_URL_TLS_KEY_PASSPHRASE, +] as const; diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/config_key.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/config_key.ts index c3a6697d68b62..52cdbd08f06c9 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/config_key.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/config_key.ts @@ -7,70 +7,8 @@ import * as t from 'io-ts'; import { tEnum } from '../../utils/t_enum'; - -// values must match keys in the integration package -export enum ConfigKey { - APM_SERVICE_NAME = 'service.name', - ENABLED = 'enabled', - HOSTS = 'hosts', - IGNORE_HTTPS_ERRORS = 'ignore_https_errors', - JOURNEY_FILTERS_MATCH = 'filter_journeys.match', - JOURNEY_FILTERS_TAGS = 'filter_journeys.tags', - MAX_REDIRECTS = 'max_redirects', - METADATA = '__ui', - MONITOR_TYPE = 'type', - NAME = 'name', - NAMESPACE = 'namespace', - LOCATIONS = 'locations', - PARAMS = 'params', - PASSWORD = 'password', - PROXY_URL = 'proxy_url', - PROXY_USE_LOCAL_RESOLVER = 'proxy_use_local_resolver', - RESPONSE_BODY_CHECK_NEGATIVE = 'check.response.body.negative', - RESPONSE_BODY_CHECK_POSITIVE = 'check.response.body.positive', - RESPONSE_BODY_INDEX = 'response.include_body', - RESPONSE_HEADERS_CHECK = 'check.response.headers', - RESPONSE_HEADERS_INDEX = 'response.include_headers', - RESPONSE_RECEIVE_CHECK = 'check.receive', - RESPONSE_STATUS_CHECK = 'check.response.status', - REQUEST_BODY_CHECK = 'check.request.body', - REQUEST_HEADERS_CHECK = 'check.request.headers', - REQUEST_METHOD_CHECK = 'check.request.method', - REQUEST_SEND_CHECK = 'check.send', - REVISION = 'revision', - SCHEDULE = 'schedule', - SCREENSHOTS = 'screenshots', - SOURCE_INLINE = 'source.inline.script', - SOURCE_ZIP_URL = 'source.zip_url.url', - SOURCE_ZIP_USERNAME = 'source.zip_url.username', - SOURCE_ZIP_PASSWORD = 'source.zip_url.password', - SOURCE_ZIP_FOLDER = 'source.zip_url.folder', - SOURCE_ZIP_PROXY_URL = 'source.zip_url.proxy_url', - SYNTHETICS_ARGS = 'synthetics_args', - TLS_CERTIFICATE_AUTHORITIES = 'ssl.certificate_authorities', - TLS_CERTIFICATE = 'ssl.certificate', - TLS_KEY = 'ssl.key', - TLS_KEY_PASSPHRASE = 'ssl.key_passphrase', - TLS_VERIFICATION_MODE = 'ssl.verification_mode', - TLS_VERSION = 'ssl.supported_protocols', - TAGS = 'tags', - TIMEOUT = 'timeout', - THROTTLING_CONFIG = 'throttling.config', - IS_THROTTLING_ENABLED = 'throttling.is_enabled', - DOWNLOAD_SPEED = 'throttling.download_speed', - UPLOAD_SPEED = 'throttling.upload_speed', - LATENCY = 'throttling.latency', - URLS = 'urls', - PORT = 'url.port', - USERNAME = 'username', - WAIT = 'wait', - ZIP_URL_TLS_CERTIFICATE_AUTHORITIES = 'source.zip_url.ssl.certificate_authorities', - ZIP_URL_TLS_CERTIFICATE = 'source.zip_url.ssl.certificate', - ZIP_URL_TLS_KEY = 'source.zip_url.ssl.key', - ZIP_URL_TLS_KEY_PASSPHRASE = 'source.zip_url.ssl.key_passphrase', - ZIP_URL_TLS_VERIFICATION_MODE = 'source.zip_url.ssl.verification_mode', - ZIP_URL_TLS_VERSION = 'source.zip_url.ssl.supported_protocols', -} +import { ConfigKey } from '../../constants/monitor_management'; +export { ConfigKey } from '../../constants/monitor_management'; export const ConfigKeyCodec = tEnum('ConfigKey', ConfigKey); export type ConfigKeyType = t.TypeOf; diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts index e0205b9362e23..44c643d2160d1 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts @@ -6,6 +6,7 @@ */ import * as t from 'io-ts'; +import { secretKeys } from '../../constants/monitor_management'; import { ConfigKey } from './config_key'; import { LocationsCodec } from './locations'; import { @@ -27,25 +28,35 @@ const Schedule = t.interface({ export const TLSFieldsCodec = t.partial({ [ConfigKey.TLS_CERTIFICATE_AUTHORITIES]: t.string, [ConfigKey.TLS_CERTIFICATE]: t.string, - [ConfigKey.TLS_KEY]: t.string, - [ConfigKey.TLS_KEY_PASSPHRASE]: t.string, [ConfigKey.TLS_VERIFICATION_MODE]: VerificationModeCodec, [ConfigKey.TLS_VERSION]: t.array(TLSVersionCodec), }); -export type TLSFields = t.TypeOf; +export const TLSSensitiveFieldsCodec = t.partial({ + [ConfigKey.TLS_KEY]: t.string, + [ConfigKey.TLS_KEY_PASSPHRASE]: t.string, +}); + +export const TLSCodec = t.intersection([TLSFieldsCodec, TLSSensitiveFieldsCodec]); + +export type TLSFields = t.TypeOf; // ZipUrlTLSFields export const ZipUrlTLSFieldsCodec = t.partial({ [ConfigKey.ZIP_URL_TLS_CERTIFICATE_AUTHORITIES]: t.string, [ConfigKey.ZIP_URL_TLS_CERTIFICATE]: t.string, - [ConfigKey.ZIP_URL_TLS_KEY]: t.string, - [ConfigKey.ZIP_URL_TLS_KEY_PASSPHRASE]: t.string, [ConfigKey.ZIP_URL_TLS_VERIFICATION_MODE]: VerificationModeCodec, [ConfigKey.ZIP_URL_TLS_VERSION]: t.array(TLSVersionCodec), }); -export type ZipUrlTLSFields = t.TypeOf; +export const ZipUrlTLSSensitiveFieldsCodec = t.partial({ + [ConfigKey.ZIP_URL_TLS_KEY]: t.string, + [ConfigKey.ZIP_URL_TLS_KEY_PASSPHRASE]: t.string, +}); + +export const ZipUrlTLSCodec = t.intersection([ZipUrlTLSFieldsCodec, ZipUrlTLSSensitiveFieldsCodec]); + +export type ZipUrlTLSFields = t.TypeOf; // CommonFields export const CommonFieldsCodec = t.intersection([ @@ -82,19 +93,33 @@ export type TCPSimpleFields = t.TypeOf; export const TCPAdvancedFieldsCodec = t.interface({ [ConfigKey.PROXY_URL]: t.string, [ConfigKey.PROXY_USE_LOCAL_RESOLVER]: t.boolean, +}); + +export const TCPSensitiveAdvancedFieldsCodec = t.interface({ [ConfigKey.RESPONSE_RECEIVE_CHECK]: t.string, [ConfigKey.REQUEST_SEND_CHECK]: t.string, }); -export type TCPAdvancedFields = t.TypeOf; +export const TCPAdvancedCodec = t.intersection([ + TCPAdvancedFieldsCodec, + TCPSensitiveAdvancedFieldsCodec, +]); + +export type TCPAdvancedFields = t.TypeOf; // TCPFields -export const TCPFieldsCodec = t.intersection([ +export const EncryptedTCPFieldsCodec = t.intersection([ TCPSimpleFieldsCodec, TCPAdvancedFieldsCodec, TLSFieldsCodec, ]); +export const TCPFieldsCodec = t.intersection([ + EncryptedTCPFieldsCodec, + TCPSensitiveAdvancedFieldsCodec, + TLSSensitiveFieldsCodec, +]); + export type TCPFields = t.TypeOf; // ICMP SimpleFields @@ -123,28 +148,43 @@ export type HTTPSimpleFields = t.TypeOf; // HTTPAdvancedFields export const HTTPAdvancedFieldsCodec = t.interface({ - [ConfigKey.PASSWORD]: t.string, [ConfigKey.PROXY_URL]: t.string, - [ConfigKey.RESPONSE_BODY_CHECK_NEGATIVE]: t.array(t.string), - [ConfigKey.RESPONSE_BODY_CHECK_POSITIVE]: t.array(t.string), [ConfigKey.RESPONSE_BODY_INDEX]: ResponseBodyIndexPolicyCodec, - [ConfigKey.RESPONSE_HEADERS_CHECK]: t.record(t.string, t.string), [ConfigKey.RESPONSE_HEADERS_INDEX]: t.boolean, [ConfigKey.RESPONSE_STATUS_CHECK]: t.array(t.string), + [ConfigKey.REQUEST_METHOD_CHECK]: t.string, +}); + +export const HTTPSensitiveAdvancedFieldsCodec = t.interface({ + [ConfigKey.PASSWORD]: t.string, + [ConfigKey.RESPONSE_BODY_CHECK_NEGATIVE]: t.array(t.string), + [ConfigKey.RESPONSE_BODY_CHECK_POSITIVE]: t.array(t.string), + [ConfigKey.RESPONSE_HEADERS_CHECK]: t.record(t.string, t.string), [ConfigKey.REQUEST_BODY_CHECK]: t.interface({ value: t.string, type: ModeCodec }), [ConfigKey.REQUEST_HEADERS_CHECK]: t.record(t.string, t.string), - [ConfigKey.REQUEST_METHOD_CHECK]: t.string, [ConfigKey.USERNAME]: t.string, }); -export type HTTPAdvancedFields = t.TypeOf; +export const HTTPAdvancedCodec = t.intersection([ + HTTPAdvancedFieldsCodec, + HTTPSensitiveAdvancedFieldsCodec, +]); + +export type HTTPAdvancedFields = t.TypeOf; // HTTPFields -export const HTTPFieldsCodec = t.intersection([ +export const EncryptedHTTPFieldsCodec = t.intersection([ HTTPSimpleFieldsCodec, HTTPAdvancedFieldsCodec, TLSFieldsCodec, ]); + +export const HTTPFieldsCodec = t.intersection([ + EncryptedHTTPFieldsCodec, + HTTPSensitiveAdvancedFieldsCodec, + TLSSensitiveFieldsCodec, +]); + export type HTTPFields = t.TypeOf; // Browser Fields @@ -156,15 +196,23 @@ export const ThrottlingConfigKeyCodec = t.union([ export type ThrottlingConfigKey = t.TypeOf; -export const BrowserSimpleFieldsCodec = t.intersection([ +export const EncryptedBrowserSimpleFieldsCodec = t.intersection([ t.interface({ [ConfigKey.METADATA]: MetadataCodec, - [ConfigKey.SOURCE_INLINE]: t.string, [ConfigKey.SOURCE_ZIP_URL]: t.string, [ConfigKey.SOURCE_ZIP_FOLDER]: t.string, + [ConfigKey.SOURCE_ZIP_PROXY_URL]: t.string, + }), + ZipUrlTLSFieldsCodec, + ZipUrlTLSSensitiveFieldsCodec, + CommonFieldsCodec, +]); + +export const BrowserSensitiveSimpleFieldsCodec = t.intersection([ + t.interface({ + [ConfigKey.SOURCE_INLINE]: t.string, [ConfigKey.SOURCE_ZIP_USERNAME]: t.string, [ConfigKey.SOURCE_ZIP_PASSWORD]: t.string, - [ConfigKey.SOURCE_ZIP_PROXY_URL]: t.string, [ConfigKey.PARAMS]: t.string, [ConfigKey.URLS]: t.union([t.string, t.undefined]), [ConfigKey.PORT]: t.union([t.number, t.undefined]), @@ -174,7 +222,6 @@ export const BrowserSimpleFieldsCodec = t.intersection([ ]); export const BrowserAdvancedFieldsCodec = t.interface({ - [ConfigKey.SYNTHETICS_ARGS]: t.array(t.string), [ConfigKey.SCREENSHOTS]: t.string, [ConfigKey.JOURNEY_FILTERS_MATCH]: t.string, [ConfigKey.JOURNEY_FILTERS_TAGS]: t.array(t.string), @@ -186,14 +233,35 @@ export const BrowserAdvancedFieldsCodec = t.interface({ [ConfigKey.THROTTLING_CONFIG]: t.string, }); +export const BrowserSimpleFieldsCodec = t.intersection([ + EncryptedBrowserSimpleFieldsCodec, + BrowserSensitiveSimpleFieldsCodec, + ZipUrlTLSSensitiveFieldsCodec, +]); + +export const BrowserSensitiveAdvancedFieldsCodec = t.interface({ + [ConfigKey.SYNTHETICS_ARGS]: t.array(t.string), +}); + +export const BrowserAdvancedsCodec = t.intersection([ + BrowserAdvancedFieldsCodec, + BrowserSensitiveAdvancedFieldsCodec, +]); + +export const EncryptedBrowserFieldsCodec = t.intersection([ + EncryptedBrowserSimpleFieldsCodec, + BrowserAdvancedFieldsCodec, +]); + export const BrowserFieldsCodec = t.intersection([ BrowserSimpleFieldsCodec, BrowserAdvancedFieldsCodec, + BrowserSensitiveAdvancedFieldsCodec, ]); export type BrowserFields = t.TypeOf; export type BrowserSimpleFields = t.TypeOf; -export type BrowserAdvancedFields = t.TypeOf; +export type BrowserAdvancedFields = t.TypeOf; // MonitorFields, represents any possible monitor type export const MonitorFieldsCodec = t.intersection([ @@ -213,17 +281,34 @@ export const SyntheticsMonitorCodec = t.union([ BrowserFieldsCodec, ]); +export const EncryptedSyntheticsMonitorCodec = t.union([ + EncryptedHTTPFieldsCodec, + EncryptedTCPFieldsCodec, + ICMPSimpleFieldsCodec, + EncryptedBrowserFieldsCodec, +]); + export type SyntheticsMonitor = t.TypeOf; export const SyntheticsMonitorWithIdCodec = t.intersection([ SyntheticsMonitorCodec, t.interface({ id: t.string }), ]); + +export const EncryptedSyntheticsMonitorWithIdCodec = t.intersection([ + EncryptedSyntheticsMonitorCodec, + t.interface({ id: t.string }), +]); + export type SyntheticsMonitorWithId = t.TypeOf; +export type EncryptedSyntheticsMonitorWithId = t.TypeOf< + typeof EncryptedSyntheticsMonitorWithIdCodec +>; + export const MonitorManagementListResultCodec = t.type({ monitors: t.array( - t.interface({ id: t.string, attributes: SyntheticsMonitorCodec, updated_at: t.string }) + t.interface({ id: t.string, attributes: EncryptedSyntheticsMonitorCodec, updated_at: t.string }) ), page: t.number, perPage: t.number, @@ -231,3 +316,19 @@ export const MonitorManagementListResultCodec = t.type({ }); export type MonitorManagementListResult = t.TypeOf; + +export const SyntheticsMonitorWithSecretsCodec = t.intersection([ + EncryptedSyntheticsMonitorCodec, + t.interface({ + secrets: t.string, + }), +]); + +export type Secret = typeof secretKeys[number]; + +export type SyntheticsMonitorWithSecrets = Omit< + t.TypeOf, + Secret +>; + +export type EncryptedSyntheticsMonitor = Omit; diff --git a/x-pack/plugins/uptime/common/types/synthetics_monitor.ts b/x-pack/plugins/uptime/common/types/synthetics_monitor.ts index f4f20fda9235f..2fba9e0c299aa 100644 --- a/x-pack/plugins/uptime/common/types/synthetics_monitor.ts +++ b/x-pack/plugins/uptime/common/types/synthetics_monitor.ts @@ -6,13 +6,17 @@ */ import { SimpleSavedObject } from 'kibana/public'; -import { SyntheticsMonitor } from '../runtime_types'; +import { EncryptedSyntheticsMonitor, SyntheticsMonitor } from '../runtime_types'; export interface MonitorIdParam { monitorId: string; } -export type SyntheticsMonitorSavedObject = SimpleSavedObject & { +export type SyntheticsMonitorSavedObject = SimpleSavedObject & { + updated_at: string; +}; + +export type DecryptedSyntheticsMonitorSavedObject = SimpleSavedObject & { updated_at: string; }; diff --git a/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson b/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson index e0088725d6e69..308be283a86b8 100644 --- a/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson +++ b/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson @@ -1,3 +1,3 @@ -{"attributes":{"__ui":{"is_tls_enabled":false,"is_zip_url_tls_enabled":false},"check.request.body":{"type":"text","value":""},"check.request.headers":{},"check.request.method":"GET","check.response.body.negative":[],"check.response.body.positive":[],"check.response.headers":{},"check.response.status":[],"enabled":true,"locations":[{"geo":{"lat":41.25,"lon":-95.86},"id":"us_central","label":"US Central","url":"https://us-central.synthetics.elastic.dev"}],"max_redirects":"0","name":"Test Monitor","password":"4SdnK70F8YLqril8Mh5qVveP","proxy_url":"","response.include_body":"on_error","response.include_headers":true,"schedule":{"number":"3","unit":"m"},"service.name":"","tags":[],"timeout":"16","type":"http","urls":"https://www.google.com","username":""},"coreMigrationVersion":"8.1.0","id":"832b9980-7fba-11ec-b360-25a79ce3f496","references":[],"sort":[1643319958480,20371],"type":"synthetics-monitor","updated_at":"2022-01-27T21:45:58.480Z","version":"WzExOTg3ODYsMl0="} -{"attributes":{"__ui":{"is_tls_enabled":false,"is_zip_url_tls_enabled":false},"check.request.body":{"type":"text","value":""},"check.request.headers":{},"check.request.method":"GET","check.response.body.negative":[],"check.response.body.positive":[],"check.response.headers":{},"check.response.status":[],"enabled":true,"locations":[{"geo":{"lat":41.25,"lon":-95.86},"id":"us_central","label":"US Central","url":"https://us-central.synthetics.elastic.dev"}],"max_redirects":"0","name":"Test Monito","password":"4SdnK70F8YLqril8Mh5qVveP","proxy_url":"","response.include_body":"on_error","response.include_headers":true,"schedule":{"number":"3","unit":"m"},"service.name":"","tags":[],"timeout":"16","type":"http","urls":"https://www.google.com","username":""},"coreMigrationVersion":"8.1.0","id":"b28380d0-7fba-11ec-b360-25a79ce3f496","references":[],"sort":[1643320037906,20374],"type":"synthetics-monitor","updated_at":"2022-01-27T21:47:17.906Z","version":"WzExOTg4MDAsMl0="} +{"attributes":{"__ui":{"is_tls_enabled":false,"is_zip_url_tls_enabled":false},"check.request.method":"GET","check.response.status":[],"enabled":true,"locations":[{"geo":{"lat":41.25,"lon":-95.86},"id":"us_central","label":"US Central","url":"https://us-central.synthetics.elastic.dev"}],"max_redirects":"0","name":"Test Monitor","proxy_url":"","response.include_body":"on_error","response.include_headers":true,"schedule":{"number":"3","unit":"m"},"service.name":"","tags":[],"timeout":"16","type":"http","urls":"https://www.google.com", "secrets": "{}"},"coreMigrationVersion":"8.1.0","id":"832b9980-7fba-11ec-b360-25a79ce3f496","references":[],"sort":[1643319958480,20371],"type":"synthetics-monitor","updated_at":"2022-01-27T21:45:58.480Z","version":"WzExOTg3ODYsMl0="} +{"attributes":{"__ui":{"is_tls_enabled":false,"is_zip_url_tls_enabled":false},"check.request.method":"GET","check.response.status":[],"enabled":true,"locations":[{"geo":{"lat":41.25,"lon":-95.86},"id":"us_central","label":"US Central","url":"https://us-central.synthetics.elastic.dev"}],"max_redirects":"0","name":"Test Monito","proxy_url":"","response.include_body":"on_error","response.include_headers":true,"schedule":{"number":"3","unit":"m"},"service.name":"","tags":[],"timeout":"16","type":"http","urls":"https://www.google.com", "secrets": "{}"},"coreMigrationVersion":"8.1.0","id":"b28380d0-7fba-11ec-b360-25a79ce3f496","references":[],"sort":[1643320037906,20374],"type":"synthetics-monitor","updated_at":"2022-01-27T21:47:17.906Z","version":"WzExOTg4MDAsMl0="} {"excludedObjects":[],"excludedObjectsCount":0,"exportedCount":2,"missingRefCount":0,"missingReferences":[]} \ No newline at end of file diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_enabled.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_enabled.tsx index 2913043aca72e..00d146a8f44b4 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_enabled.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_enabled.tsx @@ -10,12 +10,12 @@ import { i18n } from '@kbn/i18n'; import React, { useEffect, useState } from 'react'; import { useKibana } from '../../../../../../../src/plugins/kibana_react/public'; import { FETCH_STATUS, useFetcher } from '../../../../../observability/public'; -import { ConfigKey, SyntheticsMonitor } from '../../../../common/runtime_types'; +import { ConfigKey, EncryptedSyntheticsMonitor } from '../../../../common/runtime_types'; import { setMonitor } from '../../../state/api'; interface Props { id: string; - monitor: SyntheticsMonitor; + monitor: EncryptedSyntheticsMonitor; onUpdate: () => void; isDisabled?: boolean; } diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx index 8bae4160f6b0c..559e84d2dd827 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx @@ -23,7 +23,7 @@ import { MonitorFields, Ping, ServiceLocations, - SyntheticsMonitorWithId, + EncryptedSyntheticsMonitorWithId, TCPSimpleFields, } from '../../../../common/runtime_types'; import { UptimeSettingsContext } from '../../../contexts'; @@ -66,7 +66,7 @@ export const MonitorManagementList = ({ const isXl = useBreakpoints().up('xl'); const { total } = list as MonitorManagementListState['list']; - const monitors: SyntheticsMonitorWithId[] = useMemo( + const monitors: EncryptedSyntheticsMonitorWithId[] = useMemo( () => list.monitors.map((monitor) => ({ ...monitor.attributes, @@ -79,7 +79,7 @@ export const MonitorManagementList = ({ ({ page = { index: 0, size: 10 }, sort = { field: ConfigKey.NAME, direction: 'asc' }, - }: Criteria) => { + }: Criteria) => { const { index, size } = page; const { field, direction } = sort; @@ -100,9 +100,9 @@ export const MonitorManagementList = ({ pageSizeOptions: [5, 10, 25, 50, 100], }; - const sorting: EuiTableSortingType = { + const sorting: EuiTableSortingType = { sort: { - field: sortField as keyof SyntheticsMonitorWithId, + field: sortField as keyof EncryptedSyntheticsMonitorWithId, direction: sortOrder, }, }; @@ -117,7 +117,7 @@ export const MonitorManagementList = ({ defaultMessage: 'Monitor name', }), sortable: true, - render: (name: string, { id }: SyntheticsMonitorWithId) => ( + render: (name: string, { id }: EncryptedSyntheticsMonitorWithId) => ( @@ -175,7 +175,7 @@ export const MonitorManagementList = ({ name: i18n.translate('xpack.uptime.monitorManagement.monitorList.enabled', { defaultMessage: 'Enabled', }), - render: (_enabled: boolean, monitor: SyntheticsMonitorWithId) => ( + render: (_enabled: boolean, monitor: EncryptedSyntheticsMonitorWithId) => ( ( + render: (fields: EncryptedSyntheticsMonitorWithId) => ( ), }, - ] as Array>; + ] as Array>; return ( diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx index 0ebf1d6286db6..7ebfbb2297d0a 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx @@ -13,7 +13,7 @@ import { MonitorFields } from '../../../common/runtime_types'; import { EditMonitorConfig } from '../../components/monitor_management/edit_monitor_config'; import { Loader } from '../../components/monitor_management/loader/loader'; import { getMonitor } from '../../state/api'; -import { SyntheticsMonitorSavedObject } from '../../../common/types'; +import { DecryptedSyntheticsMonitorSavedObject } from '../../../common/types'; import { useLocations } from '../../components/monitor_management/hooks/use_locations'; import { useMonitorManagementBreadcrumbs } from './use_monitor_management_breadcrumbs'; @@ -23,7 +23,9 @@ export const EditMonitorPage: React.FC = () => { useMonitorManagementBreadcrumbs({ isEditMonitor: true }); const { monitorId } = useParams<{ monitorId: string }>(); - const { data, status } = useFetcher>(() => { + const { data, status } = useFetcher< + Promise + >(() => { return getMonitor({ id: Buffer.from(monitorId, 'base64').toString('utf8') }); }, [monitorId]); diff --git a/x-pack/plugins/uptime/public/state/api/monitor_management.ts b/x-pack/plugins/uptime/public/state/api/monitor_management.ts index 329c06e6ceadc..f9e08e3020936 100644 --- a/x-pack/plugins/uptime/public/state/api/monitor_management.ts +++ b/x-pack/plugins/uptime/public/state/api/monitor_management.ts @@ -12,18 +12,22 @@ import { MonitorManagementListResult, ServiceLocations, SyntheticsMonitor, + EncryptedSyntheticsMonitor, ServiceLocationsApiResponseCodec, ServiceLocationErrors, ThrottlingOptions, } from '../../../common/runtime_types'; -import { SyntheticsMonitorSavedObject, SyntheticsServiceAllowed } from '../../../common/types'; +import { + DecryptedSyntheticsMonitorSavedObject, + SyntheticsServiceAllowed, +} from '../../../common/types'; import { apiService } from './utils'; export const setMonitor = async ({ monitor, id, }: { - monitor: SyntheticsMonitor; + monitor: SyntheticsMonitor | EncryptedSyntheticsMonitor; id?: string; }): Promise<{ attributes: { errors: ServiceLocationErrors } } | SyntheticsMonitor> => { if (id) { @@ -33,7 +37,11 @@ export const setMonitor = async ({ } }; -export const getMonitor = async ({ id }: { id: string }): Promise => { +export const getMonitor = async ({ + id, +}: { + id: string; +}): Promise => { return await apiService.get(`${API_URLS.SYNTHETICS_MONITORS}/${id}`); }; diff --git a/x-pack/plugins/uptime/server/lib/requests/get_monitor.ts b/x-pack/plugins/uptime/server/lib/requests/get_monitor.ts index 4f6f8682fbeac..b74852d581311 100644 --- a/x-pack/plugins/uptime/server/lib/requests/get_monitor.ts +++ b/x-pack/plugins/uptime/server/lib/requests/get_monitor.ts @@ -6,18 +6,38 @@ */ import { SavedObject, SavedObjectsClientContract } from 'kibana/server'; -import { SyntheticsMonitor } from '../../../common/runtime_types'; -import { syntheticsMonitorType } from '../../lib/saved_objects/synthetics_monitor'; +import { EncryptedSavedObjectsClient } from '../../../../encrypted_saved_objects/server'; +import { + SyntheticsMonitorWithSecrets, + EncryptedSyntheticsMonitor, +} from '../../../common/runtime_types'; +import { + syntheticsMonitor, + syntheticsMonitorType, +} from '../../lib/saved_objects/synthetics_monitor'; export const getSyntheticsMonitor = async ({ monitorId, + encryptedSavedObjectsClient, savedObjectsClient, }: { monitorId: string; + encryptedSavedObjectsClient: EncryptedSavedObjectsClient; savedObjectsClient: SavedObjectsClientContract; -}): Promise> => { +}): Promise> => { try { - return await savedObjectsClient.get(syntheticsMonitorType, monitorId); + const encryptedMonitor = await savedObjectsClient.get( + syntheticsMonitorType, + monitorId + ); + + return await encryptedSavedObjectsClient.getDecryptedAsInternalUser( + syntheticsMonitor.name, + monitorId, + { + namespace: encryptedMonitor.namespaces?.[0], + } + ); } catch (e) { throw e; } diff --git a/x-pack/plugins/uptime/server/lib/saved_objects/saved_objects.ts b/x-pack/plugins/uptime/server/lib/saved_objects/saved_objects.ts index 67f05bfb55d03..74f3a4a8f7366 100644 --- a/x-pack/plugins/uptime/server/lib/saved_objects/saved_objects.ts +++ b/x-pack/plugins/uptime/server/lib/saved_objects/saved_objects.ts @@ -12,6 +12,7 @@ import { import { EncryptedSavedObjectsPluginSetup } from '../../../../encrypted_saved_objects/server'; import { DYNAMIC_SETTINGS_DEFAULTS } from '../../../common/constants'; +import { secretKeys } from '../../../common/constants/monitor_management'; import { DynamicSettings } from '../../../common/runtime_types'; import { UMSavedObjectsQueryFn } from '../adapters'; import { UptimeConfig } from '../../../common/config'; @@ -34,6 +35,20 @@ export const registerUptimeSavedObjects = ( type: syntheticsServiceApiKey.name, attributesToEncrypt: new Set(['apiKey']), }); + + encryptedSavedObjects.registerType({ + type: syntheticsMonitor.name, + attributesToEncrypt: new Set([ + 'secrets', + /* adding secretKeys to the list of attributes to encrypt ensures + * that secrets are never stored on the resulting saved object, + * even in the presence of developer error. + * + * In practice, all secrets should be stored as a single JSON + * payload on the `secrets` key. This ensures performant decryption. */ + ...secretKeys, + ]), + }); } }; diff --git a/x-pack/plugins/uptime/server/lib/saved_objects/synthetics_monitor.ts b/x-pack/plugins/uptime/server/lib/saved_objects/synthetics_monitor.ts index 88e9ad6f7f0fb..ea20c4c9232e9 100644 --- a/x-pack/plugins/uptime/server/lib/saved_objects/synthetics_monitor.ts +++ b/x-pack/plugins/uptime/server/lib/saved_objects/synthetics_monitor.ts @@ -32,6 +32,9 @@ export const syntheticsMonitor: SavedObjectsType = { tags: { type: 'keyword', }, + secrets: { + type: 'text', + }, }, }, management: { diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.test.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.test.ts index 5c493a38ac862..68a656a976141 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.test.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.test.ts @@ -6,7 +6,7 @@ */ import { hydrateSavedObjects } from './hydrate_saved_object'; -import { SyntheticsMonitorSavedObject } from '../../../common/types'; +import { DecryptedSyntheticsMonitorSavedObject } from '../../../common/types'; import { UptimeServerSetup } from '../adapters'; import moment from 'moment'; @@ -42,9 +42,9 @@ describe('hydrateSavedObjects', () => { ...mockMonitorTemplate, attributes: { ...mockMonitorTemplate.attributes, type }, updated_at: moment(time).subtract(1, 'hour').toISOString(), - } as SyntheticsMonitorSavedObject; + } as DecryptedSyntheticsMonitorSavedObject; - const monitors: SyntheticsMonitorSavedObject[] = [monitor]; + const monitors: DecryptedSyntheticsMonitorSavedObject[] = [monitor]; mockEsClient.search.mockResolvedValue( toKibanaResponse([ diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.ts index 8ee9fbca88561..6002d1bd8f1ec 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/hydrate_saved_object.ts @@ -8,14 +8,14 @@ import moment from 'moment'; import { UptimeESClient } from '../lib'; import { UptimeServerSetup } from '../adapters'; -import { SyntheticsMonitorSavedObject } from '../../../common/types'; +import { DecryptedSyntheticsMonitorSavedObject } from '../../../common/types'; import { SyntheticsMonitor, MonitorFields, Ping } from '../../../common/runtime_types'; export const hydrateSavedObjects = async ({ monitors, server, }: { - monitors: SyntheticsMonitorSavedObject[]; + monitors: DecryptedSyntheticsMonitorSavedObject[]; server: UptimeServerSetup; }) => { try { @@ -43,7 +43,7 @@ export const hydrateSavedObjects = async ({ missingInfoIds ); - const updatedObjects: SyntheticsMonitorSavedObject[] = []; + const updatedObjects: DecryptedSyntheticsMonitorSavedObject[] = []; monitors .filter((monitor) => missingInfoIds.includes(monitor.id)) .forEach((monitor) => { @@ -73,7 +73,7 @@ export const hydrateSavedObjects = async ({ updatedObjects.push({ ...monitor, attributes: resultAttributes, - } as SyntheticsMonitorSavedObject); + } as DecryptedSyntheticsMonitorSavedObject); } }); diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts index 6027b328d4493..4a86725d137ac 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts @@ -7,6 +7,7 @@ /* eslint-disable max-classes-per-file */ +import { SavedObject } from 'kibana/server'; import { KibanaRequest, Logger } from '../../../../../../src/core/server'; import { ConcreteTaskInstance, @@ -18,7 +19,7 @@ import { UptimeServerSetup } from '../adapters'; import { installSyntheticsIndexTemplates } from '../../rest_api/synthetics_service/install_index_templates'; import { SyntheticsServiceApiKey } from '../../../common/runtime_types/synthetics_service_api_key'; import { getAPIKeyForSyntheticsService } from './get_api_key'; -import { syntheticsMonitorType } from '../saved_objects/synthetics_monitor'; +import { syntheticsMonitorType, syntheticsMonitor } from '../saved_objects/synthetics_monitor'; import { getEsHosts } from './get_es_hosts'; import { ServiceConfig } from '../../../common/config'; import { ServiceAPIClient } from './service_api_client'; @@ -30,10 +31,13 @@ import { SyntheticsMonitor, ThrottlingOptions, SyntheticsMonitorWithId, + SyntheticsMonitorWithSecrets, } from '../../../common/runtime_types'; import { getServiceLocations } from './get_service_locations'; import { hydrateSavedObjects } from './hydrate_saved_object'; -import { SyntheticsMonitorSavedObject } from '../../../common/types'; +import { DecryptedSyntheticsMonitorSavedObject } from '../../../common/types'; + +import { normalizeSecrets } from './utils/secrets'; const SYNTHETICS_SERVICE_SYNC_MONITORS_TASK_TYPE = 'UPTIME:SyntheticsService:Sync-Saved-Monitor-Objects'; @@ -302,31 +306,53 @@ export class SyntheticsService { async getMonitorConfigs() { const savedObjectsClient = this.server.savedObjectsClient; + const encryptedClient = this.server.encryptedSavedObjects.getClient(); if (!savedObjectsClient?.find) { return [] as SyntheticsMonitorWithId[]; } - const findResult = await savedObjectsClient.find({ + const { saved_objects: encryptedMonitors } = await savedObjectsClient.find({ type: syntheticsMonitorType, namespaces: ['*'], perPage: 10000, }); + const start = performance.now(); + + const monitors: Array> = await Promise.all( + encryptedMonitors.map((monitor) => + encryptedClient.getDecryptedAsInternalUser( + syntheticsMonitor.name, + monitor.id + ) + ) + ); + + const end = performance.now(); + const duration = end - start; + + this.logger.debug(`Decrypted ${monitors.length} monitors. Took ${duration} milliseconds`, { + event: { + duration, + }, + monitors: monitors.length, + }); + if (this.indexTemplateExists) { // without mapping, querying won't make sense hydrateSavedObjects({ - monitors: findResult.saved_objects as unknown as SyntheticsMonitorSavedObject[], + monitors: monitors as unknown as DecryptedSyntheticsMonitorSavedObject[], server: this.server, }); } - return (findResult.saved_objects ?? []).map(({ attributes, id }) => ({ - ...attributes, - id, + return (monitors ?? []).map((monitor) => ({ + ...normalizeSecrets(monitor).attributes, + id: monitor.id, fields_under_root: true, - fields: { config_id: id }, - })) as SyntheticsMonitorWithId[]; + fields: { config_id: monitor.id }, + })); } formatConfigs(configs: SyntheticsMonitorWithId[]) { diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/utils/secrets.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/utils/secrets.ts new file mode 100644 index 0000000000000..7848dbedb7fed --- /dev/null +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/utils/secrets.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { omit, pick } from 'lodash'; +import { SavedObject } from 'kibana/server'; +import { secretKeys } from '../../../../common/constants/monitor_management'; +import { + SyntheticsMonitor, + SyntheticsMonitorWithSecrets, +} from '../../../../common/runtime_types/monitor_management'; + +export function formatSecrets(monitor: SyntheticsMonitor): SyntheticsMonitorWithSecrets { + const monitorWithoutSecrets = omit(monitor, secretKeys) as SyntheticsMonitorWithSecrets; + const secrets = pick(monitor, secretKeys); + + return { + ...monitorWithoutSecrets, + secrets: JSON.stringify(secrets), + }; +} + +export function normalizeSecrets( + monitor: SavedObject +): SavedObject { + return { + ...monitor, + attributes: { + ...monitor.attributes, + ...JSON.parse(monitor.attributes.secrets || ''), + }, + }; +} diff --git a/x-pack/plugins/uptime/server/rest_api/monitors/monitor_status.ts b/x-pack/plugins/uptime/server/rest_api/monitors/monitor_status.ts index 5089f5250f504..1d52f2c24a7f1 100644 --- a/x-pack/plugins/uptime/server/rest_api/monitors/monitor_status.ts +++ b/x-pack/plugins/uptime/server/rest_api/monitors/monitor_status.ts @@ -21,8 +21,9 @@ export const createGetStatusBarRoute: UMRestApiRouteFactory = (libs: UMServerLib dateEnd: schema.string(), }), }, - handler: async ({ uptimeEsClient, request, server }): Promise => { + handler: async ({ uptimeEsClient, request, server, savedObjectsClient }): Promise => { const { monitorId, dateStart, dateEnd } = request.query; + const encryptedSavedObjectsClient = server.encryptedSavedObjects.getClient(); const latestMonitor = await libs.requests.getLatestMonitor({ uptimeEsClient, @@ -42,7 +43,8 @@ export const createGetStatusBarRoute: UMRestApiRouteFactory = (libs: UMServerLib try { const monitorSavedObject = await libs.requests.getSyntheticsMonitor({ monitorId, - savedObjectsClient: server.savedObjectsClient, + encryptedSavedObjectsClient, + savedObjectsClient, }); if (!monitorSavedObject) { @@ -54,7 +56,7 @@ export const createGetStatusBarRoute: UMRestApiRouteFactory = (libs: UMServerLib [ConfigKey.NAME]: name, [ConfigKey.HOSTS]: host, [ConfigKey.MONITOR_TYPE]: type, - } = monitorSavedObject.attributes as MonitorFields; + } = monitorSavedObject.attributes as Partial; return { url: { diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts index ee3ef1fe6380c..d5beeb9967b18 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts @@ -6,12 +6,17 @@ */ import { schema } from '@kbn/config-schema'; import { SavedObject } from 'kibana/server'; -import { MonitorFields, SyntheticsMonitor } from '../../../common/runtime_types'; +import { + MonitorFields, + SyntheticsMonitor, + EncryptedSyntheticsMonitor, +} from '../../../common/runtime_types'; import { UMRestApiRouteFactory } from '../types'; import { API_URLS } from '../../../common/constants'; import { syntheticsMonitorType } from '../../lib/saved_objects/synthetics_monitor'; import { validateMonitor } from './monitor_validation'; import { sendTelemetryEvents, formatTelemetryEvent } from './telemetry/monitor_upgrade_sender'; +import { formatSecrets } from '../../lib/synthetics_service/utils/secrets'; export const addSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ method: 'POST', @@ -29,17 +34,20 @@ export const addSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ return response.badRequest({ body: { message, attributes: { details, ...payload } } }); } - const newMonitor: SavedObject = - await savedObjectsClient.create(syntheticsMonitorType, { - ...monitor, - revision: 1, - }); + const newMonitor: SavedObject = + await savedObjectsClient.create( + syntheticsMonitorType, + formatSecrets({ + ...monitor, + revision: 1, + }) + ); const { syntheticsService } = server; const errors = await syntheticsService.pushConfigs(request, [ { - ...newMonitor.attributes, + ...monitor, id: newMonitor.id, fields: { config_id: newMonitor.id, diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts index 6d744a7a1a406..6e94e1a802897 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts @@ -6,15 +6,22 @@ */ import { schema } from '@kbn/config-schema'; import { SavedObjectsErrorHelpers } from '../../../../../../src/core/server'; -import { SyntheticsMonitor } from '../../../common/runtime_types'; +import { + EncryptedSyntheticsMonitor, + SyntheticsMonitorWithSecrets, +} from '../../../common/runtime_types'; import { UMRestApiRouteFactory } from '../types'; import { API_URLS } from '../../../common/constants'; -import { syntheticsMonitorType } from '../../lib/saved_objects/synthetics_monitor'; +import { + syntheticsMonitorType, + syntheticsMonitor, +} from '../../lib/saved_objects/synthetics_monitor'; import { getMonitorNotFoundResponse } from './service_errors'; import { sendTelemetryEvents, formatTelemetryDeleteEvent, } from './telemetry/monitor_upgrade_sender'; +import { normalizeSecrets } from '../../lib/synthetics_service/utils/secrets'; export const deleteSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ method: 'DELETE', @@ -24,26 +31,42 @@ export const deleteSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ monitorId: schema.string({ minLength: 1, maxLength: 1024 }), }), }, - handler: async ({ request, response, savedObjectsClient, server }): Promise => { - const { monitorId } = request.params; + handler: async ({ + request, + response, + savedObjectsClient, + server: { encryptedSavedObjects, syntheticsService, logger, telemetry, kibanaVersion }, + }): Promise => { + const encryptedSavedObjectsClient = encryptedSavedObjects.getClient(); - const { syntheticsService } = server; + const { monitorId } = request.params; try { - const monitor = await savedObjectsClient.get( + const encryptedMonitor = await savedObjectsClient.get( syntheticsMonitorType, monitorId ); + const monitor = + await encryptedSavedObjectsClient.getDecryptedAsInternalUser( + syntheticsMonitor.name, + monitorId, + { + namespace: encryptedMonitor.namespaces?.[0], + } + ); + + const normalizedMonitor = normalizeSecrets(monitor); + await savedObjectsClient.delete(syntheticsMonitorType, monitorId); const errors = await syntheticsService.deleteConfigs(request, [ - { ...monitor.attributes, id: monitorId }, + { ...normalizedMonitor.attributes, id: monitorId }, ]); sendTelemetryEvents( - server.logger, - server.telemetry, - formatTelemetryDeleteEvent(monitor, server.kibanaVersion, new Date().toISOString(), errors) + logger, + telemetry, + formatTelemetryDeleteEvent(monitor, kibanaVersion, new Date().toISOString(), errors) ); if (errors && errors.length > 0) { diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts index 6170bdd72ac36..f590c45166fd5 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts @@ -8,16 +8,26 @@ import { schema } from '@kbn/config-schema'; import { SavedObjectsUpdateResponse, SavedObject } from 'kibana/server'; import { SavedObjectsErrorHelpers } from '../../../../../../src/core/server'; -import { MonitorFields, SyntheticsMonitor, ConfigKey } from '../../../common/runtime_types'; +import { + MonitorFields, + EncryptedSyntheticsMonitor, + SyntheticsMonitorWithSecrets, + SyntheticsMonitor, + ConfigKey, +} from '../../../common/runtime_types'; import { UMRestApiRouteFactory } from '../types'; import { API_URLS } from '../../../common/constants'; -import { syntheticsMonitorType } from '../../lib/saved_objects/synthetics_monitor'; +import { + syntheticsMonitorType, + syntheticsMonitor, +} from '../../lib/saved_objects/synthetics_monitor'; import { validateMonitor } from './monitor_validation'; import { getMonitorNotFoundResponse } from './service_errors'; import { sendTelemetryEvents, formatTelemetryUpdateEvent, } from './telemetry/monitor_upgrade_sender'; +import { formatSecrets, normalizeSecrets } from '../../lib/synthetics_service/utils/secrets'; // Simplify return promise type and type it with runtime_types export const editSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ @@ -29,31 +39,52 @@ export const editSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ }), body: schema.any(), }, - handler: async ({ request, response, savedObjectsClient, server }): Promise => { + handler: async ({ + request, + response, + savedObjectsClient, + server: { encryptedSavedObjects, syntheticsService, logger, telemetry, kibanaVersion }, + }): Promise => { + const encryptedSavedObjectsClient = encryptedSavedObjects.getClient(); const monitor = request.body as SyntheticsMonitor; - - const validationResult = validateMonitor(monitor as MonitorFields); - - if (!validationResult.valid) { - const { reason: message, details, payload } = validationResult; - return response.badRequest({ body: { message, attributes: { details, ...payload } } }); - } - const { monitorId } = request.params; - const { syntheticsService } = server; - try { - const previousMonitor: SavedObject = await savedObjectsClient.get( + const previousMonitor: SavedObject = await savedObjectsClient.get( syntheticsMonitorType, monitorId ); - const monitorWithRevision = { + + /* Decrypting the previous monitor before editing ensures that all existing fields remain + * on the object, even in flows where decryption does not take place, such as the enabled tab + * on the monitor list table. We do not decrypt monitors in bulk for the monitor list table */ + const decryptedPreviousMonitor = + await encryptedSavedObjectsClient.getDecryptedAsInternalUser( + syntheticsMonitor.name, + monitorId, + { + namespace: previousMonitor.namespaces?.[0], + } + ); + + const editedMonitor = { + ...normalizeSecrets(decryptedPreviousMonitor).attributes, ...monitor, - revision: (previousMonitor.attributes[ConfigKey.REVISION] || 0) + 1, }; - const editMonitor: SavedObjectsUpdateResponse = + const validationResult = validateMonitor(editedMonitor as MonitorFields); + + if (!validationResult.valid) { + const { reason: message, details, payload } = validationResult; + return response.badRequest({ body: { message, attributes: { details, ...payload } } }); + } + + const monitorWithRevision = formatSecrets({ + ...editedMonitor, + revision: (previousMonitor.attributes[ConfigKey.REVISION] || 0) + 1, + }); + + const editMonitor: SavedObjectsUpdateResponse = await savedObjectsClient.update( syntheticsMonitorType, monitorId, @@ -62,7 +93,7 @@ export const editSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ const errors = await syntheticsService.pushConfigs(request, [ { - ...(editMonitor.attributes as SyntheticsMonitor), + ...editedMonitor, id: editMonitor.id, fields: { config_id: editMonitor.id, @@ -72,9 +103,9 @@ export const editSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ ]); sendTelemetryEvents( - server.logger, - server.telemetry, - formatTelemetryUpdateEvent(editMonitor, previousMonitor, server.kibanaVersion, errors) + logger, + telemetry, + formatTelemetryUpdateEvent(editMonitor, previousMonitor, kibanaVersion, errors) ); // Return service sync errors in OK response @@ -89,6 +120,7 @@ export const editSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ if (SavedObjectsErrorHelpers.isNotFoundError(updateErr)) { return getMonitorNotFoundResponse(response, monitorId); } + logger.error(updateErr); throw updateErr; } diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_monitor.ts index 5b7052ffa061d..e32497b4dbc80 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_monitor.ts @@ -12,6 +12,7 @@ import { UMRestApiRouteFactory } from '../types'; import { API_URLS } from '../../../common/constants'; import { syntheticsMonitorType } from '../../lib/saved_objects/synthetics_monitor'; import { getMonitorNotFoundResponse } from './service_errors'; +import { normalizeSecrets } from '../../lib/synthetics_service/utils/secrets'; export const getSyntheticsMonitorRoute: UMRestApiRouteFactory = (libs: UMServerLibs) => ({ method: 'GET', @@ -21,10 +22,21 @@ export const getSyntheticsMonitorRoute: UMRestApiRouteFactory = (libs: UMServerL monitorId: schema.string({ minLength: 1, maxLength: 1024 }), }), }, - handler: async ({ request, response, savedObjectsClient }): Promise => { + handler: async ({ + request, + response, + server: { encryptedSavedObjects }, + savedObjectsClient, + }): Promise => { const { monitorId } = request.params; + const encryptedSavedObjectsClient = encryptedSavedObjects.getClient(); try { - return await libs.requests.getSyntheticsMonitor({ monitorId, savedObjectsClient }); + const monitorWithSecrets = await libs.requests.getSyntheticsMonitor({ + monitorId, + encryptedSavedObjectsClient, + savedObjectsClient, + }); + return normalizeSecrets(monitorWithSecrets); } catch (getErr) { if (SavedObjectsErrorHelpers.isNotFoundError(getErr)) { return getMonitorNotFoundResponse(response, monitorId); diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts index d4ac7c85c9586..2fe8d9eba761c 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts @@ -9,7 +9,7 @@ import type { Logger } from 'src/core/server'; import { SavedObjectsUpdateResponse, SavedObject } from 'kibana/server'; import { MonitorFields, - SyntheticsMonitor, + EncryptedSyntheticsMonitor, ConfigKey, ServiceLocationErrors, } from '../../../../common/runtime_types'; @@ -48,7 +48,7 @@ export function formatTelemetryEvent({ deletedAt, errors, }: { - monitor: SavedObject; + monitor: SavedObject; kibanaVersion: string; lastUpdatedAt?: string; durationSinceLastUpdated?: number; @@ -70,7 +70,7 @@ export function formatTelemetryEvent({ monitorNameLength: attributes[ConfigKey.NAME].length, monitorInterval: parseInt(attributes[ConfigKey.SCHEDULE].number, 10) * 60 * 1000, stackVersion: kibanaVersion, - scriptType: getScriptType(attributes as MonitorFields), + scriptType: getScriptType(attributes as Partial), errors: errors && errors?.length ? errors.map((e) => ({ @@ -88,8 +88,8 @@ export function formatTelemetryEvent({ } export function formatTelemetryUpdateEvent( - currentMonitor: SavedObjectsUpdateResponse, - previousMonitor: SavedObject, + currentMonitor: SavedObjectsUpdateResponse, + previousMonitor: SavedObject, kibanaVersion: string, errors?: ServiceLocationErrors ) { @@ -101,7 +101,7 @@ export function formatTelemetryUpdateEvent( } return formatTelemetryEvent({ - monitor: currentMonitor as SavedObject, + monitor: currentMonitor as SavedObject, kibanaVersion, durationSinceLastUpdated, lastUpdatedAt: previousMonitor.updated_at, @@ -110,7 +110,7 @@ export function formatTelemetryUpdateEvent( } export function formatTelemetryDeleteEvent( - previousMonitor: SavedObject, + previousMonitor: SavedObject, kibanaVersion: string, deletedAt: string, errors?: ServiceLocationErrors @@ -122,7 +122,7 @@ export function formatTelemetryDeleteEvent( } return formatTelemetryEvent({ - monitor: previousMonitor as SavedObject, + monitor: previousMonitor as SavedObject, kibanaVersion, durationSinceLastUpdated, lastUpdatedAt: previousMonitor.updated_at, @@ -131,12 +131,14 @@ export function formatTelemetryDeleteEvent( }); } -function getScriptType(attributes: MonitorFields): 'inline' | 'recorder' | 'zip' | undefined { +function getScriptType( + attributes: Partial +): 'inline' | 'recorder' | 'zip' | undefined { if (attributes[ConfigKey.SOURCE_ZIP_URL]) { return 'zip'; } else if ( attributes[ConfigKey.SOURCE_INLINE] && - attributes[ConfigKey.METADATA].script_source?.is_generated_script + attributes[ConfigKey.METADATA]?.script_source?.is_generated_script ) { return 'recorder'; } else if (attributes[ConfigKey.SOURCE_INLINE]) { diff --git a/x-pack/test/api_integration/apis/uptime/rest/add_monitor.ts b/x-pack/test/api_integration/apis/uptime/rest/add_monitor.ts index b7c1fc6bc5852..54c8cbc6b07a9 100644 --- a/x-pack/test/api_integration/apis/uptime/rest/add_monitor.ts +++ b/x-pack/test/api_integration/apis/uptime/rest/add_monitor.ts @@ -4,7 +4,9 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ +import { omit } from 'lodash'; import expect from '@kbn/expect'; +import { secretKeys } from '../../../../../plugins/uptime/common/constants/monitor_management'; import { HTTPFields } from '../../../../../plugins/uptime/common/runtime_types'; import { FtrProviderContext } from '../../../ftr_provider_context'; import { API_URLS } from '../../../../../plugins/uptime/common/constants'; @@ -33,7 +35,7 @@ export default function ({ getService }: FtrProviderContext) { .set('kbn-xsrf', 'true') .send(newMonitor); - expect(apiResponse.body.attributes).eql(newMonitor); + expect(apiResponse.body.attributes).eql(omit(newMonitor, secretKeys)); }); it('returns bad request if payload is invalid for HTTP monitor', async () => { diff --git a/x-pack/test/api_integration/apis/uptime/rest/edit_monitor.ts b/x-pack/test/api_integration/apis/uptime/rest/edit_monitor.ts index c453d28259a2c..4263d7aece810 100644 --- a/x-pack/test/api_integration/apis/uptime/rest/edit_monitor.ts +++ b/x-pack/test/api_integration/apis/uptime/rest/edit_monitor.ts @@ -5,7 +5,9 @@ * 2.0. */ import expect from '@kbn/expect'; +import { omit } from 'lodash'; import { SimpleSavedObject } from 'kibana/public'; +import { secretKeys } from '../../../../../plugins/uptime/common/constants/monitor_management'; import { ConfigKey, HTTPFields, @@ -46,14 +48,14 @@ export default function ({ getService }: FtrProviderContext) { newMonitor as MonitorFields ); - expect(savedMonitor).eql(newMonitor); + expect(savedMonitor).eql(omit(newMonitor, secretKeys)); const updates: Partial = { [ConfigKey.URLS]: 'https://modified-host.com', [ConfigKey.NAME]: 'Modified name', }; - const modifiedMonitor = { ...savedMonitor, ...updates, revision: 2 }; + const modifiedMonitor = { ...newMonitor, ...updates }; const editResponse = await supertest .put(API_URLS.SYNTHETICS_MONITORS + '/' + monitorId) @@ -61,7 +63,9 @@ export default function ({ getService }: FtrProviderContext) { .send(modifiedMonitor) .expect(200); - expect(editResponse.body.attributes).eql(modifiedMonitor); + expect(editResponse.body.attributes).eql( + omit({ ...modifiedMonitor, revision: 2 }, secretKeys) + ); }); it('returns 404 if monitor id is not present', async () => { @@ -83,7 +87,7 @@ export default function ({ getService }: FtrProviderContext) { ); // Delete a required property to make payload invalid - const toUpdate = { ...savedMonitor, 'check.request.headers': undefined }; + const toUpdate = { ...savedMonitor, 'check.request.headers': null }; const apiResponse = await supertest .put(API_URLS.SYNTHETICS_MONITORS + '/' + monitorId) diff --git a/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts b/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts index 37339cc0e0594..b24a83769caa9 100644 --- a/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts +++ b/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts @@ -10,6 +10,7 @@ import { SimpleSavedObject } from 'kibana/public'; import { MonitorFields } from '../../../../../plugins/uptime/common/runtime_types'; import { FtrProviderContext } from '../../../ftr_provider_context'; import { API_URLS } from '../../../../../plugins/uptime/common/constants'; +import { formatSecrets } from '../../../../../plugins/uptime/server/lib/synthetics_service/utils/secrets'; import { getFixtureJson } from './helper/get_fixture_json'; export default function ({ getService }: FtrProviderContext) { @@ -85,13 +86,17 @@ export default function ({ getService }: FtrProviderContext) { describe('get one monitor', () => { it('should get by id', async () => { - const [{ id: id1, attributes: mon1 }] = await Promise.all(monitors.map(saveMonitor)); + const [{ id: id1 }] = await Promise.all(monitors.map(saveMonitor)); const apiResponse = await supertest .get(API_URLS.SYNTHETICS_MONITORS + '/' + id1) .expect(200); - expect(apiResponse.body.attributes).eql(mon1); + expect(apiResponse.body.attributes).eql({ + ...monitors[0], + revision: 1, + secrets: formatSecrets(monitors[0]).secrets, + }); }); it('returns 404 if monitor id is not found', async () => { From 610fe94a00927cedc0de72d3420324f56b3a21d3 Mon Sep 17 00:00:00 2001 From: Caroline Horn <549577+cchaos@users.noreply.github.com> Date: Mon, 28 Mar 2022 15:54:59 -0400 Subject: [PATCH 050/160] [Space Selector Screen] General visual and styles cleanup (#128565) --- src/core/public/core_app/styles/_mixins.scss | 2 +- .../space_selector.test.tsx.snap | 106 +++++----- .../space_selector/components/space_card.tsx | 2 +- .../public/space_selector/space_selector.scss | 29 +-- .../public/space_selector/space_selector.tsx | 197 +++++++++--------- .../translations/translations/fr-FR.json | 1 - .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - 8 files changed, 162 insertions(+), 177 deletions(-) diff --git a/src/core/public/core_app/styles/_mixins.scss b/src/core/public/core_app/styles/_mixins.scss index d088a47144f33..a801ffd7a2cae 100644 --- a/src/core/public/core_app/styles/_mixins.scss +++ b/src/core/public/core_app/styles/_mixins.scss @@ -91,7 +91,7 @@ } &::before { - position: absolute; + position: fixed; top: 0; left: 0; z-index: 1; diff --git a/x-pack/plugins/spaces/public/space_selector/__snapshots__/space_selector.test.tsx.snap b/x-pack/plugins/spaces/public/space_selector/__snapshots__/space_selector.test.tsx.snap index a9fd636776a4f..294e183d183d8 100644 --- a/x-pack/plugins/spaces/public/space_selector/__snapshots__/space_selector.test.tsx.snap +++ b/x-pack/plugins/spaces/public/space_selector/__snapshots__/space_selector.test.tsx.snap @@ -1,66 +1,60 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`it renders without crashing 1`] = ` - - - + + + +

- - - - - -

- -

-
- -

- -

-
- - + - - - - - - +

+ +

+ + + + + + `; diff --git a/x-pack/plugins/spaces/public/space_selector/components/space_card.tsx b/x-pack/plugins/spaces/public/space_selector/components/space_card.tsx index 214659169e72d..5b1182c99029d 100644 --- a/x-pack/plugins/spaces/public/space_selector/components/space_card.tsx +++ b/x-pack/plugins/spaces/public/space_selector/components/space_card.tsx @@ -42,7 +42,7 @@ function renderSpaceAvatar(space: Space) { // not announcing space name here because the title of the EuiCard that the SpaceAvatar lives in is already // announcing it. See https://github.com/elastic/kibana/issues/27748 return ( - }> + }> ); diff --git a/x-pack/plugins/spaces/public/space_selector/space_selector.scss b/x-pack/plugins/spaces/public/space_selector/space_selector.scss index b888fb765b884..9d07d62564eb8 100644 --- a/x-pack/plugins/spaces/public/space_selector/space_selector.scss +++ b/x-pack/plugins/spaces/public/space_selector/space_selector.scss @@ -3,37 +3,26 @@ } .spcSpaceSelector__pageContent { - background-color: transparent; - box-shadow: none; - border: none; - text-align: center; position: relative; z-index: 10; } -.spcSpaceSelector__heading { - flex-direction: column; - flex-shrink: 0; - position: relative; - padding: $euiSizeXL; - z-index: 10; -} - -.spcSpaceSelector__logo { - @include kibanaCircleLogo; - @include euiBottomShadowMedium; - margin-bottom: $euiSizeXL; +// Fix forced focus outline on text that isn't a link to just be an underline +.spcSpaceSelector__pageHeader { + &:focus { + outline: none; + text-decoration: underline; + } } .spcSpaceSelector__searchHolder { width: $euiFormMaxWidth; // make sure it's as wide as our default form element width max-width: 100%; + margin-inline: auto; } .spcSpaceSelector__errorPanel { - position: relative; - margin: auto; - padding-left: $euiSizeXL; - padding-right: $euiSizeXL; + text-align: center; + margin-inline: auto; max-width: 700px; } diff --git a/x-pack/plugins/spaces/public/space_selector/space_selector.tsx b/x-pack/plugins/spaces/public/space_selector/space_selector.tsx index 438822de36134..f785d5dbf3677 100644 --- a/x-pack/plugins/spaces/public/space_selector/space_selector.tsx +++ b/x-pack/plugins/spaces/public/space_selector/space_selector.tsx @@ -9,17 +9,11 @@ import './space_selector.scss'; import { EuiFieldSearch, - EuiFlexGroup, - EuiFlexItem, - EuiIcon, EuiLoadingSpinner, - EuiPage, - EuiPageBody, - EuiPageContent, - EuiPageHeader, EuiPanel, EuiSpacer, EuiText, + EuiTextColor, EuiTitle, } from '@elastic/eui'; import React, { Component, Fragment } from 'react'; @@ -27,9 +21,13 @@ import ReactDOM from 'react-dom'; import { i18n } from '@kbn/i18n'; import { FormattedMessage } from '@kbn/i18n-react'; +import { KibanaSolutionAvatar } from '@kbn/shared-ux-components'; import type { AppMountParameters, CoreStart } from 'src/core/public'; -import { KibanaThemeProvider } from '../../../../../src/plugins/kibana_react/public'; +import { + KibanaPageTemplate, + KibanaThemeProvider, +} from '../../../../../src/plugins/kibana_react/public'; import type { Space } from '../../common'; import { SPACE_SEARCH_COUNT_THRESHOLD } from '../../common/constants'; import type { SpacesManager } from '../spaces_manager'; @@ -106,84 +104,90 @@ export class SpaceSelector extends Component { } return ( - - - - - - - - - -

- -

-
- -

- -

-
-
- - - {this.getSearchField()} - - - - - {this.state.loading && } - - {!this.state.loading && ( - - )} - - {!this.state.loading && !this.state.error && filteredSpaces.length === 0 && ( - - - + + + + + +

+ +

+ +

+ +

+
+
+ + + {this.getSearchField()} + + + + {this.state.loading && } + + {!this.state.loading && ( + + )} + + {!this.state.loading && !this.state.error && filteredSpaces.length === 0 && ( + + + + +

+ {i18n.translate( + 'xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription', + { + defaultMessage: 'No spaces match {searchTerm}', + values: { searchTerm: `"${this.state.searchTerm}"` }, + } + )} +

+
+
+
+ )} + + {!this.state.loading && this.state.error && ( + + + + +

+ +

+

- - - )} - - {!this.state.loading && this.state.error && ( - - - - - - - - - - - - )} - - - +

+
+
+
+ )} +
); } @@ -191,19 +195,20 @@ export class SpaceSelector extends Component { if (!this.state.spaces || this.state.spaces.length < SPACE_SEARCH_COUNT_THRESHOLD) { return null; } + + const inputLabel = i18n.translate('xpack.spaces.spaceSelector.findSpacePlaceholder', { + defaultMessage: 'Find a space', + }); + return ( - - { - - } - +
+ +
); }; diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 9056d2e6053b3..400ded66eec9b 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -23321,7 +23321,6 @@ "xpack.spaces.spaceSelector.contactSysAdminDescription": "Contactez votre administrateur système.", "xpack.spaces.spaceSelector.errorLoadingSpacesDescription": "Erreur lors du chargement des espaces ({message})", "xpack.spaces.spaceSelector.findSpacePlaceholder": "Rechercher un espace", - "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "Aucun espace ne correspond aux critères de recherche", "xpack.spaces.spaceSelector.selectSpacesTitle": "Sélectionner votre espace", "xpack.spaces.spacesTitle": "Espaces", "xpack.spaces.uiApi.errorBoundaryToastMessage": "Rechargez la page pour continuer.", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index e2e106515d408..1f4a558f32033 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -26650,7 +26650,6 @@ "xpack.spaces.spaceSelector.contactSysAdminDescription": "システム管理者にお問い合わせください。", "xpack.spaces.spaceSelector.errorLoadingSpacesDescription": "スペースの読み込みエラー({message})", "xpack.spaces.spaceSelector.findSpacePlaceholder": "スペースを検索", - "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "検索条件に一致するスペースがありません", "xpack.spaces.spaceSelector.selectSpacesTitle": "スペースの選択", "xpack.spaces.spacesTitle": "スペース", "xpack.spaces.uiApi.errorBoundaryToastMessage": "続行するにはページを再読み込みしてください。", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 0ddb9de4feb12..43474cbe6e99b 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -26679,7 +26679,6 @@ "xpack.spaces.spaceSelector.contactSysAdminDescription": "请联系您的系统管理员。", "xpack.spaces.spaceSelector.errorLoadingSpacesDescription": "加载工作区时出错 ({message})", "xpack.spaces.spaceSelector.findSpacePlaceholder": "查找工作区", - "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "没有匹配搜索条件的空间", "xpack.spaces.spaceSelector.selectSpacesTitle": "选择您的空间", "xpack.spaces.spacesTitle": "工作区", "xpack.spaces.uiApi.errorBoundaryToastMessage": "重新加载页面以继续。", From d8323c224667cc37871082f9f319a76214c1621d Mon Sep 17 00:00:00 2001 From: Anton Dosov Date: Mon, 28 Mar 2022 22:06:59 +0200 Subject: [PATCH 051/160] Fix KQL typeahead missing description (#128480) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * fix display description in typeahead * Design fixes - Fiddled with the flex properties to ensure the min-width for text is 250px but will expand in full until the edges are reached then both the text and description will start truncating - Remove now unused/unnecssary `—withDescription` class * remove description for fields suggestions Co-authored-by: cchaos --- .../kql_query_suggestion/field.test.ts | 4 +- .../providers/kql_query_suggestion/field.tsx | 16 ------- .../suggestion_component.test.tsx.snap | 2 + .../data/public/ui/typeahead/_suggestion.scss | 45 +++++++------------ .../ui/typeahead/suggestion_component.tsx | 14 +++++- .../ui/typeahead/suggestions_component.tsx | 8 ++-- test/functional/services/query_bar.ts | 12 +++++ .../translations/translations/fr-FR.json | 1 - .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - .../apps/discover/value_suggestions.ts | 6 +++ 11 files changed, 54 insertions(+), 56 deletions(-) diff --git a/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.test.ts b/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.test.ts index d5b071dda9f38..9462b8c5d171f 100644 --- a/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.test.ts +++ b/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.test.ts @@ -116,7 +116,7 @@ describe('Kuery field suggestions', () => { expect(keywordIndex).toBeLessThan(analyzedIndex); }); - test('should have descriptions', async () => { + test('should not have descriptions', async () => { const prefix = ''; const suffix = ''; const suggestions = await getSuggestions( @@ -125,7 +125,7 @@ describe('Kuery field suggestions', () => { ); expect(suggestions.length).toBeGreaterThan(0); suggestions.forEach((suggestion) => { - expect(suggestion).toHaveProperty('description'); + expect(suggestion).not.toHaveProperty('description'); }); }); diff --git a/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.tsx b/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.tsx index dc34cd8dee247..a0008101b5aec 100644 --- a/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.tsx +++ b/src/plugins/data/public/autocomplete/providers/kql_query_suggestion/field.tsx @@ -6,9 +6,7 @@ * Side Public License, v 1. */ -import React from 'react'; import { flatten } from 'lodash'; -import { FormattedMessage } from '@kbn/i18n-react'; import { escapeKuery } from './lib/escape_kuery'; import { sortPrefixFirst } from './sort_prefix_first'; import { @@ -19,18 +17,6 @@ import { } from '../../../../../../../src/plugins/data/public'; import { KqlQuerySuggestionProvider } from './types'; -const getDescription = (field: IFieldType) => { - return ( -

- {field.name} }} - /> -

- ); -}; - const keywordComparator = (first: IFieldType, second: IFieldType) => { const extensions = ['raw', 'keyword']; if (extensions.map((ext) => `${first.name}.${ext}`).includes(second.name)) { @@ -72,7 +58,6 @@ export const setupGetFieldSuggestions: KqlQuerySuggestionProvider 0 ? text.length - 2 @@ -81,7 +66,6 @@ export const setupGetFieldSuggestions: KqlQuerySuggestionProvider
This is not a helpful suggestion
@@ -63,6 +64,7 @@ exports[`SuggestionComponent Should make the element active if the selected prop
This is not a helpful suggestion
diff --git a/src/plugins/data/public/ui/typeahead/_suggestion.scss b/src/plugins/data/public/ui/typeahead/_suggestion.scss index 345c7493dc293..9e0c163f9c94c 100644 --- a/src/plugins/data/public/ui/typeahead/_suggestion.scss +++ b/src/plugins/data/public/ui/typeahead/_suggestion.scss @@ -4,6 +4,7 @@ $kbnTypeaheadTypes: ( value: $euiColorSuccess, operator: $euiColorPrimary, conjunction: $euiColorVis3, + recentSearch: $euiColorMediumShade, ); .kbnTypeahead.kbnTypeahead--small { @@ -88,11 +89,11 @@ $kbnTypeaheadTypes: ( } .kbnSuggestionItem { - display: flex; - flex-grow: 1; + display: inline-flex; align-items: center; font-size: $euiFontSizeXS; white-space: nowrap; + width: 100%; @each $name, $color in $kbnTypeaheadTypes { &.kbnSuggestionItem--#{$name} { @@ -102,29 +103,17 @@ $kbnTypeaheadTypes: ( } } } - - &.kbnSuggestionItem--recentSearch { - .kbnSuggestionItem__type { - background-color: $euiColorLightShade; - color: $euiColorMediumShade; - } - - .kbnSuggestionItem__text { - width: auto; - } - } } .kbnSuggestionItem__text, .kbnSuggestionItem__type, .kbnSuggestionItem__description { - flex-grow: 1; - flex-basis: 0%; - display: flex; - flex-direction: column; + padding-right: $euiSize; } .kbnSuggestionItem__type { + display: flex; + flex-direction: column; flex-grow: 0; flex-shrink: 0; flex-basis: auto; @@ -138,25 +127,28 @@ $kbnTypeaheadTypes: ( } .kbnSuggestionItem__text { - flex-grow: 0; /* 2 */ - flex-basis: auto; /* 2 */ font-family: $euiCodeFontFamily; - width: 250px; overflow: hidden; text-overflow: ellipsis; - padding: $euiSizeXS $euiSizeS; + padding-left: $euiSizeS; color: $euiTextColor; + min-width: 250px; } .kbnSuggestionItem__description { color: $euiColorDarkShade; overflow: hidden; text-overflow: ellipsis; - margin-left: $euiSizeXL; + flex-shrink: 1; + + // In case the description contains a paragraph in which the truncation needs to be at this level + > p { + overflow: hidden; + text-overflow: ellipsis; + } &:empty { - flex-grow: 0; - margin-left: 0; + width: 0; } } @@ -167,8 +159,3 @@ $kbnTypeaheadTypes: ( padding: 0 $euiSizeXS; display: inline-block; } - -.kbnSuggestionItem--value .kbnSuggestionItem__text { - flex-basis: 50%; - flex-grow: 1; -} diff --git a/src/plugins/data/public/ui/typeahead/suggestion_component.tsx b/src/plugins/data/public/ui/typeahead/suggestion_component.tsx index 8f555f710612b..938fdb5c9fb2b 100644 --- a/src/plugins/data/public/ui/typeahead/suggestion_component.tsx +++ b/src/plugins/data/public/ui/typeahead/suggestion_component.tsx @@ -75,7 +75,12 @@ export const SuggestionComponent = React.memo(function SuggestionComponent(props props.suggestion.type }-${props.suggestion.text.replace(/\s/g, '-')}`} > -
+
@@ -83,7 +88,12 @@ export const SuggestionComponent = React.memo(function SuggestionComponent(props {props.suggestion.text}
{props.shouldDisplayDescription && ( -
{props.suggestion.description}
+
+ {props.suggestion.description} +
)}
diff --git a/src/plugins/data/public/ui/typeahead/suggestions_component.tsx b/src/plugins/data/public/ui/typeahead/suggestions_component.tsx index 7a0a4378c4ddc..a5ee6f31ada31 100644 --- a/src/plugins/data/public/ui/typeahead/suggestions_component.tsx +++ b/src/plugins/data/public/ui/typeahead/suggestions_component.tsx @@ -88,14 +88,14 @@ export default class SuggestionsComponent extends PureComponent - {(containerWidth: number) => ( + {(rect: DOMRect) => (
- {renderSuggestions(containerWidth)} + {renderSuggestions(rect.width)}
)} @@ -158,9 +158,9 @@ const StyledSuggestionsListDiv = styled.div` const ResizableSuggestionsListDiv: React.FC<{ inputContainer: HTMLElement; suggestionsSize?: SuggestionsListSize; + children: (rect: DOMRect) => ReactNode; }> = React.memo((props) => { const inputContainer = props.inputContainer; - const children = props.children as (rect: DOMRect) => ReactNode; const [{ documentHeight }, { pageYOffset }, containerRect] = useDimensions(inputContainer); @@ -191,7 +191,7 @@ const ResizableSuggestionsListDiv: React.FC<{ ['kbnTypeahead__popover--top']: !isSuggestionsListFittable, })} > - {children(containerRect)} + {props.children(containerRect)} diff --git a/test/functional/services/query_bar.ts b/test/functional/services/query_bar.ts index 55a27f0423eed..ec5fc039101a5 100644 --- a/test/functional/services/query_bar.ts +++ b/test/functional/services/query_bar.ts @@ -96,4 +96,16 @@ export class QueryBarService extends FtrService { } }); } + + private async getSuggestionsDescription() { + const suggestions = await this.testSubjects.findAll('autoCompleteSuggestionDescription'); + return Promise.all(suggestions.map((suggestion) => suggestion.getVisibleText())); + } + + public async expectSuggestionsDescription({ count }: { count: number }) { + await this.retry.try(async () => { + const suggestions = await this.getSuggestionsDescription(); + expect(suggestions.length).to.be(count); + }); + } } diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 400ded66eec9b..103097e1a9b9a 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -1616,7 +1616,6 @@ "data.kueryAutocomplete.equalOperatorDescription.equalsText": "égale", "data.kueryAutocomplete.existOperatorDescription": "{exists} sous un certain format", "data.kueryAutocomplete.existOperatorDescription.existsText": "existe", - "data.kueryAutocomplete.filterResultsDescription": "Filtrer les résultats contenant {fieldName}", "data.kueryAutocomplete.greaterThanOperatorDescription": "est {greaterThan} une certaine valeur", "data.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "supérieur à", "data.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "est {greaterThanOrEqualTo} une certaine valeur", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 1f4a558f32033..90f8cc4ce970c 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -1939,7 +1939,6 @@ "data.kueryAutocomplete.equalOperatorDescription.equalsText": "一致する", "data.kueryAutocomplete.existOperatorDescription": "いずれかの形式中に{exists}", "data.kueryAutocomplete.existOperatorDescription.existsText": "存在する", - "data.kueryAutocomplete.filterResultsDescription": "{fieldName}を含む結果をフィルタリング", "data.kueryAutocomplete.greaterThanOperatorDescription": "が一部の値{greaterThan}", "data.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "より大きい", "data.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "が一部の値{greaterThanOrEqualTo}", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 43474cbe6e99b..7af2c39da66eb 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -1944,7 +1944,6 @@ "data.kueryAutocomplete.equalOperatorDescription.equalsText": "等于", "data.kueryAutocomplete.existOperatorDescription": "以任意形式{exists}", "data.kueryAutocomplete.existOperatorDescription.existsText": "存在", - "data.kueryAutocomplete.filterResultsDescription": "筛选包含 {fieldName} 的结果", "data.kueryAutocomplete.greaterThanOperatorDescription": "{greaterThan}某一值", "data.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "大于", "data.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "{greaterThanOrEqualTo}某一值", diff --git a/x-pack/test/functional/apps/discover/value_suggestions.ts b/x-pack/test/functional/apps/discover/value_suggestions.ts index e67d42bf27896..34fbebbba5b55 100644 --- a/x-pack/test/functional/apps/discover/value_suggestions.ts +++ b/x-pack/test/functional/apps/discover/value_suggestions.ts @@ -68,6 +68,12 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { await queryBar.setQuery('extension.raw : '); await queryBar.expectSuggestions({ count: 5, contains: '"jpg"' }); }); + + it('also displays descriptions for operators', async () => { + await PageObjects.timePicker.setDefaultAbsoluteRange(); + await queryBar.setQuery('extension.raw'); + await queryBar.expectSuggestionsDescription({ count: 2 }); + }); }); describe('context', () => { From 4235f8157e0ac9767343ea712bafaba2c7b3c4dc Mon Sep 17 00:00:00 2001 From: Jiawei Wu <74562234+JiaweiWu@users.noreply.github.com> Date: Mon, 28 Mar 2022 13:08:25 -0700 Subject: [PATCH 052/160] [ResponseOps] Execution log - data grid component, date picker, and status filter (#128183) * Event log and alerts tab in rule summary * Fix tests * Event log implementation in rule summary page * Unit testing * run lint * rule event log unit tests * Load execution API unit test * With bulk rule api test update * Fix lint * Address comments * Fix feature flag test * Fix import type linting * Integration test and fixed lint * Lazy load execution log list * Bump up triggers_actions_ui limits.yml size to 100kbs * Address comments Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- packages/kbn-optimizer/limits.yml | 2 +- .../alerting/common/execution_log_types.ts | 40 ++ x-pack/plugins/alerting/common/index.ts | 1 + .../lib/get_execution_log_aggregation.ts | 24 +- .../server/rules_client/rules_client.ts | 2 +- .../common/experimental_features.ts | 2 +- .../public/application/constants/index.ts | 32 ++ .../application/lib/monitoring_utils.test.ts | 2 + .../application/lib/monitoring_utils.ts | 17 +- .../public/application/lib/rule_api/index.ts | 2 + .../load_execution_log_aggregations.test.ts | 96 ++++ .../load_execution_log_aggregations.ts | 97 ++++ .../with_bulk_rule_api_operations.test.tsx | 37 ++ .../with_bulk_rule_api_operations.tsx | 12 + .../components/alert_muted_switch.tsx | 2 +- .../rule_details/components/rule.test.tsx | 193 +++++-- .../sections/rule_details/components/rule.tsx | 195 ++----- .../components/rule_alert_list.tsx | 168 ++++++ .../components/rule_event_log_list.test.tsx | 504 ++++++++++++++++++ .../components/rule_event_log_list.tsx | 446 ++++++++++++++++ ...rule_event_log_list_cell_renderer.test.tsx | 62 +++ .../rule_event_log_list_cell_renderer.tsx | 48 ++ .../components/rule_event_log_list_status.tsx | 42 ++ ...rule_event_log_list_status_filter.test.tsx | 62 +++ .../rule_event_log_list_status_filter.tsx | 79 +++ .../sections/rule_details/components/types.ts | 21 + .../common/get_experimental_features.test.tsx | 4 +- .../apps/triggers_actions_ui/details.ts | 141 ++++- .../page_objects/triggers_actions_ui_page.ts | 33 ++ 29 files changed, 2133 insertions(+), 233 deletions(-) create mode 100644 x-pack/plugins/alerting/common/execution_log_types.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.test.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_alert_list.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.test.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.test.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.test.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/types.ts diff --git a/packages/kbn-optimizer/limits.yml b/packages/kbn-optimizer/limits.yml index 34c2285016086..25656a3977fea 100644 --- a/packages/kbn-optimizer/limits.yml +++ b/packages/kbn-optimizer/limits.yml @@ -56,7 +56,7 @@ pageLoadAssetSize: telemetry: 51957 telemetryManagementSection: 38586 transform: 41007 - triggersActionsUi: 100000 + triggersActionsUi: 102400 upgradeAssistant: 81241 uptime: 40825 urlForwarding: 32579 diff --git a/x-pack/plugins/alerting/common/execution_log_types.ts b/x-pack/plugins/alerting/common/execution_log_types.ts new file mode 100644 index 0000000000000..0307985265160 --- /dev/null +++ b/x-pack/plugins/alerting/common/execution_log_types.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export const executionLogSortableColumns = [ + 'timestamp', + 'execution_duration', + 'total_search_duration', + 'es_search_duration', + 'schedule_delay', + 'num_triggered_actions', +] as const; + +export type ExecutionLogSortFields = typeof executionLogSortableColumns[number]; + +export interface IExecutionLog { + id: string; + timestamp: string; + duration_ms: number; + status: string; + message: string; + num_active_alerts: number; + num_new_alerts: number; + num_recovered_alerts: number; + num_triggered_actions: number; + num_succeeded_actions: number; + num_errored_actions: number; + total_search_duration_ms: number; + es_search_duration_ms: number; + schedule_delay_ms: number; + timed_out: boolean; +} + +export interface IExecutionLogResult { + total: number; + data: IExecutionLog[]; +} diff --git a/x-pack/plugins/alerting/common/index.ts b/x-pack/plugins/alerting/common/index.ts index 8a6fec74fb619..732d9061e58da 100644 --- a/x-pack/plugins/alerting/common/index.ts +++ b/x-pack/plugins/alerting/common/index.ts @@ -20,6 +20,7 @@ export * from './builtin_action_groups'; export * from './disabled_action_groups'; export * from './alert_notify_when_type'; export * from './parse_duration'; +export * from './execution_log_types'; export interface AlertingFrameworkHealth { isSufficientlySecure: boolean; diff --git a/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts b/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts index 22b7d15f72c11..d090e7f649228 100644 --- a/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts +++ b/x-pack/plugins/alerting/server/lib/get_execution_log_aggregation.ts @@ -10,6 +10,7 @@ import Boom from '@hapi/boom'; import { flatMap, get } from 'lodash'; import { parseDuration } from '.'; import { AggregateEventsBySavedObjectResult } from '../../../event_log/server'; +import { IExecutionLog, IExecutionLogResult } from '../../common'; const DEFAULT_MAX_BUCKETS_LIMIT = 1000; // do not retrieve more than this number of executions @@ -29,29 +30,6 @@ const EXECUTION_UUID_FIELD = 'kibana.alert.rule.execution.uuid'; const Millis2Nanos = 1000 * 1000; -export interface IExecutionLog { - id: string; - timestamp: string; - duration_ms: number; - status: string; - message: string; - num_active_alerts: number; - num_new_alerts: number; - num_recovered_alerts: number; - num_triggered_actions: number; - num_succeeded_actions: number; - num_errored_actions: number; - total_search_duration_ms: number; - es_search_duration_ms: number; - schedule_delay_ms: number; - timed_out: boolean; -} - -export interface IExecutionLogResult { - total: number; - data: IExecutionLog[]; -} - export const EMPTY_EXECUTION_LOG_RESULT = { total: 0, data: [], diff --git a/x-pack/plugins/alerting/server/rules_client/rules_client.ts b/x-pack/plugins/alerting/server/rules_client/rules_client.ts index c60fce223bea7..ab34158861ad2 100644 --- a/x-pack/plugins/alerting/server/rules_client/rules_client.ts +++ b/x-pack/plugins/alerting/server/rules_client/rules_client.ts @@ -88,8 +88,8 @@ import { AlertingRulesConfig } from '../config'; import { formatExecutionLogResult, getExecutionLogAggregation, - IExecutionLogResult, } from '../lib/get_execution_log_aggregation'; +import { IExecutionLogResult } from '../../common'; import { validateSnoozeDate } from '../lib/validate_snooze_date'; import { RuleMutedError } from '../lib/errors/rule_muted'; import { diff --git a/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts b/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts index fa848d56e0113..c3ae062d76523 100644 --- a/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts +++ b/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts @@ -13,7 +13,7 @@ export type ExperimentalFeatures = typeof allowedExperimentalValues; */ export const allowedExperimentalValues = Object.freeze({ rulesListDatagrid: true, - rulesDetailLogs: false, + rulesDetailLogs: true, }); type ExperimentalConfigKeys = Array; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts b/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts index 77282f834f9fd..0058147ca0d05 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts +++ b/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts @@ -38,3 +38,35 @@ export enum SORT_ORDERS { export const DEFAULT_SEARCH_PAGE_SIZE: number = 10; export const DEFAULT_RULE_INTERVAL = '1m'; + +export const RULE_EXECUTION_LOG_COLUMN_IDS = [ + 'id', + 'timestamp', + 'execution_duration', + 'status', + 'message', + 'num_active_alerts', + 'num_new_alerts', + 'num_recovered_alerts', + 'num_triggered_actions', + 'num_succeeded_actions', + 'num_errored_actions', + 'total_search_duration', + 'es_search_duration', + 'schedule_delay', + 'timed_out', +] as const; + +export const RULE_EXECUTION_LOG_DURATION_COLUMNS = [ + 'execution_duration', + 'total_search_duration', + 'es_search_duration', + 'schedule_delay', +]; + +export const RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS = [ + 'timestamp', + 'execution_duration', + 'status', + 'message', +]; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.test.ts b/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.test.ts index 2ac04ffd6eaaf..7f06baf8698f6 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.test.ts +++ b/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.test.ts @@ -19,7 +19,9 @@ describe('monitoring_utils', () => { it('should return a formatted duration', () => { expect(getFormattedDuration(0)).toEqual('00:00'); expect(getFormattedDuration(100.111)).toEqual('00:00'); + expect(getFormattedDuration(500)).toEqual('00:01'); expect(getFormattedDuration(50000)).toEqual('00:50'); + expect(getFormattedDuration(59900)).toEqual('01:00'); expect(getFormattedDuration(500000)).toEqual('08:20'); expect(getFormattedDuration(5000000)).toEqual('83:20'); expect(getFormattedDuration(50000000)).toEqual('833:20'); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.ts b/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.ts index f5bec63056103..a71d7b8f8efdd 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.ts +++ b/x-pack/plugins/triggers_actions_ui/public/application/lib/monitoring_utils.ts @@ -16,10 +16,21 @@ export function getFormattedDuration(value: number) { if (!value) { return '00:00'; } + const duration = moment.duration(value); - const minutes = Math.floor(duration.asMinutes()).toString().padStart(2, '0'); - const seconds = duration.seconds().toString().padStart(2, '0'); - return `${minutes}:${seconds}`; + let minutes = Math.floor(duration.asMinutes()); + let seconds = duration.seconds(); + const ms = duration.milliseconds(); + + if (ms >= 500) { + seconds += 1; + if (seconds === 60) { + seconds = 0; + minutes += 1; + } + } + + return `${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`; } export function getFormattedMilliseconds(value: number) { diff --git a/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/index.ts b/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/index.ts index 75e2bdc8b4a2b..89ede79f4a21d 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/index.ts +++ b/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/index.ts @@ -19,6 +19,8 @@ export { muteRule, muteRules } from './mute'; export { loadRuleTypes } from './rule_types'; export { loadRules } from './rules'; export { loadRuleState } from './state'; +export type { LoadExecutionLogAggregationsProps } from './load_execution_log_aggregations'; +export { loadExecutionLogAggregations } from './load_execution_log_aggregations'; export { unmuteAlertInstance } from './unmute_alert'; export { unmuteRule, unmuteRules } from './unmute'; export { updateRule } from './update'; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.test.ts b/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.test.ts new file mode 100644 index 0000000000000..c323f0d4fa189 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.test.ts @@ -0,0 +1,96 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { httpServiceMock } from '../../../../../../../src/core/public/mocks'; +import { loadExecutionLogAggregations, SortField } from './load_execution_log_aggregations'; + +const http = httpServiceMock.createStartContract(); + +const mockResponse = { + data: [ + { + duration_ms: 50, + es_search_duration_ms: 1, + id: '13af2138-1c9d-4d34-95c1-c25fbfbb8eeb', + message: "rule executed: .index-threshold:c8f2ccb0-aac4-11ec-a5ae-2101bb96406d: 'test'", + num_active_alerts: 0, + num_errored_actions: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_succeeded_actions: 0, + num_triggered_actions: 0, + schedule_delay_ms: 1623, + status: 'success', + timed_out: false, + timestamp: '2022-03-23T16:17:53.482Z', + total_search_duration_ms: 4, + }, + ], + total: 5, +}; + +describe('loadExecutionLogAggregations', () => { + test('should call load execution log aggregation API', async () => { + http.get.mockResolvedValueOnce(mockResponse); + + const sortTimestamp = { + timestamp: { + order: 'asc', + }, + } as SortField; + + const result = await loadExecutionLogAggregations({ + id: 'test-id', + dateStart: '2022-03-23T16:17:53.482Z', + dateEnd: '2022-03-23T16:17:53.482Z', + filter: ['success', 'unknown'], + perPage: 10, + page: 0, + sort: [sortTimestamp], + http, + }); + + expect(result).toEqual({ + ...mockResponse, + data: [ + { + execution_duration: 50, + es_search_duration: 1, + id: '13af2138-1c9d-4d34-95c1-c25fbfbb8eeb', + message: "rule executed: .index-threshold:c8f2ccb0-aac4-11ec-a5ae-2101bb96406d: 'test'", + num_active_alerts: 0, + num_errored_actions: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_succeeded_actions: 0, + num_triggered_actions: 0, + schedule_delay: 1623, + status: 'success', + timed_out: false, + timestamp: '2022-03-23T16:17:53.482Z', + total_search_duration: 4, + }, + ], + }); + + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/internal/alerting/rule/test-id/_execution_log", + Object { + "query": Object { + "date_end": "2022-03-23T16:17:53.482Z", + "date_start": "2022-03-23T16:17:53.482Z", + "filter": "success OR unknown", + "page": 1, + "per_page": 10, + "sort": "[{\\"timestamp\\":{\\"order\\":\\"asc\\"}}]", + }, + }, + ] + `); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.ts b/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.ts new file mode 100644 index 0000000000000..2dceac6dfd7d9 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/lib/rule_api/load_execution_log_aggregations.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +/* eslint-disable @typescript-eslint/naming-convention */ + +import { HttpSetup } from 'kibana/public'; +import type { SortOrder } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { INTERNAL_BASE_ALERTING_API_PATH } from '../../constants'; + +import { + IExecutionLogResult, + IExecutionLog, + ExecutionLogSortFields, +} from '../../../../../alerting/common'; +import { AsApiContract, RewriteRequestCase } from '../../../../../actions/common'; + +const getRenamedLog = (data: IExecutionLog) => { + const { + duration_ms, + total_search_duration_ms, + es_search_duration_ms, + schedule_delay_ms, + ...rest + } = data; + + return { + execution_duration: data.duration_ms, + total_search_duration: data.total_search_duration_ms, + es_search_duration: data.es_search_duration_ms, + schedule_delay: data.schedule_delay_ms, + ...rest, + }; +}; + +const rewriteBodyRes: RewriteRequestCase = ({ data, total }: any) => ({ + data: data.map((log: IExecutionLog) => getRenamedLog(log)), + total, +}); + +const getFilter = (filter: string[] | undefined) => { + if (!filter || !filter.length) { + return; + } + return filter.join(' OR '); +}; + +export type SortField = Record< + ExecutionLogSortFields, + { + order: SortOrder; + } +>; + +export interface LoadExecutionLogAggregationsProps { + id: string; + dateStart: string; + dateEnd?: string; + filter?: string[]; + perPage?: number; + page?: number; + sort?: SortField[]; +} + +export const loadExecutionLogAggregations = async ({ + id, + http, + dateStart, + dateEnd, + filter, + perPage = 10, + page = 0, + sort = [], +}: LoadExecutionLogAggregationsProps & { http: HttpSetup }) => { + const sortField: any[] = sort; + + const result = await http.get>( + `${INTERNAL_BASE_ALERTING_API_PATH}/rule/${id}/_execution_log`, + { + query: { + date_start: dateStart, + date_end: dateEnd, + filter: getFilter(filter), + per_page: perPage, + // Need to add the + 1 for pages because APIs are 1 indexed, + // whereas data grid sorts are 0 indexed. + page: page + 1, + sort: sortField.length ? JSON.stringify(sortField) : undefined, + }, + } + ); + + return rewriteBodyRes(result); +}; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.test.tsx index d0950c0c75fc2..1eefd329d2a4d 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.test.tsx @@ -10,6 +10,8 @@ import { shallow, mount } from 'enzyme'; import uuid from 'uuid'; import { withBulkRuleOperations, ComponentOpts } from './with_bulk_rule_api_operations'; import * as ruleApi from '../../../lib/rule_api'; +import { SortField } from '../../../lib/rule_api/load_execution_log_aggregations'; + import { Rule } from '../../../../types'; import { useKibana } from '../../../../common/lib/kibana'; jest.mock('../../../../common/lib/kibana'); @@ -37,6 +39,7 @@ describe('with_bulk_rule_api_operations', () => { expect(typeof props.loadRule).toEqual('function'); expect(typeof props.loadRuleTypes).toEqual('function'); expect(typeof props.resolveRule).toEqual('function'); + expect(typeof props.loadExecutionLogAggregations).toEqual('function'); return
; }; @@ -246,6 +249,40 @@ describe('with_bulk_rule_api_operations', () => { expect(ruleApi.loadRuleTypes).toHaveBeenCalledTimes(1); expect(ruleApi.loadRuleTypes).toHaveBeenCalledWith({ http }); }); + + it('loadExecutionLogAggregations calls the loadExecutionLogAggregations api', () => { + const { http } = useKibanaMock().services; + + const sortTimestamp = { + timestamp: { + order: 'asc', + }, + } as SortField; + + const callProps = { + id: 'test-id', + dateStart: '2022-03-23T16:17:53.482Z', + dateEnd: '2022-03-23T16:17:53.482Z', + filter: ['success', 'unknown'], + perPage: 10, + page: 0, + sort: [sortTimestamp], + }; + + const ComponentToExtend = ({ loadExecutionLogAggregations }: ComponentOpts) => { + return ; + }; + + const ExtendedComponent = withBulkRuleOperations(ComponentToExtend); + const component = mount(); + component.find('button').simulate('click'); + + expect(ruleApi.loadExecutionLogAggregations).toHaveBeenCalledTimes(1); + expect(ruleApi.loadExecutionLogAggregations).toHaveBeenCalledWith({ + ...callProps, + http, + }); + }); }); function mockRule(overloads: Partial = {}): Rule { diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.tsx index d9bafe5816d69..a9c9dfa72279c 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/common/components/with_bulk_rule_api_operations.tsx @@ -33,7 +33,10 @@ import { loadRuleTypes, alertingFrameworkHealth, resolveRule, + loadExecutionLogAggregations, + LoadExecutionLogAggregationsProps, } from '../../../lib/rule_api'; +import { IExecutionLogResult } from '../../../../../../alerting/common'; import { useKibana } from '../../../../common/lib/kibana'; export interface ComponentOpts { @@ -59,6 +62,9 @@ export interface ComponentOpts { loadRuleState: (id: Rule['id']) => Promise; loadRuleSummary: (id: Rule['id'], numberOfExecutions?: number) => Promise; loadRuleTypes: () => Promise; + loadExecutionLogAggregations: ( + props: LoadExecutionLogAggregationsProps + ) => Promise; getHealth: () => Promise; resolveRule: (id: Rule['id']) => Promise; } @@ -131,6 +137,12 @@ export function withBulkRuleOperations( loadRuleSummary({ http, ruleId, numberOfExecutions }) } loadRuleTypes={async () => loadRuleTypes({ http })} + loadExecutionLogAggregations={async (loadProps: LoadExecutionLogAggregationsProps) => + loadExecutionLogAggregations({ + ...loadProps, + http, + }) + } resolveRule={async (ruleId: Rule['id']) => resolveRule({ http, ruleId })} getHealth={async () => alertingFrameworkHealth({ http })} /> diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/alert_muted_switch.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/alert_muted_switch.tsx index 3f236ea25a19b..b63300a83fcbc 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/alert_muted_switch.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/alert_muted_switch.tsx @@ -8,7 +8,7 @@ import React, { useState } from 'react'; import { EuiSwitch, EuiLoadingSpinner } from '@elastic/eui'; -import { AlertListItem } from './rule'; +import { AlertListItem } from './types'; interface ComponentOpts { alert: AlertListItem; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx index ac103f113a8f1..737501f444300 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx @@ -10,13 +10,20 @@ import uuid from 'uuid'; import { shallow } from 'enzyme'; import { mountWithIntl, nextTick } from '@kbn/test-jest-helpers'; import { act } from 'react-dom/test-utils'; -import { RuleComponent, AlertListItem, alertToListItem } from './rule'; +import { RuleComponent, alertToListItem } from './rule'; +import { AlertListItem } from './types'; +import { RuleAlertList } from './rule_alert_list'; import { Rule, RuleSummary, AlertStatus, RuleType } from '../../../../types'; -import { EuiBasicTable } from '@elastic/eui'; import { ExecutionDurationChart } from '../../common/components/execution_duration_chart'; jest.mock('../../../../common/lib/kibana'); +jest.mock('../../../../common/get_experimental_features', () => ({ + getIsExperimentalFeatureEnabled: jest.fn(), +})); + +import { getIsExperimentalFeatureEnabled } from '../../../../common/get_experimental_features'; + const fakeNow = new Date('2020-02-09T23:15:41.941Z'); const fake2MinutesAgo = new Date('2020-02-09T23:13:41.941Z'); @@ -29,12 +36,16 @@ const mockAPIs = { }; beforeAll(() => { - jest.resetAllMocks(); + jest.clearAllMocks(); global.Date.now = jest.fn(() => fakeNow.getTime()); }); +beforeEach(() => { + (getIsExperimentalFeatureEnabled as jest.Mock).mockImplementation(() => false); +}); + describe('rules', () => { - it('render a list of rules', () => { + it('render a list of rules', async () => { const rule = mockRule(); const ruleType = mockRuleType(); const ruleSummary = mockRuleSummary({ @@ -59,19 +70,22 @@ describe('rules', () => { alertToListItem(fakeNow.getTime(), ruleType, 'first_rule', ruleSummary.alerts.first_rule), ]; - expect( - shallow( - - ) - .find(EuiBasicTable) - .prop('items') - ).toEqual(rules); + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await new Promise((resolve) => setTimeout(resolve)); + wrapper.update(); + }); + + expect(wrapper.find(RuleAlertList).prop('items')).toEqual(rules); }); it('render a hidden field with duration epoch', () => { @@ -95,7 +109,7 @@ describe('rules', () => { ).toEqual(fake2MinutesAgo.getTime()); }); - it('render all active rules', () => { + it('render all active rules', async () => { const rule = mockRule(); const ruleType = mockRuleType(); const alerts: Record = { @@ -108,27 +122,31 @@ describe('rules', () => { muted: false, }, }; - expect( - shallow( - - ) - .find(EuiBasicTable) - .prop('items') - ).toEqual([ + + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await new Promise((resolve) => setTimeout(resolve)); + wrapper.update(); + }); + + expect(wrapper.find(RuleAlertList).prop('items')).toEqual([ alertToListItem(fakeNow.getTime(), ruleType, 'us-central', alerts['us-central']), alertToListItem(fakeNow.getTime(), ruleType, 'us-east', alerts['us-east']), ]); }); - it('render all inactive rules', () => { + it('render all inactive rules', async () => { const rule = mockRule({ mutedInstanceIds: ['us-west', 'us-east'], }); @@ -136,30 +154,33 @@ describe('rules', () => { const ruleUsWest: AlertStatus = { status: 'OK', muted: false }; const ruleUsEast: AlertStatus = { status: 'OK', muted: false }; - expect( - shallow( - - ) - .find(EuiBasicTable) - .prop('items') - ).toEqual([ + 'us-east': { + status: 'OK', + muted: false, + }, + }, + })} + /> + ); + + await act(async () => { + await new Promise((resolve) => setTimeout(resolve)); + wrapper.update(); + }); + + expect(wrapper.find(RuleAlertList).prop('items')).toEqual([ alertToListItem(fakeNow.getTime(), ruleType, 'us-west', ruleUsWest), alertToListItem(fakeNow.getTime(), ruleType, 'us-east', ruleUsEast), ]); @@ -379,6 +400,64 @@ describe('execution duration overview', () => { }); }); +describe('tabbed content', () => { + it('tabbed content renders when the event log experiment is on', async () => { + // Enable the event log experiment + (getIsExperimentalFeatureEnabled as jest.Mock).mockImplementation(() => true); + + const rule = mockRule(); + const ruleType = mockRuleType(); + const ruleSummary = mockRuleSummary({ + alerts: { + first_rule: { + status: 'OK', + muted: false, + actionGroupId: 'default', + }, + second_rule: { + status: 'Active', + muted: false, + actionGroupId: 'action group id unknown', + }, + }, + }); + + const wrapper = shallow( + + ); + + const tabbedContent = wrapper.find('[data-test-subj="ruleDetailsTabbedContent"]').dive(); + + // Need to mock this function + (tabbedContent.instance() as any).focusTab = jest.fn(); + tabbedContent.update(); + + await act(async () => { + await new Promise((resolve) => setTimeout(resolve)); + tabbedContent.update(); + }); + + expect(tabbedContent.find('[aria-labelledby="rule_event_log_list"]').exists()).toBeTruthy(); + expect(tabbedContent.find('[aria-labelledby="rule_alert_list"]').exists()).toBeFalsy(); + + tabbedContent.find('[data-test-subj="ruleAlertListTab"]').simulate('click'); + + expect(tabbedContent.find('[aria-labelledby="rule_event_log_list"]').exists()).toBeFalsy(); + expect(tabbedContent.find('[aria-labelledby="rule_alert_list"]').exists()).toBeTruthy(); + + tabbedContent.find('[data-test-subj="eventLogListTab"]').simulate('click'); + + expect(tabbedContent.find('[aria-labelledby="rule_event_log_list"]').exists()).toBeTruthy(); + expect(tabbedContent.find('[aria-labelledby="rule_alert_list"]').exists()).toBeFalsy(); + }); +}); + function mockRule(overloads: Partial = {}): Rule { return { id: uuid.v4(), diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.tsx index 1a08f12c11743..c3eb699cc0c90 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.tsx @@ -5,37 +5,32 @@ * 2.0. */ -import React, { useState } from 'react'; -import moment, { Duration } from 'moment'; +import React, { lazy } from 'react'; import { i18n } from '@kbn/i18n'; import { - EuiBasicTable, EuiHealth, EuiSpacer, - EuiToolTip, EuiFlexGroup, EuiFlexItem, EuiHorizontalRule, EuiPanel, EuiStat, EuiIconTip, + EuiTabbedContent, } from '@elastic/eui'; // @ts-ignore import { RIGHT_ALIGNMENT, CENTER_ALIGNMENT } from '@elastic/eui/lib/services'; -import { padStart, chunk } from 'lodash'; import { ActionGroup, AlertExecutionStatusErrorReasons, AlertStatusValues, } from '../../../../../../alerting/common'; -import { Rule, RuleSummary, AlertStatus, RuleType, Pagination } from '../../../../types'; +import { Rule, RuleSummary, AlertStatus, RuleType } from '../../../../types'; import { ComponentOpts as RuleApis, withBulkRuleOperations, } from '../../common/components/with_bulk_rule_api_operations'; -import { DEFAULT_SEARCH_PAGE_SIZE } from '../../../constants'; import './rule.scss'; -import { AlertMutedSwitch } from './alert_muted_switch'; import { getHealthColor } from '../../rules_list/components/rule_status_filter'; import { rulesStatusesTranslationsMapping, @@ -46,6 +41,14 @@ import { shouldShowDurationWarning, } from '../../../lib/execution_duration_utils'; import { ExecutionDurationChart } from '../../common/components/execution_duration_chart'; +// import { RuleEventLogListWithApi } from './rule_event_log_list'; +import { AlertListItem } from './types'; +import { getIsExperimentalFeatureEnabled } from '../../../../common/get_experimental_features'; +import { suspendedComponentWithProps } from '../../../lib/suspended_component_with_props'; + +const RuleEventLogListWithApi = lazy(() => import('./rule_event_log_list')); + +const RuleAlertList = lazy(() => import('./rule_alert_list')); type RuleProps = { rule: Rule; @@ -59,95 +62,8 @@ type RuleProps = { isLoadingChart?: boolean; } & Pick; -export const alertsTableColumns = ( - onMuteAction: (alert: AlertListItem) => Promise, - readOnly: boolean -) => [ - { - field: 'alert', - name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.Alert', { - defaultMessage: 'Alert', - }), - sortable: false, - truncateText: true, - width: '45%', - 'data-test-subj': 'alertsTableCell-alert', - render: (value: string) => { - return ( - - {value} - - ); - }, - }, - { - field: 'status', - name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.status', { - defaultMessage: 'Status', - }), - width: '15%', - render: (value: AlertListItemStatus) => { - return ( - - {value.label} - {value.actionGroup ? ` (${value.actionGroup})` : ``} - - ); - }, - sortable: false, - 'data-test-subj': 'alertsTableCell-status', - }, - { - field: 'start', - width: '190px', - render: (value: Date | undefined) => { - return value ? moment(value).format('D MMM YYYY @ HH:mm:ss') : ''; - }, - name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.start', { - defaultMessage: 'Start', - }), - sortable: false, - 'data-test-subj': 'alertsTableCell-start', - }, - { - field: 'duration', - render: (value: number) => { - return value ? durationAsString(moment.duration(value)) : ''; - }, - name: i18n.translate( - 'xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.duration', - { defaultMessage: 'Duration' } - ), - sortable: false, - width: '80px', - 'data-test-subj': 'alertsTableCell-duration', - }, - { - field: '', - align: RIGHT_ALIGNMENT, - width: '60px', - name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.mute', { - defaultMessage: 'Mute', - }), - render: (alert: AlertListItem) => { - return ( - await onMuteAction(alert)} - alert={alert} - /> - ); - }, - sortable: false, - 'data-test-subj': 'alertsTableCell-actions', - }, -]; - -function durationAsString(duration: Duration): string { - return [duration.hours(), duration.minutes(), duration.seconds()] - .map((value) => padStart(`${value}`, 2, '0')) - .join(':'); -} +const EVENT_LOG_LIST_TAB = 'rule_event_log_list'; +const ALERT_LIST_TAB = 'rule_alert_list'; export function RuleComponent({ rule, @@ -162,17 +78,10 @@ export function RuleComponent({ durationEpoch = Date.now(), isLoadingChart, }: RuleProps) { - const [pagination, setPagination] = useState({ - index: 0, - size: DEFAULT_SEARCH_PAGE_SIZE, - }); - const alerts = Object.entries(ruleSummary.alerts) .map(([alertId, alert]) => alertToListItem(durationEpoch, ruleType, alertId, alert)) .sort((leftAlert, rightAlert) => leftAlert.sortPriority - rightAlert.sortPriority); - const pageOfAlerts = getPage(alerts, pagination); - const onMuteAction = async (alert: AlertListItem) => { await (alert.isMuted ? unmuteAlertInstance(rule, alert.alert) @@ -192,6 +101,44 @@ export function RuleComponent({ ? ALERT_STATUS_LICENSE_ERROR : rulesStatusesTranslationsMapping[rule.executionStatus.status]; + const renderRuleAlertList = () => { + return suspendedComponentWithProps( + RuleAlertList, + 'xl' + )({ + items: alerts, + readOnly, + onMuteAction, + }); + }; + + const tabs = [ + { + id: EVENT_LOG_LIST_TAB, + name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.rule.eventLogTabText', { + defaultMessage: 'Execution History', + }), + 'data-test-subj': 'eventLogListTab', + content: suspendedComponentWithProps(RuleEventLogListWithApi, 'xl')({ rule }), + }, + { + id: ALERT_LIST_TAB, + name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.rule.alertsTabText', { + defaultMessage: 'Alerts', + }), + 'data-test-subj': 'ruleAlertListTab', + content: renderRuleAlertList(), + }, + ]; + + const renderTabs = () => { + const isEnabled = getIsExperimentalFeatureEnabled('rulesDetailLogs'); + if (isEnabled) { + return ; + } + return renderRuleAlertList(); + }; + return ( <> @@ -277,50 +224,12 @@ export function RuleComponent({ name="alertsDurationEpoch" value={durationEpoch} /> - { - setPagination(changedPage); - }} - rowProps={() => ({ - 'data-test-subj': 'alert-row', - })} - cellProps={() => ({ - 'data-test-subj': 'cell', - })} - columns={alertsTableColumns(onMuteAction, readOnly)} - data-test-subj="alertsList" - tableLayout="fixed" - className="alertsList" - /> + {renderTabs()} ); } export const RuleWithApi = withBulkRuleOperations(RuleComponent); -function getPage(items: any[], pagination: Pagination) { - return chunk(items, pagination.size)[pagination.index] || []; -} - -interface AlertListItemStatus { - label: string; - healthColor: string; - actionGroup?: string; -} -export interface AlertListItem { - alert: string; - status: AlertListItemStatus; - start?: Date; - duration: number; - isMuted: boolean; - sortPriority: number; -} - const ACTIVE_LABEL = i18n.translate( 'xpack.triggersActionsUI.sections.ruleDetails.rulesList.status.active', { defaultMessage: 'Active' } diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_alert_list.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_alert_list.tsx new file mode 100644 index 0000000000000..5756edd360393 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_alert_list.tsx @@ -0,0 +1,168 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useMemo, useCallback, useState } from 'react'; +import moment, { Duration } from 'moment'; +import { padStart, chunk } from 'lodash'; +import { EuiHealth, EuiBasicTable, EuiToolTip } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { RIGHT_ALIGNMENT } from '@elastic/eui/lib/services'; +import { DEFAULT_SEARCH_PAGE_SIZE } from '../../../constants'; +import { Pagination } from '../../../../types'; +import { AlertListItemStatus, AlertListItem } from './types'; +import { AlertMutedSwitch } from './alert_muted_switch'; + +const durationAsString = (duration: Duration): string => { + return [duration.hours(), duration.minutes(), duration.seconds()] + .map((value) => padStart(`${value}`, 2, '0')) + .join(':'); +}; + +const alertsTableColumns = ( + onMuteAction: (alert: AlertListItem) => Promise, + readOnly: boolean +) => [ + { + field: 'alert', + name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.Alert', { + defaultMessage: 'Alert', + }), + sortable: false, + truncateText: true, + width: '45%', + 'data-test-subj': 'alertsTableCell-alert', + render: (value: string) => { + return ( + + {value} + + ); + }, + }, + { + field: 'status', + name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.status', { + defaultMessage: 'Status', + }), + width: '15%', + render: (value: AlertListItemStatus) => { + return ( + + {value.label} + {value.actionGroup ? ` (${value.actionGroup})` : ``} + + ); + }, + sortable: false, + 'data-test-subj': 'alertsTableCell-status', + }, + { + field: 'start', + width: '190px', + render: (value: Date | undefined) => { + return value ? moment(value).format('D MMM YYYY @ HH:mm:ss') : ''; + }, + name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.start', { + defaultMessage: 'Start', + }), + sortable: false, + 'data-test-subj': 'alertsTableCell-start', + }, + { + field: 'duration', + render: (value: number) => { + return value ? durationAsString(moment.duration(value)) : ''; + }, + name: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.duration', + { defaultMessage: 'Duration' } + ), + sortable: false, + width: '80px', + 'data-test-subj': 'alertsTableCell-duration', + }, + { + field: '', + align: RIGHT_ALIGNMENT, + width: '60px', + name: i18n.translate('xpack.triggersActionsUI.sections.ruleDetails.alertsList.columns.mute', { + defaultMessage: 'Mute', + }), + render: (alert: AlertListItem) => { + return ( + await onMuteAction(alert)} + alert={alert} + /> + ); + }, + sortable: false, + 'data-test-subj': 'alertsTableCell-actions', + }, +]; + +interface RuleAlertListProps { + items: AlertListItem[]; + readOnly: boolean; + onMuteAction: (alert: AlertListItem) => Promise; +} + +const getRowProps = () => ({ + 'data-test-subj': 'alert-row', +}); + +const getCellProps = () => ({ + 'data-test-subj': 'cell', +}); + +function getPage(items: T[], pagination: Pagination) { + return chunk(items, pagination.size)[pagination.index] || []; +} + +export const RuleAlertList = (props: RuleAlertListProps) => { + const { items, readOnly, onMuteAction } = props; + + const [pagination, setPagination] = useState({ + index: 0, + size: DEFAULT_SEARCH_PAGE_SIZE, + }); + + const pageOfAlerts = getPage(items, pagination); + + const paginationOptions = useMemo(() => { + return { + pageIndex: pagination.index, + pageSize: pagination.size, + totalItemCount: items.length, + }; + }, [pagination, items]); + + const onChange = useCallback( + ({ page: changedPage }: { page: Pagination }) => { + setPagination(changedPage); + }, + [setPagination] + ); + + return ( + + items={pageOfAlerts} + pagination={paginationOptions} + onChange={onChange} + rowProps={getRowProps} + cellProps={getCellProps} + columns={alertsTableColumns(onMuteAction, readOnly)} + data-test-subj="alertsList" + tableLayout="fixed" + className="alertsList" + /> + ); +}; + +// eslint-disable-next-line import/no-default-export +export { RuleAlertList as default }; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.test.tsx new file mode 100644 index 0000000000000..008e19bcb99bf --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.test.tsx @@ -0,0 +1,504 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import uuid from 'uuid'; +import { act } from 'react-dom/test-utils'; +import { mountWithIntl, nextTick } from '@kbn/test-jest-helpers'; +import { useKibana } from '../../../../common/lib/kibana'; + +import { EuiSuperDatePicker, EuiDataGrid } from '@elastic/eui'; +import { RuleEventLogListStatusFilter } from './rule_event_log_list_status_filter'; +import { RuleEventLogList } from './rule_event_log_list'; +import { RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS } from '../../../constants'; +import { Rule } from '../../../../types'; + +const useKibanaMock = useKibana as jest.Mocked; +jest.mock('../../../../common/lib/kibana'); + +const mockLogResponse: any = { + data: [ + { + id: uuid.v4(), + timestamp: '2022-03-20T07:40:44-07:00', + duration: 5000000, + status: 'success', + message: 'rule execution #1', + num_active_alerts: 2, + num_new_alerts: 4, + num_recovered_alerts: 3, + num_triggered_actions: 10, + num_succeeded_actions: 0, + num_errored_actions: 4, + total_search_duration: 1000000, + es_search_duration: 1400000, + schedule_delay: 2000000, + timed_out: false, + }, + { + id: uuid.v4(), + timestamp: '2022-03-20T07:40:45-07:00', + duration: 6000000, + status: 'success', + message: 'rule execution #2', + num_active_alerts: 4, + num_new_alerts: 2, + num_recovered_alerts: 4, + num_triggered_actions: 5, + num_succeeded_actions: 3, + num_errored_actions: 0, + total_search_duration: 300000, + es_search_duration: 300000, + schedule_delay: 300000, + timed_out: false, + }, + { + id: uuid.v4(), + timestamp: '2022-03-20T07:40:46-07:00', + duration: 340000, + status: 'failure', + message: 'rule execution #3', + num_active_alerts: 8, + num_new_alerts: 5, + num_recovered_alerts: 0, + num_triggered_actions: 1, + num_succeeded_actions: 1, + num_errored_actions: 4, + total_search_duration: 2300000, + es_search_duration: 2300000, + schedule_delay: 2300000, + timed_out: false, + }, + { + id: uuid.v4(), + timestamp: '2022-03-21T07:40:46-07:00', + duration: 3000000, + status: 'unknown', + message: 'rule execution #4', + num_active_alerts: 4, + num_new_alerts: 4, + num_recovered_alerts: 4, + num_triggered_actions: 4, + num_succeeded_actions: 4, + num_errored_actions: 4, + total_search_duration: 400000, + es_search_duration: 400000, + schedule_delay: 400000, + timed_out: false, + }, + ], + total: 4, +}; + +const mockRule: Rule = { + id: uuid.v4(), + enabled: true, + name: `rule-${uuid.v4()}`, + tags: [], + ruleTypeId: '.noop', + consumer: 'consumer', + schedule: { interval: '1m' }, + actions: [], + params: {}, + createdBy: null, + updatedBy: null, + createdAt: new Date(), + updatedAt: new Date(), + apiKeyOwner: null, + throttle: null, + notifyWhen: null, + muteAll: false, + mutedInstanceIds: [], + executionStatus: { + status: 'unknown', + lastExecutionDate: new Date('2020-08-20T19:23:38Z'), + }, +}; + +const loadExecutionLogAggregationsMock = jest.fn(); + +describe('rule_event_log_list', () => { + beforeEach(() => { + jest.clearAllMocks(); + useKibanaMock().services.uiSettings.get = jest.fn().mockImplementation((value: string) => { + if (value === 'timepicker:quickRanges') { + return [ + { + from: 'now-15m', + to: 'now', + display: 'Last 15 minutes', + }, + ]; + } + }); + loadExecutionLogAggregationsMock.mockResolvedValue(mockLogResponse); + }); + + it('renders correctly', async () => { + const wrapper = mountWithIntl( + + ); + + // Run the initial load fetch call + expect(loadExecutionLogAggregationsMock).toHaveBeenCalledTimes(1); + + expect(loadExecutionLogAggregationsMock).toHaveBeenCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: [], + page: 0, + perPage: 10, + }) + ); + + // Loading + expect(wrapper.find(EuiSuperDatePicker).props().isLoading).toBeTruthy(); + + // Verify the initial columns are rendered + RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS.forEach((column) => { + expect(wrapper.find(`[data-test-subj="dataGridHeaderCell-${column}"]`).exists()).toBeTruthy(); + }); + + // No data initially + expect(wrapper.find('[data-gridcell-column-id="timestamp"]').length).toEqual(1); + + // Let the load resolve + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(wrapper.find(EuiSuperDatePicker).props().isLoading).toBeFalsy(); + + expect(wrapper.find(RuleEventLogListStatusFilter).exists()).toBeTruthy(); + expect(wrapper.find('[data-gridcell-column-id="timestamp"]').length).toEqual(5); + expect(wrapper.find(EuiDataGrid).props().rowCount).toEqual(mockLogResponse.total); + }); + + it('can sort by single and/or multiple column(s)', async () => { + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + let headerCellButton = wrapper.find('[data-test-subj="dataGridHeaderCell-timestamp"] button'); + + headerCellButton.simulate('click'); + + let headerAction = wrapper.find('[data-test-subj="dataGridHeaderCellActionGroup-timestamp"]'); + + expect(headerAction.exists()).toBeTruthy(); + + // Sort by the timestamp column + headerAction.find('li').at(1).find('button').simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [ + { + timestamp: { + order: 'asc', + }, + }, + ], + filter: [], + page: 0, + perPage: 10, + }) + ); + + // Open the popover again + headerCellButton.simulate('click'); + + headerAction = wrapper.find('[data-test-subj="dataGridHeaderCellActionGroup-timestamp"]'); + + // Sort by the timestamp column, this time, in the opposite direction + headerAction.find('li').at(2).find('button').simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [ + { + timestamp: { + order: 'desc', + }, + }, + ], + filter: [], + page: 0, + perPage: 10, + }) + ); + + // Find another column + headerCellButton = wrapper.find( + '[data-test-subj="dataGridHeaderCell-execution_duration"] button' + ); + + // Open the popover again + headerCellButton.simulate('click'); + + headerAction = wrapper.find( + '[data-test-subj="dataGridHeaderCellActionGroup-execution_duration"]' + ); + + // Sort + headerAction.find('li').at(1).find('button').simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [ + { + timestamp: { order: 'desc' }, + }, + { + execution_duration: { order: 'asc' }, + }, + ], + filter: [], + page: 0, + perPage: 10, + }) + ); + }); + + it('can filter by execution log outcome status', async () => { + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + // Filter by success + wrapper.find('[data-test-subj="ruleEventLogStatusFilterButton"]').at(0).simulate('click'); + + wrapper.find('[data-test-subj="ruleEventLogStatusFilter-success"]').at(0).simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: ['success'], + page: 0, + perPage: 10, + }) + ); + + // Filter by failure as well + wrapper.find('[data-test-subj="ruleEventLogStatusFilterButton"]').at(0).simulate('click'); + + wrapper.find('[data-test-subj="ruleEventLogStatusFilter-failure"]').at(0).simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: ['success', 'failure'], + page: 0, + perPage: 10, + }) + ); + }); + + it('can paginate', async () => { + loadExecutionLogAggregationsMock.mockResolvedValue({ + ...mockLogResponse, + total: 100, + }); + + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(wrapper.find('.euiPagination').exists()).toBeTruthy(); + + // Paginate to the next page + wrapper.find('.euiPagination .euiPagination__item a').at(0).simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: [], + page: 1, + perPage: 10, + }) + ); + + // Change the page size + wrapper.find('[data-test-subj="tablePaginationPopoverButton"] button').simulate('click'); + + wrapper.find('[data-test-subj="tablePagination-50-rows"] button').simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: [], + page: 0, + perPage: 50, + }) + ); + }); + + it('can filter by start and end date', async () => { + const nowMock = jest.spyOn(Date, 'now').mockReturnValue(0); + + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: [], + page: 0, + perPage: 10, + dateStart: '1969-12-30T19:00:00-05:00', + dateEnd: '1969-12-31T19:00:00-05:00', + }) + ); + + wrapper + .find('[data-test-subj="superDatePickerToggleQuickMenuButton"] button') + .simulate('click'); + + wrapper + .find('[data-test-subj="superDatePickerCommonlyUsed_Last_15 minutes"] button') + .simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect(loadExecutionLogAggregationsMock).toHaveBeenLastCalledWith( + expect.objectContaining({ + id: mockRule.id, + sort: [], + filter: [], + page: 0, + perPage: 10, + dateStart: '1969-12-31T18:45:00-05:00', + dateEnd: '1969-12-31T19:00:00-05:00', + }) + ); + + nowMock.mockRestore(); + }); + + it('can save display columns to localStorage', async () => { + const wrapper = mountWithIntl( + + ); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect( + JSON.parse( + localStorage.getItem('xpack.triggersActionsUI.ruleEventLogList.initialColumns') ?? 'null' + ) + ).toEqual(RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS); + + wrapper.find('[data-test-subj="dataGridColumnSelectorButton"] button').simulate('click'); + + wrapper + .find( + '[data-test-subj="dataGridColumnSelectorToggleColumnVisibility-num_active_alerts"] button' + ) + .simulate('click'); + + await act(async () => { + await nextTick(); + wrapper.update(); + }); + + expect( + JSON.parse( + localStorage.getItem('xpack.triggersActionsUI.ruleEventLogList.initialColumns') ?? 'null' + ) + ).toEqual([...RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS, 'num_active_alerts']); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.tsx new file mode 100644 index 0000000000000..9a6814d1dd9c4 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list.tsx @@ -0,0 +1,446 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useCallback, useEffect, useState, useMemo } from 'react'; +import { i18n } from '@kbn/i18n'; +import datemath from '@elastic/datemath'; +import { + EuiDataGrid, + EuiFlexItem, + EuiFlexGroup, + EuiProgress, + EuiSpacer, + EuiDataGridSorting, + Pagination, + EuiSuperDatePicker, + EuiDataGridCellValueElementProps, + OnTimeChangeProps, +} from '@elastic/eui'; +import { useKibana } from '../../../../common/lib/kibana'; +import { RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS } from '../../../constants'; +import { RuleEventLogListStatusFilter } from './rule_event_log_list_status_filter'; +import { RuleEventLogListCellRenderer, ColumnId } from './rule_event_log_list_cell_renderer'; + +import { LoadExecutionLogAggregationsProps } from '../../../lib/rule_api'; +import { Rule } from '../../../../types'; +import { + IExecutionLog, + executionLogSortableColumns, + ExecutionLogSortFields, +} from '../../../../../../alerting/common'; +import { + ComponentOpts as RuleApis, + withBulkRuleOperations, +} from '../../common/components/with_bulk_rule_api_operations'; + +const getParsedDate = (date: string) => { + if (date.includes('now')) { + return datemath.parse(date)?.format() || date; + } + return date; +}; + +const getIsColumnSortable = (columnId: string) => { + return executionLogSortableColumns.includes(columnId as ExecutionLogSortFields); +}; + +const columns = [ + { + id: 'id', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.id', + { + defaultMessage: 'Id', + } + ), + isSortable: getIsColumnSortable('id'), + }, + { + id: 'timestamp', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.timestamp', + { + defaultMessage: 'Timestamp', + } + ), + isSortable: getIsColumnSortable('timestamp'), + initialWidth: 250, + }, + { + id: 'execution_duration', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.duration', + { + defaultMessage: 'Duration', + } + ), + isSortable: getIsColumnSortable('execution_duration'), + initialWidth: 100, + }, + { + id: 'status', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.status', + { + defaultMessage: 'Status', + } + ), + isSortable: getIsColumnSortable('status'), + initialWidth: 100, + }, + { + id: 'message', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.message', + { + defaultMessage: 'Message', + } + ), + isSortable: getIsColumnSortable('message'), + }, + { + id: 'num_active_alerts', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.activeAlerts', + { + defaultMessage: 'Active alerts', + } + ), + isSortable: getIsColumnSortable('num_active_alerts'), + }, + { + id: 'num_new_alerts', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.newAlerts', + { + defaultMessage: 'New alerts', + } + ), + isSortable: getIsColumnSortable('num_new_alerts'), + }, + { + id: 'num_recovered_alerts', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.recoveredAlerts', + { + defaultMessage: 'Recovered alerts', + } + ), + isSortable: getIsColumnSortable('num_recovered_alerts'), + }, + { + id: 'num_triggered_actions', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.triggeredActions', + { + defaultMessage: 'Triggered actions', + } + ), + isSortable: getIsColumnSortable('num_triggered_actions'), + }, + { + id: 'num_succeeded_actions', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.succeededActions', + { + defaultMessage: 'Succeeded actions', + } + ), + isSortable: getIsColumnSortable('num_succeeded_actions'), + }, + { + id: 'num_errored_actions', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.erroredActions', + { + defaultMessage: 'Errored actions', + } + ), + isSortable: getIsColumnSortable('num_errored_actions'), + }, + { + id: 'total_search_duration', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.totalSearchDuration', + { + defaultMessage: 'Total search duration', + } + ), + isSortable: getIsColumnSortable('total_search_duration'), + }, + { + id: 'es_search_duration', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.esSearchDuration', + { + defaultMessage: 'ES search duration', + } + ), + isSortable: getIsColumnSortable('es_search_duration'), + }, + { + id: 'schedule_delay', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.scheduleDelay', + { + defaultMessage: 'Schedule delay', + } + ), + isSortable: getIsColumnSortable('schedule_delay'), + }, + { + id: 'timed_out', + displayAsText: i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.timedOut', + { + defaultMessage: 'Timed out', + } + ), + isSortable: getIsColumnSortable('timed_out'), + }, +]; + +const API_FAILED_MESSAGE = i18n.translate( + 'xpack.triggersActionsUI.sections.ruleDetails.eventLogColumn.apiError', + { + defaultMessage: 'Failed to fetch execution history', + } +); + +const RULE_EVENT_LOG_LIST_STORAGE_KEY = 'xpack.triggersActionsUI.ruleEventLogList.initialColumns'; + +const PAGE_SIZE_OPTION = [10, 50, 100]; + +const updateButtonProps = { + iconOnly: true, + fill: false, +}; + +export type RuleEventLogListProps = { + rule: Rule; + localStorageKey?: string; +} & Pick; + +export const RuleEventLogList = (props: RuleEventLogListProps) => { + const { + rule, + localStorageKey = RULE_EVENT_LOG_LIST_STORAGE_KEY, + loadExecutionLogAggregations, + } = props; + + const { uiSettings, notifications } = useKibana().services; + + // Data grid states + const [logs, setLogs] = useState([]); + const [visibleColumns, setVisibleColumns] = useState(() => { + return ( + JSON.parse(localStorage.getItem(localStorageKey) ?? 'null') || + RULE_EXECUTION_DEFAULT_INITIAL_VISIBLE_COLUMNS + ); + }); + const [sortingColumns, setSortingColumns] = useState([]); + const [filter, setFilter] = useState([]); + const [pagination, setPagination] = useState({ + pageIndex: 0, + pageSize: 10, + totalItemCount: 0, + }); + + // Date related states + const [isLoading, setIsLoading] = useState(false); + const [dateStart, setDateStart] = useState('now-24h'); + const [dateEnd, setDateEnd] = useState('now'); + const [dateFormat] = useState(() => uiSettings?.get('dateFormat')); + const [commonlyUsedRanges] = useState(() => { + return ( + uiSettings + ?.get('timepicker:quickRanges') + ?.map(({ from, to, display }: { from: string; to: string; display: string }) => ({ + start: from, + end: to, + label: display, + })) || [] + ); + }); + + // Main cell renderer, renders durations, statuses, etc. + const renderCell = ({ rowIndex, columnId }: EuiDataGridCellValueElementProps) => { + const { pageIndex, pageSize } = pagination; + const pagedRowIndex = rowIndex - pageIndex * pageSize; + + const value = logs?.[pagedRowIndex]?.[columnId as keyof IExecutionLog] as string; + return ( + + ); + }; + + // Computed data grid props + const sortingProps = useMemo( + () => ({ + onSort: setSortingColumns, + columns: sortingColumns, + }), + [sortingColumns] + ); + + // Formats the sort columns to be consumed by the API endpoint + const formattedSort = useMemo(() => { + return sortingColumns.map(({ id: sortId, direction }) => ({ + [sortId]: { + order: direction, + }, + })); + }, [sortingColumns]); + + const loadEventLogs = async () => { + setIsLoading(true); + try { + const result = await loadExecutionLogAggregations({ + id: rule.id, + sort: formattedSort as LoadExecutionLogAggregationsProps['sort'], + filter, + dateStart: getParsedDate(dateStart), + dateEnd: getParsedDate(dateEnd), + page: pagination.pageIndex, + perPage: pagination.pageSize, + }); + setLogs(result.data); + setPagination({ + ...pagination, + totalItemCount: result.total, + }); + } catch (e) { + notifications.toasts.addDanger({ + title: API_FAILED_MESSAGE, + text: e.body.message, + }); + } + setIsLoading(false); + }; + + const onChangeItemsPerPage = useCallback( + (pageSize: number) => { + setPagination((prevPagination) => ({ + ...prevPagination, + pageIndex: 0, + pageSize, + })); + }, + [setPagination] + ); + + const onChangePage = useCallback( + (pageIndex: number) => { + setPagination((prevPagination) => ({ + ...prevPagination, + pageIndex, + })); + }, + [setPagination] + ); + + const paginationProps = useMemo( + () => ({ + ...pagination, + pageSizeOptions: PAGE_SIZE_OPTION, + onChangeItemsPerPage, + onChangePage, + }), + [pagination, onChangeItemsPerPage, onChangePage] + ); + + const columnVisibilityProps = useMemo( + () => ({ + visibleColumns, + setVisibleColumns, + }), + [visibleColumns, setVisibleColumns] + ); + + const onTimeChange = useCallback( + ({ start, end, isInvalid }: OnTimeChangeProps) => { + if (isInvalid) { + return; + } + setDateStart(start); + setDateEnd(end); + }, + [setDateStart, setDateEnd] + ); + + const onRefresh = () => { + loadEventLogs(); + }; + + const onFilterChange = useCallback( + (newFilter: string[]) => { + setPagination((prevPagination) => ({ + ...prevPagination, + pageIndex: 0, + })); + setFilter(newFilter); + }, + [setPagination, setFilter] + ); + + useEffect(() => { + loadEventLogs(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [sortingColumns, dateStart, dateEnd, filter, pagination.pageIndex, pagination.pageSize]); + + useEffect(() => { + localStorage.setItem(localStorageKey, JSON.stringify(visibleColumns)); + }, [localStorageKey, visibleColumns]); + + return ( +
+ + + + + + + + + + + {isLoading && ( + + )} + +
+ ); +}; + +export const RuleEventLogListWithApi = withBulkRuleOperations(RuleEventLogList); + +// eslint-disable-next-line import/no-default-export +export { RuleEventLogListWithApi as default }; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.test.tsx new file mode 100644 index 0000000000000..f973815dbd586 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.test.tsx @@ -0,0 +1,62 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import moment from 'moment'; +import { EuiIcon } from '@elastic/eui'; +import { shallow, mount } from 'enzyme'; +import { + RuleEventLogListCellRenderer, + DEFAULT_DATE_FORMAT, +} from './rule_event_log_list_cell_renderer'; +import { RuleEventLogListStatus } from './rule_event_log_list_status'; +import { RuleDurationFormat } from '../../../sections/rules_list/components/rule_duration_format'; + +describe('rule_event_log_list_cell_renderer', () => { + it('renders primitive values correctly', () => { + const wrapper = shallow(); + + expect(wrapper.text()).toEqual('test'); + }); + + it('renders undefined correctly', () => { + const wrapper = shallow(); + + expect(wrapper.text()).toBeFalsy(); + }); + + it('renders date duration correctly', () => { + const wrapper = shallow( + + ); + + expect(wrapper.find(RuleDurationFormat).exists()).toBeTruthy(); + expect(wrapper.find(RuleDurationFormat).props().duration).toEqual(100000); + }); + + it('renders timestamps correctly', () => { + const time = '2022-03-20T07:40:44-07:00'; + const wrapper = shallow(); + + expect(wrapper.text()).toEqual(moment(time).format(DEFAULT_DATE_FORMAT)); + }); + + it('renders alert status correctly', () => { + const wrapper = shallow(); + + expect(wrapper.find(RuleEventLogListStatus).exists()).toBeTruthy(); + expect(wrapper.find(RuleEventLogListStatus).props().status).toEqual('success'); + }); + + it('unaccounted status will still render, but with the unknown color', () => { + const wrapper = mount(); + + expect(wrapper.find(RuleEventLogListStatus).exists()).toBeTruthy(); + expect(wrapper.find(RuleEventLogListStatus).text()).toEqual('newOutcome'); + expect(wrapper.find(EuiIcon).props().color).toEqual('gray'); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.tsx new file mode 100644 index 0000000000000..ea502f6c5ebbc --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_cell_renderer.tsx @@ -0,0 +1,48 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import moment from 'moment'; +import { EcsEventOutcome } from 'kibana/server'; +import { RuleEventLogListStatus } from './rule_event_log_list_status'; +import { RuleDurationFormat } from '../../../sections/rules_list/components/rule_duration_format'; +import { + RULE_EXECUTION_LOG_COLUMN_IDS, + RULE_EXECUTION_LOG_DURATION_COLUMNS, +} from '../../../constants'; + +export const DEFAULT_DATE_FORMAT = 'MMM D, YYYY @ HH:mm:ss.SSS'; + +export type ColumnId = typeof RULE_EXECUTION_LOG_COLUMN_IDS[number]; + +interface RuleEventLogListCellRendererProps { + columnId: ColumnId; + value?: string; + dateFormat?: string; +} + +export const RuleEventLogListCellRenderer = (props: RuleEventLogListCellRendererProps) => { + const { columnId, value, dateFormat = DEFAULT_DATE_FORMAT } = props; + + if (typeof value === 'undefined') { + return null; + } + + if (columnId === 'status') { + return ; + } + + if (columnId === 'timestamp') { + return <>{moment(value).format(dateFormat)}; + } + + if (RULE_EXECUTION_LOG_DURATION_COLUMNS.includes(columnId)) { + return ; + } + + return <>{value}; +}; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status.tsx new file mode 100644 index 0000000000000..8b50ec1469698 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { EuiIcon } from '@elastic/eui'; +import { EcsEventOutcome } from 'kibana/server'; + +interface RuleEventLogListStatusProps { + status: EcsEventOutcome; +} + +const statusContainerStyles = { + display: 'flex', + alignItems: 'center', + textTransform: 'capitalize' as const, +}; + +const iconStyles = { + marginRight: '8px', +}; + +const STATUS_TO_COLOR: Record = { + success: 'success', + failure: 'danger', + unknown: 'gray', +}; + +export const RuleEventLogListStatus = (props: RuleEventLogListStatusProps) => { + const { status } = props; + const color = STATUS_TO_COLOR[status] || 'gray'; + + return ( +
+ + {status} +
+ ); +}; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.test.tsx new file mode 100644 index 0000000000000..bb7f87b59aa5b --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.test.tsx @@ -0,0 +1,62 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { mountWithIntl } from '@kbn/test-jest-helpers'; +import { EuiFilterButton, EuiFilterSelectItem } from '@elastic/eui'; +import { RuleEventLogListStatusFilter } from './rule_event_log_list_status_filter'; + +const onChangeMock = jest.fn(); + +describe('rule_event_log_list_status_filter', () => { + beforeEach(() => { + onChangeMock.mockReset(); + }); + + it('renders correctly', () => { + const wrapper = mountWithIntl( + + ); + + expect(wrapper.find(EuiFilterSelectItem).exists()).toBeFalsy(); + expect(wrapper.find(EuiFilterButton).exists()).toBeTruthy(); + + expect(wrapper.find('.euiNotificationBadge').text()).toEqual('0'); + }); + + it('can open the popover correctly', () => { + const wrapper = mountWithIntl( + + ); + + wrapper.find(EuiFilterButton).simulate('click'); + + const statusItems = wrapper.find(EuiFilterSelectItem); + expect(statusItems.length).toEqual(3); + + statusItems.at(0).simulate('click'); + expect(onChangeMock).toHaveBeenCalledWith(['success']); + + wrapper.setProps({ + selectedOptions: ['success'], + }); + + expect(wrapper.find('.euiNotificationBadge').text()).toEqual('1'); + + statusItems.at(1).simulate('click'); + expect(onChangeMock).toHaveBeenCalledWith(['success', 'failure']); + + wrapper.setProps({ + selectedOptions: ['success', 'failure'], + }); + + expect(wrapper.find('.euiNotificationBadge').text()).toEqual('2'); + + statusItems.at(0).simulate('click'); + expect(onChangeMock).toHaveBeenCalledWith(['failure']); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.tsx new file mode 100644 index 0000000000000..85adfe90def44 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule_event_log_list_status_filter.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useState, useCallback } from 'react'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { EuiFilterButton, EuiPopover, EuiFilterGroup, EuiFilterSelectItem } from '@elastic/eui'; +import { EcsEventOutcome } from 'kibana/server'; +import { RuleEventLogListStatus } from './rule_event_log_list_status'; + +const statusFilters: EcsEventOutcome[] = ['success', 'failure', 'unknown']; + +interface RuleEventLogListStatusFilterProps { + selectedOptions: string[]; + onChange: (selectedValues: string[]) => void; +} + +export const RuleEventLogListStatusFilter = (props: RuleEventLogListStatusFilterProps) => { + const { selectedOptions = [], onChange = () => {} } = props; + + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + + const onFilterItemClick = useCallback( + (newOption: string) => () => { + if (selectedOptions.includes(newOption)) { + onChange(selectedOptions.filter((option) => option !== newOption)); + return; + } + onChange([...selectedOptions, newOption]); + }, + [selectedOptions, onChange] + ); + + const onClick = useCallback(() => { + setIsPopoverOpen((prevIsOpen) => !prevIsOpen); + }, [setIsPopoverOpen]); + + return ( + + setIsPopoverOpen(false)} + button={ + 0} + numActiveFilters={selectedOptions.length} + numFilters={selectedOptions.length} + onClick={onClick} + > + + + } + > + <> + {statusFilters.map((status) => { + return ( + + + + ); + })} + + + + ); +}; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/types.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/types.ts new file mode 100644 index 0000000000000..0a4b706c8676e --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/types.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export interface AlertListItemStatus { + label: string; + healthColor: string; + actionGroup?: string; +} + +export interface AlertListItem { + alert: string; + status: AlertListItemStatus; + start?: Date; + duration: number; + isMuted: boolean; + sortPriority: number; +} diff --git a/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx b/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx index 23d77b6e07a9b..0b865eb5b61be 100644 --- a/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx @@ -13,7 +13,7 @@ describe('getIsExperimentalFeatureEnabled', () => { ExperimentalFeaturesService.init({ experimentalFeatures: { rulesListDatagrid: true, - rulesDetailLogs: false, + rulesDetailLogs: true, }, }); @@ -23,7 +23,7 @@ describe('getIsExperimentalFeatureEnabled', () => { result = getIsExperimentalFeatureEnabled('rulesDetailLogs'); - expect(result).toEqual(false); + expect(result).toEqual(true); expect(() => getIsExperimentalFeatureEnabled('doesNotExist' as any)).toThrowError( 'Invalid enable value doesNotExist. Allowed values are: rulesListDatagrid, rulesDetailLogs' diff --git a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/details.ts b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/details.ts index 74595e812f42a..22c98b189a590 100644 --- a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/details.ts +++ b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/details.ts @@ -9,6 +9,7 @@ import expect from '@kbn/expect'; import uuid from 'uuid'; import { omit, mapValues, range, flatten } from 'lodash'; import moment from 'moment'; +import { asyncForEach } from '@kbn/std'; import { FtrProviderContext } from '../../ftr_provider_context'; import { ObjectRemover } from '../../lib/object_remover'; import { alwaysFiringAlertType } from '../../fixtures/plugins/alerts/server/plugin'; @@ -74,7 +75,8 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { async function createRuleWithActionsAndParams( testRunUuid: string, - params: Record = {} + params: Record = {}, + overwrites: Record = {} ) { const connectors = await createConnectors(testRunUuid); return await createAlwaysFiringRule({ @@ -88,6 +90,7 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { }, })), params, + ...overwrites, }); } @@ -581,6 +584,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { // Get action groups const { actionGroups } = alwaysFiringAlertType; + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + // Verify content await testSubjects.existOrFail('alertsList'); @@ -679,6 +685,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { // refresh to see rule await browser.refresh(); + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + const alertsList: any[] = await pageObjects.ruleDetailsUI.getAlertsList(); expect(alertsList.filter((a) => a.alert === 'eu/east')).to.eql([ { @@ -691,6 +700,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { }); it('allows the user to mute a specific alert', async () => { + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + // Verify content await testSubjects.existOrFail('alertsList'); @@ -705,6 +717,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { }); it('allows the user to unmute a specific alert', async () => { + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + // Verify content await testSubjects.existOrFail('alertsList'); @@ -725,6 +740,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { }); it('allows the user unmute an inactive alert', async () => { + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + log.debug(`Ensuring eu/east is muted`); await pageObjects.ruleDetailsUI.ensureAlertMuteState('eu/east', true); @@ -778,6 +796,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { const PAGE_SIZE = 10; it('renders the first page', async () => { + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + // Verify content await testSubjects.existOrFail('alertsList'); @@ -791,6 +812,9 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { }); it('navigates to the next page', async () => { + // If the tab exists, click on the alert list + await pageObjects.triggersActionsUI.maybeClickOnAlertTab(); + // Verify content await testSubjects.existOrFail('alertsList'); @@ -804,5 +828,120 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { }); }); }); + + describe('Execution log', () => { + const testRunUuid = uuid.v4(); + let rule: any; + + before(async () => { + await pageObjects.common.navigateToApp('triggersActions'); + + const alerts = [{ id: 'us-central' }]; + rule = await createRuleWithActionsAndParams( + testRunUuid, + { + instances: alerts, + }, + { + schedule: { interval: '1s' }, + throttle: null, + } + ); + + // refresh to see rule + await browser.refresh(); + await pageObjects.header.waitUntilLoadingHasFinished(); + + // click on first rule + await pageObjects.triggersActionsUI.clickOnAlertInAlertsList(rule.name); + + // await first run to complete so we have an initial state + await retry.try(async () => { + const { alerts: alertInstances } = await getAlertSummary(rule.id); + expect(Object.keys(alertInstances).length).to.eql(alerts.length); + }); + }); + + after(async () => { + await objectRemover.removeAll(); + }); + + it('renders the event log list and can filter/sort', async () => { + await browser.refresh(); + + // Check to see if the experimental is enabled, if not, just return + const tabbedContentExists = await testSubjects.exists('ruleDetailsTabbedContent'); + if (!tabbedContentExists) { + return; + } + + // Ensure we have some log data to work with + await new Promise((resolve) => setTimeout(resolve, 5000)); + + const refreshButton = await testSubjects.find('superDatePickerApplyTimeButton'); + await refreshButton.click(); + + // List, date picker, and status picker all exists + await testSubjects.existOrFail('ruleEventLogList'); + await testSubjects.existOrFail('ruleEventLogListDatePicker'); + await testSubjects.existOrFail('ruleEventLogStatusFilterButton'); + + let statusFilter = await testSubjects.find('ruleEventLogStatusFilterButton'); + let statusNumber = await statusFilter.findByCssSelector('.euiNotificationBadge'); + + expect(statusNumber.getVisibleText()).to.eql(0); + + await statusFilter.click(); + await testSubjects.click('ruleEventLogStatusFilter-success'); + await statusFilter.click(); + + statusFilter = await testSubjects.find('ruleEventLogStatusFilterButton'); + statusNumber = await statusFilter.findByCssSelector('.euiNotificationBadge'); + + expect(statusNumber.getVisibleText()).to.eql(1); + + const eventLogList = await find.byCssSelector('.euiDataGridRow'); + const rows = await eventLogList.parseDomContent(); + expect(rows.length).to.be.greaterThan(0); + + await pageObjects.triggersActionsUI.ensureEventLogColumnExists('timestamp'); + await pageObjects.triggersActionsUI.ensureEventLogColumnExists('total_search_duration'); + + const timestampCells = await find.allByCssSelector( + '[data-gridcell-column-id="timestamp"][data-test-subj="dataGridRowCell"]' + ); + + // The test can be flaky and sometimes we'll get results without dates, + // This is a reasonable compromise as we still validate the good rows + let validTimestamps = 0; + await asyncForEach(timestampCells, async (cell) => { + const text = await cell.getVisibleText(); + if (text.toLowerCase() !== 'invalid date') { + if (moment(text).isValid()) { + validTimestamps += 1; + } + } + }); + expect(validTimestamps).to.be.greaterThan(0); + + // Ensure duration cells are properly formatted + const durationCells = await find.allByCssSelector( + '[data-gridcell-column-id="total_search_duration"][data-test-subj="dataGridRowCell"]' + ); + + await asyncForEach(durationCells, async (cell) => { + const text = await cell.getVisibleText(); + if (text) { + expect(text).to.match(/^N\/A|\d{2,}:\d{2}$/); + } + }); + + await pageObjects.triggersActionsUI.sortEventLogColumn('timestamp', 'asc'); + await pageObjects.triggersActionsUI.sortEventLogColumn('total_search_duration', 'asc'); + + await testSubjects.existOrFail('dataGridHeaderCellSortingIcon-timestamp'); + await testSubjects.existOrFail('dataGridHeaderCellSortingIcon-total_search_duration'); + }); + }); }); }; 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 index 7379a5ad1329c..e346971b48ea4 100644 --- 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 @@ -141,6 +141,12 @@ export function TriggersActionsPageProvider({ getService }: FtrProviderContext) await this.searchAlerts(name); await find.clickDisplayedByCssSelector(`[data-test-subj="rulesList"] [title="${name}"]`); }, + async maybeClickOnAlertTab() { + if (await testSubjects.exists('ruleDetailsTabbedContent')) { + const alertTab = await testSubjects.find('ruleAlertListTab'); + await alertTab.click(); + } + }, async changeTabs(tab: 'rulesTab' | 'connectorsTab') { await testSubjects.click(tab); }, @@ -195,5 +201,32 @@ export function TriggersActionsPageProvider({ getService }: FtrProviderContext) expect(title.toLowerCase()).to.eql(expectedStatus.toLowerCase()); }); }, + async ensureEventLogColumnExists(columnId: string) { + const columnsButton = await testSubjects.find('dataGridColumnSelectorButton'); + await columnsButton.click(); + + const button = await testSubjects.find( + `dataGridColumnSelectorToggleColumnVisibility-${columnId}` + ); + const isChecked = await button.getAttribute('aria-checked'); + + if (isChecked === 'false') { + await button.click(); + } + + await columnsButton.click(); + }, + async sortEventLogColumn(columnId: string, direction: string) { + await testSubjects.click(`dataGridHeaderCell-${columnId}`); + const popover = await testSubjects.find(`dataGridHeaderCellActionGroup-${columnId}`); + const popoverListItems = await popover.findAllByCssSelector('li'); + + if (direction === 'asc') { + await popoverListItems[1].click(); + } + if (direction === 'desc') { + await popoverListItems[2].click(); + } + }, }; } From 7c83144dd008c9991c0198fb86d876a74147dcca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ece=20=C3=96zalp?= Date: Mon, 28 Mar 2022 16:08:51 -0400 Subject: [PATCH 053/160] [CTI][PIT] adds PIT to indicator search (#128433) --- .../security_solution/common/cti/constants.ts | 2 + .../threat_mapping/build_threat_enrichment.ts | 6 ++- .../threat_mapping/create_event_signal.ts | 7 ++-- .../threat_mapping/create_threat_signals.ts | 42 +++++++++++++++---- .../signals/threat_mapping/get_threat_list.ts | 16 ++++--- .../signals/threat_mapping/types.ts | 8 +++- 6 files changed, 62 insertions(+), 19 deletions(-) diff --git a/x-pack/plugins/security_solution/common/cti/constants.ts b/x-pack/plugins/security_solution/common/cti/constants.ts index 9dbeffed6e8ab..3ea8a900b27dc 100644 --- a/x-pack/plugins/security_solution/common/cti/constants.ts +++ b/x-pack/plugins/security_solution/common/cti/constants.ts @@ -63,3 +63,5 @@ export const DEFAULT_EVENT_ENRICHMENT_TO = 'now'; export const TI_INTEGRATION_PREFIX = 'ti'; export const OTHER_TI_DATASET_KEY = '_others_ti_'; + +export const THREAT_PIT_KEEP_ALIVE = '5m'; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/build_threat_enrichment.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/build_threat_enrichment.ts index 2281381efb2ac..bc31ee660aad8 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/build_threat_enrichment.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/build_threat_enrichment.ts @@ -7,8 +7,8 @@ import { SignalSearchResponse, SignalsEnrichment } from '../types'; import { enrichSignalThreatMatches } from './enrich_signal_threat_matches'; -import { getThreatList } from './get_threat_list'; import { BuildThreatEnrichmentOptions, GetMatchedThreats } from './types'; +import { getThreatList } from './get_threat_list'; export const buildThreatEnrichment = ({ buildRuleMessage, @@ -20,6 +20,8 @@ export const buildThreatEnrichment = ({ threatIndicatorPath, threatLanguage, threatQuery, + pitId, + reassignPitId, }: BuildThreatEnrichmentOptions): SignalsEnrichment => { const getMatchedThreats: GetMatchedThreats = async (ids) => { const matchedThreatsFilter = { @@ -46,6 +48,8 @@ export const buildThreatEnrichment = ({ _source: [`${threatIndicatorPath}.*`, 'threat.feed.*'], fields: undefined, }, + pitId, + reassignPitId, }); return threatResponse.hits.hits; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts index c1beb55e90a85..faa14bcbab309 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts @@ -44,9 +44,9 @@ export const createEventSignal = async ({ threatFilters, threatLanguage, threatIndex, - threatListConfig, threatIndicatorPath, - perPage, + threatPitId, + reassignThreatPitId, }: CreateEventSignalOptions): Promise => { const threatFilter = buildThreatMappingFilter({ threatMapping, @@ -77,7 +77,8 @@ export const createEventSignal = async ({ _source: [`${threatIndicatorPath}.*`, 'threat.feed.*'], fields: undefined, }, - perPage, + pitId: threatPitId, + reassignPitId: reassignThreatPitId, }); const signalMatches = getSignalMatchesFromThreatList(threatListHits); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signals.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signals.ts index eecc55a67ad52..f02d273585ef7 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signals.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signals.ts @@ -6,6 +6,8 @@ */ import chunk from 'lodash/fp/chunk'; +import { OpenPointInTimeResponse } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; + import { getThreatList, getThreatListCount } from './get_threat_list'; import { CreateThreatSignalsOptions, @@ -19,6 +21,7 @@ import { buildExecutionIntervalValidator, combineConcurrentResults } from './uti import { buildThreatEnrichment } from './build_threat_enrichment'; import { getEventCount, getEventList } from './get_event_count'; import { getMappingFilters } from './get_mapping_filters'; +import { THREAT_PIT_KEEP_ALIVE } from '../../../../../common/cti/constants'; export const createThreatSignals = async ({ alertId, @@ -89,6 +92,16 @@ export const createThreatSignals = async ({ return results; } + let threatPitId: OpenPointInTimeResponse['id'] = ( + await services.scopedClusterClient.asCurrentUser.openPointInTime({ + index: threatIndex, + keep_alive: THREAT_PIT_KEEP_ALIVE, + }) + ).id; + const reassignThreatPitId = (newPitId: OpenPointInTimeResponse['id'] | undefined) => { + if (newPitId) threatPitId = newPitId; + }; + const threatListCount = await getThreatListCount({ esClient: services.scopedClusterClient.asCurrentUser, exceptionItems, @@ -115,6 +128,8 @@ export const createThreatSignals = async ({ threatIndicatorPath, threatLanguage, threatQuery, + pitId: threatPitId, + reassignPitId: reassignThreatPitId, }); const createSignals = async ({ @@ -188,8 +203,8 @@ export const createThreatSignals = async ({ buildRuleMessage, bulkCreate, completeRule, - currentResult: results, currentEventList: slicedChunk, + currentResult: results, eventsTelemetry, exceptionItems, filters: allEventFilters, @@ -199,21 +214,21 @@ export const createThreatSignals = async ({ logger, outputIndex, query, + reassignThreatPitId, savedId, searchAfterSize, services, threatEnrichment, + threatFilters: allThreatFilters, + threatIndex, + threatIndicatorPath, + threatLanguage, threatMapping, + threatPitId, + threatQuery, tuple, type, wrapHits, - threatQuery, - threatFilters: allThreatFilters, - threatLanguage, - threatIndex, - threatListConfig, - threatIndicatorPath, - perPage, }), }); } else { @@ -232,6 +247,8 @@ export const createThreatSignals = async ({ buildRuleMessage, perPage, threatListConfig, + pitId: threatPitId, + reassignPitId: reassignThreatPitId, }), createSignal: (slicedChunk) => @@ -263,6 +280,15 @@ export const createThreatSignals = async ({ }); } + try { + await services.scopedClusterClient.asCurrentUser.closePointInTime({ id: threatPitId }); + } catch (error) { + // Don't fail due to a bad point in time closure. We have seen failures in e2e tests during nominal operations. + logger.warn( + `Error trying to close point in time: "${threatPitId}", it will expire within "${THREAT_PIT_KEEP_ALIVE}". Error is: "${error}"` + ); + } + logger.debug(buildRuleMessage('Indicator matching rule has completed')); return results; }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/get_threat_list.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/get_threat_list.ts index 9f2fcef2f6883..93e6dccdbed33 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/get_threat_list.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/get_threat_list.ts @@ -17,22 +17,24 @@ import { /** * This should not exceed 10000 (10k) */ -export const MAX_PER_PAGE = 9000; +export const INDICATOR_PER_PAGE = 1000; export const getThreatList = async ({ esClient, query, language, index, - perPage, searchAfter, exceptionItems, threatFilters, buildRuleMessage, logger, threatListConfig, + pitId, + reassignPitId, + perPage, }: GetThreatListOptions): Promise> => { - const calculatedPerPage = perPage ?? MAX_PER_PAGE; + const calculatedPerPage = perPage ?? INDICATOR_PER_PAGE; if (calculatedPerPage > 10000) { throw new TypeError('perPage cannot exceed the size of 10000'); } @@ -58,15 +60,17 @@ export const getThreatList = async ({ ...threatListConfig, query: queryFilter, search_after: searchAfter, - sort: ['_doc', { '@timestamp': 'asc' }], + sort: ['_shard_doc', { '@timestamp': 'asc' }], }, track_total_hits: false, - ignore_unavailable: true, - index, size: calculatedPerPage, + pit: { id: pitId }, }); logger.debug(buildRuleMessage(`Retrieved indicator items of size: ${response.hits.hits.length}`)); + + reassignPitId(response.pit_id); + return response; }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/types.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/types.ts index 8beabe072c13f..f0f2d7e1af3b5 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/types.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/types.ts @@ -18,6 +18,7 @@ import type { Type, } from '@kbn/securitysolution-io-ts-alerting-types'; import type { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; +import { OpenPointInTimeResponse } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import { ListClient } from '../../../../../../lists/server'; import { AlertInstanceContext, @@ -123,8 +124,9 @@ export interface CreateEventSignalOptions { threatLanguage: ThreatLanguageOrUndefined; threatMapping: ThreatMapping; threatQuery: ThreatQuery; - threatListConfig: ThreatListConfig; perPage?: number; + threatPitId: OpenPointInTimeResponse['id']; + reassignThreatPitId: (newPitId: OpenPointInTimeResponse['id'] | undefined) => void; } type EntryKey = 'field' | 'value'; @@ -186,6 +188,8 @@ export interface GetThreatListOptions { searchAfter: estypes.SortResults | undefined; threatFilters: unknown[]; threatListConfig: ThreatListConfig; + pitId: OpenPointInTimeResponse['id']; + reassignPitId: (newPitId: OpenPointInTimeResponse['id'] | undefined) => void; } export interface ThreatListCountOptions { @@ -236,6 +240,8 @@ export interface BuildThreatEnrichmentOptions { threatIndicatorPath: ThreatIndicatorPath; threatLanguage: ThreatLanguageOrUndefined; threatQuery: ThreatQuery; + pitId: string; + reassignPitId: (newPitId: OpenPointInTimeResponse['id'] | undefined) => void; } export interface EventsOptions { From 8061a06d0074e0813037c53295e3575a74596f34 Mon Sep 17 00:00:00 2001 From: Brandon Morelli Date: Mon, 28 Mar 2022 14:21:10 -0600 Subject: [PATCH 054/160] [APM] Update custom option messages in Create Rules drop-downs (#128336) * update rule creation text * remove unused translations Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../apm/public/components/alerting/fields.tsx | 27 +++++++------------ .../translations/translations/ja-JP.json | 3 --- .../translations/translations/zh-CN.json | 3 --- 3 files changed, 9 insertions(+), 24 deletions(-) diff --git a/x-pack/plugins/apm/public/components/alerting/fields.tsx b/x-pack/plugins/apm/public/components/alerting/fields.tsx index 4abbd97d98db4..9ea3c5aa2a6bd 100644 --- a/x-pack/plugins/apm/public/components/alerting/fields.tsx +++ b/x-pack/plugins/apm/public/components/alerting/fields.tsx @@ -39,12 +39,9 @@ export function ServiceField({ > Date: Mon, 28 Mar 2022 16:46:12 -0400 Subject: [PATCH 055/160] lodash-es 4.17.15 -> 4.17.21 (#128668) --- yarn.lock | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/yarn.lock b/yarn.lock index ce17dc8768523..6814b5463143e 100644 --- a/yarn.lock +++ b/yarn.lock @@ -19048,9 +19048,9 @@ locate-path@^6.0.0: p-locate "^5.0.0" lodash-es@^4.17.11: - version "4.17.15" - resolved "https://registry.yarnpkg.com/lodash-es/-/lodash-es-4.17.15.tgz#21bd96839354412f23d7a10340e5eac6ee455d78" - integrity sha512-rlrc3yU3+JNOpZ9zj5pQtxnx2THmvRykwL4Xlxoa8I9lHBlVbbyPhgyPMioxVZ4NqyxaVVtaJnzsyOidQIhyyQ== + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash-es/-/lodash-es-4.17.21.tgz#43e626c46e6591b7750beb2b50117390c609e3ee" + integrity sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw== lodash._reinterpolate@^3.0.0: version "3.0.0" From ba6be79adb3dcf4a644929b35f665f9d64b6f7cd Mon Sep 17 00:00:00 2001 From: Catherine Liu Date: Mon, 28 Mar 2022 14:06:47 -0700 Subject: [PATCH 056/160] [Controls] Range slider (#125584) * Adds range slider control Fix ts error Fix ref type error Extracted i18n strings Fixed number rounding Fixed missing i18n string Add loading state to range slider control output Remove unnecessary change Fix i18n errors Apply formatter to range slider tick labels * Apply comment updates from code review Co-authored-by: Devon Thomson * Remove extra fetches * set min width for panel * Fix functional tests * Fixed controls page object Co-authored-by: Devon Thomson Co-authored-by: andreadelrio Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../range_slider_persistable_state.ts | 47 +++ .../control_types/range_slider/types.ts | 19 + src/plugins/controls/common/index.ts | 7 +- .../public/__stories__/controls.stories.tsx | 61 ++++ .../storybook_control_factories.ts | 8 + .../controls/public/control_types/index.ts | 1 + .../options_list/options_list_strings.ts | 4 - .../control_types/range_slider/index.ts | 13 + .../range_slider/range_slider.component.tsx | 72 ++++ .../range_slider/range_slider.scss | 57 +++ .../range_slider/range_slider_editor.tsx | 104 ++++++ .../range_slider/range_slider_embeddable.tsx | 330 ++++++++++++++++++ .../range_slider_embeddable_factory.tsx | 59 ++++ .../range_slider/range_slider_popover.tsx | 242 +++++++++++++ .../range_slider/range_slider_reducers.ts | 21 ++ .../range_slider/range_slider_strings.ts | 59 ++++ .../control_types/range_slider/types.ts | 10 + src/plugins/controls/public/index.ts | 5 +- src/plugins/controls/public/plugin.ts | 26 +- src/plugins/controls/public/services/data.ts | 2 + .../controls/public/services/kibana/data.ts | 4 +- .../public/services/storybook/data.ts | 15 + .../public/__stories__/fixtures/flights.ts | 12 +- .../apps/dashboard_elements/controls/index.ts | 1 + .../controls/options_list.ts | 4 +- .../controls/range_slider.ts | 204 +++++++++++ .../apps/dashboard_elements/index.ts | 6 + .../page_objects/dashboard_page_controls.ts | 132 ++++++- .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - 30 files changed, 1497 insertions(+), 30 deletions(-) create mode 100644 src/plugins/controls/common/control_types/range_slider/range_slider_persistable_state.ts create mode 100644 src/plugins/controls/common/control_types/range_slider/types.ts create mode 100644 src/plugins/controls/public/control_types/range_slider/index.ts create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider.component.tsx create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider.scss create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider_editor.tsx create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider_embeddable.tsx create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider_embeddable_factory.tsx create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider_popover.tsx create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider_reducers.ts create mode 100644 src/plugins/controls/public/control_types/range_slider/range_slider_strings.ts create mode 100644 src/plugins/controls/public/control_types/range_slider/types.ts create mode 100644 test/functional/apps/dashboard_elements/controls/range_slider.ts diff --git a/src/plugins/controls/common/control_types/range_slider/range_slider_persistable_state.ts b/src/plugins/controls/common/control_types/range_slider/range_slider_persistable_state.ts new file mode 100644 index 0000000000000..c50fe3f6fb710 --- /dev/null +++ b/src/plugins/controls/common/control_types/range_slider/range_slider_persistable_state.ts @@ -0,0 +1,47 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { + EmbeddableStateWithType, + EmbeddablePersistableStateService, +} from '../../../../embeddable/common'; +import { RangeSliderEmbeddableInput } from './types'; +import { SavedObjectReference } from '../../../../../core/types'; +import { DATA_VIEW_SAVED_OBJECT_TYPE } from '../../../../data_views/common'; + +type RangeSliderInputWithType = Partial & { type: string }; +const dataViewReferenceName = 'optionsListDataView'; + +export const createRangeSliderInject = (): EmbeddablePersistableStateService['inject'] => { + return (state: EmbeddableStateWithType, references: SavedObjectReference[]) => { + const workingState = { ...state } as EmbeddableStateWithType | RangeSliderInputWithType; + references.forEach((reference) => { + if (reference.name === dataViewReferenceName) { + (workingState as RangeSliderInputWithType).dataViewId = reference.id; + } + }); + return workingState as EmbeddableStateWithType; + }; +}; + +export const createRangeSliderExtract = (): EmbeddablePersistableStateService['extract'] => { + return (state: EmbeddableStateWithType) => { + const workingState = { ...state } as EmbeddableStateWithType | RangeSliderInputWithType; + const references: SavedObjectReference[] = []; + + if ('dataViewId' in workingState) { + references.push({ + name: dataViewReferenceName, + type: DATA_VIEW_SAVED_OBJECT_TYPE, + id: workingState.dataViewId!, + }); + delete workingState.dataViewId; + } + return { state: workingState as EmbeddableStateWithType, references }; + }; +}; diff --git a/src/plugins/controls/common/control_types/range_slider/types.ts b/src/plugins/controls/common/control_types/range_slider/types.ts new file mode 100644 index 0000000000000..e63ec0337a57e --- /dev/null +++ b/src/plugins/controls/common/control_types/range_slider/types.ts @@ -0,0 +1,19 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { ControlInput } from '../../types'; + +export const RANGE_SLIDER_CONTROL = 'rangeSliderControl'; + +export type RangeValue = [string, string]; + +export interface RangeSliderEmbeddableInput extends ControlInput { + fieldName: string; + dataViewId: string; + value: RangeValue; +} diff --git a/src/plugins/controls/common/index.ts b/src/plugins/controls/common/index.ts index e10258026e64d..23779e225ce47 100644 --- a/src/plugins/controls/common/index.ts +++ b/src/plugins/controls/common/index.ts @@ -6,10 +6,13 @@ * Side Public License, v 1. */ +export type { ControlWidth } from './types'; export type { ControlPanelState, ControlsPanels, ControlGroupInput } from './control_group/types'; export type { OptionsListEmbeddableInput } from './control_types/options_list/types'; -export type { ControlWidth } from './types'; +export type { RangeSliderEmbeddableInput } from './control_types/range_slider/types'; -export { OPTIONS_LIST_CONTROL } from './control_types/options_list/types'; export { CONTROL_GROUP_TYPE } from './control_group/types'; +export { OPTIONS_LIST_CONTROL } from './control_types/options_list/types'; +export { RANGE_SLIDER_CONTROL } from './control_types/range_slider/types'; + export { getDefaultControlGroupInput } from './control_group/control_group_constants'; diff --git a/src/plugins/controls/public/__stories__/controls.stories.tsx b/src/plugins/controls/public/__stories__/controls.stories.tsx index 436cee506916a..12bf0cacbe136 100644 --- a/src/plugins/controls/public/__stories__/controls.stories.tsx +++ b/src/plugins/controls/public/__stories__/controls.stories.tsx @@ -19,7 +19,9 @@ import { import { ControlGroupContainerFactory, OptionsListEmbeddableInput, + RangeSliderEmbeddableInput, OPTIONS_LIST_CONTROL, + RANGE_SLIDER_CONTROL, } from '../'; import { ViewMode } from '../../../embeddable/public'; @@ -169,6 +171,65 @@ export const ConfiguredControlGroupStory = () => ( fieldName: 'Carrier', } as OptionsListEmbeddableInput, }, + rangeSlider1: { + type: RANGE_SLIDER_CONTROL, + order: 4, + width: 'auto', + explicitInput: { + id: 'rangeSlider1', + title: 'Average ticket price', + dataViewId: 'demoDataFlights', + fieldName: 'AvgTicketPrice', + value: ['4', '12'], + step: 2, + } as RangeSliderEmbeddableInput, + }, + }} + /> +); + +export const RangeSliderControlGroupStory = () => ( + ); diff --git a/src/plugins/controls/public/__stories__/storybook_control_factories.ts b/src/plugins/controls/public/__stories__/storybook_control_factories.ts index 9809e90bd12fc..12674a97d856d 100644 --- a/src/plugins/controls/public/__stories__/storybook_control_factories.ts +++ b/src/plugins/controls/public/__stories__/storybook_control_factories.ts @@ -7,6 +7,7 @@ */ import { OptionsListEmbeddableFactory } from '../control_types/options_list'; +import { RangeSliderEmbeddableFactory } from '../control_types/range_slider'; import { ControlsService } from '../services/controls'; import { ControlFactory } from '..'; @@ -17,4 +18,11 @@ export const populateStorybookControlFactories = (controlsServiceStub: ControlsS const optionsListControlFactory = optionsListFactoryStub as unknown as ControlFactory; optionsListControlFactory.getDefaultInput = () => ({}); controlsServiceStub.registerControlType(optionsListControlFactory); + + const rangeSliderFactoryStub = new RangeSliderEmbeddableFactory(); + + // cast to unknown because the stub cannot use the embeddable start contract to transform the EmbeddableFactoryDefinition into an EmbeddableFactory + const rangeSliderControlFactory = rangeSliderFactoryStub as unknown as ControlFactory; + rangeSliderControlFactory.getDefaultInput = () => ({}); + controlsServiceStub.registerControlType(rangeSliderControlFactory); }; diff --git a/src/plugins/controls/public/control_types/index.ts b/src/plugins/controls/public/control_types/index.ts index 141e9f9b4d55f..2b53723f4bafd 100644 --- a/src/plugins/controls/public/control_types/index.ts +++ b/src/plugins/controls/public/control_types/index.ts @@ -7,3 +7,4 @@ */ export * from './options_list'; +export * from './range_slider'; diff --git a/src/plugins/controls/public/control_types/options_list/options_list_strings.ts b/src/plugins/controls/public/control_types/options_list/options_list_strings.ts index 62fb54163c2bd..f6dd7f3a2ddf1 100644 --- a/src/plugins/controls/public/control_types/options_list/options_list_strings.ts +++ b/src/plugins/controls/public/control_types/options_list/options_list_strings.ts @@ -28,10 +28,6 @@ export const OptionsListStrings = { }), }, editor: { - getIndexPatternTitle: () => - i18n.translate('controls.optionsList.editor.indexPatternTitle', { - defaultMessage: 'Index pattern', - }), getDataViewTitle: () => i18n.translate('controls.optionsList.editor.dataViewTitle', { defaultMessage: 'Data view', diff --git a/src/plugins/controls/public/control_types/range_slider/index.ts b/src/plugins/controls/public/control_types/range_slider/index.ts new file mode 100644 index 0000000000000..5fdd29672b86f --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export { RANGE_SLIDER_CONTROL } from '../../../common/control_types/range_slider/types'; +export { RangeSliderEmbeddableFactory } from './range_slider_embeddable_factory'; + +export type { RangeSliderEmbeddable } from './range_slider_embeddable'; +export type { RangeSliderEmbeddableInput } from '../../../common/control_types/range_slider/types'; diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider.component.tsx b/src/plugins/controls/public/control_types/range_slider/range_slider.component.tsx new file mode 100644 index 0000000000000..822c88ca10df0 --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider.component.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React, { FC, useCallback, useState } from 'react'; +import { BehaviorSubject } from 'rxjs'; + +import { DataViewField } from '../../../../data_views/public'; +import { useReduxEmbeddableContext } from '../../../../presentation_util/public'; +import { useStateObservable } from '../../hooks/use_state_observable'; +import { RangeSliderPopover } from './range_slider_popover'; +import { rangeSliderReducers } from './range_slider_reducers'; +import { RangeSliderEmbeddableInput, RangeValue } from './types'; + +import './range_slider.scss'; + +interface Props { + componentStateSubject: BehaviorSubject; +} +// Availableoptions and loading state is controled by the embeddable, but is not considered embeddable input. +export interface RangeSliderComponentState { + field?: DataViewField; + fieldFormatter: (value: string) => string; + min: string; + max: string; + loading: boolean; +} + +export const RangeSliderComponent: FC = ({ componentStateSubject }) => { + // Redux embeddable Context to get state from Embeddable input + const { + useEmbeddableDispatch, + useEmbeddableSelector, + actions: { selectRange }, + } = useReduxEmbeddableContext(); + const dispatch = useEmbeddableDispatch(); + + // useStateObservable to get component state from Embeddable + const { loading, min, max, fieldFormatter } = useStateObservable( + componentStateSubject, + componentStateSubject.getValue() + ); + + const { value = ['', ''], id, title } = useEmbeddableSelector((state) => state); + + const [selectedValue, setSelectedValue] = useState(value || ['', '']); + + const onChangeComplete = useCallback( + (range: RangeValue) => { + dispatch(selectRange(range)); + setSelectedValue(range); + }, + [selectRange, setSelectedValue, dispatch] + ); + + return ( + + ); +}; diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider.scss b/src/plugins/controls/public/control_types/range_slider/range_slider.scss new file mode 100644 index 0000000000000..82d892cd0b9c5 --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider.scss @@ -0,0 +1,57 @@ +.rangeSlider__popoverOverride { + height: 100%; + max-width: 100%; + width: 100%; +} + +@include euiBreakpoint('m', 'l', 'xl') { + .rangeSlider__panelOverride { + min-width: $euiSizeXXL * 12; + } +} + +.rangeSlider__anchorOverride { + >div { + height: 100%; + } +} + +.rangeSliderAnchor__button { + display: flex; + align-items: center; + width: 100%; + height: 100%; + justify-content: space-between; + background-color: $euiFormBackgroundColor; + @include euiFormControlSideBorderRadius($euiFormControlBorderRadius, $side: 'right', $internal: true); + + .euiToolTipAnchor { + width: 100%; + } + + .rangeSliderAnchor__delimiter { + background-color: unset; + } + .rangeSliderAnchor__fieldNumber { + font-weight: $euiFontWeightBold; + box-shadow: none; + text-align: center; + background-color: unset; + + &::placeholder { + font-weight: $euiFontWeightRegular; + color: $euiColorMediumShade; + text-decoration: none; + } + } + + .rangeSliderAnchor__fieldNumber--invalid { + text-decoration: line-through; + font-weight: $euiFontWeightRegular; + color: $euiColorMediumShade; + } + + .rangeSliderAnchor__spinner { + padding-right: $euiSizeS; + } +} \ No newline at end of file diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider_editor.tsx b/src/plugins/controls/public/control_types/range_slider/range_slider_editor.tsx new file mode 100644 index 0000000000000..d2dbef62f2b0f --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider_editor.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import useMount from 'react-use/lib/useMount'; +import React, { useEffect, useState } from 'react'; +import { EuiFormRow } from '@elastic/eui'; + +import { pluginServices } from '../../services'; +import { ControlEditorProps } from '../../types'; +import { RangeSliderEmbeddableInput } from './types'; +import { RangeSliderStrings } from './range_slider_strings'; +import { DataViewListItem, DataView } from '../../../../data_views/common'; +import { + LazyDataViewPicker, + LazyFieldPicker, + withSuspense, +} from '../../../../presentation_util/public'; + +interface RangeSliderEditorState { + dataViewListItems: DataViewListItem[]; + dataView?: DataView; + fieldName?: string; +} + +const FieldPicker = withSuspense(LazyFieldPicker, null); +const DataViewPicker = withSuspense(LazyDataViewPicker, null); + +export const RangeSliderEditor = ({ + onChange, + initialInput, + setValidState, + setDefaultTitle, +}: ControlEditorProps) => { + // Controls Services Context + const { dataViews } = pluginServices.getHooks(); + const { getIdsWithTitle, getDefaultId, get } = dataViews.useService(); + + const [state, setState] = useState({ + fieldName: initialInput?.fieldName, + dataViewListItems: [], + }); + + useMount(() => { + let mounted = true; + if (state.fieldName) setDefaultTitle(state.fieldName); + (async () => { + const dataViewListItems = await getIdsWithTitle(); + const initialId = initialInput?.dataViewId ?? (await getDefaultId()); + let dataView: DataView | undefined; + if (initialId) { + onChange({ dataViewId: initialId }); + dataView = await get(initialId); + } + if (!mounted) return; + setState((s) => ({ ...s, dataView, dataViewListItems })); + })(); + return () => { + mounted = false; + }; + }); + + useEffect( + () => setValidState(Boolean(state.fieldName) && Boolean(state.dataView)), + [state.fieldName, setValidState, state.dataView] + ); + + const { dataView, fieldName } = state; + return ( + <> + + { + onChange({ dataViewId }); + get(dataViewId).then((newDataView) => + setState((s) => ({ ...s, dataView: newDataView })) + ); + }} + trigger={{ + label: state.dataView?.title ?? RangeSliderStrings.editor.getNoDataViewTitle(), + }} + /> + + + field.aggregatable && field.type === 'number'} + selectedFieldName={fieldName} + dataView={dataView} + onSelectField={(field) => { + setDefaultTitle(field.displayName ?? field.name); + onChange({ fieldName: field.name }); + setState((s) => ({ ...s, fieldName: field.name })); + }} + /> + + + ); +}; diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider_embeddable.tsx b/src/plugins/controls/public/control_types/range_slider/range_slider_embeddable.tsx new file mode 100644 index 0000000000000..ef4bc41abeefc --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider_embeddable.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { isEmpty } from 'lodash'; +import { + compareFilters, + buildRangeFilter, + COMPARE_ALL_OPTIONS, + RangeFilterParams, +} from '@kbn/es-query'; +import React from 'react'; +import ReactDOM from 'react-dom'; +import { get, isEqual } from 'lodash'; +import deepEqual from 'fast-deep-equal'; +import { Subscription, BehaviorSubject } from 'rxjs'; +import { debounceTime, distinctUntilChanged, skip, map } from 'rxjs/operators'; + +import { + withSuspense, + LazyReduxEmbeddableWrapper, + ReduxEmbeddableWrapperPropsWithChildren, +} from '../../../../presentation_util/public'; +import { Embeddable, IContainer } from '../../../../embeddable/public'; +import { DataView, DataViewField } from '../../../../data_views/public'; + +import { ControlsDataViewsService } from '../../services/data_views'; +import { ControlsDataService } from '../../services/data'; +import { ControlInput, ControlOutput } from '../..'; +import { pluginServices } from '../../services'; + +import { RangeSliderComponent, RangeSliderComponentState } from './range_slider.component'; +import { rangeSliderReducers } from './range_slider_reducers'; +import { RangeSliderStrings } from './range_slider_strings'; +import { RangeSliderEmbeddableInput, RANGE_SLIDER_CONTROL } from './types'; + +const RangeSliderReduxWrapper = withSuspense< + ReduxEmbeddableWrapperPropsWithChildren +>(LazyReduxEmbeddableWrapper); + +const diffDataFetchProps = ( + current?: RangeSliderDataFetchProps, + last?: RangeSliderDataFetchProps +) => { + if (!current || !last) return false; + const { filters: currentFilters, ...currentWithoutFilters } = current; + const { filters: lastFilters, ...lastWithoutFilters } = last; + if (!deepEqual(currentWithoutFilters, lastWithoutFilters)) return false; + if (!compareFilters(lastFilters ?? [], currentFilters ?? [], COMPARE_ALL_OPTIONS)) return false; + return true; +}; + +interface RangeSliderDataFetchProps { + fieldName: string; + dataViewId: string; + query?: ControlInput['query']; + filters?: ControlInput['filters']; +} + +const fieldMissingError = (fieldName: string) => + new Error(`field ${fieldName} not found in index pattern`); + +export class RangeSliderEmbeddable extends Embeddable { + public readonly type = RANGE_SLIDER_CONTROL; + public deferEmbeddableLoad = true; + + private subscriptions: Subscription = new Subscription(); + private node?: HTMLElement; + + // Controls services + private dataService: ControlsDataService; + private dataViewsService: ControlsDataViewsService; + + // Internal data fetching state for this input control. + private dataView?: DataView; + private field?: DataViewField; + + // State to be passed down to component + private componentState: RangeSliderComponentState; + private componentStateSubject$ = new BehaviorSubject({ + min: '', + max: '', + loading: true, + fieldFormatter: (value: string) => value, + }); + + constructor(input: RangeSliderEmbeddableInput, output: ControlOutput, parent?: IContainer) { + super(input, output, parent); // get filters for initial output... + + // Destructure controls services + ({ data: this.dataService, dataViews: this.dataViewsService } = pluginServices.getServices()); + + this.componentState = { + min: '', + max: '', + loading: true, + fieldFormatter: (value: string) => value, + }; + this.updateComponentState(this.componentState); + + this.initialize(); + } + + private initialize = async () => { + const initialValue = this.getInput().value; + if (!initialValue) { + this.setInitializationFinished(); + } + + this.fetchMinMax().then(async () => { + if (initialValue) { + this.setInitializationFinished(); + } + this.setupSubscriptions(); + }); + }; + + private setupSubscriptions = () => { + const dataFetchPipe = this.getInput$().pipe( + map((newInput) => ({ + lastReloadRequestTime: newInput.lastReloadRequestTime, + dataViewId: newInput.dataViewId, + fieldName: newInput.fieldName, + timeRange: newInput.timeRange, + filters: newInput.filters, + query: newInput.query, + })), + distinctUntilChanged(diffDataFetchProps), + skip(1) + ); + + // fetch available min/max when input changes + this.subscriptions.add(dataFetchPipe.subscribe(this.fetchMinMax)); + + // build filters when value change + this.subscriptions.add( + this.getInput$() + .pipe( + debounceTime(400), + distinctUntilChanged((a, b) => isEqual(a.value, b.value)), + skip(1) // skip the first input update because initial filters will be built by initialize. + ) + .subscribe(this.buildFilter) + ); + }; + + private getCurrentDataViewAndField = async (): Promise<{ + dataView: DataView; + field: DataViewField; + }> => { + const { dataViewId, fieldName } = this.getInput(); + if (!this.dataView || this.dataView.id !== dataViewId) { + this.dataView = await this.dataViewsService.get(dataViewId); + if (this.dataView === undefined) { + this.onFatalError( + new Error(RangeSliderStrings.errors.getDataViewNotFoundError(dataViewId)) + ); + } + } + + if (!this.field || this.field.name !== fieldName) { + this.field = this.dataView.getFieldByName(fieldName); + if (this.field === undefined) { + this.onFatalError(new Error(RangeSliderStrings.errors.getDataViewNotFoundError(fieldName))); + } + + this.updateComponentState({ + field: this.field, + fieldFormatter: this.field + ? this.dataView.getFormatterForField(this.field).getConverterFor('text') + : (value: string) => value, + }); + } + + return { dataView: this.dataView, field: this.field! }; + }; + + private updateComponentState(changes: Partial) { + this.componentState = { + ...this.componentState, + ...changes, + }; + this.componentStateSubject$.next(this.componentState); + } + + private minMaxAgg = (field?: DataViewField) => { + const aggBody: any = {}; + if (field) { + if (field.scripted) { + aggBody.script = { + source: field.script, + lang: field.lang, + }; + } else { + aggBody.field = field.name; + } + } + + return { + maxAgg: { + max: aggBody, + }, + minAgg: { + min: aggBody, + }, + }; + }; + + private fetchMinMax = async () => { + this.updateComponentState({ loading: true }); + this.updateOutput({ loading: true }); + const { dataView, field } = await this.getCurrentDataViewAndField(); + const embeddableInput = this.getInput(); + const { ignoreParentSettings, fieldName, query, timeRange } = embeddableInput; + let { filters = [] } = embeddableInput; + + if (!field) { + this.updateComponentState({ loading: false }); + this.updateOutput({ loading: false }); + throw fieldMissingError(fieldName); + } + + if (ignoreParentSettings?.ignoreFilters) { + filters = []; + } + + if (!ignoreParentSettings?.ignoreTimerange && timeRange) { + const timeFilter = this.dataService.timefilter.createFilter(dataView, timeRange); + if (timeFilter) { + filters = filters.concat(timeFilter); + } + } + + const searchSource = await this.dataService.searchSource.create(); + searchSource.setField('size', 0); + searchSource.setField('index', dataView); + + const aggs = this.minMaxAgg(field); + searchSource.setField('aggs', aggs); + + searchSource.setField('filter', filters); + + if (!ignoreParentSettings?.ignoreQuery) { + searchSource.setField('query', query); + } + + const resp = await searchSource.fetch$().toPromise(); + + const min = get(resp, 'rawResponse.aggregations.minAgg.value', ''); + const max = get(resp, 'rawResponse.aggregations.maxAgg.value', ''); + + this.updateComponentState({ + min: `${min ?? ''}`, + max: `${max ?? ''}`, + }); + + // build filter with new min/max + await this.buildFilter(); + }; + + private buildFilter = async () => { + const { value: [selectedMin, selectedMax] = ['', ''], ignoreParentSettings } = this.getInput(); + + const hasData = !isEmpty(this.componentState.min) && !isEmpty(this.componentState.max); + const hasLowerSelection = !isEmpty(selectedMin); + const hasUpperSelection = !isEmpty(selectedMax); + const hasEitherSelection = hasLowerSelection || hasUpperSelection; + const hasBothSelections = hasLowerSelection && hasUpperSelection; + const hasInvalidSelection = + !ignoreParentSettings?.ignoreValidations && + hasBothSelections && + parseFloat(selectedMin) > parseFloat(selectedMax); + const isLowerSelectionOutOfRange = + hasLowerSelection && parseFloat(selectedMin) > parseFloat(this.componentState.max); + const isUpperSelectionOutOfRange = + hasUpperSelection && parseFloat(selectedMax) < parseFloat(this.componentState.min); + const isSelectionOutOfRange = + (!ignoreParentSettings?.ignoreValidations && hasData && isLowerSelectionOutOfRange) || + isUpperSelectionOutOfRange; + const { dataView, field } = await this.getCurrentDataViewAndField(); + + if (!hasData || !hasEitherSelection || hasInvalidSelection || isSelectionOutOfRange) { + this.updateComponentState({ loading: false }); + this.updateOutput({ filters: [], dataViews: [dataView], loading: false }); + return; + } + + const params = {} as RangeFilterParams; + + if (selectedMin) { + params.gte = selectedMin; + } + if (selectedMax) { + params.lte = selectedMax; + } + + const rangeFilter = buildRangeFilter(field, params, dataView); + + rangeFilter.meta.key = field?.name; + + this.updateComponentState({ loading: false }); + this.updateOutput({ filters: [rangeFilter], dataViews: [dataView], loading: false }); + }; + + reload = () => { + this.fetchMinMax(); + }; + + public destroy = () => { + super.destroy(); + this.subscriptions.unsubscribe(); + }; + + public render = (node: HTMLElement) => { + if (this.node) { + ReactDOM.unmountComponentAtNode(this.node); + } + this.node = node; + ReactDOM.render( + + + , + node + ); + }; +} diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider_embeddable_factory.tsx b/src/plugins/controls/public/control_types/range_slider/range_slider_embeddable_factory.tsx new file mode 100644 index 0000000000000..fbdaff4f5b349 --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider_embeddable_factory.tsx @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import deepEqual from 'fast-deep-equal'; + +import { RangeSliderEditor } from './range_slider_editor'; +import { ControlEmbeddable, IEditableControlFactory } from '../../types'; +import { RangeSliderEmbeddableInput, RANGE_SLIDER_CONTROL } from './types'; +import { EmbeddableFactoryDefinition, IContainer } from '../../../../embeddable/public'; +import { + createRangeSliderExtract, + createRangeSliderInject, +} from '../../../common/control_types/range_slider/range_slider_persistable_state'; +import { RangeSliderStrings } from './range_slider_strings'; + +export class RangeSliderEmbeddableFactory + implements EmbeddableFactoryDefinition, IEditableControlFactory +{ + public type = RANGE_SLIDER_CONTROL; + public canCreateNew = () => false; + + constructor() {} + + public async create(initialInput: RangeSliderEmbeddableInput, parent?: IContainer) { + const { RangeSliderEmbeddable } = await import('./range_slider_embeddable'); + return Promise.resolve(new RangeSliderEmbeddable(initialInput, {}, parent)); + } + + public presaveTransformFunction = ( + newInput: Partial, + embeddable?: ControlEmbeddable + ) => { + if ( + embeddable && + (!deepEqual(newInput.fieldName, embeddable.getInput().fieldName) || + !deepEqual(newInput.dataViewId, embeddable.getInput().dataViewId)) + ) { + // if the field name or data view id has changed in this editing session, selected values are invalid, so reset them. + newInput.value = ['', '']; + } + return newInput; + }; + + public controlEditorComponent = RangeSliderEditor; + + public isEditable = () => Promise.resolve(false); + + public getDisplayName = () => RangeSliderStrings.getDisplayName(); + public getIconType = () => 'controlsHorizontal'; + public getDescription = () => RangeSliderStrings.getDescription(); + + public inject = createRangeSliderInject(); + public extract = createRangeSliderExtract(); +} diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider_popover.tsx b/src/plugins/controls/public/control_types/range_slider/range_slider_popover.tsx new file mode 100644 index 0000000000000..a4ed84ec01a2e --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider_popover.tsx @@ -0,0 +1,242 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React, { FC, useState, useRef } from 'react'; +import { + EuiFieldNumber, + EuiPopoverTitle, + EuiText, + EuiInputPopover, + EuiButtonIcon, + EuiToolTip, + EuiLoadingSpinner, + EuiFlexGroup, + EuiFlexItem, + EuiDualRange, +} from '@elastic/eui'; + +import { RangeSliderStrings } from './range_slider_strings'; +import { RangeValue } from './types'; + +export interface Props { + id: string; + isLoading?: boolean; + min: string; + max: string; + title?: string; + value: RangeValue; + onChange: (value: RangeValue) => void; + fieldFormatter: (value: string) => string; +} + +export const RangeSliderPopover: FC = ({ + id, + isLoading, + min, + max, + title, + value, + onChange, + fieldFormatter, +}) => { + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + const rangeRef = useRef(null); + let errorMessage = ''; + let helpText = ''; + + const hasAvailableRange = min !== '' && max !== ''; + const hasLowerBoundSelection = value[0] !== ''; + const hasUpperBoundSelection = value[1] !== ''; + + const lowerBoundValue = parseFloat(value[0]); + const upperBoundValue = parseFloat(value[1]); + const minValue = parseFloat(min); + const maxValue = parseFloat(max); + + if (!hasAvailableRange) { + helpText = 'There is no data to display. Adjust the time range and filters.'; + } + + // EuiDualRange can only handle integers as min/max + const roundedMin = hasAvailableRange ? Math.floor(minValue) : minValue; + const roundedMax = hasAvailableRange ? Math.ceil(maxValue) : maxValue; + + const isLowerSelectionInvalid = hasLowerBoundSelection && lowerBoundValue > roundedMax; + const isUpperSelectionInvalid = hasUpperBoundSelection && upperBoundValue < roundedMin; + const isSelectionInvalid = + hasAvailableRange && (isLowerSelectionInvalid || isUpperSelectionInvalid); + + if (isSelectionInvalid) { + helpText = RangeSliderStrings.popover.getNoDataHelpText(); + } + + if (lowerBoundValue > upperBoundValue) { + errorMessage = RangeSliderStrings.errors.getUpperLessThanLowerErrorMessage(); + } + + const rangeSliderMin = Math.min( + roundedMin, + isNaN(lowerBoundValue) ? Infinity : lowerBoundValue, + isNaN(upperBoundValue) ? Infinity : upperBoundValue + ); + const rangeSliderMax = Math.max( + roundedMax, + isNaN(lowerBoundValue) ? -Infinity : lowerBoundValue, + isNaN(upperBoundValue) ? -Infinity : upperBoundValue + ); + + const displayedValue = [ + hasLowerBoundSelection ? String(lowerBoundValue) : hasAvailableRange ? String(roundedMin) : '', + hasUpperBoundSelection ? String(upperBoundValue) : hasAvailableRange ? String(roundedMax) : '', + ] as RangeValue; + + const ticks = []; + const levels = []; + + if (hasAvailableRange) { + ticks.push({ value: rangeSliderMin, label: fieldFormatter(String(rangeSliderMin)) }); + ticks.push({ value: rangeSliderMax, label: fieldFormatter(String(rangeSliderMax)) }); + levels.push({ min: roundedMin, max: roundedMax, color: 'success' }); + } + + const button = ( + + ); + + return ( + setIsPopoverOpen(false)} + anchorPosition="downCenter" + initialFocus={false} + repositionOnScroll + disableFocusTrap + onPanelResize={() => { + if (rangeRef?.current) { + rangeRef.current.onResize(); + } + }} + > + {title} + + + { + const updatedLowerBound = + typeof newLowerBound === 'number' ? String(newLowerBound) : value[0]; + const updatedUpperBound = + typeof newUpperBound === 'number' ? String(newUpperBound) : value[1]; + + onChange([updatedLowerBound, updatedUpperBound]); + }} + value={displayedValue} + ticks={hasAvailableRange ? ticks : undefined} + levels={hasAvailableRange ? levels : undefined} + showTicks={hasAvailableRange} + disabled={!hasAvailableRange} + fullWidth + ref={rangeRef} + data-test-subj="rangeSlider__slider" + /> + + {errorMessage || helpText} + + + {hasAvailableRange ? ( + + + onChange(['', ''])} + aria-label={RangeSliderStrings.popover.getClearRangeButtonTitle()} + data-test-subj="rangeSlider__clearRangeButton" + /> + + + ) : null} + + + ); +}; diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider_reducers.ts b/src/plugins/controls/public/control_types/range_slider/range_slider_reducers.ts new file mode 100644 index 0000000000000..ce7e5ced101a6 --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider_reducers.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { PayloadAction } from '@reduxjs/toolkit'; +import { WritableDraft } from 'immer/dist/types/types-external'; + +import { RangeSliderEmbeddableInput, RangeValue } from './types'; + +export const rangeSliderReducers = { + selectRange: ( + state: WritableDraft, + action: PayloadAction + ) => { + state.value = action.payload; + }, +}; diff --git a/src/plugins/controls/public/control_types/range_slider/range_slider_strings.ts b/src/plugins/controls/public/control_types/range_slider/range_slider_strings.ts new file mode 100644 index 0000000000000..a901f79ba20f5 --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/range_slider_strings.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; + +export const RangeSliderStrings = { + getDisplayName: () => + i18n.translate('controls.rangeSlider.displayName', { + defaultMessage: 'Range slider', + }), + getDescription: () => + i18n.translate('controls.rangeSlider.description', { + defaultMessage: 'Add a control for selecting a range of field values.', + }), + editor: { + getDataViewTitle: () => + i18n.translate('controls.rangeSlider.editor.dataViewTitle', { + defaultMessage: 'Data view', + }), + getNoDataViewTitle: () => + i18n.translate('controls.rangeSlider.editor.noDataViewTitle', { + defaultMessage: 'Select data view', + }), + getFieldTitle: () => + i18n.translate('controls.rangeSlider.editor.fieldTitle', { + defaultMessage: 'Field', + }), + }, + popover: { + getAllOptionsButtonTitle: () => + i18n.translate('controls.rangeSlider.popover.allOptionsTitle', { + defaultMessage: 'Show all options', + }), + getClearRangeButtonTitle: () => + i18n.translate('controls.rangeSlider.popover.clearRangeTitle', { + defaultMessage: 'Clear range', + }), + getNoDataHelpText: () => + i18n.translate('controls.rangeSlider.popover.noDataHelpText', { + defaultMessage: 'Selected range is outside of available data. No filter was applied.', + }), + }, + errors: { + getDataViewNotFoundError: (dataViewId: string) => + i18n.translate('controls.optionsList.errors.dataViewNotFound', { + defaultMessage: 'Could not locate data view: {dataViewId}', + values: { dataViewId }, + }), + getUpperLessThanLowerErrorMessage: () => + i18n.translate('controls.rangeSlider.popover.upperLessThanLowerErrorMessage', { + defaultMessage: 'The upper bound must be greater than or equal to the lower bound.', + }), + }, +}; diff --git a/src/plugins/controls/public/control_types/range_slider/types.ts b/src/plugins/controls/public/control_types/range_slider/types.ts new file mode 100644 index 0000000000000..e9ebe61bf6267 --- /dev/null +++ b/src/plugins/controls/public/control_types/range_slider/types.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export * from '../../../common/control_types/options_list/types'; +export * from '../../../common/control_types/range_slider/types'; diff --git a/src/plugins/controls/public/index.ts b/src/plugins/controls/public/index.ts index 7caf9d19e49b2..db4586b315075 100644 --- a/src/plugins/controls/public/index.ts +++ b/src/plugins/controls/public/index.ts @@ -24,7 +24,7 @@ export type { ControlInput, } from '../common/types'; -export { OPTIONS_LIST_CONTROL, CONTROL_GROUP_TYPE } from '../common'; +export { CONTROL_GROUP_TYPE, OPTIONS_LIST_CONTROL, RANGE_SLIDER_CONTROL } from '../common'; export { ControlGroupContainer, @@ -37,6 +37,9 @@ export { OptionsListEmbeddableFactory, OptionsListEmbeddable, type OptionsListEmbeddableInput, + RangeSliderEmbeddableFactory, + RangeSliderEmbeddable, + type RangeSliderEmbeddableInput, } from './control_types'; export { LazyControlsCallout, type CalloutProps } from './controls_callout'; diff --git a/src/plugins/controls/public/plugin.ts b/src/plugins/controls/public/plugin.ts index 0c81f4c826175..96cb7eeef3a27 100644 --- a/src/plugins/controls/public/plugin.ts +++ b/src/plugins/controls/public/plugin.ts @@ -20,7 +20,16 @@ import { OptionsListEmbeddableFactory, OptionsListEmbeddableInput, } from './control_types/options_list'; -import { ControlGroupContainerFactory, CONTROL_GROUP_TYPE, OPTIONS_LIST_CONTROL } from '.'; +import { + RangeSliderEmbeddableFactory, + RangeSliderEmbeddableInput, +} from './control_types/range_slider'; +import { + ControlGroupContainerFactory, + CONTROL_GROUP_TYPE, + OPTIONS_LIST_CONTROL, + RANGE_SLIDER_CONTROL, +} from '.'; import { controlsService } from './services/kibana/controls'; import { EmbeddableFactory } from '../../embeddable/public'; @@ -56,6 +65,7 @@ export class ControlsPlugin _setupPlugins: ControlsPluginSetupDeps ): ControlsPluginSetup { const { registerControlType } = controlsService; + const { embeddable } = _setupPlugins; // register control group embeddable factory _coreSetup.getStartServices().then(([, deps]) => { @@ -75,8 +85,19 @@ export class ControlsPlugin optionsListFactory ); registerControlType(optionsListFactory); + + // Register range slider + const rangeSliderFactoryDef = new RangeSliderEmbeddableFactory(); + const rangeSliderFactory = embeddable.registerEmbeddableFactory( + RANGE_SLIDER_CONTROL, + rangeSliderFactoryDef + )(); + this.transferEditorFunctions( + rangeSliderFactoryDef, + rangeSliderFactory + ); + registerControlType(rangeSliderFactory); }); - const { embeddable } = _setupPlugins; return { registerControlType, @@ -87,6 +108,7 @@ export class ControlsPlugin this.startControlsKibanaServices(coreStart, startPlugins); const { getControlFactory, getControlTypes } = controlsService; + return { getControlFactory, getControlTypes, diff --git a/src/plugins/controls/public/services/data.ts b/src/plugins/controls/public/services/data.ts index f25b3f6a95801..f11e451995535 100644 --- a/src/plugins/controls/public/services/data.ts +++ b/src/plugins/controls/public/services/data.ts @@ -11,4 +11,6 @@ import { DataPublicPluginStart } from '../../../data/public'; export interface ControlsDataService { autocomplete: DataPublicPluginStart['autocomplete']; query: DataPublicPluginStart['query']; + searchSource: DataPublicPluginStart['search']['searchSource']; + timefilter: DataPublicPluginStart['query']['timefilter']['timefilter']; } diff --git a/src/plugins/controls/public/services/kibana/data.ts b/src/plugins/controls/public/services/kibana/data.ts index e411766fe0f34..0830233109e2a 100644 --- a/src/plugins/controls/public/services/kibana/data.ts +++ b/src/plugins/controls/public/services/kibana/data.ts @@ -17,10 +17,12 @@ export type DataServiceFactory = KibanaPluginServiceFactory< export const dataServiceFactory: DataServiceFactory = ({ startPlugins }) => { const { - data: { query, autocomplete }, + data: { autocomplete, query, search }, } = startPlugins; return { autocomplete, query, + searchSource: search.searchSource, + timefilter: query.timefilter.timefilter, }; }; diff --git a/src/plugins/controls/public/services/storybook/data.ts b/src/plugins/controls/public/services/storybook/data.ts index c26d7c0835295..bfdcf05767b01 100644 --- a/src/plugins/controls/public/services/storybook/data.ts +++ b/src/plugins/controls/public/services/storybook/data.ts @@ -6,6 +6,7 @@ * Side Public License, v 1. */ +import { of } from 'rxjs'; import { PluginServiceFactory } from '../../../../presentation_util/public'; import { DataPublicPluginStart } from '../../../../data/public'; import { DataViewField } from '../../../../data_views/common'; @@ -23,4 +24,18 @@ export const dataServiceFactory: DataServiceFactory = () => ({ getValueSuggestions: valueSuggestionMethod, } as unknown as DataPublicPluginStart['autocomplete'], query: {} as unknown as DataPublicPluginStart['query'], + searchSource: { + create: () => ({ + setField: () => {}, + fetch$: () => + of({ + resp: { + rawResponse: { aggregations: { minAgg: { value: 0 }, maxAgg: { value: 1000 } } }, + }, + }), + }), + } as unknown as DataPublicPluginStart['search']['searchSource'], + timefilter: { + createFilter: () => {}, + } as unknown as DataPublicPluginStart['query']['timefilter']['timefilter'], }); diff --git a/src/plugins/presentation_util/public/__stories__/fixtures/flights.ts b/src/plugins/presentation_util/public/__stories__/fixtures/flights.ts index 0ec82b1e1994b..d999db22b4057 100644 --- a/src/plugins/presentation_util/public/__stories__/fixtures/flights.ts +++ b/src/plugins/presentation_util/public/__stories__/fixtures/flights.ts @@ -43,12 +43,22 @@ export const flightFieldNames: FlightField[] = [ 'timestamp', ]; +const numberFields = [ + 'AvgTicketPrice', + 'dayOfWeek', + 'DistanceKilometers', + 'DistanceMiles', + 'FlightDelayMin', + 'FlightTimeHour', + 'FlightTimeMin', +]; + export const flightFieldByName: { [key: string]: DataViewField } = {}; flightFieldNames.forEach( (flightFieldName) => (flightFieldByName[flightFieldName] = { name: flightFieldName, - type: 'string', + type: numberFields.includes(flightFieldName) ? 'number' : 'string', aggregatable: true, } as unknown as DataViewField) ); diff --git a/test/functional/apps/dashboard_elements/controls/index.ts b/test/functional/apps/dashboard_elements/controls/index.ts index a29834c848094..f5ec41d593995 100644 --- a/test/functional/apps/dashboard_elements/controls/index.ts +++ b/test/functional/apps/dashboard_elements/controls/index.ts @@ -49,6 +49,7 @@ export default function ({ loadTestFile, getService, getPageObjects }: FtrProvid loadTestFile(require.resolve('./controls_callout')); loadTestFile(require.resolve('./control_group_settings')); loadTestFile(require.resolve('./options_list')); + loadTestFile(require.resolve('./range_slider')); loadTestFile(require.resolve('./control_group_chaining')); }); } diff --git a/test/functional/apps/dashboard_elements/controls/options_list.ts b/test/functional/apps/dashboard_elements/controls/options_list.ts index 6c52581d2878f..ce04b2b01c091 100644 --- a/test/functional/apps/dashboard_elements/controls/options_list.ts +++ b/test/functional/apps/dashboard_elements/controls/options_list.ts @@ -100,8 +100,8 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { const firstId = (await dashboardControls.getAllControlIds())[0]; await dashboardControls.editExistingControl(firstId); - await dashboardControls.optionsListEditorSetDataView('animals-*'); - await dashboardControls.optionsListEditorSetfield('animal.keyword'); + await dashboardControls.controlsEditorSetDataView('animals-*'); + await dashboardControls.controlsEditorSetfield('animal.keyword'); await dashboardControls.controlEditorSave(); // when creating a new filter, the ability to select a data view should be removed, because the dashboard now only has one data view diff --git a/test/functional/apps/dashboard_elements/controls/range_slider.ts b/test/functional/apps/dashboard_elements/controls/range_slider.ts new file mode 100644 index 0000000000000..b2132e1919bd6 --- /dev/null +++ b/test/functional/apps/dashboard_elements/controls/range_slider.ts @@ -0,0 +1,204 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import expect from '@kbn/expect'; + +import { FtrProviderContext } from '../../../ftr_provider_context'; + +export default function ({ getService, getPageObjects }: FtrProviderContext) { + const retry = getService('retry'); + const esArchiver = getService('esArchiver'); + const security = getService('security'); + const filterBar = getService('filterBar'); + const testSubjects = getService('testSubjects'); + const kibanaServer = getService('kibanaServer'); + const { dashboardControls, timePicker, common, dashboard } = getPageObjects([ + 'dashboardControls', + 'timePicker', + 'dashboard', + 'common', + 'header', + ]); + + describe('Range Slider Control', async () => { + before(async () => { + await security.testUser.setRoles([ + 'kibana_admin', + 'kibana_sample_admin', + 'test_logstash_reader', + ]); + await esArchiver.load('test/functional/fixtures/es_archiver/kibana_sample_data_flights'); + await kibanaServer.importExport.load( + 'test/functional/fixtures/kbn_archiver/dashboard/current/kibana' + ); + await kibanaServer.importExport.load( + 'test/functional/fixtures/kbn_archiver/kibana_sample_data_flights_index_pattern' + ); + await kibanaServer.uiSettings.replace({ + defaultIndex: '0bf35f60-3dc9-11e8-8660-4d65aa086b3c', + }); + await common.navigateToApp('dashboard'); + await dashboardControls.enableControlsLab(); + await common.navigateToApp('dashboard'); + await dashboard.preserveCrossAppState(); + await dashboard.gotoDashboardLandingPage(); + await dashboard.clickNewDashboard(); + await timePicker.setAbsoluteRange( + 'Oct 22, 2018 @ 00:00:00.000', + 'Dec 3, 2018 @ 00:00:00.000' + ); + }); + + after(async () => { + await dashboardControls.clearAllControls(); + await kibanaServer.importExport.unload( + 'test/functional/fixtures/kbn_archiver/kibana_sample_data_flights_index_pattern' + ); + await esArchiver.unload('test/functional/fixtures/es_archiver/kibana_sample_data_flights'); + await kibanaServer.uiSettings.unset('defaultIndex'); + await security.testUser.restoreDefaults(); + }); + + describe('create and edit', async () => { + it('can create a new range slider control from a blank state', async () => { + await dashboardControls.createRangeSliderControl({ fieldName: 'bytes', width: 'small' }); + expect(await dashboardControls.getControlsCount()).to.be(1); + }); + + it('can add a second range list control with a non-default data view', async () => { + await dashboardControls.createRangeSliderControl({ + dataViewTitle: 'kibana_sample_data_flights', + fieldName: 'AvgTicketPrice', + width: 'medium', + }); + expect(await dashboardControls.getControlsCount()).to.be(2); + const secondId = (await dashboardControls.getAllControlIds())[1]; + expect( + await dashboardControls.rangeSliderGetLowerBoundAttribute(secondId, 'placeholder') + ).to.be('100'); + expect( + await dashboardControls.rangeSliderGetUpperBoundAttribute(secondId, 'placeholder') + ).to.be('1200'); + // data views should be properly propagated from the control group to the dashboard + expect(await filterBar.getIndexPatterns()).to.be('logstash-*,kibana_sample_data_flights'); + }); + + it('renames an existing control', async () => { + const secondId = (await dashboardControls.getAllControlIds())[1]; + const newTitle = 'Average ticket price'; + await dashboardControls.editExistingControl(secondId); + await dashboardControls.controlEditorSetTitle(newTitle); + await dashboardControls.controlEditorSave(); + expect(await dashboardControls.doesControlTitleExist(newTitle)).to.be(true); + }); + + it('can edit range slider control', async () => { + const firstId = (await dashboardControls.getAllControlIds())[0]; + await dashboardControls.editExistingControl(firstId); + await dashboardControls.controlsEditorSetDataView('kibana_sample_data_flights'); + await dashboardControls.controlsEditorSetfield('dayOfWeek'); + await dashboardControls.controlEditorSave(); + await dashboardControls.rangeSliderWaitForLoading(); + expect( + await dashboardControls.rangeSliderGetLowerBoundAttribute(firstId, 'placeholder') + ).to.be('0'); + expect( + await dashboardControls.rangeSliderGetUpperBoundAttribute(firstId, 'placeholder') + ).to.be('6'); + // when creating a new filter, the ability to select a data view should be removed, because the dashboard now only has one data view + await retry.try(async () => { + await testSubjects.click('addFilter'); + const indexPatternSelectExists = await testSubjects.exists('filterIndexPatternsSelect'); + await filterBar.ensureFieldEditorModalIsClosed(); + expect(indexPatternSelectExists).to.be(false); + }); + }); + + it('can enter lower bound selection from the number field', async () => { + const firstId = (await dashboardControls.getAllControlIds())[0]; + await dashboardControls.rangeSliderSetLowerBound(firstId, '1'); + const lowerBoundSelection = await dashboardControls.rangeSliderGetLowerBoundAttribute( + firstId, + 'value' + ); + expect(lowerBoundSelection).to.be('1'); + }); + + it('can enter upper bound selection into the number field', async () => { + const firstId = (await dashboardControls.getAllControlIds())[0]; + await dashboardControls.rangeSliderSetUpperBound(firstId, '2'); + const upperBoundSelection = await dashboardControls.rangeSliderGetUpperBoundAttribute( + firstId, + 'value' + ); + expect(upperBoundSelection).to.be('2'); + }); + + it('applies filter from the first control on the second control', async () => { + await dashboardControls.rangeSliderWaitForLoading(); + const secondId = (await dashboardControls.getAllControlIds())[1]; + const availableMin = await dashboardControls.rangeSliderGetLowerBoundAttribute( + secondId, + 'placeholder' + ); + expect(availableMin).to.be('100'); + const availabeMax = await dashboardControls.rangeSliderGetUpperBoundAttribute( + secondId, + 'placeholder' + ); + expect(availabeMax).to.be('1000'); + }); + + it('can clear out selections by clicking the reset button', async () => { + const firstId = (await dashboardControls.getAllControlIds())[0]; + await dashboardControls.rangeSliderClearSelection(firstId); + const lowerBoundSelection = await dashboardControls.rangeSliderGetLowerBoundAttribute( + firstId, + 'value' + ); + expect(lowerBoundSelection.length).to.be(0); + const upperBoundSelection = await dashboardControls.rangeSliderGetUpperBoundAttribute( + firstId, + 'value' + ); + expect(upperBoundSelection.length).to.be(0); + }); + + it('deletes an existing control', async () => { + const firstId = (await dashboardControls.getAllControlIds())[0]; + await dashboardControls.removeExistingControl(firstId); + expect(await dashboardControls.getControlsCount()).to.be(1); + }); + }); + + describe('validation', async () => { + it('displays error message when upper bound selection is less than lower bound selection', async () => { + const firstId = (await dashboardControls.getAllControlIds())[0]; + await dashboardControls.rangeSliderSetLowerBound(firstId, '500'); + await dashboardControls.rangeSliderSetUpperBound(firstId, '400'); + }); + + it('disables inputs when no data available', async () => { + await dashboardControls.createRangeSliderControl({ fieldName: 'bytes', width: 'small' }); + const secondId = (await dashboardControls.getAllControlIds())[1]; + expect( + await dashboardControls.rangeSliderGetLowerBoundAttribute(secondId, 'disabled') + ).to.be('true'); + expect( + await dashboardControls.rangeSliderGetUpperBoundAttribute(secondId, 'disabled') + ).to.be('true'); + await dashboardControls.rangeSliderOpenPopover(secondId); + await dashboardControls.rangeSliderPopoverAssertOpen(); + expect( + await dashboardControls.rangeSliderGetDualRangeAttribute(secondId, 'disabled') + ).to.be('true'); + expect((await testSubjects.getVisibleText('rangeSlider__helpText')).length).to.be.above(0); + }); + }); + }); +} diff --git a/test/functional/apps/dashboard_elements/index.ts b/test/functional/apps/dashboard_elements/index.ts index 059576389f32e..6bd3e4e04a9c9 100644 --- a/test/functional/apps/dashboard_elements/index.ts +++ b/test/functional/apps/dashboard_elements/index.ts @@ -23,6 +23,12 @@ export default function ({ getService, loadTestFile }: FtrProviderContext) { await esArchiver.loadIfNeeded('test/functional/fixtures/es_archiver/long_window_logstash'); }); + after(async () => { + await esArchiver.unload('test/functional/fixtures/es_archiver/empty_kibana'); + await esArchiver.unload('test/functional/fixtures/es_archiver/logstash_functional'); + await esArchiver.unload('test/functional/fixtures/es_archiver/long_window_logstash'); + }); + describe('dashboard elements ciGroup10', function () { this.tags('ciGroup10'); diff --git a/test/functional/page_objects/dashboard_page_controls.ts b/test/functional/page_objects/dashboard_page_controls.ts index f0dd7ed9ddd3d..0f52bf1255693 100644 --- a/test/functional/page_objects/dashboard_page_controls.ts +++ b/test/functional/page_objects/dashboard_page_controls.ts @@ -8,7 +8,11 @@ import expect from '@kbn/expect'; import { WebElementWrapper } from 'test/functional/services/lib/web_element_wrapper'; -import { OPTIONS_LIST_CONTROL, ControlWidth } from '../../../src/plugins/controls/common'; +import { + OPTIONS_LIST_CONTROL, + ControlWidth, + RANGE_SLIDER_CONTROL, +} from '../../../src/plugins/controls/common'; import { ControlGroupChainingSystem } from '../../../src/plugins/controls/common/control_group/types'; import { FtrService } from '../ftr_provider_context'; @@ -238,6 +242,14 @@ export class DashboardPageControls extends FtrService { }); } + public async clickExistingControl(controlId: string) { + const elementToClick = await this.getControlElementById(controlId); + await this.retry.try(async () => { + await elementToClick.click(); + await this.testSubjects.existOrFail(`control-action-${controlId}-edit`); + }); + } + public async editExistingControl(controlId: string) { this.log.debug(`Opening control editor for control: ${controlId}`); await this.hoverOverExistingControl(controlId); @@ -344,6 +356,26 @@ export class DashboardPageControls extends FtrService { } } + public async controlsEditorSetDataView(dataViewTitle: string) { + this.log.debug(`Setting control data view to ${dataViewTitle}`); + await this.testSubjects.click('open-data-view-picker'); + await this.retry.try(async () => { + await this.testSubjects.existOrFail('data-view-picker-title'); + }); + await this.testSubjects.click(`data-view-picker-${dataViewTitle}`); + } + + public async controlsEditorSetfield(fieldName: string, shouldSearch: boolean = false) { + this.log.debug(`Setting control field to ${fieldName}`); + if (shouldSearch) { + await this.testSubjects.setValue('field-search-input', fieldName); + } + await this.retry.try(async () => { + await this.testSubjects.existOrFail(`field-picker-select-${fieldName}`); + }); + await this.testSubjects.click(`field-picker-select-${fieldName}`); + } + // Options List editor functions public async createOptionsListControl({ dataViewTitle, @@ -359,8 +391,8 @@ export class DashboardPageControls extends FtrService { this.log.debug(`Creating options list control ${title ?? fieldName}`); await this.openCreateControlFlyout(OPTIONS_LIST_CONTROL); - if (dataViewTitle) await this.optionsListEditorSetDataView(dataViewTitle); - if (fieldName) await this.optionsListEditorSetfield(fieldName); + if (dataViewTitle) await this.controlsEditorSetDataView(dataViewTitle); + if (fieldName) await this.controlsEditorSetfield(fieldName); if (title) await this.controlEditorSetTitle(title); if (width) await this.controlEditorSetWidth(width); @@ -378,23 +410,93 @@ export class DashboardPageControls extends FtrService { return dataViewName; } - public async optionsListEditorSetDataView(dataViewTitle: string) { - this.log.debug(`Setting options list data view to ${dataViewTitle}`); - await this.testSubjects.click('open-data-view-picker'); + // Range slider functions + public async rangeSliderGetLowerBoundAttribute(controlId: string, attribute: string) { + this.log.debug(`Getting range slider lower bound ${attribute} for ${controlId}`); + return await this.testSubjects.getAttribute( + `range-slider-control-${controlId} > rangeSlider__lowerBoundFieldNumber`, + attribute + ); + } + public async rangeSliderGetUpperBoundAttribute(controlId: string, attribute: string) { + this.log.debug(`Getting range slider upper bound ${attribute} for ${controlId}`); + return await this.testSubjects.getAttribute( + `range-slider-control-${controlId} > rangeSlider__upperBoundFieldNumber`, + attribute + ); + } + public async rangeSliderGetDualRangeAttribute(controlId: string, attribute: string) { + this.log.debug(`Getting range slider dual range ${attribute} for ${controlId}`); + return await this.testSubjects.getAttribute(`rangeSlider__slider`, attribute); + } + public async rangeSliderSetLowerBound(controlId: string, value: string) { + this.log.debug(`Setting range slider lower bound to ${value}`); + await this.testSubjects.setValue( + `range-slider-control-${controlId} > rangeSlider__lowerBoundFieldNumber`, + value + ); + } + public async rangeSliderSetUpperBound(controlId: string, value: string) { + this.log.debug(`Setting range slider lower bound to ${value}`); + await this.testSubjects.setValue( + `range-slider-control-${controlId} > rangeSlider__upperBoundFieldNumber`, + value + ); + } + + public async rangeSliderOpenPopover(controlId: string) { + this.log.debug(`Opening popover for Range Slider: ${controlId}`); + await this.testSubjects.click(`range-slider-control-${controlId}`); await this.retry.try(async () => { - await this.testSubjects.existOrFail('data-view-picker-title'); + await this.testSubjects.existOrFail(`rangeSlider-control-actions`); }); - await this.testSubjects.click(`data-view-picker-${dataViewTitle}`); } - public async optionsListEditorSetfield(fieldName: string, shouldSearch: boolean = false) { - this.log.debug(`Setting options list field to ${fieldName}`); - if (shouldSearch) { - await this.testSubjects.setValue('field-search-input', fieldName); - } + public async rangeSliderEnsurePopoverIsClosed(controlId: string) { + this.log.debug(`Opening popover for Range Slider: ${controlId}`); + await this.testSubjects.click(`range-slider-control-${controlId}`); + await this.testSubjects.waitForDeleted(`rangeSlider-control-actions`); + } + + public async rangeSliderPopoverAssertOpen() { await this.retry.try(async () => { - await this.testSubjects.existOrFail(`field-picker-select-${fieldName}`); + if (!(await this.testSubjects.exists(`rangeSlider-control-actions`))) { + throw new Error('options list popover must be open before calling selectOption'); + } }); - await this.testSubjects.click(`field-picker-select-${fieldName}`); + } + + public async rangeSliderWaitForLoading() { + await this.testSubjects.waitForDeleted('range-slider-loading-spinner'); + } + + public async rangeSliderClearSelection(controlId: string) { + this.log.debug(`Clearing range slider selection from control: ${controlId}`); + await this.rangeSliderOpenPopover(controlId); + await this.rangeSliderPopoverAssertOpen(); + await this.testSubjects.click('rangeSlider__clearRangeButton'); + } + + // Range slider editor functions + public async createRangeSliderControl({ + dataViewTitle, + fieldName, + width, + title, + }: { + title?: string; + fieldName: string; + width?: ControlWidth; + dataViewTitle?: string; + }) { + this.log.debug(`Creating range slider control ${title ?? fieldName}`); + await this.openCreateControlFlyout(RANGE_SLIDER_CONTROL); + + if (dataViewTitle) await this.controlsEditorSetDataView(dataViewTitle); + if (fieldName) await this.controlsEditorSetfield(fieldName); + if (title) await this.controlEditorSetTitle(title); + if (width) await this.controlEditorSetWidth(width); + + await this.controlEditorSave(); } } diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 63b23f18a4229..a770b1c237e70 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -1231,7 +1231,6 @@ "controls.optionsList.editor.allowMultiselectTitle": "ドロップダウンでの複数選択を許可", "controls.optionsList.editor.dataViewTitle": "データビュー", "controls.optionsList.editor.fieldTitle": "フィールド", - "controls.optionsList.editor.indexPatternTitle": "インデックスパターン", "controls.optionsList.editor.noDataViewTitle": "データビューを選択", "controls.optionsList.errors.dataViewNotFound": "データビュー{dataViewId}が見つかりませんでした", "controls.optionsList.popover.allOptionsTitle": "すべてのオプションを表示", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index e7434219172a8..d6c0753033212 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -1235,7 +1235,6 @@ "controls.optionsList.editor.allowMultiselectTitle": "下拉列表中允许多选", "controls.optionsList.editor.dataViewTitle": "数据视图", "controls.optionsList.editor.fieldTitle": "字段", - "controls.optionsList.editor.indexPatternTitle": "索引模式", "controls.optionsList.editor.noDataViewTitle": "选择数据视图", "controls.optionsList.errors.dataViewNotFound": "找不到数据视图:{dataViewId}", "controls.optionsList.popover.allOptionsTitle": "显示所有选项", From 9bc4c0c22c597b6f08c1b509431c159a833114e8 Mon Sep 17 00:00:00 2001 From: Garrett Spong Date: Mon, 28 Mar 2022 16:42:46 -0600 Subject: [PATCH 057/160] [Security Solution][Detections] Adds rule execution log table (#126215) ## Summary Resolves #119598, #119599, #101014 Test plan ([internal doc](https://docs.google.com/document/d/1-prIUGYaPHiwGA79CgSdw1926lxIPKGWWkYOUD2BM1U/edit#heading=h.womzsfdt6zt8)) Adds `Rule Execution Log` table to Rule Details page:

### Implementation notes The useful metrics within `event-log` for a given rule execution are spread between a few different platform (`execute-start`, `execute`) and security (`execution-metrics`, `status-change`) events. In effort to provide consolidated metrics per rule execution (and avoiding a lot of empty cells and mis-matched statuses like in the image below)

these rule execution events are aggregated by their `executionId`, and then fields are merged from each different event. This PR was re-worked to take advantage of the new event-log aggregation support added in https://github.com/elastic/kibana/pull/126948, and is no longer implemented as an in-memory aggregation server side. * Due to restrictions around supplying search filters that may match multiple sub-agg buckets and missing data ([see discussion here](https://github.com/elastic/kibana/pull/127339/files#r825240516)), it was decided that we'd disable the search bar for the time being. We have both a near-term (writing single rollup event) and long-term (ES|QL) solution that will allow us to re-enable this functionality. * Note, since a `terms` agg is used to fetch all execution events, an upper bound must be set. See [this discussion](https://github.com/elastic/kibana/pull/127339/files#r823035420) for more details, but setting this max to `1000` events for the time being, and returning total cardinality of execution events back within `total` to allow the UI to inform the user that they should narrow their search further to better isolate and find possible issues. This should be a be a reasonable constraint for most all rules as a rule executing every 5 minutes, 1000 executions would cover over 3 days of execution time.

The `Filter for alerts` action will be available on all `Succeeded`/`Partial Failure` executions even if there weren't alerts generated until https://github.com/elastic/kibana/pull/126210 is merged and we can start returning the alert count, at which point we can programmatically enabled/disable this action based on alert count.

--- .../src/configuration_constants.ts | 12 + .../kbn-securitysolution-rules/src/index.ts | 1 + .../security_solution/common/constants.ts | 3 + .../schemas/common/rule_monitoring.ts | 28 + ...ts => get_rule_execution_events_schema.ts} | 15 + .../get_rule_execution_events_response.ts | 13 +- .../detection_engine/rules/__mocks__/api.ts | 36 +- .../detection_engine/rules/api.test.ts | 28 +- .../containers/detection_engine/rules/api.ts | 45 +- .../detection_engine/rules/translations.ts | 7 + .../rules/use_rule_execution_events.test.tsx | 52 +- .../rules/use_rule_execution_events.tsx | 54 +- .../rules/all/popover_tooltip.tsx | 5 +- .../rules/all/use_columns.tsx | 2 +- .../execution_log_search_bar.test.tsx.snap | 78 + .../execution_log_table.test.tsx.snap | 210 +++ .../rule_duration_format.test.tsx.snap | 9 + .../execution_log_columns.tsx | 171 +++ .../execution_log_search_bar.test.tsx | 24 + .../execution_log_search_bar.tsx | 147 ++ .../execution_log_table.test.tsx | 103 ++ .../execution_log_table.tsx | 325 ++++ .../rule_duration_format.test.tsx | 21 + .../rule_duration_format.tsx | 55 + .../execution_log_table/translations.ts | 182 +++ .../rules/details/failure_history.tsx | 80 - .../detection_engine/rules/details/index.tsx | 22 +- .../rules/details/translations.ts | 34 +- .../detection_engine/rules/translations.ts | 7 + .../routes/__mocks__/request_responses.ts | 60 + .../get_rule_execution_events_route.test.ts | 17 +- .../rules/get_rule_execution_events_route.ts | 42 +- .../rule_execution_log/__mocks__/index.ts | 1 + .../client_for_routes/client.ts | 44 +- .../client_for_routes/client_interface.ts | 38 + .../event_log/event_log_reader.ts | 82 + .../index.test.ts | 1321 +++++++++++++++++ .../get_execution_event_aggregation/index.ts | 351 +++++ .../get_execution_event_aggregation/types.ts | 61 + .../translations/translations/fr-FR.json | 5 - .../translations/translations/ja-JP.json | 5 - .../translations/translations/zh-CN.json | 5 - .../tests/get_rule_execution_events.ts | 227 +++ .../security_and_spaces/tests/index.ts | 1 + .../tests/template_data/execution_events.ts | 630 ++++++++ .../detection_engine_api_integration/utils.ts | 119 ++ 46 files changed, 4595 insertions(+), 183 deletions(-) create mode 100644 packages/kbn-securitysolution-rules/src/configuration_constants.ts rename x-pack/plugins/security_solution/common/detection_engine/schemas/request/{get_rule_execution_events_request.ts => get_rule_execution_events_schema.ts} (51%) create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_search_bar.test.tsx.snap create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_table.test.tsx.snap create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/rule_duration_format.test.tsx.snap create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_columns.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.test.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.test.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.test.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/translations.ts delete mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/failure_history.tsx create mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.test.ts create mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.ts create mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/types.ts create mode 100644 x-pack/test/detection_engine_api_integration/security_and_spaces/tests/get_rule_execution_events.ts create mode 100644 x-pack/test/detection_engine_api_integration/security_and_spaces/tests/template_data/execution_events.ts diff --git a/packages/kbn-securitysolution-rules/src/configuration_constants.ts b/packages/kbn-securitysolution-rules/src/configuration_constants.ts new file mode 100644 index 0000000000000..115c6996739db --- /dev/null +++ b/packages/kbn-securitysolution-rules/src/configuration_constants.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +/** + * Max number of execution events to aggregate in memory for the Rule Execution Log + */ +export const MAX_EXECUTION_EVENTS_DISPLAYED = 1000 as const; diff --git a/packages/kbn-securitysolution-rules/src/index.ts b/packages/kbn-securitysolution-rules/src/index.ts index 1d59b9842c90d..45d35ea80b39c 100644 --- a/packages/kbn-securitysolution-rules/src/index.ts +++ b/packages/kbn-securitysolution-rules/src/index.ts @@ -6,6 +6,7 @@ * Side Public License, v 1. */ +export * from './configuration_constants'; export * from './rule_type_constants'; export * from './rule_type_mappings'; export * from './utils'; diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index 91545e25057d7..f205c6c439dc9 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -440,3 +440,6 @@ export const RULES_TABLE_PAGE_SIZE_OPTIONS = [5, 10, 20, 50, RULES_TABLE_MAX_PAG */ export const RULES_MANAGEMENT_FEATURE_TOUR_STORAGE_KEY = 'securitySolution.rulesManagementPage.newFeaturesTour.v8.1'; + +export const RULE_DETAILS_EXECUTION_LOG_TABLE_SHOW_METRIC_COLUMNS_STORAGE_KEY = + 'securitySolution.ruleDetails.ruleExecutionLog.showMetrics.v8.2'; diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/common/rule_monitoring.ts b/x-pack/plugins/security_solution/common/detection_engine/schemas/common/rule_monitoring.ts index 6fd792c44ae96..19369ca32f415 100644 --- a/x-pack/plugins/security_solution/common/detection_engine/schemas/common/rule_monitoring.ts +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/common/rule_monitoring.ts @@ -106,3 +106,31 @@ export const ruleExecutionEvent = t.type({ }); export type RuleExecutionEvent = t.TypeOf; + +// ------------------------------------------------------------------------------------------------- +// Aggregate Rule execution events + +export const aggregateRuleExecutionEvent = t.type({ + execution_uuid: t.string, + timestamp: IsoDateString, + duration_ms: t.number, + status: t.string, + message: t.string, + num_active_alerts: t.number, + num_new_alerts: t.number, + num_recovered_alerts: t.number, + num_triggered_actions: t.number, + num_succeeded_actions: t.number, + num_errored_actions: t.number, + total_search_duration_ms: t.number, + es_search_duration_ms: t.number, + schedule_delay_ms: t.number, + timed_out: t.boolean, + indexing_duration_ms: t.number, + search_duration_ms: t.number, + gap_duration_ms: t.number, + security_status: t.string, + security_message: t.string, +}); + +export type AggregateRuleExecutionEvent = t.TypeOf; diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/request/get_rule_execution_events_request.ts b/x-pack/plugins/security_solution/common/detection_engine/schemas/request/get_rule_execution_events_schema.ts similarity index 51% rename from x-pack/plugins/security_solution/common/detection_engine/schemas/request/get_rule_execution_events_request.ts rename to x-pack/plugins/security_solution/common/detection_engine/schemas/request/get_rule_execution_events_schema.ts index 5e0e63ae7330d..798e9abb5adec 100644 --- a/x-pack/plugins/security_solution/common/detection_engine/schemas/request/get_rule_execution_events_request.ts +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/request/get_rule_execution_events_schema.ts @@ -7,12 +7,27 @@ import * as t from 'io-ts'; +import { sortFieldOrUndefined, sortOrderOrUndefined } from '../common'; + export const GetRuleExecutionEventsRequestParams = t.exact( t.type({ ruleId: t.string, }) ); +export const GetRuleExecutionEventsQueryParams = t.exact( + t.type({ + start: t.string, + end: t.string, + query_text: t.union([t.string, t.undefined]), + status_filters: t.union([t.string, t.undefined]), + per_page: t.union([t.string, t.undefined]), + page: t.union([t.string, t.undefined]), + sort_field: sortFieldOrUndefined, + sort_order: sortOrderOrUndefined, + }) +); + export type GetRuleExecutionEventsRequestParams = t.TypeOf< typeof GetRuleExecutionEventsRequestParams >; diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/response/get_rule_execution_events_response.ts b/x-pack/plugins/security_solution/common/detection_engine/schemas/response/get_rule_execution_events_response.ts index 9a732a46cbaba..dd1a8dd9d00ec 100644 --- a/x-pack/plugins/security_solution/common/detection_engine/schemas/response/get_rule_execution_events_response.ts +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/response/get_rule_execution_events_response.ts @@ -6,7 +6,7 @@ */ import * as t from 'io-ts'; -import { ruleExecutionEvent } from '../common'; +import { aggregateRuleExecutionEvent, ruleExecutionEvent } from '../common'; export const GetRuleExecutionEventsResponse = t.exact( t.type({ @@ -15,3 +15,14 @@ export const GetRuleExecutionEventsResponse = t.exact( ); export type GetRuleExecutionEventsResponse = t.TypeOf; + +export const GetAggregateRuleExecutionEventsResponse = t.exact( + t.type({ + events: t.array(aggregateRuleExecutionEvent), + total: t.number, + }) +); + +export type GetAggregateRuleExecutionEventsResponse = t.TypeOf< + typeof GetAggregateRuleExecutionEventsResponse +>; diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/__mocks__/api.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/__mocks__/api.ts index 0922c4b3b78b7..d93d667f5fbca 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/__mocks__/api.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/__mocks__/api.ts @@ -5,9 +5,8 @@ * 2.0. */ -import { RuleExecutionStatus } from '../../../../../../common/detection_engine/schemas/common'; import { - GetRuleExecutionEventsResponse, + GetAggregateRuleExecutionEventsResponse, RulesSchema, } from '../../../../../../common/detection_engine/schemas/response'; @@ -62,19 +61,44 @@ export const fetchRules = async (_: FetchRulesProps): Promise => { +}): Promise => { return Promise.resolve({ events: [ { - date: '2021-12-29T10:42:59.996Z', - status: RuleExecutionStatus.succeeded, - message: 'Rule executed successfully', + duration_ms: 3866, + es_search_duration_ms: 1236, + execution_uuid: '88d15095-7937-462c-8f21-9763e1387cad', + gap_duration_ms: 0, + indexing_duration_ms: 95, + message: + "rule executed: siem.queryRule:fb1fc150-a292-11ec-a2cf-c1b28b0392b0: 'Lots of Execution Events'", + num_active_alerts: 0, + num_errored_actions: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_succeeded_actions: 1, + num_triggered_actions: 1, + schedule_delay_ms: -127535, + search_duration_ms: 1255, + security_message: 'succeeded', + security_status: 'succeeded', + status: 'success', + timed_out: false, + timestamp: '2022-03-13T06:04:05.838Z', + total_search_duration_ms: 0, }, ], + total: 1, }); }; diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts index ecfa98bfa3076..16613d7cb4d0f 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts @@ -595,19 +595,43 @@ describe('Detections Rules API', () => { }); test('calls API with correct parameters', async () => { - await fetchRuleExecutionEvents({ ruleId: '42', signal: abortCtrl.signal }); + await fetchRuleExecutionEvents({ + ruleId: '42', + start: '2001-01-01T17:00:00.000Z', + end: '2001-01-02T17:00:00.000Z', + queryText: '', + statusFilters: '', + signal: abortCtrl.signal, + }); expect(fetchMock).toHaveBeenCalledWith( '/internal/detection_engine/rules/42/execution/events', { method: 'GET', + query: { + end: '2001-01-02T17:00:00.000Z', + page: undefined, + per_page: undefined, + query_text: '', + sort_field: undefined, + sort_order: undefined, + start: '2001-01-01T17:00:00.000Z', + status_filters: '', + }, signal: abortCtrl.signal, } ); }); test('returns API response as is', async () => { - const response = await fetchRuleExecutionEvents({ ruleId: '42', signal: abortCtrl.signal }); + const response = await fetchRuleExecutionEvents({ + ruleId: '42', + start: 'now-30', + end: 'now', + queryText: '', + statusFilters: '', + signal: abortCtrl.signal, + }); expect(response).toEqual(responseMock); }); }); diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.ts index 5b29671d05bac..5006d6390f45a 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.ts @@ -6,6 +6,7 @@ */ import { camelCase } from 'lodash'; +import dateMath from '@elastic/datemath'; import { HttpStart } from 'src/core/public'; import { @@ -24,7 +25,7 @@ import { } from '../../../../../common/detection_engine/schemas/request'; import { RulesSchema, - GetRuleExecutionEventsResponse, + GetAggregateRuleExecutionEventsResponse, } from '../../../../../common/detection_engine/schemas/response'; import { @@ -315,21 +316,57 @@ export const exportRules = async ({ /** * Fetch rule execution events (e.g. status changes) from Event Log. * - * @param ruleId string Saved Object ID of the rule (`rule.id`, not static `rule.rule_id`) + * @param ruleId Saved Object ID of the rule (`rule.id`, not static `rule.rule_id`) + * @param start Start daterange either in UTC ISO8601 or as datemath string (e.g. `2021-12-29T02:44:41.653Z` or `now-30`) + * @param end End daterange either in UTC ISO8601 or as datemath string (e.g. `2021-12-29T02:44:41.653Z` or `now/w`) + * @param queryText search string in querystring format (e.g. `event.duration > 1000 OR kibana.alert.rule.execution.metrics.execution_gap_duration_s > 100`) + * @param statusFilters comma separated string of `statusFilters` (e.g. `succeeded,failed,partial failure`) + * @param page current page to fetch + * @param perPage number of results to fetch per page + * @param sortField field to sort by + * @param sortOrder what order to sort by (e.g. `asc` or `desc`) * @param signal AbortSignal Optional signal for cancelling the request * * @throws An error if response is not OK */ export const fetchRuleExecutionEvents = async ({ ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, signal, }: { ruleId: string; + start: string; + end: string; + queryText?: string; + statusFilters?: string; + page?: number; + perPage?: number; + sortField?: string; + sortOrder?: string; signal?: AbortSignal; -}): Promise => { +}): Promise => { const url = detectionEngineRuleExecutionEventsUrl(ruleId); - return KibanaServices.get().http.fetch(url, { + const startDate = dateMath.parse(start); + const endDate = dateMath.parse(end, { roundUp: true }); + return KibanaServices.get().http.fetch(url, { method: 'GET', + query: { + start: startDate?.utc().toISOString(), + end: endDate?.utc().toISOString(), + query_text: queryText?.trim(), + status_filters: statusFilters?.trim(), + page, + per_page: perPage, + sort_field: sortField, + sort_order: sortOrder, + }, signal, }); }; diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/translations.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/translations.ts index 86107a4019b0a..5d2bac9e8b501 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/translations.ts @@ -14,6 +14,13 @@ export const RULE_AND_TIMELINE_FETCH_FAILURE = i18n.translate( } ); +export const RULE_EXECUTION_FETCH_FAILURE = i18n.translate( + 'xpack.securitySolution.containers.detectionEngine.ruleExecutionLogFailureDescription', + { + defaultMessage: 'Failed to fetch Rule Execution Events', + } +); + export const RULE_ADD_FAILURE = i18n.translate( 'xpack.securitySolution.containers.detectionEngine.addRuleFailDescription', { diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.test.tsx b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.test.tsx index 4a98110153830..2a4efb7f69491 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.test.tsx @@ -12,7 +12,6 @@ import React from 'react'; import { QueryClient, QueryClientProvider } from 'react-query'; import { renderHook, cleanup } from '@testing-library/react-hooks'; -import { RuleExecutionStatus } from '../../../../../common/detection_engine/schemas/common'; import { useRuleExecutionEvents } from './use_rule_execution_events'; import * as api from './api'; @@ -45,9 +44,19 @@ describe('useRuleExecutionEvents', () => { }; const render = () => - renderHook(() => useRuleExecutionEvents(SOME_RULE_ID), { - wrapper: createReactQueryWrapper(), - }); + renderHook( + () => + useRuleExecutionEvents({ + ruleId: SOME_RULE_ID, + start: 'now-30', + end: 'now', + queryText: '', + statusFilters: '', + }), + { + wrapper: createReactQueryWrapper(), + } + ); it('calls the API via fetchRuleExecutionEvents', async () => { const fetchRuleExecutionEvents = jest.spyOn(api, 'fetchRuleExecutionEvents'); @@ -77,13 +86,34 @@ describe('useRuleExecutionEvents', () => { expect(result.current.isLoading).toEqual(false); expect(result.current.isSuccess).toEqual(true); expect(result.current.isError).toEqual(false); - expect(result.current.data).toEqual([ - { - date: '2021-12-29T10:42:59.996Z', - status: RuleExecutionStatus.succeeded, - message: 'Rule executed successfully', - }, - ]); + expect(result.current.data).toEqual({ + events: [ + { + duration_ms: 3866, + es_search_duration_ms: 1236, + execution_uuid: '88d15095-7937-462c-8f21-9763e1387cad', + gap_duration_ms: 0, + indexing_duration_ms: 95, + message: + "rule executed: siem.queryRule:fb1fc150-a292-11ec-a2cf-c1b28b0392b0: 'Lots of Execution Events'", + num_active_alerts: 0, + num_errored_actions: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_succeeded_actions: 1, + num_triggered_actions: 1, + schedule_delay_ms: -127535, + search_duration_ms: 1255, + security_message: 'succeeded', + security_status: 'succeeded', + status: 'success', + timed_out: false, + timestamp: '2022-03-13T06:04:05.838Z', + total_search_duration_ms: 0, + }, + ], + total: 1, + }); }); it('handles exceptions from the API', async () => { diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.tsx b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.tsx index 58f4c524dc362..33b965cab979f 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.tsx +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/use_rule_execution_events.tsx @@ -6,18 +6,62 @@ */ import { useQuery } from 'react-query'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response'; import { useAppToasts } from '../../../../common/hooks/use_app_toasts'; import { fetchRuleExecutionEvents } from './api'; import * as i18n from './translations'; -export const useRuleExecutionEvents = (ruleId: string) => { +interface UseRuleExecutionEventsArgs { + ruleId: string; + start: string; + end: string; + queryText?: string; + statusFilters?: string; + page?: number; + perPage?: number; + sortField?: string; + sortOrder?: string; +} + +export const useRuleExecutionEvents = ({ + ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, +}: UseRuleExecutionEventsArgs) => { const { addError } = useAppToasts(); - return useQuery( - ['ruleExecutionEvents', ruleId], + return useQuery( + [ + 'ruleExecutionEvents', + ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, + ], async ({ signal }) => { - const response = await fetchRuleExecutionEvents({ ruleId, signal }); - return response.events; + return fetchRuleExecutionEvents({ + ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, + signal, + }); }, { onError: (e) => { diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/popover_tooltip.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/popover_tooltip.tsx index 22bad4fffade9..564f73c379c63 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/popover_tooltip.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/popover_tooltip.tsx @@ -30,7 +30,10 @@ const PopoverTooltipComponent = ({ columnName, children }: PopoverTooltipProps) button={ setIsPopoverOpen(!isPopoverOpen)} + onClick={(event: React.MouseEvent) => { + setIsPopoverOpen(!isPopoverOpen); + event.stopPropagation(); + }} size="xs" color="primary" iconType="questionInCircle" diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/use_columns.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/use_columns.tsx index 5882cc9a72d9a..a6891af1cc7da 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/use_columns.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/use_columns.tsx @@ -346,7 +346,7 @@ export const useMonitoringColumns = ({ hasPermissions }: ColumnsProps): TableCol href={`${docLinks.links.siem.troubleshootGaps}`} target="_blank" > - {'see documentation'} + {i18n.COLUMN_GAP_TOOLTIP_SEE_DOCUMENTATION} ), }} diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_search_bar.test.tsx.snap b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_search_bar.test.tsx.snap new file mode 100644 index 0000000000000..a4e8e2cf6e9bd --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_search_bar.test.tsx.snap @@ -0,0 +1,78 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`ExecutionLogSearchBar snapshots renders correctly against snapshot 1`] = ` + + + + + + Status + + } + closePopover={[Function]} + display="inlineBlock" + hasArrow={true} + isOpen={false} + ownFocus={true} + panelPaddingSize="none" + repositionOnScroll={true} + > + + + Succeeded + + + + + Failed + + + + + Partial failure + + + + + + +`; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_table.test.tsx.snap b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_table.test.tsx.snap new file mode 100644 index 0000000000000..fdec953b833e6 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/execution_log_table.test.tsx.snap @@ -0,0 +1,210 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`ExecutionLogTable snapshots renders correctly against snapshot 1`] = ` + + + + + + + + + + + + + + + Showing 0 rule executions + + + + + + + + + , + "render": [Function], + "sortable": false, + "truncateText": false, + "width": "10%", + }, + Object { + "field": "timestamp", + "name": , + "render": [Function], + "sortable": true, + "truncateText": false, + "width": "15%", + }, + Object { + "field": "duration_ms", + "name": , + "render": [Function], + "sortable": true, + "truncateText": false, + "width": "10%", + }, + Object { + "field": "security_message", + "name": , + "render": [Function], + "sortable": false, + "truncateText": false, + "width": "35%", + }, + Object { + "actions": Array [ + Object { + "data-test-subj": "action-filter-by-execution-id", + "description": "Filter alerts by rule execution ID.", + "field": "", + "icon": "filter", + "isPrimary": true, + "name": "Edit", + "onClick": [Function], + "type": "icon", + }, + ], + "field": "kibana.alert.rule.execution.uuid", + "name": "Actions", + "width": "5%", + }, + ] + } + items={Array []} + noItemsMessage={ + + } + onChange={[Function]} + pagination={ + Object { + "pageIndex": 0, + "pageSize": 5, + "pageSizeOptions": Array [ + 5, + 10, + 25, + 50, + ], + "totalItemCount": 0, + } + } + responsive={true} + sorting={ + Object { + "sort": Object { + "direction": "desc", + "field": "timestamp", + }, + } + } + tableLayout="fixed" + /> + +`; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/rule_duration_format.test.tsx.snap b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/rule_duration_format.test.tsx.snap new file mode 100644 index 0000000000000..ddb59cf52a890 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/__snapshots__/rule_duration_format.test.tsx.snap @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`RuleDurationFormat snapshots renders correctly against snapshot 1`] = ` + + 00:00:00:000 + +`; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_columns.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_columns.tsx new file mode 100644 index 0000000000000..5242b6dbe0313 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_columns.tsx @@ -0,0 +1,171 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { EuiBasicTableColumn, EuiHealth, EuiLink, EuiText } from '@elastic/eui'; +import { capitalize } from 'lodash'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { DocLinksStart } from 'kibana/public'; +import React from 'react'; +import { + AggregateRuleExecutionEvent, + RuleExecutionStatus, +} from '../../../../../../../common/detection_engine/schemas/common'; +import { getEmptyTagValue, getEmptyValue } from '../../../../../../common/components/empty_value'; +import { FormattedDate } from '../../../../../../common/components/formatted_date'; +import { getStatusColor } from '../../../../../components/rules/rule_execution_status/utils'; +import { PopoverTooltip } from '../../all/popover_tooltip'; +import { TableHeaderTooltipCell } from '../../all/table_header_tooltip_cell'; + +import * as i18n from './translations'; +import { RuleDurationFormat } from './rule_duration_format'; + +export const EXECUTION_LOG_COLUMNS: Array> = [ + { + name: ( + + ), + field: 'security_status', + render: (value: RuleExecutionStatus, data) => + value ? ( + {capitalize(value)} + ) : ( + getEmptyTagValue() + ), + sortable: false, + truncateText: false, + width: '10%', + }, + { + field: 'timestamp', + name: ( + + ), + render: (value: string) => , + sortable: true, + truncateText: false, + width: '15%', + }, + { + field: 'duration_ms', + name: ( + + ), + render: (value: number) => ( + <>{value ? : getEmptyValue()} + ), + sortable: true, + truncateText: false, + width: '10%', + }, + { + field: 'security_message', + name: ( + + ), + render: (value: string) => <>{value}, + sortable: false, + truncateText: false, + width: '35%', + }, +]; + +export const GET_EXECUTION_LOG_METRICS_COLUMNS = ( + docLinks: DocLinksStart +): Array> => [ + { + field: 'gap_duration_ms', + name: ( + + + +

+ + {i18n.COLUMN_GAP_TOOLTIP_SEE_DOCUMENTATION} + + ), + }} + /> +

+
+
+
+ } + /> + ), + render: (value: number) => ( + <>{value ? : getEmptyValue()} + ), + sortable: true, + truncateText: false, + width: '10%', + }, + { + field: 'indexing_duration_ms', + name: ( + + ), + render: (value: number) => ( + <>{value ? : getEmptyValue()} + ), + sortable: true, + truncateText: false, + width: '10%', + }, + { + field: 'search_duration_ms', + name: ( + + ), + render: (value: number) => ( + <>{value ? : getEmptyValue()} + ), + sortable: true, + truncateText: false, + width: '10%', + }, + { + field: 'schedule_delay_ms', + name: ( + + ), + render: (value: number) => ( + <>{value ? : getEmptyValue()} + ), + sortable: true, + truncateText: false, + width: '10%', + }, +]; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.test.tsx new file mode 100644 index 0000000000000..cfa5322769940 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.test.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { shallow } from 'enzyme'; +import React from 'react'; +import { ExecutionLogSearchBar } from './execution_log_search_bar'; +import { noop } from 'lodash/fp'; + +// TODO: Replace snapshot test with base test cases + +describe('ExecutionLogSearchBar', () => { + describe('snapshots', () => { + test('renders correctly against snapshot', () => { + const wrapper = shallow( + + ); + expect(wrapper).toMatchSnapshot(); + }); + }); +}); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.tsx new file mode 100644 index 0000000000000..2c0b18828dcbc --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_search_bar.tsx @@ -0,0 +1,147 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useCallback, useEffect, useMemo, useState } from 'react'; +import { capitalize, replace } from 'lodash'; +import { + EuiHealth, + EuiFieldSearch, + EuiFlexGroup, + EuiFlexItem, + EuiPopover, + EuiFilterGroup, + EuiFilterButton, + EuiFilterSelectItem, +} from '@elastic/eui'; +import { RuleExecutionStatus } from '../../../../../../../common/detection_engine/schemas/common'; +import { getStatusColor } from '../../../../../components/rules/rule_execution_status/utils'; +import * as i18n from './translations'; + +export const EXECUTION_LOG_SCHEMA_MAPPING = { + status: 'kibana.alert.rule.execution.status', + timestamp: '@timestamp', + duration: 'event.duration', + message: 'message', + gapDuration: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + indexDuration: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + searchDuration: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + totalActions: 'kibana.alert.rule.execution.metrics.number_of_triggered_actions', + schedulingDelay: 'kibana.task.schedule_delay', +}; + +export const replaceQueryTextAliases = (queryText: string): string => { + return Object.entries(EXECUTION_LOG_SCHEMA_MAPPING).reduce( + (updatedQuery, [key, value]) => { + return replace(updatedQuery, key, value); + }, + queryText + ); +}; + +const statuses = [ + RuleExecutionStatus.succeeded, + RuleExecutionStatus.failed, + RuleExecutionStatus['partial failure'], +]; + +const statusFilters = statuses.map((status) => ({ + label: {capitalize(status)}, + selected: false, +})); + +interface ExecutionLogTableSearchProps { + onlyShowFilters: true; + onSearch: (queryText: string) => void; + onStatusFilterChange: (statusFilters: string[]) => void; +} + +export const ExecutionLogSearchBar = React.memo( + ({ onlyShowFilters, onSearch, onStatusFilterChange }) => { + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + const [selectedFilters, setSelectedFilters] = useState([]); + + const onSearchCallback = useCallback( + (queryText: string) => { + onSearch(replaceQueryTextAliases(queryText)); + }, + [onSearch] + ); + + const onStatusFilterChangeCallback = useCallback( + (filter: RuleExecutionStatus) => { + setSelectedFilters( + selectedFilters.includes(filter) + ? selectedFilters.filter((f) => f !== filter) + : [...selectedFilters, filter] + ); + }, + [selectedFilters] + ); + + const filtersComponent = useMemo(() => { + return statuses.map((filter, index) => ( + onStatusFilterChangeCallback(filter)} + title={filter} + > + {capitalize(filter)} + + )); + }, [onStatusFilterChangeCallback, selectedFilters]); + + useEffect(() => { + onStatusFilterChange(selectedFilters); + }, [onStatusFilterChange, selectedFilters]); + + return ( + + + {!onlyShowFilters && ( + + )} + + + + setIsPopoverOpen(!isPopoverOpen)} + numFilters={statusFilters.length} + isSelected={isPopoverOpen} + hasActiveFilters={selectedFilters.length > 0} + numActiveFilters={selectedFilters.length} + > + {i18n.COLUMN_STATUS} + + } + isOpen={isPopoverOpen} + closePopover={() => setIsPopoverOpen(false)} + panelPaddingSize="none" + repositionOnScroll + > + {filtersComponent} + + + + + ); + } +); + +ExecutionLogSearchBar.displayName = 'ExecutionLogSearchBar'; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.test.tsx new file mode 100644 index 0000000000000..8a3bb8621f7ae --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.test.tsx @@ -0,0 +1,103 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { shallow } from 'enzyme'; +import { noop } from 'lodash/fp'; + +import { useSourcererDataView } from '../../../../../../common/containers/sourcerer'; +import { ExecutionLogTable } from './execution_log_table'; + +jest.mock('../../../../../containers/detection_engine/rules', () => { + const original = jest.requireActual('../../../../../containers/detection_engine/rules'); + return { + ...original, + useRuleExecutionEvents: jest.fn().mockReturnValue({ + loading: true, + setQuery: () => undefined, + data: null, + response: '', + request: '', + refetch: null, + }), + }; +}); + +jest.mock('../../../../../../common/containers/sourcerer'); + +jest.mock('../../../../../../common/hooks/use_app_toasts', () => { + const original = jest.requireActual('../../../../../../common/hooks/use_app_toasts'); + + return { + ...original, + useAppToasts: () => ({ + addSuccess: jest.fn(), + addError: jest.fn(), + }), + }; +}); + +jest.mock('react-redux', () => { + const original = jest.requireActual('react-redux'); + return { + ...original, + useDispatch: () => jest.fn(), + useSelector: () => jest.fn(), + }; +}); + +jest.mock('../../../../../../common/lib/kibana', () => { + const original = jest.requireActual('../../../../../../common/lib/kibana'); + + return { + ...original, + useUiSetting$: jest.fn().mockReturnValue([]), + useKibana: () => ({ + services: { + data: { + query: { + filterManager: jest.fn().mockReturnValue({}), + }, + }, + docLinks: { + links: { + siem: { + troubleshootGaps: 'link', + }, + }, + }, + storage: { + get: jest.fn(), + set: jest.fn(), + }, + timelines: { + getLastUpdated: jest.fn(), + getFieldBrowser: jest.fn(), + }, + }, + }), + }; +}); + +const mockUseSourcererDataView = useSourcererDataView as jest.Mock; +mockUseSourcererDataView.mockReturnValue({ + missingPatterns: {}, + selectedPatterns: {}, + scopeSelectedPatterns: {}, + loading: false, +}); + +// TODO: Replace snapshot test with base test cases + +describe('ExecutionLogTable', () => { + describe('snapshots', () => { + test('renders correctly against snapshot', () => { + const wrapper = shallow(); + expect(wrapper).toMatchSnapshot(); + }); + }); +}); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx new file mode 100644 index 0000000000000..212ac9ec5b94f --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx @@ -0,0 +1,325 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { SortOrder } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { DurationRange } from '@elastic/eui/src/components/date_picker/types'; +import { get } from 'lodash'; +import styled from 'styled-components'; +import React, { useCallback, useMemo, useState } from 'react'; +import { + EuiTextColor, + EuiFlexGroup, + EuiFlexItem, + EuiSuperDatePicker, + OnTimeChangeProps, + OnRefreshProps, + OnRefreshChangeProps, + EuiSpacer, + EuiSwitch, + EuiBasicTable, +} from '@elastic/eui'; +import { buildFilter, FILTERS } from '@kbn/es-query'; +import { MAX_EXECUTION_EVENTS_DISPLAYED } from '@kbn/securitysolution-rules'; +import { RULE_DETAILS_EXECUTION_LOG_TABLE_SHOW_METRIC_COLUMNS_STORAGE_KEY } from '../../../../../../../common/constants'; +import { AggregateRuleExecutionEvent } from '../../../../../../../common/detection_engine/schemas/common'; + +import { + UtilityBar, + UtilityBarGroup, + UtilityBarSection, + UtilityBarText, +} from '../../../../../../common/components/utility_bar'; +import { useSourcererDataView } from '../../../../../../common/containers/sourcerer'; +import { useAppToasts } from '../../../../../../common/hooks/use_app_toasts'; +import { useKibana } from '../../../../../../common/lib/kibana'; +import { SourcererScopeName } from '../../../../../../common/store/sourcerer/model'; +import { useRuleExecutionEvents } from '../../../../../containers/detection_engine/rules'; +import * as i18n from './translations'; +import { EXECUTION_LOG_COLUMNS, GET_EXECUTION_LOG_METRICS_COLUMNS } from './execution_log_columns'; +import { ExecutionLogSearchBar } from './execution_log_search_bar'; + +const EXECUTION_UUID_FIELD_NAME = 'kibana.alert.rule.execution.uuid'; + +const UtilitySwitch = styled(EuiSwitch)` + margin-left: 17px; +`; + +interface ExecutionLogTableProps { + ruleId: string; + selectAlertsTab: () => void; +} + +const ExecutionLogTableComponent: React.FC = ({ + ruleId, + selectAlertsTab, +}) => { + const { + docLinks, + data: { + query: { filterManager }, + }, + storage, + timelines, + } = useKibana().services; + // Datepicker state + const [recentlyUsedRanges, setRecentlyUsedRanges] = useState([]); + const [refreshInterval, setRefreshInterval] = useState(1000); + const [isPaused, setIsPaused] = useState(true); + const [start, setStart] = useState('now-24h'); + const [end, setEnd] = useState('now'); + + // Searchbar/Filter/Settings state + const [queryText, setQueryText] = useState(''); + const [statusFilters, setStatusFilters] = useState(''); + const [showMetricColumns, setShowMetricColumns] = useState( + storage.get(RULE_DETAILS_EXECUTION_LOG_TABLE_SHOW_METRIC_COLUMNS_STORAGE_KEY) ?? false + ); + + // Pagination state + const [pageIndex, setPageIndex] = useState(0); + const [pageSize, setPageSize] = useState(5); + const [sortField, setSortField] = useState('timestamp'); + const [sortDirection, setSortDirection] = useState('desc'); + // Index for `add filter` action and toasts for errors + const { indexPattern } = useSourcererDataView(SourcererScopeName.detections); + const { addError } = useAppToasts(); + + // Table data state + const { + data: events, + dataUpdatedAt, + isFetching, + isLoading, + refetch, + } = useRuleExecutionEvents({ + ruleId, + start, + end, + queryText, + statusFilters, + page: pageIndex, + perPage: pageSize, + sortField, + sortOrder: sortDirection, + }); + const items = events?.events ?? []; + const maxEvents = events?.total ?? 0; + + // Callbacks + const onTableChangeCallback = useCallback(({ page = {}, sort = {} }) => { + const { index, size } = page; + const { field, direction } = sort; + + setPageIndex(index); + setPageSize(size); + setSortField(field); + setSortDirection(direction); + }, []); + + const onTimeChangeCallback = useCallback( + (props: OnTimeChangeProps) => { + const recentlyUsedRange = recentlyUsedRanges.filter((range) => { + const isDuplicate = range.start === props.start && range.end === props.end; + return !isDuplicate; + }); + recentlyUsedRange.unshift({ start: props.start, end: props.end }); + setStart(props.start); + setEnd(props.end); + setRecentlyUsedRanges( + recentlyUsedRange.length > 10 ? recentlyUsedRange.slice(0, 9) : recentlyUsedRange + ); + }, + [recentlyUsedRanges] + ); + + const onRefreshChangeCallback = useCallback((props: OnRefreshChangeProps) => { + setIsPaused(props.isPaused); + setRefreshInterval(props.refreshInterval); + }, []); + + const onRefreshCallback = useCallback( + (props: OnRefreshProps) => { + refetch(); + }, + [refetch] + ); + + const onSearchCallback = useCallback((updatedQueryText: string) => { + setQueryText(updatedQueryText); + }, []); + + const onStatusFilterChangeCallback = useCallback((updatedStatusFilters: string[]) => { + setStatusFilters(updatedStatusFilters.sort().join(',')); + }, []); + + const onFilterByExecutionIdCallback = useCallback( + (executionId: string) => { + const field = indexPattern.fields.find((f) => f.name === EXECUTION_UUID_FIELD_NAME); + if (field != null) { + const filter = buildFilter( + indexPattern, + field, + FILTERS.PHRASE, + false, + false, + executionId, + null + ); + filterManager.addFilters(filter); + selectAlertsTab(); + } else { + addError(i18n.ACTIONS_FIELD_NOT_FOUND_ERROR, { + title: i18n.ACTIONS_FIELD_NOT_FOUND_ERROR_TITLE, + }); + } + }, + [addError, filterManager, indexPattern, selectAlertsTab] + ); + + const onShowMetricColumnsCallback = useCallback( + (showMetrics: boolean) => { + storage.set(RULE_DETAILS_EXECUTION_LOG_TABLE_SHOW_METRIC_COLUMNS_STORAGE_KEY, showMetrics); + setShowMetricColumns(showMetrics); + }, + [storage] + ); + + // Memoized state + const pagination = useMemo(() => { + return { + pageIndex, + pageSize, + totalItemCount: + maxEvents > MAX_EXECUTION_EVENTS_DISPLAYED ? MAX_EXECUTION_EVENTS_DISPLAYED : maxEvents, + pageSizeOptions: [5, 10, 25, 50], + }; + }, [maxEvents, pageIndex, pageSize]); + + const sorting = useMemo(() => { + return { + sort: { + field: sortField, + direction: sortDirection, + }, + }; + }, [sortDirection, sortField]); + + const actions = useMemo( + () => [ + { + field: EXECUTION_UUID_FIELD_NAME, + name: i18n.COLUMN_ACTIONS, + width: '5%', + actions: [ + { + name: 'Edit', + isPrimary: true, + field: '', + description: i18n.COLUMN_ACTIONS_TOOLTIP, + icon: 'filter', + type: 'icon', + onClick: (value: object) => { + const executionId = get(value, EXECUTION_UUID_FIELD_NAME); + if (executionId) { + onFilterByExecutionIdCallback(executionId); + } + }, + 'data-test-subj': 'action-filter-by-execution-id', + }, + ], + }, + ], + [onFilterByExecutionIdCallback] + ); + + const executionLogColumns = useMemo( + () => + showMetricColumns + ? [...EXECUTION_LOG_COLUMNS, ...GET_EXECUTION_LOG_METRICS_COLUMNS(docLinks), ...actions] + : [...EXECUTION_LOG_COLUMNS, ...actions], + [actions, docLinks, showMetricColumns] + ); + + return ( + <> + + + + + + + + + + + + + + {i18n.SHOWING_EXECUTIONS( + maxEvents > MAX_EXECUTION_EVENTS_DISPLAYED + ? MAX_EXECUTION_EVENTS_DISPLAYED + : maxEvents + )} + + + {maxEvents > MAX_EXECUTION_EVENTS_DISPLAYED && ( + + + + {i18n.RULE_EXECUTION_LOG_SEARCH_LIMIT_EXCEEDED( + maxEvents, + MAX_EXECUTION_EVENTS_DISPLAYED + )} + + + + )} + + + + {timelines.getLastUpdated({ + showUpdating: isLoading || isFetching, + updatedAt: dataUpdatedAt, + })} + + onShowMetricColumnsCallback(e.target.checked)} + /> + + + + + ); +}; + +export const ExecutionLogTable = React.memo(ExecutionLogTableComponent); +ExecutionLogTable.displayName = 'ExecutionLogTable'; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.test.tsx new file mode 100644 index 0000000000000..44f765f934ae8 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.test.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { shallow } from 'enzyme'; +import React from 'react'; +import { RuleDurationFormat } from './rule_duration_format'; + +// TODO: Replace snapshot test with base test cases + +describe('RuleDurationFormat', () => { + describe('snapshots', () => { + test('renders correctly against snapshot', () => { + const wrapper = shallow(); + expect(wrapper).toMatchSnapshot(); + }); + }); +}); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.tsx new file mode 100644 index 0000000000000..cdbc19ce16c3b --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/rule_duration_format.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import numeral from '@elastic/numeral'; +import moment from 'moment'; +import React, { useMemo } from 'react'; + +interface Props { + duration: number; + isMillis?: boolean; + allowZero?: boolean; +} + +export function getFormattedDuration(value: number) { + if (!value) { + return '00:00:00:000'; + } + const duration = moment.duration(value); + const hours = Math.floor(duration.asHours()).toString().padStart(2, '0'); + const minutes = Math.floor(duration.asMinutes()).toString().padStart(2, '0'); + const seconds = duration.seconds().toString().padStart(2, '0'); + const ms = duration.milliseconds().toString().padStart(3, '0'); + return `${hours}:${minutes}:${seconds}:${ms}`; +} + +export function getFormattedMilliseconds(value: number) { + const formatted = numeral(value).format('0,0'); + return `${formatted} ms`; +} + +/** + * Formats duration as (hh:mm:ss:SSS) + * @param props duration default as nanos, set isMillis:true to pass in ms + * @constructor + */ +const RuleDurationFormatComponent = (props: Props) => { + const { duration, isMillis = false, allowZero = true } = props; + + const formattedDuration = useMemo(() => { + // Durations can be buggy and return negative + if (allowZero && duration >= 0) { + return getFormattedDuration(isMillis ? duration * 1000 : duration); + } + return 'N/A'; + }, [allowZero, duration, isMillis]); + + return {formattedDuration}; +}; + +export const RuleDurationFormat = React.memo(RuleDurationFormatComponent); +RuleDurationFormat.displayName = 'RuleDurationFormat'; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/translations.ts new file mode 100644 index 0000000000000..97ae8e42ebb61 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/translations.ts @@ -0,0 +1,182 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { i18n } from '@kbn/i18n'; + +export const SHOWING_EXECUTIONS = (totalItems: number) => + i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.totalExecutionsLabel', + { + values: { totalItems }, + defaultMessage: + 'Showing {totalItems} {totalItems, plural, =1 {rule execution} other {rule executions}}', + } + ); + +export const RULE_EXECUTION_LOG_SEARCH_LIMIT_EXCEEDED = (totalItems: number, maxItems: number) => + i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.searchLimitExceededLabel', + { + values: { totalItems, maxItems }, + defaultMessage: + "More than {totalItems} rule executions match filters provided. Showing first {maxItems} by most recent '@timestamp'. Constrain filters further to view additional execution events.", + } + ); + +export const RULE_EXECUTION_LOG_SEARCH_PLACEHOLDER = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.searchPlaceholder', + { + defaultMessage: 'duration > 100 and gapDuration > 10', + } +); + +export const RULE_EXECUTION_LOG_SHOW_METRIC_COLUMNS_SWITCH = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.showMetricColumnsSwitchTitle', + { + defaultMessage: 'Show metrics columns', + } +); + +export const COLUMN_STATUS = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.statusColumn', + { + defaultMessage: 'Status', + } +); + +export const COLUMN_STATUS_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.statusColumnTooltip', + { + defaultMessage: 'Overall status of execution.', + } +); + +export const COLUMN_TIMESTAMP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.timestampColumn', + { + defaultMessage: 'Timestamp', + } +); + +export const COLUMN_TIMESTAMP_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.timestampColumnTooltip', + { + defaultMessage: 'Datetime rule execution initiated.', + } +); + +export const COLUMN_DURATION = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.durationColumn', + { + defaultMessage: 'Duration', + } +); + +export const COLUMN_DURATION_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.durationColumnTooltip', + { + defaultMessage: 'The length of time it took for the rule to run (hh:mm:ss:SSS).', + } +); + +export const COLUMN_MESSAGE = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.messageColumn', + { + defaultMessage: 'Message', + } +); + +export const COLUMN_MESSAGE_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.messageColumnTooltip', + { + defaultMessage: 'Relevant message from execution outcome.', + } +); + +export const COLUMN_GAP_DURATION = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.gapDurationColumn', + { + defaultMessage: 'Gap Duration', + } +); + +export const COLUMN_GAP_TOOLTIP_SEE_DOCUMENTATION = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.gapTooltipSeeDocsDescription', + { + defaultMessage: 'see documentation', + } +); + +export const COLUMN_INDEX_DURATION = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.indexDurationColumn', + { + defaultMessage: 'Index Duration', + } +); + +export const COLUMN_INDEX_DURATION_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.indexDurationColumnTooltip', + { + defaultMessage: 'The length of time it took to index detected alerts (hh:mm:ss:SSS).', + } +); + +export const COLUMN_SEARCH_DURATION = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.searchDurationColumn', + { + defaultMessage: 'Search Duration', + } +); + +export const COLUMN_SEARCH_DURATION_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.searchDurationColumnTooltip', + { + defaultMessage: 'The length of time it took to search for alerts (hh:mm:ss:SSS).', + } +); + +export const COLUMN_SCHEDULING_DELAY = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.schedulingDelayColumn', + { + defaultMessage: 'Scheduling Delay', + } +); + +export const COLUMN_SCHEDULING_DELAY_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.schedulingDelayColumnTooltip', + { + defaultMessage: 'The length of time from rule scheduled till rule executed (hh:mm:ss:SSS).', + } +); + +export const COLUMN_ACTIONS = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.actionsColumn', + { + defaultMessage: 'Actions', + } +); + +export const COLUMN_ACTIONS_TOOLTIP = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.actionsColumnTooltip', + { + defaultMessage: 'Filter alerts by rule execution ID.', + } +); + +export const ACTIONS_FIELD_NOT_FOUND_ERROR_TITLE = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.actionFieldNotFoundErrorTitle', + { + defaultMessage: 'Unable to filter alerts', + } +); + +export const ACTIONS_FIELD_NOT_FOUND_ERROR = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLog.actionFieldNotFoundErrorDescription', + { + defaultMessage: "Cannot find field 'kibana.alert.rule.execution.uuid' in alerts index.", + } +); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/failure_history.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/failure_history.tsx deleted file mode 100644 index 05665d7c6b3c2..0000000000000 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/failure_history.tsx +++ /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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import React from 'react'; -import { - EuiBasicTable, - EuiPanel, - EuiLoadingContent, - EuiHealth, - EuiBasicTableColumn, -} from '@elastic/eui'; - -import { RuleExecutionEvent } from '../../../../../../common/detection_engine/schemas/common'; -import { useRuleExecutionEvents } from '../../../../containers/detection_engine/rules'; -import { HeaderSection } from '../../../../../common/components/header_section'; -import * as i18n from './translations'; -import { FormattedDate } from '../../../../../common/components/formatted_date'; - -const columns: Array> = [ - { - name: i18n.COLUMN_STATUS_TYPE, - render: () => {i18n.TYPE_FAILED}, - truncateText: false, - width: '16%', - }, - { - field: 'date', - name: i18n.COLUMN_FAILED_AT, - render: (value: string) => , - sortable: false, - truncateText: false, - width: '24%', - }, - { - field: 'message', - name: i18n.COLUMN_FAILED_MSG, - render: (value: string) => <>{value}, - sortable: false, - truncateText: false, - width: '60%', - }, -]; - -interface FailureHistoryProps { - ruleId: string; -} - -const FailureHistoryComponent: React.FC = ({ ruleId }) => { - const events = useRuleExecutionEvents(ruleId); - const loading = events.isLoading; - const items = events.data ?? []; - - if (loading) { - return ( - - - - - ); - } - - return ( - - - - - ); -}; - -export const FailureHistory = React.memo(FailureHistoryComponent); -FailureHistory.displayName = 'FailureHistory'; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/index.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/index.tsx index 4f91b9208ab6c..791a3fcd0a5b4 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/index.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/index.tsx @@ -104,10 +104,10 @@ import { RuleStatusFailedCallOut, ruleStatusI18n, } from '../../../../components/rules/rule_execution_status'; -import { FailureHistory } from './failure_history'; import * as detectionI18n from '../../translations'; import * as ruleI18n from '../translations'; +import { ExecutionLogTable } from './execution_log_table/execution_log_table'; import * as i18n from './translations'; import { NeedAdminForUpdateRulesCallOut } from '../../../../components/callouts/need_admin_for_update_callout'; import { MissingPrivilegesCallOut } from '../../../../components/callouts/missing_privileges_callout'; @@ -133,7 +133,7 @@ const StyledFullHeightContainer = styled.div` enum RuleDetailTabs { alerts = 'alerts', - failures = 'failures', + executionLogs = 'executionLogs', exceptions = 'exceptions', } @@ -151,10 +151,10 @@ const ruleDetailTabs = [ dataTestSubj: 'exceptionsTab', }, { - id: RuleDetailTabs.failures, - name: i18n.FAILURE_HISTORY_TAB, + id: RuleDetailTabs.executionLogs, + name: i18n.RULE_EXECUTION_LOGS, disabled: false, - dataTestSubj: 'failureHistoryTab', + dataTestSubj: 'executionLogsTab', }, ]; @@ -431,7 +431,7 @@ const RuleDetailsPageComponent: React.FC = ({ setRuleDetailTab(tab.id)} isSelected={tab.id === ruleDetailTab} - disabled={tab.disabled} + disabled={tab.disabled || (tab.id === RuleDetailTabs.executionLogs && !isExistingRule)} key={tab.id} data-test-subj={tab.dataTestSubj} > @@ -440,7 +440,7 @@ const RuleDetailsPageComponent: React.FC = ({ ))} ), - [ruleDetailTab, setRuleDetailTab, pageTabs] + [isExistingRule, ruleDetailTab, setRuleDetailTab, pageTabs] ); const ruleIndices = useMemo(() => rule?.index ?? DEFAULT_INDEX_PATTERN, [rule?.index]); @@ -605,6 +605,10 @@ const RuleDetailsPageComponent: React.FC = ({ [containerElement, onSkipFocusBeforeEventsTable, onSkipFocusAfterEventsTable] ); + const selectAlertsTabCallback = useCallback(() => { + setRuleDetailTab(RuleDetailTabs.alerts); + }, []); + if ( redirectToDetections( isSignalIndexExists, @@ -806,7 +810,9 @@ const RuleDetailsPageComponent: React.FC = ({ onRuleChange={refreshRule} /> )} - {ruleDetailTab === RuleDetailTabs.failures && } + {ruleDetailTab === RuleDetailTabs.executionLogs && ( + + )} diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/translations.ts index 9a51952d17a91..595396e0fd28a 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/translations.ts @@ -42,38 +42,10 @@ export const UNKNOWN = i18n.translate( } ); -export const FAILURE_HISTORY_TAB = i18n.translate( - 'xpack.securitySolution.detectionEngine.ruleDetails.failureHistoryTab', +export const RULE_EXECUTION_LOGS = i18n.translate( + 'xpack.securitySolution.detectionEngine.ruleDetails.ruleExecutionLogsTab', { - defaultMessage: 'Failure History', - } -); - -export const LAST_FIVE_ERRORS = i18n.translate( - 'xpack.securitySolution.detectionEngine.ruleDetails.lastFiveErrorsTitle', - { - defaultMessage: 'Last five errors', - } -); - -export const COLUMN_STATUS_TYPE = i18n.translate( - 'xpack.securitySolution.detectionEngine.ruleDetails.statusTypeColumn', - { - defaultMessage: 'Type', - } -); - -export const COLUMN_FAILED_AT = i18n.translate( - 'xpack.securitySolution.detectionEngine.ruleDetails.statusFailedAtColumn', - { - defaultMessage: 'Failed at', - } -); - -export const COLUMN_FAILED_MSG = i18n.translate( - 'xpack.securitySolution.detectionEngine.ruleDetails.statusFailedMsgColumn', - { - defaultMessage: 'Failed message', + defaultMessage: 'Rule execution logs ', } ); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts index f2f3ef2828e9b..55a564f472c59 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts @@ -584,6 +584,13 @@ export const COLUMN_GAP = i18n.translate( } ); +export const COLUMN_GAP_TOOLTIP_SEE_DOCUMENTATION = i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.columns.gapTooltipSeeDocsDescription', + { + defaultMessage: 'see documentation', + } +); + export const RULES_TAB = i18n.translate( 'xpack.securitySolution.detectionEngine.rules.allRules.tabs.rules', { diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/__mocks__/request_responses.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/__mocks__/request_responses.ts index 9118df4fc413f..0c9418657a4eb 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/__mocks__/request_responses.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/__mocks__/request_responses.ts @@ -25,6 +25,7 @@ import { DETECTION_ENGINE_RULES_BULK_ACTION, DETECTION_ENGINE_RULE_EXECUTION_EVENTS_URL, } from '../../../../../common/constants'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response'; import { RuleAlertType, HapiReadableStream } from '../../rules/types'; import { requestMock } from './request'; import { QuerySignalsSchemaDecoded } from '../../../../../common/detection_engine/schemas/request/query_signals_index_schema'; @@ -242,6 +243,12 @@ export const getRuleExecutionEventsRequest = () => params: { ruleId: '04128c15-0d1b-4716-a4c5-46997ac7f3bd', }, + query: { + start: 'now-30', + end: 'now', + query_text: '', + status_filters: '', + }, }); export const getImportRulesRequest = (hapiStream?: HapiReadableStream) => @@ -552,6 +559,59 @@ export const getLastFailures = (): RuleExecutionEvent[] => [ }, ]; +export const getAggregateExecutionEvents = (): GetAggregateRuleExecutionEventsResponse => ({ + events: [ + { + execution_uuid: '34bab6e0-89b6-4d10-9cbb-cda76d362db6', + timestamp: '2022-03-11T22:04:05.931Z', + duration_ms: 1975, + status: 'success', + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 0, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 538, + schedule_delay_ms: 2091, + timed_out: false, + indexing_duration_ms: 7, + search_duration_ms: 551, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + { + execution_uuid: '254d8400-9dc7-43c5-ad4b-227273d1a44b', + timestamp: '2022-03-11T22:02:41.923Z', + duration_ms: 11916, + status: 'success', + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 1, + num_succeeded_actions: 1, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 1406, + schedule_delay_ms: 1583, + timed_out: false, + indexing_duration_ms: 0, + search_duration_ms: 0, + gap_duration_ms: 0, + security_status: 'partial failure', + security_message: + 'Check privileges failed to execute ResponseError: index_not_found_exception: [index_not_found_exception] Reason: no such index [broken-index] name: "This Rule Makes Alerts, Actions, AND Moar!" id: "f78f3550-a186-11ec-89a1-0bce95157aba" rule id: "b64b4540-d035-4826-a1e7-f505bf4b9653" execution id: "254d8400-9dc7-43c5-ad4b-227273d1a44b" space ID: "default"', + }, + ], + total: 2, +}); + export const getBasicEmptySearchResponse = (): estypes.SearchResponse => ({ took: 1, timed_out: false, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.test.ts index 97cba0f3b4f34..b24789d77a9bb 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.test.ts @@ -6,9 +6,14 @@ */ import { serverMock, requestContextMock } from '../__mocks__'; -import { getRuleExecutionEventsRequest, getLastFailures } from '../__mocks__/request_responses'; +import { + getRuleExecutionEventsRequest, + getAggregateExecutionEvents, +} from '../__mocks__/request_responses'; import { getRuleExecutionEventsRoute } from './get_rule_execution_events_route'; +// TODO: Add additional tests for param validation + describe('getRuleExecutionEventsRoute', () => { let server: ReturnType; let { clients, context } = requestContextMock.createTools(); @@ -22,21 +27,19 @@ describe('getRuleExecutionEventsRoute', () => { describe('when it finds events in rule execution log', () => { it('returns 200 response with the events', async () => { - const lastFailures = getLastFailures(); - clients.ruleExecutionLog.getLastFailures.mockResolvedValue(lastFailures); + const executionEvents = getAggregateExecutionEvents(); + clients.ruleExecutionLog.getAggregateExecutionEvents.mockResolvedValue(executionEvents); const response = await server.inject(getRuleExecutionEventsRequest(), context); expect(response.status).toEqual(200); - expect(response.body).toEqual({ - events: lastFailures, - }); + expect(response.body).toEqual(executionEvents); }); }); describe('when rule execution log client throws an error', () => { it('returns 500 response with it', async () => { - clients.ruleExecutionLog.getLastFailures.mockRejectedValue(new Error('Boom!')); + clients.ruleExecutionLog.getAggregateExecutionEvents.mockRejectedValue(new Error('Boom!')); const response = await server.inject(getRuleExecutionEventsRequest(), context); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.ts index 4a3e0aef8b2c7..d74f1df329730 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/get_rule_execution_events_route.ts @@ -6,20 +6,20 @@ */ import { transformError } from '@kbn/securitysolution-es-utils'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response'; import { buildRouteValidation } from '../../../../utils/build_validation/route_validation'; import { buildSiemResponse } from '../utils'; import type { SecuritySolutionPluginRouter } from '../../../../types'; import { DETECTION_ENGINE_RULE_EXECUTION_EVENTS_URL } from '../../../../../common/constants'; -import { GetRuleExecutionEventsRequestParams } from '../../../../../common/detection_engine/schemas/request/get_rule_execution_events_request'; -import { GetRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response/get_rule_execution_events_response'; +import { + GetRuleExecutionEventsQueryParams, + GetRuleExecutionEventsRequestParams, +} from '../../../../../common/detection_engine/schemas/request/get_rule_execution_events_schema'; /** - * Returns execution events of a given rule (e.g. status changes) from Event Log. - * Accepts rule's saved object ID (`rule.id`). - * - * NOTE: This endpoint is under construction. It will be extended and finalized. - * https://github.com/elastic/kibana/issues/119598 + * Returns execution events of a given rule (aggregated by executionId) from Event Log. + * Accepts rule's saved object ID (`rule.id`), `start`, `end` and `filters` query params. */ export const getRuleExecutionEventsRoute = (router: SecuritySolutionPluginRouter) => { router.get( @@ -27,6 +27,7 @@ export const getRuleExecutionEventsRoute = (router: SecuritySolutionPluginRouter path: DETECTION_ENGINE_RULE_EXECUTION_EVENTS_URL, validate: { params: buildRouteValidation(GetRuleExecutionEventsRequestParams), + query: buildRouteValidation(GetRuleExecutionEventsQueryParams), }, options: { tags: ['access:securitySolution'], @@ -34,14 +35,35 @@ export const getRuleExecutionEventsRoute = (router: SecuritySolutionPluginRouter }, async (context, request, response) => { const { ruleId } = request.params; + const { + start, + end, + query_text: queryText = '', + status_filters: statusFilters = '', + page, + per_page: perPage, + sort_field: sortField = 'timestamp', + sort_order: sortOrder = 'desc', + } = request.query; const siemResponse = buildSiemResponse(response); try { const executionLog = context.securitySolution.getRuleExecutionLog(); - const executionEvents = await executionLog.getLastFailures(ruleId); + const { events, total } = await executionLog.getAggregateExecutionEvents({ + ruleId, + start, + end, + queryText, + statusFilters: statusFilters.length ? statusFilters.split(',') : [], + page: page != null ? parseInt(page, 10) : 0, + perPage: perPage != null ? parseInt(perPage, 10) : 10, + sortField, + sortOrder, + }); - const responseBody: GetRuleExecutionEventsResponse = { - events: executionEvents, + const responseBody: GetAggregateRuleExecutionEventsResponse = { + events, + total, }; return response.ok({ body: responseBody }); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/__mocks__/index.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/__mocks__/index.ts index dbad1e95cb7d6..04516f22734db 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/__mocks__/index.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/__mocks__/index.ts @@ -13,6 +13,7 @@ import { const ruleExecutionLogForRoutesMock = { create: (): jest.Mocked => ({ + getAggregateExecutionEvents: jest.fn(), getExecutionSummariesBulk: jest.fn(), getExecutionSummary: jest.fn(), clearExecutionSummary: jest.fn(), diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client.ts index a4c528d941ba4..1ee23da39fe74 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client.ts @@ -7,6 +7,7 @@ import { chunk, mapValues } from 'lodash'; import { Logger } from 'src/core/server'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response'; import { initPromisePool } from '../../../../utils/promise_pool'; import { withSecuritySpan } from '../../../../utils/with_security_span'; @@ -14,7 +15,7 @@ import { RuleExecutionStatus } from '../../../../../common/detection_engine/sche import { IEventLogReader } from '../event_log/event_log_reader'; import { IRuleExecutionSavedObjectsClient } from '../execution_saved_object/saved_objects_client'; -import { IRuleExecutionLogForRoutes } from './client_interface'; +import { GetAggregateExecutionEventsArgs, IRuleExecutionLogForRoutes } from './client_interface'; import { ExtMeta } from '../utils/console_logging'; import { truncateList } from '../utils/normalization'; @@ -28,6 +29,47 @@ export const createClientForRoutes = ( logger: Logger ): IRuleExecutionLogForRoutes => { return { + getAggregateExecutionEvents({ + ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, + }: GetAggregateExecutionEventsArgs): Promise { + return withSecuritySpan( + 'IRuleExecutionLogForRoutes.getAggregateExecutionEvents', + async () => { + try { + return await eventLog.getAggregateExecutionEvents({ + ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, + }); + } catch (e) { + const logMessage = + 'Error getting last aggregation of execution failures from event log'; + const logAttributes = `rule id: "${ruleId}"`; + const logReason = e instanceof Error ? e.message : String(e); + const logMeta: ExtMeta = { + rule: { id: ruleId }, + }; + + logger.error(`${logMessage}; ${logAttributes}; ${logReason}`, logMeta); + throw e; + } + } + ); + }, /** * Get the current rule execution summary for each of the given rule IDs. * This method splits work into chunks so not to overwhelm Elasticsearch diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client_interface.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client_interface.ts index 14f99762ed6ef..541eaa827097d 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client_interface.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/client_for_routes/client_interface.ts @@ -9,6 +9,19 @@ import { RuleExecutionEvent, RuleExecutionSummary, } from '../../../../../common/detection_engine/schemas/common'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response'; + +export interface GetAggregateExecutionEventsArgs { + ruleId: string; + start: string; + end: string; + queryText: string; + statusFilters: string[]; + page: number; + perPage: number; + sortField: string; + sortOrder: string; +} /** * Used from route handlers to fetch and manage various information about the rule execution: @@ -16,6 +29,31 @@ import { * - execution events such as recent failures and status changes */ export interface IRuleExecutionLogForRoutes { + /** + * Fetches list of execution events aggregated by executionId, combining data from both alerting + * and security-solution event-log documents + * @param ruleId Saved object id of the rule (`rule.id`). + * @param start start of daterange to filter to + * @param end end of daterange to filter to + * @param queryText string of field-based filters, e.g. kibana.alert.rule.execution.status:* + * @param statusFilters array of status filters, e.g. ['succeeded', 'going to run'] + * @param page current page to fetch + * @param perPage number of results to fetch per page + * @param sortField field to sort by + * @param sortOrder what order to sort by (e.g. `asc` or `desc`) + */ + getAggregateExecutionEvents({ + ruleId, + start, + end, + queryText, + statusFilters, + page, + perPage, + sortField, + sortOrder, + }: GetAggregateExecutionEventsArgs): Promise; + /** * Fetches a list of current execution summaries of multiple rules. * @param ruleIds A list of saved object ids of multiple rules (`rule.id`). diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/event_log_reader.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/event_log_reader.ts index 3a59c26c769ee..765defb803756 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/event_log_reader.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/event_log_reader.ts @@ -5,12 +5,15 @@ * 2.0. */ +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { MAX_EXECUTION_EVENTS_DISPLAYED } from '@kbn/securitysolution-rules'; import { IEventLogClient } from '../../../../../../event_log/server'; import { RuleExecutionEvent, RuleExecutionStatus, } from '../../../../../common/detection_engine/schemas/common'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../common/detection_engine/schemas/response'; import { invariant } from '../../../../../common/utils/invariant'; import { withSecuritySpan } from '../../../../utils/with_security_span'; import { @@ -18,11 +21,32 @@ import { RULE_EXECUTION_LOG_PROVIDER, RuleExecutionLogAction, } from './constants'; +import { + formatExecutionEventResponse, + getExecutionEventAggregation, +} from './get_execution_event_aggregation'; +import { ExecutionUuidAggResult } from './get_execution_event_aggregation/types'; export interface IEventLogReader { + getAggregateExecutionEvents( + args: GetAggregateExecutionEventsArgs + ): Promise; + getLastStatusChanges(args: GetLastStatusChangesArgs): Promise; } +export interface GetAggregateExecutionEventsArgs { + ruleId: string; + start: string; + end: string; + queryText: string; + statusFilters: string[]; + page: number; + perPage: number; + sortField: string; + sortOrder: string; +} + export interface GetLastStatusChangesArgs { ruleId: string; count: number; @@ -31,6 +55,64 @@ export interface GetLastStatusChangesArgs { export const createEventLogReader = (eventLog: IEventLogClient): IEventLogReader => { return { + async getAggregateExecutionEvents( + args: GetAggregateExecutionEventsArgs + ): Promise { + const { ruleId, start, end, statusFilters, page, perPage, sortField, sortOrder } = args; + const soType = RULE_SAVED_OBJECT_TYPE; + const soIds = [ruleId]; + + // Current workaround to support root level filters without missing fields in the aggregate event + // or including events from statuses that aren't selected + // TODO: See: https://github.com/elastic/kibana/pull/127339/files#r825240516 + // First fetch execution uuid's by status filter if provided + let statusIds: string[] = []; + // If 0 or 3 statuses are selected we can search for all statuses and don't need this pre-filter by ID + if (statusFilters.length > 0 && statusFilters.length < 3) { + // TODO: Add cardinality agg and pass as maxEvents in response + const statusResults = await eventLog.aggregateEventsBySavedObjectIds(soType, soIds, { + start, + end, + filter: `kibana.alert.rule.execution.status:(${statusFilters.join(' OR ')})`, + aggs: { + filteredExecutionUUIDs: { + terms: { + field: 'kibana.alert.rule.execution.uuid', + size: MAX_EXECUTION_EVENTS_DISPLAYED, + }, + }, + }, + }); + const filteredExecutionUUIDs = statusResults.aggregations + ?.filteredExecutionUUIDs as ExecutionUuidAggResult; + statusIds = filteredExecutionUUIDs?.buckets?.map((b) => b.key) ?? []; + // Early return if no results based on status filter + if (statusIds.length === 0) { + return { + total: 0, + events: [], + }; + } + } + + // Now query for aggregate events, and pass any ID's as filters as determined from the above status/queryText results + const idsFilter = statusIds.length + ? `kibana.alert.rule.execution.uuid:(${statusIds.join(' OR ')})` + : ''; + const results = await eventLog.aggregateEventsBySavedObjectIds(soType, soIds, { + start, + end, + filter: idsFilter, + aggs: getExecutionEventAggregation({ + maxExecutions: MAX_EXECUTION_EVENTS_DISPLAYED, + page, + perPage, + sort: [{ [sortField]: { order: sortOrder } }] as estypes.Sort, + }), + }); + + return formatExecutionEventResponse(results); + }, async getLastStatusChanges(args) { const soType = RULE_SAVED_OBJECT_TYPE; const soIds = [args.ruleId]; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.test.ts new file mode 100644 index 0000000000000..d90d262688e86 --- /dev/null +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.test.ts @@ -0,0 +1,1321 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { MAX_EXECUTION_EVENTS_DISPLAYED } from '@kbn/securitysolution-rules'; + +import { + formatExecutionEventResponse, + formatSortForBucketSort, + formatSortForTermsSort, + getExecutionEventAggregation, + getProviderAndActionFilter, +} from './index'; + +describe('getExecutionEventAggregation', () => { + test('should throw error when given bad maxExecutions field', () => { + expect(() => { + getExecutionEventAggregation({ + maxExecutions: 1001, + page: 1, + perPage: 10, + sort: [{ timestamp: { order: 'asc' } }], + }); + }).toThrowErrorMatchingInlineSnapshot( + `"Invalid maxExecutions requested \\"1001\\" - must be less than ${MAX_EXECUTION_EVENTS_DISPLAYED}"` + ); + }); + + test('should throw error when given bad page field', () => { + expect(() => { + getExecutionEventAggregation({ + maxExecutions: 5, + page: -1, + perPage: 10, + sort: [{ timestamp: { order: 'asc' } }], + }); + }).toThrowErrorMatchingInlineSnapshot(`"Invalid page field \\"-1\\" - must be greater than 0"`); + }); + + test('should throw error when given bad perPage field', () => { + expect(() => { + getExecutionEventAggregation({ + maxExecutions: 5, + page: 1, + perPage: 0, + sort: [{ timestamp: { order: 'asc' } }], + }); + }).toThrowErrorMatchingInlineSnapshot( + `"Invalid perPage field \\"0\\" - must be greater than 0"` + ); + }); + + test('should throw error when given bad sort field', () => { + expect(() => { + getExecutionEventAggregation({ + maxExecutions: 5, + page: 1, + perPage: 10, + sort: [{ notsortable: { order: 'asc' } }], + }); + }).toThrowErrorMatchingInlineSnapshot( + `"Invalid sort field \\"notsortable\\" - must be one of [timestamp,duration_ms,indexing_duration_ms,search_duration_ms,gap_duration_ms,schedule_delay_ms,num_triggered_actions]"` + ); + }); + + test('should throw error when given one bad sort field', () => { + expect(() => { + getExecutionEventAggregation({ + maxExecutions: 5, + page: 1, + perPage: 10, + sort: [{ notsortable: { order: 'asc' } }, { timestamp: { order: 'asc' } }], + }); + }).toThrowErrorMatchingInlineSnapshot( + `"Invalid sort field \\"notsortable\\" - must be one of [timestamp,duration_ms,indexing_duration_ms,search_duration_ms,gap_duration_ms,schedule_delay_ms,num_triggered_actions]"` + ); + }); + + test('should correctly generate aggregation', () => { + expect( + getExecutionEventAggregation({ + maxExecutions: 5, + page: 2, + perPage: 10, + sort: [{ timestamp: { order: 'asc' } }, { duration_ms: { order: 'desc' } }], + }) + ).toEqual({ + totalExecutions: { + cardinality: { + field: 'kibana.alert.rule.execution.uuid', + }, + }, + executionUuid: { + terms: { + field: 'kibana.alert.rule.execution.uuid', + size: 5, + order: [ + { + 'ruleExecution>executeStartTime': 'asc', + }, + { + 'ruleExecution>executionDuration': 'desc', + }, + ], + }, + aggs: { + executionUuidSorted: { + bucket_sort: { + sort: [ + { + 'ruleExecution>executeStartTime': { + order: 'asc', + }, + }, + { + 'ruleExecution>executionDuration': { + order: 'desc', + }, + }, + ], + from: 20, + size: 10, + gap_policy: 'insert_zeros', + }, + }, + actionExecution: { + filter: { + bool: { + must: [ + { + match: { + 'event.action': 'execute', + }, + }, + { + match: { + 'event.provider': 'actions', + }, + }, + ], + }, + }, + aggs: { + actionOutcomes: { + terms: { + field: 'event.outcome', + size: 2, + }, + }, + }, + }, + ruleExecution: { + filter: { + bool: { + must: [ + { + match: { + 'event.action': 'execute', + }, + }, + { + match: { + 'event.provider': 'alerting', + }, + }, + ], + }, + }, + aggs: { + executeStartTime: { + min: { + field: 'event.start', + }, + }, + scheduleDelay: { + max: { + field: 'kibana.task.schedule_delay', + }, + }, + esSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.es_search_duration_ms', + }, + }, + numTriggeredActions: { + max: { + field: 'kibana.alert.rule.execution.metrics.number_of_triggered_actions', + }, + }, + executionDuration: { + max: { + field: 'event.duration', + }, + }, + outcomeAndMessage: { + top_hits: { + size: 1, + _source: { + includes: ['event.outcome', 'message'], + }, + }, + }, + }, + }, + securityMetrics: { + filter: { + bool: { + must: [ + { + match: { + 'event.action': 'execution-metrics', + }, + }, + { + match: { + 'event.provider': 'securitySolution.ruleExecution', + }, + }, + ], + }, + }, + aggs: { + gapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + missing: 0, + }, + }, + indexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + searchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + securityStatus: { + filter: { + bool: { + must: [ + { + match: { + 'event.action': 'status-change', + }, + }, + { + match: { + 'event.provider': 'securitySolution.ruleExecution', + }, + }, + ], + }, + }, + aggs: { + status: { + top_hits: { + sort: { + '@timestamp': { + order: 'desc', + }, + }, + size: 1, + _source: { + includes: 'kibana.alert.rule.execution.status', + }, + }, + }, + message: { + top_hits: { + size: 1, + sort: { + '@timestamp': { + order: 'desc', + }, + }, + _source: { + includes: 'message', + }, + }, + }, + }, + }, + timeoutMessage: { + filter: { + bool: { + must: [ + { + match: { + 'event.action': 'execute-timeout', + }, + }, + { + match: { + 'event.provider': 'alerting', + }, + }, + ], + }, + }, + }, + }, + }, + }); + }); +}); + +describe('getProviderAndActionFilter', () => { + test('should correctly format array of sort combinations for bucket sorting', () => { + expect(getProviderAndActionFilter('securitySolution.ruleExecution', 'status-change')).toEqual({ + bool: { + must: [ + { match: { 'event.action': 'status-change' } }, + { match: { 'event.provider': 'securitySolution.ruleExecution' } }, + ], + }, + }); + }); +}); + +describe('formatSortForBucketSort', () => { + test('should correctly format array of sort combinations for bucket sorting', () => { + expect( + formatSortForBucketSort([{ timestamp: { order: 'desc' } }, { duration_ms: { order: 'asc' } }]) + ).toEqual([ + { 'ruleExecution>executeStartTime': { order: 'desc' } }, + { 'ruleExecution>executionDuration': { order: 'asc' } }, + ]); + }); +}); + +describe('formatSortForTermsSort', () => { + test('should correctly format array of sort combinations for bucket sorting', () => { + expect( + formatSortForTermsSort([{ timestamp: { order: 'desc' } }, { duration_ms: { order: 'asc' } }]) + ).toEqual([ + { 'ruleExecution>executeStartTime': 'desc' }, + { 'ruleExecution>executionDuration': 'asc' }, + ]); + }); +}); + +describe('formatExecutionEventResponse', () => { + test('should return empty results if aggregations are undefined', () => { + expect(formatExecutionEventResponse({ aggregations: undefined })).toEqual({ + total: 0, + events: [], + }); + }); + test('should format results correctly', () => { + const results = { + aggregations: { + executionUuid: { + meta: {}, + doc_count_error_upper_bound: -1, + sum_other_doc_count: 1184, + buckets: [ + { + key: '01e458c9-d01a-4359-94f9-1ed256c6488e', + doc_count: 6, + timeoutMessage: { + meta: {}, + doc_count: 0, + }, + securityMetrics: { + meta: {}, + doc_count: 1, + searchDuration: { + value: 480.0, + }, + indexDuration: { + value: 7.0, + }, + gapDuration: { + value: 0.0, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 0.0, + }, + scheduleDelay: { + value: 3.147e9, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'Ca-qiX8Brb7RSEAgSLXB', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + }, + }, + ], + }, + }, + esSearchDuration: { + value: 464.0, + }, + executionDuration: { + value: 1.775e9, + }, + executeStartTime: { + value: 1.647282110867e12, + value_as_string: '2022-03-14T18:21:50.867Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 0, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [], + }, + }, + securityStatus: { + meta: {}, + doc_count: 2, + message: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'B6-qiX8Brb7RSEAgSLXB', + _score: null, + _source: { + message: 'succeeded', + }, + sort: [1647282112198], + }, + ], + }, + }, + status: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'B6-qiX8Brb7RSEAgSLXB', + _score: null, + _source: { + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + }, + }, + }, + }, + }, + sort: [1647282112198], + }, + ], + }, + }, + }, + }, + { + key: '02b7c7a4-ae1a-4da5-b134-c2fb96eb0e04', + doc_count: 5, + timeoutMessage: { + meta: {}, + doc_count: 0, + }, + securityMetrics: { + meta: {}, + doc_count: 1, + searchDuration: { + value: 9.0, + }, + indexDuration: { + value: 0.0, + }, + gapDuration: { + value: 0.0, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 0.0, + }, + scheduleDelay: { + value: 9.96e8, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'pK84iX8Brb7RSEAg3a-L', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: siem.queryRule:7457b121-a3a8-11ec-a0f0-cbd1c2ae6ee8: 'Endpoint Security'", + }, + }, + ], + }, + }, + esSearchDuration: { + value: 5.0, + }, + executionDuration: { + value: 1.922e9, + }, + executeStartTime: { + value: 1.647274677664e12, + value_as_string: '2022-03-14T16:17:57.664Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 0, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [], + }, + }, + securityStatus: { + meta: {}, + doc_count: 2, + message: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'o684iX8Brb7RSEAg2a-j', + _score: null, + _source: { + message: 'succeeded', + }, + sort: [1647274678629], + }, + ], + }, + }, + status: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'o684iX8Brb7RSEAg2a-j', + _score: null, + _source: { + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + }, + }, + }, + }, + }, + sort: [1647274678629], + }, + ], + }, + }, + }, + }, + ], + }, + totalExecutions: { + value: 768, + }, + }, + }; + expect(formatExecutionEventResponse(results)).toEqual({ + total: 768, + events: [ + { + execution_uuid: '01e458c9-d01a-4359-94f9-1ed256c6488e', + timestamp: '2022-03-14T18:21:50.867Z', + duration_ms: 1775, + status: 'success', + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 0, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 464, + schedule_delay_ms: 3147, + timed_out: false, + indexing_duration_ms: 7, + search_duration_ms: 480, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + { + execution_uuid: '02b7c7a4-ae1a-4da5-b134-c2fb96eb0e04', + timestamp: '2022-03-14T16:17:57.664Z', + duration_ms: 1922, + status: 'success', + message: + "rule executed: siem.queryRule:7457b121-a3a8-11ec-a0f0-cbd1c2ae6ee8: 'Endpoint Security'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 0, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 5, + schedule_delay_ms: 996, + timed_out: false, + indexing_duration_ms: 0, + search_duration_ms: 9, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + ], + }); + }); + + test('should format results correctly when execution timeouts occur', () => { + const results = { + aggregations: { + executionUuid: { + meta: {}, + doc_count_error_upper_bound: -1, + sum_other_doc_count: 1184, + buckets: [ + { + key: '01e458c9-d01a-4359-94f9-1ed256c6488e', + doc_count: 6, + timeoutMessage: { + meta: {}, + doc_count: 1, + }, + securityMetrics: { + meta: {}, + doc_count: 1, + searchDuration: { + value: 480.0, + }, + indexDuration: { + value: 7.0, + }, + gapDuration: { + value: 0.0, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 0.0, + }, + scheduleDelay: { + value: 3.147e9, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'Ca-qiX8Brb7RSEAgSLXB', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + }, + }, + ], + }, + }, + esSearchDuration: { + value: 464.0, + }, + executionDuration: { + value: 1.775e9, + }, + executeStartTime: { + value: 1.647282110867e12, + value_as_string: '2022-03-14T18:21:50.867Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 0, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [], + }, + }, + securityStatus: { + meta: {}, + doc_count: 2, + message: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'B6-qiX8Brb7RSEAgSLXB', + _score: null, + _source: { + message: 'succeeded', + }, + sort: [1647282112198], + }, + ], + }, + }, + status: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'B6-qiX8Brb7RSEAgSLXB', + _score: null, + _source: { + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + }, + }, + }, + }, + }, + sort: [1647282112198], + }, + ], + }, + }, + }, + }, + { + key: '02b7c7a4-ae1a-4da5-b134-c2fb96eb0e04', + doc_count: 5, + timeoutMessage: { + meta: {}, + doc_count: 0, + }, + securityMetrics: { + meta: {}, + doc_count: 1, + searchDuration: { + value: 9.0, + }, + indexDuration: { + value: 0.0, + }, + gapDuration: { + value: 0.0, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 0.0, + }, + scheduleDelay: { + value: 9.96e8, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'pK84iX8Brb7RSEAg3a-L', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: siem.queryRule:7457b121-a3a8-11ec-a0f0-cbd1c2ae6ee8: 'Endpoint Security'", + }, + }, + ], + }, + }, + esSearchDuration: { + value: 5.0, + }, + executionDuration: { + value: 1.922e9, + }, + executeStartTime: { + value: 1.647274677664e12, + value_as_string: '2022-03-14T16:17:57.664Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 0, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [], + }, + }, + securityStatus: { + meta: {}, + doc_count: 2, + message: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'o684iX8Brb7RSEAg2a-j', + _score: null, + _source: { + message: 'succeeded', + }, + sort: [1647274678629], + }, + ], + }, + }, + status: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'o684iX8Brb7RSEAg2a-j', + _score: null, + _source: { + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + }, + }, + }, + }, + }, + sort: [1647274678629], + }, + ], + }, + }, + }, + }, + ], + }, + totalExecutions: { + value: 768, + }, + }, + }; + expect(formatExecutionEventResponse(results)).toEqual({ + total: 768, + events: [ + { + execution_uuid: '01e458c9-d01a-4359-94f9-1ed256c6488e', + timestamp: '2022-03-14T18:21:50.867Z', + duration_ms: 1775, + status: 'success', + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 0, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 464, + schedule_delay_ms: 3147, + timed_out: true, + indexing_duration_ms: 7, + search_duration_ms: 480, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + { + execution_uuid: '02b7c7a4-ae1a-4da5-b134-c2fb96eb0e04', + timestamp: '2022-03-14T16:17:57.664Z', + duration_ms: 1922, + status: 'success', + message: + "rule executed: siem.queryRule:7457b121-a3a8-11ec-a0f0-cbd1c2ae6ee8: 'Endpoint Security'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 0, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 5, + schedule_delay_ms: 996, + timed_out: false, + indexing_duration_ms: 0, + search_duration_ms: 9, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + ], + }); + }); + + test('should format results correctly when action errors occur', () => { + const results = { + aggregations: { + executionUuid: { + meta: {}, + doc_count_error_upper_bound: -1, + sum_other_doc_count: 1184, + buckets: [ + { + key: '01e458c9-d01a-4359-94f9-1ed256c6488e', + doc_count: 6, + timeoutMessage: { + meta: {}, + doc_count: 1, + }, + securityMetrics: { + meta: {}, + doc_count: 1, + searchDuration: { + value: 480.0, + }, + indexDuration: { + value: 7.0, + }, + gapDuration: { + value: 0.0, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 0.0, + }, + scheduleDelay: { + value: 3.147e9, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'Ca-qiX8Brb7RSEAgSLXB', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + }, + }, + ], + }, + }, + esSearchDuration: { + value: 464.0, + }, + executionDuration: { + value: 1.775e9, + }, + executeStartTime: { + value: 1.647282110867e12, + value_as_string: '2022-03-14T18:21:50.867Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 5, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [ + { + key: 'success', + doc_count: 5, + }, + ], + }, + }, + securityStatus: { + meta: {}, + doc_count: 2, + message: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'B6-qiX8Brb7RSEAgSLXB', + _score: null, + _source: { + message: 'succeeded', + }, + sort: [1647282112198], + }, + ], + }, + }, + status: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'B6-qiX8Brb7RSEAgSLXB', + _score: null, + _source: { + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + }, + }, + }, + }, + }, + sort: [1647282112198], + }, + ], + }, + }, + }, + }, + { + key: '02b7c7a4-ae1a-4da5-b134-c2fb96eb0e04', + doc_count: 5, + timeoutMessage: { + meta: {}, + doc_count: 0, + }, + securityMetrics: { + meta: {}, + doc_count: 1, + searchDuration: { + value: 9.0, + }, + indexDuration: { + value: 0.0, + }, + gapDuration: { + value: 0.0, + }, + }, + ruleExecution: { + meta: {}, + doc_count: 1, + numTriggeredActions: { + value: 0.0, + }, + scheduleDelay: { + value: 9.96e8, + }, + outcomeAndMessage: { + hits: { + total: { + value: 1, + relation: 'eq', + }, + max_score: 1.0, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'pK84iX8Brb7RSEAg3a-L', + _score: 1.0, + _source: { + event: { + outcome: 'success', + }, + message: + "rule executed: siem.queryRule:7457b121-a3a8-11ec-a0f0-cbd1c2ae6ee8: 'Endpoint Security'", + }, + }, + ], + }, + }, + esSearchDuration: { + value: 5.0, + }, + executionDuration: { + value: 1.922e9, + }, + executeStartTime: { + value: 1.647274677664e12, + value_as_string: '2022-03-14T16:17:57.664Z', + }, + }, + actionExecution: { + meta: {}, + doc_count: 0, + actionOutcomes: { + doc_count_error_upper_bound: 0, + sum_other_doc_count: 0, + buckets: [], + }, + }, + securityStatus: { + meta: {}, + doc_count: 2, + message: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'o684iX8Brb7RSEAg2a-j', + _score: null, + _source: { + message: 'succeeded', + }, + sort: [1647274678629], + }, + ], + }, + }, + status: { + hits: { + total: { + value: 2, + relation: 'eq', + }, + max_score: null, + hits: [ + { + _index: '.kibana-event-log-8.2.0-000001', + _id: 'o684iX8Brb7RSEAg2a-j', + _score: null, + _source: { + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + }, + }, + }, + }, + }, + sort: [1647274678629], + }, + ], + }, + }, + }, + }, + ], + }, + totalExecutions: { + value: 768, + }, + }, + }; + expect(formatExecutionEventResponse(results)).toEqual({ + total: 768, + events: [ + { + execution_uuid: '01e458c9-d01a-4359-94f9-1ed256c6488e', + timestamp: '2022-03-14T18:21:50.867Z', + duration_ms: 1775, + status: 'success', + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 5, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 464, + schedule_delay_ms: 3147, + timed_out: true, + indexing_duration_ms: 7, + search_duration_ms: 480, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + { + execution_uuid: '02b7c7a4-ae1a-4da5-b134-c2fb96eb0e04', + timestamp: '2022-03-14T16:17:57.664Z', + duration_ms: 1922, + status: 'success', + message: + "rule executed: siem.queryRule:7457b121-a3a8-11ec-a0f0-cbd1c2ae6ee8: 'Endpoint Security'", + num_active_alerts: 0, + num_new_alerts: 0, + num_recovered_alerts: 0, + num_triggered_actions: 0, + num_succeeded_actions: 0, + num_errored_actions: 0, + total_search_duration_ms: 0, + es_search_duration_ms: 5, + schedule_delay_ms: 996, + timed_out: false, + indexing_duration_ms: 0, + search_duration_ms: 9, + gap_duration_ms: 0, + security_status: 'succeeded', + security_message: 'succeeded', + }, + ], + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.ts new file mode 100644 index 0000000000000..a66a2cccd538a --- /dev/null +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/index.ts @@ -0,0 +1,351 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { BadRequestError } from '@kbn/securitysolution-es-utils'; +import { flatMap, get } from 'lodash'; +import { MAX_EXECUTION_EVENTS_DISPLAYED } from '@kbn/securitysolution-rules'; +import { AggregateEventsBySavedObjectResult } from '../../../../../../../event_log/server'; +import { AggregateRuleExecutionEvent } from '../../../../../../common/detection_engine/schemas/common'; +import { GetAggregateRuleExecutionEventsResponse } from '../../../../../../common/detection_engine/schemas/response'; +import { + ExecutionEventAggregationOptions, + ExecutionUuidAggResult, + ExecutionUuidAggBucket, +} from './types'; + +// Base ECS fields +const ACTION_FIELD = 'event.action'; +const DURATION_FIELD = 'event.duration'; +const MESSAGE_FIELD = 'message'; +const PROVIDER_FIELD = 'event.provider'; +const OUTCOME_FIELD = 'event.outcome'; +const START_FIELD = 'event.start'; +const TIMESTAMP_FIELD = '@timestamp'; +// Platform fields +const SCHEDULE_DELAY_FIELD = 'kibana.task.schedule_delay'; +const ES_SEARCH_DURATION_FIELD = 'kibana.alert.rule.execution.metrics.es_search_duration_ms'; +const TOTAL_ACTIONS_TRIGGERED_FIELD = + 'kibana.alert.rule.execution.metrics.number_of_triggered_actions'; +const EXECUTION_UUID_FIELD = 'kibana.alert.rule.execution.uuid'; +// TODO: To be added in https://github.com/elastic/kibana/pull/126210 +// const TOTAL_ALERTS_CREATED: 'kibana.alert.rule.execution.metrics.total_alerts_created', +// const TOTAL_ALERTS_DETECTED: 'kibana.alert.rule.execution.metrics.total_alerts_detected', +// Security fields +const GAP_DURATION_FIELD = 'kibana.alert.rule.execution.metrics.execution_gap_duration_s'; +const INDEXING_DURATION_FIELD = 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms'; +const SEARCH_DURATION_FIELD = 'kibana.alert.rule.execution.metrics.total_search_duration_ms'; +const STATUS_FIELD = 'kibana.alert.rule.execution.status'; + +const ONE_MILLISECOND_AS_NANOSECONDS = 1_000_000; + +const SORT_FIELD_TO_AGG_MAPPING: Record = { + timestamp: 'ruleExecution>executeStartTime', + duration_ms: 'ruleExecution>executionDuration', + indexing_duration_ms: 'securityMetrics>indexDuration', + search_duration_ms: 'securityMetrics>searchDuration', + gap_duration_ms: 'securityMetrics>gapDuration', + schedule_delay_ms: 'ruleExecution>scheduleDelay', + num_triggered_actions: 'ruleExecution>numTriggeredActions', + // TODO: To be added in https://github.com/elastic/kibana/pull/126210 + // total_alerts_created: 'securityMetrics>totalAlertsDetected', + // total_alerts_detected: 'securityMetrics>totalAlertsCreated', +}; + +/** + * Returns `aggs` to be supplied to aggregateEventsBySavedObjectIds + * @param maxExecutions upper bounds of execution events to return (to narrow below max terms agg limit) + * @param page current page to retrieve, starting at 0 + * @param perPage number of execution events to display per page + * @param sort field to sort on + */ +export const getExecutionEventAggregation = ({ + maxExecutions, + page, + perPage, + sort, +}: ExecutionEventAggregationOptions): Record => { + // Last stop validation for any other consumers so there's a friendly message instead of failed ES Query + if (maxExecutions > MAX_EXECUTION_EVENTS_DISPLAYED) { + throw new BadRequestError( + `Invalid maxExecutions requested "${maxExecutions}" - must be less than ${MAX_EXECUTION_EVENTS_DISPLAYED}` + ); + } + + if (page < 0) { + throw new BadRequestError(`Invalid page field "${page}" - must be greater than 0`); + } + + if (perPage <= 0) { + throw new BadRequestError(`Invalid perPage field "${perPage}" - must be greater than 0`); + } + + const sortFields = flatMap(sort as estypes.SortCombinations[], (s) => Object.keys(s)); + for (const field of sortFields) { + if (!Object.keys(SORT_FIELD_TO_AGG_MAPPING).includes(field)) { + throw new BadRequestError( + `Invalid sort field "${field}" - must be one of [${Object.keys( + SORT_FIELD_TO_AGG_MAPPING + ).join(',')}]` + ); + } + } + + return { + // Total unique executions for given root filters + totalExecutions: { + cardinality: { + field: EXECUTION_UUID_FIELD, + }, + }, + executionUuid: { + // Bucket by execution UUID + terms: { + field: EXECUTION_UUID_FIELD, + size: maxExecutions, + order: formatSortForTermsSort(sort), + }, + aggs: { + // Bucket sort for paging + executionUuidSorted: { + bucket_sort: { + sort: formatSortForBucketSort(sort), + from: page * perPage, + size: perPage, + gap_policy: 'insert_zeros', + }, + }, + // Filter by action execute doc to retrieve action outcomes (successful/failed) + actionExecution: { + filter: getProviderAndActionFilter('actions', 'execute'), + aggs: { + actionOutcomes: { + terms: { + field: OUTCOME_FIELD, + size: 2, + }, + }, + }, + }, + // Filter by alerting execute doc to retrieve platform metrics + ruleExecution: { + filter: getProviderAndActionFilter('alerting', 'execute'), + aggs: { + executeStartTime: { + min: { + field: START_FIELD, + }, + }, + scheduleDelay: { + max: { + field: SCHEDULE_DELAY_FIELD, + }, + }, + esSearchDuration: { + max: { + field: ES_SEARCH_DURATION_FIELD, + }, + }, + numTriggeredActions: { + max: { + field: TOTAL_ACTIONS_TRIGGERED_FIELD, + }, + }, + executionDuration: { + max: { + field: DURATION_FIELD, + }, + }, + outcomeAndMessage: { + top_hits: { + size: 1, + _source: { + includes: [OUTCOME_FIELD, MESSAGE_FIELD], + }, + }, + }, + }, + }, + // Filter by securitySolution status-change doc to retrieve security metrics + securityMetrics: { + filter: getProviderAndActionFilter('securitySolution.ruleExecution', 'execution-metrics'), + aggs: { + gapDuration: { + min: { + field: GAP_DURATION_FIELD, + missing: 0, // Necessary for sorting since field isn't written if no gap + }, + }, + indexDuration: { + min: { + field: INDEXING_DURATION_FIELD, + }, + }, + searchDuration: { + min: { + field: SEARCH_DURATION_FIELD, + }, + }, + }, + }, + // Filter by securitySolution ruleExecution doc to retrieve status and message + securityStatus: { + filter: getProviderAndActionFilter('securitySolution.ruleExecution', 'status-change'), + aggs: { + status: { + top_hits: { + sort: { + [TIMESTAMP_FIELD]: { + order: 'desc', + }, + }, + size: 1, + _source: { + includes: STATUS_FIELD, + }, + }, + }, + message: { + top_hits: { + size: 1, + sort: { + [TIMESTAMP_FIELD]: { + order: 'desc', + }, + }, + _source: { + includes: MESSAGE_FIELD, + }, + }, + }, + }, + }, + // If there was a timeout, this filter will return non-zero doc count + timeoutMessage: { + filter: getProviderAndActionFilter('alerting', 'execute-timeout'), + }, + }, + }, + }; +}; + +/** + * Returns bool filter for matching a specific provider AND action combination + * @param provider provider to match + * @param action action to match + */ +export const getProviderAndActionFilter = (provider: string, action: string) => { + return { + bool: { + must: [ + { + match: { + [ACTION_FIELD]: action, + }, + }, + { + match: { + [PROVIDER_FIELD]: provider, + }, + }, + ], + }, + }; +}; + +/** + * Formats aggregate execution event from bucket response + * @param bucket + */ +export const formatAggExecutionEventFromBucket = ( + bucket: ExecutionUuidAggBucket +): AggregateRuleExecutionEvent => { + const durationUs = bucket?.ruleExecution?.executionDuration?.value ?? 0; + const scheduleDelayUs = bucket?.ruleExecution?.scheduleDelay?.value ?? 0; + const timedOut = (bucket?.timeoutMessage?.doc_count ?? 0) > 0; + + const actionOutcomes = bucket?.actionExecution?.actionOutcomes?.buckets ?? []; + const actionExecutionSuccess = actionOutcomes.find((b) => b?.key === 'success')?.doc_count ?? 0; + const actionExecutionError = actionOutcomes.find((b) => b?.key === 'failure')?.doc_count ?? 0; + + return { + execution_uuid: bucket?.key ?? '', + timestamp: bucket?.ruleExecution?.executeStartTime.value_as_string ?? '', + duration_ms: durationUs / ONE_MILLISECOND_AS_NANOSECONDS, + status: bucket?.ruleExecution?.outcomeAndMessage?.hits?.hits[0]?._source?.event?.outcome, + message: bucket?.ruleExecution?.outcomeAndMessage?.hits?.hits[0]?._source?.message, + num_active_alerts: bucket?.alertCounts?.buckets?.activeAlerts?.doc_count ?? 0, + num_new_alerts: bucket?.alertCounts?.buckets?.newAlerts?.doc_count ?? 0, + num_recovered_alerts: bucket?.alertCounts?.buckets?.recoveredAlerts?.doc_count ?? 0, + num_triggered_actions: bucket?.ruleExecution?.numTriggeredActions?.value ?? 0, + num_succeeded_actions: actionExecutionSuccess, + num_errored_actions: actionExecutionError, + total_search_duration_ms: bucket?.ruleExecution?.totalSearchDuration?.value ?? 0, + es_search_duration_ms: bucket?.ruleExecution?.esSearchDuration?.value ?? 0, + schedule_delay_ms: scheduleDelayUs / ONE_MILLISECOND_AS_NANOSECONDS, + timed_out: timedOut, + // security fields + indexing_duration_ms: bucket?.securityMetrics?.indexDuration?.value ?? 0, + search_duration_ms: bucket?.securityMetrics?.searchDuration?.value ?? 0, + gap_duration_ms: bucket?.securityMetrics?.gapDuration?.value ?? 0, + security_status: + bucket?.securityStatus?.status?.hits?.hits[0]?._source?.kibana?.alert?.rule?.execution + ?.status, + security_message: bucket?.securityStatus?.message?.hits?.hits[0]?._source?.message, + }; +}; + +/** + * Formats getAggregateExecutionEvents response from Elasticsearch response + * @param results Elasticsearch response + */ +export const formatExecutionEventResponse = ( + results: AggregateEventsBySavedObjectResult +): GetAggregateRuleExecutionEventsResponse => { + const { aggregations } = results; + + if (!aggregations) { + return { + total: 0, + events: [], + }; + } + + const total = (aggregations.totalExecutions as estypes.AggregationsCardinalityAggregate).value; + const buckets = (aggregations.executionUuid as ExecutionUuidAggResult).buckets; + + return { + total, + events: buckets.map((b: ExecutionUuidAggBucket) => formatAggExecutionEventFromBucket(b)), + }; +}; + +/** + * Formats sort field into bucket_sort agg format + * @param sort + */ +export const formatSortForBucketSort = (sort: estypes.Sort) => { + return (sort as estypes.SortCombinations[]).map((s) => + Object.keys(s).reduce( + (acc, curr) => ({ ...acc, [SORT_FIELD_TO_AGG_MAPPING[curr]]: get(s, curr) }), + {} + ) + ); +}; + +/** + * Formats sort field into terms agg format + * @param sort + */ +export const formatSortForTermsSort = (sort: estypes.Sort) => { + return (sort as estypes.SortCombinations[]).map((s) => + Object.keys(s).reduce( + (acc, curr) => ({ ...acc, [SORT_FIELD_TO_AGG_MAPPING[curr]]: get(s, `${curr}.order`) }), + {} + ) + ); +}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/types.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/types.ts new file mode 100644 index 0000000000000..bfe5f7d4e631b --- /dev/null +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_execution_log/event_log/get_execution_event_aggregation/types.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; + +type AlertCounts = estypes.AggregationsMultiBucketAggregateBase & { + buckets: { + activeAlerts: estypes.AggregationsSingleBucketAggregateBase; + newAlerts: estypes.AggregationsSingleBucketAggregateBase; + recoveredAlerts: estypes.AggregationsSingleBucketAggregateBase; + }; +}; + +type ActionExecution = estypes.AggregationsTermsAggregateBase<{ + key: string; + doc_count: number; +}> & { + buckets: Array<{ key: string; doc_count: number }>; +}; + +export type ExecutionUuidAggBucket = estypes.AggregationsStringTermsBucketKeys & { + timeoutMessage: estypes.AggregationsMultiBucketBase; + ruleExecution: { + executeStartTime: estypes.AggregationsMinAggregate; + executionDuration: estypes.AggregationsMaxAggregate; + scheduleDelay: estypes.AggregationsMaxAggregate; + esSearchDuration: estypes.AggregationsMaxAggregate; + totalSearchDuration: estypes.AggregationsMaxAggregate; + numTriggeredActions: estypes.AggregationsMaxAggregate; + outcomeAndMessage: estypes.AggregationsTopHitsAggregate; + }; + alertCounts: AlertCounts; + actionExecution: { + actionOutcomes: ActionExecution; + }; + securityStatus: { + message: estypes.AggregationsTopHitsAggregate; + status: estypes.AggregationsTopHitsAggregate; + }; + securityMetrics: { + searchDuration: estypes.AggregationsMinAggregate; + indexDuration: estypes.AggregationsMinAggregate; + gapDuration: estypes.AggregationsMinAggregate; + }; +}; + +export type ExecutionUuidAggResult = + estypes.AggregationsAggregateBase & { + buckets: TBucket[]; + }; + +export interface ExecutionEventAggregationOptions { + maxExecutions: number; + page: number; + perPage: number; + sort: estypes.Sort; +} diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 103097e1a9b9a..63bc9f34c8a11 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -20775,15 +20775,10 @@ "xpack.securitySolution.detectionEngine.ruleDetails.deletedRule": "Règle supprimée", "xpack.securitySolution.detectionEngine.ruleDetails.exceptionsTab": "Exceptions", "xpack.securitySolution.detectionEngine.ruleDetails.experimentalDescription": "Expérimental", - "xpack.securitySolution.detectionEngine.ruleDetails.failureHistoryTab": "Historique des échecs", - "xpack.securitySolution.detectionEngine.ruleDetails.lastFiveErrorsTitle": "Cinq dernières erreurs", "xpack.securitySolution.detectionEngine.ruleDetails.pageTitle": "Détails de la règle", "xpack.securitySolution.detectionEngine.ruleDetails.ruleCreationDescription": "Créé par : {by} le {date}", "xpack.securitySolution.detectionEngine.ruleDetails.ruleUpdateDescription": "Mis à jour par : {by} le {date}", - "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedAtColumn": "Échoué à", "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedDescription": "Échoué", - "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedMsgColumn": "Message échoué", - "xpack.securitySolution.detectionEngine.ruleDetails.statusTypeColumn": "Type", "xpack.securitySolution.detectionEngine.ruleDetails.unknownDescription": "Inconnu", "xpack.securitySolution.detectionEngine.rules.aboutRuleTitle": "À propos de la règle", "xpack.securitySolution.detectionEngine.rules.addNewRuleTitle": "Créer une nouvelle règle", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index a770b1c237e70..338cef102027f 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -23754,15 +23754,10 @@ "xpack.securitySolution.detectionEngine.ruleDetails.deletedRule": "削除されたルール", "xpack.securitySolution.detectionEngine.ruleDetails.exceptionsTab": "例外", "xpack.securitySolution.detectionEngine.ruleDetails.experimentalDescription": "テクニカルプレビュー", - "xpack.securitySolution.detectionEngine.ruleDetails.failureHistoryTab": "エラー履歴", - "xpack.securitySolution.detectionEngine.ruleDetails.lastFiveErrorsTitle": "最後の5件のエラー", "xpack.securitySolution.detectionEngine.ruleDetails.pageTitle": "ルール詳細", "xpack.securitySolution.detectionEngine.ruleDetails.ruleCreationDescription": "作成者: {by} 日付: {date}", "xpack.securitySolution.detectionEngine.ruleDetails.ruleUpdateDescription": "更新者:{by} 日付:{date}", - "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedAtColumn": "失敗", "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedDescription": "失敗", - "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedMsgColumn": "失敗メッセージ", - "xpack.securitySolution.detectionEngine.ruleDetails.statusTypeColumn": "型", "xpack.securitySolution.detectionEngine.ruleDetails.unknownDescription": "不明", "xpack.securitySolution.detectionEngine.rules.aboutRuleTitle": "ルールについて", "xpack.securitySolution.detectionEngine.rules.addNewRuleTitle": "新規ルールを作成", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index d6c0753033212..615229a857b11 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -23781,15 +23781,10 @@ "xpack.securitySolution.detectionEngine.ruleDetails.deletedRule": "已删除规则", "xpack.securitySolution.detectionEngine.ruleDetails.exceptionsTab": "例外", "xpack.securitySolution.detectionEngine.ruleDetails.experimentalDescription": "技术预览", - "xpack.securitySolution.detectionEngine.ruleDetails.failureHistoryTab": "失败历史记录", - "xpack.securitySolution.detectionEngine.ruleDetails.lastFiveErrorsTitle": "上五个错误", "xpack.securitySolution.detectionEngine.ruleDetails.pageTitle": "规则详情", "xpack.securitySolution.detectionEngine.ruleDetails.ruleCreationDescription": "由 {by} 于 {date}创建", "xpack.securitySolution.detectionEngine.ruleDetails.ruleUpdateDescription": "由 {by} 于 {date}更新", - "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedAtColumn": "失败于", "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedDescription": "失败", - "xpack.securitySolution.detectionEngine.ruleDetails.statusFailedMsgColumn": "失败消息", - "xpack.securitySolution.detectionEngine.ruleDetails.statusTypeColumn": "类型", "xpack.securitySolution.detectionEngine.ruleDetails.unknownDescription": "未知", "xpack.securitySolution.detectionEngine.rules.aboutRuleTitle": "关于规则", "xpack.securitySolution.detectionEngine.rules.addNewRuleTitle": "创建新规则", diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/get_rule_execution_events.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/get_rule_execution_events.ts new file mode 100644 index 0000000000000..555c16e206ab8 --- /dev/null +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/get_rule_execution_events.ts @@ -0,0 +1,227 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import dateMath from '@elastic/datemath'; +import expect from '@kbn/expect'; +import moment from 'moment'; +import { set } from '@elastic/safer-lodash-set'; +import uuid from 'uuid'; +import { detectionEngineRuleExecutionEventsUrl } from '../../../../plugins/security_solution/common/constants'; +import { RuleExecutionStatus } from '../../../../plugins/security_solution/common/detection_engine/schemas/common'; + +import { FtrProviderContext } from '../../common/ftr_provider_context'; +import { + createRule, + createSignalsIndex, + deleteAllAlerts, + deleteAllEventLogExecutionEvents, + deleteSignalsIndex, + getRuleForSignalTesting, + indexEventLogExecutionEvents, + waitForEventLogExecuteComplete, + waitForRuleSuccessOrStatus, +} from '../../utils'; +import { failedGapExecution } from './template_data/execution_events'; + +// eslint-disable-next-line import/no-default-export +export default ({ getService }: FtrProviderContext) => { + const supertest = getService('supertest'); + const esArchiver = getService('esArchiver'); + const es = getService('es'); + const log = getService('log'); + + describe('Get Rule Execution Log Events', () => { + before(async () => { + await esArchiver.load('x-pack/test/functional/es_archives/auditbeat/hosts'); + await esArchiver.load('x-pack/test/functional/es_archives/security_solution/alias'); + await createSignalsIndex(supertest, log); + }); + + after(async () => { + await esArchiver.unload('x-pack/test/functional/es_archives/auditbeat/hosts'); + await esArchiver.unload('x-pack/test/functional/es_archives/security_solution/alias'); + await deleteSignalsIndex(supertest, log); + }); + + beforeEach(async () => { + await deleteAllAlerts(supertest, log); + await deleteAllEventLogExecutionEvents(es, log); + }); + + afterEach(async () => { + await deleteAllAlerts(supertest, log); + await deleteAllEventLogExecutionEvents(es, log); + }); + + it('should return an error if rule does not exist', async () => { + const start = dateMath.parse('now-24h')?.utc().toISOString(); + const end = dateMath.parse('now', { roundUp: true })?.utc().toISOString(); + const response = await supertest + .get(detectionEngineRuleExecutionEventsUrl('1')) + .set('kbn-xsrf', 'true') + .query({ start, end }); + + expect(response.status).to.eql(404); + expect(response.text).to.eql( + '{"message":"Saved object [alert/1] not found","status_code":404}' + ); + }); + + it('should return execution events for a rule that has executed successfully', async () => { + const rule = getRuleForSignalTesting(['auditbeat-*']); + const { id } = await createRule(supertest, log, rule); + await waitForRuleSuccessOrStatus(supertest, log, id); + await waitForEventLogExecuteComplete(es, log, id); + + const start = dateMath.parse('now-24h')?.utc().toISOString(); + const end = dateMath.parse('now', { roundUp: true })?.utc().toISOString(); + const response = await supertest + .get(detectionEngineRuleExecutionEventsUrl(id)) + .set('kbn-xsrf', 'true') + .query({ start, end }); + + expect(response.status).to.eql(200); + expect(response.body.total).to.eql(1); + expect(response.body.events[0].duration_ms).to.greaterThan(0); + expect(response.body.events[0].search_duration_ms).to.greaterThan(0); + expect(response.body.events[0].schedule_delay_ms).to.greaterThan(0); + expect(response.body.events[0].indexing_duration_ms).to.greaterThan(0); + expect(response.body.events[0].gap_duration_ms).to.eql(0); + expect(response.body.events[0].security_status).to.eql('succeeded'); + expect(response.body.events[0].security_message).to.eql('succeeded'); + }); + + it('should return execution events for a rule that has executed in a warning state', async () => { + const rule = getRuleForSignalTesting(['auditbeat-*', 'no-name-index']); + const { id } = await createRule(supertest, log, rule); + await waitForRuleSuccessOrStatus(supertest, log, id, RuleExecutionStatus['partial failure']); + await waitForEventLogExecuteComplete(es, log, id); + + const start = dateMath.parse('now-24h')?.utc().toISOString(); + const end = dateMath.parse('now', { roundUp: true })?.utc().toISOString(); + const response = await supertest + .get(detectionEngineRuleExecutionEventsUrl(id)) + .set('kbn-xsrf', 'true') + .query({ start, end }); + + expect(response.status).to.eql(200); + expect(response.body.total).to.eql(1); + expect(response.body.events[0].duration_ms).to.greaterThan(0); + expect(response.body.events[0].search_duration_ms).to.eql(0); + expect(response.body.events[0].schedule_delay_ms).to.greaterThan(0); + expect(response.body.events[0].indexing_duration_ms).to.eql(0); + expect(response.body.events[0].gap_duration_ms).to.eql(0); + expect(response.body.events[0].security_status).to.eql('partial failure'); + expect( + response.body.events[0].security_message.startsWith( + 'Check privileges failed to execute ResponseError: index_not_found_exception: [index_not_found_exception] Reason: no such index [no-name-index]' + ) + ).to.eql(true); + }); + + // TODO: Debug indexing + it.skip('should return execution events for a rule that has executed in a failure state with a gap', async () => { + const rule = getRuleForSignalTesting(['auditbeat-*'], uuid.v4(), false); + const { id } = await createRule(supertest, log, rule); + + const start = dateMath.parse('now')?.utc().toISOString(); + const end = dateMath.parse('now+24h', { roundUp: true })?.utc().toISOString(); + + // Create 5 timestamps a minute apart to use in the templated data + const dateTimes = [...Array(5).keys()].map((i) => + moment(start) + .add(i + 1, 'm') + .toDate() + .toISOString() + ); + + const events = failedGapExecution.map((e, i) => { + set(e, '@timestamp', dateTimes[i]); + set(e, 'event.start', dateTimes[i]); + set(e, 'event.end', dateTimes[i]); + set(e, 'rule.id', id); + return e; + }); + + await indexEventLogExecutionEvents(es, log, events); + await waitForEventLogExecuteComplete(es, log, id); + + const response = await supertest + .get(detectionEngineRuleExecutionEventsUrl(id)) + .set('kbn-xsrf', 'true') + .query({ start, end }); + + // console.log(JSON.stringify(response)); + + expect(response.status).to.eql(200); + expect(response.body.total).to.eql(1); + expect(response.body.events[0].duration_ms).to.eql(4236); + expect(response.body.events[0].search_duration_ms).to.eql(0); + expect(response.body.events[0].schedule_delay_ms).to.greaterThan(0); + expect(response.body.events[0].indexing_duration_ms).to.eql(0); + expect(response.body.events[0].gap_duration_ms).to.greaterThan(0); + expect(response.body.events[0].security_status).to.eql('failed'); + expect( + response.body.events[0].security_message.startsWith( + 'Check privileges failed to execute ResponseError: index_not_found_exception: [index_not_found_exception] Reason: no such index [no-name-index]' + ) + ).to.eql(true); + }); + + // it('should return execution events when providing a status filter', async () => { + // const rule = getRuleForSignalTesting(['auditbeat-*', 'no-name-index']); + // const { id } = await createRule(supertest, log, rule); + // await waitForRuleSuccessOrStatus(supertest, log, id, RuleExecutionStatus.failed); + // await waitForSignalsToBePresent(supertest, log, 1, [id]); + // + // const start = dateMath.parse('now-24h')?.utc().toISOString(); + // const end = dateMath.parse('now', { roundUp: true })?.utc().toISOString(); + // const response = await supertest + // .get(detectionEngineRuleExecutionEventsUrl(id)) + // .set('kbn-xsrf', 'true') + // .query({ start, end }); + // + // expect(response.status).to.eql(200); + // expect(response.body.total).to.eql(1); + // expect(response.body.events[0].duration_ms).to.greaterThan(0); + // expect(response.body.events[0].search_duration_ms).to.eql(0); + // expect(response.body.events[0].schedule_delay_ms).to.greaterThan(0); + // expect(response.body.events[0].indexing_duration_ms).to.eql(0); + // expect(response.body.events[0].gap_duration_ms).to.eql(0); + // expect(response.body.events[0].security_status).to.eql('failed'); + // expect(response.body.events[0].security_message).to.include( + // 'were not queried between this rule execution and the last execution, so signals may have been missed. ' + // ); + // }); + + // it('should return execution events when providing a status filter and sortField', async () => { + // const rule = getRuleForSignalTesting(['auditbeat-*', 'no-name-index']); + // const { id } = await createRule(supertest, log, rule); + // await waitForRuleSuccessOrStatus(supertest, log, id, RuleExecutionStatus.failed); + // await waitForSignalsToBePresent(supertest, log, 1, [id]); + // + // const start = dateMath.parse('now-24h')?.utc().toISOString(); + // const end = dateMath.parse('now', { roundUp: true })?.utc().toISOString(); + // const response = await supertest + // .get(detectionEngineRuleExecutionEventsUrl(id)) + // .set('kbn-xsrf', 'true') + // .query({ start, end }); + // + // expect(response.status).to.eql(200); + // expect(response.body.total).to.eql(1); + // expect(response.body.events[0].duration_ms).to.greaterThan(0); + // expect(response.body.events[0].search_duration_ms).to.eql(0); + // expect(response.body.events[0].schedule_delay_ms).to.greaterThan(0); + // expect(response.body.events[0].indexing_duration_ms).to.eql(0); + // expect(response.body.events[0].gap_duration_ms).to.eql(0); + // expect(response.body.events[0].security_status).to.eql('failed'); + // expect(response.body.events[0].security_message).to.include( + // 'were not queried between this rule execution and the last execution, so signals may have been missed. ' + // ); + // }); + }); +}; diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/index.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/index.ts index a9bda19638041..dbe24c77b57ae 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/index.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/index.ts @@ -32,6 +32,7 @@ export default ({ loadTestFile }: FtrProviderContext): void => { loadTestFile(require.resolve('./find_rules')); loadTestFile(require.resolve('./generating_signals')); loadTestFile(require.resolve('./get_prepackaged_rules_status')); + loadTestFile(require.resolve('./get_rule_execution_events')); loadTestFile(require.resolve('./import_rules')); loadTestFile(require.resolve('./import_export_rules')); loadTestFile(require.resolve('./read_rules')); diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/template_data/execution_events.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/template_data/execution_events.ts new file mode 100644 index 0000000000000..c4767bbcc5632 --- /dev/null +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/template_data/execution_events.ts @@ -0,0 +1,630 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export const successfulExecution = [ + { + '@timestamp': '2022-03-17T22:59:31.360Z', + event: { + provider: 'alerting', + action: 'execute', + kind: 'alert', + category: ['siem'], + start: '2022-03-17T22:59:28.100Z', + outcome: 'success', + end: '2022-03-17T22:59:31.283Z', + duration: 3183000000, + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '7e62d859-aeaa-4e3d-8b9c-b3b737356383', + metrics: { + number_of_triggered_actions: 0, + number_of_searches: 2, + es_search_duration_ms: 1, + total_search_duration_ms: 15, + }, + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + type_id: 'siem.queryRule', + }, + ], + task: { + scheduled: '2022-03-17T22:59:25.051Z', + schedule_delay: 3049000000, + }, + alerting: { + status: 'ok', + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + license: 'basic', + category: 'siem.queryRule', + ruleset: 'siem', + name: 'Lots of Execution Events', + }, + message: + "rule executed: siem.queryRule:fb1fc150-a292-11ec-a2cf-c1b28b0392b0: 'Lots of Execution Events'", + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T22:59:30.296Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'metric', + action: 'execution-metrics', + sequence: 1, + }, + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + name: 'Lots of Execution Events', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + metrics: { + total_search_duration_ms: 12, + total_indexing_duration_ms: 0, + }, + uuid: '7e62d859-aeaa-4e3d-8b9c-b3b737356383', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T22:59:30.296Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'event', + action: 'status-change', + sequence: 2, + }, + message: 'succeeded', + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + name: 'Lots of Execution Events', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + status: 'succeeded', + status_order: 0, + uuid: '7e62d859-aeaa-4e3d-8b9c-b3b737356383', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T22:59:28.134Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'event', + action: 'status-change', + sequence: 0, + }, + message: '', + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + name: 'Lots of Execution Events', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + status: 'running', + status_order: 15, + uuid: '7e62d859-aeaa-4e3d-8b9c-b3b737356383', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T22:59:28.100Z', + event: { + provider: 'alerting', + action: 'execute-start', + kind: 'alert', + category: ['siem'], + start: '2022-03-17T22:59:28.100Z', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '7e62d859-aeaa-4e3d-8b9c-b3b737356383', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + type_id: 'siem.queryRule', + }, + ], + task: { + scheduled: '2022-03-17T22:59:25.051Z', + schedule_delay: 3049000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + license: 'basic', + category: 'siem.queryRule', + ruleset: 'siem', + }, + message: 'rule execution start: "fb1fc150-a292-11ec-a2cf-c1b28b0392b0"', + ecs: { + version: '1.8.0', + }, + }, +]; + +export const failedGapExecution = [ + { + '@timestamp': '2022-03-17T12:36:16.413Z', + event: { + provider: 'alerting', + action: 'execute', + kind: 'alert', + category: ['siem'], + start: '2022-03-17T12:36:14.868Z', + outcome: 'success', + end: '2022-03-17T12:36:16.413Z', + duration: 1545000000, + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '38fa2d4a-94d3-4ea3-80d6-d1284eb98357', + metrics: { + number_of_triggered_actions: 0, + number_of_searches: 6, + es_search_duration_ms: 2, + total_search_duration_ms: 15, + }, + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + type_id: 'siem.queryRule', + }, + ], + task: { + scheduled: '2022-03-17T12:27:10.060Z', + schedule_delay: 544808000000, + }, + alerting: { + status: 'ok', + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + license: 'basic', + category: 'siem.queryRule', + ruleset: 'siem', + name: 'Lots of Execution Events', + }, + message: + "rule executed: siem.queryRule:fb1fc150-a292-11ec-a2cf-c1b28b0392b0: 'Lots of Execution Events'", + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T12:36:15.382Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'metric', + action: 'execution-metrics', + sequence: 1, + }, + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + name: 'Lots of Execution Events', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + metrics: { + execution_gap_duration_s: 245, + }, + uuid: '38fa2d4a-94d3-4ea3-80d6-d1284eb98357', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T12:36:15.382Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'event', + action: 'status-change', + sequence: 2, + }, + message: + '4 minutes (244689ms) were not queried between this rule execution and the last execution, so signals may have been missed. Consider increasing your look behind time or adding more Kibana instances. name: "Lots of Execution Events" id: "fb1fc150-a292-11ec-a2cf-c1b28b0392b0" rule id: "7c44befd-f611-4994-b116-9861df75d0cb" execution id: "38fa2d4a-94d3-4ea3-80d6-d1284eb98357" space ID: "default"', + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + name: 'Lots of Execution Events', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + status: 'failed', + status_order: 30, + uuid: '38fa2d4a-94d3-4ea3-80d6-d1284eb98357', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T12:36:14.888Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'event', + action: 'status-change', + sequence: 0, + }, + message: '', + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + name: 'Lots of Execution Events', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + status: 'running', + status_order: 15, + uuid: '38fa2d4a-94d3-4ea3-80d6-d1284eb98357', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-17T12:36:14.868Z', + event: { + provider: 'alerting', + action: 'execute-start', + kind: 'alert', + category: ['siem'], + start: '2022-03-17T12:36:14.868Z', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: '38fa2d4a-94d3-4ea3-80d6-d1284eb98357', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + type_id: 'siem.queryRule', + }, + ], + task: { + scheduled: '2022-03-17T12:27:10.060Z', + schedule_delay: 544808000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'fb1fc150-a292-11ec-a2cf-c1b28b0392b0', + license: 'basic', + category: 'siem.queryRule', + ruleset: 'siem', + }, + message: 'rule execution start: "fb1fc150-a292-11ec-a2cf-c1b28b0392b0"', + ecs: { + version: '1.8.0', + }, + }, +]; + +export const partialWarningExecution = [ + { + '@timestamp': '2022-03-16T23:28:36.012Z', + event: { + provider: 'alerting', + action: 'execute', + kind: 'alert', + category: ['siem'], + start: '2022-03-16T23:28:34.365Z', + outcome: 'success', + end: '2022-03-16T23:28:36.012Z', + duration: 1647000000, + }, + kibana: { + alert: { + rule: { + execution: { + uuid: 'ce37a09d-9359-4756-abbf-e319dd6b1336', + metrics: { + number_of_triggered_actions: 0, + number_of_searches: 2, + es_search_duration_ms: 0, + total_search_duration_ms: 3, + }, + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + type_id: 'siem.queryRule', + }, + ], + task: { + scheduled: '2022-03-16T23:28:31.233Z', + schedule_delay: 3132000000, + }, + alerting: { + status: 'ok', + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + license: 'basic', + category: 'siem.queryRule', + ruleset: 'siem', + name: 'This Rule Makes Alerts, Actions, AND Moar!', + }, + message: + "rule executed: siem.queryRule:f78f3550-a186-11ec-89a1-0bce95157aba: 'This Rule Makes Alerts, Actions, AND Moar!'", + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-16T23:28:34.998Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'event', + action: 'status-change', + sequence: 1, + }, + message: + 'Check privileges failed to execute ResponseError: index_not_found_exception: [index_not_found_exception] Reason: no such index [frank] name: "This Rule Makes Alerts, Actions, AND Moar!" id: "f78f3550-a186-11ec-89a1-0bce95157aba" rule id: "b64b4540-d035-4826-a1e7-f505bf4b9653" execution id: "ce37a09d-9359-4756-abbf-e319dd6b1336" space ID: "default"', + rule: { + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + name: 'This Rule Makes Alerts, Actions, AND Moar!', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + status: 'partial failure', + status_order: 20, + uuid: 'ce37a09d-9359-4756-abbf-e319dd6b1336', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-16T23:28:34.386Z', + event: { + provider: 'securitySolution.ruleExecution', + kind: 'event', + action: 'status-change', + sequence: 0, + }, + message: '', + rule: { + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + name: 'This Rule Makes Alerts, Actions, AND Moar!', + category: 'siem.queryRule', + }, + kibana: { + alert: { + rule: { + execution: { + status: 'running', + status_order: 15, + uuid: 'ce37a09d-9359-4756-abbf-e319dd6b1336', + }, + }, + }, + space_ids: ['default'], + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + }, + ], + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + ecs: { + version: '1.8.0', + }, + }, + { + '@timestamp': '2022-03-16T23:28:34.365Z', + event: { + provider: 'alerting', + action: 'execute-start', + kind: 'alert', + category: ['siem'], + start: '2022-03-16T23:28:34.365Z', + }, + kibana: { + alert: { + rule: { + execution: { + uuid: 'ce37a09d-9359-4756-abbf-e319dd6b1336', + }, + }, + }, + saved_objects: [ + { + rel: 'primary', + type: 'alert', + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + type_id: 'siem.queryRule', + }, + ], + task: { + scheduled: '2022-03-16T23:28:31.233Z', + schedule_delay: 3132000000, + }, + server_uuid: '5b2de169-2785-441b-ae8c-186a1936b17d', + version: '8.2.0', + }, + rule: { + id: 'f78f3550-a186-11ec-89a1-0bce95157aba', + license: 'basic', + category: 'siem.queryRule', + ruleset: 'siem', + }, + message: 'rule execution start: "f78f3550-a186-11ec-89a1-0bce95157aba"', + ecs: { + version: '1.8.0', + }, + }, +]; diff --git a/x-pack/test/detection_engine_api_integration/utils.ts b/x-pack/test/detection_engine_api_integration/utils.ts index 545bd20fc777b..594f380199dd6 100644 --- a/x-pack/test/detection_engine_api_integration/utils.ts +++ b/x-pack/test/detection_engine_api_integration/utils.ts @@ -5,6 +5,7 @@ * 2.0. */ +import { SearchTotalHits } from '@elastic/elasticsearch/lib/api/types'; import { KbnClient } from '@kbn/test'; import { ALERT_RULE_RULE_ID, ALERT_RULE_UUID } from '@kbn/rule-data-utils'; @@ -1466,6 +1467,124 @@ export const waitForSignalsToBePresent = async ( ); }; +/** + * Waits for the event-log execution completed doc count to be greater than the + * supplied number before continuing with a default of at least one execution + * @param es The ES client + * @param log + * @param ruleId The id of rule to check execution logs for + * @param totalExecutions The number of executions to wait for, default is 1 + */ +export const waitForEventLogExecuteComplete = async ( + es: Client, + log: ToolingLog, + ruleId: string, + totalExecutions = 1 +): Promise => { + await waitFor( + async () => { + const executionCount = await getEventLogExecuteCompleteById(es, log, ruleId); + return executionCount >= totalExecutions; + }, + 'waitForEventLogExecuteComplete', + log + ); +}; + +/** + * Given a single rule id this will return the number of event-log execution + * completed docs + * @param es The ES client + * @param log + * @param ruleId Rule id + */ +export const getEventLogExecuteCompleteById = async ( + es: Client, + log: ToolingLog, + ruleId: string +): Promise => { + const response = await es.search({ + index: '.kibana-event-log*', + track_total_hits: true, + size: 0, + query: { + bool: { + must: [], + filter: [ + { + match_phrase: { + 'event.provider': 'alerting', + }, + }, + { + match_phrase: { + 'event.action': 'execute', + }, + }, + { + match_phrase: { + 'rule.id': ruleId, + }, + }, + ], + should: [], + must_not: [], + }, + }, + }); + + return (response?.hits?.total as SearchTotalHits)?.value ?? 0; +}; + +/** + * Indexes provided execution events into .kibana-event-log-* + * @param es The ElasticSearch handle + * @param log The tooling logger + * @param events + */ +export const indexEventLogExecutionEvents = async ( + es: Client, + log: ToolingLog, + events: object[] +): Promise => { + const operations = events.flatMap((doc: object) => [ + { index: { _index: '.kibana-event-log-*' } }, + doc, + ]); + + await es.bulk({ refresh: true, operations }); + + return; +}; + +/** + * Remove all .kibana-event-log-* documents with an execution.uuid + * This will retry 20 times before giving up and hopefully still not interfere with other tests + * @param es The ElasticSearch handle + * @param log The tooling logger + */ +export const deleteAllEventLogExecutionEvents = async ( + es: Client, + log: ToolingLog +): Promise => { + return countDownES( + async () => { + return es.deleteByQuery( + { + index: '.kibana-event-log-*', + q: '_exists_:kibana.alert.rule.execution.uuid', + wait_for_completion: true, + refresh: true, + body: {}, + }, + { meta: true } + ); + }, + 'deleteAllEventLogExecutionEvents', + log + ); +}; + /** * Returns all signals both closed and opened by ruleId * @param supertest Deps From 065b58575731a14d7856c23219b8a3d711c98d36 Mon Sep 17 00:00:00 2001 From: Karl Godard Date: Mon, 28 Mar 2022 15:52:28 -0700 Subject: [PATCH 058/160] Fix to sessionview search (#128680) * Fix for process event pagination in session view * Added useMemo to getChildren call. Also fixed some issues around search when verbose mode is OFF * Added useMemo to getChildren call. Also fixed some issues around search when verbose mode is OFF Co-authored-by: mitodrummer --- .../public/components/process_tree/hooks.ts | 7 +-- .../public/components/process_tree/index.tsx | 15 +++-- .../components/process_tree_node/buttons.tsx | 55 +------------------ .../components/process_tree_node/index.tsx | 21 +++++-- 4 files changed, 28 insertions(+), 70 deletions(-) diff --git a/x-pack/plugins/session_view/public/components/process_tree/hooks.ts b/x-pack/plugins/session_view/public/components/process_tree/hooks.ts index eb1472c767c01..39c038fd8499f 100644 --- a/x-pack/plugins/session_view/public/components/process_tree/hooks.ts +++ b/x-pack/plugins/session_view/public/components/process_tree/hooks.ts @@ -83,7 +83,7 @@ export class ProcessImpl implements Process { child.getDetails().process; // search matches or processes with alerts will never be filtered out - if (child.searchMatched || child.hasAlerts()) { + if (child.autoExpand || child.searchMatched || child.hasAlerts()) { return true; } @@ -94,11 +94,6 @@ export class ProcessImpl implements Process { return false; } - // If the process has no children and has not exec'd (fork only), we hide it. - if (child.children.length === 0 && !child.hasExec()) { - return false; - } - return true; }); } diff --git a/x-pack/plugins/session_view/public/components/process_tree/index.tsx b/x-pack/plugins/session_view/public/components/process_tree/index.tsx index 1c65eb9b3aad8..a702bb19f8e30 100644 --- a/x-pack/plugins/session_view/public/components/process_tree/index.tsx +++ b/x-pack/plugins/session_view/public/components/process_tree/index.tsx @@ -145,14 +145,16 @@ export const ProcessTree = ({ if (processEl) { processEl.prepend(selectionAreaEl); - const cTop = scrollerRef.current.scrollTop; - const cBottom = cTop + scrollerRef.current.clientHeight; + const { height: elHeight, y: elTop } = processEl.getBoundingClientRect(); + const { y: viewPortElTop, height: viewPortElHeight } = + scrollerRef.current.getBoundingClientRect(); - const eTop = processEl.offsetTop; - const eBottom = eTop + processEl.clientHeight; - const isVisible = eTop >= cTop && eBottom <= cBottom; + const viewPortElBottom = viewPortElTop + viewPortElHeight; + const elBottom = elTop + elHeight; + const isVisible = elBottom >= viewPortElTop && elTop <= viewPortElBottom; - if (!isVisible) { + // jest will die when calling scrollIntoView (perhaps not part of the DOM it executes under) + if (!isVisible && processEl.scrollIntoView) { processEl.scrollIntoView({ block: 'center' }); } } @@ -209,6 +211,7 @@ export const ProcessTree = ({ onShowAlertDetails={onShowAlertDetails} timeStampOn={timeStampOn} verboseModeOn={verboseModeOn} + searchResults={searchResults} /> )}
void; - showGroupLeadersOnly: boolean; - childCount: number; -}) => { - const groupLeaderCount = process.getChildren(false).length; - const sameGroupCount = childCount - groupLeaderCount; - const { button, buttonArrow, expandedIcon } = useButtonStyles({ - isExpanded: !showGroupLeadersOnly, - }); - - if (sameGroupCount > 0) { - return ( - - -

- } - > - - - - -
- ); - } - return null; -}; - export const AlertButton = ({ isExpanded, onToggle, diff --git a/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx b/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx index b38b7335fe27e..d2e5b1b899553 100644 --- a/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx +++ b/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx @@ -42,6 +42,7 @@ export interface ProcessDeps { selectedProcessId?: string; timeStampOn?: boolean; verboseModeOn?: boolean; + searchResults?: Process[]; scrollerRef: RefObject; onChangeJumpToEventVisibility: (isVisible: boolean, isAbove: boolean) => void; onShowAlertDetails: (alertUuid: string) => void; @@ -60,6 +61,7 @@ export function ProcessTreeNode({ selectedProcessId, timeStampOn = true, verboseModeOn = true, + searchResults, scrollerRef, onChangeJumpToEventVisibility, onShowAlertDetails, @@ -171,6 +173,18 @@ export function ProcessTreeNode({ } }, [hasExec, process.parent]); + const children = useMemo(() => { + if (searchResults) { + // noop + // Only used to break cache on this memo when search changes. We need this ref + // to avoid complaints from the useEffect dependency eslint rule. + // This fixes an issue when verbose mode is OFF and there are matching results on + // hidden processes. + } + + return process.getChildren(verboseModeOn); + }, [process, verboseModeOn, searchResults]); + if (!processDetails?.process) { return null; } @@ -187,9 +201,7 @@ export function ProcessTreeNode({ start, } = processDetails.process; - const children = process.getChildren(verboseModeOn); - const childCount = process.getChildren(true).length; - const shouldRenderChildren = childrenExpanded && children && children.length > 0; + const shouldRenderChildren = childrenExpanded && children?.length > 0; const childrenTreeDepth = depth + 1; const showUserEscalation = user.id !== parent.user.id; @@ -261,7 +273,7 @@ export function ProcessTreeNode({ {user.name} )} - {!isSessionLeader && childCount > 0 && ( + {!isSessionLeader && children.length > 0 && ( )} {alerts.length > 0 && ( @@ -298,6 +310,7 @@ export function ProcessTreeNode({ selectedProcessId={selectedProcessId} timeStampOn={timeStampOn} verboseModeOn={verboseModeOn} + searchResults={searchResults} scrollerRef={scrollerRef} onChangeJumpToEventVisibility={onChangeJumpToEventVisibility} onShowAlertDetails={onShowAlertDetails} From 8d117ca3492c8036982857baebc3bdda1e9f3d2a Mon Sep 17 00:00:00 2001 From: Paulo Henrique Date: Mon, 28 Mar 2022 20:49:15 -0300 Subject: [PATCH 059/160] [Security solution][Session view] - Add Sessions tab into the Hosts page (#127920) * add Session Leader Table * WIP: Session Leader Table * sessions search strategy * session viewer component * add timelineId * remove session leader table * cleaning * cleaning * updating search strategy * add space for open in session viewer icon * add sessionEntityId as key cache * updating deep links * updating headers * adding filterQuery * adding timeline * add runtime fields to search strategy * updating comment * fixing tests * removing unecessary intermediate component * removing intermediary component * adding tests for session viewer * remove unnecessary runtime_mappings Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../security_solution/common/constants.ts | 1 + .../common/types/timeline/index.ts | 2 + x-pack/plugins/security_solution/kibana.json | 3 +- .../public/app/deep_links/index.ts | 7 + .../__snapshots__/index.test.tsx.snap | 107 ++++++++++++++ .../sessions_viewer/default_headers.ts | 63 ++++++++ .../components/sessions_viewer/index.test.tsx | 137 ++++++++++++++++++ .../components/sessions_viewer/index.tsx | 111 ++++++++++++++ .../sessions_viewer/translations.ts | 22 +++ .../components/sessions_viewer/types.ts | 18 +++ .../common/components/top_n/helpers.test.tsx | 1 + .../public/common/mock/global_state.ts | 2 + .../security_solution/public/hosts/index.ts | 1 + .../hosts/pages/details/details_tabs.tsx | 4 + .../public/hosts/pages/details/nav_tabs.tsx | 6 + .../public/hosts/pages/details/utils.ts | 1 + .../public/hosts/pages/hosts_tabs.tsx | 4 + .../public/hosts/pages/index.tsx | 6 +- .../public/hosts/pages/nav_tabs.tsx | 6 + .../public/hosts/pages/navigation/index.ts | 1 + .../pages/navigation/sessions_tab_body.tsx | 35 +++++ .../public/hosts/pages/translations.ts | 7 + .../public/hosts/store/helpers.test.ts | 16 ++ .../public/hosts/store/model.ts | 2 + .../public/hosts/store/reducer.ts | 8 + .../plugins/security_solution/public/types.ts | 3 +- .../plugins/security_solution/tsconfig.json | 3 +- x-pack/plugins/session_view/public/index.ts | 2 + x-pack/plugins/session_view/public/types.ts | 11 +- .../search_strategy/timeline/events/index.ts | 1 + .../timelines/common/types/timeline/index.ts | 2 + .../timelines/public/store/t_grid/types.ts | 1 + .../timeline/factory/helpers/constants.ts | 5 + .../server/search_strategy/timeline/index.ts | 55 +++++++ 34 files changed, 644 insertions(+), 10 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/common/components/sessions_viewer/__snapshots__/index.test.tsx.snap create mode 100644 x-pack/plugins/security_solution/public/common/components/sessions_viewer/default_headers.ts create mode 100644 x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.test.tsx create mode 100644 x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.tsx create mode 100644 x-pack/plugins/security_solution/public/common/components/sessions_viewer/translations.ts create mode 100644 x-pack/plugins/security_solution/public/common/components/sessions_viewer/types.ts create mode 100644 x-pack/plugins/security_solution/public/hosts/pages/navigation/sessions_tab_body.tsx diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index f205c6c439dc9..0d0802315063f 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -118,6 +118,7 @@ export enum SecurityPageName { users = 'users', usersAnomalies = 'users-anomalies', usersRisk = 'users-risk', + sessions = 'sessions', } export const TIMELINES_PATH = '/timelines' as const; diff --git a/x-pack/plugins/security_solution/common/types/timeline/index.ts b/x-pack/plugins/security_solution/common/types/timeline/index.ts index 5e933efbbc61d..93dd6f9efb671 100644 --- a/x-pack/plugins/security_solution/common/types/timeline/index.ts +++ b/x-pack/plugins/security_solution/common/types/timeline/index.ts @@ -318,6 +318,7 @@ export enum TimelineId { usersPageExternalAlerts = 'users-page-external-alerts', hostsPageEvents = 'hosts-page-events', hostsPageExternalAlerts = 'hosts-page-external-alerts', + hostsPageSessions = 'hosts-page-sessions', detectionsRulesDetailsPage = 'detections-rules-details-page', detectionsPage = 'detections-page', networkPageExternalAlerts = 'network-page-external-alerts', @@ -332,6 +333,7 @@ export const TimelineIdLiteralRt = runtimeTypes.union([ runtimeTypes.literal(TimelineId.usersPageExternalAlerts), runtimeTypes.literal(TimelineId.hostsPageEvents), runtimeTypes.literal(TimelineId.hostsPageExternalAlerts), + runtimeTypes.literal(TimelineId.hostsPageSessions), runtimeTypes.literal(TimelineId.detectionsRulesDetailsPage), runtimeTypes.literal(TimelineId.detectionsPage), runtimeTypes.literal(TimelineId.networkPageExternalAlerts), diff --git a/x-pack/plugins/security_solution/kibana.json b/x-pack/plugins/security_solution/kibana.json index 36edfd43d5ea5..bd18b5d4acc31 100644 --- a/x-pack/plugins/security_solution/kibana.json +++ b/x-pack/plugins/security_solution/kibana.json @@ -25,7 +25,8 @@ "taskManager", "timelines", "triggersActionsUi", - "uiActions" + "uiActions", + "sessionView" ], "optionalPlugins": [ "encryptedSavedObjects", diff --git a/x-pack/plugins/security_solution/public/app/deep_links/index.ts b/x-pack/plugins/security_solution/public/app/deep_links/index.ts index efb220467c9d0..2df243d9b2d41 100644 --- a/x-pack/plugins/security_solution/public/app/deep_links/index.ts +++ b/x-pack/plugins/security_solution/public/app/deep_links/index.ts @@ -221,6 +221,13 @@ export const securitySolutionsDeepLinks: SecuritySolutionDeepLink[] = [ path: `${HOSTS_PATH}/anomalies`, isPremium: true, }, + { + id: SecurityPageName.sessions, + title: i18n.translate('xpack.securitySolution.search.hosts.sessions', { + defaultMessage: 'Sessions', + }), + path: `${HOSTS_PATH}/sessions`, + }, ], }, { diff --git a/x-pack/plugins/security_solution/public/common/components/sessions_viewer/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000000..32268e2f21e7f --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/__snapshots__/index.test.tsx.snap @@ -0,0 +1,107 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SessionsView renders correctly against snapshot 1`] = ` + + .c1 { + width: 100%; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-flex: 1; + -webkit-flex-grow: 1; + -ms-flex-positive: 1; + flex-grow: 1; +} + +.c1 > * { + max-width: 100%; +} + +.c1 .inspectButtonComponent { + pointer-events: none; + opacity: 0; + -webkit-transition: opacity 250ms ease; + transition: opacity 250ms ease; +} + +.c1:hover .inspectButtonComponent { + pointer-events: auto; + opacity: 1; +} + +.c0 { + -webkit-flex: 1 1 auto; + -ms-flex: 1 1 auto; + flex: 1 1 auto; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + width: 100%; +} + +
+
+
+
+
+ sessions +
+
+ 2022-03-22T22:10:56.794Z +
+
+ 2022-03-21T22:10:56.791Z +
+
+ hosts-page-sessions +
+
+ process.start +
+
+ process.end +
+
+ process.executable +
+
+ user.name +
+
+ process.interactive +
+
+ process.pid +
+
+ host.hostname +
+
+ process.entry_leader.entry_meta.type +
+
+ process.entry_leader.entry_meta.source.ip +
+
+
+
+
+
+`; diff --git a/x-pack/plugins/security_solution/public/common/components/sessions_viewer/default_headers.ts b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/default_headers.ts new file mode 100644 index 0000000000000..ee2f2e5452298 --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/default_headers.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { ColumnHeaderOptions, RowRendererId } from '../../../../common/types/timeline'; +import { defaultColumnHeaderType } from '../../../timelines/components/timeline/body/column_headers/default_headers'; +import { DEFAULT_DATE_COLUMN_MIN_WIDTH } from '../../../timelines/components/timeline/body/constants'; +import { SubsetTimelineModel } from '../../../timelines/store/timeline/model'; +import { timelineDefaults } from '../../../timelines/store/timeline/defaults'; + +export const sessionsHeaders: ColumnHeaderOptions[] = [ + { + columnHeaderType: defaultColumnHeaderType, + id: 'process.start', + initialWidth: DEFAULT_DATE_COLUMN_MIN_WIDTH, + }, + // TODO: Using event.created as an way of getting the end time of the process. (Currently endpoint doesn't populate process.end) + // event.created of a event.action with value of "end" is what we consider that to be the end time of the process + // Current action are: 'start', 'exec', 'end', so we usually have three events per process. + { + columnHeaderType: defaultColumnHeaderType, + id: 'event.created', + display: 'process.end', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'process.executable', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'user.name', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'process.interactive', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'process.pid', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'host.hostname', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'process.entry_leader.entry_meta.type', + }, + { + columnHeaderType: defaultColumnHeaderType, + id: 'process.entry_leader.entry_meta.source.ip', + }, +]; + +export const sessionsDefaultModel: SubsetTimelineModel = { + ...timelineDefaults, + columns: sessionsHeaders, + defaultColumns: sessionsHeaders, + excludedRowRendererIds: Object.values(RowRendererId), +}; diff --git a/x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.test.tsx b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.test.tsx new file mode 100644 index 0000000000000..eb1b75b81a94b --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.test.tsx @@ -0,0 +1,137 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useEffect } from 'react'; +import { waitFor, render } from '@testing-library/react'; +import { TestProviders } from '../../mock'; +import { TEST_ID, SessionsView, defaultSessionsFilter } from '.'; +import { EntityType, TimelineId } from '../../../../../timelines/common'; +import { SessionsComponentsProps } from './types'; +import { TimelineModel } from '../../../timelines/store/timeline/model'; + +jest.mock('../../../common/lib/kibana'); + +jest.mock('../../components/url_state/normalize_time_range.ts'); + +const startDate = '2022-03-22T22:10:56.794Z'; +const endDate = '2022-03-21T22:10:56.791Z'; + +const filterQuery = + '{"bool":{"must":[],"filter":[{"match_phrase":{"host.name":{"query":"ubuntu-impish"}}}],"should":[],"must_not":[]}}'; + +const testProps: SessionsComponentsProps = { + timelineId: TimelineId.hostsPageSessions, + entityType: 'sessions', + pageFilters: [], + startDate, + endDate, + filterQuery, +}; + +type Props = Partial & { + start: string; + end: string; + entityType: EntityType; +}; + +const TEST_PREFIX = 'security_solution:sessions_viewer:sessions_view'; + +const callFilters = jest.fn(); + +// creating a dummy component for testing TGrid to avoid mocking all the implementation details +// but still test if the TGrid will render properly +const SessionsViewerTGrid: React.FC = ({ columns, start, end, id, filters, entityType }) => { + useEffect(() => { + callFilters(filters); + }, [filters]); + + return ( +
+
{entityType}
+
{start}
+
{end}
+
{id}
+ {columns?.map((header) => ( +
{header.display ?? header.id}
+ ))} +
+ ); +}; + +jest.mock('../../../../../timelines/public/mock/plugin_mock.tsx', () => { + const originalModule = jest.requireActual('../../../../../timelines/public/mock/plugin_mock.tsx'); + return { + ...originalModule, + createTGridMocks: () => ({ + ...originalModule.createTGridMocks, + getTGrid: SessionsViewerTGrid, + }), + }; +}); + +describe('SessionsView', () => { + it('renders the session view', async () => { + const wrapper = render( + + + + ); + + await waitFor(() => { + expect(wrapper.queryByTestId(TEST_ID)).toBeInTheDocument(); + }); + }); + + it('renders correctly against snapshot', async () => { + const { asFragment } = render( + + + + ); + + await waitFor(() => { + expect(asFragment()).toMatchSnapshot(); + }); + }); + + it('passes in the right parameters to TGrid', async () => { + const wrapper = render( + + + + ); + await waitFor(() => { + expect(wrapper.getByTestId(`${TEST_PREFIX}:entityType`)).toHaveTextContent('sessions'); + expect(wrapper.getByTestId(`${TEST_PREFIX}:startDate`)).toHaveTextContent(startDate); + expect(wrapper.getByTestId(`${TEST_PREFIX}:endDate`)).toHaveTextContent(endDate); + expect(wrapper.getByTestId(`${TEST_PREFIX}:timelineId`)).toHaveTextContent( + 'hosts-page-sessions' + ); + }); + }); + it('passes in the right filters to TGrid', async () => { + render( + + + + ); + await waitFor(() => { + expect(callFilters).toHaveBeenCalledWith([ + { + ...defaultSessionsFilter, + query: { + ...defaultSessionsFilter.query, + bool: { + ...defaultSessionsFilter.query.bool, + filter: defaultSessionsFilter.query.bool.filter.concat(JSON.parse(filterQuery)), + }, + }, + }, + ]); + }); + }); +}); diff --git a/x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.tsx b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.tsx new file mode 100644 index 0000000000000..3005d59bdc738 --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/index.tsx @@ -0,0 +1,111 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useMemo } from 'react'; +import type { Filter } from '@kbn/es-query'; +import { SessionsComponentsProps } from './types'; +import { ESBoolQuery } from '../../../../common/typed_json'; +import { StatefulEventsViewer } from '../events_viewer'; +import { sessionsDefaultModel } from './default_headers'; +import { defaultRowRenderers } from '../../../timelines/components/timeline/body/renderers'; +import { DefaultCellRenderer } from '../../../timelines/components/timeline/cell_rendering/default_cell_renderer'; +import * as i18n from './translations'; +import { SourcererScopeName } from '../../store/sourcerer/model'; +import { getDefaultControlColumn } from '../../../timelines/components/timeline/body/control_columns'; + +export const TEST_ID = 'security_solution:sessions_viewer:sessions_view'; + +export const defaultSessionsFilter: Required> = { + query: { + bool: { + filter: [ + { + bool: { + should: [ + { + match: { + // TODO: update to process.entry_leader.same_as_process once ECS is updated to support same_as_process + 'process.is_entry_leader': true, + }, + }, + ], + minimum_should_match: 1, + }, + }, + ], + }, + }, + meta: { + alias: null, + disabled: false, + key: 'process.is_entry_leader', + negate: false, + params: {}, + type: 'boolean', + }, +}; + +const SessionsViewComponent: React.FC = ({ + timelineId, + endDate, + entityType = 'sessions', + pageFilters, + startDate, + filterQuery, +}) => { + const parsedFilterQuery: ESBoolQuery = useMemo(() => { + if (filterQuery && filterQuery !== '') { + return JSON.parse(filterQuery); + } + return {}; + }, [filterQuery]); + + const sessionsFilter = useMemo( + () => [ + { + ...defaultSessionsFilter, + query: { + ...defaultSessionsFilter.query, + bool: { + ...defaultSessionsFilter.query.bool, + filter: defaultSessionsFilter.query.bool.filter.concat(parsedFilterQuery), + }, + }, + }, + ...pageFilters, + ], + [pageFilters, parsedFilterQuery] + ); + + const ACTION_BUTTON_COUNT = 5; + const leadingControlColumns = useMemo(() => getDefaultControlColumn(ACTION_BUTTON_COUNT), []); + + const unit = (c: number) => + c > 1 ? i18n.TOTAL_COUNT_OF_SESSIONS : i18n.SINGLE_COUNT_OF_SESSIONS; + + return ( +
+ +
+ ); +}; + +SessionsViewComponent.displayName = 'SessionsViewComponent'; + +export const SessionsView = React.memo(SessionsViewComponent); diff --git a/x-pack/plugins/security_solution/public/common/components/sessions_viewer/translations.ts b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/translations.ts new file mode 100644 index 0000000000000..606ae2b46fc6a --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/translations.ts @@ -0,0 +1,22 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { i18n } from '@kbn/i18n'; + +export const TOTAL_COUNT_OF_SESSIONS = i18n.translate( + 'xpack.securitySolution.sessionsView.totalCountOfSessions', + { + defaultMessage: 'sessions', + } +); + +export const SINGLE_COUNT_OF_SESSIONS = i18n.translate( + 'xpack.securitySolution.sessionsView.singleCountOfSessions', + { + defaultMessage: 'session', + } +); diff --git a/x-pack/plugins/security_solution/public/common/components/sessions_viewer/types.ts b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/types.ts new file mode 100644 index 0000000000000..3c1a73a3292b3 --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/components/sessions_viewer/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import type { Filter } from '@kbn/es-query'; +import type { EntityType } from '../../../../../timelines/common'; +import { QueryTabBodyProps } from '../../../hosts/pages/navigation/types'; +import { TimelineIdLiteral } from '../../../../common/types/timeline'; + +export interface SessionsComponentsProps extends Pick { + timelineId: TimelineIdLiteral; + pageFilters: Filter[]; + defaultFilters?: Filter[]; + entityType?: EntityType; + filterQuery?: string; +} diff --git a/x-pack/plugins/security_solution/public/common/components/top_n/helpers.test.tsx b/x-pack/plugins/security_solution/public/common/components/top_n/helpers.test.tsx index 6c87dafef942e..10613efc265ae 100644 --- a/x-pack/plugins/security_solution/public/common/components/top_n/helpers.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/top_n/helpers.test.tsx @@ -28,6 +28,7 @@ const detectionAlertsTimelines = [TimelineId.detectionsPage, TimelineId.detectio const otherTimelines = [ TimelineId.hostsPageEvents, TimelineId.hostsPageExternalAlerts, + TimelineId.hostsPageSessions, TimelineId.networkPageExternalAlerts, TimelineId.active, TimelineId.casePage, diff --git a/x-pack/plugins/security_solution/public/common/mock/global_state.ts b/x-pack/plugins/security_solution/public/common/mock/global_state.ts index 9882ca9f3ab3d..bd90892a43fc6 100644 --- a/x-pack/plugins/security_solution/public/common/mock/global_state.ts +++ b/x-pack/plugins/security_solution/public/common/mock/global_state.ts @@ -88,6 +88,7 @@ export const mockGlobalState: State = { sort: { field: RiskScoreFields.riskScore, direction: Direction.desc }, severitySelection: [], }, + sessions: { activePage: 0, limit: 10 }, }, }, details: { @@ -109,6 +110,7 @@ export const mockGlobalState: State = { sort: { field: RiskScoreFields.riskScore, direction: Direction.desc }, severitySelection: [], }, + sessions: { activePage: 0, limit: 10 }, }, }, }, diff --git a/x-pack/plugins/security_solution/public/hosts/index.ts b/x-pack/plugins/security_solution/public/hosts/index.ts index cbb539f8e4107..f818a812b57a3 100644 --- a/x-pack/plugins/security_solution/public/hosts/index.ts +++ b/x-pack/plugins/security_solution/public/hosts/index.ts @@ -15,6 +15,7 @@ import { initialHostsState, hostsReducer, HostsState } from './store'; const HOST_TIMELINE_IDS: TimelineIdLiteral[] = [ TimelineId.hostsPageEvents, TimelineId.hostsPageExternalAlerts, + TimelineId.hostsPageSessions, ]; export class Hosts { diff --git a/x-pack/plugins/security_solution/public/hosts/pages/details/details_tabs.tsx b/x-pack/plugins/security_solution/public/hosts/pages/details/details_tabs.tsx index 142f3b922f842..7baa72b31ae07 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/details/details_tabs.tsx +++ b/x-pack/plugins/security_solution/public/hosts/pages/details/details_tabs.tsx @@ -26,6 +26,7 @@ import { UncommonProcessQueryTabBody, HostAlertsQueryTabBody, HostRiskTabBody, + SessionsTabBody, } from '../navigation'; import { TimelineId } from '../../../../common/types'; @@ -111,6 +112,9 @@ export const HostDetailsTabs = React.memo( + + + ); } diff --git a/x-pack/plugins/security_solution/public/hosts/pages/details/nav_tabs.tsx b/x-pack/plugins/security_solution/public/hosts/pages/details/nav_tabs.tsx index 33cafd8ef2114..eb22e69e14c43 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/details/nav_tabs.tsx +++ b/x-pack/plugins/security_solution/public/hosts/pages/details/nav_tabs.tsx @@ -62,6 +62,12 @@ export const navTabsHostDetails = ({ href: getTabsOnHostDetailsUrl(hostName, HostsTableType.risk), disabled: false, }, + [HostsTableType.sessions]: { + id: HostsTableType.sessions, + name: i18n.NAVIGATION_SESSIONS_TITLE, + href: getTabsOnHostDetailsUrl(hostName, HostsTableType.sessions), + disabled: false, + }, }; if (!hasMlUserPermissions) { diff --git a/x-pack/plugins/security_solution/public/hosts/pages/details/utils.ts b/x-pack/plugins/security_solution/public/hosts/pages/details/utils.ts index 19975b6ad7abb..346ac7bf3517b 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/details/utils.ts +++ b/x-pack/plugins/security_solution/public/hosts/pages/details/utils.ts @@ -28,6 +28,7 @@ const TabNameMappedToI18nKey: Record = { [HostsTableType.events]: i18n.NAVIGATION_EVENTS_TITLE, [HostsTableType.alerts]: i18n.NAVIGATION_ALERTS_TITLE, [HostsTableType.risk]: i18n.NAVIGATION_HOST_RISK_TITLE, + [HostsTableType.sessions]: i18n.NAVIGATION_SESSIONS_TITLE, }; export const getBreadcrumbs = ( diff --git a/x-pack/plugins/security_solution/public/hosts/pages/hosts_tabs.tsx b/x-pack/plugins/security_solution/public/hosts/pages/hosts_tabs.tsx index d7c615c08ec28..ed2a1ec983b20 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/hosts_tabs.tsx +++ b/x-pack/plugins/security_solution/public/hosts/pages/hosts_tabs.tsx @@ -23,6 +23,7 @@ import { HostRiskScoreQueryTabBody, AuthenticationsQueryTabBody, UncommonProcessQueryTabBody, + SessionsTabBody, } from './navigation'; import { HostAlertsQueryTabBody } from './navigation/alerts_query_tab_body'; import { TimelineId } from '../../../common/types'; @@ -103,6 +104,9 @@ export const HostsTabs = memo( + + + ); } diff --git a/x-pack/plugins/security_solution/public/hosts/pages/index.tsx b/x-pack/plugins/security_solution/public/hosts/pages/index.tsx index 453d6182984c1..e42be25941ea7 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/index.tsx +++ b/x-pack/plugins/security_solution/public/hosts/pages/index.tsx @@ -23,7 +23,8 @@ const getHostsTabPath = () => `${HostsTableType.anomalies}|` + `${HostsTableType.events}|` + `${HostsTableType.risk}|` + - `${HostsTableType.alerts})`; + `${HostsTableType.alerts}|` + + `${HostsTableType.sessions})`; const getHostDetailsTabPath = () => `${hostDetailsPagePath}/:tabName(` + @@ -32,7 +33,8 @@ const getHostDetailsTabPath = () => `${HostsTableType.anomalies}|` + `${HostsTableType.events}|` + `${HostsTableType.risk}|` + - `${HostsTableType.alerts})`; + `${HostsTableType.alerts}|` + + `${HostsTableType.sessions})`; export const HostsContainer = React.memo(() => ( diff --git a/x-pack/plugins/security_solution/public/hosts/pages/nav_tabs.tsx b/x-pack/plugins/security_solution/public/hosts/pages/nav_tabs.tsx index 789273da073e9..59fb0d08f7dc7 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/nav_tabs.tsx +++ b/x-pack/plugins/security_solution/public/hosts/pages/nav_tabs.tsx @@ -66,6 +66,12 @@ export const navTabsHosts = ({ href: getTabsOnHostsUrl(HostsTableType.risk), disabled: false, }, + [HostsTableType.sessions]: { + id: HostsTableType.sessions, + name: i18n.NAVIGATION_SESSIONS_TITLE, + href: getTabsOnHostsUrl(HostsTableType.sessions), + disabled: false, + }, }; if (!hasMlUserPermissions) { diff --git a/x-pack/plugins/security_solution/public/hosts/pages/navigation/index.ts b/x-pack/plugins/security_solution/public/hosts/pages/navigation/index.ts index 3ef211e1aef33..5ebbc61cabe41 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/navigation/index.ts +++ b/x-pack/plugins/security_solution/public/hosts/pages/navigation/index.ts @@ -11,3 +11,4 @@ export * from './uncommon_process_query_tab_body'; export * from './alerts_query_tab_body'; export * from './host_risk_tab_body'; export * from './host_risk_score_tab_body'; +export * from './sessions_tab_body'; diff --git a/x-pack/plugins/security_solution/public/hosts/pages/navigation/sessions_tab_body.tsx b/x-pack/plugins/security_solution/public/hosts/pages/navigation/sessions_tab_body.tsx new file mode 100644 index 0000000000000..0ff47a104ca21 --- /dev/null +++ b/x-pack/plugins/security_solution/public/hosts/pages/navigation/sessions_tab_body.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useMemo } from 'react'; +import { TimelineId } from '../../../../common/types/timeline'; +import { SessionsView } from '../../../common/components/sessions_viewer'; +import { filterHostExternalAlertData } from '../../../common/components/visualization_actions/utils'; +import { AlertsComponentQueryProps } from './types'; + +export const SessionsTabBody = React.memo((alertsProps: AlertsComponentQueryProps) => { + const { pageFilters, filterQuery, ...rest } = alertsProps; + const hostPageFilters = useMemo( + () => + pageFilters != null + ? [...filterHostExternalAlertData, ...pageFilters] + : filterHostExternalAlertData, + [pageFilters] + ); + + return ( + + ); +}); + +SessionsTabBody.displayName = 'SessionsTabBody'; diff --git a/x-pack/plugins/security_solution/public/hosts/pages/translations.ts b/x-pack/plugins/security_solution/public/hosts/pages/translations.ts index c2ece6c40e701..8b92ef035405f 100644 --- a/x-pack/plugins/security_solution/public/hosts/pages/translations.ts +++ b/x-pack/plugins/security_solution/public/hosts/pages/translations.ts @@ -64,6 +64,13 @@ export const NAVIGATION_HOST_RISK_TITLE = i18n.translate( } ); +export const NAVIGATION_SESSIONS_TITLE = i18n.translate( + 'xpack.securitySolution.hosts.navigation.sessionsTitle', + { + defaultMessage: 'Sessions', + } +); + export const ERROR_FETCHING_AUTHENTICATIONS_DATA = i18n.translate( 'xpack.securitySolution.hosts.navigaton.matrixHistogram.errorFetchingAuthenticationsData', { diff --git a/x-pack/plugins/security_solution/public/hosts/store/helpers.test.ts b/x-pack/plugins/security_solution/public/hosts/store/helpers.test.ts index 64e4d9088abd7..111b7f0e79737 100644 --- a/x-pack/plugins/security_solution/public/hosts/store/helpers.test.ts +++ b/x-pack/plugins/security_solution/public/hosts/store/helpers.test.ts @@ -45,6 +45,10 @@ export const mockHostsState: HostsModel = { }, severitySelection: [], }, + [HostsTableType.sessions]: { + activePage: DEFAULT_TABLE_ACTIVE_PAGE, + limit: DEFAULT_TABLE_LIMIT, + }, }, }, details: { @@ -81,6 +85,10 @@ export const mockHostsState: HostsModel = { }, severitySelection: [], }, + [HostsTableType.sessions]: { + activePage: DEFAULT_TABLE_ACTIVE_PAGE, + limit: DEFAULT_TABLE_LIMIT, + }, }, }, }; @@ -121,6 +129,10 @@ describe('Hosts redux store', () => { field: 'risk_stats.risk_score', }, }, + [HostsTableType.sessions]: { + activePage: 0, + limit: 10, + }, }); }); @@ -158,6 +170,10 @@ describe('Hosts redux store', () => { field: 'risk_stats.risk_score', }, }, + [HostsTableType.sessions]: { + activePage: 0, + limit: 10, + }, }); }); }); diff --git a/x-pack/plugins/security_solution/public/hosts/store/model.ts b/x-pack/plugins/security_solution/public/hosts/store/model.ts index 090a469c5fb76..09bec3643c4d4 100644 --- a/x-pack/plugins/security_solution/public/hosts/store/model.ts +++ b/x-pack/plugins/security_solution/public/hosts/store/model.ts @@ -25,6 +25,7 @@ export enum HostsTableType { anomalies = 'anomalies', alerts = 'externalAlerts', risk = 'hostRisk', + sessions = 'sessions', } export interface BasicQueryPaginated { @@ -50,6 +51,7 @@ export interface Queries { [HostsTableType.anomalies]: null | undefined; [HostsTableType.alerts]: BasicQueryPaginated; [HostsTableType.risk]: HostRiskScoreQuery; + [HostsTableType.sessions]: BasicQueryPaginated; } export interface GenericHostsModel { diff --git a/x-pack/plugins/security_solution/public/hosts/store/reducer.ts b/x-pack/plugins/security_solution/public/hosts/store/reducer.ts index f413607b85e1c..1ea20bf5e2871 100644 --- a/x-pack/plugins/security_solution/public/hosts/store/reducer.ts +++ b/x-pack/plugins/security_solution/public/hosts/store/reducer.ts @@ -62,6 +62,10 @@ export const initialHostsState: HostsState = { }, severitySelection: [], }, + [HostsTableType.sessions]: { + activePage: DEFAULT_TABLE_ACTIVE_PAGE, + limit: DEFAULT_TABLE_LIMIT, + }, }, }, details: { @@ -98,6 +102,10 @@ export const initialHostsState: HostsState = { }, severitySelection: [], }, + [HostsTableType.sessions]: { + activePage: DEFAULT_TABLE_ACTIVE_PAGE, + limit: DEFAULT_TABLE_LIMIT, + }, }, }, }; diff --git a/x-pack/plugins/security_solution/public/types.ts b/x-pack/plugins/security_solution/public/types.ts index 0916bc73f4198..65ca8466ef00a 100644 --- a/x-pack/plugins/security_solution/public/types.ts +++ b/x-pack/plugins/security_solution/public/types.ts @@ -25,11 +25,11 @@ import type { import type { CasesUiStart } from '../../cases/public'; import type { SecurityPluginSetup } from '../../security/public'; import type { TimelinesUIStart } from '../../timelines/public'; +import type { SessionViewUIStart } from '../../session_view/public'; import type { ResolverPluginSetup } from './resolver/types'; import type { Inspect } from '../common/search_strategy'; import type { MlPluginSetup, MlPluginStart } from '../../ml/public'; import type { OsqueryPluginStart } from '../../osquery/public'; - import type { Detections } from './detections'; import type { Cases } from './cases'; import type { Exceptions } from './exceptions'; @@ -71,6 +71,7 @@ export interface StartPlugins { spaces?: SpacesPluginStart; dataViewFieldEditor: IndexPatternFieldEditorStart; osquery?: OsqueryPluginStart; + sessionView: SessionViewUIStart; } export type StartServices = CoreStart & diff --git a/x-pack/plugins/security_solution/tsconfig.json b/x-pack/plugins/security_solution/tsconfig.json index b1cb49b737952..e6b5a79540458 100644 --- a/x-pack/plugins/security_solution/tsconfig.json +++ b/x-pack/plugins/security_solution/tsconfig.json @@ -42,6 +42,7 @@ { "path": "../osquery/tsconfig.json" }, { "path": "../spaces/tsconfig.json" }, { "path": "../security/tsconfig.json" }, - { "path": "../timelines/tsconfig.json" } + { "path": "../timelines/tsconfig.json" }, + { "path": "../session_view/tsconfig.json" } ] } diff --git a/x-pack/plugins/session_view/public/index.ts b/x-pack/plugins/session_view/public/index.ts index 90043e9a691dc..3d66164bfec4f 100644 --- a/x-pack/plugins/session_view/public/index.ts +++ b/x-pack/plugins/session_view/public/index.ts @@ -7,6 +7,8 @@ import { SessionViewPlugin } from './plugin'; +export type { SessionViewUIStart } from './types'; + export function plugin() { return new SessionViewPlugin(); } diff --git a/x-pack/plugins/session_view/public/types.ts b/x-pack/plugins/session_view/public/types.ts index a2099d11275f8..8c98912250865 100644 --- a/x-pack/plugins/session_view/public/types.ts +++ b/x-pack/plugins/session_view/public/types.ts @@ -4,14 +4,15 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import { ReactNode } from 'react'; +import { ReactElement, ReactNode } from 'react'; import { CoreStart } from '../../../../src/core/public'; -import { TimelinesUIStart } from '../../timelines/public'; import { ProcessEvent, Teletype } from '../common/types/process_tree'; -export type SessionViewServices = CoreStart & { - timelines: TimelinesUIStart; -}; +export type SessionViewServices = CoreStart; + +export interface SessionViewUIStart { + getSessionView: (sessionEntityId: string) => ReactElement; +} export interface SessionViewDeps { // the root node of the process tree to render. e.g process.entry.entity_id or process.session_leader.entity_id diff --git a/x-pack/plugins/timelines/common/search_strategy/timeline/events/index.ts b/x-pack/plugins/timelines/common/search_strategy/timeline/events/index.ts index 6b204224d3d5d..f7df9bfde3d05 100644 --- a/x-pack/plugins/timelines/common/search_strategy/timeline/events/index.ts +++ b/x-pack/plugins/timelines/common/search_strategy/timeline/events/index.ts @@ -20,5 +20,6 @@ export enum TimelineEventsQueries { export const EntityType = { ALERTS: 'alerts', EVENTS: 'events', + SESSIONS: 'sessions', } as const; export type EntityType = typeof EntityType[keyof typeof EntityType]; diff --git a/x-pack/plugins/timelines/common/types/timeline/index.ts b/x-pack/plugins/timelines/common/types/timeline/index.ts index 1e12baf13c2db..e7a0faf261318 100644 --- a/x-pack/plugins/timelines/common/types/timeline/index.ts +++ b/x-pack/plugins/timelines/common/types/timeline/index.ts @@ -314,6 +314,7 @@ export enum TimelineId { usersPageExternalAlerts = 'users-page-external-alerts', hostsPageEvents = 'hosts-page-events', hostsPageExternalAlerts = 'hosts-page-external-alerts', + hostsPageSessions = 'hosts-page-sessions', detectionsRulesDetailsPage = 'detections-rules-details-page', detectionsPage = 'detections-page', networkPageExternalAlerts = 'network-page-external-alerts', @@ -326,6 +327,7 @@ export enum TimelineId { export const TimelineIdLiteralRt = runtimeTypes.union([ runtimeTypes.literal(TimelineId.hostsPageEvents), runtimeTypes.literal(TimelineId.hostsPageExternalAlerts), + runtimeTypes.literal(TimelineId.hostsPageSessions), runtimeTypes.literal(TimelineId.detectionsRulesDetailsPage), runtimeTypes.literal(TimelineId.detectionsPage), runtimeTypes.literal(TimelineId.networkPageExternalAlerts), diff --git a/x-pack/plugins/timelines/public/store/t_grid/types.ts b/x-pack/plugins/timelines/public/store/t_grid/types.ts index dfa8331669535..b065a5e1b1e95 100644 --- a/x-pack/plugins/timelines/public/store/t_grid/types.ts +++ b/x-pack/plugins/timelines/public/store/t_grid/types.ts @@ -46,6 +46,7 @@ export enum TimelineId { usersPageExternalAlerts = 'users-page-external-alerts', hostsPageEvents = 'hosts-page-events', hostsPageExternalAlerts = 'hosts-page-external-alerts', + hostsPageSessions = 'hosts-page-sessions', detectionsRulesDetailsPage = 'detections-rules-details-page', detectionsPage = 'detections-page', networkPageExternalAlerts = 'network-page-external-alerts', diff --git a/x-pack/plugins/timelines/server/search_strategy/timeline/factory/helpers/constants.ts b/x-pack/plugins/timelines/server/search_strategy/timeline/factory/helpers/constants.ts index e764e32243c18..b0dd730c749d2 100644 --- a/x-pack/plugins/timelines/server/search_strategy/timeline/factory/helpers/constants.ts +++ b/x-pack/plugins/timelines/server/search_strategy/timeline/factory/helpers/constants.ts @@ -199,10 +199,14 @@ export const TIMELINE_EVENTS_FIELDS = [ 'tls.server_certificate.fingerprint.sha1', 'user.domain', 'winlog.event_id', + 'process.end', + 'process.entry_leader.entry_meta.type', + 'process.entry_leader.entry_meta.source.ip', 'process.exit_code', 'process.hash.md5', 'process.hash.sha1', 'process.hash.sha256', + 'process.interactive', 'process.parent.name', 'process.parent.pid', 'process.pid', @@ -211,6 +215,7 @@ export const TIMELINE_EVENTS_FIELDS = [ 'process.args', 'process.entity_id', 'process.executable', + 'process.start', 'process.title', 'process.working_directory', 'zeek.session_id', diff --git a/x-pack/plugins/timelines/server/search_strategy/timeline/index.ts b/x-pack/plugins/timelines/server/search_strategy/timeline/index.ts index 24e0edb5ddcc0..a5ef2f57888da 100644 --- a/x-pack/plugins/timelines/server/search_strategy/timeline/index.ts +++ b/x-pack/plugins/timelines/server/search_strategy/timeline/index.ts @@ -64,6 +64,14 @@ export const timelineSearchStrategyProvider = ({ }) ); }; + +const timelineSessionsSearchStrategy = ({ + es, + request, + options, + deps, + queryFactory, +}: { + es: ISearchStrategy; + request: TimelineStrategyRequestType; + options: ISearchOptions; + deps: SearchStrategyDependencies; + queryFactory: TimelineFactory; +}) => { + const indices = request.defaultIndex ?? request.indexType; + + const runtimeMappings = { + // TODO: remove once ECS is updated to support process.entry_leader.same_as_process + 'process.is_entry_leader': { + type: 'boolean', + script: { + source: + "emit(doc.containsKey('process.entry_leader.entity_id') && doc['process.entry_leader.entity_id'].size() > 0 && doc['process.entity_id'].value == doc['process.entry_leader.entity_id'].value)", + }, + }, + }; + + const requestSessionLeaders = { + ...request, + defaultIndex: indices, + indexName: indices, + }; + + const dsl = queryFactory.buildDsl(requestSessionLeaders); + + const params = { ...dsl, runtime_mappings: runtimeMappings }; + + return es.search({ ...requestSessionLeaders, params }, options, deps).pipe( + map((response) => { + return { + ...response, + rawResponse: shimHitsTotal(response.rawResponse, options), + }; + }), + mergeMap((esSearchRes) => queryFactory.parse(requestSessionLeaders, esSearchRes)) + ); +}; From ecd2a50c19200e8f01d439374738773682a1d5af Mon Sep 17 00:00:00 2001 From: Vadim Yakhin Date: Mon, 28 Mar 2022 17:06:33 -0700 Subject: [PATCH 060/160] Add Elasticsearch guide (#128190) * Add basic elasticsearch card and page * Add more content and styles * Update content * Add language client select * Get client language from URL * Add language instructions * Make designs close to pixel perfect * Add i18n strings * Add elasticsearch_cloud_id component and tests Co-authored-by: joemcelroy * Fix linter errors * Use i18n instead of FormattedMessage for consistency * Remove redundant FormattedMessage * include cloud deployment link in UI * Add instructions for all language clients * Rewrite language selector with switch * Add missing target blank * Remove trailing whitespace in code blocks * Fix i18n * Invert ruby instructions * Update page layout * Add syntax highlighting * Remove PERL * Reorder languages * Add placeholder for elasticsearch version * Change docs version to current * Add missing links * Add target="_blank" to links * Simplify strong prop * Fix column stretching from Kibana PR Cloud ID in code blocks * Fix page keeping the scroll position * Fix typo * Adhere to writing guidelines * Use docLinks service * Update dotnet guide * Use elasticsearch query dsl link instead of creating a new one for Ruby client * Update php connecting link Looks like it was fixed in `master`, but not in `current` docs. Since the PR is going to master, we could use the corrected link Co-authored-by: joemcelroy Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- packages/kbn-doc-links/src/get_doc_links.ts | 17 ++ packages/kbn-doc-links/src/types.ts | 16 ++ .../elasticsearch_card/elasticsearch_card.tsx | 54 +++++ .../components/elasticsearch_card/index.ts | 8 + .../elasticsearch_client_instructions.tsx | 51 +++++ .../elasticsearch_dotnet.tsx | 155 ++++++++++++++ .../elasticsearch_go.tsx | 139 ++++++++++++ .../elasticsearch_java.tsx | 107 ++++++++++ .../elasticsearch_javascript.tsx | 97 +++++++++ .../elasticsearch_php.tsx | 113 ++++++++++ .../elasticsearch_python.tsx | 163 ++++++++++++++ .../elasticsearch_ruby.tsx | 161 ++++++++++++++ .../elasticsearch_rust.tsx | 89 ++++++++ .../index.ts | 8 + .../elasticsearch_cloud_id.test.tsx | 99 +++++++++ .../elasticsearch_cloud_id.tsx | 149 +++++++++++++ .../elasticsearch_cloud_id/index.ts | 8 + .../elasticsearch_guide.tsx | 198 ++++++++++++++++++ .../components/elasticsearch_guide/index.ts | 8 + .../elasticsearch_resources.tsx | 57 +++++ .../elasticsearch_resources/index.ts | 8 + .../product_selector/product_selector.tsx | 5 + .../enterprise_search_overview/index.tsx | 6 +- .../enterprise_search_overview/routes.ts | 1 + .../shared/doc_links/doc_links.ts | 66 ++++++ 25 files changed, 1782 insertions(+), 1 deletion(-) create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/elasticsearch_card.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/index.ts create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/index.ts create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.test.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/index.ts create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/index.ts create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/elasticsearch_resources.tsx create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/index.ts diff --git a/packages/kbn-doc-links/src/get_doc_links.ts b/packages/kbn-doc-links/src/get_doc_links.ts index d0ff7dc704f76..c31aaab76e2ad 100644 --- a/packages/kbn-doc-links/src/get_doc_links.ts +++ b/packages/kbn-doc-links/src/get_doc_links.ts @@ -243,6 +243,7 @@ export const getDocLinks = ({ kibanaBranch }: GetDocLinkOptions): DocLinks => { dataStreams: `${ELASTICSEARCH_DOCS}data-streams.html`, deprecationLogging: `${ELASTICSEARCH_DOCS}logging.html#deprecation-logging`, frozenIndices: `${ELASTICSEARCH_DOCS}frozen-indices.html`, + gettingStarted: `${ELASTICSEARCH_DOCS}getting-started.html`, hiddenIndices: `${ELASTICSEARCH_DOCS}multi-index.html#hidden`, ilm: `${ELASTICSEARCH_DOCS}index-lifecycle-management.html`, ilmForceMerge: `${ELASTICSEARCH_DOCS}ilm-forcemerge.html`, @@ -598,15 +599,31 @@ export const getDocLinks = ({ kibanaBranch }: GetDocLinkOptions): DocLinks => { clients: { /** Changes to these URLs must also be synched in src/plugins/custom_integrations/server/language_clients/index.ts */ guide: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/index.html`, + goIndex: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/go-api/${DOC_LINK_VERSION}/index.html`, goOverview: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/go-api/${DOC_LINK_VERSION}/overview.html`, + javaBasicAuthentication: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/java-api-client/${DOC_LINK_VERSION}/_basic_authentication.html`, javaIndex: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/java-api-client/${DOC_LINK_VERSION}/index.html`, + javaInstallation: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/java-api-client/${DOC_LINK_VERSION}/installation.html`, + javaIntroduction: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/java-api-client/${DOC_LINK_VERSION}/introduction.html`, + javaRestLow: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/java-api-client/${DOC_LINK_VERSION}/java-rest-low.html`, + jsClientConnecting: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/javascript-api/${DOC_LINK_VERSION}/client-connecting.html`, jsIntro: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/javascript-api/${DOC_LINK_VERSION}/introduction.html`, netGuide: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/net-api/${DOC_LINK_VERSION}/index.html`, + netIntroduction: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/net-api/${DOC_LINK_VERSION}/introduction.html`, + netNest: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/net-api/${DOC_LINK_VERSION}/nest.html`, + netSingleNode: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/net-api/${DOC_LINK_VERSION}/connecting.html#single-node`, perlGuide: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/perl-api/${DOC_LINK_VERSION}/index.html`, + phpConnecting: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/php-api/${DOC_LINK_VERSION}/connecting.html`, + phpInstallation: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/php-api/${DOC_LINK_VERSION}/installation.html`, phpGuide: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/php-api/${DOC_LINK_VERSION}/index.html`, + phpOverview: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/php-api/${DOC_LINK_VERSION}/overview.html`, + pythonAuthentication: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/python-api/${DOC_LINK_VERSION}/connecting.html#authentication`, pythonGuide: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/python-api/${DOC_LINK_VERSION}/index.html`, + pythonOverview: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/python-api/${DOC_LINK_VERSION}/overview.html`, + rubyAuthentication: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/ruby-api/${DOC_LINK_VERSION}/connecting.html#client-auth`, rubyOverview: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/ruby-api/${DOC_LINK_VERSION}/ruby_client.html`, rustGuide: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/rust-api/${DOC_LINK_VERSION}/index.html`, + rustOverview: `${ELASTIC_WEBSITE_URL}guide/en/elasticsearch/client/rust-api/${DOC_LINK_VERSION}/overview.html`, }, endpoints: { troubleshooting: `${ELASTIC_WEBSITE_URL}guide/en/security/${DOC_LINK_VERSION}/ts-management.html#ts-endpoints`, diff --git a/packages/kbn-doc-links/src/types.ts b/packages/kbn-doc-links/src/types.ts index fa1b4d6af41c8..a5875ce03cf5b 100644 --- a/packages/kbn-doc-links/src/types.ts +++ b/packages/kbn-doc-links/src/types.ts @@ -359,15 +359,31 @@ export interface DocLinks { }; readonly clients: { readonly guide: string; + readonly goIndex: string; readonly goOverview: string; + readonly javaBasicAuthentication: string; readonly javaIndex: string; + readonly javaInstallation: string; + readonly javaIntroduction: string; + readonly javaRestLow: string; + readonly jsClientConnecting: string; readonly jsIntro: string; readonly netGuide: string; + readonly netIntroduction: string; + readonly netNest: string; + readonly netSingleNode: string; readonly perlGuide: string; readonly phpGuide: string; + readonly phpConnecting: string; + readonly phpInstallation: string; + readonly phpOverview: string; + readonly pythonAuthentication: string; readonly pythonGuide: string; + readonly pythonOverview: string; + readonly rubyAuthentication: string; readonly rubyOverview: string; readonly rustGuide: string; + readonly rustOverview: string; }; readonly endpoints: { readonly troubleshooting: string; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/elasticsearch_card.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/elasticsearch_card.tsx new file mode 100644 index 0000000000000..0283249ac2890 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/elasticsearch_card.tsx @@ -0,0 +1,54 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import { EuiPanel, EuiFlexGroup, EuiFlexItem, EuiText, EuiTitle, EuiSpacer } from '@elastic/eui'; + +import { i18n } from '@kbn/i18n'; + +import { EuiButtonTo } from '../../../shared/react_router_helpers'; +import { ELASTICSEARCH_GUIDE_PATH } from '../../routes'; +import { ElasticsearchResources } from '../elasticsearch_resources'; + +export const ElasticsearchCard: React.FC = () => { + return ( + + + + +

+ {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchCard.heading', { + defaultMessage: 'Get started with Elasticsearch', + })} +

+
+ + + {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchCard.description', { + defaultMessage: + 'Design and build performant, relevant search-powered applications or large-scale search implementations directly in Elasticsearch', + })} + + + + {/* div is needed to prevent button from stretching */} +
+ + {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchCard.button', { + defaultMessage: 'Get started', + })} + +
+
+ + + +
+
+ ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/index.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/index.ts new file mode 100644 index 0000000000000..7e9c6947d37e2 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_card/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export { ElasticsearchCard } from './elasticsearch_card'; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx new file mode 100644 index 0000000000000..de387b01e994d --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx @@ -0,0 +1,51 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import { useValues } from 'kea'; + +import { KibanaLogic } from '../../../shared/kibana'; + +import { ElasticsearchDotnet } from './elasticsearch_dotnet'; +import { ElasticsearchGo } from './elasticsearch_go'; +import { ElasticsearchJava } from './elasticsearch_java'; +import { ElasticsearchJavascript } from './elasticsearch_javascript'; +import { ElasticsearchPhp } from './elasticsearch_php'; +import { ElasticsearchPython } from './elasticsearch_python'; +import { ElasticsearchRuby } from './elasticsearch_ruby'; +import { ElasticsearchRust } from './elasticsearch_rust'; + +const useCloudId = (): string | undefined => { + const { cloud } = useValues(KibanaLogic); + return cloud?.cloudId; +}; + +export const ElasticsearchClientInstructions: React.FC<{ language: string }> = ({ language }) => { + const cloudId = useCloudId(); + + switch (language) { + case 'dotnet': + return ; + case 'go': + return ; + case 'java': + return ; + case 'javascript': + return ; + case 'php': + return ; + case 'python': + return ; + case 'ruby': + return ; + case 'rust': + return ; + default: + return null; + } +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx new file mode 100644 index 0000000000000..66f59673d925f --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx @@ -0,0 +1,155 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchDotnet: React.FC<{ cloudId?: string }> = ({ cloudId }) => { + return ( + <> + +

+ The official .Net client for Elasticsearch includes all the features you need to add + search to a .Net application: +

+
    +
  • One-to-one mapping with REST API.
  • +
  • Strongly typed requests and responses for Elasticsearch APIs.
  • +
  • Fluent API for building requests.
  • +
  • Helpers for common tasks such as bulk indexing of documents.
  • +
  • Pluggable serialization of requests and responses based on System.Text.Json.
  • +
  • Diagnostics, auditing, and .NET activity integration.
  • +
+ +

+ The .NET Elasticsearch client is built upon the Elastic Transport library which provides: +

+
    +
  • Connection management and load balancing across all available nodes.
  • +
  • Request retries and dead connections handling.
  • +
+ + + Learn more about the official .NET clients for Elasticsearch + + + + The official Elasticsearch .NET clients on Github + +
+ + + + +

Installation

+

+ For SDK style projects, you can install the Elasticsearch client by running the following + .NET CLI command in your terminal: +

+
+ + + {dedent` + dotnet add package Elastic.Clients.Elasticsearch + `} + + + +

+ This command adds a package reference to your project (csproj) file for the latest stable + version of the client. +

+

+ If you prefer, you may also manually add a package reference inside your project file: +

+
+ + + {dedent` + + `} + + + + + +

+ For Visual Studio users, the .NET client can also be installed from the Package Manager + Console inside Visual Studio using the following command: +

+
+ + + {dedent` + Install-Package Elastic.Clients.Elasticsearch + `} + + + + + +

+ Alternatively, search for Elastic.Clients.Elasticsearch in the NuGet Package Manager UI. +

+
+ + + + {cloudId ? ( + <> + +

Connecting to Elastic Cloud

+

+ Connecting to an Elasticsearch Service deployment is achieved by providing the unique + Cloud ID for your deployment when configuring the ElasticsearchClient instance. You + can retrieve the Cloud ID from the homepage of the deployment in Elasticsearch + Service. You also require suitable credentials that your application uses to + authenticate with your deployment. +

+

+ As a security best practice, it is recommended to create a dedicated API key per + application, with permissions limited to only those required for any API calls the + application is authorized to make. +

+

+ The following snippet shows you how to create a client instance that connects to an + Elasticsearch deployment in the cloud. +

+
+ + + {dedent` + using Elastic.Clients.Elasticsearch; + using Elastic.Transport; + + var client = new ElasticsearchClient("${cloudId}", new ApiKey("")); + + `} + + + ) : ( + <> + +

Connecting to Elasticsearch

+

+ The .Net client for Elasticsearch supports connecting to single nodes as well as + multiple nodes utilizing a node pool.{' '} + + Visit the documentation to learn more about connecting to Elasticsearch. + +

+
+ + )} + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx new file mode 100644 index 0000000000000..54d6dd7a0f333 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx @@ -0,0 +1,139 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchGo: React.FC<{ cloudId?: string }> = ({ cloudId }) => { + return ( + <> + +

+ The official Go client for Elasticsearch includes all the features you need to add search + to a Go application: +

+
    +
  • One-to-one mapping with the Elasticsearch REST API
  • +
  • Generalized, pluggable architecture
  • +
  • Helpers for convenience
  • +
  • A rich set of examples in the documentation
  • +
+ + Learn more about the Go client for Elasticsearch + + + + The Go client for Elasticsearch on Github + + + + View the documentation on GoDoc + +
+ + + + +

Installation

+

Add the package to your go.mod file:

+
+ + + {dedent` + require github.com/elastic/go-elasticsearch/v8 main + `} + + + + + +

Getting started

+

+ The elasticsearch package ties together two separate packages for calling the + Elasticsearch APIs and transferring data over HTTP: esapi and{' '} + elastictransport. +

+

+ Use the elasticsearch.NewDefaultClient() function to create the client with + the default settings. +

+
+ + + {dedent` + es, err := elasticsearch.NewDefaultClient() + if err != nil { + log.Fatalf("Error creating the client: %s", err) + } + + res, err := es.Info() + if err != nil { + log.Fatalf("Error getting response: %s", err) + } + + defer res.Body.Close() + log.Println(res) + `} + + + + + {cloudId ? ( + <> + +

Connecting to Elastic Cloud

+

+ If you are using Elastic Cloud, the client offers an easy way to connect to it. You + must pass your Cloud ID to the client, which is found in the Cloud console, as well as + a corresponding API key. +

+
+ + + {dedent` + cfg := elasticsearch.Config{ + CloudID: "${cloudId}", + APIKey: "API_KEY" + } + es, err := elasticsearch.NewClient(cfg) + `} + + + ) : ( + <> + +

Connecting to Elasticsearch

+

+ To set the cluster endpoint(s) programmatically, pass a configuration object to the{' '} + elasticsearch.NewClient() function. To set the username and password, + include them in the endpoint URL, or use the corresponding configuration options. +

+
+ + + {dedent` + cfg := elasticsearch.Config{ + Addresses: []string{ + "http://localhost:9200", + "http://localhost:9201", + }, + Username: "", + Password: "", + } + es, err := elasticsearch.NewClient(cfg) + `} + + + )} + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx new file mode 100644 index 0000000000000..d10deac35c96b --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchJava: React.FC = () => { + return ( + <> + +

+ The Elasticsearch Java API Client includes all the features you need to add search to a + Java application: +

+
    +
  • Strongly typed requests and responses for all Elasticsearch APIs.
  • +
  • Blocking and asynchronous versions of all APIs.
  • +
  • + Use of fluent builders and functional patterns to allow writing concise yet readable + code when creating complex nested structures. +
  • +
  • + Seamless integration of application classes by using an object mapper such as Jackson or + any JSON-B implementation. +
  • +
+ + Learn more about the Elasticsearch JAVA API client + + + + The Elasticsearch JAVA API client on Github + +
+ + + + +

Installation

+

+ There are several ways to install the Java API client.{' '} + + Visit the client documentation to learn more + + . +

+

Connecting to Elasticsearch

+

The client is structured around three main components:

+
    +
  • + API client classes. These provide strongly typed data structures and + methods for Elasticsearch APIs. Since the Elasticsearch API is large, it is structured + in feature groups (also called “namespaces”), each having its own client class. + Elasticsearch core features are implemented in the ElasticsearchClient class. +
  • +
  • + A JSON object mapper. This maps your application classes to JSON and + seamlessly integrates them with the API client. +
  • +
  • + A transport layer implementation. This is where all HTTP request + handling takes place. +
  • +
+

The code snippet below creates and wires these three components together:

+
+ + + {dedent` + // Create the low-level client + RestClient restClient = RestClient.builder( + new HttpHost("localhost", 9200)).build(); + + // Create the transport with a Jackson mapper + ElasticsearchTransport transport = new RestClientTransport( + restClient, new JacksonJsonpMapper()); + + // And create the API client + ElasticsearchClient client = new ElasticsearchClient(transport); + `} + + + +

+ Authentication is managed by the{' '} + + Java Low Level REST Client + + . For further details on configuring authentication, refer to{' '} + + its documentation + + . +

+
+ + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx new file mode 100644 index 0000000000000..5f94eed342883 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchJavascript: React.FC<{ cloudId?: string }> = ({ cloudId }) => { + return ( + <> + +

+ This is the official Node.js client for Elasticsearch includes all the features you need + to add search to any Node.js application: +

+
    +
  • One-to-one mapping with REST API.
  • +
  • Generalized, pluggable architecture.
  • +
  • Configurable, automatic discovery of cluster nodes.
  • +
  • Persistent, Keep-Alive connections.
  • +
  • Load balancing across all available nodes.
  • +
  • Child client support.
  • +
  • TypeScript support out of the box.
  • +
+ + Learn more about the official Node.js client for Elasticsearch + + + + The official Node.js client for Elasticsearch on Github + +
+ + + + +

Installation

+

To install the latest version of the client, run the following command:

+
+ + + npm install @elastic/elasticsearch + + + + + {cloudId ? ( + <> + +

Connecting to Elastic Cloud

+

+ If you are using Elastic Cloud, the client offers an easy way to connect to it via the + cloud option. You must pass the Cloud ID that you can find in the cloud console, then + your username and password inside the auth option. +

+
+ + + {dedent` + const { Client } = require('@elastic/elasticsearch') + const client = new Client({ + cloud: { + id: '${cloudId}', + }, + auth: { + username: '', + password: '' + } + })`} + + + ) : ( + <> + +

Connecting to Elasticsearch

+

+ There are several ways to connect and authenticate to Elasticsearch running outside of + Cloud, including API keys, bearer tokens, and basic authentication.{' '} + + Visit the client’s documentation to learn more + + . +

+
+ + )} + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.tsx new file mode 100644 index 0000000000000..6a724e508c39e --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchPhp: React.FC<{ cloudId?: string }> = ({ cloudId }) => { + return ( + <> + +

+ This official PHP client for Elasticsearch is designed to be a low-level client that does + not stray from the Elasticsearch REST API. +

+ + Learn more about the official PHP client for Elasticsearch + + + + The official PHP client for Elasticsearch on Github + +
+ + + + +

Installation

+

To install the latest version of the client, run the following command:

+ +

Elasticsearch-php only has four requirements that you need to pay attention:

+
    +
  • PHP 7.1.0 or higher
  • +
  • + + Composer + +
  • +
  • + + ext-curl + + : the Libcurl extension for PHP +
  • +
  • Native JSON Extensions (ext-json) 1.3.7 or higher
  • +
+

+ The rest of the dependencies are automatically downloaded and installed by Composer. + Composer is a package and dependency manager for PHP and makes it easy to install + Elasticsearch-php. +

+ + Visit the documentation for more information. + +
+ + + + {cloudId ? ( + <> + +

Connecting to Elastic Cloud

+

+ You can connect to Elastic Cloud using Basic authentication or an{' '} + API key. Where {''} is reported in the Deployment UI. For + basic authentication, {''} and {''} are generated when you deploy + a new cloud instance. You’ll need to store the {''} and {''} since + they will not be available via UI. +

+
+ + + {dedent` + // Connect via basic authentication + $client = ClientBuilder::create() + ->setElasticCloudId('${cloudId}') + ->setBasicAuthentication('', '') + ->build(); + + // Connect with an API key + $client = ClientBuilder::create() + ->setElasticCloudId('${cloudId}') + ->setApiKey('', '') + ->build(); + `} + + + ) : ( + <> + +

Connecting to Elasticsearch

+

+ There are several ways to connect and authenticate to Elasticsearch running outside of + Cloud, including API keys, bearer tokens, and basic authentication.{' '} + + Visit the client’s documentation to learn more + + . +

+
+ + )} + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx new file mode 100644 index 0000000000000..7a2183051feb2 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx @@ -0,0 +1,163 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchPython: React.FC<{ cloudId?: string }> = ({ cloudId }) => { + return ( + <> + +

+ elasticsearch-py, the official Python client for Elasticsearch, is a low-level client for + interacting with Elasticsearch’s REST API. It’s designed to be unopinionated and + extendable. +

+ + Learn more about the Python client for Elasticsearch + + + + The Python client for Elasticsearch on Read the Docs + + + + elasticsearch-py on Github + +
+ + + + +

Installation

+

+ Install the elasticsearch package with{' '} + + pip + + : +

+
+ + + {dedent` + $ python -m pip install elasticsearch + `} + + + + + +

+ If your application uses async/await in Python you can install the client with the async + extra: +

+
+ + + {dedent` + $ python -m pip install elasticsearch[async] + `} + + + +

+ Learn more about{' '} + + using asyncio with this project + + . +

+
+ + + + {cloudId ? ( + <> + +

Connecting to Elastic Cloud

+

+ Cloud ID is an easy way to configure your client to work with your Elastic Cloud + deployment. Combine the cloud_id with either basic_auth or api_key to authenticate + with your Elastic Cloud deployment. +

+

+ Using cloud_id enables TLS verification and HTTP compression by default and sets the + port to 443 unless otherwise overwritten via the port parameter or the port value + encoded within cloud_id. Using Cloud ID also disables sniffing as a proxy is in use. +

+
+ + + {dedent` + from elasticsearch import Elasticsearch + + es = Elasticsearch( + cloud_id="${cloudId}" + ) + `} + + + ) : ( + <> + +

Connecting to Elasticsearch

+

+ A single node can be specified via a scheme, host,{' '} + port, and optional path_prefix. These values can either be + specified manually via a URL in a string, dictionary, + NodeConfig, or a list of these values. You must specify at least{' '} + scheme, host and port + for each node. All of the following are valid configurations: +

+
+ + + {dedent` + from elasticsearch import Elasticsearch + + # Single node via URL + es = Elasticsearch("http://localhost:9200") + + # Multiple nodes via URL + es = Elasticsearch([ + "http://localhost:9200", + "http://localhost:9201", + "http://localhost:9202" + ]) + + # Single node via dictionary + es = Elasticsearch({"scheme": "http", "host": "localhost", "port": 9200}) + + # Multiple nodes via dictionary + es = Elasticsearch([ + {"scheme": "http", "host": "localhost", "port": 9200}, + {"scheme": "http", "host": "localhost", "port": 9201}, + ]) + `} + + + +

+ There are several ways to authenticate to Elasticsearch running outside of Cloud, + including API keys, bearer tokens, and basic authentication.{' '} + + Visit the client’s documentation to learn more + + . +

+
+ + )} + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx new file mode 100644 index 0000000000000..4dc80eb026871 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx @@ -0,0 +1,161 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchRuby: React.FC<{ cloudId?: string }> = ({ cloudId }) => { + return ( + <> + +

+ The elasticsearch{' '} + + Rubygem + {' '} + provides a low-level client for communicating with an Elasticsearch cluster, fully + compatible with other official clients. +

+ + Learn more about the Ruby client for Elasticsearch + + + + The Elasticsearch Ruby client on Github + + + + The Elasticsearch Ruby client on RubyDoc + + + + +

Check out these other official Ruby libraries for working with Elasticsearch:

+ +
+ + + + +

Installation

+

+ Install the elasticsearch gem from Rubygems: +

+
+ + + {dedent` + $ gem install elasticsearch + `} + + + +

Or add it to your project’s Gemfile:

+
+ + + {dedent` + gem 'elasticsearch', '' + `} + + + + + {cloudId ? ( + <> + +

Connecting to Elastic Cloud

+

+ If you are using Elastic Cloud, the client offers an easy way to connect to it. You + must pass the Cloud ID that you can find in the cloud console. +

+

+ You can connect to Elastic Cloud using Basic authentication or an{' '} + API key. Where {''} is reported in the Deployment UI. For + basic authentication, {''} and {''} are generated when you deploy + a new cloud instance. You’ll need to store the {''} and {''} since + they will not be available via UI. +

+
+ + + {dedent` + require 'elasticsearch' + + // Connect via basic authentication + client = Elasticsearch::Client.new( + cloud_id: '${cloudId}' + user: '', + password: '', + ) + + // Connect via API key + client = Elasticsearch::Client.new( + cloud_id: '${cloudId}', + api_key: {id: '', api_key: ''} + ) + `} + + + ) : ( + <> + +

Connecting to Elasticsearch

+

+ There are several ways to authenticate to Elasticsearch running outside of Cloud, + including API keys, bearer tokens, and basic authentication.{' '} + + Visit the client’s documentation to learn more + + . +

+
+ + )} + + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.tsx new file mode 100644 index 0000000000000..5b1eecfe7a846 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import dedent from 'dedent'; + +import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchRust: React.FC = () => { + return ( + <> + +

+ The official Rust client for Elasticsearch includes all the features you need to add + search to a Rust application: +

+
    +
  • Fluent builders for all Elasticsearch REST API endpoints
  • +
  • Persistent keep-alive connections
  • +
  • TLS support with system or custom certificates
  • +
  • Proxy support with authentication
  • +
  • Async support with Tokio
  • +
+ + Learn more about the Rust client for Elasticsearch + + + + The official Rust client for Elasticsearch on Github + + + + View the documentation on docs.rs + +
+ + + + +

Installation

+

+ Add elasticsearch crate and version to Cargo.toml. +

+
+ + + {dedent` + [dependencies] + elasticsearch = "" + `} + + + +

+ The following optional dependencies may also be useful to create requests and read + responses +

+
+ + + {dedent` + serde = "~1" + serde_json = "~1" + `} + + + +

+ The client also includes{' '} + + async support with tokio + + . +

+
+ + ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/index.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/index.ts new file mode 100644 index 0000000000000..901adb44b00d3 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export { ElasticsearchClientInstructions } from './elasticsearch_client_instructions'; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.test.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.test.tsx new file mode 100644 index 0000000000000..8f30abf2daaa0 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.test.tsx @@ -0,0 +1,99 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { setMockValues, mockTelemetryActions } from '../../../__mocks__/kea_logic'; + +import React from 'react'; + +import { shallow, ShallowWrapper } from 'enzyme'; + +import { EuiButtonIcon, EuiCopy, EuiFieldText } from '@elastic/eui'; + +import { ElasticsearchCloudId } from './'; + +const execCommandMock = (global.document.execCommand = jest.fn()); +const warn = jest.spyOn(console, 'warn').mockImplementation(() => {}); + +describe('Elasticsearch Cloud Id', () => { + let wrapper: ShallowWrapper; + + beforeEach(() => { + setMockValues({ + cloud: { + cloudId: 'example-cloud-id', + deploymentUrl: 'https://cloud.elastic.co/deployments/fake-deployment-id', + }, + }); + wrapper = shallow(); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); + + describe('Visibility conditions', () => { + it('renders panel when cloud id is provided', () => { + expect(wrapper.find('[data-test-subj="CloudIdPanel"]')).toHaveLength(1); + }); + + it('is hidden when cloud id isnt available', () => { + setMockValues({ cloud: { cloudId: null } }); + wrapper = shallow(); + expect(wrapper.find('[data-test-subj="CloudIdPanel"]')).toHaveLength(0); + }); + }); + + describe('Cloud Id Interactions', () => { + it('should be able copy cloud id', () => { + const field = wrapper.find(EuiFieldText).dive(); + + expect(field.props()).toEqual( + expect.objectContaining({ + readOnly: true, + }) + ); + expect(field.find('input').props()).toEqual( + expect.objectContaining({ + value: 'example-cloud-id', + }) + ); + + const euiCopyHOC = field.dive().find(EuiCopy); + expect(euiCopyHOC.props().textToCopy).toEqual('example-cloud-id'); + const copyButton = euiCopyHOC.dive().find(EuiButtonIcon); + expect(copyButton).toHaveLength(1); + execCommandMock.mockImplementationOnce(() => true); + + copyButton.simulate('click'); + expect(execCommandMock).toHaveBeenCalledWith('copy'); + expect(mockTelemetryActions.sendEnterpriseSearchTelemetry).toHaveBeenCalledWith({ + action: 'clicked', + metric: 'cloud_id', + }); + }); + + it('should fail gracefully if not allowed to copy', () => { + const field = wrapper.find(EuiFieldText).dive(); + const euiCopyHOC = field.dive().find(EuiCopy); + const copyButton = euiCopyHOC.dive().find(EuiButtonIcon); + execCommandMock.mockImplementationOnce(() => false); + + copyButton.simulate('click'); + expect(execCommandMock).toHaveBeenCalledWith('copy'); + expect(warn).toHaveBeenCalledWith('Unable to copy to clipboard.'); + expect(mockTelemetryActions.sendEnterpriseSearchTelemetry).toHaveBeenCalled(); + }); + + it('should present a manage link to deployment screen', () => { + const manageLink = wrapper.find('[data-test-subj="cloudManageLink"]'); + expect(manageLink).toHaveLength(1); + expect(manageLink.props().href).toEqual( + 'https://cloud.elastic.co/deployments/fake-deployment-id' + ); + }); + }); +}); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.tsx new file mode 100644 index 0000000000000..416c4a428c848 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/elasticsearch_cloud_id.tsx @@ -0,0 +1,149 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import { useActions, useValues } from 'kea'; + +import { + EuiButton, + EuiButtonIcon, + EuiCopy, + EuiFieldText, + EuiFlexGroup, + EuiFlexItem, + EuiForm, + EuiFormRow, + EuiLink, + EuiPanel, + EuiTitle, +} from '@elastic/eui'; + +import { i18n } from '@kbn/i18n'; + +import { HttpLogic } from '../../../shared/http'; +import { KibanaLogic } from '../../../shared/kibana'; +import { TelemetryLogic } from '../../../shared/telemetry'; +import { SendTelemetryHelper } from '../../../shared/telemetry/telemetry_logic'; + +const onFocusHandler = (e: React.FocusEvent): void => { + e.target.select(); +}; + +interface CloudDetails { + cloudId: string | undefined; + deploymentUrl: string | undefined; +} + +const useCloudDetails = (): CloudDetails => { + const { cloud } = useValues(KibanaLogic); + return { + cloudId: cloud?.cloudId, + deploymentUrl: cloud?.deploymentUrl, + }; +}; + +const copyCloudIdHandler = ( + copy: () => void, + sendTelemetry: ({ action, metric }: SendTelemetryHelper) => void +) => { + return () => { + copy(); + sendTelemetry({ + action: 'clicked', + metric: 'cloud_id', + }); + }; +}; + +export const ElasticsearchCloudId: React.FC = () => { + const cloud = useCloudDetails(); + const { sendEnterpriseSearchTelemetry } = useActions(TelemetryLogic); + const { http } = useValues(HttpLogic); + + // hide the panel when no cloud context is available + if (!cloud.cloudId) { + return null; + } + + return ( + + + + + + +

+ {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchCloudId.heading', { + defaultMessage: 'My Deployment', + })} +

+
+
+
+
+ + + {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchCloudId.manageLink', { + defaultMessage: 'Manage', + })} + + +
+ + + + + + {(copy) => ( + + )} + + } + /> + + + + + + + {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchCloudId.manageApiKeysLink', + { + defaultMessage: 'Manage API keys', + } + )} + + + +
+ ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/index.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/index.ts new file mode 100644 index 0000000000000..950ac3cbda25d --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_cloud_id/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export { ElasticsearchCloudId } from './elasticsearch_cloud_id'; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx new file mode 100644 index 0000000000000..8a5fb8037bb8d --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx @@ -0,0 +1,198 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useEffect, useState } from 'react'; + +import queryString from 'query-string'; + +import { + EuiPageTemplate, + EuiText, + EuiFlexGroup, + EuiFlexItem, + EuiSpacer, + EuiSteps, + EuiSelect, + EuiLink, + useGeneratedHtmlId, +} from '@elastic/eui'; + +import { i18n } from '@kbn/i18n'; + +import { docLinks } from '../../../shared/doc_links'; + +import { ElasticsearchClientInstructions } from '../elasticsearch_client_instructions'; +import { ElasticsearchCloudId } from '../elasticsearch_cloud_id'; +import { ElasticsearchResources } from '../elasticsearch_resources'; + +// Replace FormattedMessage with i18n strings + +export const ElasticsearchGuide: React.FC = () => { + const languages = [ + { value: 'dotnet', text: '.Net' }, + { value: 'go', text: 'Go' }, + { value: 'java', text: 'Java' }, + { value: 'javascript', text: 'JavaScript' }, + { value: 'php', text: 'PHP' }, + { value: 'python', text: 'Python' }, + { value: 'ruby', text: 'Ruby' }, + { value: 'rust', text: 'Rust' }, + ]; + + const client = queryString.parse(window.location.search).client; + const languageExists = languages.some((language) => language.value === client); + const [selectedLanguage, setSelectedLanguage] = useState( + languageExists ? (client as string) : 'java' + ); + + const basicSelectId = useGeneratedHtmlId({ prefix: 'languageSelect' }); + + const onChange = (e: React.ChangeEvent) => { + setSelectedLanguage(e.target.value); + }; + + // TODO: The page keeps the scroll position if being opened from Enterpise Search Overview, + // This is a temporary solution for demoing + useEffect(() => { + window.scrollTo(0, 0); + }, []); + + return ( + + + {/* maxWidth is needed to prevent code blocks with long unbreakable strings (Kibana PR Cloud ID) from stretching the column */} + + +

+ {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchTitle', + { + defaultMessage: 'Getting started with Elasticsearch', + } + )} +

+

+ {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchDescription', + { + defaultMessage: + 'Whether you are building a search-powered application, or designing a large-scale search implementation, Elasticsearch provides the low-level tools to create the most relevant and performant search experience.', + } + )} +

+
+ + + + + +

+ {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.connectToElasticsearchDescription', + { + defaultMessage: + "Elastic builds and maintains clients in several popular languages and our community has contributed many more. They're easy to work with, feel natural to use, and, just like Elasticsearch, don't limit what you might want to do with them.", + } + )} +

+ + {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchClientsLink', + { defaultMessage: 'Learn more about Elasticsearch clients' } + )} + +
+ + + + onChange(e)} + aria-label={i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchClientsSelectAriaLabel', + { defaultMessage: 'Language client' } + )} + /> + + + + ), + }, + { + title: i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchSearchExperienceTitle', + { defaultMessage: 'Build a search experience with Elasticsearch' } + ), + children: ( + <> + +

+ {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchSearchExperienceDescription', + { + defaultMessage: + 'Ready to add an engaging, modern search experience to your application or website? Search UI, Elastic’s JavaScript search framework for building world-class search experiences, was made for the task.', + } + )} +

+
+ + + + + + {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchSearchUIMarketingLink', + { defaultMessage: 'Learn more about Search UI' } + )} + + + + + + + {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchGuide.elasticsearchSearchUIGitHubLink', + { defaultMessage: 'Search UI on GitHub' } + )} + + + + + + ), + }, + ]} + /> +
+ + + + + +
+
+ ); +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/index.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/index.ts new file mode 100644 index 0000000000000..853898403e364 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export { ElasticsearchGuide } from './elasticsearch_guide'; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/elasticsearch_resources.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/elasticsearch_resources.tsx new file mode 100644 index 0000000000000..b7d0390f40077 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/elasticsearch_resources.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import { EuiSpacer, EuiPanel, EuiTitle, EuiLink } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; + +import { docLinks } from '../../../shared/doc_links'; + +export const ElasticsearchResources: React.FC = () => ( + + +

+ {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchResources.title', { + defaultMessage: 'Resources', + })} +

+
+ + + + {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchResources.gettingStarted', { + defaultMessage: 'Getting started with Elasticsearch', + })} + + + + + {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchResources.createIndex', { + defaultMessage: 'Create a new index', + })} + + + + + {i18n.translate( + 'xpack.enterpriseSearch.overview.elasticsearchResources.elasticsearchClients', + { defaultMessage: 'Elasticsearch clients' } + )} + + + + + {i18n.translate('xpack.enterpriseSearch.overview.elasticsearchResources.searchUi', { + defaultMessage: 'Search UI for Elasticsearch', + })} + +
+); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/index.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/index.ts new file mode 100644 index 0000000000000..6df669934e7b3 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_resources/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export { ElasticsearchResources } from './elasticsearch_resources'; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.tsx index 2df342ce3c672..4ed45acdfbbae 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.tsx @@ -36,6 +36,7 @@ import { SendEnterpriseSearchTelemetry as SendTelemetry } from '../../../shared/ import AppSearchImage from '../../assets/app_search.png'; import WorkplaceSearchImage from '../../assets/workplace_search.png'; +import { ElasticsearchCard } from '../elasticsearch_card'; import { LicenseCallout } from '../license_callout'; import { ProductCard } from '../product_card'; import { SetupGuideCta } from '../setup_guide'; @@ -91,6 +92,10 @@ export const ProductSelector: React.FC = ({ + + + + {config.host ? : } ); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/index.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/index.tsx index ca4b91d0e03b9..d643738352721 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/index.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/index.tsx @@ -16,10 +16,11 @@ import { HttpLogic } from '../shared/http'; import { KibanaLogic } from '../shared/kibana'; import { VersionMismatchPage } from '../shared/version_mismatch'; +import { ElasticsearchGuide } from './components/elasticsearch_guide'; import { ErrorConnecting } from './components/error_connecting'; import { ProductSelector } from './components/product_selector'; import { SetupGuide } from './components/setup_guide'; -import { ROOT_PATH, SETUP_GUIDE_PATH } from './routes'; +import { ROOT_PATH, SETUP_GUIDE_PATH, ELASTICSEARCH_GUIDE_PATH } from './routes'; export const EnterpriseSearchOverview: React.FC = ({ access = {}, @@ -56,6 +57,9 @@ export const EnterpriseSearchOverview: React.FC = ({ + + + {showView()} diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/routes.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/routes.ts index 345b8e3137f69..33e007e595191 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/routes.ts +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/routes.ts @@ -7,3 +7,4 @@ export const ROOT_PATH = '/'; export const SETUP_GUIDE_PATH = '/setup_guide'; +export const ELASTICSEARCH_GUIDE_PATH = '/elasticsearch_guide'; diff --git a/x-pack/plugins/enterprise_search/public/applications/shared/doc_links/doc_links.ts b/x-pack/plugins/enterprise_search/public/applications/shared/doc_links/doc_links.ts index de29cf931c770..6030609e8a1a0 100644 --- a/x-pack/plugins/enterprise_search/public/applications/shared/doc_links/doc_links.ts +++ b/x-pack/plugins/enterprise_search/public/applications/shared/doc_links/doc_links.ts @@ -29,13 +29,35 @@ class DocLinks { public appSearchSynonyms: string; public appSearchWebCrawler: string; public appSearchWebCrawlerEventLogs: string; + public clientsGoIndex: string; + public clientsGuide: string; + public clientsJavaBasicAuthentication: string; + public clientsJavaInstallation: string; + public clientsJavaIntroduction: string; + public clientsJavaRestLow: string; + public clientsJsClientConnecting: string; + public clientsJsIntro: string; + public clientsNetIntroduction: string; + public clientsNetNest: string; + public clientsNetSingleNode: string; + public clientsPhpConnecting: string; + public clientsPhpInstallation: string; + public clientsPhpOverview: string; + public clientsPythonAuthentication: string; + public clientsPythonOverview: string; + public clientsRubyAuthentication: string; + public clientsRubyOverview: string; + public clientsRustOverview: string; public cloudIndexManagement: string; + public elasticsearchCreateIndex: string; + public elasticsearchGettingStarted: string; public enterpriseSearchConfig: string; public enterpriseSearchMailService: string; public enterpriseSearchTroubleshootSetup: string; public enterpriseSearchUsersAccess: string; public kibanaSecurity: string; public licenseManagement: string; + public queryDsl: string; public workplaceSearchApiKeys: string; public workplaceSearchBox: string; public workplaceSearchConfluenceCloud: string; @@ -86,13 +108,35 @@ class DocLinks { this.appSearchSynonyms = ''; this.appSearchWebCrawler = ''; this.appSearchWebCrawlerEventLogs = ''; + this.clientsGoIndex = ''; + this.clientsGuide = ''; + this.clientsJavaBasicAuthentication = ''; + this.clientsJavaInstallation = ''; + this.clientsJavaIntroduction = ''; + this.clientsJavaRestLow = ''; + this.clientsJsIntro = ''; + this.clientsJsClientConnecting = ''; + this.clientsNetIntroduction = ''; + this.clientsNetNest = ''; + this.clientsNetSingleNode = ''; + this.clientsPhpConnecting = ''; + this.clientsPhpInstallation = ''; + this.clientsPhpOverview = ''; + this.clientsPythonAuthentication = ''; + this.clientsPythonOverview = ''; + this.clientsRubyAuthentication = ''; + this.clientsRubyOverview = ''; + this.clientsRustOverview = ''; this.cloudIndexManagement = ''; + this.elasticsearchCreateIndex = ''; + this.elasticsearchGettingStarted = ''; this.enterpriseSearchConfig = ''; this.enterpriseSearchMailService = ''; this.enterpriseSearchTroubleshootSetup = ''; this.enterpriseSearchUsersAccess = ''; this.kibanaSecurity = ''; this.licenseManagement = ''; + this.queryDsl = ''; this.workplaceSearchApiKeys = ''; this.workplaceSearchBox = ''; this.workplaceSearchConfluenceCloud = ''; @@ -144,13 +188,35 @@ class DocLinks { this.appSearchSynonyms = docLinks.links.appSearch.synonyms; this.appSearchWebCrawler = docLinks.links.appSearch.webCrawler; this.appSearchWebCrawlerEventLogs = docLinks.links.appSearch.webCrawlerEventLogs; + this.clientsGoIndex = docLinks.links.clients.goIndex; + this.clientsGuide = docLinks.links.clients.guide; + this.clientsJavaBasicAuthentication = docLinks.links.clients.javaBasicAuthentication; + this.clientsJavaInstallation = docLinks.links.clients.javaInstallation; + this.clientsJavaIntroduction = docLinks.links.clients.javaIntroduction; + this.clientsJavaRestLow = docLinks.links.clients.javaRestLow; + this.clientsJsClientConnecting = docLinks.links.clients.jsClientConnecting; + this.clientsJsIntro = docLinks.links.clients.jsIntro; + this.clientsNetIntroduction = docLinks.links.clients.netIntroduction; + this.clientsNetNest = docLinks.links.clients.netNest; + this.clientsNetSingleNode = docLinks.links.clients.netSingleNode; + this.clientsPhpConnecting = docLinks.links.clients.phpConnecting; + this.clientsPhpInstallation = docLinks.links.clients.phpInstallation; + this.clientsPhpOverview = docLinks.links.clients.phpOverview; + this.clientsPythonAuthentication = docLinks.links.clients.pythonAuthentication; + this.clientsPythonOverview = docLinks.links.clients.pythonOverview; + this.clientsRubyAuthentication = docLinks.links.clients.rubyAuthentication; + this.clientsRubyOverview = docLinks.links.clients.rubyOverview; + this.clientsRustOverview = docLinks.links.clients.rustOverview; this.cloudIndexManagement = docLinks.links.cloud.indexManagement; + this.elasticsearchCreateIndex = docLinks.links.elasticsearch.createIndex; + this.elasticsearchGettingStarted = docLinks.links.elasticsearch.gettingStarted; this.enterpriseSearchConfig = docLinks.links.enterpriseSearch.configuration; this.enterpriseSearchMailService = docLinks.links.enterpriseSearch.mailService; this.enterpriseSearchTroubleshootSetup = docLinks.links.enterpriseSearch.troubleshootSetup; this.enterpriseSearchUsersAccess = docLinks.links.enterpriseSearch.usersAccess; this.kibanaSecurity = docLinks.links.kibana.xpackSecurity; this.licenseManagement = docLinks.links.enterpriseSearch.licenseManagement; + this.queryDsl = docLinks.links.query.queryDsl; this.workplaceSearchApiKeys = docLinks.links.workplaceSearch.apiKeys; this.workplaceSearchBox = docLinks.links.workplaceSearch.box; this.workplaceSearchConfluenceCloud = docLinks.links.workplaceSearch.confluenceCloud; From c423cc53af3bae05ff07736547ceff6789a7387e Mon Sep 17 00:00:00 2001 From: Spencer Date: Mon, 28 Mar 2022 21:00:36 -0600 Subject: [PATCH 061/160] [fleet] add pipeline for daily package install test (#128683) * [fleet] add pipeline for daily package install test * use install_all_packages script and make sure it's executable --- .buildkite/pipelines/fleet/packages_daily.yml | 33 +++++++++++++++++++ .../steps/fleet/install_all_packages.sh | 11 +++++++ 2 files changed, 44 insertions(+) create mode 100644 .buildkite/pipelines/fleet/packages_daily.yml create mode 100755 .buildkite/scripts/steps/fleet/install_all_packages.sh diff --git a/.buildkite/pipelines/fleet/packages_daily.yml b/.buildkite/pipelines/fleet/packages_daily.yml new file mode 100644 index 0000000000000..e64358661d7b9 --- /dev/null +++ b/.buildkite/pipelines/fleet/packages_daily.yml @@ -0,0 +1,33 @@ +steps: + - command: .buildkite/scripts/lifecycle/pre_build.sh + label: Pre-Build + timeout_in_minutes: 10 + agents: + queue: kibana-default + + - wait + + - command: .buildkite/scripts/steps/build_kibana.sh + label: Build Kibana Distribution and Plugins + agents: + queue: c2-16 + key: build + if: "build.env('KIBANA_BUILD_ID') == null || build.env('KIBANA_BUILD_ID') == ''" + timeout_in_minutes: 60 + + - wait + + - command: .buildkite/scripts/steps/fleet/install_all_packages.sh + label: Install All Packages + agents: + queue: n2-2 + key: linting + timeout_in_minutes: 90 + + - wait: ~ + continue_on_failure: true + + - label: Post-Build + command: .buildkite/scripts/lifecycle/post_build.sh + agents: + queue: kibana-default diff --git a/.buildkite/scripts/steps/fleet/install_all_packages.sh b/.buildkite/scripts/steps/fleet/install_all_packages.sh new file mode 100755 index 0000000000000..1c5c661abd8c5 --- /dev/null +++ b/.buildkite/scripts/steps/fleet/install_all_packages.sh @@ -0,0 +1,11 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source .buildkite/scripts/common/util.sh + +.buildkite/scripts/bootstrap.sh + +echo '--- Installing all packages' +cd x-pack/plugins/fleet +node scripts/install_all_packages From 3c83c8322fa476336a438b1502e0be9ec487a204 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alejandro=20Fern=C3=A1ndez=20G=C3=B3mez?= Date: Tue, 29 Mar 2022 08:18:42 +0200 Subject: [PATCH 062/160] [Unified observability] Telemetry for Guided setup (#128607) --- .../observability_status_box.test.tsx | 21 ++++++++++---- .../observability_status_box.tsx | 26 +++++++++++++++-- .../observability_status_progress.tsx | 24 ++++++--------- .../public/hooks/use_guided_setup_progress.ts | 29 +++++++++++++++++++ .../pages/overview/old_overview_page.tsx | 16 ++++++++-- 5 files changed, 91 insertions(+), 25 deletions(-) create mode 100644 x-pack/plugins/observability/public/hooks/use_guided_setup_progress.ts diff --git a/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.test.tsx b/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.test.tsx index 088e0dea20bd0..3509aa009b753 100644 --- a/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.test.tsx +++ b/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.test.tsx @@ -6,9 +6,13 @@ */ import React from 'react'; -import { render, screen } from '@testing-library/react'; +import { render, screen, fireEvent } from '@testing-library/react'; import { ObservabilityStatusBox } from './observability_status_box'; import { __IntlProvider as IntlProvider } from '@kbn/i18n-react'; +import { applicationServiceMock } from '../../../../../../../src/core/public/mocks'; +import { KibanaContextProvider } from '../../../../../../../src/plugins/kibana_react/public'; + +const application = applicationServiceMock.createStartContract(); describe('ObservabilityStatusBox', () => { describe('Empty state', () => { @@ -27,9 +31,13 @@ describe('ObservabilityStatusBox', () => { weight: 1, }; + application.navigateToUrl.mockImplementation(); + render( - + + + ); }); @@ -73,9 +81,12 @@ describe('ObservabilityStatusBox', () => { // it('should have a check icon', () => {}); - it('should have the integration link', () => { - const addIntegrationLink = screen.getByText('logs add title') as HTMLElement; - expect(addIntegrationLink.closest('a')?.href).toContain('addIntegrationUrl.com'); + // FIXME for some reason `` doesn't propagate the + // services. When the code tries to call `application.naviageToUrl` (which + // this test depends on) it complains about `undefined` values. + it.skip('should have the integration link', () => { + const addIntegrationLink = screen.getByText('logs add title'); + fireEvent.click(addIntegrationLink); }); it('should have the list of modules', () => { diff --git a/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.tsx b/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.tsx index 756fb995d489b..e69eae18611cd 100644 --- a/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.tsx +++ b/x-pack/plugins/observability/public/components/app/observability_status/observability_status_box.tsx @@ -17,8 +17,10 @@ import { EuiTitle, EuiLink, } from '@elastic/eui'; -import React from 'react'; +import React, { useCallback } from 'react'; import { FormattedMessage } from '@kbn/i18n-react'; +import { useUiTracker } from '../../../hooks/use_track_metric'; +import { useKibana } from '../../../utils/kibana_react'; export interface ObservabilityStatusBoxProps { id: string; @@ -43,6 +45,7 @@ export function ObservabilityStatusBox(props: ObservabilityStatusBoxProps) { } export function CompletedStatusBox({ + id, title, modules, addLink, @@ -50,6 +53,14 @@ export function CompletedStatusBox({ goToAppTitle, goToAppLink, }: ObservabilityStatusBoxProps) { + const { application } = useKibana().services; + const trackMetric = useUiTracker({ app: 'observability-overview' }); + + const goToAddLink = useCallback(() => { + trackMetric({ metric: `guided_setup_add_integrations_${id}` }); + application.navigateToUrl(addLink); + }, [addLink, application, trackMetric, id]); + return ( @@ -67,7 +78,7 @@ export function CompletedStatusBox({
- + {addTitle} @@ -108,12 +119,21 @@ export function CompletedStatusBox({ } export function EmptyStatusBox({ + id, title, description, learnMoreLink, addTitle, addLink, }: ObservabilityStatusBoxProps) { + const { application } = useKibana().services; + const trackMetric = useUiTracker({ app: 'observability-overview' }); + + const goToAddLink = useCallback(() => { + trackMetric({ metric: `guided_setup_add_data_${id}` }); + application.navigateToUrl(addLink); + }, [id, trackMetric, application, addLink]); + return ( @@ -140,7 +160,7 @@ export function EmptyStatusBox({ - + {addTitle} diff --git a/x-pack/plugins/observability/public/components/app/observability_status/observability_status_progress.tsx b/x-pack/plugins/observability/public/components/app/observability_status/observability_status_progress.tsx index 81f08537c775f..04e77669e963c 100644 --- a/x-pack/plugins/observability/public/components/app/observability_status/observability_status_progress.tsx +++ b/x-pack/plugins/observability/public/components/app/observability_status/observability_status_progress.tsx @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import React, { useState, useEffect } from 'react'; +import React, { useState, useEffect, useCallback } from 'react'; import { EuiPanel, EuiProgress, @@ -20,8 +20,7 @@ import { reduce } from 'lodash'; import { FormattedMessage } from '@kbn/i18n-react'; import { useHasData } from '../../../hooks/use_has_data'; import { useUiTracker } from '../../../hooks/use_track_metric'; - -const LOCAL_STORAGE_HIDE_GUIDED_SETUP_KEY = 'HIDE_GUIDED_SETUP'; +import { useGuidedSetupProgress } from '../../../hooks/use_guided_setup_progress'; interface ObservabilityStatusProgressProps { onViewDetailsClick: () => void; @@ -31,12 +30,8 @@ export function ObservabilityStatusProgress({ }: ObservabilityStatusProgressProps) { const { hasDataMap, isAllRequestsComplete } = useHasData(); const trackMetric = useUiTracker({ app: 'observability-overview' }); - const hideGuidedSetupLocalStorageKey = window.localStorage.getItem( - LOCAL_STORAGE_HIDE_GUIDED_SETUP_KEY - ); - const [isGuidedSetupHidden, setIsGuidedSetupHidden] = useState( - JSON.parse(hideGuidedSetupLocalStorageKey || 'false') - ); + const { isGuidedSetupProgressDismissed, dismissGuidedSetupProgress } = useGuidedSetupProgress(); + const [progress, setProgress] = useState(0); useEffect(() => { @@ -55,18 +50,17 @@ export function ObservabilityStatusProgress({ } }, [isAllRequestsComplete, hasDataMap]); - const hideGuidedSetup = () => { - window.localStorage.setItem(LOCAL_STORAGE_HIDE_GUIDED_SETUP_KEY, 'true'); - setIsGuidedSetupHidden(true); + const dismissGuidedSetup = useCallback(() => { + dismissGuidedSetupProgress(); trackMetric({ metric: 'guided_setup_progress_dismiss' }); - }; + }, [dismissGuidedSetupProgress, trackMetric]); const showDetails = () => { onViewDetailsClick(); trackMetric({ metric: 'guided_setup_progress_view_details' }); }; - return !isGuidedSetupHidden ? ( + return !isGuidedSetupProgressDismissed ? ( <> @@ -93,7 +87,7 @@ export function ObservabilityStatusProgress({ - + ( + JSON.parse(dismissedGuidedSetupProgressLocalStorage || 'false') + ); + + const dismissGuidedSetupProgress = useCallback(() => { + window.localStorage.setItem(LOCAL_STORAGE_DISMISS_GUIDED_SETUP_PROGRESS_KEY, 'true'); + setIsGuidedSetupProgressDismissed(true); + }, []); + + return { + isGuidedSetupProgressDismissed, + dismissGuidedSetupProgress, + }; +} diff --git a/x-pack/plugins/observability/public/pages/overview/old_overview_page.tsx b/x-pack/plugins/observability/public/pages/overview/old_overview_page.tsx index 65f9def2d0f4a..610c0f66a92e3 100644 --- a/x-pack/plugins/observability/public/pages/overview/old_overview_page.tsx +++ b/x-pack/plugins/observability/public/pages/overview/old_overview_page.tsx @@ -22,7 +22,7 @@ import { FormattedMessage } from '@kbn/i18n-react'; import React, { useMemo, useRef, useCallback, useState } from 'react'; import { observabilityFeatureId } from '../../../common'; import { useKibana } from '../../../../../../src/plugins/kibana_react/public'; -import { useTrackPageview } from '../..'; +import { useTrackPageview, useUiTracker } from '../..'; import { EmptySections } from '../../components/app/empty_sections'; import { ObservabilityHeaderMenu } from '../../components/app/header'; import { NewsFeed } from '../../components/app/news_feed'; @@ -47,6 +47,7 @@ import { paths } from '../../config'; import { useDatePickerContext } from '../../hooks/use_date_picker_context'; import { ObservabilityStatusProgress } from '../../components/app/observability_status/observability_status_progress'; import { ObservabilityStatus } from '../../components/app/observability_status'; +import { useGuidedSetupProgress } from '../../hooks/use_guided_setup_progress'; interface Props { routeParams: RouteParams<'/overview'>; } @@ -58,6 +59,7 @@ function calculateBucketSize({ start, end }: { start?: number; end?: number }) { } export function OverviewPage({ routeParams }: Props) { + const trackMetric = useUiTracker({ app: 'observability-overview' }); useTrackPageview({ app: 'observability-overview', path: 'overview' }); useTrackPageview({ app: 'observability-overview', path: 'overview', delay: 15000 }); useBreadcrumbs([ @@ -81,6 +83,8 @@ export function OverviewPage({ routeParams }: Props) { const { hasAnyData, isAllRequestsComplete } = useHasData(); const refetch = useRef<() => void>(); + const { isGuidedSetupProgressDismissed } = useGuidedSetupProgress(); + const bucketSize = useMemo( () => calculateBucketSize({ @@ -94,6 +98,14 @@ export function OverviewPage({ routeParams }: Props) { refetch.current = ref; }, []); + const handleGuidedSetupClick = useCallback(() => { + if (isGuidedSetupProgressDismissed) { + trackMetric({ metric: 'guided_setup_view_details_after_dismiss' }); + } + + setIsFlyoutVisible(true); + }, [trackMetric, isGuidedSetupProgressDismissed]); + const onTimeRangeRefresh = useCallback(() => { return refetch.current && refetch.current(); }, []); @@ -125,7 +137,7 @@ export function OverviewPage({ routeParams }: Props) { ? { pageTitle: overviewPageTitle, rightSideItems: [ - setIsFlyoutVisible(true)}> + Date: Tue, 29 Mar 2022 00:03:49 -0700 Subject: [PATCH 063/160] Add tests to elasticsearch guide (#128709) Co-authored-by: Joseph McElroy Co-authored-by: Joseph McElroy --- ...elasticsearch_client_instructions.test.tsx | 57 +++++++++++++++ .../elasticsearch_client_instructions.tsx | 18 +++-- .../{ => languages}/elasticsearch_dotnet.tsx | 2 +- .../{ => languages}/elasticsearch_go.tsx | 2 +- .../{ => languages}/elasticsearch_java.tsx | 2 +- .../elasticsearch_javascript.tsx | 2 +- .../{ => languages}/elasticsearch_php.tsx | 2 +- .../{ => languages}/elasticsearch_python.tsx | 2 +- .../{ => languages}/elasticsearch_ruby.tsx | 2 +- .../{ => languages}/elasticsearch_rust.tsx | 2 +- .../languages/index.ts | 26 +++++++ .../elasticsearch_guide.test.tsx | 73 +++++++++++++++++++ .../elasticsearch_guide.tsx | 6 +- .../product_selector.test.tsx | 3 + 14 files changed, 179 insertions(+), 20 deletions(-) create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.test.tsx rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_dotnet.tsx (98%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_go.tsx (98%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_java.tsx (98%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_javascript.tsx (98%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_php.tsx (98%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_python.tsx (99%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_ruby.tsx (98%) rename x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/{ => languages}/elasticsearch_rust.tsx (97%) create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/index.ts create mode 100644 x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.test.tsx diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.test.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.test.tsx new file mode 100644 index 0000000000000..b7fe9c459ee6d --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { setMockValues } from '../../../__mocks__/kea_logic'; + +import React from 'react'; + +import { shallow, ShallowWrapper } from 'enzyme'; + +import * as Languages from './languages'; + +import { ElasticsearchClientInstructions } from '.'; + +describe('Elasticsearch Client Instructions', () => { + let wrapper: ShallowWrapper; + + afterEach(() => { + jest.clearAllMocks(); + }); + + const setup = (language: string) => { + setMockValues({ + cloud: { + cloudId: 'example-cloud-id', + }, + }); + wrapper = shallow(); + }; + + describe('Displaying the right language options', () => { + it.concurrent.each([ + ['dotnet', Languages.ElasticsearchDotnet, false], + ['go', Languages.ElasticsearchGo, true], + ['java', Languages.ElasticsearchJava, false], + ['javascript', Languages.ElasticsearchJavascript, true], + ['php', Languages.ElasticsearchPhp, true], + ['python', Languages.ElasticsearchPython, true], + ['ruby', Languages.ElasticsearchRuby, true], + ['rust', Languages.ElasticsearchRust, false], + ])('%s', (language, Component, hasCloudIdProp) => { + setup(language); + expect(wrapper.find(Component)).toHaveLength(1); + expect(wrapper.find(Component).prop('cloudId')).toEqual( + hasCloudIdProp ? 'example-cloud-id' : undefined + ); + }); + }); + + it('does not display language for unrecognised language', () => { + setup('coffeescript'); + expect(wrapper.isEmptyRender()).toEqual(true); + }); +}); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx index de387b01e994d..92c28e8f23336 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_client_instructions.tsx @@ -11,14 +11,16 @@ import { useValues } from 'kea'; import { KibanaLogic } from '../../../shared/kibana'; -import { ElasticsearchDotnet } from './elasticsearch_dotnet'; -import { ElasticsearchGo } from './elasticsearch_go'; -import { ElasticsearchJava } from './elasticsearch_java'; -import { ElasticsearchJavascript } from './elasticsearch_javascript'; -import { ElasticsearchPhp } from './elasticsearch_php'; -import { ElasticsearchPython } from './elasticsearch_python'; -import { ElasticsearchRuby } from './elasticsearch_ruby'; -import { ElasticsearchRust } from './elasticsearch_rust'; +import { + ElasticsearchDotnet, + ElasticsearchGo, + ElasticsearchJava, + ElasticsearchJavascript, + ElasticsearchPhp, + ElasticsearchPython, + ElasticsearchRuby, + ElasticsearchRust, +} from './languages'; const useCloudId = (): string | undefined => { const { cloud } = useValues(KibanaLogic); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_dotnet.tsx similarity index 98% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_dotnet.tsx index 66f59673d925f..ee739a459c774 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_dotnet.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_dotnet.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchDotnet: React.FC<{ cloudId?: string }> = ({ cloudId }) => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_go.tsx similarity index 98% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_go.tsx index 54d6dd7a0f333..cca6fe484fb3c 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_go.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_go.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchGo: React.FC<{ cloudId?: string }> = ({ cloudId }) => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_java.tsx similarity index 98% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_java.tsx index d10deac35c96b..573d447c25e03 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_java.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_java.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchJava: React.FC = () => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_javascript.tsx similarity index 98% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_javascript.tsx index 5f94eed342883..587ecb09e1198 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_javascript.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_javascript.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchJavascript: React.FC<{ cloudId?: string }> = ({ cloudId }) => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_php.tsx similarity index 98% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_php.tsx index 6a724e508c39e..229d36d487469 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_php.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_php.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchPhp: React.FC<{ cloudId?: string }> = ({ cloudId }) => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_python.tsx similarity index 99% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_python.tsx index 7a2183051feb2..54c7aca9b610a 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_python.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_python.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchPython: React.FC<{ cloudId?: string }> = ({ cloudId }) => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_ruby.tsx similarity index 98% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_ruby.tsx index 4dc80eb026871..0592037311900 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_ruby.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_ruby.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchRuby: React.FC<{ cloudId?: string }> = ({ cloudId }) => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_rust.tsx similarity index 97% rename from x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.tsx rename to x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_rust.tsx index 5b1eecfe7a846..208fffca35a52 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/elasticsearch_rust.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/elasticsearch_rust.tsx @@ -11,7 +11,7 @@ import dedent from 'dedent'; import { EuiCodeBlock, EuiLink, EuiText, EuiSpacer } from '@elastic/eui'; -import { docLinks } from '../../../shared/doc_links'; +import { docLinks } from '../../../../shared/doc_links'; export const ElasticsearchRust: React.FC = () => { return ( diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/index.ts b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/index.ts new file mode 100644 index 0000000000000..8a2accf80142f --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_client_instructions/languages/index.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { ElasticsearchDotnet } from './elasticsearch_dotnet'; +import { ElasticsearchGo } from './elasticsearch_go'; +import { ElasticsearchJava } from './elasticsearch_java'; +import { ElasticsearchJavascript } from './elasticsearch_javascript'; +import { ElasticsearchPhp } from './elasticsearch_php'; +import { ElasticsearchPython } from './elasticsearch_python'; +import { ElasticsearchRuby } from './elasticsearch_ruby'; +import { ElasticsearchRust } from './elasticsearch_rust'; + +export { + ElasticsearchDotnet, + ElasticsearchGo, + ElasticsearchJava, + ElasticsearchJavascript, + ElasticsearchPhp, + ElasticsearchPython, + ElasticsearchRuby, + ElasticsearchRust, +}; diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.test.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.test.tsx new file mode 100644 index 0000000000000..7dce063701072 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.test.tsx @@ -0,0 +1,73 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; + +import { shallow, ShallowWrapper } from 'enzyme'; + +import { EuiSteps, EuiSelect } from '@elastic/eui'; + +import { ElasticsearchClientInstructions } from '../elasticsearch_client_instructions'; + +import { ElasticsearchGuide } from './'; + +describe('Elasticsearch Guide Component', () => { + let wrapper: ShallowWrapper; + + const setup = (param: string) => { + Object.defineProperty(window, 'location', { + value: { search: param }, + writable: true, + }); + wrapper = shallow(); + }; + + describe('Rendering Language option ', () => { + it('should use default language (java)', () => { + setup(''); + const clientInstructionsElement = wrapper + .find(EuiSteps) + .dive() + .find(ElasticsearchClientInstructions); + expect(clientInstructionsElement.prop('language')).toBe('java'); + }); + + it('should use language from param (ruby)', () => { + setup('?client=ruby'); + const clientInstructionsElement = wrapper + .find(EuiSteps) + .dive() + .find(ElasticsearchClientInstructions); + expect(clientInstructionsElement.prop('language')).toBe('ruby'); + }); + + it('should fallback to java if client not recognised', () => { + setup('?client=coffeescript'); + const clientInstructionsElement = wrapper + .find(EuiSteps) + .dive() + .find(ElasticsearchClientInstructions); + expect(clientInstructionsElement.prop('language')).toBe('java'); + }); + }); + + describe('Changing Language option', () => { + it('should change the client instructions language prop when choosing another option', () => { + setup(''); + const languageSelectElement = wrapper.find(EuiSteps).dive().find(EuiSelect); + languageSelectElement.simulate('change', { target: { value: 'ruby' } }); + + wrapper.update(); + + const clientInstructionsElement = wrapper + .find(EuiSteps) + .dive() + .find(ElasticsearchClientInstructions); + expect(clientInstructionsElement.prop('language')).toBe('ruby'); + }); + }); +}); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx index 8a5fb8037bb8d..fb1bc7a2820e2 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/elasticsearch_guide/elasticsearch_guide.tsx @@ -43,11 +43,9 @@ export const ElasticsearchGuide: React.FC = () => { { value: 'rust', text: 'Rust' }, ]; - const client = queryString.parse(window.location.search).client; + const client = queryString.parse(window.location.search).client as string; const languageExists = languages.some((language) => language.value === client); - const [selectedLanguage, setSelectedLanguage] = useState( - languageExists ? (client as string) : 'java' - ); + const [selectedLanguage, setSelectedLanguage] = useState(languageExists ? client : 'java'); const basicSelectId = useGeneratedHtmlId({ prefix: 'languageSelect' }); diff --git a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.test.tsx b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.test.tsx index ff2ea86bb3911..0af49e71880ab 100644 --- a/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.test.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/enterprise_search_overview/components/product_selector/product_selector.test.tsx @@ -15,6 +15,7 @@ import { EuiEmptyPrompt } from '@elastic/eui'; import { WORKPLACE_SEARCH_PLUGIN } from '../../../../../common/constants'; +import { ElasticsearchCard } from '../elasticsearch_card'; import { LicenseCallout } from '../license_callout'; import { ProductCard } from '../product_card'; import { SetupGuideCta } from '../setup_guide'; @@ -35,6 +36,7 @@ describe('ProductSelector', () => { expect(wrapper.find(ProductCard)).toHaveLength(2); expect(wrapper.find(SetupGuideCta)).toHaveLength(1); expect(wrapper.find(LicenseCallout)).toHaveLength(0); + expect(wrapper.find(ElasticsearchCard)).toHaveLength(1); }); it('renders the trial callout', () => { @@ -97,6 +99,7 @@ describe('ProductSelector', () => { expect(wrapper.find(EuiEmptyPrompt)).toHaveLength(1); expect(wrapper.find(ProductCard)).toHaveLength(0); expect(wrapper.find(LicenseCallout)).toHaveLength(0); + expect(wrapper.find(ElasticsearchCard)).toHaveLength(0); }); }); }); From fa34ec5f0212841abdcb67151f4838308c6454c0 Mon Sep 17 00:00:00 2001 From: Ashokaditya <1849116+ashokaditya@users.noreply.github.com> Date: Tue, 29 Mar 2022 09:06:10 +0200 Subject: [PATCH 064/160] [Security Solution][Endpoint] Add sortOrder and sortField to exception list `_find` (#128529) * Add sortOrder and sortField to list find fixes elastic/security-team/issues/3446 * hard code sort order and sort field for artifact list fixes elastic/security-team/issues/3446 review changes * update test mocks --- .../public/management/common/constants.ts | 2 ++ .../management/components/artifact_list_page/types.ts | 2 -- .../hooks/artifacts/use_list_artifact.test.tsx | 6 ++++-- .../management/hooks/artifacts/use_list_artifact.tsx | 9 ++++++++- .../artifacts/flyout/policy_artifacts_flyout.test.tsx | 4 ++-- .../view/artifacts/list/policy_artifacts_list.test.tsx | 4 ++-- 6 files changed, 18 insertions(+), 9 deletions(-) diff --git a/x-pack/plugins/security_solution/public/management/common/constants.ts b/x-pack/plugins/security_solution/public/management/common/constants.ts index ea38414b0cb96..b443a49585686 100644 --- a/x-pack/plugins/security_solution/public/management/common/constants.ts +++ b/x-pack/plugins/security_solution/public/management/common/constants.ts @@ -39,6 +39,8 @@ export const MANAGEMENT_STORE_HOST_ISOLATION_EXCEPTIONS_NAMESPACE = 'hostIsolati export const MANAGEMENT_PAGE_SIZE_OPTIONS: readonly number[] = [10, 20, 50]; export const MANAGEMENT_DEFAULT_PAGE = 0; export const MANAGEMENT_DEFAULT_PAGE_SIZE = 10; +export const MANAGEMENT_DEFAULT_SORT_ORDER = 'desc'; +export const MANAGEMENT_DEFAULT_SORT_FIELD = 'created_at'; // --[ DEFAULTS ]--------------------------------------------------------------------------- /** The default polling interval to start all polling pages */ diff --git a/x-pack/plugins/security_solution/public/management/components/artifact_list_page/types.ts b/x-pack/plugins/security_solution/public/management/components/artifact_list_page/types.ts index 8ee4b50ba4671..d8a5e316d2b7d 100644 --- a/x-pack/plugins/security_solution/public/management/components/artifact_list_page/types.ts +++ b/x-pack/plugins/security_solution/public/management/components/artifact_list_page/types.ts @@ -19,8 +19,6 @@ export interface ArtifactListPageUrlParams { includedPolicies?: string; show?: 'create' | 'edit'; itemId?: string; - sortField?: string; - sortOrder?: string; } export interface ArtifactFormComponentProps { diff --git a/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.test.tsx b/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.test.tsx index e41660daa5c59..9ba0760961d7f 100644 --- a/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.test.tsx +++ b/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.test.tsx @@ -25,6 +25,8 @@ describe('List artifact hook', () => { page: number; perPage: number; policies: string[]; + sortField?: string; + sortOrder?: string; } | undefined; @@ -73,8 +75,8 @@ describe('List artifact hook', () => { namespace_type: ['agnostic'], page: 2, per_page: 20, - sort_field: undefined, - sort_order: undefined, + sort_field: 'created_at', + sort_order: 'desc', }, }); expect(onSuccessMock).toHaveBeenCalledTimes(1); diff --git a/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.tsx b/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.tsx index 1e0c4b3c55b8d..b3e1451218750 100644 --- a/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.tsx +++ b/x-pack/plugins/security_solution/public/management/hooks/artifacts/use_list_artifact.tsx @@ -8,7 +8,12 @@ import { FoundExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-t import { HttpFetchError } from 'kibana/public'; import { QueryObserverResult, useQuery, UseQueryOptions } from 'react-query'; import { useMemo } from 'react'; -import { MANAGEMENT_DEFAULT_PAGE, MANAGEMENT_DEFAULT_PAGE_SIZE } from '../../common/constants'; +import { + MANAGEMENT_DEFAULT_PAGE, + MANAGEMENT_DEFAULT_PAGE_SIZE, + MANAGEMENT_DEFAULT_SORT_FIELD, + MANAGEMENT_DEFAULT_SORT_ORDER, +} from '../../common/constants'; import { parsePoliciesAndFilterToKql, parseQueryFilterToKQL } from '../../common/utils'; import { ExceptionsListApiClient } from '../../services/exceptions_list/exceptions_list_api_client'; import { DEFAULT_EXCEPTION_LIST_ITEM_SEARCHABLE_FIELDS } from '../../../../common/endpoint/service/artifacts/constants'; @@ -53,6 +58,8 @@ export function useListArtifact( filter: filterKuery, perPage, page, + sortField: MANAGEMENT_DEFAULT_SORT_FIELD, + sortOrder: MANAGEMENT_DEFAULT_SORT_ORDER, }); return result; diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/flyout/policy_artifacts_flyout.test.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/flyout/policy_artifacts_flyout.test.tsx index e9ac077857284..f93cb91ba8384 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/flyout/policy_artifacts_flyout.test.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/flyout/policy_artifacts_flyout.test.tsx @@ -38,8 +38,8 @@ const getDefaultQueryParameters = (customFilter: string | undefined = '') => ({ namespace_type: ['agnostic'], page: MANAGEMENT_DEFAULT_PAGE + 1, per_page: MAX_ALLOWED_RESULTS, - sort_field: undefined, - sort_order: undefined, + sort_field: 'created_at', + sort_order: 'desc', }, }); const getEmptyList = () => ({ diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.test.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.test.tsx index d59285f4d8b78..76d4bb4535bc7 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.test.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/artifacts/list/policy_artifacts_list.test.tsx @@ -33,8 +33,8 @@ const getDefaultQueryParameters = (customFilter: string | undefined = '') => ({ namespace_type: ['agnostic'], page: 1, per_page: 10, - sort_field: undefined, - sort_order: undefined, + sort_field: 'created_at', + sort_order: 'desc', }, }); From 0da61413fc843f7e26c8ae7bda74e27a8a95c079 Mon Sep 17 00:00:00 2001 From: Candace Park <56409205+parkiino@users.noreply.github.com> Date: Tue, 29 Mar 2022 03:16:55 -0400 Subject: [PATCH 065/160] [Security Solution][Endpoint][Policy] Empty page for policy list (#128040) --- .../security_solution/common/constants.ts | 2 +- .../components/endpoint_policy_link.tsx | 10 +- .../components/management_empty_state.tsx | 18 +- .../pages/endpoint_hosts/view/index.tsx | 22 ++- .../components/policy_endpoint_count.tsx} | 23 ++- .../pages/policy/view/policy_details.test.tsx | 43 ++++- .../pages/policy/view/policy_details.tsx | 52 ++++-- .../pages/policy/view/policy_list.tsx | 160 ++++++++++++++---- .../services/policies/hooks.test.ts | 78 +++++++++ .../management/services/policies/hooks.ts | 30 +++- .../translations/translations/fr-FR.json | 87 +++++----- .../translations/translations/ja-JP.json | 87 +++++----- .../translations/translations/zh-CN.json | 87 +++++----- 13 files changed, 488 insertions(+), 211 deletions(-) rename x-pack/plugins/security_solution/public/management/{components/policy_endpoint_list_link.tsx => pages/policy/view/components/policy_endpoint_count.tsx} (70%) create mode 100644 x-pack/plugins/security_solution/public/management/services/policies/hooks.test.ts diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index 0d0802315063f..2e64c710aa41c 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -109,7 +109,7 @@ export enum SecurityPageName { networkHttp = 'network-http', networkTls = 'network-tls', overview = 'overview', - policies = 'policies', + policies = 'policy', rules = 'rules', timelines = 'timelines', timelinesTemplates = 'timelines-templates', diff --git a/x-pack/plugins/security_solution/public/management/components/endpoint_policy_link.tsx b/x-pack/plugins/security_solution/public/management/components/endpoint_policy_link.tsx index 0417a65b57058..c284d2b1ce3db 100644 --- a/x-pack/plugins/security_solution/public/management/components/endpoint_policy_link.tsx +++ b/x-pack/plugins/security_solution/public/management/components/endpoint_policy_link.tsx @@ -10,6 +10,7 @@ import { EuiLink, EuiLinkAnchorProps } from '@elastic/eui'; import { getPolicyDetailPath } from '../common/routing'; import { useNavigateByRouterEventHandler } from '../../common/hooks/endpoint/use_navigate_by_router_event_handler'; import { useAppUrl } from '../../common/lib/kibana/hooks'; +import { PolicyDetailsRouteState } from '../../../common/endpoint/types'; /** * A policy link (to details) that first checks to see if the policy id exists against @@ -20,17 +21,18 @@ export const EndpointPolicyLink = memo< Omit & { policyId: string; missingPolicies?: Record; + backLink?: PolicyDetailsRouteState['backLink']; } ->(({ policyId, children, onClick, missingPolicies = {}, ...otherProps }) => { +>(({ policyId, backLink, children, missingPolicies = {}, ...otherProps }) => { const { getAppUrl } = useAppUrl(); const { toRoutePath, toRouteUrl } = useMemo(() => { const path = getPolicyDetailPath(policyId); return { - toRoutePath: path, + toRoutePath: backLink ? { pathname: path, state: { backLink } } : path, toRouteUrl: getAppUrl({ path }), }; - }, [policyId, getAppUrl]); - const clickHandler = useNavigateByRouterEventHandler(toRoutePath, onClick); + }, [policyId, getAppUrl, backLink]); + const clickHandler = useNavigateByRouterEventHandler(toRoutePath); if (missingPolicies[policyId]) { return ( diff --git a/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx b/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx index a2dc37dff625b..b4a03fb18b2fe 100644 --- a/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx +++ b/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx @@ -44,7 +44,8 @@ const PolicyEmptyState = React.memo<{ loading: boolean; onActionClick: (event: MouseEvent) => void; actionDisabled?: boolean; -}>(({ loading, onActionClick, actionDisabled }) => { + policyEntryPoint?: boolean; +}>(({ loading, onActionClick, actionDisabled, policyEntryPoint = false }) => { const docLinks = useKibana().services.docLinks; return (
@@ -74,10 +75,17 @@ const PolicyEmptyState = React.memo<{ - + {policyEntryPoint ? ( + + ) : ( + + )} diff --git a/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx b/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx index 3946edb9a0981..c2d01d0181d3b 100644 --- a/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx @@ -132,6 +132,7 @@ export const EndpointList = () => { metadataTransformStats, } = useEndpointSelector(selector); const { search } = useFormatUrl(SecurityPageName.administration); + const { search: searchParams } = useLocation(); const { getAppUrl } = useAppUrl(); const dispatch = useDispatch<(a: EndpointAction) => void>(); // cap ability to page at 10k records. (max_result_window) @@ -150,6 +151,7 @@ export const EndpointList = () => { }; } + // default back button is to the policy list const policyListPath = getPoliciesPath(); return { @@ -241,6 +243,23 @@ export const EndpointList = () => { } ); + const backToEndpointList: PolicyDetailsRouteState['backLink'] = useMemo(() => { + const endpointListPath = getEndpointListPath({ name: 'endpointList' }, searchParams); + + return { + navigateTo: [ + APP_UI_ID, + { + path: endpointListPath, + }, + ], + label: i18n.translate('xpack.securitySolution.endpoint.policy.details.backToListTitle', { + defaultMessage: 'View all endpoints', + }), + href: getAppUrl({ path: endpointListPath }), + }; + }, [getAppUrl, searchParams]); + const onRefresh = useCallback(() => { dispatch({ type: 'appRequestedEndpointList', @@ -362,6 +381,7 @@ export const EndpointList = () => { policyId={policy.id} className="eui-textTruncate" data-test-subj="policyNameCellLink" + backLink={backToEndpointList} > {policy.name} @@ -504,7 +524,7 @@ export const EndpointList = () => { ], }, ]; - }, [queryParams, search, getAppUrl, PAD_LEFT]); + }, [queryParams, search, getAppUrl, backToEndpointList, PAD_LEFT]); const renderTableOrEmptyState = useMemo(() => { if (endpointsExist || areEndpointsEnrolling) { diff --git a/x-pack/plugins/security_solution/public/management/components/policy_endpoint_list_link.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/components/policy_endpoint_count.tsx similarity index 70% rename from x-pack/plugins/security_solution/public/management/components/policy_endpoint_list_link.tsx rename to x-pack/plugins/security_solution/public/management/pages/policy/view/components/policy_endpoint_count.tsx index 1386aff8bc840..08c2f1909339d 100644 --- a/x-pack/plugins/security_solution/public/management/components/policy_endpoint_list_link.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/components/policy_endpoint_count.tsx @@ -6,22 +6,26 @@ */ import React, { memo, useMemo } from 'react'; -import { EuiLink, EuiLinkAnchorProps } from '@elastic/eui'; +import { EuiLink, EuiLinkAnchorProps, EuiText } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { useLocation } from 'react-router-dom'; -import { useNavigateByRouterEventHandler } from '../../common/hooks/endpoint/use_navigate_by_router_event_handler'; -import { useAppUrl } from '../../common/lib/kibana/hooks'; -import { getEndpointListPath, getPoliciesPath } from '../common/routing'; -import { APP_UI_ID } from '../../../common/constants'; +import { useAppUrl } from '../../../../../common/lib/kibana'; +import { useNavigateByRouterEventHandler } from '../../../../../common/hooks/endpoint/use_navigate_by_router_event_handler'; +import { getEndpointListPath, getPoliciesPath } from '../../../../common/routing'; +import { APP_UI_ID } from '../../../../../../common/constants'; /** + * @param policyId + * @param nonLinkCondition: boolean where the returned component is just text and not a link + * * Returns a link component that navigates to the endpoint list page filtered by a specific policy */ -export const PolicyEndpointListLink = memo< +export const PolicyEndpointCount = memo< Omit & { policyId: string; + nonLinkCondition: boolean; } ->(({ policyId, children, ...otherProps }) => { +>(({ policyId, nonLinkCondition, children, ...otherProps }) => { const filterByPolicyQuery = `(language:kuery,query:'united.endpoint.Endpoint.policy.applied.id : "${policyId}"')`; const { search } = useLocation(); const { getAppUrl } = useAppUrl(); @@ -54,6 +58,9 @@ export const PolicyEndpointListLink = memo< }, [getAppUrl, filterByPolicyQuery, search]); const clickHandler = useNavigateByRouterEventHandler(toRoutePathWithBackOptions); + if (nonLinkCondition) { + return {children}; + } return ( // eslint-disable-next-line @elastic/eui/href-or-on-click @@ -62,4 +69,4 @@ export const PolicyEndpointListLink = memo< ); }); -PolicyEndpointListLink.displayName = 'PolicyEndpointListLink'; +PolicyEndpointCount.displayName = 'PolicyEndpointCount'; diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.test.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.test.tsx index 152e2f20b5e00..fdbe4ae83b043 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.test.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.test.tsx @@ -13,21 +13,25 @@ import { AGENT_API_ROUTES, PACKAGE_POLICY_API_ROOT } from '../../../../../../fle import { EndpointDocGenerator } from '../../../../../common/endpoint/generate_data'; import { useUserPrivileges } from '../../../../common/components/user_privileges'; import { AppContextTestRender, createAppRootMockRenderer } from '../../../../common/mock/endpoint'; -import { getEndpointListPath, getPolicyDetailPath } from '../../../common/routing'; +import { getEndpointListPath, getPoliciesPath, getPolicyDetailPath } from '../../../common/routing'; import { getHostIsolationExceptionItems } from '../../host_isolation_exceptions/service'; import { policyListApiPathHandlers } from '../store/test_mock_utils'; import { PolicyDetails } from './policy_details'; +import { APP_UI_ID } from '../../../../../common/constants'; +import { useIsExperimentalFeatureEnabled } from '../../../../common/hooks/use_experimental_features'; jest.mock('./policy_forms/components/policy_form_layout'); jest.mock('../../../../common/components/user_privileges'); jest.mock('../../host_isolation_exceptions/service'); +jest.mock('../../../../common/hooks/use_experimental_features'); const useUserPrivilegesMock = useUserPrivileges as jest.Mock; const getHostIsolationExceptionItemsMock = getHostIsolationExceptionItems as jest.Mock; +const useIsExperimentalFeatureMock = useIsExperimentalFeatureEnabled as jest.Mock; describe('Policy Details', () => { const policyDetailsPathUrl = getPolicyDetailPath('1'); - const endpointListPath = getEndpointListPath({ name: 'endpointList' }); + const policyListPath = getPoliciesPath(); const sleep = (ms = 100) => new Promise((wakeup) => setTimeout(wakeup, ms)); const generator = new EndpointDocGenerator(); let history: AppContextTestRender['history']; @@ -51,6 +55,9 @@ describe('Policy Details', () => { let releaseApiFailure: () => void; beforeEach(() => { + useIsExperimentalFeatureMock.mockReturnValue({ + policyListEnabled: true, + }); http.get.mockImplementation(async () => { await new Promise((_, reject) => { releaseApiFailure = reject.bind(null, new Error('policy not found')); @@ -125,14 +132,14 @@ describe('Policy Details', () => { expect(policyView.find('flyoutOverlay')).toHaveLength(0); }); - it('should display back to list button and policy title', async () => { + it('should display back to policy list button and policy title', async () => { policyView = render(); await asyncActions; policyView.update(); const backToListLink = policyView.find('BackToExternalAppButton'); - expect(backToListLink.prop('backButtonUrl')).toBe(`/app/security${endpointListPath}`); - expect(backToListLink.text()).toBe('View all endpoints'); + expect(backToListLink.prop('backButtonUrl')).toBe(`/app/security${policyListPath}`); + expect(backToListLink.text()).toBe('Back to policy list'); const pageTitle = policyView.find('span[data-test-subj="header-page-title"]'); expect(pageTitle).toHaveLength(1); @@ -147,7 +154,31 @@ describe('Policy Details', () => { const backToListLink = policyView.find('a[data-test-subj="policyDetailsBackLink"]'); expect(history.location.pathname).toEqual(policyDetailsPathUrl); backToListLink.simulate('click', { button: 0 }); - expect(history.location.pathname).toEqual(endpointListPath); + expect(history.location.pathname).toEqual(policyListPath); + }); + + it('should display and navigate to custom back button if non-default backLink state is present', async () => { + const customBackLinkState = { + backLink: { + navigateTo: [ + APP_UI_ID, + { + path: getEndpointListPath({ name: 'endpointList' }), + }, + ], + label: 'View all endpoints', + href: '/app/security/administration/endpoints', + }, + }; + + history.push({ pathname: policyDetailsPathUrl, state: customBackLinkState }); + policyView = render(); + await asyncActions; + policyView.update(); + + const backToListLink = policyView.find('BackToExternalAppButton'); + expect(backToListLink.prop('backButtonUrl')).toBe(`/app/security/administration/endpoints`); + expect(backToListLink.text()).toBe('View all endpoints'); }); it('should display agent stats', async () => { diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.tsx index df660bedd3ab9..210b32fcaad65 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/policy_details.tsx @@ -19,11 +19,13 @@ import { BackToExternalAppButtonProps, } from '../../../components/back_to_external_app_button/back_to_external_app_button'; import { PolicyDetailsRouteState } from '../../../../../common/endpoint/types'; -import { getEndpointListPath } from '../../../common/routing'; +import { getEndpointListPath, getPoliciesPath } from '../../../common/routing'; import { useAppUrl } from '../../../../common/lib/kibana'; import { APP_UI_ID } from '../../../../../common/constants'; +import { useIsExperimentalFeatureEnabled } from '../../../../common/hooks/use_experimental_features'; export const PolicyDetails = React.memo(() => { + const isPolicyListEnabled = useIsExperimentalFeatureEnabled('policyListEnabled'); const { state: routeState = {} } = useLocation(); const { getAppUrl } = useAppUrl(); @@ -45,24 +47,38 @@ export const PolicyDetails = React.memo(() => { }; } - const endpointListPath = getEndpointListPath({ name: 'endpointList' }); - - return { - backButtonLabel: i18n.translate( - 'xpack.securitySolution.endpoint.policy.details.backToListTitle', - { + if (isPolicyListEnabled) { + // default is to go back to the policy list + const policyListPath = getPoliciesPath(); + return { + backButtonLabel: i18n.translate('xpack.securitySolution.policyDetails.backToPolicyButton', { + defaultMessage: 'Back to policy list', + }), + backButtonUrl: getAppUrl({ path: policyListPath }), + onBackButtonNavigateTo: [ + APP_UI_ID, + { + path: policyListPath, + }, + ], + }; + } else { + // remove else block once policy list is not hidden behind feature flag + const endpointListPath = getEndpointListPath({ name: 'endpointList' }); + return { + backButtonLabel: i18n.translate('xpack.securitySolution.policyDetails.backToEndpointList', { defaultMessage: 'View all endpoints', - } - ), - backButtonUrl: getAppUrl({ path: endpointListPath }), - onBackButtonNavigateTo: [ - APP_UI_ID, - { - path: endpointListPath, - }, - ], - }; - }, [getAppUrl, routeState?.backLink]); + }), + backButtonUrl: getAppUrl({ path: endpointListPath }), + onBackButtonNavigateTo: [ + APP_UI_ID, + { + path: endpointListPath, + }, + ], + }; + } + }, [getAppUrl, routeState?.backLink, isPolicyListEnabled]); const headerRightContent = ( { const { pagination, pageSizeOptions, setPagination } = useUrlPagination(); + const { search } = useLocation(); + const { getAppUrl } = useAppUrl(); + const toasts = useToasts(); // load the list of policies - const { data, isFetching, error } = useGetEndpointSpecificPolicies({ + const { + data, + isFetching: policyIsFetching, + error, + } = useGetEndpointSpecificPolicies({ page: pagination.page, perPage: pagination.pageSize, }); // endpoint count per policy - const policyIds = data?.items.map((policies) => policies.id) ?? []; + const policyIds = useMemo(() => data?.items.map((policies) => policies.id) ?? [], [data]); const { data: endpointCount = { items: [] } } = useGetAgentCountForPolicy({ policyIds, - customQueryOptions: { enabled: policyIds.length > 0 }, + customQueryOptions: { + enabled: policyIds.length > 0, + onError: (err) => { + toasts.addDanger( + i18n.translate('xpack.securitySolution.policyList.endpointCountError', { + defaultMessage: 'Error retrieving endpoint counts', + }) + ); + }, + }, }); + // grab endpoint version for empty page + const { data: endpointPackageInfo, isFetching: packageIsFetching } = + useGetEndpointSecurityPackage({ + customQueryOptions: { + enabled: policyIds.length === 0, + onError: (err) => { + toasts.addDanger( + i18n.translate('xpack.securitySolution.policyList.packageVersionError', { + defaultMessage: 'Error retrieving the endpoint package version', + }) + ); + }, + }, + }); + const policyIdToEndpointCount = useMemo(() => { const map = new Map(); for (const policy of endpointCount?.items) { map.set(policy.package_policies[0], policy.agents ?? 0); } + + // error with the endpointCount api call, set default count to 0 + if (policyIds.length > 0 && map.size === 0) { + for (const policy of policyIds) { + map.set(policy, 0); + } + } return map; - }, [endpointCount]); + }, [endpointCount, policyIds]); - const totalItemCount = data?.total ?? 0; + const totalItemCount = useMemo(() => data?.total ?? 0, [data]); + const policyListPath = useMemo(() => getPoliciesPath(search), [search]); + + const backLink: PolicyDetailsRouteState['backLink'] = useMemo(() => { + return { + navigateTo: [ + APP_UI_ID, + { + path: policyListPath, + }, + ], + label: i18n.translate('xpack.securitySolution.policy.backToPolicyList', { + defaultMessage: 'Back to policy list', + }), + href: getAppUrl({ path: policyListPath }), + }; + }, [getAppUrl, policyListPath]); + + const handleCreatePolicyClick = useNavigateToAppEventHandler( + 'fleet', + { + path: `/integrations/${ + endpointPackageInfo ? `/endpoint-${endpointPackageInfo?.version}` : '' + }/add-integration`, + state: { + onCancelNavigateTo: [ + APP_UI_ID, + { + path: policyListPath, + }, + ], + onCancelUrl: getAppUrl({ path: getPoliciesPath() }), + onSaveNavigateTo: [ + APP_UI_ID, + { + path: policyListPath, + }, + ], + }, + } + ); const policyColumns = useMemo(() => { const updatedAtColumnName = i18n.translate('xpack.securitySolution.policy.list.updatedAt', { defaultMessage: 'Last Updated', @@ -77,6 +163,7 @@ export const PolicyList = memo(() => { policyId={policy.id} className="eui-textTruncate" data-test-subj="policyNameCellLink" + backLink={backLink} > {policy.name} @@ -155,28 +242,23 @@ export const PolicyList = memo(() => { name: i18n.translate('xpack.securitySolution.policy.list.endpoints', { defaultMessage: 'Endpoints', }), - dataType: 'number', width: '8%', render: (policy: PolicyData) => { + const count = policyIdToEndpointCount.get(policy.id); return ( - - {policyIdToEndpointCount.get(policy.id)} - + {count} + ); }, }, - { - field: '-', - name: i18n.translate('xpack.securitySolution.policy.list.actions', { - defaultMessage: 'Actions', - }), - }, ]; - }, [policyIdToEndpointCount]); + }, [policyIdToEndpointCount, backLink]); const handleTableOnChange = useCallback( ({ page }: CriteriaWithPagination) => { @@ -212,23 +294,33 @@ export const PolicyList = memo(() => { 'Use endpoint policies to customize endpoint security protections and other configurations', })} > - - 0 ? ( + <> + + + + + + + ) : ( + - - - + )} ); }); diff --git a/x-pack/plugins/security_solution/public/management/services/policies/hooks.test.ts b/x-pack/plugins/security_solution/public/management/services/policies/hooks.test.ts new file mode 100644 index 0000000000000..2b01366d8306e --- /dev/null +++ b/x-pack/plugins/security_solution/public/management/services/policies/hooks.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { useGetEndpointSecurityPackage } from './hooks'; +import { HttpFetchError, HttpSetup } from 'kibana/public'; +import { getFakeHttpService, renderQuery } from '../../hooks/artifacts/test_utils'; +import { EndpointDocGenerator } from '../../../../common/endpoint/generate_data'; +import { UseQueryOptions } from 'react-query'; +import { GetPackagesResponse } from '../../../../../fleet/common'; +import { useHttp } from '../../../common/lib/kibana'; + +jest.mock('../../../common/lib/kibana'); + +describe('useGetEndpointSecurityPackage hook', () => { + let result: ReturnType; + let fakeHttpServices: jest.Mocked; + let generator: EndpointDocGenerator; + let options: UseQueryOptions | undefined; + + beforeEach(() => { + fakeHttpServices = getFakeHttpService(); + (useHttp as jest.Mock).mockReturnValue(fakeHttpServices); + generator = new EndpointDocGenerator('endpoint-package'); + }); + + afterEach(() => { + options = undefined; + }); + + it('retrieves the endpoint package', async () => { + const apiResponse = { + items: [generator.generateEpmPackage()], + }; + fakeHttpServices.get.mockResolvedValue(apiResponse); + const onSuccessMock: jest.Mock = jest.fn(); + options = { + enabled: true, + onSuccess: onSuccessMock, + retry: false, + }; + + result = await renderQuery( + () => useGetEndpointSecurityPackage({ customQueryOptions: options }), + 'isSuccess' + ); + expect(result.data).toBe(apiResponse.items[0]); + expect(fakeHttpServices.get).toHaveBeenCalledTimes(1); + expect(onSuccessMock).toHaveBeenCalledTimes(1); + }); + + it('throws when the service fails to retrieve the endpoint package', async () => { + const error = { + response: { + status: 500, + }, + }; + fakeHttpServices.get.mockRejectedValue(error); + const onErrorMock: jest.Mock = jest.fn(); + options = { + enabled: true, + onError: onErrorMock, + retry: false, + }; + + result = await renderQuery( + () => useGetEndpointSecurityPackage({ customQueryOptions: options }), + 'isError' + ); + + expect(result.error).toBe(error); + expect(fakeHttpServices.get).toHaveBeenCalledTimes(1); + expect(onErrorMock).toHaveBeenCalledTimes(1); + }); +}); diff --git a/x-pack/plugins/security_solution/public/management/services/policies/hooks.ts b/x-pack/plugins/security_solution/public/management/services/policies/hooks.ts index a3be84bcf1eea..7b8ce6a86b148 100644 --- a/x-pack/plugins/security_solution/public/management/services/policies/hooks.ts +++ b/x-pack/plugins/security_solution/public/management/services/policies/hooks.ts @@ -9,10 +9,14 @@ import { HttpFetchError } from 'kibana/public'; import { AGENT_POLICY_SAVED_OBJECT_TYPE, GetAgentPoliciesResponse, + GetPackagesResponse, } from '../../../../../fleet/common'; -import { useHttp } from '../../../common/lib/kibana/hooks'; +import { useHttp } from '../../../common/lib/kibana'; import { MANAGEMENT_DEFAULT_PAGE_SIZE } from '../../common/constants'; -import { sendGetAgentPolicyList } from '../../pages/policy/store/services/ingest'; +import { + sendGetAgentPolicyList, + sendGetEndpointSecurityPackage, +} from '../../pages/policy/store/services/ingest'; import { GetPolicyListResponse } from '../../pages/policy/types'; import { sendGetEndpointSpecificPackagePolicies } from './policies'; import { ServerApiError } from '../../../common/types'; @@ -78,3 +82,25 @@ export function useGetAgentCountForPolicy({ } ); } + +/** + * This hook returns the endpoint security package which contains endpoint version info + */ +export function useGetEndpointSecurityPackage({ + customQueryOptions = {}, +}: { + customQueryOptions?: UseQueryOptions; +}): QueryObserverResult { + const http = useHttp(); + return useQuery( + ['endpointPackageVersion', customQueryOptions], + () => { + return sendGetEndpointSecurityPackage(http); + }, + { + refetchIntervalInBackground: false, + refetchOnWindowFocus: false, + ...customQueryOptions, + } + ); +} diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 63bc9f34c8a11..7b6e87e2d49db 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -642,10 +642,7 @@ "xpack.lens.section.workspaceLabel": "Espace de travail de visualisation", "xpack.lens.shared.chartValueLabelVisibilityLabel": "Étiquettes", "xpack.lens.shared.curveLabel": "Options visuelles", - "expressionXY.legend.filterForValueButtonAriaLabel": "Filtre pour la valeur", "xpack.lens.shared.legend.filterOptionsLegend": "{legendDataLabel}, options de filtre", - "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}, options de filtre", - "expressionXY.legend.filterOutValueButtonAriaLabel": "Filtrer la valeur", "xpack.lens.shared.legendAlignmentLabel": "Alignement", "xpack.lens.shared.legendInsideAlignmentLabel": "Alignement", "xpack.lens.shared.legendInsideColumnsLabel": "Nombre de colonnes", @@ -731,77 +728,37 @@ "xpack.lens.xyChart.axisSide.left": "Gauche", "xpack.lens.xyChart.axisSide.right": "Droite", "xpack.lens.xyChart.axisSide.top": "Haut", - "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "Afficher les titres des axes X et Y", "xpack.lens.xyChart.bottomAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe du bas est activé.", "xpack.lens.xyChart.bottomAxisLabel": "Axe du bas", "xpack.lens.xyChart.boundaryError": "La limite inférieure doit être plus grande que la limite supérieure", "xpack.lens.xyChart.curveStyleLabel": "Courbes", - "expressionXY.xyVis.curveType.help": "Définir de quelle façon le type de courbe est rendu pour un graphique linéaire", - "expressionXY.xyChart.emptyXLabel": "(vide)", - "expressionXY.axisExtentConfig.extentMode.help": "Mode d'extension", - "expressionXY.xyVis.fillOpacity.help": "Définir l'opacité du remplissage du graphique en aires", "xpack.lens.xyChart.fillOpacityLabel": "Opacité de remplissage", - "expressionXY.xyVis.fittingFunction.help": "Définir le mode de traitement des valeurs manquantes", - "expressionXY.legendConfig.floatingColumns.help": "Spécifie le nombre de colonnes lorsque la légende est affichée à l'intérieur du graphique.", "xpack.lens.xyChart.Gridlines": "Quadrillage", - "expressionXY.xyVis.gridlinesVisibilitySettings.help": "Afficher le quadrillage des axes X et Y", - "expressionXY.xyVis.help": "Graphique X/Y", - "expressionXY.xyVis.hideEndzones.help": "Masquer les marqueurs de zone de fin pour les données partielles", - "expressionXY.legendConfig.horizontalAlignment.help": "Spécifie l'alignement horizontal de la légende lorsqu'elle est affichée à l'intérieur du graphique.", "xpack.lens.xyChart.horizontalAxisLabel": "Axe horizontal", "xpack.lens.xyChart.inclusiveZero": "Les limites doivent inclure zéro.", - "expressionXY.legendConfig.isInside.help": "Spécifie si une légende se trouve à l'intérieur d'un graphique", - "expressionXY.legendConfig.isVisible.help": "Spécifie si la légende est visible ou non.", - "expressionXY.xyVis.labelsOrientation.help": "Définit la rotation des étiquettes des axes", "xpack.lens.xyChart.leftAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe de gauche est activé.", "xpack.lens.xyChart.leftAxisLabel": "Axe de gauche", - "expressionXY.xyVis.legend.help": "Configurez la légende du graphique.", "xpack.lens.xyChart.legendLocation.inside": "Intérieur", "xpack.lens.xyChart.legendLocation.outside": "Extérieur", "xpack.lens.xyChart.legendVisibility.auto": "Auto", "xpack.lens.xyChart.legendVisibility.hide": "Masquer", "xpack.lens.xyChart.legendVisibility.show": "Afficher", - "expressionXY.legendConfig.maxLines.help": "Spécifie le nombre de lignes par élément de légende.", "xpack.lens.xyChart.missingValuesLabel": "Valeurs manquantes", "xpack.lens.xyChart.missingValuesLabelHelpText": "Par défaut, Lens masque les blancs dans les données. Pour remplir le blanc, effectuez une sélection.", "xpack.lens.xyChart.nestUnderRoot": "Ensemble de données entier", - "expressionXY.legendConfig.position.help": "Spécifie la position de la légende.", - "expressionXY.xyVis.renderer.help": "Outil de rendu de graphique X/Y", "xpack.lens.xyChart.rightAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe de droite est activé.", "xpack.lens.xyChart.rightAxisLabel": "Axe de droite", "xpack.lens.xyChart.seriesColor.auto": "Auto", "xpack.lens.xyChart.seriesColor.label": "Couleur de la série", - "expressionXY.legendConfig.shouldTruncate.help": "Spécifie si les éléments de légende seront tronqués ou non", "xpack.lens.xyChart.showEnzones": "Afficher les marqueurs de données partielles", - "expressionXY.legendConfig.showSingleSeries.help": "Spécifie si une légende comportant une seule entrée doit être affichée", "xpack.lens.xyChart.splitSeries": "Répartir par", "xpack.lens.xyChart.tickLabels": "Étiquettes de graduation", - "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "Afficher les étiquettes de graduation des axes X et Y", "xpack.lens.xyChart.topAxisDisabledHelpText": "Ce paramètre s'applique uniquement lorsque l'axe du haut est activé.", "xpack.lens.xyChart.topAxisLabel": "Axe du haut", "xpack.lens.xyChart.valuesHistogramDisabledHelpText": "Ce paramètre ne peut pas être modifié dans les histogrammes.", - "expressionXY.xyVis.valuesInLegend.help": "Afficher les valeurs dans la légende", "xpack.lens.xyChart.valuesPercentageDisabledHelpText": "Ce paramètre ne peut pas être modifié dans les graphiques en aires à pourcentages.", "xpack.lens.xyChart.valuesStackedDisabledHelpText": "Ce paramètre ne peut pas être modifié dans les graphiques empilés ou les graphiques à barres à pourcentages", - "expressionXY.legendConfig.verticalAlignment.help": "Spécifie l'alignement vertical de la légende lorsqu'elle est affichée à l'intérieur du graphique.", "xpack.lens.xyChart.verticalAxisLabel": "Axe vertical", - "expressionXY.gridlinesConfig.x.help": "Spécifie si le quadrillage de l'axe X est visible ou non.", - "expressionXY.labelsOrientationConfig.x.help": "Spécifie l'orientation des étiquettes de l'axe X.", - "expressionXY.tickLabelsConfig.x.help": "Spécifie si les étiquettes de graduation de l'axe X sont visibles ou non.", - "expressionXY.axisTitlesVisibilityConfig.x.help": "Spécifie si le titre de l'axe X est visible ou non.", - "expressionXY.xyVis.xTitle.help": "Titre de l'axe X", - "expressionXY.gridlinesConfig.yLeft.help": "Spécifie si le quadrillage de l'axe Y de gauche est visible ou non.", - "expressionXY.labelsOrientationConfig.yLeft.help": "Spécifie l'orientation des étiquettes de l'axe Y de gauche.", - "expressionXY.tickLabelsConfig.yLeft.help": "Spécifie si les étiquettes de graduation de l'axe Y de gauche sont visibles ou non.", - "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "Spécifie si le titre de l'axe Y de gauche est visible ou non.", - "expressionXY.xyVis.yLeftExtent.help": "Portée de l'axe Y de gauche", - "expressionXY.xyVis.yLeftTitle.help": "Titre de l'axe Y de gauche", - "expressionXY.gridlinesConfig.yRight.help": "Spécifie si le quadrillage de l'axe Y de droite est visible ou non.", - "expressionXY.labelsOrientationConfig.yRight.help": "Spécifie l'orientation des étiquettes de l'axe Y de droite.", - "expressionXY.tickLabelsConfig.yRight.help": "Spécifie si les étiquettes de graduation de l'axe Y de droite sont visibles ou non.", - "expressionXY.axisTitlesVisibilityConfig.yRight.help": "Spécifie si le titre de l'axe Y de droite est visible ou non.", - "expressionXY.xyVis.yRightExtent.help": "Portée de l'axe Y de droite", - "expressionXY.xyVis.yRightTitle.help": "Titre de l'axe Y de droite", "xpack.lens.xySuggestions.asPercentageTitle": "Pourcentage", "xpack.lens.xySuggestions.barChartTitle": "Graphique à barres", "xpack.lens.xySuggestions.dateSuggestion": "{yTitle} sur {xTitle}", @@ -840,6 +797,49 @@ "xpack.lens.xyVisualization.stackedPercentageBarHorizontalLabel": "H. À barres à pourcentages", "xpack.lens.xyVisualization.stackedPercentageBarLabel": "Vertical à barres à pourcentages", "xpack.lens.xyVisualization.xyLabel": "XY", + "expressionXY.legend.filterForValueButtonAriaLabel": "Filtre pour la valeur", + "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}, options de filtre", + "expressionXY.legend.filterOutValueButtonAriaLabel": "Filtrer la valeur", + "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "Afficher les titres des axes X et Y", + "expressionXY.xyVis.curveType.help": "Définir de quelle façon le type de courbe est rendu pour un graphique linéaire", + "expressionXY.xyChart.emptyXLabel": "(vide)", + "expressionXY.axisExtentConfig.extentMode.help": "Mode d'extension", + "expressionXY.xyVis.fillOpacity.help": "Définir l'opacité du remplissage du graphique en aires", + "expressionXY.xyVis.fittingFunction.help": "Définir le mode de traitement des valeurs manquantes", + "expressionXY.legendConfig.floatingColumns.help": "Spécifie le nombre de colonnes lorsque la légende est affichée à l'intérieur du graphique.", + "expressionXY.xyVis.gridlinesVisibilitySettings.help": "Afficher le quadrillage des axes X et Y", + "expressionXY.xyVis.help": "Graphique X/Y", + "expressionXY.xyVis.hideEndzones.help": "Masquer les marqueurs de zone de fin pour les données partielles", + "expressionXY.legendConfig.horizontalAlignment.help": "Spécifie l'alignement horizontal de la légende lorsqu'elle est affichée à l'intérieur du graphique.", + "expressionXY.legendConfig.isInside.help": "Spécifie si une légende se trouve à l'intérieur d'un graphique", + "expressionXY.legendConfig.isVisible.help": "Spécifie si la légende est visible ou non.", + "expressionXY.xyVis.labelsOrientation.help": "Définit la rotation des étiquettes des axes", + "expressionXY.xyVis.legend.help": "Configurez la légende du graphique.", + "expressionXY.legendConfig.maxLines.help": "Spécifie le nombre de lignes par élément de légende.", + "expressionXY.legendConfig.position.help": "Spécifie la position de la légende.", + "expressionXY.xyVis.renderer.help": "Outil de rendu de graphique X/Y", + "expressionXY.legendConfig.shouldTruncate.help": "Spécifie si les éléments de légende seront tronqués ou non", + "expressionXY.legendConfig.showSingleSeries.help": "Spécifie si une légende comportant une seule entrée doit être affichée", + "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "Afficher les étiquettes de graduation des axes X et Y", + "expressionXY.xyVis.valuesInLegend.help": "Afficher les valeurs dans la légende", + "expressionXY.legendConfig.verticalAlignment.help": "Spécifie l'alignement vertical de la légende lorsqu'elle est affichée à l'intérieur du graphique.", + "expressionXY.gridlinesConfig.x.help": "Spécifie si le quadrillage de l'axe X est visible ou non.", + "expressionXY.labelsOrientationConfig.x.help": "Spécifie l'orientation des étiquettes de l'axe X.", + "expressionXY.tickLabelsConfig.x.help": "Spécifie si les étiquettes de graduation de l'axe X sont visibles ou non.", + "expressionXY.axisTitlesVisibilityConfig.x.help": "Spécifie si le titre de l'axe X est visible ou non.", + "expressionXY.xyVis.xTitle.help": "Titre de l'axe X", + "expressionXY.gridlinesConfig.yLeft.help": "Spécifie si le quadrillage de l'axe Y de gauche est visible ou non.", + "expressionXY.labelsOrientationConfig.yLeft.help": "Spécifie l'orientation des étiquettes de l'axe Y de gauche.", + "expressionXY.tickLabelsConfig.yLeft.help": "Spécifie si les étiquettes de graduation de l'axe Y de gauche sont visibles ou non.", + "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "Spécifie si le titre de l'axe Y de gauche est visible ou non.", + "expressionXY.xyVis.yLeftExtent.help": "Portée de l'axe Y de gauche", + "expressionXY.xyVis.yLeftTitle.help": "Titre de l'axe Y de gauche", + "expressionXY.gridlinesConfig.yRight.help": "Spécifie si le quadrillage de l'axe Y de droite est visible ou non.", + "expressionXY.labelsOrientationConfig.yRight.help": "Spécifie l'orientation des étiquettes de l'axe Y de droite.", + "expressionXY.tickLabelsConfig.yRight.help": "Spécifie si les étiquettes de graduation de l'axe Y de droite sont visibles ou non.", + "expressionXY.axisTitlesVisibilityConfig.yRight.help": "Spécifie si le titre de l'axe Y de droite est visible ou non.", + "expressionXY.xyVis.yRightExtent.help": "Portée de l'axe Y de droite", + "expressionXY.xyVis.yRightTitle.help": "Titre de l'axe Y de droite", "advancedSettings.advancedSettingsLabel": "Paramètres avancés", "advancedSettings.badge.readOnly.text": "Lecture seule", "advancedSettings.badge.readOnly.tooltip": "Impossible d’enregistrer les paramètres avancés", @@ -21183,7 +21183,6 @@ "xpack.securitySolution.endpoint.policyList.onboardingDocsLink": "afficher la documentation Elastic Security", "xpack.securitySolution.endpoint.policyList.onboardingSectionOne": "Protégez vos hôtes grâce à la prévention des menaces, la détection et la visibilité des données en profondeur en toute sécurité.", "xpack.securitySolution.endpoint.policyList.onboardingSectionThree": "Pour commencer, ajoutez l'intégration Endpoint Security à vos agents. Pour en savoir plus, ", - "xpack.securitySolution.endpoint.policyList.onboardingSectionTwo": "À partir de cette page, vous pourrez afficher et gérer les hôtes dans votre environnement exécutant Endpoint Security.", "xpack.securitySolution.endpoint.policyList.onboardingTitle": "Débuter avec Endpoint Security", "xpack.securitySolution.endpoint.policyResponse.appliedOn": "Révision {rev} appliquée le {date}", "xpack.securitySolution.endpoint.policyResponse.backLinkTitle": "Détails de point de terminaison", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 338cef102027f..e465e82dfa5d5 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -770,11 +770,8 @@ "xpack.lens.shared.chartValueLabelVisibilityLabel": "ラベル", "xpack.lens.shared.curveLabel": "視覚オプション", "xpack.lens.shared.legend.filterForValueButtonAriaLabel": "値でフィルター", - "expressionXY.legend.filterForValueButtonAriaLabel": "値でフィルター", - "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}、フィルターオプション", "xpack.lens.shared.legend.filterOptionsLegend": "{legendDataLabel}、フィルターオプション", "xpack.lens.shared.legend.filterOutValueButtonAriaLabel": "値を除外", - "expressionXY.legend.filterOutValueButtonAriaLabel": "値を除外", "xpack.lens.shared.legendAlignmentLabel": "アラインメント", "xpack.lens.shared.legendInsideAlignmentLabel": "アラインメント", "xpack.lens.shared.legendInsideColumnsLabel": "列の数", @@ -871,34 +868,19 @@ "xpack.lens.xyChart.axisSide.left": "左", "xpack.lens.xyChart.axisSide.right": "右", "xpack.lens.xyChart.axisSide.top": "トップ", - "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "xおよびy軸のタイトルを表示", "xpack.lens.xyChart.bottomAxisDisabledHelpText": "この設定は、下の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.bottomAxisLabel": "下の軸", "xpack.lens.xyChart.boundaryError": "下界は上界よりも大きくなければなりません", "xpack.lens.xyChart.curveStyleLabel": "曲線", - "expressionXY.xyVis.curveType.help": "折れ線グラフで曲線タイプをレンダリングする方法を定義します", - "expressionXY.xyChart.emptyXLabel": "(空)", - "expressionXY.axisExtentConfig.extentMode.help": "範囲モード", - "expressionXY.xyVis.fillOpacity.help": "エリアグラフの塗りつぶしの透明度を定義", "xpack.lens.xyChart.fillOpacityLabel": "塗りつぶしの透明度", - "expressionXY.xyVis.fittingFunction.help": "欠測値の処理方法を定義", - "expressionXY.legendConfig.floatingColumns.help": "凡例がグラフ内に表示されるときに列数を指定します。", "xpack.lens.xyChart.Gridlines": "グリッド線", - "expressionXY.xyVis.gridlinesVisibilitySettings.help": "xおよびy軸のグリッド線を表示", - "expressionXY.xyVis.help": "X/Y チャート", - "expressionXY.xyVis.hideEndzones.help": "部分データの終了ゾーンマーカーを非表示", - "expressionXY.legendConfig.horizontalAlignment.help": "凡例がグラフ内に表示されるときに凡例の横の配置を指定します。", "xpack.lens.xyChart.horizontalAxisLabel": "横軸", "xpack.lens.xyChart.horizontalLeftAxisLabel": "横上軸", "xpack.lens.xyChart.horizontalRightAxisLabel": "横下軸", "xpack.lens.xyChart.inclusiveZero": "境界にはゼロを含める必要があります。", - "expressionXY.legendConfig.isInside.help": "凡例がグラフ内に表示されるかどうかを指定します", - "expressionXY.legendConfig.isVisible.help": "判例の表示・非表示を指定します。", - "expressionXY.xyVis.labelsOrientation.help": "軸ラベルの回転を定義します", "xpack.lens.xyChart.layerReferenceLineLabel": "基準線", "xpack.lens.xyChart.leftAxisDisabledHelpText": "この設定は、左の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.leftAxisLabel": "左の軸", - "expressionXY.xyVis.legend.help": "チャートの凡例を構成します。", "xpack.lens.xyChart.legendLocation.inside": "内部", "xpack.lens.xyChart.legendLocation.outside": "外側", "xpack.lens.xyChart.legendVisibility.auto": "自動", @@ -908,49 +890,24 @@ "xpack.lens.xyChart.markerPosition.below": "一番下", "xpack.lens.xyChart.markerPosition.left": "左", "xpack.lens.xyChart.markerPosition.right": "右", - "expressionXY.legendConfig.maxLines.help": "凡例項目ごとの行数を指定します。", "xpack.lens.xyChart.missingValuesLabel": "欠測値", "xpack.lens.xyChart.missingValuesLabelHelpText": "デフォルトでは、Lensではデータのギャップが表示されません。ギャップを埋めるには、選択します。", "xpack.lens.xyChart.nestUnderRoot": "データセット全体", - "expressionXY.legendConfig.position.help": "凡例の配置を指定します。", - "expressionXY.xyVis.renderer.help": "X/Y チャートを再レンダリング", "xpack.lens.xyChart.rightAxisDisabledHelpText": "この設定は、右の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.rightAxisLabel": "右の軸", "xpack.lens.xyChart.seriesColor.auto": "自動", "xpack.lens.xyChart.seriesColor.label": "系列色", - "expressionXY.legendConfig.shouldTruncate.help": "凡例項目が切り捨てられるかどうかを指定します", "xpack.lens.xyChart.showEnzones": "部分データマーカーを表示", - "expressionXY.legendConfig.showSingleSeries.help": "エントリが1件の凡例を表示するかどうかを指定します", "xpack.lens.xyChart.splitSeries": "内訳の基準", "xpack.lens.xyChart.tickLabels": "目盛ラベル", - "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "xおよびy軸の目盛ラベルを表示", "xpack.lens.xyChart.topAxisDisabledHelpText": "この設定は、上の軸が有効であるときにのみ適用されます。", "xpack.lens.xyChart.topAxisLabel": "上の軸", "xpack.lens.xyChart.valuesHistogramDisabledHelpText": "この設定はヒストグラムで変更できません。", - "expressionXY.xyVis.valuesInLegend.help": "凡例に値を表示", "xpack.lens.xyChart.valuesPercentageDisabledHelpText": "この設定は割合エリアグラフで変更できません。", "xpack.lens.xyChart.valuesStackedDisabledHelpText": "この設定は積み上げ棒グラフまたは割合棒グラフで変更できません", - "expressionXY.legendConfig.verticalAlignment.help": "凡例がグラフ内に表示されるときに凡例の縦の配置を指定します。", "xpack.lens.xyChart.verticalAxisLabel": "縦軸", "xpack.lens.xyChart.verticalLeftAxisLabel": "縦左軸", "xpack.lens.xyChart.verticalRightAxisLabel": "縦右軸", - "expressionXY.gridlinesConfig.x.help": "x 軸のグリッド線を表示するかどうかを指定します。", - "expressionXY.labelsOrientationConfig.x.help": "x軸のラベルの向きを指定します。", - "expressionXY.tickLabelsConfig.x.help": "x軸の目盛ラベルを表示するかどうかを指定します。", - "expressionXY.axisTitlesVisibilityConfig.x.help": "x軸のタイトルを表示するかどうかを指定します。", - "expressionXY.xyVis.xTitle.help": "x軸のタイトル", - "expressionXY.gridlinesConfig.yLeft.help": "左y軸のグリッド線を表示するかどうかを指定します。", - "expressionXY.labelsOrientationConfig.yLeft.help": "左y軸のラベルの向きを指定します。", - "expressionXY.tickLabelsConfig.yLeft.help": "左y軸の目盛ラベルを表示するかどうかを指定します。", - "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "左y軸のタイトルを表示するかどうかを指定します。", - "expressionXY.xyVis.yLeftExtent.help": "Y左軸範囲", - "expressionXY.xyVis.yLeftTitle.help": "左y軸のタイトル", - "expressionXY.gridlinesConfig.yRight.help": "右y軸のグリッド線を表示するかどうかを指定します。", - "expressionXY.labelsOrientationConfig.yRight.help": "右y軸のラベルの向きを指定します。", - "expressionXY.tickLabelsConfig.yRight.help": "右y軸の目盛ラベルを表示するかどうかを指定します。", - "expressionXY.axisTitlesVisibilityConfig.yRight.help": "右y軸のタイトルを表示するかどうかを指定します。", - "expressionXY.xyVis.yRightExtent.help": "Y右軸範囲", - "expressionXY.xyVis.yRightTitle.help": "右 y 軸のタイトル", "xpack.lens.xySuggestions.asPercentageTitle": "割合(%)", "xpack.lens.xySuggestions.barChartTitle": "棒グラフ", "xpack.lens.xySuggestions.dateSuggestion": "{xTitle}の上の {yTitle}", @@ -989,6 +946,49 @@ "xpack.lens.xyVisualization.stackedPercentageBarHorizontalLabel": "H.割合棒", "xpack.lens.xyVisualization.stackedPercentageBarLabel": "縦棒割合", "xpack.lens.xyVisualization.xyLabel": "XY", + "expressionXY.legend.filterForValueButtonAriaLabel": "値でフィルター", + "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}、フィルターオプション", + "expressionXY.legend.filterOutValueButtonAriaLabel": "値を除外", + "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "xおよびy軸のタイトルを表示", + "expressionXY.xyVis.curveType.help": "折れ線グラフで曲線タイプをレンダリングする方法を定義します", + "expressionXY.xyChart.emptyXLabel": "(空)", + "expressionXY.axisExtentConfig.extentMode.help": "範囲モード", + "expressionXY.xyVis.fillOpacity.help": "エリアグラフの塗りつぶしの透明度を定義", + "expressionXY.xyVis.fittingFunction.help": "欠測値の処理方法を定義", + "expressionXY.legendConfig.floatingColumns.help": "凡例がグラフ内に表示されるときに列数を指定します。", + "expressionXY.xyVis.gridlinesVisibilitySettings.help": "xおよびy軸のグリッド線を表示", + "expressionXY.xyVis.help": "X/Y チャート", + "expressionXY.xyVis.hideEndzones.help": "部分データの終了ゾーンマーカーを非表示", + "expressionXY.legendConfig.horizontalAlignment.help": "凡例がグラフ内に表示されるときに凡例の横の配置を指定します。", + "expressionXY.legendConfig.isInside.help": "凡例がグラフ内に表示されるかどうかを指定します", + "expressionXY.legendConfig.isVisible.help": "判例の表示・非表示を指定します。", + "expressionXY.xyVis.labelsOrientation.help": "軸ラベルの回転を定義します", + "expressionXY.xyVis.legend.help": "チャートの凡例を構成します。", + "expressionXY.legendConfig.maxLines.help": "凡例項目ごとの行数を指定します。", + "expressionXY.legendConfig.position.help": "凡例の配置を指定します。", + "expressionXY.xyVis.renderer.help": "X/Y チャートを再レンダリング", + "expressionXY.legendConfig.shouldTruncate.help": "凡例項目が切り捨てられるかどうかを指定します", + "expressionXY.legendConfig.showSingleSeries.help": "エントリが1件の凡例を表示するかどうかを指定します", + "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "xおよびy軸の目盛ラベルを表示", + "expressionXY.xyVis.valuesInLegend.help": "凡例に値を表示", + "expressionXY.legendConfig.verticalAlignment.help": "凡例がグラフ内に表示されるときに凡例の縦の配置を指定します。", + "expressionXY.gridlinesConfig.x.help": "x 軸のグリッド線を表示するかどうかを指定します。", + "expressionXY.labelsOrientationConfig.x.help": "x軸のラベルの向きを指定します。", + "expressionXY.tickLabelsConfig.x.help": "x軸の目盛ラベルを表示するかどうかを指定します。", + "expressionXY.axisTitlesVisibilityConfig.x.help": "x軸のタイトルを表示するかどうかを指定します。", + "expressionXY.xyVis.xTitle.help": "x軸のタイトル", + "expressionXY.gridlinesConfig.yLeft.help": "左y軸のグリッド線を表示するかどうかを指定します。", + "expressionXY.labelsOrientationConfig.yLeft.help": "左y軸のラベルの向きを指定します。", + "expressionXY.tickLabelsConfig.yLeft.help": "左y軸の目盛ラベルを表示するかどうかを指定します。", + "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "左y軸のタイトルを表示するかどうかを指定します。", + "expressionXY.xyVis.yLeftExtent.help": "Y左軸範囲", + "expressionXY.xyVis.yLeftTitle.help": "左y軸のタイトル", + "expressionXY.gridlinesConfig.yRight.help": "右y軸のグリッド線を表示するかどうかを指定します。", + "expressionXY.labelsOrientationConfig.yRight.help": "右y軸のラベルの向きを指定します。", + "expressionXY.tickLabelsConfig.yRight.help": "右y軸の目盛ラベルを表示するかどうかを指定します。", + "expressionXY.axisTitlesVisibilityConfig.yRight.help": "右y軸のタイトルを表示するかどうかを指定します。", + "expressionXY.xyVis.yRightExtent.help": "Y右軸範囲", + "expressionXY.xyVis.yRightTitle.help": "右 y 軸のタイトル", "advancedSettings.advancedSettingsLabel": "高度な設定", "advancedSettings.badge.readOnly.text": "読み取り専用", "advancedSettings.badge.readOnly.tooltip": "高度な設定を保存できません", @@ -24275,7 +24275,6 @@ "xpack.securitySolution.endpoint.policyList.onboardingDocsLink": "Elasticsearch Securityドキュメントを表示", "xpack.securitySolution.endpoint.policyList.onboardingSectionOne": "脅威防御、検出、深いセキュリティデータの可視化を実現し、ホストを保護します。", "xpack.securitySolution.endpoint.policyList.onboardingSectionThree": "開始するには、Endpoint Security 統合をエージェントに追加します。詳細については、", - "xpack.securitySolution.endpoint.policyList.onboardingSectionTwo": "このページでは、Endpoint Securityを実行している環境でホストを表示して管理できます。", "xpack.securitySolution.endpoint.policyList.onboardingTitle": "Endpoint Securityの基本", "xpack.securitySolution.endpoint.policyResponse.appliedOn": "{date}に改訂{rev}が適用されました", "xpack.securitySolution.endpoint.policyResponse.backLinkTitle": "エンドポイント詳細", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 615229a857b11..737ad8b6e116c 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -775,10 +775,7 @@ "xpack.lens.shared.axisNameLabel": "轴标题", "xpack.lens.shared.chartValueLabelVisibilityLabel": "标签", "xpack.lens.shared.curveLabel": "视觉选项", - "expressionXY.legend.filterForValueButtonAriaLabel": "筛留值", - "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}, 筛选选项", "xpack.lens.shared.legend.filterOptionsLegend": "{legendDataLabel}, 筛选选项", - "expressionXY.legend.filterOutValueButtonAriaLabel": "筛除值", "xpack.lens.shared.legendAlignmentLabel": "对齐方式", "xpack.lens.shared.legendInsideAlignmentLabel": "对齐方式", "xpack.lens.shared.legendInsideColumnsLabel": "列数目", @@ -875,34 +872,19 @@ "xpack.lens.xyChart.axisSide.left": "左", "xpack.lens.xyChart.axisSide.right": "右", "xpack.lens.xyChart.axisSide.top": "顶部", - "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "显示 x 和 y 轴标题", "xpack.lens.xyChart.bottomAxisDisabledHelpText": "此设置仅在启用底轴时应用。", "xpack.lens.xyChart.bottomAxisLabel": "底轴", "xpack.lens.xyChart.boundaryError": "下边界必须大于上边界", "xpack.lens.xyChart.curveStyleLabel": "曲线", - "expressionXY.xyVis.curveType.help": "定义为折线图渲染曲线类型的方式", - "expressionXY.xyChart.emptyXLabel": "(空)", - "expressionXY.axisExtentConfig.extentMode.help": "范围模式", - "expressionXY.xyVis.fillOpacity.help": "定义面积图填充透明度", "xpack.lens.xyChart.fillOpacityLabel": "填充透明度", - "expressionXY.xyVis.fittingFunction.help": "定义处理缺失值的方式", - "expressionXY.legendConfig.floatingColumns.help": "指定图例显示在图表内时的列数。", "xpack.lens.xyChart.Gridlines": "网格线", - "expressionXY.xyVis.gridlinesVisibilitySettings.help": "显示 x 和 y 轴网格线", - "expressionXY.xyVis.help": "X/Y 图表", - "expressionXY.xyVis.hideEndzones.help": "隐藏部分数据的末日区域标记", - "expressionXY.legendConfig.horizontalAlignment.help": "指定图例显示在图表内时水平对齐。", "xpack.lens.xyChart.horizontalAxisLabel": "水平轴", "xpack.lens.xyChart.horizontalLeftAxisLabel": "水平顶轴", "xpack.lens.xyChart.horizontalRightAxisLabel": "水平底轴", "xpack.lens.xyChart.inclusiveZero": "边界必须包括零。", - "expressionXY.legendConfig.isInside.help": "指定图例是否在图表内", - "expressionXY.legendConfig.isVisible.help": "指定图例是否可见。", - "expressionXY.xyVis.labelsOrientation.help": "定义轴标签的旋转", "xpack.lens.xyChart.layerReferenceLineLabel": "参考线", "xpack.lens.xyChart.leftAxisDisabledHelpText": "此设置仅在启用左轴时应用。", "xpack.lens.xyChart.leftAxisLabel": "左轴", - "expressionXY.xyVis.legend.help": "配置图表图例。", "xpack.lens.xyChart.legendLocation.inside": "内部", "xpack.lens.xyChart.legendLocation.outside": "外部", "xpack.lens.xyChart.legendVisibility.auto": "自动", @@ -912,49 +894,24 @@ "xpack.lens.xyChart.markerPosition.below": "底部", "xpack.lens.xyChart.markerPosition.left": "左", "xpack.lens.xyChart.markerPosition.right": "右", - "expressionXY.legendConfig.maxLines.help": "指定每个图例项的行数。", "xpack.lens.xyChart.missingValuesLabel": "缺少的值", "xpack.lens.xyChart.missingValuesLabelHelpText": "默认情况下,Lens 隐藏数据中的缺口。要填充缺口,请进行选择。", "xpack.lens.xyChart.nestUnderRoot": "整个数据集", - "expressionXY.legendConfig.position.help": "指定图例位置。", - "expressionXY.xyVis.renderer.help": "X/Y 图表呈现器", "xpack.lens.xyChart.rightAxisDisabledHelpText": "此设置仅在启用右轴时应用。", "xpack.lens.xyChart.rightAxisLabel": "右轴", "xpack.lens.xyChart.seriesColor.auto": "自动", "xpack.lens.xyChart.seriesColor.label": "系列颜色", - "expressionXY.legendConfig.shouldTruncate.help": "指定是否将截断图例项", "xpack.lens.xyChart.showEnzones": "显示部分数据标记", - "expressionXY.legendConfig.showSingleSeries.help": "指定是否应显示只包含一个条目的图例", "xpack.lens.xyChart.splitSeries": "细分方式", "xpack.lens.xyChart.tickLabels": "刻度标签", - "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "显示 x 和 y 轴刻度标签", "xpack.lens.xyChart.topAxisDisabledHelpText": "此设置仅在启用顶轴时应用。", "xpack.lens.xyChart.topAxisLabel": "顶轴", "xpack.lens.xyChart.valuesHistogramDisabledHelpText": "不能在直方图上更改此设置。", - "expressionXY.xyVis.valuesInLegend.help": "在图例中显示值", "xpack.lens.xyChart.valuesPercentageDisabledHelpText": "不能在百分比面积图上更改此设置。", "xpack.lens.xyChart.valuesStackedDisabledHelpText": "不能在堆积图或百分比条形图上更改此设置", - "expressionXY.legendConfig.verticalAlignment.help": "指定图例显示在图表内时垂直对齐。", "xpack.lens.xyChart.verticalAxisLabel": "垂直轴", "xpack.lens.xyChart.verticalLeftAxisLabel": "垂直左轴", "xpack.lens.xyChart.verticalRightAxisLabel": "垂直右轴", - "expressionXY.gridlinesConfig.x.help": "指定 x 轴的网格线是否可见。", - "expressionXY.labelsOrientationConfig.x.help": "指定 x 轴的标签方向。", - "expressionXY.tickLabelsConfig.x.help": "指定 x 轴的刻度标签是否可见。", - "expressionXY.axisTitlesVisibilityConfig.x.help": "指定 x 轴的标题是否可见。", - "expressionXY.xyVis.xTitle.help": "X 轴标题", - "expressionXY.gridlinesConfig.yLeft.help": "指定左侧 y 轴的网格线是否可见。", - "expressionXY.labelsOrientationConfig.yLeft.help": "指定左 y 轴的标签方向。", - "expressionXY.tickLabelsConfig.yLeft.help": "指定左侧 y 轴的刻度标签是否可见。", - "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "指定左侧 y 轴的标题是否可见。", - "expressionXY.xyVis.yLeftExtent.help": "左侧 Y 轴范围", - "expressionXY.xyVis.yLeftTitle.help": "左侧 Y 轴标题", - "expressionXY.gridlinesConfig.yRight.help": "指定右侧 y 轴的网格线是否可见。", - "expressionXY.labelsOrientationConfig.yRight.help": "指定右 y 轴的标签方向。", - "expressionXY.tickLabelsConfig.yRight.help": "指定右侧 y 轴的刻度标签是否可见。", - "expressionXY.axisTitlesVisibilityConfig.yRight.help": "指定右侧 y 轴的标题是否可见。", - "expressionXY.xyVis.yRightExtent.help": "右侧 Y 轴范围", - "expressionXY.xyVis.yRightTitle.help": "右侧 Y 轴标题", "xpack.lens.xySuggestions.asPercentageTitle": "百分比", "xpack.lens.xySuggestions.barChartTitle": "条形图", "xpack.lens.xySuggestions.dateSuggestion": "{yTitle} / {xTitle}", @@ -993,6 +950,49 @@ "xpack.lens.xyVisualization.stackedPercentageBarHorizontalLabel": "水平百分比条形图", "xpack.lens.xyVisualization.stackedPercentageBarLabel": "垂直百分比条形图", "xpack.lens.xyVisualization.xyLabel": "XY", + "expressionXY.legend.filterForValueButtonAriaLabel": "筛留值", + "expressionXY.legend.filterOptionsLegend": "{legendDataLabel}, 筛选选项", + "expressionXY.legend.filterOutValueButtonAriaLabel": "筛除值", + "expressionXY.xyVis.axisTitlesVisibilitySettings.help": "显示 x 和 y 轴标题", + "expressionXY.xyVis.curveType.help": "定义为折线图渲染曲线类型的方式", + "expressionXY.xyChart.emptyXLabel": "(空)", + "expressionXY.axisExtentConfig.extentMode.help": "范围模式", + "expressionXY.xyVis.fillOpacity.help": "定义面积图填充透明度", + "expressionXY.xyVis.fittingFunction.help": "定义处理缺失值的方式", + "expressionXY.legendConfig.floatingColumns.help": "指定图例显示在图表内时的列数。", + "expressionXY.xyVis.gridlinesVisibilitySettings.help": "显示 x 和 y 轴网格线", + "expressionXY.xyVis.help": "X/Y 图表", + "expressionXY.xyVis.hideEndzones.help": "隐藏部分数据的末日区域标记", + "expressionXY.legendConfig.horizontalAlignment.help": "指定图例显示在图表内时水平对齐。", + "expressionXY.legendConfig.isInside.help": "指定图例是否在图表内", + "expressionXY.legendConfig.isVisible.help": "指定图例是否可见。", + "expressionXY.xyVis.labelsOrientation.help": "定义轴标签的旋转", + "expressionXY.xyVis.legend.help": "配置图表图例。", + "expressionXY.legendConfig.maxLines.help": "指定每个图例项的行数。", + "expressionXY.legendConfig.position.help": "指定图例位置。", + "expressionXY.xyVis.renderer.help": "X/Y 图表呈现器", + "expressionXY.legendConfig.shouldTruncate.help": "指定是否将截断图例项", + "expressionXY.legendConfig.showSingleSeries.help": "指定是否应显示只包含一个条目的图例", + "expressionXY.xyVis.tickLabelsVisibilitySettings.help": "显示 x 和 y 轴刻度标签", + "expressionXY.xyVis.valuesInLegend.help": "在图例中显示值", + "expressionXY.legendConfig.verticalAlignment.help": "指定图例显示在图表内时垂直对齐。", + "expressionXY.gridlinesConfig.x.help": "指定 x 轴的网格线是否可见。", + "expressionXY.labelsOrientationConfig.x.help": "指定 x 轴的标签方向。", + "expressionXY.tickLabelsConfig.x.help": "指定 x 轴的刻度标签是否可见。", + "expressionXY.axisTitlesVisibilityConfig.x.help": "指定 x 轴的标题是否可见。", + "expressionXY.xyVis.xTitle.help": "X 轴标题", + "expressionXY.gridlinesConfig.yLeft.help": "指定左侧 y 轴的网格线是否可见。", + "expressionXY.labelsOrientationConfig.yLeft.help": "指定左 y 轴的标签方向。", + "expressionXY.tickLabelsConfig.yLeft.help": "指定左侧 y 轴的刻度标签是否可见。", + "expressionXY.axisTitlesVisibilityConfig.yLeft.help": "指定左侧 y 轴的标题是否可见。", + "expressionXY.xyVis.yLeftExtent.help": "左侧 Y 轴范围", + "expressionXY.xyVis.yLeftTitle.help": "左侧 Y 轴标题", + "expressionXY.gridlinesConfig.yRight.help": "指定右侧 y 轴的网格线是否可见。", + "expressionXY.labelsOrientationConfig.yRight.help": "指定右 y 轴的标签方向。", + "expressionXY.tickLabelsConfig.yRight.help": "指定右侧 y 轴的刻度标签是否可见。", + "expressionXY.axisTitlesVisibilityConfig.yRight.help": "指定右侧 y 轴的标题是否可见。", + "expressionXY.xyVis.yRightExtent.help": "右侧 Y 轴范围", + "expressionXY.xyVis.yRightTitle.help": "右侧 Y 轴标题", "advancedSettings.advancedSettingsLabel": "高级设置", "advancedSettings.badge.readOnly.text": "只读", "advancedSettings.badge.readOnly.tooltip": "无法保存高级设置", @@ -24303,7 +24303,6 @@ "xpack.securitySolution.endpoint.policyList.onboardingDocsLink": "查看 Elastic Security 文档", "xpack.securitySolution.endpoint.policyList.onboardingSectionOne": "使用威胁防御、检测和深度安全数据可见性功能保护您的主机。", "xpack.securitySolution.endpoint.policyList.onboardingSectionThree": "首先,将 Endpoint Security 集成添加到您的代理。有关更多信息,", - "xpack.securitySolution.endpoint.policyList.onboardingSectionTwo": "从此页面,您将可以查看和管理环境中运行 Endpoint Security 的主机。", "xpack.securitySolution.endpoint.policyList.onboardingTitle": "开始使用 Endpoint Security", "xpack.securitySolution.endpoint.policyResponse.appliedOn": "修订 {rev} 应用于 {date}", "xpack.securitySolution.endpoint.policyResponse.backLinkTitle": "终端详情", From e628ae5b54fcaf240415864a1de3fda4b4b82f75 Mon Sep 17 00:00:00 2001 From: Katerina Patticha Date: Tue, 29 Mar 2022 09:46:14 +0200 Subject: [PATCH 066/160] [APM] Add loading state for trace samples (#128268) * Add loading state for trace samples * Fix message when there are no traces * Remove unused status * Use traces samples status to display loading indicator * Clean up code * Fix tests --- .../distribution/index.test.tsx | 2 + .../distribution/index.tsx | 8 +- .../transaction_details/trace_samples_tab.tsx | 2 + .../transaction_details_tabs.tsx | 12 +- .../app/transaction_details/types.ts | 2 + .../waterfall_with_summary/index.tsx | 72 ++++++----- .../maybe_view_trace_link.tsx | 114 ++++++++++-------- .../waterfall/transaction_flyout/index.tsx | 5 +- .../custom_link_list.tsx | 4 +- .../custom_link_menu_section/index.tsx | 2 +- .../transaction_action_menu/sections.ts | 3 +- .../transaction_action_menu.test.tsx | 7 +- .../transaction_action_menu.tsx | 108 ++++++++++------- 13 files changed, 197 insertions(+), 144 deletions(-) diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.test.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.test.tsx index 1e4d1816bf84a..e2530458ae980 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.test.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.test.tsx @@ -100,6 +100,7 @@ describe('transaction_details/distribution', () => { onChartSelection={jest.fn()} onClearSelection={jest.fn()} traceSamples={[]} + traceSamplesStatus={useFetcherModule.FETCH_STATUS.LOADING} />, { wrapper: Wrapper } @@ -124,6 +125,7 @@ describe('transaction_details/distribution', () => { onChartSelection={jest.fn()} onClearSelection={jest.fn()} traceSamples={[]} + traceSamplesStatus={useFetcherModule.FETCH_STATUS.SUCCESS} /> ); diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.tsx index 7d387a39f9334..ca2a3584c8942 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/distribution/index.tsx @@ -59,6 +59,7 @@ interface TransactionDistributionProps { onClearSelection: () => void; selection?: Selection; traceSamples: TabContentProps['traceSamples']; + traceSamplesStatus: FETCH_STATUS; } export function TransactionDistribution({ @@ -66,10 +67,15 @@ export function TransactionDistribution({ onClearSelection, selection, traceSamples, + traceSamplesStatus, }: TransactionDistributionProps) { const { urlParams } = useLegacyUrlParams(); const { waterfall, status: waterfallStatus } = useWaterfallFetcher(); + const isLoading = + waterfallStatus === FETCH_STATUS.LOADING || + traceSamplesStatus === FETCH_STATUS.LOADING; + const markerCurrentTransaction = waterfall.entryWaterfallTransaction?.doc.transaction.duration.us; @@ -189,7 +195,7 @@ export function TransactionDistribution({
diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/trace_samples_tab.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/trace_samples_tab.tsx index ad629b7a2d132..d83211a72ea59 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/trace_samples_tab.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/trace_samples_tab.tsx @@ -18,6 +18,7 @@ function TraceSamplesTab({ sampleRangeFrom, sampleRangeTo, traceSamples, + traceSamplesStatus, }: TabContentProps) { return ( ); diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/transaction_details_tabs.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/transaction_details_tabs.tsx index 5e9f1f8149d9d..b0b5d495d1f8e 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/transaction_details_tabs.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/transaction_details_tabs.tsx @@ -41,11 +41,12 @@ export function TransactionDetailsTabs() { tabs.find((tab) => tab.key === currentTab) ?? traceSamplesTab; const { environment, kuery, transactionName } = query; - const { traceSamplesData } = useTransactionTraceSamplesFetcher({ - transactionName, - kuery, - environment, - }); + const { traceSamplesData, traceSamplesStatus } = + useTransactionTraceSamplesFetcher({ + transactionName, + kuery, + environment, + }); const selectSampleFromChartSelection = (selection: XYBrushEvent) => { if (selection !== undefined) { @@ -139,6 +140,7 @@ export function TransactionDetailsTabs() { sampleRangeTo, selectSampleFromChartSelection, traceSamples, + traceSamplesStatus, }} />
diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/types.ts b/x-pack/plugins/apm/public/components/app/transaction_details/types.ts index c3d2b9648e82a..2014f7588293d 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/types.ts +++ b/x-pack/plugins/apm/public/components/app/transaction_details/types.ts @@ -8,6 +8,7 @@ import { XYBrushEvent } from '@elastic/charts'; import type { TraceSample } from '../../../hooks/use_transaction_trace_samples_fetcher'; +import { FETCH_STATUS } from '../../../hooks/use_fetcher'; export interface TabContentProps { clearChartSelection: () => void; @@ -16,4 +17,5 @@ export interface TabContentProps { sampleRangeTo?: number; selectSampleFromChartSelection: (selection: XYBrushEvent) => void; traceSamples: TraceSample[]; + traceSamplesStatus: FETCH_STATUS; } diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/index.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/index.tsx index f528ce17c02f0..93913aff6cb6b 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/index.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/index.tsx @@ -65,10 +65,9 @@ export function WaterfallWithSummary({ }; const { entryWaterfallTransaction } = waterfall; - if (!entryWaterfallTransaction) { - const content = isLoading ? ( - - ) : ( + + if ((!entryWaterfallTransaction || traceSamples.length === 0) && !isLoading) { + return ( @@ -80,11 +79,9 @@ export function WaterfallWithSummary({ titleSize="s" /> ); - - return content; } - const entryTransaction = entryWaterfallTransaction.doc; + const entryTransaction = entryWaterfallTransaction?.doc; return ( <> @@ -99,43 +96,52 @@ export function WaterfallWithSummary({ - {traceSamples && ( - - )} + - + + + + -
- - - - + {isLoading || !entryTransaction ? ( + + ) : ( + <> + + + + + )} ); } diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx index 90fdaddc71408..ecb9fb9a3bc39 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/maybe_view_trace_link.tsx @@ -5,7 +5,7 @@ * 2.0. */ -import { EuiButton, EuiFlexItem, EuiToolTip } from '@elastic/eui'; +import { EuiButton, EuiToolTip } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import React from 'react'; import { getNextEnvironmentUrlParam } from '../../../../../common/environment_filter_values'; @@ -15,12 +15,35 @@ import { IWaterfall } from './waterfall_container/waterfall/waterfall_helpers/wa import { Environment } from '../../../../../common/environment_rt'; import { useApmParams } from '../../../../hooks/use_apm_params'; +function FullTraceButton({ + isLoading, + isDisabled, +}: { + isLoading?: boolean; + isDisabled?: boolean; +}) { + return ( + + {i18n.translate('xpack.apm.transactionDetails.viewFullTraceButtonLabel', { + defaultMessage: 'View full trace', + })} + + ); +} + export function MaybeViewTraceLink({ + isLoading, transaction, waterfall, environment, }: { - transaction: ITransaction; + isLoading: boolean; + transaction?: ITransaction; waterfall: IWaterfall; environment: Environment; }) { @@ -28,31 +51,24 @@ export function MaybeViewTraceLink({ query: { latencyAggregationType, comparisonEnabled, offset }, } = useApmParams('/services/{serviceName}/transactions/view'); - const viewFullTraceButtonLabel = i18n.translate( - 'xpack.apm.transactionDetails.viewFullTraceButtonLabel', - { - defaultMessage: 'View full trace', - } - ); + if (isLoading || !transaction) { + return ; + } const { rootTransaction } = waterfall; // the traceroot cannot be found, so we cannot link to it if (!rootTransaction) { return ( - - - - {viewFullTraceButtonLabel} - - - + + + ); } @@ -61,20 +77,16 @@ export function MaybeViewTraceLink({ // the user is already viewing the full trace, so don't link to it if (isRoot) { return ( - - - - {viewFullTraceButtonLabel} - - - + + + ); // the user is viewing a zoomed in version of the trace. Link to the full trace @@ -85,23 +97,19 @@ export function MaybeViewTraceLink({ }); return ( - - - - {viewFullTraceButtonLabel} - - - + + + ); } } diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/transaction_flyout/index.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/transaction_flyout/index.tsx index 43a7ebfa2f97f..fd68fde81fb60 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/transaction_flyout/index.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/transaction_flyout/index.tsx @@ -76,7 +76,10 @@ export function TransactionFlyout({ - +
diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_list.tsx b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_list.tsx index 7ea7cd35c443a..5cd7188c8ba8b 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_list.tsx +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_list.tsx @@ -20,7 +20,7 @@ export function CustomLinkList({ transaction, }: { customLinks: CustomLink[]; - transaction: Transaction; + transaction?: Transaction; }) { return ( @@ -39,7 +39,7 @@ export function CustomLinkList({ ); } -function getHref(link: CustomLink, transaction: Transaction) { +function getHref(link: CustomLink, transaction?: Transaction) { try { return Mustache.render(link.url, transaction); } catch (e) { diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/index.tsx b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/index.tsx index aa3445d098c0e..68442ede98347 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/index.tsx +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/index.tsx @@ -41,7 +41,7 @@ const DEFAULT_LINKS_TO_SHOW = 3; export function CustomLinkMenuSection({ transaction, }: { - transaction: Transaction; + transaction?: Transaction; }) { const [showAllLinks, setShowAllLinks] = useState(false); const [isCreateEditFlyoutOpen, setIsCreateEditFlyoutOpen] = useState(false); diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/sections.ts b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/sections.ts index 20c10b6d9557c..8fbf0ea1f3235 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/sections.ts +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/sections.ts @@ -35,11 +35,12 @@ export const getSections = ({ location, urlParams, }: { - transaction: Transaction; + transaction?: Transaction; basePath: IBasePath; location: Location; urlParams: ApmUrlParams; }) => { + if (!transaction) return []; const hostName = transaction.host?.hostname; const podId = transaction.kubernetes?.pod?.uid; const containerId = transaction.container?.id; diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.test.tsx b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.test.tsx index f2919fc12cad6..ebdbf759bcddc 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.test.tsx +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.test.tsx @@ -47,7 +47,10 @@ function Wrapper({ children }: { children?: React.ReactNode }) { const renderTransaction = async (transaction: Record) => { const rendered = render( - , + , { wrapper: Wrapper, } @@ -271,6 +274,7 @@ describe('TransactionActionMenu component', () => { return render( , @@ -308,6 +312,7 @@ describe('TransactionActionMenu component', () => { const component = render( , diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.tsx b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.tsx index 2f856dce387bf..253c792246139 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.tsx +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/transaction_action_menu.tsx @@ -26,12 +26,24 @@ import { CustomLinkMenuSection } from './custom_link_menu_section'; import { getSections } from './sections'; interface Props { - readonly transaction: Transaction; + readonly transaction?: Transaction; + isLoading: boolean; } -function ActionMenuButton({ onClick }: { onClick: () => void }) { +function ActionMenuButton({ + onClick, + isLoading, +}: { + onClick: () => void; + isLoading: boolean; +}) { return ( - + {i18n.translate('xpack.apm.transactionActionMenu.actionsButtonLabel', { defaultMessage: 'Investigate', })} @@ -39,23 +51,12 @@ function ActionMenuButton({ onClick }: { onClick: () => void }) { ); } -export function TransactionActionMenu({ transaction }: Props) { +export function TransactionActionMenu({ transaction, isLoading }: Props) { const license = useLicenseContext(); const hasGoldLicense = license?.isActive && license?.hasAtLeast('gold'); - const { core } = useApmPluginContext(); - const location = useLocation(); - const { urlParams } = useLegacyUrlParams(); - const [isActionPopoverOpen, setIsActionPopoverOpen] = useState(false); - const sections = getSections({ - transaction, - basePath: core.http.basePath, - location, - urlParams, - }); - return ( <> setIsActionPopoverOpen( (prevIsActionPopoverOpen) => !prevIsActionPopoverOpen @@ -73,38 +75,52 @@ export function TransactionActionMenu({ transaction }: Props) { /> } > -
- {sections.map((section, idx) => { - const isLastSection = idx !== sections.length - 1; - return ( -
- {section.map((item) => ( -
- {item.title && {item.title}} - {item.subtitle && ( - {item.subtitle} - )} - - {item.actions.map((action) => ( - - ))} - -
- ))} - {isLastSection && } -
- ); - })} - - {hasGoldLicense && ( - - )} -
+ + {hasGoldLicense && }
); } + +function ActionMenuSections({ transaction }: { transaction?: Transaction }) { + const { core } = useApmPluginContext(); + const location = useLocation(); + const { urlParams } = useLegacyUrlParams(); + + const sections = getSections({ + transaction, + basePath: core.http.basePath, + location, + urlParams, + }); + + return ( +
+ {sections.map((section, idx) => { + const isLastSection = idx !== sections.length - 1; + return ( +
+ {section.map((item) => ( +
+ {item.title && {item.title}} + {item.subtitle && ( + {item.subtitle} + )} + + {item.actions.map((action) => ( + + ))} + +
+ ))} + {isLastSection && } +
+ ); + })} +
+ ); +} From 52f0bf0a6ab8df5d393630571b7c95535723f770 Mon Sep 17 00:00:00 2001 From: Giorgos Bamparopoulos Date: Tue, 29 Mar 2022 09:16:00 +0100 Subject: [PATCH 067/160] Set metadata tab as default and display Stack Trace tab only if stackframes exist (#128598) --- .../waterfall/span_flyout/index.tsx | 41 +++++++++++-------- 1 file changed, 23 insertions(+), 18 deletions(-) diff --git a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/index.tsx b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/index.tsx index 477098aa81d04..5d3c1d733e040 100644 --- a/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/index.tsx +++ b/x-pack/plugins/apm/public/components/app/transaction_details/waterfall_with_summary/waterfall_container/waterfall/span_flyout/index.tsx @@ -21,6 +21,7 @@ import { } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import React, { Fragment } from 'react'; +import { isEmpty } from 'lodash'; import { CompositeSpanDurationSummaryItem } from '../../../../../../shared/summary/composite_span_duration_summary_item'; import { euiStyled } from '../../../../../../../../../../../src/plugins/kibana_react/common'; import { Span } from '../../../../../../../../typings/es_schemas/ui/span'; @@ -216,24 +217,6 @@ export function SpanFlyout({ - - -
- ), - }, { id: 'metadata', name: i18n.translate( @@ -249,6 +232,28 @@ export function SpanFlyout({ ), }, + ...(!isEmpty(stackframes) + ? [ + { + id: 'stack-trace', + name: i18n.translate( + 'xpack.apm.transactionDetails.spanFlyout.stackTraceTabLabel', + { + defaultMessage: 'Stack Trace', + } + ), + content: ( + + + + + ), + }, + ] + : []), ]} /> From eb51ea64c5bb531658c38e9995f7455c39822b63 Mon Sep 17 00:00:00 2001 From: Dmitrii Shevchenko Date: Tue, 29 Mar 2022 10:18:33 +0200 Subject: [PATCH 068/160] Add the ability to filter by index pattern to the rules management table (#128245) --- .../detection_rules/sorting.spec.ts | 14 ++-- .../cypress/tasks/alerts_detection_rules.ts | 2 +- .../filters/toggle_selected_group.tsx | 4 +- .../rule_actions_overflow/index.test.tsx | 6 +- .../detection_engine/rules/api.test.ts | 38 ++++++++- .../detection_engine/rules/utils.test.ts | 16 +++- .../detection_engine/rules/utils.ts | 64 +++++++++------ .../detection_engine/rules/all/actions.ts | 19 ----- .../all/bulk_actions/use_bulk_actions.tsx | 23 +++--- .../all/rules_table/rules_table_context.tsx | 27 +++--- .../rules/all/rules_table/use_find_rules.ts | 8 +- .../rules/all/rules_table/utils.ts | 32 +------- .../rules_table_filters.test.tsx | 77 ++++++----------- .../rules_table_filters.tsx | 82 +++++++------------ .../tags_filter_popover.test.tsx | 8 +- .../tags_filter_popover.tsx | 20 +---- .../rules/all/rules_tables.tsx | 62 +++++--------- .../rules/all/utility_bar.tsx | 15 +++- .../detection_engine/rules/translations.ts | 9 +- .../translations/translations/fr-FR.json | 2 - .../translations/translations/ja-JP.json | 2 - .../translations/translations/zh-CN.json | 2 - 22 files changed, 225 insertions(+), 307 deletions(-) diff --git a/x-pack/plugins/security_solution/cypress/integration/detection_rules/sorting.spec.ts b/x-pack/plugins/security_solution/cypress/integration/detection_rules/sorting.spec.ts index a162ca4a544d1..7084ff99b5881 100644 --- a/x-pack/plugins/security_solution/cypress/integration/detection_rules/sorting.spec.ts +++ b/x-pack/plugins/security_solution/cypress/integration/detection_rules/sorting.spec.ts @@ -13,7 +13,7 @@ import { FOURTH_RULE, RULES_TABLE, pageSelector, - RULES_TABLE_REFRESH_INDICATOR, + RULES_ROW, } from '../../screens/alerts_detection_rules'; import { goToManageAlertsDetectionRules, waitForAlertsPanelToBeLoaded } from '../../tasks/alerts'; @@ -90,14 +90,10 @@ describe('Alerts detection rules', () => { .invoke('text') .then((ruleNameFirstPage) => { goToPage(2); - cy.get(RULES_TABLE_REFRESH_INDICATOR).should('not.exist'); - cy.get(RULES_TABLE) - .find(RULE_NAME) - .first() - .invoke('text') - .should((ruleNameSecondPage) => { - expect(ruleNameFirstPage).not.to.eq(ruleNameSecondPage); - }); + // Check that the rules table shows at least one row + cy.get(RULES_TABLE).find(RULES_ROW).should('have.length.gte', 1); + // Check that the rules table doesn't show the rule from the first page + cy.get(RULES_TABLE).should('not.contain', ruleNameFirstPage); }); cy.get(RULES_TABLE) diff --git a/x-pack/plugins/security_solution/cypress/tasks/alerts_detection_rules.ts b/x-pack/plugins/security_solution/cypress/tasks/alerts_detection_rules.ts index 8d125c242be35..afe3981219217 100644 --- a/x-pack/plugins/security_solution/cypress/tasks/alerts_detection_rules.ts +++ b/x-pack/plugins/security_solution/cypress/tasks/alerts_detection_rules.ts @@ -154,7 +154,7 @@ export const goToRuleDetails = () => { }; export const goToTheRuleDetailsOf = (ruleName: string) => { - cy.get(RULE_NAME).contains(ruleName).click(); + cy.get(RULE_NAME).should('contain', ruleName).contains(ruleName).click(); }; export const loadPrebuiltDetectionRules = () => { diff --git a/x-pack/plugins/security_solution/public/common/components/ml_popover/jobs_table/filters/toggle_selected_group.tsx b/x-pack/plugins/security_solution/public/common/components/ml_popover/jobs_table/filters/toggle_selected_group.tsx index d452aa9a311e7..4f7064afe642f 100644 --- a/x-pack/plugins/security_solution/public/common/components/ml_popover/jobs_table/filters/toggle_selected_group.tsx +++ b/x-pack/plugins/security_solution/public/common/components/ml_popover/jobs_table/filters/toggle_selected_group.tsx @@ -5,12 +5,10 @@ * 2.0. */ -import { Dispatch, SetStateAction } from 'react'; - export const toggleSelectedGroup = ( group: string, selectedGroups: string[], - setSelectedGroups: Dispatch> + setSelectedGroups: (groups: string[]) => void ): void => { const selectedGroupIndex = selectedGroups.indexOf(group); const updatedSelectedGroups = [...selectedGroups]; diff --git a/x-pack/plugins/security_solution/public/detections/components/rules/rule_actions_overflow/index.test.tsx b/x-pack/plugins/security_solution/public/detections/components/rules/rule_actions_overflow/index.test.tsx index 3037a3c82f946..71fabef22c904 100644 --- a/x-pack/plugins/security_solution/public/detections/components/rules/rule_actions_overflow/index.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/rules/rule_actions_overflow/index.test.tsx @@ -178,7 +178,7 @@ describe('RuleActionsOverflow', () => { ).toEqual(false); }); - test('it calls duplicateRulesAction when rules-details-duplicate-rule is clicked', () => { + test('it calls duplicate action when rules-details-duplicate-rule is clicked', () => { const wrapper = mount( { ); }); - test('it calls duplicateRulesAction with the rule and rule.id when rules-details-duplicate-rule is clicked', () => { + test('it calls duplicate action with the rule and rule.id when rules-details-duplicate-rule is clicked', () => { const rule = mockRule('id'); const wrapper = mount( @@ -210,7 +210,7 @@ describe('RuleActionsOverflow', () => { }); }); - test('it calls editRuleAction after the rule is duplicated', async () => { + test('it navigates to edit page after the rule is duplicated', async () => { const rule = mockRule('id'); const ruleDuplicate = mockRule('newRule'); executeRulesBulkActionMock.mockImplementation(() => diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts index 16613d7cb4d0f..c8d8b5bb6ffd0 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts @@ -142,7 +142,37 @@ describe('Detections Rules API', () => { expect(fetchMock).toHaveBeenCalledWith('/api/detection_engine/rules/_find', { method: 'GET', query: { - filter: 'alert.attributes.name: hello world', + filter: + '(alert.attributes.name: "hello world" OR alert.attributes.params.index: "hello world" OR alert.attributes.params.threat.tactic.id: "hello world" OR alert.attributes.params.threat.tactic.name: "hello world" OR alert.attributes.params.threat.technique.id: "hello world" OR alert.attributes.params.threat.technique.name: "hello world")', + page: 1, + per_page: 20, + sort_field: 'enabled', + sort_order: 'desc', + }, + signal: abortCtrl.signal, + }); + }); + + test('check parameter url, query with a filter get escaped correctly', async () => { + await fetchRules({ + filterOptions: { + filter: '" OR (foo:bar)', + showCustomRules: false, + showElasticRules: false, + tags: [], + }, + sortingOptions: { + field: 'enabled', + order: 'desc', + }, + signal: abortCtrl.signal, + }); + + expect(fetchMock).toHaveBeenCalledWith('/api/detection_engine/rules/_find', { + method: 'GET', + query: { + filter: + '(alert.attributes.name: "\\" OR (foo:bar)" OR alert.attributes.params.index: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo:bar)")', page: 1, per_page: 20, sort_field: 'enabled', @@ -226,7 +256,7 @@ describe('Detections Rules API', () => { expect(fetchMock).toHaveBeenCalledWith('/api/detection_engine/rules/_find', { method: 'GET', query: { - filter: 'alert.attributes.tags: "hello" AND alert.attributes.tags: "world"', + filter: 'alert.attributes.tags:("hello" AND "world")', page: 1, per_page: 20, sort_field: 'enabled', @@ -254,7 +284,7 @@ describe('Detections Rules API', () => { expect(fetchMock).toHaveBeenCalledWith('/api/detection_engine/rules/_find', { method: 'GET', query: { - filter: 'alert.attributes.tags: "hello" AND alert.attributes.tags: "world"', + filter: 'alert.attributes.tags:("hello" AND "world")', page: 1, per_page: 20, sort_field: 'updatedAt', @@ -353,7 +383,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - 'alert.attributes.name: ruleName AND alert.attributes.tags: "__internal_immutable:false" AND alert.attributes.tags: "__internal_immutable:true" AND (alert.attributes.tags: "hello" AND alert.attributes.tags: "world")', + 'alert.attributes.tags: "__internal_immutable:false" AND alert.attributes.tags: "__internal_immutable:true" AND alert.attributes.tags:("hello" AND "world") AND (alert.attributes.name: "ruleName" OR alert.attributes.params.index: "ruleName" OR alert.attributes.params.threat.tactic.id: "ruleName" OR alert.attributes.params.threat.tactic.name: "ruleName" OR alert.attributes.params.threat.technique.id: "ruleName" OR alert.attributes.params.threat.technique.name: "ruleName")', page: 1, per_page: 20, sort_field: 'enabled', diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts index 7f69d07e83467..e3d2300972a51 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts @@ -26,7 +26,17 @@ describe('convertRulesFilterToKQL', () => { it('handles presence of "filter" properly', () => { const kql = convertRulesFilterToKQL({ ...filterOptions, filter: 'foo' }); - expect(kql).toBe('alert.attributes.name: foo'); + expect(kql).toBe( + '(alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo")' + ); + }); + + it('escapes "filter" value properly', () => { + const kql = convertRulesFilterToKQL({ ...filterOptions, filter: '" OR (foo: bar)' }); + + expect(kql).toBe( + '(alert.attributes.name: "\\" OR (foo: bar)" OR alert.attributes.params.index: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo: bar)")' + ); }); it('handles presence of "showCustomRules" properly', () => { @@ -44,7 +54,7 @@ describe('convertRulesFilterToKQL', () => { it('handles presence of "tags" properly', () => { const kql = convertRulesFilterToKQL({ ...filterOptions, tags: ['tag1', 'tag2'] }); - expect(kql).toBe('alert.attributes.tags: "tag1" AND alert.attributes.tags: "tag2"'); + expect(kql).toBe('alert.attributes.tags:("tag1" AND "tag2")'); }); it('handles combination of different properties properly', () => { @@ -56,7 +66,7 @@ describe('convertRulesFilterToKQL', () => { }); expect(kql).toBe( - `alert.attributes.name: foo AND alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true" AND (alert.attributes.tags: "tag1" AND alert.attributes.tags: "tag2")` + `alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true" AND alert.attributes.tags:(\"tag1\" AND \"tag2\") AND (alert.attributes.name: \"foo\" OR alert.attributes.params.index: \"foo\" OR alert.attributes.params.threat.tactic.id: \"foo\" OR alert.attributes.params.threat.tactic.name: \"foo\" OR alert.attributes.params.threat.technique.id: \"foo\" OR alert.attributes.params.threat.technique.name: \"foo\")` ); }); }); diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts index 841b2adca09e0..f5e52fd6362c1 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts @@ -6,8 +6,18 @@ */ import { INTERNAL_IMMUTABLE_KEY } from '../../../../../common/constants'; +import { escapeKuery } from '../../../../common/lib/keury'; import { FilterOptions } from './types'; +const SEARCHABLE_RULE_PARAMS = [ + 'alert.attributes.name', + 'alert.attributes.params.index', + 'alert.attributes.params.threat.tactic.id', + 'alert.attributes.params.threat.tactic.name', + 'alert.attributes.params.threat.technique.id', + 'alert.attributes.params.threat.technique.name', +]; + /** * Convert rules filter options object to KQL query * @@ -15,27 +25,35 @@ import { FilterOptions } from './types'; * * @returns KQL string */ -export const convertRulesFilterToKQL = (filterOptions: FilterOptions): string => { - const showCustomRuleFilter = filterOptions.showCustomRules - ? [`alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:false"`] - : []; - const showElasticRuleFilter = filterOptions.showElasticRules - ? [`alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true"`] - : []; - const filtersWithoutTags = [ - ...(filterOptions.filter.length ? [`alert.attributes.name: ${filterOptions.filter}`] : []), - ...showCustomRuleFilter, - ...showElasticRuleFilter, - ].join(' AND '); - - const tags = filterOptions.tags - .map((t) => `alert.attributes.tags: "${t.replace(/"/g, '\\"')}"`) - .join(' AND '); - - const filterString = - filtersWithoutTags !== '' && tags !== '' - ? `${filtersWithoutTags} AND (${tags})` - : filtersWithoutTags + tags; - - return filterString; +export const convertRulesFilterToKQL = ({ + showCustomRules, + showElasticRules, + filter, + tags, +}: FilterOptions): string => { + const filters: string[] = []; + + if (showCustomRules) { + filters.push(`alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:false"`); + } + + if (showElasticRules) { + filters.push(`alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true"`); + } + + if (tags.length > 0) { + filters.push( + `alert.attributes.tags:(${tags.map((tag) => `"${escapeKuery(tag)}"`).join(' AND ')})` + ); + } + + if (filter.length) { + const searchQuery = SEARCHABLE_RULE_PARAMS.map( + (param) => `${param}: "${escapeKuery(filter)}"` + ).join(' OR '); + + filters.push(`(${searchQuery})`); + } + + return filters.join(' AND '); }; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/actions.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/actions.ts index 10c099e4bfcc8..488fd3625bf59 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/actions.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/actions.ts @@ -81,25 +81,6 @@ export const executeRulesBulkAction = async ({ } }; -export const initRulesBulkAction = (params: Omit) => { - const byQuery = (query: string) => - executeRulesBulkAction({ - ...params, - search: { query }, - }); - - const byIds = (ids: string[]) => - executeRulesBulkAction({ - ...params, - search: { ids }, - }); - - return { - byQuery, - byIds, - }; -}; - function defaultErrorHandler(toasts: UseAppToasts, action: BulkAction, error: HTTPError) { // if response doesn't have number of failed rules, it means the whole bulk action failed // and general error toast will be shown. Otherwise - error toast for partial failure diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx index 491b693a442ba..6bd7cfc67f308 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx @@ -30,7 +30,7 @@ import { canEditRuleWithActions } from '../../../../../../common/utils/privilege import { useRulesTableContext } from '../rules_table/rules_table_context'; import * as detectionI18n from '../../../translations'; import * as i18n from '../../translations'; -import { executeRulesBulkAction, initRulesBulkAction } from '../actions'; +import { executeRulesBulkAction } from '../actions'; import { useHasActionsPrivileges } from '../use_has_actions_privileges'; import { useHasMlPermissions } from '../use_has_ml_permissions'; import { getCustomRulesCountFromCache } from './use_custom_rules_count'; @@ -239,26 +239,23 @@ export const useBulkActions = ({ ); }, 5 * 1000); - const rulesBulkAction = initRulesBulkAction({ + await executeRulesBulkAction({ visibleRuleIds: selectedRuleIds, action: BulkAction.edit, setLoadingRules, toasts, payload: { edit: [editPayload] }, onFinish: () => hideWarningToast(), + search: isAllSelected + ? { + query: convertRulesFilterToKQL({ + ...filterOptions, + showCustomRules: true, // only edit custom rules, as elastic rule are immutable + }), + } + : { ids: customSelectedRuleIds }, }); - // only edit custom rules, as elastic rule are immutable - if (isAllSelected) { - const customRulesOnlyFilterQuery = convertRulesFilterToKQL({ - ...filterOptions, - showCustomRules: true, - }); - await rulesBulkAction.byQuery(customRulesOnlyFilterQuery); - } else { - await rulesBulkAction.byIds(customSelectedRuleIds); - } - isBulkEditFinished = true; invalidateRules(); if (getIsMounted()) { diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/rules_table_context.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/rules_table_context.tsx index 2bf20acfb9334..130dd61c371ae 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/rules_table_context.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/rules_table_context.tsx @@ -16,7 +16,7 @@ import { SortingOptions, } from '../../../../../containers/detection_engine/rules/types'; import { useFindRules } from './use_find_rules'; -import { getRulesComparator, getRulesPredicate } from './utils'; +import { getRulesComparator } from './utils'; export interface RulesTableState { /** @@ -114,7 +114,7 @@ export interface LoadingRules { export interface RulesTableActions { reFetchRules: ReturnType['refetch']; - setFilterOptions: React.Dispatch>; + setFilterOptions: (newFilter: Partial) => void; setIsAllSelected: React.Dispatch>; setIsInMemorySorting: (value: boolean) => void; setIsRefreshOn: React.Dispatch>; @@ -186,6 +186,13 @@ export const RulesTableContextProvider = ({ const pagination = useMemo(() => ({ page, perPage }), [page, perPage]); + const handleFilterOptionsChange = useCallback((newFilter: Partial) => { + setFilterOptions((currentFilter) => ({ ...currentFilter, ...newFilter })); + setPage(1); + setSelectedRuleIds([]); + setIsAllSelected(false); + }, []); + // Fetch rules const { data: { rules, total } = { rules: [], total: 0 }, @@ -210,15 +217,10 @@ export const RulesTableContextProvider = ({ } }, [isFetched, isRefetching, refetchPrePackagedRulesStatus]); - // Filter rules - const filteredRules = isInMemorySorting ? rules.filter(getRulesPredicate(filterOptions)) : rules; - // Paginate and sort rules const rulesToDisplay = isInMemorySorting - ? filteredRules - .sort(getRulesComparator(sortingOptions)) - .slice((page - 1) * perPage, page * perPage) - : filteredRules; + ? rules.sort(getRulesComparator(sortingOptions)).slice((page - 1) * perPage, page * perPage) + : rules; const providerValue = useMemo( () => ({ @@ -227,7 +229,7 @@ export const RulesTableContextProvider = ({ pagination: { page, perPage, - total: isInMemorySorting ? filteredRules.length : total, + total: isInMemorySorting ? rules.length : total, }, filterOptions, isActionInProgress, @@ -246,7 +248,7 @@ export const RulesTableContextProvider = ({ }, actions: { reFetchRules: refetch, - setFilterOptions, + setFilterOptions: handleFilterOptionsChange, setIsAllSelected, setIsInMemorySorting: toggleInMemorySorting, setIsRefreshOn, @@ -260,7 +262,7 @@ export const RulesTableContextProvider = ({ [ dataUpdatedAt, filterOptions, - filteredRules.length, + handleFilterOptionsChange, isActionInProgress, isAllSelected, isFetched, @@ -274,6 +276,7 @@ export const RulesTableContextProvider = ({ page, perPage, refetch, + rules.length, rulesToDisplay, selectedRuleIds, sortingOptions, diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/use_find_rules.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/use_find_rules.ts index 47a2617dd2e25..6544df7e7ed2a 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/use_find_rules.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/use_find_rules.ts @@ -31,8 +31,12 @@ export const useFindRules = (args: UseFindRulesArgs) => { // Use this query result when isInMemorySorting = true const allRules = useFindRulesQuery( ['all'], - { pagination: { page: 1, perPage: MAX_RULES_PER_PAGE } }, - { refetchInterval, enabled: isInMemorySorting } + { pagination: { page: 1, perPage: MAX_RULES_PER_PAGE }, filterOptions }, + { + refetchInterval, + enabled: isInMemorySorting, + keepPreviousData: true, // Use this option so that the state doesn't jump between "success" and "loading" on page change + } ); // Use this query result when isInMemorySorting = false diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/utils.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/utils.ts index 37deade0d1316..12d114cb3c990 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/utils.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table/utils.ts @@ -6,11 +6,7 @@ */ import { get } from 'lodash'; -import { - FilterOptions, - Rule, - SortingOptions, -} from '../../../../../containers/detection_engine/rules/types'; +import { Rule, SortingOptions } from '../../../../../containers/detection_engine/rules/types'; /** * Returns a comparator function to be used with .sort() @@ -79,29 +75,3 @@ const compareNumbers = (a: number, b: number, direction: number) => { } return 0; }; - -/** - * Returns a predicate function to be used with .filter() - * - * @param filterOptions Current table filter - */ -export function getRulesPredicate(filterOptions: FilterOptions) { - return (rule: Rule) => { - if ( - filterOptions.filter && - !rule.name.toLowerCase().includes(filterOptions.filter.toLowerCase()) - ) { - return false; - } - if (filterOptions.showCustomRules && rule.immutable) { - return false; - } - if (filterOptions.showElasticRules && !rule.immutable) { - return false; - } - if (filterOptions.tags.length && !filterOptions.tags.every((tag) => rule.tags.includes(tag))) { - return false; - } - return true; - }; -} diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx index e627ce3815e59..816ffdfa9dad6 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx @@ -7,65 +7,38 @@ import React from 'react'; import { mount } from 'enzyme'; -import { act } from '@testing-library/react'; import { RulesTableFilters } from './rules_table_filters'; -import { useAppToastsMock } from '../../../../../../common/hooks/use_app_toasts.mock'; -import { useAppToasts } from '../../../../../../common/hooks/use_app_toasts'; -jest.mock('../../../../../../common/hooks/use_app_toasts'); +import { TestProviders } from '../../../../../../common/mock'; -describe('RulesTableFilters', () => { - let appToastsMock: jest.Mocked>; - - beforeEach(() => { - jest.resetAllMocks(); - appToastsMock = useAppToastsMock.create(); - (useAppToasts as jest.Mock).mockReturnValue(appToastsMock); - }); +jest.mock('../rules_table/rules_table_context'); +describe('RulesTableFilters', () => { it('renders no numbers next to rule type button filter if none exist', async () => { - await act(async () => { - const wrapper = mount( - ({})} - /> - ); - - expect(wrapper.find('[data-test-subj="showElasticRulesFilterButton"]').at(0).text()).toEqual( - 'Elastic rules' - ); - expect(wrapper.find('[data-test-subj="showCustomRulesFilterButton"]').at(0).text()).toEqual( - 'Custom rules' - ); - }); + const wrapper = mount( + , + { wrappingComponent: TestProviders } + ); + + expect(wrapper.find('[data-test-subj="showElasticRulesFilterButton"]').at(0).text()).toEqual( + 'Elastic rules' + ); + expect(wrapper.find('[data-test-subj="showCustomRulesFilterButton"]').at(0).text()).toEqual( + 'Custom rules' + ); }); it('renders number of custom and prepackaged rules', async () => { - await act(async () => { - const wrapper = mount( - ({})} - /> - ); - - expect(wrapper.find('[data-test-subj="showElasticRulesFilterButton"]').at(0).text()).toEqual( - 'Elastic rules (9)' - ); - expect(wrapper.find('[data-test-subj="showCustomRulesFilterButton"]').at(0).text()).toEqual( - 'Custom rules (10)' - ); - }); + const wrapper = mount( + , + { wrappingComponent: TestProviders } + ); + + expect(wrapper.find('[data-test-subj="showElasticRulesFilterButton"]').at(0).text()).toEqual( + 'Elastic rules (9)' + ); + expect(wrapper.find('[data-test-subj="showCustomRulesFilterButton"]').at(0).text()).toEqual( + 'Custom rules (10)' + ); }); }); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx index 5987cd75d303e..b4c81ae5a177d 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx @@ -5,8 +5,6 @@ * 2.0. */ -import React, { useCallback, useEffect, useState } from 'react'; - import { EuiFieldSearch, EuiFilterButton, @@ -15,76 +13,63 @@ import { EuiFlexItem, } from '@elastic/eui'; import { isEqual } from 'lodash/fp'; - +import React, { useCallback } from 'react'; +import styled from 'styled-components'; import * as i18n from '../../translations'; - -import { FilterOptions } from '../../../../../containers/detection_engine/rules'; +import { useRulesTableContext } from '../rules_table/rules_table_context'; import { TagsFilterPopover } from './tags_filter_popover'; +const FilterWrapper = styled(EuiFlexGroup)` + margin-bottom: ${({ theme }) => theme.eui.euiSizeXS}; +`; + interface RulesTableFiltersProps { - onFilterChanged: (filterOptions: Partial) => void; rulesCustomInstalled: number | null; rulesInstalled: number | null; - currentFilterTags: string[]; - tags: string[]; - isLoadingTags: boolean; - reFetchTags: () => void; + allTags: string[]; } /** * Collection of filters for filtering data within the RulesTable. Contains search bar, Elastic/Custom * Rules filter button toggle, and tag selection - * - * @param onFilterChanged change listener to be notified on filter changes */ const RulesTableFiltersComponent = ({ - onFilterChanged, rulesCustomInstalled, rulesInstalled, - currentFilterTags, - tags, - isLoadingTags, - reFetchTags, + allTags, }: RulesTableFiltersProps) => { - const [filter, setFilter] = useState(''); - const [selectedTags, setSelectedTags] = useState([]); - const [showCustomRules, setShowCustomRules] = useState(false); - const [showElasticRules, setShowElasticRules] = useState(false); + const { + state: { filterOptions }, + actions: { setFilterOptions }, + } = useRulesTableContext(); - useEffect(() => { - reFetchTags(); - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [rulesCustomInstalled, rulesInstalled]); + const { showCustomRules, showElasticRules, tags: selectedTags } = filterOptions; - // Propagate filter changes to parent - useEffect(() => { - onFilterChanged({ filter, showCustomRules, showElasticRules, tags: selectedTags }); - }, [filter, selectedTags, showCustomRules, showElasticRules, onFilterChanged]); - - const handleOnSearch = useCallback((filterString) => setFilter(filterString.trim()), [setFilter]); + const handleOnSearch = useCallback( + (filterString) => setFilterOptions({ filter: filterString.trim() }), + [setFilterOptions] + ); const handleElasticRulesClick = useCallback(() => { - setShowElasticRules(!showElasticRules); - setShowCustomRules(false); - }, [setShowElasticRules, showElasticRules, setShowCustomRules]); + setFilterOptions({ showElasticRules: !showElasticRules, showCustomRules: false }); + }, [setFilterOptions, showElasticRules]); const handleCustomRulesClick = useCallback(() => { - setShowCustomRules(!showCustomRules); - setShowElasticRules(false); - }, [setShowElasticRules, showCustomRules, setShowCustomRules]); + setFilterOptions({ showCustomRules: !showCustomRules, showElasticRules: false }); + }, [setFilterOptions, showCustomRules]); const handleSelectedTags = useCallback( - (newTags) => { + (newTags: string[]) => { if (!isEqual(newTags, selectedTags)) { - setSelectedTags(newTags); + setFilterOptions({ tags: newTags }); } }, - [selectedTags] + [selectedTags, setFilterOptions] ); return ( - - + + - @@ -123,14 +105,12 @@ const RulesTableFiltersComponent = ({ onClick={handleCustomRulesClick} data-test-subj="showCustomRulesFilterButton" > - <> - {i18n.CUSTOM_RULES} - {rulesCustomInstalled != null ? ` (${rulesCustomInstalled})` : ''} - + {i18n.CUSTOM_RULES} + {rulesCustomInstalled != null ? ` (${rulesCustomInstalled})` : ''} - + ); }; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.test.tsx index bb41c2d87cd5a..c8b5e78a94563 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.test.tsx @@ -13,13 +13,7 @@ import { TagsFilterPopover } from './tags_filter_popover'; describe('TagsFilterPopover', () => { it('renders correctly', () => { const wrapper = shallow( - + ); expect(wrapper.find('EuiPopover')).toHaveLength(1); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.tsx index c5262caf6c776..ca2c2b4d00d30 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/tags_filter_popover.tsx @@ -5,15 +5,7 @@ * 2.0. */ -import React, { - ChangeEvent, - Dispatch, - SetStateAction, - useCallback, - useEffect, - useMemo, - useState, -} from 'react'; +import React, { ChangeEvent, useCallback, useEffect, useMemo, useState } from 'react'; import { EuiFilterButton, EuiFilterSelectItem, @@ -33,10 +25,7 @@ import { caseInsensitiveSort } from '../helpers'; interface TagsFilterPopoverProps { selectedTags: string[]; tags: string[]; - onSelectedTagsChanged: Dispatch>; - currentFilterTags: string[]; - // eslint-disable-next-line react/no-unused-prop-types - isLoading: boolean; // TO DO reimplement? + onSelectedTagsChanged: (newTags: string[]) => void; } const PopoverContentWrapper = styled.div` @@ -64,11 +53,10 @@ const TagsFilterPopoverComponent = ({ tags, selectedTags, onSelectedTagsChanged, - currentFilterTags, }: TagsFilterPopoverProps) => { const sortedTags = useMemo( - () => caseInsensitiveSort(Array.from(new Set([...tags, ...currentFilterTags]))), - [tags, currentFilterTags] + () => caseInsensitiveSort(Array.from(new Set([...tags, ...selectedTags]))), + [selectedTags, tags] ); const [isTagPopoverOpen, setIsTagPopoverOpen] = useState(false); const [searchInput, setSearchInput] = useState(''); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_tables.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_tables.tsx index c38c8e48928f1..3962fa217ccfb 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_tables.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_tables.tsx @@ -14,19 +14,16 @@ import { EuiLoadingContent, EuiProgress, } from '@elastic/eui'; -import React, { useCallback, useMemo, useRef } from 'react'; +import React, { useCallback, useEffect, useMemo, useRef } from 'react'; import { partition } from 'lodash/fp'; import { AllRulesTabs } from './rules_table_toolbar'; -import { HeaderSection } from '../../../../../common/components/header_section'; import { Loader } from '../../../../../common/components/loader'; import { useBoolState } from '../../../../../common/hooks/use_bool_state'; import { useValueChanged } from '../../../../../common/hooks/use_value_changed'; -import { useKibana } from '../../../../../common/lib/kibana'; import { PrePackagedRulesPrompt } from '../../../../components/rules/pre_packaged_rules/load_empty_prompt'; import { CreatePreBuiltRules, - FilterOptions, Rule, RulesSortingFields, } from '../../../../containers/detection_engine/rules'; @@ -85,7 +82,6 @@ export const RulesTables = React.memo( rulesNotUpdated, selectedTab, }) => { - const { timelines } = useKibana().services; const tableRef = useRef(null); const rulesTableContext = useRulesTableContext(); @@ -96,11 +92,9 @@ export const RulesTables = React.memo( isActionInProgress, isAllSelected, isFetched, - isFetching, isLoading, isRefetching, isRefreshOn, - lastUpdated, loadingRuleIds, loadingRulesAction, pagination, @@ -109,7 +103,6 @@ export const RulesTables = React.memo( }, actions: { reFetchRules, - setFilterOptions, setIsAllSelected, setIsRefreshOn, setPage, @@ -125,7 +118,12 @@ export const RulesTables = React.memo( rulesNotUpdated ); - const [isLoadingTags, tags, reFetchTags] = useTags(); + const [, allTags, reFetchTags] = useTags(); + + useEffect(() => { + reFetchTags(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [rulesCustomInstalled, rulesInstalled]); const [isDeleteConfirmationVisible, showDeleteConfirmation, hideDeleteConfirmation] = useBoolState(); @@ -183,16 +181,6 @@ export const RulesTables = React.memo( [pagination] ); - const onFilterChangedCallback = useCallback( - (newFilter: Partial) => { - setFilterOptions((currentFilter) => ({ ...currentFilter, ...newFilter })); - setPage(1); - setSelectedRuleIds([]); - setIsAllSelected(false); - }, - [setFilterOptions, setIsAllSelected, setPage, setSelectedRuleIds] - ); - const tableOnChangeCallback = useCallback( ({ page, sort }: EuiBasicTableOnChange) => { setSortingOptions({ @@ -286,9 +274,11 @@ export const RulesTables = React.memo( } : { 'data-test-subj': 'monitoring-table', columns: monitoringColumns }; + const shouldShowLinearProgress = isFetched && isRefetching; + const shouldShowLoadingOverlay = (!isFetched && isRefetching) || isActionInProgress; return ( <> - {isFetched && isRefetching && ( + {shouldShowLinearProgress && ( ( color="accent" /> )} - {((!isFetched && isRefetching) || isActionInProgress) && ( + {shouldShowLoadingOverlay && ( )} - - {shouldShowRulesTable && ( - - )} - + {shouldShowRulesTable && ( + + )} {shouldShowPrepackagedRulesPrompt && ( ( editAction={bulkEditActionType} onClose={handleBulkEditFormCancel} onConfirm={handleBulkEditFormConfirm} - tags={tags} + tags={allTags} /> )} {shouldShowRulesTable && ( diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/utility_bar.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/utility_bar.tsx index 6d9c2f92b214e..5513f70c42297 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/utility_bar.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/utility_bar.tsx @@ -22,6 +22,8 @@ import { UtilityBarText, } from '../../../../../common/components/utility_bar'; import * as i18n from '../translations'; +import { useKibana } from '../../../../../common/lib/kibana'; +import { useRulesTableContextOptional } from './rules_table/rules_table_context'; interface AllRulesUtilityBarProps { canBulkEdit: boolean; @@ -55,6 +57,9 @@ export const AllRulesUtilityBar = React.memo( isBulkActionInProgress, hasDisabledActions, }) => { + const { timelines } = useKibana().services; + const rulesTableContext = useRulesTableContextOptional(); + const handleGetBulkItemsPopoverContent = useCallback( (closePopover: () => void): JSX.Element | null => { if (onGetBulkItemsPopoverContent != null) { @@ -100,7 +105,7 @@ export const AllRulesUtilityBar = React.memo( ); return ( - + {hasBulkActions ? ( @@ -180,6 +185,14 @@ export const AllRulesUtilityBar = React.memo( )} + {rulesTableContext && ( + + {timelines.getLastUpdated({ + showUpdating: rulesTableContext.state.isFetching, + updatedAt: rulesTableContext.state.lastUpdated, + })} + + )} ); } diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts index 55a564f472c59..f93ca2f48d2db 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts @@ -391,13 +391,6 @@ export const EXPORT_FILENAME = i18n.translate( } ); -export const ALL_RULES = i18n.translate( - 'xpack.securitySolution.detectionEngine.rules.allRules.tableTitle', - { - defaultMessage: 'All rules', - } -); - export const SEARCH_RULES = i18n.translate( 'xpack.securitySolution.detectionEngine.rules.allRules.searchAriaLabel', { @@ -408,7 +401,7 @@ export const SEARCH_RULES = i18n.translate( export const SEARCH_PLACEHOLDER = i18n.translate( 'xpack.securitySolution.detectionEngine.rules.allRules.searchPlaceholder', { - defaultMessage: 'e.g. rule name', + defaultMessage: 'Search by rule name, index pattern, or MITRE ATT&CK tactic or technique', } ); diff --git a/x-pack/plugins/translations/translations/fr-FR.json b/x-pack/plugins/translations/translations/fr-FR.json index 7b6e87e2d49db..ddb2ca0490c48 100644 --- a/x-pack/plugins/translations/translations/fr-FR.json +++ b/x-pack/plugins/translations/translations/fr-FR.json @@ -20830,14 +20830,12 @@ "xpack.securitySolution.detectionEngine.rules.allRules.inactiveRuleDescription": "inactive", "xpack.securitySolution.detectionEngine.rules.allRules.refreshTitle": "Actualiser", "xpack.securitySolution.detectionEngine.rules.allRules.searchAriaLabel": "Rechercher les règles", - "xpack.securitySolution.detectionEngine.rules.allRules.searchPlaceholder": "par ex. nom de règle", "xpack.securitySolution.detectionEngine.rules.allRules.selectAllRulesTitle": "Sélection totale de {totalRules} {totalRules, plural, =1 {règle} other {règles}} effectuée", "xpack.securitySolution.detectionEngine.rules.allRules.selectedRulesTitle": "Sélection de {selectedRules} {selectedRules, plural, =1 {règle} other {règles}} effectuée", "xpack.securitySolution.detectionEngine.rules.allRules.showingExceptionLists": "Affichage de {totalLists} {totalLists, plural, =1 {liste} other {listes}}", "xpack.securitySolution.detectionEngine.rules.allRules.showingRulesTitle": "Affichage de {totalRules} {totalRules, plural, =1 {règle} other {règles}}", "xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.duplicate.successToastDescription": "Duplication réussie de {totalRules, plural, =1 {{totalRules} règle} other {{totalRules} règles}}", "xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.export.successToastDescription": "Exportation réussie de {exportedRules} sur {totalRules} {totalRules, plural, =1 {règle} other {règles}}. Les règles prédéfinies ont été exclues du fichier résultant.", - "xpack.securitySolution.detectionEngine.rules.allRules.tableTitle": "Toutes les règles", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.exceptions": "Listes d'exceptions", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.monitoring": "Monitoring des règles", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.rules": "Règles", diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index e465e82dfa5d5..cc840ab4a3534 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -23836,14 +23836,12 @@ "xpack.securitySolution.detectionEngine.rules.allRules.inactiveRuleDescription": "非アクティブ", "xpack.securitySolution.detectionEngine.rules.allRules.refreshTitle": "更新", "xpack.securitySolution.detectionEngine.rules.allRules.searchAriaLabel": "ルールの検索", - "xpack.securitySolution.detectionEngine.rules.allRules.searchPlaceholder": "例:ルール名", "xpack.securitySolution.detectionEngine.rules.allRules.selectAllRulesTitle": "すべての{totalRules} {totalRules, plural, other {個のルール}}を選択", "xpack.securitySolution.detectionEngine.rules.allRules.selectedRulesTitle": "{selectedRules} {selectedRules, plural, other {ルール}}を選択しました", "xpack.securitySolution.detectionEngine.rules.allRules.showingExceptionLists": "{totalLists} {totalLists, plural, other {件のリスト}}を表示しています。", "xpack.securitySolution.detectionEngine.rules.allRules.showingRulesTitle": "{totalRules} {totalRules, plural, other {ルール}}を表示中", "xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.duplicate.successToastDescription": "{totalRules, plural, other {{totalRules}ルール}}を正常に複製しました", "xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.export.successToastDescription": "{exportedRules}/{totalRules} {totalRules, plural, other {件のルール}}を正常にエクスポートしました事前構築済みルールは結果のファイルから除外されました。", - "xpack.securitySolution.detectionEngine.rules.allRules.tableTitle": "すべてのルール", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.exceptions": "例外リスト", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.monitoring": "ルール監視", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.rules": "ルール", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 737ad8b6e116c..8697109f3b927 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -23863,14 +23863,12 @@ "xpack.securitySolution.detectionEngine.rules.allRules.inactiveRuleDescription": "非活动", "xpack.securitySolution.detectionEngine.rules.allRules.refreshTitle": "刷新", "xpack.securitySolution.detectionEngine.rules.allRules.searchAriaLabel": "搜索规则", - "xpack.securitySolution.detectionEngine.rules.allRules.searchPlaceholder": "例如,规则名", "xpack.securitySolution.detectionEngine.rules.allRules.selectAllRulesTitle": "选择所有 {totalRules} 个{totalRules, plural, other {规则}}", "xpack.securitySolution.detectionEngine.rules.allRules.selectedRulesTitle": "已选择 {selectedRules} 个{selectedRules, plural, other {规则}}", "xpack.securitySolution.detectionEngine.rules.allRules.showingExceptionLists": "正在显示 {totalLists} 个{totalLists, plural, other {列表}}", "xpack.securitySolution.detectionEngine.rules.allRules.showingRulesTitle": "正在显示 {totalRules} 个{totalRules, plural, other {规则}}", "xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.duplicate.successToastDescription": "已成功复制 {totalRules, plural, other {{totalRules} 个规则}}", "xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.export.successToastDescription": "已成功导出 {exportedRules}/{totalRules} 个{totalRules, plural, other {规则}}。预置规则已从结果文件中排除。", - "xpack.securitySolution.detectionEngine.rules.allRules.tableTitle": "所有规则", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.exceptions": "例外列表", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.monitoring": "规则监测", "xpack.securitySolution.detectionEngine.rules.allRules.tabs.rules": "规则", From 617bb305c90bd97683febab280387d0c478d1bb7 Mon Sep 17 00:00:00 2001 From: Matthias Wilhelm Date: Tue, 29 Mar 2022 10:19:40 +0200 Subject: [PATCH 069/160] [Discover] Cleanup usage of deprecated APIs (#128602) --- src/plugins/discover/public/__mocks__/services.ts | 6 ++---- .../context/services/context_state.test.ts | 3 ++- .../application/main/components/chart/histogram.tsx | 4 ++-- .../main/components/layout/discover_layout.test.tsx | 4 ---- .../__stories__/discover_field_details.stories.tsx | 5 +++-- .../components/sidebar/discover_sidebar.test.tsx | 8 +++----- .../sidebar/discover_sidebar_responsive.test.tsx | 7 +++---- .../public/embeddable/saved_search_embeddable.tsx | 12 ++++-------- .../components/doc_viewer_source/get_height.test.tsx | 3 ++- 9 files changed, 21 insertions(+), 31 deletions(-) diff --git a/src/plugins/discover/public/__mocks__/services.ts b/src/plugins/discover/public/__mocks__/services.ts index bc66ae363711e..5f9511d2a63fe 100644 --- a/src/plugins/discover/public/__mocks__/services.ts +++ b/src/plugins/discover/public/__mocks__/services.ts @@ -21,6 +21,7 @@ import { UI_SETTINGS } from '../../../data/public'; import { TopNavMenu } from '../../../navigation/public'; import { FORMATS_UI_SETTINGS } from 'src/plugins/field_formats/common'; import { LocalStorageMock } from './local_storage_mock'; +import { fieldFormatsMock } from '../../../field_formats/common/mocks'; const dataPlugin = dataPluginMock.createStartContract(); export const discoverServiceMock = { @@ -45,10 +46,7 @@ export const discoverServiceMock = { save: true, }, }, - fieldFormats: { - getDefaultInstance: jest.fn(() => ({ convert: (value: unknown) => value })), - getFormatterForField: jest.fn(() => ({ convert: (value: unknown) => value })), - }, + fieldFormats: fieldFormatsMock, filterManager: dataPlugin.query.filterManager, uiSettings: { get: jest.fn((key: string) => { diff --git a/src/plugins/discover/public/application/context/services/context_state.test.ts b/src/plugins/discover/public/application/context/services/context_state.test.ts index 8f564d56c1042..3eb0e8a1e85d4 100644 --- a/src/plugins/discover/public/application/context/services/context_state.test.ts +++ b/src/plugins/discover/public/application/context/services/context_state.test.ts @@ -6,10 +6,11 @@ * Side Public License, v 1. */ +import { Filter } from '@kbn/es-query'; import { IUiSettingsClient } from 'kibana/public'; import { getState } from './context_state'; import { createBrowserHistory, History } from 'history'; -import { FilterManager, Filter } from '../../../../../data/public'; +import { FilterManager } from '../../../../../data/public'; import { coreMock } from '../../../../../../core/public/mocks'; import { SEARCH_FIELDS_FROM_SOURCE } from '../../../../common'; diff --git a/src/plugins/discover/public/application/main/components/chart/histogram.tsx b/src/plugins/discover/public/application/main/components/chart/histogram.tsx index 369513d3b7a31..22eff35be2325 100644 --- a/src/plugins/discover/public/application/main/components/chart/histogram.tsx +++ b/src/plugins/discover/public/application/main/components/chart/histogram.tsx @@ -65,7 +65,7 @@ export function DiscoverHistogram({ savedSearchData$, timefilterUpdateHandler, }: DiscoverHistogramProps) { - const { data, theme, uiSettings } = useDiscoverServices(); + const { data, theme, uiSettings, fieldFormats } = useDiscoverServices(); const chartTheme = theme.useChartsTheme(); const chartBaseTheme = theme.useChartsBaseTheme(); @@ -207,7 +207,7 @@ export function DiscoverHistogram({ type: TooltipType.VerticalCursor, }; - const xAxisFormatter = data.fieldFormats.deserialize(chartData.yAxisFormat); + const xAxisFormatter = fieldFormats.deserialize(chartData.yAxisFormat); const useLegacyTimeAxis = uiSettings.get(LEGACY_TIME_AXIS, false); diff --git a/src/plugins/discover/public/application/main/components/layout/discover_layout.test.tsx b/src/plugins/discover/public/application/main/components/layout/discover_layout.test.tsx index c9a9ea6441a0b..6ff808a65eb5e 100644 --- a/src/plugins/discover/public/application/main/components/layout/discover_layout.test.tsx +++ b/src/plugins/discover/public/application/main/components/layout/discover_layout.test.tsx @@ -43,10 +43,6 @@ function mountComponent(indexPattern: DataView, prevSidebarClosed?: boolean) { const searchSourceMock = createSearchSourceMock({}); const services = { ...discoverServiceMock, - fieldFormats: { - getDefaultInstance: jest.fn(() => ({ convert: (value: unknown) => value })), - getFormatterForField: jest.fn(() => ({ convert: (value: unknown) => value })), - }, storage: new LocalStorageMock({ [SIDEBAR_CLOSED_KEY]: prevSidebarClosed, }) as unknown as Storage, diff --git a/src/plugins/discover/public/application/main/components/sidebar/__stories__/discover_field_details.stories.tsx b/src/plugins/discover/public/application/main/components/sidebar/__stories__/discover_field_details.stories.tsx index 2951840b834b0..3547359209700 100644 --- a/src/plugins/discover/public/application/main/components/sidebar/__stories__/discover_field_details.stories.tsx +++ b/src/plugins/discover/public/application/main/components/sidebar/__stories__/discover_field_details.stories.tsx @@ -10,7 +10,8 @@ import { storiesOf } from '@storybook/react'; import React from 'react'; import { KBN_FIELD_TYPES } from '@kbn/field-types'; import { DiscoverFieldDetails } from '../discover_field_details'; -import { DataView, IndexPatternField } from '../../../../../../../data_views/public'; +import { DataViewField } from '../../../../../../../data_views/public'; +import { DataView } from '../../../../../../../data_views/public'; import { fieldSpecMap } from './fields'; import { numericField as field } from './fields'; import { Bucket } from '../types'; @@ -36,7 +37,7 @@ const fieldFormat = { defaultMap, }; -const scriptedField = new IndexPatternField({ +const scriptedField = new DataViewField({ name: 'machine.os', type: 'string', esTypes: ['long'], diff --git a/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar.test.tsx b/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar.test.tsx index 266174a002271..3d3c4b9da4516 100644 --- a/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar.test.tsx +++ b/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar.test.tsx @@ -31,11 +31,9 @@ import { AvailableFields$ } from '../../utils/use_saved_search'; function getCompProps(): DiscoverSidebarProps { const indexPattern = stubLogstashIndexPattern; - - // @ts-expect-error _.each() is passing additional args to flattenHit - const hits = each(cloneDeep(realHits), indexPattern.flattenHit) as Array< - Record - > as ElasticSearchHit[]; + const hits = each(cloneDeep(realHits), (hit) => + flattenHit(hit, indexPattern) + ) as unknown as ElasticSearchHit[]; const indexPatternList = [ { id: '0', attributes: { title: 'b' } } as SavedObject, diff --git a/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar_responsive.test.tsx b/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar_responsive.test.tsx index 05e0e25d606f6..ef8fcd145c908 100644 --- a/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar_responsive.test.tsx +++ b/src/plugins/discover/public/application/main/components/sidebar/discover_sidebar_responsive.test.tsx @@ -73,10 +73,9 @@ jest.mock('../../utils/calc_field_counts', () => ({ function getCompProps(): DiscoverSidebarResponsiveProps { const indexPattern = stubLogstashIndexPattern; - // @ts-expect-error _.each() is passing additional args to flattenHit - const hits = each(cloneDeep(realHits), (hit) => flattenHit(hit, indexPattern)) as Array< - Record - > as ElasticSearchHit[]; + const hits = each(cloneDeep(realHits), (hit) => + flattenHit(hit, indexPattern) + ) as unknown as ElasticSearchHit[]; const indexPatternList = [ { id: '0', attributes: { title: 'b' } } as SavedObject, diff --git a/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx b/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx index f67adf0976e59..e5a8fb2898e4b 100644 --- a/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx +++ b/src/plugins/discover/public/embeddable/saved_search_embeddable.tsx @@ -7,6 +7,7 @@ */ import { Subscription } from 'rxjs'; +import { onlyDisabledFiltersChanged, Filter } from '@kbn/es-query'; import React from 'react'; import ReactDOM from 'react-dom'; import { i18n } from '@kbn/i18n'; @@ -18,14 +19,9 @@ import { ISearchEmbeddable, SearchInput, SearchOutput } from './types'; import { SavedSearch } from '../services/saved_searches'; import { Adapters, RequestAdapter } from '../../../inspector/common'; import { SEARCH_EMBEDDABLE_TYPE } from './constants'; -import { - APPLY_FILTER_TRIGGER, - esFilters, - FilterManager, - generateFilters, -} from '../../../data/public'; +import { APPLY_FILTER_TRIGGER, FilterManager, generateFilters } from '../../../data/public'; import { DiscoverServices } from '../build_services'; -import { Filter, ISearchSource, Query, TimeRange, FilterStateStore } from '../../../data/public'; +import { ISearchSource, Query, TimeRange, FilterStateStore } from '../../../data/public'; import { DataView, DataViewField } from '../../../data_views/public'; import { SavedSearchEmbeddableComponent } from './saved_search_embeddable_component'; import { UiActionsStart } from '../../../ui_actions/public'; @@ -332,7 +328,7 @@ export class SavedSearchEmbeddable { forceFetch = false }: { forceFetch: boolean } = { forceFetch: false } ) { const isFetchRequired = - !esFilters.onlyDisabledFiltersChanged(this.input.filters, this.prevFilters) || + !onlyDisabledFiltersChanged(this.input.filters, this.prevFilters) || !isEqual(this.prevQuery, this.input.query) || !isEqual(this.prevTimeRange, this.input.timeRange) || !isEqual(searchProps.sort, this.input.sort || this.savedSearch.sort) || diff --git a/src/plugins/discover/public/services/doc_views/components/doc_viewer_source/get_height.test.tsx b/src/plugins/discover/public/services/doc_views/components/doc_viewer_source/get_height.test.tsx index 5b641cced5163..fc8f7498f6efc 100644 --- a/src/plugins/discover/public/services/doc_views/components/doc_viewer_source/get_height.test.tsx +++ b/src/plugins/discover/public/services/doc_views/components/doc_viewer_source/get_height.test.tsx @@ -10,7 +10,8 @@ import { monaco } from '@kbn/monaco'; import { getHeight } from './get_height'; describe('getHeight', () => { - window.innerHeight = 500; + Object.defineProperty(window, 'innerHeight', { writable: true, configurable: true, value: 500 }); + const getMonacoMock = (lineCount: number) => { return { getDomNode: jest.fn(() => { From aa4ce92457ff968903559d2d623302380c326286 Mon Sep 17 00:00:00 2001 From: Aleh Zasypkin Date: Tue, 29 Mar 2022 10:44:00 +0200 Subject: [PATCH 070/160] Update API keys docs to remove unnecessary API keys service section. (#128464) --- docs/user/security/api-keys/index.asciidoc | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/docs/user/security/api-keys/index.asciidoc b/docs/user/security/api-keys/index.asciidoc index 94301568b6438..bc277609d43e4 100644 --- a/docs/user/security/api-keys/index.asciidoc +++ b/docs/user/security/api-keys/index.asciidoc @@ -19,20 +19,6 @@ To manage API keys, open the main menu, then click *Stack Management > API Keys* [role="screenshot"] image:images/api-keys.png["API Keys UI"] -[float] -[[api-keys-service]] -=== {es} API key service - -The {es} API key service is automatically enabled when you configure -{ref}/configuring-tls.html#tls-http[TLS on the HTTP interface]. -This ensures that clients are unable to send API keys in clear-text. - -When HTTPS connections are not enabled between {kib} and {es}, -you cannot create or manage API keys, and you get an error message. -For more information, see the -{ref}/security-api-create-api-key.html[{es} API key documentation], -or contact your system administrator. - [float] [[api-keys-security-privileges]] === Security privileges From bef90a58663b6c4b668a7fe0ce45a002fb68c474 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Yulia=20=C4=8Cech?= <6585477+yuliacech@users.noreply.github.com> Date: Tue, 29 Mar 2022 10:44:11 +0200 Subject: [PATCH 071/160] Jest axe a11y testing (#127185) * [A11y] Added axe testing to testBed to be used in jest tests (CITs) * [A11y] Refactored axe helpers to be outside of testBed for better separation of concerns. Also added tests for indices tab in Index Management. * [A11y] Switched `axe_helpers` to use a Kibana wide axe config and rules that are now in kbn-test package * [A11y] Switched `axe_helpers` to use a Kibana wide axe config and rules that are now in kbn-test package * [A11y] Completed a11y tests in Index Management Indices tab. Also refactored http requests helper file. * Removed import comment * Reverted yarn.lock change * Correct yarn.lock changes * [IM] Updated the branch after merging main * [IM] Reverted unrelated ResponseError interface changes * [IM] Fixed eslint issue with kbn/test import --- package.json | 2 + packages/kbn-test-jest-helpers/BUILD.bazel | 5 + .../kbn-test-jest-helpers/src/axe_helpers.ts | 35 +++++ packages/kbn-test-jest-helpers/src/index.ts | 2 + .../src/testbed/types.ts | 2 +- packages/kbn-test/BUILD.bazel | 1 + .../kbn-test/src/a11y/config.ts | 0 packages/kbn-test/src/index.ts | 2 + test/accessibility/services/a11y/a11y.ts | 2 +- .../apm/ftr_e2e/cypress/support/commands.ts | 5 +- .../applications/shared/cypress/commands.ts | 6 +- .../__jest__/a11y/indices_tab.a11y.test.ts | 125 ++++++++++++++++++ .../client_integration/helpers/fixtures.ts | 47 +++++++ .../helpers/http_requests.ts | 17 ++- .../client_integration/helpers/index.ts | 2 + .../helpers/test_subjects.ts | 3 +- yarn.lock | 85 ++++++++++-- 17 files changed, 317 insertions(+), 24 deletions(-) create mode 100644 packages/kbn-test-jest-helpers/src/axe_helpers.ts rename test/accessibility/services/a11y/constants.ts => packages/kbn-test/src/a11y/config.ts (100%) create mode 100644 x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts create mode 100644 x-pack/plugins/index_management/__jest__/client_integration/helpers/fixtures.ts diff --git a/package.json b/package.json index b8ec92ab796d6..4eba243e30b8a 100644 --- a/package.json +++ b/package.json @@ -571,6 +571,7 @@ "@types/inquirer": "^7.3.1", "@types/intl-relativeformat": "^2.1.0", "@types/jest": "^26.0.22", + "@types/jest-axe": "^3.5.3", "@types/jest-specific-snapshot": "^0.5.5", "@types/joi": "^17.2.3", "@types/jquery": "^3.3.31", @@ -821,6 +822,7 @@ "is-glob": "^4.0.1", "is-path-inside": "^3.0.2", "jest": "^26.6.3", + "jest-axe": "^5.0.0", "jest-canvas-mock": "^2.3.1", "jest-circus": "^26.6.3", "jest-cli": "^26.6.3", diff --git a/packages/kbn-test-jest-helpers/BUILD.bazel b/packages/kbn-test-jest-helpers/BUILD.bazel index d910fab5295d5..c97859e8baab1 100644 --- a/packages/kbn-test-jest-helpers/BUILD.bazel +++ b/packages/kbn-test-jest-helpers/BUILD.bazel @@ -34,6 +34,7 @@ NPM_MODULE_EXTRA_FILES = [ RUNTIME_DEPS = [ "//packages/kbn-dev-utils", "//packages/kbn-i18n-react", + "//packages/kbn-test", "//packages/kbn-std", "//packages/kbn-utils", "@npm//@elastic/elasticsearch", @@ -51,6 +52,7 @@ RUNTIME_DEPS = [ "@npm//he", "@npm//history", "@npm//jest", + "@npm//jest-axe", "@npm//jest-cli", "@npm//jest-snapshot", "@npm//jest-styled-components", @@ -76,9 +78,11 @@ TYPES_DEPS = [ "//packages/kbn-dev-utils:npm_module_types", "//packages/kbn-i18n-react:npm_module_types", "//packages/kbn-std:npm_module_types", + "//packages/kbn-test:npm_module_types", "//packages/kbn-utils:npm_module_types", "@npm//@elastic/elasticsearch", "@npm//axios", + "@npm//axe-core", "@npm//elastic-apm-node", "@npm//del", "@npm//exit-hook", @@ -96,6 +100,7 @@ TYPES_DEPS = [ "@npm//@types/he", "@npm//@types/history", "@npm//@types/jest", + "@npm//@types/jest-axe", "@npm//@types/joi", "@npm//@types/lodash", "@npm//@types/mustache", diff --git a/packages/kbn-test-jest-helpers/src/axe_helpers.ts b/packages/kbn-test-jest-helpers/src/axe_helpers.ts new file mode 100644 index 0000000000000..215209546f956 --- /dev/null +++ b/packages/kbn-test-jest-helpers/src/axe_helpers.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { configureAxe } from 'jest-axe'; +import { Result } from 'axe-core'; +import { AXE_OPTIONS, AXE_CONFIG } from '@kbn/test'; +import { ReactWrapper } from './testbed/types'; + +const axeRunner = configureAxe({ globalOptions: { ...AXE_CONFIG } }); + +/** + * Function to test if a component doesn't have a11y violations from axe automated testing + * @param component + */ +export const expectToBeAccessible = async (component: ReactWrapper): Promise => { + const violations = await getA11yViolations(component); + expect(violations).toHaveLength(0); +}; + +/** + * Returns a11y violations as found by axe testing + * @param component + */ +export const getA11yViolations = async (component: ReactWrapper): Promise => { + const axeResults = await axeRunner(component.html(), { + ...AXE_OPTIONS, + resultTypes: ['violations'], + }); + return axeResults.violations; +}; diff --git a/packages/kbn-test-jest-helpers/src/index.ts b/packages/kbn-test-jest-helpers/src/index.ts index 3594df854cbe4..809d4380df10a 100644 --- a/packages/kbn-test-jest-helpers/src/index.ts +++ b/packages/kbn-test-jest-helpers/src/index.ts @@ -24,6 +24,8 @@ export * from './stub_web_worker'; export * from './testbed'; +export * from './axe_helpers'; + export const nextTick = () => new Promise((res) => process.nextTick(res)); export const delay = (time = 0) => new Promise((resolve) => setTimeout(resolve, time)); diff --git a/packages/kbn-test-jest-helpers/src/testbed/types.ts b/packages/kbn-test-jest-helpers/src/testbed/types.ts index 11f8c802a9751..15996646ec80a 100644 --- a/packages/kbn-test-jest-helpers/src/testbed/types.ts +++ b/packages/kbn-test-jest-helpers/src/testbed/types.ts @@ -30,7 +30,7 @@ export interface EuiTableMetaData { } export interface TestBed { - /** The comonent under test */ + /** The component under test */ component: ReactWrapper; /** * Pass it a `data-test-subj` and it will return true if it exists or false if it does not exist. diff --git a/packages/kbn-test/BUILD.bazel b/packages/kbn-test/BUILD.bazel index 4dc8d684941f3..99d8c64c88032 100644 --- a/packages/kbn-test/BUILD.bazel +++ b/packages/kbn-test/BUILD.bazel @@ -86,6 +86,7 @@ TYPES_DEPS = [ "@npm//@elastic/elasticsearch", "@npm//@jest/console", "@npm//@jest/reporters", + "@npm//axe-core", "@npm//axios", "@npm//elastic-apm-node", "@npm//del", diff --git a/test/accessibility/services/a11y/constants.ts b/packages/kbn-test/src/a11y/config.ts similarity index 100% rename from test/accessibility/services/a11y/constants.ts rename to packages/kbn-test/src/a11y/config.ts diff --git a/packages/kbn-test/src/index.ts b/packages/kbn-test/src/index.ts index c9f0e67c558f1..a0e45f9d7b752 100644 --- a/packages/kbn-test/src/index.ts +++ b/packages/kbn-test/src/index.ts @@ -69,3 +69,5 @@ export { runJest } from './jest/run'; export * from './kbn_archiver_cli'; export * from './kbn_client'; + +export { AXE_CONFIG, AXE_OPTIONS } from './a11y/config'; diff --git a/test/accessibility/services/a11y/a11y.ts b/test/accessibility/services/a11y/a11y.ts index f4d5ceba5a6e3..fd4362c1c82b4 100644 --- a/test/accessibility/services/a11y/a11y.ts +++ b/test/accessibility/services/a11y/a11y.ts @@ -8,9 +8,9 @@ import chalk from 'chalk'; import testSubjectToCss from '@kbn/test-subj-selector'; +import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; import { FtrService } from '../../ftr_provider_context'; -import { AXE_CONFIG, AXE_OPTIONS } from './constants'; import { AxeReport, printResult } from './axe_report'; // @ts-ignore JS that is run in browser as is import { analyzeWithAxe, analyzeWithAxeWithClient } from './analyze_with_axe'; diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts b/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts index 91edae9046f6d..89d8fa620c183 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts @@ -7,10 +7,7 @@ import 'cypress-real-events/support'; import { Interception } from 'cypress/types/net-stubbing'; import 'cypress-axe'; -import { - AXE_CONFIG, - AXE_OPTIONS, -} from 'test/accessibility/services/a11y/constants'; +import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; Cypress.Commands.add('loginAsReadOnlyUser', () => { cy.loginAs({ username: 'apm_read_user', password: 'changeme' }); diff --git a/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts b/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts index 475343948f348..083d55e6f7029 100644 --- a/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts +++ b/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts @@ -38,9 +38,11 @@ export const login = ({ * Cypress setup/helpers */ +// eslint complains this should be in `dependencies` and not `devDependencies`, but these tests should only run on dev // eslint-disable-next-line import/no-extraneous-dependencies -import 'cypress-axe'; // eslint complains this should be in `dependencies` and not `devDependencies`, but these tests should only run on dev -import { AXE_CONFIG, AXE_OPTIONS } from 'test/accessibility/services/a11y/constants'; +import 'cypress-axe'; +// eslint-disable-next-line import/no-extraneous-dependencies +import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; const axeConfig = { ...AXE_CONFIG, diff --git a/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts b/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts new file mode 100644 index 0000000000000..dada1c0fc91c5 --- /dev/null +++ b/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { act } from 'react-dom/test-utils'; +// import { expectToBeAccessible } from '@kbn/test-jest-helpers'; +import { getA11yViolations } from '@kbn/test-jest-helpers'; +import { IndicesTestBed, setup } from '../client_integration/home/indices_tab.helpers'; +import { + indexMappings, + indexSettings, + indexStats, + setupEnvironment, +} from '../client_integration/helpers'; +import { + createDataStreamBackingIndex, + createNonDataStreamIndex, +} from '../client_integration/home/data_streams_tab.helpers'; + +describe('A11y Indices tab', () => { + let testBed: IndicesTestBed; + let httpSetup: ReturnType['httpSetup']; + let httpRequestsMockHelpers: ReturnType['httpRequestsMockHelpers']; + + beforeEach(() => { + const mockEnvironment = setupEnvironment(); + httpRequestsMockHelpers = mockEnvironment.httpRequestsMockHelpers; + httpSetup = mockEnvironment.httpSetup; + }); + + it('when there are no indices', async () => { + httpRequestsMockHelpers.setLoadIndicesResponse([]); + await act(async () => { + testBed = await setup(httpSetup); + }); + const { component } = testBed; + component.update(); + // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana + // await expectToBeAccessible(component); + // until then check that only 1 expected violation is found + const violations = await getA11yViolations(component); + expect(violations).toHaveLength(1); + const { id } = violations[0]; + expect(id).toEqual('aria-allowed-attr'); + }); + + it('when there are indices', async () => { + httpRequestsMockHelpers.setLoadIndicesResponse([ + createNonDataStreamIndex('non-data-stream-test-index'), + createDataStreamBackingIndex('data-stream-test-index', 'test-data-stream'), + ]); + await act(async () => { + testBed = await setup(httpSetup); + }); + const { component } = testBed; + component.update(); + // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana + // await expectToBeAccessible(component); + // until then check that only 1 expected violation is found + const violations = await getA11yViolations(component); + expect(violations).toHaveLength(1); + const { id } = violations[0]; + expect(id).toEqual('aria-allowed-attr'); + }); + + describe('index details flyout', () => { + beforeEach(async () => { + httpRequestsMockHelpers.setLoadIndicesResponse([ + createNonDataStreamIndex('non-data-stream-test-index'), + ]); + httpRequestsMockHelpers.setLoadIndexSettingsResponse(indexSettings); + httpRequestsMockHelpers.setLoadIndexMappingResponse(indexMappings); + httpRequestsMockHelpers.setLoadIndexStatsResponse(indexStats); + await act(async () => { + testBed = await setup(httpSetup); + }); + const { component, find } = testBed; + component.update(); + find('indexTableIndexNameLink').at(0).simulate('click'); + component.update(); + }); + + it('summary tab', async () => { + const { component, find } = testBed; + expect(find('detailPanelTabSelected').text()).toEqual('Summary'); + // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana + // await expectToBeAccessible(component); + // until then check that only 1 expected violation is found + const violations = await getA11yViolations(component); + expect(violations).toHaveLength(1); + const { id } = violations[0]; + expect(id).toEqual('aria-allowed-attr'); + }); + ['settings', 'mappings', 'stats'].forEach((tab) => { + it(`${tab} tab`, async () => { + const { component, find, actions } = testBed; + await actions.selectIndexDetailsTab(tab as 'settings'); + expect(find('detailPanelTabSelected').text().toLowerCase()).toEqual(tab); + // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana + // await expectToBeAccessible(component); + // until then check that only 1 expected violation is found + const violations = await getA11yViolations(component); + expect(violations).toHaveLength(1); + const { id } = violations[0]; + expect(id).toEqual('aria-allowed-attr'); + }); + }); + + it('edit settings tab', async () => { + const { component, find, actions } = testBed; + await actions.selectIndexDetailsTab('edit_settings'); + expect(find('detailPanelTabSelected').text()).toEqual('Edit settings'); + // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana + // await expectToBeAccessible(component); + // until then check that only 1 expected violation is found + const violations = await getA11yViolations(component); + expect(violations).toHaveLength(1); + const { id } = violations[0]; + expect(id).toEqual('aria-allowed-attr'); + }); + }); +}); diff --git a/x-pack/plugins/index_management/__jest__/client_integration/helpers/fixtures.ts b/x-pack/plugins/index_management/__jest__/client_integration/helpers/fixtures.ts new file mode 100644 index 0000000000000..9f2423b1056f8 --- /dev/null +++ b/x-pack/plugins/index_management/__jest__/client_integration/helpers/fixtures.ts @@ -0,0 +1,47 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export const indexSettings = { + settings: { index: { number_of_shards: '1' } }, + defaults: { index: { flush_after_merge: '512mb' } }, +}; + +export const indexMappings = { + mappings: { + dynamic: 'strict', + properties: { + '@timestamp': { + type: 'date', + }, + }, + }, +}; + +export const indexStats = { + _shards: { + total: 1, + successful: 1, + failed: 0, + }, + stats: { + uuid: 'test-uuid', + health: 'green', + status: 'open', + primaries: { + docs: { + count: 0, + deleted: 0, + }, + }, + total: { + docs: { + count: 0, + deleted: 0, + }, + }, + }, +}; diff --git a/x-pack/plugins/index_management/__jest__/client_integration/helpers/http_requests.ts b/x-pack/plugins/index_management/__jest__/client_integration/helpers/http_requests.ts index 4726286319e52..2be3d9c9460cf 100644 --- a/x-pack/plugins/index_management/__jest__/client_integration/helpers/http_requests.ts +++ b/x-pack/plugins/index_management/__jest__/client_integration/helpers/http_requests.ts @@ -94,11 +94,14 @@ const registerHttpRequestMockHelpers = ( const setCreateTemplateResponse = (response?: HttpResponse, error?: ResponseError) => mockResponse('POST', `${API_BASE_PATH}/index_templates`, response, error); - const setUpdateTemplateResponse = ( - templateId: string, - response?: HttpResponse, - error?: ResponseError - ) => mockResponse('PUT', `${API_BASE_PATH}/index_templates/${templateId}`, response, error); + const setLoadIndexSettingsResponse = (response?: HttpResponse, error?: ResponseError) => + mockResponse('GET', `${API_BASE_PATH}/settings/:name`, response, error); + + const setLoadIndexMappingResponse = (response?: HttpResponse, error?: ResponseError) => + mockResponse('GET', `${API_BASE_PATH}/mapping/:name`, response, error); + + const setLoadIndexStatsResponse = (response?: HttpResponse, error?: ResponseError) => + mockResponse('GET', `${API_BASE_PATH}/stats/:name`, response, error); const setUpdateIndexSettingsResponse = ( indexName: string, @@ -128,7 +131,9 @@ const registerHttpRequestMockHelpers = ( setDeleteTemplateResponse, setLoadTemplateResponse, setCreateTemplateResponse, - setUpdateTemplateResponse, + setLoadIndexSettingsResponse, + setLoadIndexMappingResponse, + setLoadIndexStatsResponse, setUpdateIndexSettingsResponse, setSimulateTemplateResponse, setLoadComponentTemplatesResponse, diff --git a/x-pack/plugins/index_management/__jest__/client_integration/helpers/index.ts b/x-pack/plugins/index_management/__jest__/client_integration/helpers/index.ts index ba2dea966d8cb..1fad428342482 100644 --- a/x-pack/plugins/index_management/__jest__/client_integration/helpers/index.ts +++ b/x-pack/plugins/index_management/__jest__/client_integration/helpers/index.ts @@ -18,3 +18,5 @@ export { } from './setup_environment'; export type { TestSubjects } from './test_subjects'; + +export * from './fixtures'; diff --git a/x-pack/plugins/index_management/__jest__/client_integration/helpers/test_subjects.ts b/x-pack/plugins/index_management/__jest__/client_integration/helpers/test_subjects.ts index f7066fbeda95e..2574594c7fcf8 100644 --- a/x-pack/plugins/index_management/__jest__/client_integration/helpers/test_subjects.ts +++ b/x-pack/plugins/index_management/__jest__/client_integration/helpers/test_subjects.ts @@ -62,4 +62,5 @@ export type TestSubjects = | 'unfreezeIndexMenuButton' | 'updateEditIndexSettingsButton' | 'updateIndexSettingsErrorCallout' - | 'viewButton'; + | 'viewButton' + | 'detailPanelTabSelected'; diff --git a/yarn.lock b/yarn.lock index 6814b5463143e..5180f8fbbc6b8 100644 --- a/yarn.lock +++ b/yarn.lock @@ -5826,6 +5826,14 @@ dependencies: "@types/istanbul-lib-report" "*" +"@types/jest-axe@^3.5.3": + version "3.5.3" + resolved "https://registry.yarnpkg.com/@types/jest-axe/-/jest-axe-3.5.3.tgz#5af918553388aa0a448af75603b44093985778c6" + integrity sha512-ad9qI9f+00N8IlOuGh6dnZ6o0BDdV9VhGfTUr1zCejsPvOfZd6eohffe4JYxUoUuRYEftyMcaJ6Ux4+MsOpGHg== + dependencies: + "@types/jest" "*" + axe-core "^3.5.5" + "@types/jest-specific-snapshot@^0.5.3", "@types/jest-specific-snapshot@^0.5.5": version "0.5.5" resolved "https://registry.yarnpkg.com/@types/jest-specific-snapshot/-/jest-specific-snapshot-0.5.5.tgz#47ce738870be99898ed6d7b08dbf0240c74ae553" @@ -8447,6 +8455,16 @@ aws4@^1.8.0: resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.8.0.tgz#f0e003d9ca9e7f59c7a508945d7b2ef9a04a542f" integrity sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ== +axe-core@4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.2.1.tgz#2e50bcf10ee5b819014f6e342e41e45096239e34" + integrity sha512-evY7DN8qSIbsW2H/TWQ1bX3sXN1d4MNb5Vb4n7BzPuCwRHdkZ1H2eNLuSh73EoQqkGKUtju2G2HCcjCfhvZIAA== + +axe-core@^3.5.5: + version "3.5.6" + resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-3.5.6.tgz#e762a90d7f6dbd244ceacb4e72760ff8aad521b5" + integrity sha512-LEUDjgmdJoA3LqklSTwKYqkjcZ4HKc4ddIYGSAiSkr46NTjzg2L9RNB+lekO9P7Dlpa87+hBtzc2Fzn/+GUWMQ== + axe-core@^4.0.2: version "4.0.2" resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.0.2.tgz#c7cf7378378a51fcd272d3c09668002a4990b1cb" @@ -9752,6 +9770,14 @@ chalk@2.4.2, chalk@^2.0.0, chalk@^2.0.1, chalk@^2.3.0, chalk@^2.4.1, chalk@^2.4. escape-string-regexp "^1.0.5" supports-color "^5.3.0" +chalk@4.1.0, chalk@^4.0.0, chalk@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.0.tgz#4e14870a618d9e2edd97dd8345fd9d9dc315646a" + integrity sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + chalk@4.1.2, chalk@^4.1.1, chalk@^4.1.2: version "4.1.2" resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" @@ -9779,14 +9805,6 @@ chalk@^3.0.0: ansi-styles "^4.1.0" supports-color "^7.1.0" -chalk@^4.0.0, chalk@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.0.tgz#4e14870a618d9e2edd97dd8345fd9d9dc315646a" - integrity sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A== - dependencies: - ansi-styles "^4.1.0" - supports-color "^7.1.0" - chalk@~0.5.1: version "0.5.1" resolved "https://registry.yarnpkg.com/chalk/-/chalk-0.5.1.tgz#663b3a648b68b55d04690d49167aa837858f2174" @@ -12376,6 +12394,11 @@ diff-sequences@^27.0.6: resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-27.0.6.tgz#3305cb2e55a033924054695cc66019fd7f8e5723" integrity sha512-ag6wfpBFyNXZ0p8pcuIDS//D8H062ZQJ3fzYxjpmeKjnz8W4pekL3AI8VohmyZmsWW2PWaHgjsmqR6L13101VQ== +diff-sequences@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-27.5.1.tgz#eaecc0d327fd68c8d9672a1e64ab8dccb2ef5327" + integrity sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ== + diff@5.0.0, diff@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/diff/-/diff-5.0.0.tgz#7ed6ad76d859d030787ec35855f5b1daf31d852b" @@ -17573,6 +17596,16 @@ jake@^10.6.1: filelist "^1.0.1" minimatch "^3.0.4" +jest-axe@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/jest-axe/-/jest-axe-5.0.1.tgz#26c43643b2e5f2bd4900c1ab36f8283635957a6e" + integrity sha512-MMOWA6gT4pcZGbTLS8ZEqABH08Lnj5bInfLPpn9ADWX2wFF++odbbh8csmSfkwKjHaioVPzlCtIypAtxFDx/rw== + dependencies: + axe-core "4.2.1" + chalk "4.1.0" + jest-matcher-utils "27.0.2" + lodash.merge "4.6.2" + jest-canvas-mock@^2.3.1: version "2.3.1" resolved "https://registry.yarnpkg.com/jest-canvas-mock/-/jest-canvas-mock-2.3.1.tgz#9535d14bc18ccf1493be36ac37dd349928387826" @@ -17680,6 +17713,16 @@ jest-diff@^26.0.0, jest-diff@^26.6.2: jest-get-type "^26.3.0" pretty-format "^26.6.2" +jest-diff@^27.0.2: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-27.5.1.tgz#a07f5011ac9e6643cf8a95a462b7b1ecf6680def" + integrity sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw== + dependencies: + chalk "^4.0.0" + diff-sequences "^27.5.1" + jest-get-type "^27.5.1" + pretty-format "^27.5.1" + jest-diff@^27.2.0: version "27.2.0" resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-27.2.0.tgz#bda761c360f751bab1e7a2fe2fc2b0a35ce8518c" @@ -17752,6 +17795,11 @@ jest-get-type@^26.3.0: resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-26.3.0.tgz#e97dc3c3f53c2b406ca7afaed4493b1d099199e0" integrity sha512-TpfaviN1R2pQWkIihlfEanwOXK0zcxrKEE4MlU6Tn7keoXdN6/3gK/xl0yEh8DOunn5pOVGKf8hB4R9gVh04ig== +jest-get-type@^27.0.1, jest-get-type@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-27.5.1.tgz#3cd613c507b0f7ace013df407a1c1cd578bcb4f1" + integrity sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw== + jest-get-type@^27.0.6: version "27.0.6" resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-27.0.6.tgz#0eb5c7f755854279ce9b68a9f1a4122f69047cfe" @@ -17810,6 +17858,16 @@ jest-leak-detector@^26.6.2: jest-get-type "^26.3.0" pretty-format "^26.6.2" +jest-matcher-utils@27.0.2: + version "27.0.2" + resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-27.0.2.tgz#f14c060605a95a466cdc759acc546c6f4cbfc4f0" + integrity sha512-Qczi5xnTNjkhcIB0Yy75Txt+Ez51xdhOxsukN7awzq2auZQGPHcQrJ623PZj0ECDEMOk2soxWx05EXdXGd1CbA== + dependencies: + chalk "^4.0.0" + jest-diff "^27.0.2" + jest-get-type "^27.0.1" + pretty-format "^27.0.2" + jest-matcher-utils@^24.9.0: version "24.9.0" resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-24.9.0.tgz#f5b3661d5e628dffe6dd65251dfdae0e87c3a073" @@ -19162,7 +19220,7 @@ lodash.memoize@~3.0.3: resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-3.0.4.tgz#2dcbd2c287cbc0a55cc42328bd0c736150d53e3f" integrity sha1-LcvSwofLwKVcxCMovQxzYVDVPj8= -lodash.merge@^4.6.2: +lodash.merge@4.6.2, lodash.merge@^4.6.2: version "4.6.2" resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== @@ -22889,6 +22947,15 @@ pretty-format@^26.0.0, pretty-format@^26.6.2: ansi-styles "^4.0.0" react-is "^17.0.1" +pretty-format@^27.0.2, pretty-format@^27.5.1: + version "27.5.1" + resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-27.5.1.tgz#2181879fdea51a7a5851fb39d920faa63f01d88e" + integrity sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ== + dependencies: + ansi-regex "^5.0.1" + ansi-styles "^5.0.0" + react-is "^17.0.1" + pretty-format@^27.2.0: version "27.2.0" resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-27.2.0.tgz#ee37a94ce2a79765791a8649ae374d468c18ef19" From 2dcdbbe658e12a713280c7fcb8a8956a672fde90 Mon Sep 17 00:00:00 2001 From: Yaroslav Kuznietsov Date: Tue, 29 Mar 2022 11:58:26 +0300 Subject: [PATCH 072/160] [XY] `system_palette` and `palette` support. (#128053) * Added support of `system_palette` and `palette` types at the `dataLayer` `palette` arg. Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> Co-authored-by: Marta Bondyra --- .../expression_functions/data_layer_config.ts | 4 +- .../__snapshots__/to_expression.test.ts.snap | 16 +++++++ .../public/xy_visualization/to_expression.ts | 46 ++++++++++--------- 3 files changed, 42 insertions(+), 24 deletions(-) diff --git a/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts b/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts index 3aac992d674d9..e9ffa0f41f49f 100644 --- a/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts +++ b/src/plugins/chart_expressions/expression_xy/common/expression_functions/data_layer_config.ts @@ -106,11 +106,11 @@ export const dataLayerConfigFunction: ExpressionFunctionDefinition< }), }, palette: { - default: `{theme "palette" default={system_palette name="default"} }`, + types: ['palette', 'system_palette'], help: i18n.translate('expressionXY.dataLayer.palette.help', { defaultMessage: 'Palette', }), - types: ['palette'], + default: '{palette}', }, }, fn(input, args) { diff --git a/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap b/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap index 27cc383834049..256df38ffa5b3 100644 --- a/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap +++ b/x-pack/plugins/lens/public/xy_visualization/__snapshots__/to_expression.test.ts.snap @@ -113,6 +113,22 @@ Object { "layerId": Array [ "first", ], + "palette": Array [ + Object { + "chain": Array [ + Object { + "arguments": Object { + "name": Array [ + "default", + ], + }, + "function": "system_palette", + "type": "function", + }, + ], + "type": "expression", + }, + ], "seriesType": Array [ "area", ], diff --git a/x-pack/plugins/lens/public/xy_visualization/to_expression.ts b/x-pack/plugins/lens/public/xy_visualization/to_expression.ts index ec9093a999c84..86ae7e0bc328e 100644 --- a/x-pack/plugins/lens/public/xy_visualization/to_expression.ts +++ b/x-pack/plugins/lens/public/xy_visualization/to_expression.ts @@ -480,29 +480,31 @@ const dataLayerToExpression = ( seriesType: [layer.seriesType], accessors: layer.accessors, columnToLabel: [JSON.stringify(columnToLabel)], - ...(layer.palette - ? { - palette: [ - { - type: 'expression', - chain: [ - { - type: 'function', - function: 'theme', - arguments: { - variable: ['palette'], - default: [ - paletteService - .get(layer.palette.name) - .toExpression(layer.palette.params), - ], - }, + palette: [ + { + type: 'expression', + chain: [ + layer.palette + ? { + type: 'function', + function: 'theme', + arguments: { + variable: ['palette'], + default: [ + paletteService.get(layer.palette.name).toExpression(layer.palette.params), + ], }, - ], - }, - ], - } - : {}), + } + : { + type: 'function', + function: 'system_palette', + arguments: { + name: ['default'], + }, + }, + ], + }, + ], }, }, ], From 7cb72014aab9d5bb403c1b3507922c44c18acefa Mon Sep 17 00:00:00 2001 From: Thomas Watson Date: Tue, 29 Mar 2022 11:08:21 +0200 Subject: [PATCH 073/160] Bump @elastic/request-crypto from v2.0.0 to v2.0.1 (#128710) --- package.json | 3 +-- yarn.lock | 69 ++++++++++++++++++++++++++++++++++------------------ 2 files changed, 47 insertions(+), 25 deletions(-) diff --git a/package.json b/package.json index 4eba243e30b8a..35edc14f01325 100644 --- a/package.json +++ b/package.json @@ -86,7 +86,6 @@ "**/json-schema": "^0.4.0", "**/minimatch": "^3.1.2", "**/minimist": "^1.2.6", - "**/node-forge": "^1.3.0", "**/pdfkit/crypto-js": "4.0.0", "**/react-syntax-highlighter": "^15.3.1", "**/react-syntax-highlighter/**/highlight.js": "^10.4.1", @@ -114,7 +113,7 @@ "@elastic/node-crypto": "1.2.1", "@elastic/numeral": "^2.5.1", "@elastic/react-search-ui": "^1.6.0", - "@elastic/request-crypto": "2.0.0", + "@elastic/request-crypto": "2.0.1", "@elastic/safer-lodash-set": "link:bazel-bin/packages/elastic-safer-lodash-set", "@elastic/search-ui-app-search-connector": "^1.6.0", "@emotion/cache": "^11.4.0", diff --git a/yarn.lock b/yarn.lock index 5180f8fbbc6b8..ce7e815915a8b 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1613,14 +1613,14 @@ "@elastic/react-search-ui-views" "1.6.0" "@elastic/search-ui" "1.6.0" -"@elastic/request-crypto@2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@elastic/request-crypto/-/request-crypto-2.0.0.tgz#a3988be98ed63398c3d0177948c7ac2a857835bb" - integrity sha512-jIReBeHzgUKNsYwdhnTyLFSGHyLsJgQIIw+AMEnq1lcONA/uKG7hhFUK2Z8XxjJ86/oXt1TwJ4BIagZR3mzq7w== +"@elastic/request-crypto@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@elastic/request-crypto/-/request-crypto-2.0.1.tgz#88dc41e4bbba6764c323e1a820757607e2f4f720" + integrity sha512-ZFZ+CF1hb22+BLAe93D4Kc1EMPfVDKckd8SY6IHk/N4H1WUthQ9xXfPVx06r+pTkz62HliyQfXgLKFTQa+aSmw== dependencies: "@elastic/node-crypto" "1.1.1" - "@types/node-jose" "1.1.8" - node-jose "2.0.0" + "@types/node-jose" "1.1.10" + node-jose "2.1.0" "@elastic/safer-lodash-set@link:bazel-bin/packages/elastic-safer-lodash-set": version "0.0.0" @@ -6364,10 +6364,10 @@ dependencies: "@types/node" "*" -"@types/node-jose@1.1.8": - version "1.1.8" - resolved "https://registry.yarnpkg.com/@types/node-jose/-/node-jose-1.1.8.tgz#26b7ae96e3309acb426ea5393ff5d6a0c1c38625" - integrity sha512-AFcArbplUaO+DqGVEPaiz/guw3uUA+dRHjaj26EEDF0DmTEPUd3dEdfdJMUx4kD65EAR3TnI1iHIcb31+Ko87Q== +"@types/node-jose@1.1.10": + version "1.1.10" + resolved "https://registry.yarnpkg.com/@types/node-jose/-/node-jose-1.1.10.tgz#1fc559b63e665f27acedbcb91601e2fee256fad0" + integrity sha512-7L0ucJTugW4x/sYpQ+c5IudAwr0pFuxDVnZLpHKWpff7p1lVa3wTuNvnrzFBNeLojE+UY0cVCwNGXLxXsMIrzw== dependencies: "@types/node" "*" @@ -9432,6 +9432,14 @@ buffer@^5.2.1: base64-js "^1.3.1" ieee754 "^1.1.13" +buffer@^6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" + integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.2.1" + buffer@~5.2.1: version "5.2.1" resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.2.1.tgz#dd57fa0f109ac59c602479044dca7b8b3d0b71d6" @@ -16401,7 +16409,7 @@ ieee754@^1.1.12, ieee754@^1.1.4: resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.13.tgz#ec168558e95aa181fd87d37f55c32bbcb6708b84" integrity sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg== -ieee754@^1.1.13: +ieee754@^1.1.13, ieee754@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== @@ -19380,6 +19388,11 @@ long@^4.0.0: resolved "https://registry.yarnpkg.com/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28" integrity sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA== +long@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/long/-/long-5.2.0.tgz#2696dadf4b4da2ce3f6f6b89186085d94d52fd61" + integrity sha512-9RTUNjK60eJbx3uz+TEGF7fUr29ZDxR5QzXcyDpeSfeH28S9ycINflOgOlppit5U+4kNTe83KQnMEerw7GmE8w== + longest-streak@^2.0.0, longest-streak@^2.0.1: version "2.0.4" resolved "https://registry.yarnpkg.com/longest-streak/-/longest-streak-2.0.4.tgz#b8599957da5b5dab64dee3fe316fa774597d90e4" @@ -20768,7 +20781,12 @@ node-fetch@2.6.1, node-fetch@^1.0.1, node-fetch@^2.3.0, node-fetch@^2.6.1, node- dependencies: whatwg-url "^5.0.0" -node-forge@^0.10.0, node-forge@^1.3.0: +node-forge@^0.10.0: + version "0.10.0" + resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-0.10.0.tgz#32dea2afb3e9926f02ee5ce8794902691a676bf3" + integrity sha512-PPmu8eEeG9saEUvI97fm4OYxXVB6bFvyNTyiUOBichBpFG8A1Ljw3bY62+5oOjDEMHRnd0Y7HQ+x7uzxOzC6JA== + +node-forge@^1.2.1, node-forge@^1.3.0: version "1.3.0" resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-1.3.0.tgz#37a874ea723855f37db091e6c186e5b67a01d4b2" integrity sha512-08ARB91bUi6zNKzVmaj3QO7cr397uiDT2nJ63cHjyNtCTWIgvS47j3eT0WfzUwS9+6Z5YshRaoasFkXCKrIYbA== @@ -20815,20 +20833,20 @@ node-int64@^0.4.0: resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" integrity sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs= -node-jose@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/node-jose/-/node-jose-2.0.0.tgz#541c6b52c387a3f18fc06cd502baad759af9c470" - integrity sha512-j8zoFze1gijl8+DK/dSXXqX7+o2lMYv1XS+ptnXgGV/eloQaqq1YjNtieepbKs9jBS4WTnMOqyKSaQuunJzx0A== +node-jose@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/node-jose/-/node-jose-2.1.0.tgz#a2d12a7ff2d386f23979c1bf77f939449ce073d8" + integrity sha512-Zmm8vFPJabphGBc5Wz1/LUMPS+1cynqw16RIhgVNQMEI2yEQrvl7Gx2EwN9GhP8tkm8f7SH53K2nIx8TeNTIdg== dependencies: base64url "^3.0.1" - buffer "^5.5.0" + buffer "^6.0.3" es6-promise "^4.2.8" - lodash "^4.17.15" - long "^4.0.0" - node-forge "^0.10.0" - pako "^1.0.11" + lodash "^4.17.21" + long "^5.2.0" + node-forge "^1.2.1" + pako "^2.0.4" process "^0.11.10" - uuid "^3.3.3" + uuid "^8.3.2" node-libs-browser@^2.2.1: version "2.2.1" @@ -21744,11 +21762,16 @@ pako@^0.2.5: resolved "https://registry.yarnpkg.com/pako/-/pako-0.2.9.tgz#f3f7522f4ef782348da8161bad9ecfd51bf83a75" integrity sha1-8/dSL073gjSNqBYbrZ7P1Rv4OnU= -pako@^1.0.11, pako@^1.0.3, pako@^1.0.5, pako@~1.0.2, pako@~1.0.5: +pako@^1.0.3, pako@^1.0.5, pako@~1.0.2, pako@~1.0.5: version "1.0.11" resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== +pako@^2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/pako/-/pako-2.0.4.tgz#6cebc4bbb0b6c73b0d5b8d7e8476e2b2fbea576d" + integrity sha512-v8tweI900AUkZN6heMU/4Uy4cXRc2AYNRggVmTR+dEncawDJgCdLMximOVA2p4qO57WMynangsfGRb5WD6L1Bg== + papaparse@^5.2.0: version "5.2.0" resolved "https://registry.yarnpkg.com/papaparse/-/papaparse-5.2.0.tgz#97976a1b135c46612773029153dc64995caa3b7b" From 23586d2e4f0039c5a95f70a8e51c01a1ae1485b7 Mon Sep 17 00:00:00 2001 From: Jordan <51442161+JordanSh@users.noreply.github.com> Date: Tue, 29 Mar 2022 12:32:19 +0300 Subject: [PATCH 074/160] CSP Viewing states (#128215) --- .../cloud_security_posture/common/types.ts | 2 +- .../public/common/api/index.ts | 2 +- .../api/use_cis_kubernetes_integration.tsx | 31 +++ ...s => use_compliance_dashboard_data_api.ts} | 6 +- .../public/components/chart_panel.tsx | 4 +- .../components/csp_page_template.test.tsx | 258 ++++++++++++++++++ .../public/components/csp_page_template.tsx | 202 ++++++++++++++ .../public/components/page_template.test.tsx | 158 ----------- .../public/components/page_template.tsx | 117 -------- .../public/components/translations.ts | 41 ++- .../public/components/unknown_route.tsx | 2 +- .../pages/benchmarks/benchmarks.test.tsx | 7 + .../public/pages/benchmarks/benchmarks.tsx | 5 +- .../compliance_charts/risks_table.tsx | 6 +- .../compliance_dashboard.tsx | 53 ++-- .../dashboard_sections/benchmarks_section.tsx | 42 +-- .../dashboard_sections/summary_section.tsx | 25 +- .../compliance_dashboard/translations.ts | 15 + .../public/pages/findings/findings.test.tsx | 5 + .../public/pages/findings/findings.tsx | 11 +- .../public/pages/rules/index.tsx | 17 +- .../public/pages/rules/rules.test.tsx | 7 + .../public/test/fixtures/react_query.ts | 8 +- .../compliance_dashboard.ts | 4 +- .../compliance_dashboard/get_clusters.test.ts | 2 +- .../compliance_dashboard/get_clusters.ts | 8 +- .../get_resources_types.test.ts | 2 +- .../get_resources_types.ts | 8 +- .../compliance_dashboard/get_stats.test.ts | 2 +- .../routes/compliance_dashboard/get_stats.ts | 8 +- 30 files changed, 646 insertions(+), 412 deletions(-) create mode 100644 x-pack/plugins/cloud_security_posture/public/common/api/use_cis_kubernetes_integration.tsx rename x-pack/plugins/cloud_security_posture/public/common/api/{use_cloud_posture_stats_api.ts => use_compliance_dashboard_data_api.ts} (71%) create mode 100644 x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx create mode 100644 x-pack/plugins/cloud_security_posture/public/components/csp_page_template.tsx delete mode 100644 x-pack/plugins/cloud_security_posture/public/components/page_template.test.tsx delete mode 100644 x-pack/plugins/cloud_security_posture/public/components/page_template.tsx diff --git a/x-pack/plugins/cloud_security_posture/common/types.ts b/x-pack/plugins/cloud_security_posture/common/types.ts index ca01d1ad927cd..b414b49ef30d3 100644 --- a/x-pack/plugins/cloud_security_posture/common/types.ts +++ b/x-pack/plugins/cloud_security_posture/common/types.ts @@ -35,7 +35,7 @@ export interface Cluster { resourcesTypes: ResourceType[]; } -export interface CloudPostureStats { +export interface ComplianceDashboardData { stats: Stats; resourcesTypes: ResourceType[]; clusters: Cluster[]; diff --git a/x-pack/plugins/cloud_security_posture/public/common/api/index.ts b/x-pack/plugins/cloud_security_posture/public/common/api/index.ts index 915881e2ab9b2..2468e095ff5f9 100644 --- a/x-pack/plugins/cloud_security_posture/public/common/api/index.ts +++ b/x-pack/plugins/cloud_security_posture/public/common/api/index.ts @@ -5,4 +5,4 @@ * 2.0. */ -export * from './use_cloud_posture_stats_api'; +export * from './use_compliance_dashboard_data_api'; diff --git a/x-pack/plugins/cloud_security_posture/public/common/api/use_cis_kubernetes_integration.tsx b/x-pack/plugins/cloud_security_posture/public/common/api/use_cis_kubernetes_integration.tsx new file mode 100644 index 0000000000000..09b77a20835f7 --- /dev/null +++ b/x-pack/plugins/cloud_security_posture/public/common/api/use_cis_kubernetes_integration.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { useQuery } from 'react-query'; +import { + epmRouteService, + type GetInfoResponse, + type DefaultPackagesInstallationError, +} from '../../../../fleet/common'; +import { CIS_KUBERNETES_PACKAGE_NAME } from '../../../common/constants'; +import { useKibana } from '../hooks/use_kibana'; + +export const CIS_KUBERNETES_INTEGRATION_VERSION = '0.0.1'; + +/** + * This hook will find our cis integration and return its PackageInfo + * */ +export const useCisKubernetesIntegration = () => { + const { http } = useKibana().services; + + return useQuery(['integrations'], () => + http.get( + epmRouteService.getInfoPath(CIS_KUBERNETES_PACKAGE_NAME, CIS_KUBERNETES_INTEGRATION_VERSION), + { query: { experimental: true } } + ) + ); +}; diff --git a/x-pack/plugins/cloud_security_posture/public/common/api/use_cloud_posture_stats_api.ts b/x-pack/plugins/cloud_security_posture/public/common/api/use_compliance_dashboard_data_api.ts similarity index 71% rename from x-pack/plugins/cloud_security_posture/public/common/api/use_cloud_posture_stats_api.ts rename to x-pack/plugins/cloud_security_posture/public/common/api/use_compliance_dashboard_data_api.ts index c1cc4a61fd7ae..91bedbf83769d 100644 --- a/x-pack/plugins/cloud_security_posture/public/common/api/use_cloud_posture_stats_api.ts +++ b/x-pack/plugins/cloud_security_posture/public/common/api/use_compliance_dashboard_data_api.ts @@ -7,12 +7,12 @@ import { useQuery } from 'react-query'; import { useKibana } from '../../../../../../src/plugins/kibana_react/public'; -import { CloudPostureStats } from '../../../common/types'; +import { ComplianceDashboardData } from '../../../common/types'; import { STATS_ROUTE_PATH } from '../../../common/constants'; const getStatsKey = 'csp_dashboard_stats'; -export const useCloudPostureStatsApi = () => { +export const useComplianceDashboardDataApi = () => { const { http } = useKibana().services; - return useQuery([getStatsKey], () => http!.get(STATS_ROUTE_PATH)); + return useQuery([getStatsKey], () => http!.get(STATS_ROUTE_PATH)); }; diff --git a/x-pack/plugins/cloud_security_posture/public/components/chart_panel.tsx b/x-pack/plugins/cloud_security_posture/public/components/chart_panel.tsx index 2b0882d0916e6..54592880f47ff 100644 --- a/x-pack/plugins/cloud_security_posture/public/components/chart_panel.tsx +++ b/x-pack/plugins/cloud_security_posture/public/components/chart_panel.tsx @@ -19,8 +19,8 @@ import { CHART_PANEL_TEST_SUBJECTS } from './constants'; interface ChartPanelProps { title?: string; hasBorder?: boolean; - isLoading: boolean; - isError: boolean; + isLoading?: boolean; + isError?: boolean; } const Loading = () => ( diff --git a/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx b/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx new file mode 100644 index 0000000000000..ef097f224ab5f --- /dev/null +++ b/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React, { type ComponentProps } from 'react'; +import { render, screen } from '@testing-library/react'; +import Chance from 'chance'; +import { coreMock } from '../../../../../src/core/public/mocks'; +import { createNavigationItemFixture } from '../test/fixtures/navigation_item'; +import { createReactQueryResponse } from '../test/fixtures/react_query'; +import { TestProvider } from '../test/test_provider'; +import { CspPageTemplate, getSideNavItems, isCommonError } from './csp_page_template'; +import { LOADING, PACKAGE_NOT_INSTALLED_TEXT, DEFAULT_NO_DATA_TEXT } from './translations'; +import { useCisKubernetesIntegration } from '../common/api/use_cis_kubernetes_integration'; +import { UseQueryResult } from 'react-query'; + +const chance = new Chance(); + +// Synchronized to the error message in the formatted message in `csp_page_template.tsx` +const ERROR_LOADING_DATA_DEFAULT_MESSAGE = "We couldn't fetch your cloud security posture data"; +const packageNotInstalledUniqueTexts = [ + PACKAGE_NOT_INSTALLED_TEXT.PAGE_TITLE, + PACKAGE_NOT_INSTALLED_TEXT.DESCRIPTION, +]; + +jest.mock('../common/api/use_cis_kubernetes_integration'); + +describe('getSideNavItems', () => { + it('maps navigation items to side navigation items', () => { + const navigationItem = createNavigationItemFixture(); + const id = chance.word(); + const sideNavItems = getSideNavItems({ [id]: navigationItem }); + + expect(sideNavItems).toHaveLength(1); + expect(sideNavItems[0]).toMatchObject({ + id, + name: navigationItem.name, + renderItem: expect.any(Function), + }); + }); + + it('does not map disabled navigation items to side navigation items', () => { + const navigationItem = createNavigationItemFixture({ disabled: true }); + const id = chance.word(); + const sideNavItems = getSideNavItems({ [id]: navigationItem }); + expect(sideNavItems).toHaveLength(0); + }); +}); + +describe('', () => { + beforeEach(() => { + jest.resetAllMocks(); + // if package installation status is 'not_installed', CspPageTemplate will render a noDataConfig prompt + (useCisKubernetesIntegration as jest.Mock).mockImplementation(() => ({ + data: { item: { status: 'installed' } }, + })); + }); + + const renderCspPageTemplate = (props: ComponentProps = {}) => { + const mockCore = coreMock.createStart(); + + render( + + + + ); + }; + + it('renders children if integration is installed', () => { + const children = chance.sentence(); + renderCspPageTemplate({ children }); + + expect(screen.getByText(children)).toBeInTheDocument(); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); + + it('renders integrations installation prompt if integration is not installed', () => { + (useCisKubernetesIntegration as jest.Mock).mockImplementation(() => ({ + isSuccess: true, + data: { item: { status: 'not_installed' } }, + })); + + const children = chance.sentence(); + renderCspPageTemplate({ children }); + + Object.values(PACKAGE_NOT_INSTALLED_TEXT).forEach((text) => + expect(screen.getByText(text)).toBeInTheDocument() + ); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); + }); + + it('renders default loading text when query isLoading', () => { + const query = createReactQueryResponse({ + status: 'loading', + }) as unknown as UseQueryResult; + + const children = chance.sentence(); + renderCspPageTemplate({ children, query }); + + expect(screen.getByText(LOADING)).toBeInTheDocument(); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); + + it('renders default error texts when query isError', () => { + const error = chance.sentence(); + const message = chance.sentence(); + const statusCode = chance.integer(); + + const query = createReactQueryResponse({ + status: 'error', + error: { + body: { + error, + message, + statusCode, + }, + }, + }) as unknown as UseQueryResult; + + const children = chance.sentence(); + renderCspPageTemplate({ children, query }); + + [ERROR_LOADING_DATA_DEFAULT_MESSAGE, error, message, statusCode].forEach((text) => + expect(screen.getByText(text, { exact: false })).toBeInTheDocument() + ); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); + + it('prefers custom error render', () => { + const error = chance.sentence(); + const message = chance.sentence(); + const statusCode = chance.integer(); + + const query = createReactQueryResponse({ + status: 'error', + error: { + body: { + error, + message, + statusCode, + }, + }, + }) as unknown as UseQueryResult; + + const children = chance.sentence(); + renderCspPageTemplate({ + children, + query, + errorRender: (err) =>
{isCommonError(err) && err.body.message}
, + }); + + expect(screen.getByText(message)).toBeInTheDocument(); + [ERROR_LOADING_DATA_DEFAULT_MESSAGE, error, statusCode].forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); + + it('prefers custom loading render', () => { + const loading = chance.sentence(); + + const query = createReactQueryResponse({ + status: 'loading', + }) as unknown as UseQueryResult; + + const children = chance.sentence(); + renderCspPageTemplate({ + children, + query, + loadingRender: () =>
{loading}
, + }); + + expect(screen.getByText(loading)).toBeInTheDocument(); + expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); + + it('renders noDataConfig prompt when query data is undefined', () => { + const query = createReactQueryResponse({ + status: 'success', + data: undefined, + }) as unknown as UseQueryResult; + + const children = chance.sentence(); + renderCspPageTemplate({ children, query }); + + expect(screen.getByText(DEFAULT_NO_DATA_TEXT.PAGE_TITLE)).toBeInTheDocument(); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); + + it('prefers custom noDataConfig prompt', () => { + const pageTitle = chance.sentence(); + const solution = chance.sentence(); + const docsLink = chance.sentence(); + + const query = createReactQueryResponse({ + status: 'success', + data: undefined, + }) as unknown as UseQueryResult; + + const children = chance.sentence(); + renderCspPageTemplate({ + children, + query, + noDataConfig: { pageTitle, solution, docsLink, actions: {} }, + }); + + expect(screen.getByText(pageTitle)).toBeInTheDocument(); + expect(screen.getByText(solution, { exact: false })).toBeInTheDocument(); + expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); + expect(screen.queryByText(children)).not.toBeInTheDocument(); + expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); + packageNotInstalledUniqueTexts.forEach((text) => + expect(screen.queryByText(text)).not.toBeInTheDocument() + ); + }); +}); diff --git a/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.tsx b/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.tsx new file mode 100644 index 0000000000000..8d1d96f2cb9f7 --- /dev/null +++ b/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React from 'react'; +import type { UseQueryResult } from 'react-query'; +import { NavLink } from 'react-router-dom'; +import { EuiEmptyPrompt, EuiErrorBoundary, EuiTitle } from '@elastic/eui'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { + KibanaPageTemplate, + type KibanaPageTemplateProps, +} from '../../../../../src/plugins/kibana_react/public'; +import { allNavigationItems } from '../common/navigation/constants'; +import type { CspNavigationItem } from '../common/navigation/types'; +import { CLOUD_SECURITY_POSTURE } from '../common/translations'; +import { CspLoadingState } from './csp_loading_state'; +import { DEFAULT_NO_DATA_TEXT, LOADING, PACKAGE_NOT_INSTALLED_TEXT } from './translations'; +import { useCisKubernetesIntegration } from '../common/api/use_cis_kubernetes_integration'; +import { useCISIntegrationLink } from '../common/navigation/use_navigate_to_cis_integration'; + +export interface CommonError { + body: { + error: string; + message: string; + statusCode: number; + }; +} + +export const isCommonError = (x: any): x is CommonError => { + if (!('body' in x)) return false; + + const { + body: { error, message, statusCode }, + } = x; + + return !!(error && message && statusCode); +}; + +const activeItemStyle = { fontWeight: 700 }; + +export const getSideNavItems = ( + navigationItems: Record +): NonNullable['items'] => + Object.entries(navigationItems) + .filter(([_, navigationItem]) => !navigationItem.disabled) + .map(([id, navigationItem]) => ({ + id, + name: navigationItem.name, + renderItem: () => ( + + {navigationItem.name} + + ), + })); + +const DEFAULT_PAGE_PROPS: KibanaPageTemplateProps = { + solutionNav: { + name: CLOUD_SECURITY_POSTURE, + items: getSideNavItems({ + dashboard: allNavigationItems.dashboard, + findings: allNavigationItems.findings, + benchmark: allNavigationItems.benchmarks, + }), + }, + restrictWidth: false, +}; + +export const DEFAULT_NO_DATA_CONFIG: KibanaPageTemplateProps['noDataConfig'] = { + pageTitle: DEFAULT_NO_DATA_TEXT.PAGE_TITLE, + solution: DEFAULT_NO_DATA_TEXT.SOLUTION, + // TODO: Add real docs link once we have it + docsLink: 'https://www.elastic.co/guide/index.html', + logo: 'logoSecurity', + actions: {}, +}; + +const getPackageNotInstalledNoDataConfig = ( + cisIntegrationLink: string +): KibanaPageTemplateProps['noDataConfig'] => ({ + pageTitle: PACKAGE_NOT_INSTALLED_TEXT.PAGE_TITLE, + solution: PACKAGE_NOT_INSTALLED_TEXT.SOLUTION, + // TODO: Add real docs link once we have it + docsLink: 'https://www.elastic.co/guide/index.html', + logo: 'logoSecurity', + actions: { + elasticAgent: { + href: cisIntegrationLink, + title: PACKAGE_NOT_INSTALLED_TEXT.BUTTON_TITLE, + description: PACKAGE_NOT_INSTALLED_TEXT.DESCRIPTION, + }, + }, +}); + +const DefaultLoading = () => {LOADING}; + +const DefaultError = (error: unknown) => ( + + +

+ +

+
+ {isCommonError(error) && ( + <> + +
+ +
+
+ +
+ +
+
+ + )} + + } + /> +); + +export const CspPageTemplate = ({ + query, + children, + loadingRender = DefaultLoading, + errorRender = DefaultError, + ...kibanaPageTemplateProps +}: KibanaPageTemplateProps & { + loadingRender?: () => React.ReactNode; + errorRender?: (error: TError) => React.ReactNode; + query?: UseQueryResult; +}) => { + const cisKubernetesPackageInfo = useCisKubernetesIntegration(); + const cisIntegrationLink = useCISIntegrationLink(); + + const getNoDataConfig = (): KibanaPageTemplateProps['noDataConfig'] => { + if ( + cisKubernetesPackageInfo?.isSuccess && + cisKubernetesPackageInfo.data.item.status === 'not_installed' + ) { + return getPackageNotInstalledNoDataConfig(cisIntegrationLink); + } + + // when query was successful, but data is undefined + if (query?.isSuccess && !query?.data) { + return kibanaPageTemplateProps.noDataConfig || DEFAULT_NO_DATA_CONFIG; + } + + // when the consumer didn't pass a query, most likely to handle the render on his own + if (!query) return kibanaPageTemplateProps.noDataConfig; + }; + + const getTemplate = (): KibanaPageTemplateProps['template'] => { + if (query?.isLoading || query?.isError) return 'centeredContent'; + + return kibanaPageTemplateProps.template || 'default'; + }; + + const render = () => { + if (query?.isLoading) return loadingRender(); + if (query?.isError) return errorRender(query.error); + if (query?.isSuccess) return children; + + return children; + }; + + return ( + + + {cisKubernetesPackageInfo?.data?.item.status === 'installed' && render()} + + + ); +}; diff --git a/x-pack/plugins/cloud_security_posture/public/components/page_template.test.tsx b/x-pack/plugins/cloud_security_posture/public/components/page_template.test.tsx deleted file mode 100644 index 1c367cd5c57f0..0000000000000 --- a/x-pack/plugins/cloud_security_posture/public/components/page_template.test.tsx +++ /dev/null @@ -1,158 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import React, { type ComponentProps } from 'react'; -import { render, screen } from '@testing-library/react'; -import Chance from 'chance'; -import { coreMock } from '../../../../../src/core/public/mocks'; -import { createStubDataView } from '../../../../../src/plugins/data_views/public/data_views/data_view.stub'; -import { CSP_KUBEBEAT_INDEX_PATTERN } from '../../common/constants'; -import { useKubebeatDataView } from '../common/api/use_kubebeat_data_view'; -import { createNavigationItemFixture } from '../test/fixtures/navigation_item'; -import { createReactQueryResponse } from '../test/fixtures/react_query'; -import { TestProvider } from '../test/test_provider'; -import { CspPageTemplate, getSideNavItems } from './page_template'; -import { - LOADING, - NO_DATA_CONFIG_BUTTON, - NO_DATA_CONFIG_DESCRIPTION, - NO_DATA_CONFIG_TITLE, -} from './translations'; - -const chance = new Chance(); - -const BLANK_PAGE_GRAPHIC_TEXTS = [ - NO_DATA_CONFIG_TITLE, - NO_DATA_CONFIG_DESCRIPTION, - NO_DATA_CONFIG_BUTTON, -]; - -// Synchronized to the error message in the formatted message in `page_template.tsx` -const ERROR_LOADING_DATA_DEFAULT_MESSAGE = "We couldn't fetch your cloud security posture data"; - -jest.mock('../common/api/use_kubebeat_data_view'); - -describe('getSideNavItems', () => { - it('maps navigation items to side navigation items', () => { - const navigationItem = createNavigationItemFixture(); - const id = chance.word(); - const sideNavItems = getSideNavItems({ [id]: navigationItem }); - - expect(sideNavItems).toHaveLength(1); - expect(sideNavItems[0]).toMatchObject({ - id, - name: navigationItem.name, - renderItem: expect.any(Function), - }); - }); - - it('does not map disabled navigation items to side navigation items', () => { - const navigationItem = createNavigationItemFixture({ disabled: true }); - const id = chance.word(); - const sideNavItems = getSideNavItems({ [id]: navigationItem }); - expect(sideNavItems).toHaveLength(0); - }); -}); - -describe('', () => { - beforeEach(() => { - jest.resetAllMocks(); - }); - - const renderCspPageTemplate = (props: ComponentProps = {}) => { - const mockCore = coreMock.createStart(); - - render( - - - - ); - }; - - it('renders children when data view is found', () => { - (useKubebeatDataView as jest.Mock).mockImplementation(() => - createReactQueryResponse({ - status: 'success', - data: createStubDataView({ - spec: { - id: CSP_KUBEBEAT_INDEX_PATTERN, - }, - }), - }) - ); - - const children = chance.sentence(); - renderCspPageTemplate({ children }); - - expect(screen.getByText(children)).toBeInTheDocument(); - expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); - expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); - BLANK_PAGE_GRAPHIC_TEXTS.forEach((blankPageGraphicText) => - expect(screen.queryByText(blankPageGraphicText)).not.toBeInTheDocument() - ); - }); - - it('renders loading text when data view is loading', () => { - (useKubebeatDataView as jest.Mock).mockImplementation(() => - createReactQueryResponse({ status: 'loading' }) - ); - - const children = chance.sentence(); - renderCspPageTemplate({ children }); - - expect(screen.getByText(LOADING)).toBeInTheDocument(); - expect(screen.queryByText(children)).not.toBeInTheDocument(); - expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); - BLANK_PAGE_GRAPHIC_TEXTS.forEach((blankPageGraphicText) => - expect(screen.queryByText(blankPageGraphicText)).not.toBeInTheDocument() - ); - }); - - it('renders an error view when data view fetching has an error', () => { - (useKubebeatDataView as jest.Mock).mockImplementation(() => - createReactQueryResponse({ status: 'error', error: new Error('') }) - ); - - const children = chance.sentence(); - renderCspPageTemplate({ children }); - - expect(screen.getByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).toBeInTheDocument(); - expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); - expect(screen.queryByText(children)).not.toBeInTheDocument(); - BLANK_PAGE_GRAPHIC_TEXTS.forEach((blankPageGraphicText) => - expect(screen.queryByText(blankPageGraphicText)).not.toBeInTheDocument() - ); - }); - - it('renders the blank page graphic when data view is missing', () => { - (useKubebeatDataView as jest.Mock).mockImplementation(() => - createReactQueryResponse({ - status: 'success', - data: undefined, - }) - ); - - const children = chance.sentence(); - renderCspPageTemplate({ children }); - - BLANK_PAGE_GRAPHIC_TEXTS.forEach((text) => expect(screen.getByText(text)).toBeInTheDocument()); - expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); - expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); - expect(screen.queryByText(children)).not.toBeInTheDocument(); - }); -}); diff --git a/x-pack/plugins/cloud_security_posture/public/components/page_template.tsx b/x-pack/plugins/cloud_security_posture/public/components/page_template.tsx deleted file mode 100644 index 45cae3f996e36..0000000000000 --- a/x-pack/plugins/cloud_security_posture/public/components/page_template.tsx +++ /dev/null @@ -1,117 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import React from 'react'; -import { NavLink } from 'react-router-dom'; -import { EuiEmptyPrompt, EuiErrorBoundary, EuiTitle } from '@elastic/eui'; -import { FormattedMessage } from '@kbn/i18n-react'; -import { - KibanaPageTemplate, - type KibanaPageTemplateProps, -} from '../../../../../src/plugins/kibana_react/public'; -import { useKubebeatDataView } from '../common/api/use_kubebeat_data_view'; -import { allNavigationItems } from '../common/navigation/constants'; -import type { CspNavigationItem } from '../common/navigation/types'; -import { useCISIntegrationLink } from '../common/navigation/use_navigate_to_cis_integration'; -import { CLOUD_SECURITY_POSTURE } from '../common/translations'; -import { CspLoadingState } from './csp_loading_state'; -import { - LOADING, - NO_DATA_CONFIG_BUTTON, - NO_DATA_CONFIG_DESCRIPTION, - NO_DATA_CONFIG_SOLUTION_NAME, - NO_DATA_CONFIG_TITLE, -} from './translations'; - -const activeItemStyle = { fontWeight: 700 }; - -export const getSideNavItems = ( - navigationItems: Record -): NonNullable['items'] => - Object.entries(navigationItems) - .filter(([_, navigationItem]) => !navigationItem.disabled) - .map(([id, navigationItem]) => ({ - id, - name: navigationItem.name, - renderItem: () => ( - - {navigationItem.name} - - ), - })); - -const DEFAULT_PROPS: KibanaPageTemplateProps = { - solutionNav: { - name: CLOUD_SECURITY_POSTURE, - items: getSideNavItems({ - dashboard: allNavigationItems.dashboard, - findings: allNavigationItems.findings, - benchmark: allNavigationItems.benchmarks, - }), - }, - restrictWidth: false, -}; - -const getNoDataConfig = (cisIntegrationLink: string): KibanaPageTemplateProps['noDataConfig'] => ({ - pageTitle: NO_DATA_CONFIG_TITLE, - solution: NO_DATA_CONFIG_SOLUTION_NAME, - // TODO: Add real docs link once we have it - docsLink: 'https://www.elastic.co/guide/index.html', - logo: 'logoSecurity', - actions: { - elasticAgent: { - href: cisIntegrationLink, - title: NO_DATA_CONFIG_BUTTON, - description: NO_DATA_CONFIG_DESCRIPTION, - }, - }, -}); - -export const CspPageTemplate: React.FC = ({ children, ...props }) => { - // TODO: Consider using more sophisticated logic to find out if our integration is installed - const kubeBeatQuery = useKubebeatDataView(); - const cisIntegrationLink = useCISIntegrationLink(); - - let noDataConfig: KibanaPageTemplateProps['noDataConfig']; - if (kubeBeatQuery.status === 'success' && !kubeBeatQuery.data) { - noDataConfig = getNoDataConfig(cisIntegrationLink); - } - - let template: KibanaPageTemplateProps['template'] = 'default'; - if (kubeBeatQuery.status === 'error' || kubeBeatQuery.status === 'loading') { - template = 'centeredContent'; - } - - return ( - - - {kubeBeatQuery.status === 'loading' && {LOADING}} - {kubeBeatQuery.status === 'error' && ( - -

- -

- - } - /> - )} - {kubeBeatQuery.status === 'success' && children} -
-
- ); -}; diff --git a/x-pack/plugins/cloud_security_posture/public/components/translations.ts b/x-pack/plugins/cloud_security_posture/public/components/translations.ts index b203d0365a28f..facbbcc3176da 100644 --- a/x-pack/plugins/cloud_security_posture/public/components/translations.ts +++ b/x-pack/plugins/cloud_security_posture/public/components/translations.ts @@ -40,28 +40,27 @@ export const CSP_EVALUATION_BADGE_PASSED = i18n.translate( } ); -export const NO_DATA_CONFIG_TITLE = i18n.translate('xpack.csp.pageTemplate.noDataConfigTitle', { - defaultMessage: 'Understand your cloud security posture', -}); - -export const NO_DATA_CONFIG_SOLUTION_NAME = i18n.translate( - 'xpack.csp.pageTemplate.noDataConfig.solutionNameLabel', - { +export const PACKAGE_NOT_INSTALLED_TEXT = { + PAGE_TITLE: i18n.translate('xpack.csp.cspPageTemplate.packageNotInstalled.pageTitle', { + defaultMessage: 'Install Integration to get started', + }), + SOLUTION: i18n.translate('xpack.csp.cspPageTemplate.packageNotInstalled.solutionNameLabel', { defaultMessage: 'Cloud Security Posture', - } -); - -export const NO_DATA_CONFIG_DESCRIPTION = i18n.translate( - 'xpack.csp.pageTemplate.noDataConfigDescription', - { + }), + BUTTON_TITLE: i18n.translate('xpack.csp.cspPageTemplate.packageNotInstalled.buttonLabel', { + defaultMessage: 'Add a CIS integration', + }), + DESCRIPTION: i18n.translate('xpack.csp.cspPageTemplate.packageNotInstalled.description', { defaultMessage: 'Use our CIS Kubernetes Benchmark integration to measure your Kubernetes cluster setup against the CIS recommendations.', - } -); + }), +}; -export const NO_DATA_CONFIG_BUTTON = i18n.translate( - 'xpack.csp.pageTemplate.noDataConfigButtonLabel', - { - defaultMessage: 'Add a CIS integration', - } -); +export const DEFAULT_NO_DATA_TEXT = { + PAGE_TITLE: i18n.translate('xpack.csp.cspPageTemplate.defaultNoDataConfig.pageTitle', { + defaultMessage: 'No data found', + }), + SOLUTION: i18n.translate('xpack.csp.cspPageTemplate.defaultNoDataConfig.solutionNameLabel', { + defaultMessage: 'Cloud Security Posture', + }), +}; diff --git a/x-pack/plugins/cloud_security_posture/public/components/unknown_route.tsx b/x-pack/plugins/cloud_security_posture/public/components/unknown_route.tsx index 248d598302b9f..90a469ba2dd48 100644 --- a/x-pack/plugins/cloud_security_posture/public/components/unknown_route.tsx +++ b/x-pack/plugins/cloud_security_posture/public/components/unknown_route.tsx @@ -7,7 +7,7 @@ import React from 'react'; import { EuiEmptyPrompt } from '@elastic/eui'; -import { CspPageTemplate } from './page_template'; +import { CspPageTemplate } from './csp_page_template'; import * as TEXT from './translations'; export const UnknownRoute = React.memo(() => ( diff --git a/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.test.tsx b/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.test.tsx index 983c58f2d5d7c..918294794e9d2 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.test.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.test.tsx @@ -21,13 +21,20 @@ import { TABLE_COLUMN_HEADERS, } from './translations'; import { useCspBenchmarkIntegrations } from './use_csp_benchmark_integrations'; +import { useCisKubernetesIntegration } from '../../common/api/use_cis_kubernetes_integration'; jest.mock('./use_csp_benchmark_integrations'); jest.mock('../../common/api/use_kubebeat_data_view'); +jest.mock('../../common/api/use_cis_kubernetes_integration'); describe('', () => { beforeEach(() => { jest.resetAllMocks(); + + // if package installation status is 'not_installed', CspPageTemplate will render a noDataConfig prompt + (useCisKubernetesIntegration as jest.Mock).mockImplementation(() => ({ + data: { item: { status: 'installed' } }, + })); // Required for the page template to render the benchmarks page (useKubebeatDataView as jest.Mock).mockImplementation(() => createReactQueryResponse({ diff --git a/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.tsx b/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.tsx index e7f8991eedf8f..e303c619a8d01 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/benchmarks/benchmarks.tsx @@ -4,6 +4,8 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ + +import React, { useState } from 'react'; import { EuiFieldSearch, EuiFieldSearchProps, @@ -15,13 +17,12 @@ import { EuiTextColor, EuiText, } from '@elastic/eui'; -import React, { useState } from 'react'; import { FormattedMessage } from '@kbn/i18n-react'; import useDebounce from 'react-use/lib/useDebounce'; import { allNavigationItems } from '../../common/navigation/constants'; import { useCspBreadcrumbs } from '../../common/navigation/use_csp_breadcrumbs'; import { useCISIntegrationLink } from '../../common/navigation/use_navigate_to_cis_integration'; -import { CspPageTemplate } from '../../components/page_template'; +import { CspPageTemplate } from '../../components/csp_page_template'; import { BenchmarksTable } from './benchmarks_table'; import { ADD_A_CIS_INTEGRATION, BENCHMARK_INTEGRATIONS } from './translations'; import { diff --git a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_charts/risks_table.tsx b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_charts/risks_table.tsx index 1e355b3f3c82f..086fea34a2c50 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_charts/risks_table.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_charts/risks_table.tsx @@ -14,7 +14,7 @@ import { EuiLink, EuiText, } from '@elastic/eui'; -import { CloudPostureStats, ResourceType } from '../../../../common/types'; +import { ComplianceDashboardData, ResourceType } from '../../../../common/types'; import { CompactFormattedNumber } from '../../../components/compact_formatted_number'; import * as TEXT from '../translations'; import { INTERNAL_FEATURE_FLAGS } from '../../../../common/constants'; @@ -59,14 +59,14 @@ const mockData = [ ]; export interface RisksTableProps { - data: CloudPostureStats['resourcesTypes']; + data: ComplianceDashboardData['resourcesTypes']; maxItems: number; onCellClick: (resourceTypeName: string) => void; onViewAllClick: () => void; } export const getTopRisks = ( - resourcesTypes: CloudPostureStats['resourcesTypes'], + resourcesTypes: ComplianceDashboardData['resourcesTypes'], maxItems: number ) => { const filtered = resourcesTypes.filter((x) => x.totalFailed > 0); diff --git a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_dashboard.tsx b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_dashboard.tsx index 07b5294a8d4ae..ff564744384e0 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_dashboard.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/compliance_dashboard.tsx @@ -6,40 +6,51 @@ */ import React from 'react'; -import { EuiSpacer } from '@elastic/eui'; +import { EuiSpacer, EuiIcon } from '@elastic/eui'; import { allNavigationItems } from '../../common/navigation/constants'; import { useCspBreadcrumbs } from '../../common/navigation/use_csp_breadcrumbs'; import { SummarySection } from './dashboard_sections/summary_section'; import { BenchmarksSection } from './dashboard_sections/benchmarks_section'; -import { useCloudPostureStatsApi } from '../../common/api'; -import { CspPageTemplate } from '../../components/page_template'; -import * as TEXT from './translations'; +import { useComplianceDashboardDataApi } from '../../common/api'; +import { CspPageTemplate } from '../../components/csp_page_template'; +import { type KibanaPageTemplateProps } from '../../../../../../src/plugins/kibana_react/public'; +import { CLOUD_POSTURE, NO_DATA_CONFIG_TEXT } from './translations'; -const CompliancePage = () => { - const getStats = useCloudPostureStatsApi(); - if (getStats.isLoading) return null; - - return ( - <> - - - - - - ); -}; +const getNoDataConfig = (onClick: () => void): KibanaPageTemplateProps['noDataConfig'] => ({ + pageTitle: NO_DATA_CONFIG_TEXT.PAGE_TITLE, + solution: NO_DATA_CONFIG_TEXT.SOLUTION, + // TODO: Add real docs link once we have it + docsLink: 'https://www.elastic.co/guide/index.html', + logo: 'logoSecurity', + actions: { + dashboardNoDataCard: { + icon: , + onClick, + title: NO_DATA_CONFIG_TEXT.BUTTON_TITLE, + description: NO_DATA_CONFIG_TEXT.DESCRIPTION, + }, + }, +}); export const ComplianceDashboard = () => { + const getDashboardDataQuery = useComplianceDashboardDataApi(); useCspBreadcrumbs([allNavigationItems.dashboard]); return ( - + {getDashboardDataQuery.data && ( + <> + + + + + + )} ); }; diff --git a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/dashboard_sections/benchmarks_section.tsx b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/dashboard_sections/benchmarks_section.tsx index 0fc8f0d3d0bef..565811bca7ee7 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/dashboard_sections/benchmarks_section.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/dashboard_sections/benchmarks_section.tsx @@ -17,34 +17,25 @@ import { useEuiTheme, } from '@elastic/eui'; import moment from 'moment'; -import { EuiIconType } from '@elastic/eui/src/components/icon/icon'; import { PartitionElementEvent } from '@elastic/charts'; import { EuiThemeComputed } from '@elastic/eui/src/services/theme/types'; import { CloudPostureScoreChart } from '../compliance_charts/cloud_posture_score_chart'; -import { useCloudPostureStatsApi } from '../../../common/api/use_cloud_posture_stats_api'; import { ChartPanel } from '../../../components/chart_panel'; import * as TEXT from '../translations'; -import { Evaluation } from '../../../../common/types'; +import type { ComplianceDashboardData, Evaluation } from '../../../../common/types'; import { RisksTable } from '../compliance_charts/risks_table'; import { INTERNAL_FEATURE_FLAGS, RULE_FAILED } from '../../../../common/constants'; import { useNavigateFindings } from '../../../common/hooks/use_navigate_findings'; -const logoMap: ReadonlyMap = new Map([['CIS Kubernetes', 'logoKubernetes']]); - -const getBenchmarkLogo = (benchmarkName: string): EuiIconType => { - return logoMap.get(benchmarkName) ?? 'logoElastic'; -}; - -const mockClusterId = '2468540'; - const cardHeight = 300; -export const BenchmarksSection = () => { +export const BenchmarksSection = ({ + complianceData, +}: { + complianceData: ComplianceDashboardData; +}) => { const { euiTheme } = useEuiTheme(); const navToFindings = useNavigateFindings(); - const getStats = useCloudPostureStatsApi(); - const clusters = getStats.isSuccess && getStats.data.clusters; - if (!clusters) return null; const handleElementClick = (clusterId: string, elements: PartitionElementEvent[]) => { const [element] = elements; @@ -68,7 +59,7 @@ export const BenchmarksSection = () => { return ( <> - {clusters.map((cluster) => { + {complianceData.clusters.map((cluster) => { const shortId = cluster.meta.clusterId.slice(0, 6); return ( @@ -82,7 +73,7 @@ export const BenchmarksSection = () => {

{cluster.meta.benchmarkName}

-

{`Cluster ID ${shortId || mockClusterId}`}

+

{`Cluster ID ${shortId}`}

@@ -91,7 +82,8 @@ export const BenchmarksSection = () => { - + {/* TODO: change default k8s logo to use a getBenchmarkLogo function */} + {INTERNAL_FEATURE_FLAGS.showManageRulesMock && ( @@ -104,12 +96,7 @@ export const BenchmarksSection = () => { grow={4} style={{ borderRight: `1px solid ${euiTheme.colors.lightShade}` }} > - + { - + { +export const SummarySection = ({ complianceData }: { complianceData: ComplianceDashboardData }) => { const navToFindings = useNavigateFindings(); - const getStats = useCloudPostureStatsApi(); - if (!getStats.isSuccess) return null; const handleElementClick = (elements: PartitionElementEvent[]) => { const [element] = elements; @@ -49,22 +46,18 @@ export const SummarySection = () => { return ( - + - + { - + diff --git a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/translations.ts b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/translations.ts index 87193ef67fa3a..0e87681037c66 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/translations.ts +++ b/x-pack/plugins/cloud_security_posture/public/pages/compliance_dashboard/translations.ts @@ -82,3 +82,18 @@ export const RESOURCE_TYPE = i18n.translate('xpack.csp.resource_type', { export const FINDINGS = i18n.translate('xpack.csp.findings', { defaultMessage: 'Findings', }); + +export const NO_DATA_CONFIG_TEXT = { + PAGE_TITLE: i18n.translate('xpack.csp.complianceDashboard.noDataConfig.pageTitle', { + defaultMessage: 'Cloud Security Compliance Dashboard', + }), + SOLUTION: i18n.translate('xpack.csp.complianceDashboard.noDataConfig.solutionNameLabel', { + defaultMessage: 'Cloud Security Posture', + }), + BUTTON_TITLE: i18n.translate('xpack.csp.complianceDashboard.noDataConfig.actionTitle', { + defaultMessage: 'Try Again', + }), + DESCRIPTION: i18n.translate('xpack.csp.complianceDashboard.noDataConfig.actionDescription', { + defaultMessage: 'You can try to refetch your data', + }), +}; diff --git a/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.test.tsx b/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.test.tsx index 54f1ecf9f31ed..1094d5fa847de 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.test.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.test.tsx @@ -17,9 +17,11 @@ import { import { createStubDataView } from '../../../../../../src/plugins/data_views/public/data_views/data_view.stub'; import { CSP_KUBEBEAT_INDEX_PATTERN } from '../../../common/constants'; import * as TEST_SUBJECTS from './test_subjects'; +import { useCisKubernetesIntegration } from '../../common/api/use_cis_kubernetes_integration'; import type { DataView } from '../../../../../../src/plugins/data/common'; jest.mock('../../common/api/use_kubebeat_data_view'); +jest.mock('../../common/api/use_cis_kubernetes_integration'); beforeEach(() => { jest.restoreAllMocks(); @@ -36,6 +38,9 @@ describe('', () => { const data = dataPluginMock.createStartContract(); const source = await data.search.searchSource.create(); + (useCisKubernetesIntegration as jest.Mock).mockImplementation(() => ({ + data: { item: { status: 'installed' } }, + })); (source.fetch$ as jest.Mock).mockReturnValue({ toPromise: () => Promise.resolve({ rawResponse: { hits: { hits: [] } } }), }); diff --git a/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.tsx b/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.tsx index 6ed043361b44f..fba8fc37f54d1 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/findings/findings.tsx @@ -10,7 +10,7 @@ import { useKubebeatDataView } from '../../common/api/use_kubebeat_data_view'; import { allNavigationItems } from '../../common/navigation/constants'; import { useCspBreadcrumbs } from '../../common/navigation/use_csp_breadcrumbs'; import { FindingsContainer } from './findings_container'; -import { CspPageTemplate } from '../../components/page_template'; +import { CspPageTemplate } from '../../components/csp_page_template'; import { FINDINGS } from './translations'; const pageHeader: EuiPageHeaderProps = { @@ -18,15 +18,12 @@ const pageHeader: EuiPageHeaderProps = { }; export const Findings = () => { - const dataView = useKubebeatDataView(); + const dataViewQuery = useKubebeatDataView(); useCspBreadcrumbs([allNavigationItems.findings]); return ( - // `CspPageTemplate` takes care of loading and error states for the kubebeat data view, no need to handle them here - - {dataView.status === 'success' && dataView.data && ( - - )} + + {dataViewQuery.data && } ); }; diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/index.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/index.tsx index bcfc06e8e16a5..288f9e2f30c01 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/index.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/index.tsx @@ -4,19 +4,19 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ + import React, { useMemo } from 'react'; import { RouteComponentProps } from 'react-router-dom'; import { EuiTextColor, EuiEmptyPrompt } from '@elastic/eui'; import * as t from 'io-ts'; -import { CspPageTemplate } from '../../components/page_template'; import { RulesContainer, type PageUrlParams } from './rules_container'; import { allNavigationItems } from '../../common/navigation/constants'; import { useCspBreadcrumbs } from '../../common/navigation/use_csp_breadcrumbs'; import type { KibanaPageTemplateProps } from '../../../../../../src/plugins/kibana_react/public'; -import { CspLoadingState } from '../../components/csp_loading_state'; import { CspNavigationItem } from '../../common/navigation/types'; import { extractErrorMessage } from '../../../common/utils/helpers'; import { useCspIntegration } from './use_csp_integration'; +import { CspPageTemplate } from '../../components/csp_page_template'; const getRulesBreadcrumbs = (name?: string): CspNavigationItem[] => [allNavigationItems.benchmarks, { ...allNavigationItems.rules, name }].filter( @@ -35,7 +35,6 @@ export const Rules = ({ match: { params } }: RouteComponentProps) const pageProps: KibanaPageTemplateProps = useMemo( () => ({ - template: integrationInfo.status !== 'success' ? 'centeredContent' : undefined, pageHeader: { bottomBorder: false, // TODO: border still shows. pageTitle: 'Rules', @@ -46,16 +45,16 @@ export const Rules = ({ match: { params } }: RouteComponentProps) ), }, }), - [integrationInfo.data, integrationInfo.status] + [integrationInfo.data] ); return ( - + } + > {integrationInfo.status === 'success' && } - {integrationInfo.status === 'error' && ( - - )} - {integrationInfo.status === 'loading' && } ); }; diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules.test.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules.test.tsx index aaf7bdc557e21..bf5badfca1d95 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules.test.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules.test.tsx @@ -15,10 +15,12 @@ import { type RouteComponentProps } from 'react-router-dom'; import { cspLoadingStateTestId } from '../../components/csp_loading_state'; import type { PageUrlParams } from './rules_container'; import * as TEST_SUBJECTS from './test_subjects'; +import { useCisKubernetesIntegration } from '../../common/api/use_cis_kubernetes_integration'; jest.mock('./use_csp_integration', () => ({ useCspIntegration: jest.fn(), })); +jest.mock('../../common/api/use_cis_kubernetes_integration'); const queryClient = new QueryClient({ defaultOptions: { @@ -43,6 +45,9 @@ describe('', () => { beforeEach(() => { queryClient.clear(); jest.clearAllMocks(); + (useCisKubernetesIntegration as jest.Mock).mockImplementation(() => ({ + data: { item: { status: 'installed' } }, + })); }); it('calls API with URL params', async () => { @@ -63,6 +68,7 @@ describe('', () => { const Component = getTestComponent({ packagePolicyId: '1', policyId: '2' }); const request = { status: 'error', + isError: true, data: null, error: new Error('some error message'), }; @@ -78,6 +84,7 @@ describe('', () => { const Component = getTestComponent({ packagePolicyId: '21', policyId: '22' }); const request = { status: 'loading', + isLoading: true, }; (useCspIntegration as jest.Mock).mockReturnValue(request); diff --git a/x-pack/plugins/cloud_security_posture/public/test/fixtures/react_query.ts b/x-pack/plugins/cloud_security_posture/public/test/fixtures/react_query.ts index 2e6eeb5addb0a..201a8d85b4278 100644 --- a/x-pack/plugins/cloud_security_posture/public/test/fixtures/react_query.ts +++ b/x-pack/plugins/cloud_security_posture/public/test/fixtures/react_query.ts @@ -22,11 +22,15 @@ export const createReactQueryResponse = ({ data = undefined, }: CreateReactQueryResponseInput = {}): Partial> => { if (status === 'success') { - return { status, data }; + return { status, data, isSuccess: true, isLoading: false, isError: false }; } if (status === 'error') { - return { status, error }; + return { status, error, isSuccess: false, isLoading: false, isError: true }; + } + + if (status === 'loading') { + return { status, data: undefined, isSuccess: false, isLoading: true, isError: false }; } return { status }; diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/compliance_dashboard.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/compliance_dashboard.ts index e414dab92606a..154c2d58cd330 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/compliance_dashboard.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/compliance_dashboard.ts @@ -13,7 +13,7 @@ import type { QueryDslQueryContainer, SearchRequest, } from '@elastic/elasticsearch/lib/api/types'; -import type { CloudPostureStats } from '../../../common/types'; +import type { ComplianceDashboardData } from '../../../common/types'; import { CSP_KUBEBEAT_INDEX_PATTERN, STATS_ROUTE_PATH } from '../../../common/constants'; import { CspAppContext } from '../../plugin'; import { getResourcesTypes } from './get_resources_types'; @@ -102,7 +102,7 @@ export const defineGetComplianceDashboardRoute = ( getClusters(esClient, query), ]); - const body: CloudPostureStats = { + const body: ComplianceDashboardData = { stats, resourcesTypes, clusters, diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.test.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.test.ts index df45e7fb8e737..1630d4fe3537f 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.test.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.test.ts @@ -51,7 +51,7 @@ const mockClusterBuckets: ClusterBucket[] = [ ]; describe('getClustersFromAggs', () => { - it('should return value matching CloudPostureStats["clusters"]', async () => { + it('should return value matching ComplianceDashboardData["clusters"]', async () => { const clusters = getClustersFromAggs(mockClusterBuckets); expect(clusters).toEqual([ { diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.ts index 04eecd67cc283..98171bf5ec332 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_clusters.ts @@ -11,7 +11,7 @@ import type { QueryDslQueryContainer, SearchRequest, } from '@elastic/elasticsearch/lib/api/types'; -import { CloudPostureStats } from '../../../common/types'; +import { ComplianceDashboardData } from '../../../common/types'; import { getResourceTypeFromAggs, resourceTypeAggQuery } from './get_resources_types'; import type { ResourceTypeQueryResult } from './get_resources_types'; import { CSP_KUBEBEAT_INDEX_PATTERN } from '../../../common/constants'; @@ -66,7 +66,9 @@ export const getClustersQuery = (query: QueryDslQueryContainer): SearchRequest = }, }); -export const getClustersFromAggs = (clusters: ClusterBucket[]): CloudPostureStats['clusters'] => +export const getClustersFromAggs = ( + clusters: ClusterBucket[] +): ComplianceDashboardData['clusters'] => clusters.map((cluster) => { // get cluster's meta data const benchmarks = cluster.benchmarks.buckets; @@ -101,7 +103,7 @@ export const getClustersFromAggs = (clusters: ClusterBucket[]): CloudPostureStat export const getClusters = async ( esClient: ElasticsearchClient, query: QueryDslQueryContainer -): Promise => { +): Promise => { const queryResult = await esClient.search(getClustersQuery(query), { meta: true, }); diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.test.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.test.ts index b01644fc3f45b..411290738f33e 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.test.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.test.ts @@ -31,7 +31,7 @@ const resourceTypeBuckets: ResourceTypeBucket[] = [ ]; describe('getResourceTypeFromAggs', () => { - it('should return value matching CloudPostureStats["resourcesTypes"]', async () => { + it('should return value matching ComplianceDashboardData["resourcesTypes"]', async () => { const resourceTypes = getResourceTypeFromAggs(resourceTypeBuckets); expect(resourceTypes).toEqual([ { diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.ts index 0fc6e4b00944a..8d31fb7a8e88d 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_resources_types.ts @@ -6,12 +6,12 @@ */ import { ElasticsearchClient } from 'kibana/server'; -import { +import type { AggregationsMultiBucketAggregateBase as Aggregation, QueryDslQueryContainer, SearchRequest, } from '@elastic/elasticsearch/lib/api/types'; -import { CloudPostureStats } from '../../../common/types'; +import type { ComplianceDashboardData } from '../../../common/types'; import { KeyDocCount } from './compliance_dashboard'; import { CSP_KUBEBEAT_INDEX_PATTERN } from '../../../common/constants'; @@ -53,7 +53,7 @@ export const getRisksEsQuery = (query: QueryDslQueryContainer): SearchRequest => export const getResourceTypeFromAggs = ( queryResult: ResourceTypeBucket[] -): CloudPostureStats['resourcesTypes'] => +): ComplianceDashboardData['resourcesTypes'] => queryResult.map((bucket) => ({ name: bucket.key, totalFindings: bucket.doc_count, @@ -64,7 +64,7 @@ export const getResourceTypeFromAggs = ( export const getResourcesTypes = async ( esClient: ElasticsearchClient, query: QueryDslQueryContainer -): Promise => { +): Promise => { const resourceTypesQueryResult = await esClient.search( getRisksEsQuery(query), { meta: true } diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.test.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.test.ts index 558fec85860ea..27404533afeb0 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.test.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.test.ts @@ -59,7 +59,7 @@ describe('getStatsFromFindingsEvaluationsAggs', () => { expect(score).toEqual(36.4); }); - it('should return value matching CloudPostureStats["stats"]', async () => { + it('should return value matching ComplianceDashboardData["stats"]', async () => { const stats = getStatsFromFindingsEvaluationsAggs(standardQueryResult); expect(stats).toEqual({ totalFailed: 30, diff --git a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.ts b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.ts index 8d5417de24c52..82d1dd9a5d49f 100644 --- a/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.ts +++ b/x-pack/plugins/cloud_security_posture/server/routes/compliance_dashboard/get_stats.ts @@ -6,9 +6,9 @@ */ import { ElasticsearchClient } from 'kibana/server'; -import { QueryDslQueryContainer, SearchRequest } from '@elastic/elasticsearch/lib/api/types'; +import type { QueryDslQueryContainer, SearchRequest } from '@elastic/elasticsearch/lib/api/types'; import { CSP_KUBEBEAT_INDEX_PATTERN } from '../../../common/constants'; -import { CloudPostureStats, Score } from '../../../common/types'; +import type { ComplianceDashboardData, Score } from '../../../common/types'; /** * @param value value is [0, 1] range @@ -44,7 +44,7 @@ export const getEvaluationsQuery = (query: QueryDslQueryContainer): SearchReques export const getStatsFromFindingsEvaluationsAggs = ( findingsEvaluationsAggs: FindingsEvaluationsQueryResult -): CloudPostureStats['stats'] => { +): ComplianceDashboardData['stats'] => { const failedFindings = findingsEvaluationsAggs.failed_findings.doc_count || 0; const passedFindings = findingsEvaluationsAggs.passed_findings.doc_count || 0; const totalFindings = failedFindings + passedFindings; @@ -62,7 +62,7 @@ export const getStatsFromFindingsEvaluationsAggs = ( export const getStats = async ( esClient: ElasticsearchClient, query: QueryDslQueryContainer -): Promise => { +): Promise => { const evaluationsQueryResult = await esClient.search( getEvaluationsQuery(query), { meta: true } From 43ad6e2597dfebe5055189c31a442f1ca11d7dd4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20S=C3=A1nchez?= Date: Tue, 29 Mar 2022 11:42:32 +0200 Subject: [PATCH 075/160] [Security solution] [Endpoint] Updates translations in policy details tab for blocklist and trusted applications (#128466) * Updates translations in policy details tab for blocklist and trusted apps * Fix wrong search placeholder on blocklist list page * Fix wrong blocklist translation key * Fixes more multilangs * Adds 'entry' word next to 'blocklist' for singular reference Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../pages/blocklist/view/blocklist.tsx | 3 ++ .../view/tabs/blocklists_translations.ts | 47 ++++++++++--------- .../pages/policy/view/tabs/policy_tabs.tsx | 6 +-- .../view/tabs/trusted_apps_translations.ts | 44 ++++++++--------- 4 files changed, 52 insertions(+), 48 deletions(-) diff --git a/x-pack/plugins/security_solution/public/management/pages/blocklist/view/blocklist.tsx b/x-pack/plugins/security_solution/public/management/pages/blocklist/view/blocklist.tsx index 75d4b22fe16a1..c4d4edb5e1331 100644 --- a/x-pack/plugins/security_solution/public/management/pages/blocklist/view/blocklist.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/blocklist/view/blocklist.tsx @@ -95,6 +95,9 @@ const BLOCKLIST_PAGE_LABELS: ArtifactListPageProps['labels'] = { 'xpack.securitySolution.blocklist.emptyStatePrimaryButtonLabel', { defaultMessage: 'Add blocklist' } ), + searchPlaceholderInfo: i18n.translate('xpack.securitySolution.blocklist.searchPlaceholderInfo', { + defaultMessage: 'Search on the fields below: name, description, value', + }), }; export const Blocklist = memo(() => { diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/blocklists_translations.ts b/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/blocklists_translations.ts index 9eb2d57a506b3..0bc32d35ea341 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/blocklists_translations.ts +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/blocklists_translations.ts @@ -12,20 +12,20 @@ export const POLICY_ARTIFACT_BLOCKLISTS_LABELS = Object.freeze({ deleteModalTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.list.removeDialog.title', { - defaultMessage: 'Remove blocklist from policy', + defaultMessage: 'Remove blocklist entry from policy', } ), deleteModalImpactInfo: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.list.removeDialog.messageCallout', { defaultMessage: - 'This blocklist will be removed only from this policy and can still be found and managed from the artifact page.', + 'This blocklist entry will be removed only from this policy and can still be found and managed from the artifact page.', } ), deleteModalErrorMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.list.removeDialog.errorToastTitle', { - defaultMessage: 'Error while attempting to remove blocklist', + defaultMessage: 'Error while attempting to remove blocklist entry', } ), flyoutWarningCalloutMessage: (maxNumber: number) => @@ -33,37 +33,37 @@ export const POLICY_ARTIFACT_BLOCKLISTS_LABELS = Object.freeze({ 'xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.searchWarning.text', { defaultMessage: - 'Only the first {maxNumber} blocklists are displayed. Please use the search bar to refine the results.', + 'Only the first {maxNumber} blocklist entries are displayed. Please use the search bar to refine the results.', values: { maxNumber }, } ), flyoutNoArtifactsToBeAssignedMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.noAssignable', { - defaultMessage: 'There are no blocklists that can be assigned to this policy.', + defaultMessage: 'There are no blocklist entries that can be assigned to this policy.', } ), flyoutTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.title', { - defaultMessage: 'Assign blocklists', + defaultMessage: 'Assign blocklist entries', } ), flyoutSubtitle: (policyName: string): string => i18n.translate('xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.subtitle', { - defaultMessage: 'Select blocklists to add to {policyName}', + defaultMessage: 'Select blocklist entries to add to {policyName}', values: { policyName }, }), flyoutSearchPlaceholder: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.search.label', { - defaultMessage: 'Search blocklists', + defaultMessage: 'Search blocklist entries', } ), flyoutErrorMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.toastError.text', { - defaultMessage: `An error occurred updating blocklists`, + defaultMessage: `An error occurred updating blocklist entry`, } ), flyoutSuccessMessageText: (updatedExceptions: ExceptionListItemSchema[]): string => @@ -71,56 +71,57 @@ export const POLICY_ARTIFACT_BLOCKLISTS_LABELS = Object.freeze({ ? i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.toastSuccess.textMultiples', { - defaultMessage: '{count} blocklists have been added to your list.', + defaultMessage: '{count} blocklist entries have been added to your list.', values: { count: updatedExceptions.length }, } ) : i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.flyout.toastSuccess.textSingle', { - defaultMessage: '"{name}" has been added to your blocklist list.', + defaultMessage: '"{name}" blocklist has been added to your list.', values: { name: updatedExceptions[0].name }, } ), emptyUnassignedTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.empty.unassigned.title', - { defaultMessage: 'No assigned blocklists' } + { defaultMessage: 'No assigned blocklist entries' } ), emptyUnassignedMessage: (policyName: string): string => i18n.translate('xpack.securitySolution.endpoint.policy.blocklists.empty.unassigned.content', { defaultMessage: - 'There are currently no blocklists assigned to {policyName}. Assign blocklists now or add and manage them on the blocklists page.', + 'There are currently no blocklist entries assigned to {policyName}. Assign blocklist entries now or add and manage them on the blocklist page.', values: { policyName }, }), emptyUnassignedPrimaryActionButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.empty.unassigned.primaryAction', { - defaultMessage: 'Assign blocklists', + defaultMessage: 'Assign blocklist entry', } ), emptyUnassignedSecondaryActionButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.empty.unassigned.secondaryAction', { - defaultMessage: 'Manage blocklists', + defaultMessage: 'Manage blocklist entries', } ), emptyUnexistingTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.empty.unexisting.title', - { defaultMessage: 'No blocklists exist' } + { defaultMessage: 'No blocklist entries exist' } ), emptyUnexistingMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.empty.unexisting.content', { - defaultMessage: 'There are currently no blocklists applied to your endpoints.', + defaultMessage: 'There are currently no blocklist entries applied to your endpoints.', } ), emptyUnexistingPrimaryActionButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.empty.unexisting.action', - { defaultMessage: 'Add blocklists' } + { defaultMessage: 'Add blocklist entry' } ), listTotalItemCountMessage: (totalItemsCount: number): string => i18n.translate('xpack.securitySolution.endpoint.policy.blocklists.list.totalItemCount', { - defaultMessage: 'Showing {totalItemsCount, plural, one {# blocklist} other {# blocklists}}', + defaultMessage: + 'Showing {totalItemsCount, plural, one {# blocklist entry} other {# blocklist entries}}', values: { totalItemsCount }, }), listRemoveActionNotAllowedMessage: i18n.translate( @@ -132,22 +133,22 @@ export const POLICY_ARTIFACT_BLOCKLISTS_LABELS = Object.freeze({ listSearchPlaceholderMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.list.search.placeholder', { - defaultMessage: `Search on the fields below: name, description, IP`, + defaultMessage: `Search on the fields below: name, description, value`, } ), layoutTitle: i18n.translate('xpack.securitySolution.endpoint.policy.blocklists.layout.title', { - defaultMessage: 'Assigned blocklists', + defaultMessage: 'Assigned blocklist entries', }), layoutAssignButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.assignToPolicy', { - defaultMessage: 'Assign blocklists to policy', + defaultMessage: 'Assign blocklist entry to policy', } ), layoutViewAllLinkMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.blocklists.layout.about.viewAllLinkLabel', { - defaultMessage: 'view all blocklists', + defaultMessage: 'view all blocklist entries', } ), }); diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/policy_tabs.tsx b/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/policy_tabs.tsx index 17c880ffa6261..6b40477c7bb6f 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/policy_tabs.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/policy_tabs.tsx @@ -123,7 +123,7 @@ export const PolicyTabs = React.memo(() => { layoutAboutMessage: (count: number, link: React.ReactElement): React.ReactNode => ( ), @@ -156,7 +156,7 @@ export const PolicyTabs = React.memo(() => { layoutAboutMessage: (count: number, link: React.ReactElement): React.ReactNode => ( ), @@ -241,7 +241,7 @@ export const PolicyTabs = React.memo(() => { [PolicyTabKeys.BLOCKLISTS]: { id: PolicyTabKeys.BLOCKLISTS, name: i18n.translate('xpack.securitySolution.endpoint.policy.details.tabs.blocklists', { - defaultMessage: 'Blocklists', + defaultMessage: 'Blocklist', }), content: ( <> diff --git a/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/trusted_apps_translations.ts b/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/trusted_apps_translations.ts index f83568498df25..b990c2f9fc26c 100644 --- a/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/trusted_apps_translations.ts +++ b/x-pack/plugins/security_solution/public/management/pages/policy/view/tabs/trusted_apps_translations.ts @@ -12,14 +12,14 @@ export const POLICY_ARTIFACT_TRUSTED_APPS_LABELS = Object.freeze({ deleteModalTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.list.removeDialog.title', { - defaultMessage: 'Remove trusted app from policy', + defaultMessage: 'Remove trusted application from policy', } ), deleteModalImpactInfo: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.list.removeDialog.messageCallout', { defaultMessage: - 'This trusted app will be removed only from this policy and can still be found and managed from the artifact page.', + 'This trusted application will be removed only from this policy and can still be found and managed from the artifact page.', } ), deleteModalErrorMessage: i18n.translate( @@ -33,37 +33,37 @@ export const POLICY_ARTIFACT_TRUSTED_APPS_LABELS = Object.freeze({ 'xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.searchWarning.text', { defaultMessage: - 'Only the first {maxNumber} trusted apps are displayed. Please use the search bar to refine the results.', + 'Only the first {maxNumber} trusted applications are displayed. Please use the search bar to refine the results.', values: { maxNumber }, } ), flyoutNoArtifactsToBeAssignedMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.noAssignable', { - defaultMessage: 'There are no trusted apps that can be assigned to this policy.', + defaultMessage: 'There are no trusted applications that can be assigned to this policy.', } ), flyoutTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.title', { - defaultMessage: 'Assign trusted apps', + defaultMessage: 'Assign trusted applications', } ), flyoutSubtitle: (policyName: string): string => i18n.translate('xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.subtitle', { - defaultMessage: 'Select trusted apps to add to {policyName}', + defaultMessage: 'Select trusted applications to add to {policyName}', values: { policyName }, }), flyoutSearchPlaceholder: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.search.label', { - defaultMessage: 'Search trusted apps', + defaultMessage: 'Search trusted applications', } ), flyoutErrorMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.toastError.text', { - defaultMessage: `An error occurred updating trusted apps`, + defaultMessage: `An error occurred updating trusted applications`, } ), flyoutSuccessMessageText: (updatedExceptions: ExceptionListItemSchema[]): string => @@ -71,61 +71,61 @@ export const POLICY_ARTIFACT_TRUSTED_APPS_LABELS = Object.freeze({ ? i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.toastSuccess.textMultiples', { - defaultMessage: '{count} trusted apps have been added to your list.', + defaultMessage: '{count} trusted applications have been added to your list.', values: { count: updatedExceptions.length }, } ) : i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.flyout.toastSuccess.textSingle', { - defaultMessage: '"{name}" has been added to your trusted app list.', + defaultMessage: '"{name}" has been added to your trusted application list.', values: { name: updatedExceptions[0].name }, } ), emptyUnassignedTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.empty.unassigned.title', - { defaultMessage: 'No assigned trusted apps' } + { defaultMessage: 'No assigned trusted applications' } ), emptyUnassignedMessage: (policyName: string): string => i18n.translate('xpack.securitySolution.endpoint.policy.trustedApps.empty.unassigned.content', { defaultMessage: - 'There are currently no trusted apps assigned to {policyName}. Assign trusted apps now or add and manage them on the trusted apps page.', + 'There are currently no trusted applications assigned to {policyName}. Assign trusted applications now or add and manage them on the trusted applications page.', values: { policyName }, }), emptyUnassignedPrimaryActionButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.empty.unassigned.primaryAction', { - defaultMessage: 'Assign trusted apps', + defaultMessage: 'Assign trusted applications', } ), emptyUnassignedSecondaryActionButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.empty.unassigned.secondaryAction', { - defaultMessage: 'Manage trusted apps', + defaultMessage: 'Manage trusted applications', } ), emptyUnexistingTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.empty.unexisting.title', - { defaultMessage: 'No trusted apps exist' } + { defaultMessage: 'No trusted applications exist' } ), emptyUnexistingMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.empty.unexisting.content', - { defaultMessage: 'There are currently no trusted apps applied to your endpoints.' } + { defaultMessage: 'There are currently no trusted applications applied to your endpoints.' } ), emptyUnexistingPrimaryActionButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.empty.unexisting.action', - { defaultMessage: 'Add trusted apps' } + { defaultMessage: 'Add trusted applications' } ), listTotalItemCountMessage: (totalItemsCount: number): string => i18n.translate('xpack.securitySolution.endpoint.policy.trustedApps.list.totalItemCount', { defaultMessage: - 'Showing {totalItemsCount, plural, one {# trusted app} other {# trusted apps}}', + 'Showing {totalItemsCount, plural, one {# trusted app} other {# trusted applications}}', values: { totalItemsCount }, }), listRemoveActionNotAllowedMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.list.removeActionNotAllowed', { - defaultMessage: 'Globally applied trusted app cannot be removed from policy.', + defaultMessage: 'Globally applied trusted application cannot be removed from policy.', } ), listSearchPlaceholderMessage: i18n.translate( @@ -135,18 +135,18 @@ export const POLICY_ARTIFACT_TRUSTED_APPS_LABELS = Object.freeze({ } ), layoutTitle: i18n.translate('xpack.securitySolution.endpoint.policy.trustedApps.layout.title', { - defaultMessage: 'Assigned trusted apps', + defaultMessage: 'Assigned trusted applications', }), layoutAssignButtonTitle: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.assignToPolicy', { - defaultMessage: 'Assign trusted apps to policy', + defaultMessage: 'Assign trusted applications to policy', } ), layoutViewAllLinkMessage: i18n.translate( 'xpack.securitySolution.endpoint.policy.trustedApps.layout.about.viewAllLinkLabel', { - defaultMessage: 'view all trusted apps', + defaultMessage: 'view all trusted applications', } ), }); From bf2769d7ee5994c73532739d47ca896a319740b9 Mon Sep 17 00:00:00 2001 From: Sander Philipse <94373878+sphilipse@users.noreply.github.com> Date: Tue, 29 Mar 2022 12:31:05 +0200 Subject: [PATCH 076/160] [Workplace Search] Add source skips config step correctly (#128715) --- .../components/add_source/add_source.test.tsx | 5 ++++- .../content_sources/components/add_source/add_source.tsx | 4 ++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx index e9cbafd01003e..48e57d92272ba 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.test.tsx @@ -81,7 +81,10 @@ describe('AddSourceList', () => { configured: true, }; shallow(); - expect(initializeAddSource).toHaveBeenCalledWith(expect.objectContaining({ connect: true })); + expect(initializeAddSource).toHaveBeenNthCalledWith( + 2, + expect.objectContaining({ connect: true }) + ); }); it('renders default state correctly when there are multiple connector options', () => { diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.tsx b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.tsx index 3fa316333bccc..98e9f32bb33ac 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.tsx +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/components/add_source/add_source.tsx @@ -59,9 +59,9 @@ export const AddSource: React.FC = (props) => { // We can land on this page from a choice page for multiple types of connectors // If that's the case we want to skip the intro and configuration, if the external & internal connector have already been configured const goToConnect = externalConnectorAvailable && externalConfigured && configured; - initializeAddSource(goToConnect ? props : { ...props, connect: true }); + initializeAddSource(goToConnect ? { ...props, connect: true } : props); return resetSourceState; - }, []); + }, [configured]); const goToConfigurationIntro = () => setAddSourceStep(AddSourceSteps.ConfigIntroStep); const goToSaveConfig = () => setAddSourceStep(AddSourceSteps.SaveConfigStep); From a07c47c652ae47d6bae35ee1edb011fda4bc853b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20S=C3=A1nchez?= Date: Tue, 29 Mar 2022 12:44:31 +0200 Subject: [PATCH 077/160] Set filter to undefined when it's empty on findExceptionLists method (#128455) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../src/api/index.ts | 2 +- .../lists/public/exceptions/api.test.ts | 25 +++++++++++++++++++ 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/packages/kbn-securitysolution-list-api/src/api/index.ts b/packages/kbn-securitysolution-list-api/src/api/index.ts index 77c50fb32c299..a0361d044977c 100644 --- a/packages/kbn-securitysolution-list-api/src/api/index.ts +++ b/packages/kbn-securitysolution-list-api/src/api/index.ts @@ -231,7 +231,7 @@ const fetchExceptionLists = async ({ signal, }: ApiCallFetchExceptionListsProps): Promise => { const query = { - filter: filters, + filter: filters || undefined, namespace_type: namespaceTypes, page: pagination.page ? `${pagination.page}` : '1', per_page: pagination.perPage ? `${pagination.perPage}` : '20', diff --git a/x-pack/plugins/lists/public/exceptions/api.test.ts b/x-pack/plugins/lists/public/exceptions/api.test.ts index 65c11bfc1dfd0..923f4db19f62e 100644 --- a/x-pack/plugins/lists/public/exceptions/api.test.ts +++ b/x-pack/plugins/lists/public/exceptions/api.test.ts @@ -278,6 +278,31 @@ describe('Exceptions Lists API', () => { expect(exceptionResponse.data).toEqual([getExceptionListSchemaMock()]); }); + test('it returns expected exception lists when empty filter', async () => { + const exceptionResponse = await fetchExceptionLists({ + filters: '', + http: httpMock, + namespaceTypes: 'single,agnostic', + pagination: { + page: 1, + perPage: 20, + }, + signal: abortCtrl.signal, + }); + expect(httpMock.fetch).toHaveBeenCalledWith('/api/exception_lists/_find', { + method: 'GET', + query: { + namespace_type: 'single,agnostic', + page: '1', + per_page: '20', + sort_field: 'exception-list.created_at', + sort_order: 'desc', + }, + signal: abortCtrl.signal, + }); + expect(exceptionResponse.data).toEqual([getExceptionListSchemaMock()]); + }); + test('it returns error if response payload fails decode', async () => { const badPayload = getExceptionListSchemaMock(); // @ts-expect-error From 131a2892fb22b4a711155bb822408653e5ed0f0c Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Tue, 29 Mar 2022 12:49:51 +0200 Subject: [PATCH 078/160] [Lens] Add normalize_by_unit function and option (#128303) * add time scale function and option * add example to documentation * fixes * rename * fix test Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/lens/public/index.ts | 1 + .../definitions/calculations/index.ts | 2 + .../definitions/calculations/time_scale.tsx | 147 ++++++++++++++++++ .../definitions/formula/formula.test.tsx | 1 + .../definitions/formula/formula.tsx | 3 +- .../operations/definitions/index.ts | 4 + .../operations/index.ts | 1 + .../operations/operations.test.ts | 4 + .../public/indexpattern_datasource/types.ts | 1 + 9 files changed, 163 insertions(+), 1 deletion(-) create mode 100644 x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/time_scale.tsx diff --git a/x-pack/plugins/lens/public/index.ts b/x-pack/plugins/lens/public/index.ts index 5b1501410df26..4cdbe464bd302 100644 --- a/x-pack/plugins/lens/public/index.ts +++ b/x-pack/plugins/lens/public/index.ts @@ -66,6 +66,7 @@ export type { OverallSumIndexPatternColumn, FormulaPublicApi, StaticValueIndexPatternColumn, + TimeScaleIndexPatternColumn, } from './indexpattern_datasource/types'; export type { XYArgs, diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/index.ts b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/index.ts index 1ffbdea00b775..3a3de198d4205 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/index.ts +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/index.ts @@ -25,3 +25,5 @@ export { overallMaxOperation, overallAverageOperation, } from './overall_metric'; +export type { TimeScaleIndexPatternColumn } from './time_scale'; +export { timeScaleOperation } from './time_scale'; diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/time_scale.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/time_scale.tsx new file mode 100644 index 0000000000000..326d564ef4832 --- /dev/null +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/calculations/time_scale.tsx @@ -0,0 +1,147 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { i18n } from '@kbn/i18n'; +import type { + FormattedIndexPatternColumn, + ReferenceBasedIndexPatternColumn, +} from '../column_types'; +import { getErrorsForDateReference } from './utils'; +import type { OperationDefinition } from '..'; +import { combineErrorMessages, getFormatFromPreviousColumn } from '../helpers'; +import { IndexPatternLayer } from '../../../types'; +import { getDisallowedPreviousShiftMessage } from '../../../time_shift_utils'; + +type OverallMetricIndexPatternColumn = FormattedIndexPatternColumn & + ReferenceBasedIndexPatternColumn & { + operationType: T; + }; + +export type OverallSumIndexPatternColumn = OverallMetricIndexPatternColumn<'overall_sum'>; +export type OverallMinIndexPatternColumn = OverallMetricIndexPatternColumn<'overall_min'>; +export type OverallMaxIndexPatternColumn = OverallMetricIndexPatternColumn<'overall_max'>; +export type OverallAverageIndexPatternColumn = OverallMetricIndexPatternColumn<'overall_average'>; + +export type TimeScaleIndexPatternColumn = FormattedIndexPatternColumn & + ReferenceBasedIndexPatternColumn & { + operationType: 'normalize_by_unit'; + params: { + unit?: string; + }; + }; + +export const timeScaleOperation: OperationDefinition = + { + type: 'normalize_by_unit', + priority: 1, + displayName: i18n.translate('xpack.lens.indexPattern.timeScale', { + defaultMessage: 'Normalize by unit', + }), + input: 'fullReference', + selectionStyle: 'hidden', + requiredReferences: [ + { + input: ['field', 'managedReference', 'fullReference'], + validateMetadata: (meta) => meta.dataType === 'number' && !meta.isBucketed, + }, + ], + operationParams: [{ name: 'unit', type: 'string', required: true }], + getPossibleOperation: () => { + return { + dataType: 'number', + isBucketed: false, + scale: 'ratio', + }; + }, + getDefaultLabel: (column, indexPattern, columns) => { + return 'normalize_by_unit'; + }, + toExpression: (layer, columnId) => { + const currentColumn = layer.columns[columnId] as unknown as TimeScaleIndexPatternColumn; + const buckets = layer.columnOrder.filter((colId) => layer.columns[colId].isBucketed); + const dateColumn = buckets.find( + (colId) => layer.columns[colId].operationType === 'date_histogram' + )!; + return [ + { + type: 'function', + function: 'lens_time_scale', + arguments: { + dateColumnId: [dateColumn], + inputColumnId: [currentColumn.references[0]], + outputColumnId: [columnId], + outputColumnName: [currentColumn.label], + targetUnit: [currentColumn.params.unit!], + }, + }, + ]; + }, + buildColumn: ({ referenceIds, previousColumn, layer, indexPattern }, columnParams) => { + return { + label: 'Normalize by unit', + dataType: 'number', + operationType: 'normalize_by_unit', + isBucketed: false, + scale: 'ratio', + references: referenceIds, + params: { + ...getFormatFromPreviousColumn(previousColumn), + unit: columnParams?.unit, + }, + }; + }, + isTransferable: () => { + return true; + }, + getErrorMessage: (layer: IndexPatternLayer, columnId: string) => { + return combineErrorMessages([ + getErrorsForDateReference( + layer, + columnId, + i18n.translate('xpack.lens.indexPattern.timeScale', { + defaultMessage: 'Normalize by unit', + }) + ), + getDisallowedPreviousShiftMessage(layer, columnId), + !(layer.columns[columnId] as TimeScaleIndexPatternColumn).params.unit + ? [ + i18n.translate('xpack.lens.indexPattern.timeScale.missingUnit', { + defaultMessage: 'No unit specified for normalize by unit.', + }), + ] + : [], + ['s', 'm', 'h', 'd'].indexOf( + (layer.columns[columnId] as TimeScaleIndexPatternColumn).params.unit || 's' + ) === -1 + ? [ + i18n.translate('xpack.lens.indexPattern.timeScale.wrongUnit', { + defaultMessage: 'Unknown unit specified, use s,m,h or d.', + }), + ] + : [], + ]); + }, + filterable: false, + shiftable: false, + documentation: { + section: 'calculation', + signature: i18n.translate('xpack.lens.indexPattern.time_scale', { + defaultMessage: 'metric: number, unit: s|m|h|d|w|M|y', + }), + description: i18n.translate('xpack.lens.indexPattern.time_scale.documentation.markdown', { + defaultMessage: ` + +This advanced function is useful for normalizing counts and sums to a specific time interval. It allows for integration with metrics that are stored already normalized to a specific time interval. + +This function can only be used if there's a date histogram function used in the current chart. + +Example: A ratio comparing an already normalized metric to another metric that needs to be normalized. +\`normalize_by_unit(counter_rate(max(system.diskio.write.bytes)), unit='s') / last_value(apache.status.bytes_per_second)\` + `, + }), + }, + }; diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.test.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.test.tsx index 0fb7f35beb02b..51e7d363ac39d 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.test.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.test.tsx @@ -343,6 +343,7 @@ describe('formula', () => { formula: 'moving_average(average(bytes), window=3)', }, references: [], + timeScale: 'd', }); }); diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.tsx index 9bbd1588d29b6..1f0fbceff3d5b 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/operations/definitions/formula/formula.tsx @@ -168,6 +168,7 @@ export const formulaOperation: OperationDefinition { @@ -181,6 +182,6 @@ export const formulaOperation: OperationDefinition { "operationType": "overall_average", "type": "fullReference", }, + Object { + "operationType": "normalize_by_unit", + "type": "fullReference", + }, Object { "field": "bytes", "operationType": "min", diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/types.ts b/x-pack/plugins/lens/public/indexpattern_datasource/types.ts index 5bb4d58ed20fa..5d518b4048ed0 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/types.ts +++ b/x-pack/plugins/lens/public/indexpattern_datasource/types.ts @@ -37,6 +37,7 @@ export type { MathIndexPatternColumn, OverallSumIndexPatternColumn, StaticValueIndexPatternColumn, + TimeScaleIndexPatternColumn, } from './operations'; export type { FormulaPublicApi } from './operations/definitions/formula/formula_public_api'; From 53dde5f44e77300169eab7d34aa06f3f1b446250 Mon Sep 17 00:00:00 2001 From: Pablo Machado Date: Tue, 29 Mar 2022 12:51:12 +0200 Subject: [PATCH 079/160] [Security Solution] Update user page deep links (#128722) * Update user page deep links * Fix a couple of code style issues introduced on #128375 https://github.com/elastic/kibana/pull/128375 --- .../security_solution/common/constants.ts | 7 +- .../public/app/deep_links/index.test.ts | 8 ++ .../public/app/deep_links/index.ts | 45 ++++++++++- .../users/components/all_users/index.tsx | 76 +++++++++---------- .../factory/users/all/query.all_users.dsl.ts | 4 +- 5 files changed, 93 insertions(+), 47 deletions(-) diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index 2e64c710aa41c..591c7d68e17cb 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -79,7 +79,6 @@ export const DEFAULT_THREAT_MATCH_QUERY = '@timestamp >= "now-30d/d"' as const; export enum SecurityPageName { administration = 'administration', alerts = 'alerts', - authentications = 'authentications', /* * Warning: Computed values are not permitted in an enum with string valued members * The 3 following Cases page names must match `CasesDeepLinkId` in x-pack/plugins/cases/public/common/navigation.ts @@ -92,7 +91,6 @@ export enum SecurityPageName { detectionAndResponse = 'detection_response', endpoints = 'endpoints', eventFilters = 'event_filters', - events = 'events', exceptions = 'exceptions', explore = 'explore', hostIsolationExceptions = 'host_isolation_exceptions', @@ -100,6 +98,8 @@ export enum SecurityPageName { hostsAnomalies = 'hosts-anomalies', hostsExternalAlerts = 'hosts-external_alerts', hostsRisk = 'hosts-risk', + hostsEvents = 'hosts-events', + hostsAuthentications = 'hosts-authentications', investigate = 'investigate', landing = 'get_started', network = 'network', @@ -116,9 +116,12 @@ export enum SecurityPageName { trustedApps = 'trusted_apps', uncommonProcesses = 'uncommon_processes', users = 'users', + usersAuthentications = 'users-authentications', usersAnomalies = 'users-anomalies', usersRisk = 'users-risk', sessions = 'sessions', + usersEvents = 'users-events', + usersExternalAlerts = 'users-external_alerts', } export const TIMELINES_PATH = '/timelines' as const; diff --git a/x-pack/plugins/security_solution/public/app/deep_links/index.test.ts b/x-pack/plugins/security_solution/public/app/deep_links/index.test.ts index 583f1f3ea9b0d..0676c516ede64 100644 --- a/x-pack/plugins/security_solution/public/app/deep_links/index.test.ts +++ b/x-pack/plugins/security_solution/public/app/deep_links/index.test.ts @@ -154,6 +154,14 @@ describe('deepLinks', () => { expect(findDeepLink(SecurityPageName.users, deepLinks)).toBeTruthy(); }); + it('should NOT return host authentications when enableExperimental.usersEnabled === true', () => { + const deepLinks = getDeepLinks({ + ...mockGlobalState.app.enableExperimental, + usersEnabled: true, + }); + expect(findDeepLink(SecurityPageName.hostsAuthentications, deepLinks)).toBeFalsy(); + }); + it('should return NO detection & Response link when enableExperimental.detectionResponseEnabled === false', () => { const deepLinks = getDeepLinks(mockGlobalState.app.enableExperimental); expect(findDeepLink(SecurityPageName.detectionAndResponse, deepLinks)).toBeFalsy(); diff --git a/x-pack/plugins/security_solution/public/app/deep_links/index.ts b/x-pack/plugins/security_solution/public/app/deep_links/index.ts index 2df243d9b2d41..6b417a984d899 100644 --- a/x-pack/plugins/security_solution/public/app/deep_links/index.ts +++ b/x-pack/plugins/security_solution/public/app/deep_links/index.ts @@ -68,7 +68,14 @@ type Feature = typeof FEATURE[keyof typeof FEATURE]; type SecuritySolutionDeepLink = AppDeepLink & { isPremium?: boolean; features?: Feature[]; + /** + * Displays deep link when feature flag is enabled. + */ experimentalKey?: keyof ExperimentalFeatures; + /** + * Hides deep link when feature flag is enabled. + */ + hideWhenExperimentalKey?: keyof ExperimentalFeatures; deepLinks?: SecuritySolutionDeepLink[]; }; @@ -186,11 +193,12 @@ export const securitySolutionsDeepLinks: SecuritySolutionDeepLink[] = [ order: 9002, deepLinks: [ { - id: SecurityPageName.authentications, + id: SecurityPageName.hostsAuthentications, title: i18n.translate('xpack.securitySolution.search.hosts.authentications', { defaultMessage: 'Authentications', }), path: `${HOSTS_PATH}/authentications`, + hideWhenExperimentalKey: 'usersEnabled', }, { id: SecurityPageName.uncommonProcesses, @@ -200,7 +208,7 @@ export const securitySolutionsDeepLinks: SecuritySolutionDeepLink[] = [ path: `${HOSTS_PATH}/uncommonProcesses`, }, { - id: SecurityPageName.events, + id: SecurityPageName.hostsEvents, title: i18n.translate('xpack.securitySolution.search.hosts.events', { defaultMessage: 'Events', }), @@ -293,6 +301,13 @@ export const securitySolutionsDeepLinks: SecuritySolutionDeepLink[] = [ ], order: 9004, deepLinks: [ + { + id: SecurityPageName.usersAuthentications, + title: i18n.translate('xpack.securitySolution.search.users.authentications', { + defaultMessage: 'Authentications', + }), + path: `${USERS_PATH}/authentications`, + }, { id: SecurityPageName.usersAnomalies, title: i18n.translate('xpack.securitySolution.search.users.anomalies', { @@ -307,7 +322,21 @@ export const securitySolutionsDeepLinks: SecuritySolutionDeepLink[] = [ defaultMessage: 'Risk', }), path: `${USERS_PATH}/userRisk`, - isPremium: true, + experimentalKey: 'riskyUsersEnabled', + }, + { + id: SecurityPageName.usersEvents, + title: i18n.translate('xpack.securitySolution.search.users.events', { + defaultMessage: 'Events', + }), + path: `${USERS_PATH}/events`, + }, + { + id: SecurityPageName.usersExternalAlerts, + title: i18n.translate('xpack.securitySolution.search.users.externalAlerts', { + defaultMessage: 'External Alerts', + }), + path: `${USERS_PATH}/externalAlerts`, }, ], }, @@ -428,13 +457,21 @@ export function getDeepLinks( ): AppDeepLink[] { const filterDeepLinks = (securityDeepLinks: SecuritySolutionDeepLink[]): AppDeepLink[] => securityDeepLinks.reduce( - (deepLinks: AppDeepLink[], { isPremium, features, experimentalKey, ...deepLink }) => { + ( + deepLinks: AppDeepLink[], + { isPremium, features, experimentalKey, hideWhenExperimentalKey, ...deepLink } + ) => { if (licenseType && isPremium && !isPremiumLicense(licenseType)) { return deepLinks; } if (experimentalKey && !enableExperimental[experimentalKey]) { return deepLinks; } + + if (hideWhenExperimentalKey && enableExperimental[hideWhenExperimentalKey]) { + return deepLinks; + } + if (capabilities != null && !hasFeaturesCapability(features, capabilities)) { return deepLinks; } diff --git a/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx b/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx index 15626d0650ac8..9a00a637f551d 100644 --- a/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx +++ b/x-pack/plugins/security_solution/public/users/components/all_users/index.tsx @@ -58,6 +58,44 @@ const rowItems: ItemsPerRow[] = [ }, ]; +const getUsersColumns = (): UsersTableColumns => [ + { + field: 'name', + name: i18n.USER_NAME, + truncateText: false, + sortable: true, + mobileOptions: { show: true }, + render: (name) => + getRowItemDraggables({ + rowItems: [name], + attrName: 'user.name', + idPrefix: `users-table-${name}-name`, + render: (item) => , + }), + }, + { + field: 'lastSeen', + name: i18n.LAST_SEEN, + sortable: true, + truncateText: false, + mobileOptions: { show: true }, + render: (lastSeen) => , + }, + { + field: 'domain', + name: i18n.DOMAIN, + sortable: false, + truncateText: false, + mobileOptions: { show: true }, + render: (domain) => + getRowItemDraggables({ + rowItems: [domain], + attrName: 'user.domain', + idPrefix: `users-table-${domain}-domain`, + }), + }, +]; + const UsersTableComponent: React.FC = ({ users, totalCount, @@ -146,41 +184,3 @@ const UsersTableComponent: React.FC = ({ UsersTableComponent.displayName = 'UsersTableComponent'; export const UsersTable = React.memo(UsersTableComponent); - -const getUsersColumns = (): UsersTableColumns => [ - { - field: 'name', - name: i18n.USER_NAME, - truncateText: false, - sortable: true, - mobileOptions: { show: true }, - render: (name) => - getRowItemDraggables({ - rowItems: [name], - attrName: 'user.name', - idPrefix: `users-table-${name}-name`, - render: (item) => , - }), - }, - { - field: 'lastSeen', - name: i18n.LAST_SEEN, - sortable: true, - truncateText: false, - mobileOptions: { show: true }, - render: (lastSeen) => , - }, - { - field: 'domain', - name: i18n.DOMAIN, - sortable: false, - truncateText: false, - mobileOptions: { show: true }, - render: (domain) => - getRowItemDraggables({ - rowItems: [domain], - attrName: 'user.domain', - idPrefix: `users-table-${domain}-domain`, - }), - }, -]; diff --git a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts index ee98c92d2ac6b..850a590fdfe41 100644 --- a/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts +++ b/x-pack/plugins/security_solution/server/search_strategy/security_solution/factory/users/all/query.all_users.dsl.ts @@ -37,8 +37,6 @@ export const buildUsersQuery = ({ }, ]; - const agg = { user_count: { cardinality: { field: 'user.name' } } }; - const dslQuery = { allow_no_indices: true, index: defaultIndex, @@ -47,7 +45,7 @@ export const buildUsersQuery = ({ body: { ...(!isEmpty(docValueFields) ? { docvalue_fields: docValueFields } : {}), aggregations: { - ...agg, + user_count: { cardinality: { field: 'user.name' } }, user_data: { terms: { size: querySize, field: 'user.name', order: getQueryOrder(sort) }, aggs: { From 17086ad6ceb726411a99c2a41477f6e89359b9a1 Mon Sep 17 00:00:00 2001 From: Georgii Gorbachev Date: Tue, 29 Mar 2022 13:42:36 +0200 Subject: [PATCH 080/160] [Security Solution][Detections] Adds UI for bulk applying timeline template (#128691) **Addresses:** https://github.com/elastic/kibana/issues/93083, https://github.com/elastic/security-team/issues/2078 (internal) ## Summary This PR adds a UI for applying a timeline template to multiple rules in bulk. - A new bulk actions menu item to the Rule Management table. - A new form flyout for applying a timeline template. - Some glue code to connect them. There are a few issues that I'd like to address in a follow-up PR after the FF: 1. Resetting already applied templates to `None` doesn't work because of the way the `patchRules` function works. This is a known bug in this implementation. We will need to replace `patchRules` with something else for bulk editing actions. 2. I need to add some test coverage. Other notes: - I changed some copies to hopefully make it a little bit clearer. Let me know if you want to rephrase. ## Screenshots ![](https://puu.sh/IRpnL/9abe2ce1b5.png) The template selector doesn't look good on a smaller screen: ![](https://puu.sh/IRpyP/eb7bebabc7.png) --- .../all/bulk_actions/bulk_edit_flyout.tsx | 4 + .../forms/bulk_edit_form_wrapper.tsx | 14 +-- .../forms/timeline_template_form.tsx | 102 ++++++++++++++++++ .../rules/all/bulk_actions/translations.tsx | 50 +++++++++ .../all/bulk_actions/use_bulk_actions.tsx | 10 ++ .../detection_engine/rules/translations.ts | 7 ++ .../rules/bulk_action_edit.ts | 11 +- 7 files changed, 187 insertions(+), 11 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/timeline_template_form.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/translations.tsx diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/bulk_edit_flyout.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/bulk_edit_flyout.tsx index a6b5f664fc7cd..07967ae53a041 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/bulk_edit_flyout.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/bulk_edit_flyout.tsx @@ -14,6 +14,7 @@ import { import { IndexPatternsForm } from './forms/index_patterns_form'; import { TagsForm } from './forms/tags_form'; +import { TimelineTemplateForm } from './forms/timeline_template_form'; interface BulkEditFlyoutProps { onClose: () => void; @@ -35,6 +36,9 @@ const BulkEditFlyoutComponent = ({ editAction, tags, ...props }: BulkEditFlyoutP case BulkActionEditType.set_tags: return ; + case BulkActionEditType.set_timeline: + return ; + default: return null; } diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/bulk_edit_form_wrapper.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/bulk_edit_form_wrapper.tsx index a56a4fe3d159e..49d4487808740 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/bulk_edit_form_wrapper.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/bulk_edit_form_wrapper.tsx @@ -24,19 +24,21 @@ import { Form, FormHook } from '../../../../../../../shared_imports'; import * as i18n from '../../../translations'; interface BulkEditFormWrapperProps { - onClose: () => void; - onSubmit: () => void; - title: string; form: FormHook; + title: string; + banner?: React.ReactNode; children: React.ReactNode; + onClose: () => void; + onSubmit: () => void; } const BulkEditFormWrapperComponent: FC = ({ form, + title, + banner, + children, onClose, onSubmit, - children, - title, }) => { const simpleFlyoutTitleId = useGeneratedHtmlId({ prefix: 'RulesBulkEditForm', @@ -50,7 +52,7 @@ const BulkEditFormWrapperComponent: FC = ({

{title}

- +
{children}
diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/timeline_template_form.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/timeline_template_form.tsx new file mode 100644 index 0000000000000..8e67b2711a278 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/forms/timeline_template_form.tsx @@ -0,0 +1,102 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useCallback } from 'react'; +import { EuiCallOut } from '@elastic/eui'; + +import { useForm, UseField, FormSchema } from '../../../../../../../shared_imports'; +import { PickTimeline } from '../../../../../../components/rules/pick_timeline'; +import { + BulkActionEditType, + BulkActionEditPayload, +} from '../../../../../../../../common/detection_engine/schemas/common/schemas'; + +import { BulkEditFormWrapper } from './bulk_edit_form_wrapper'; +import { bulkApplyTimelineTemplate as i18n } from '../translations'; + +export interface TimelineTemplateFormData { + timeline: { + id: string | null; + title: string; + }; +} + +const formSchema: FormSchema = { + timeline: { + label: i18n.TEMPLATE_SELECTOR_LABEL, + helpText: i18n.TEMPLATE_SELECTOR_HELP_TEXT, + }, +}; + +const defaultFormData: TimelineTemplateFormData = { + timeline: { + id: null, + title: i18n.TEMPLATE_SELECTOR_DEFAULT_VALUE, + }, +}; + +interface TimelineTemplateFormProps { + rulesCount: number; + onClose: () => void; + onConfirm: (bulkActionEditPayload: BulkActionEditPayload) => void; +} + +const TimelineTemplateFormComponent = (props: TimelineTemplateFormProps) => { + const { rulesCount, onClose, onConfirm } = props; + + const { form } = useForm({ + schema: formSchema, + defaultValue: defaultFormData, + }); + + const handleSubmit = useCallback(async () => { + const { data, isValid } = await form.submit(); + if (!isValid) { + return; + } + + const timelineId = data.timeline.id || ''; + const timelineTitle = timelineId ? data.timeline.title : ''; + + onConfirm({ + type: BulkActionEditType.set_timeline, + value: { + timeline_id: timelineId, + timeline_title: timelineTitle, + }, + }); + }, [form, onConfirm]); + + const warningCallout = ( + + {i18n.warningCalloutMessage(rulesCount)} + + ); + + return ( + + {/* Timeline template selector */} + + + ); +}; + +export const TimelineTemplateForm = React.memo(TimelineTemplateFormComponent); +TimelineTemplateForm.displayName = 'TimelineTemplateForm'; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/translations.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/translations.tsx new file mode 100644 index 0000000000000..d35a89484f264 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/translations.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; + +export const bulkApplyTimelineTemplate = { + FORM_TITLE: i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.edit.applyTimelineTemplate.formTitle', + { + defaultMessage: 'Apply timeline template', + } + ), + + TEMPLATE_SELECTOR_LABEL: i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.edit.applyTimelineTemplate.templateSelectorLabel', + { + defaultMessage: 'Apply timeline template to selected rules', + } + ), + + TEMPLATE_SELECTOR_HELP_TEXT: i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.edit.applyTimelineTemplate.templateSelectorHelpText', + { + defaultMessage: + 'Select which timeline to apply to selected rules when investigating generated alerts.', + } + ), + + TEMPLATE_SELECTOR_DEFAULT_VALUE: i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.edit.applyTimelineTemplate.templateSelectorDefaultValue', + { + defaultMessage: 'None', + } + ), + + warningCalloutMessage: (rulesCount: number): JSX.Element => ( + + ), +}; diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx index 6bd7cfc67f308..9aa175002af7b 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/bulk_actions/use_bulk_actions.tsx @@ -307,6 +307,16 @@ export const useBulkActions = ({ disabled: isEditDisabled, panel: 1, }, + { + key: i18n.BULK_ACTION_APPLY_TIMELINE_TEMPLATE, + name: i18n.BULK_ACTION_APPLY_TIMELINE_TEMPLATE, + 'data-test-subj': 'applyTimelineTemplateBulk', + disabled: isEditDisabled, + onClick: handleBulkEdit(BulkActionEditType.set_timeline), + toolTipContent: missingActionPrivileges ? i18n.EDIT_RULE_SETTINGS_TOOLTIP : undefined, + toolTipPosition: 'right', + icon: undefined, + }, { key: i18n.BULK_ACTION_EXPORT, name: i18n.BULK_ACTION_EXPORT, diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts index f93ca2f48d2db..f99ebc2c72c26 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts @@ -193,6 +193,13 @@ export const BULK_ACTION_DELETE_TAGS = i18n.translate( } ); +export const BULK_ACTION_APPLY_TIMELINE_TEMPLATE = i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.applyTimelineTemplateTitle', + { + defaultMessage: 'Apply timeline template', + } +); + export const BULK_ACTION_MENU_TITLE = i18n.translate( 'xpack.securitySolution.detectionEngine.rules.allRules.bulkActions.contextMenuTitle', { diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rules/bulk_action_edit.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rules/bulk_action_edit.ts index 8df66dcc3b191..5133d1604d621 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rules/bulk_action_edit.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rules/bulk_action_edit.ts @@ -78,11 +78,12 @@ export const applyBulkActionEditToRule = ( // timeline actions case BulkActionEditType.set_timeline: - rule.params = { - ...rule.params, - timelineId: action.value.timeline_id, - timelineTitle: action.value.timeline_title, - }; + const timelineId = action.value.timeline_id.trim() || undefined; + const timelineTitle = timelineId ? action.value.timeline_title : undefined; + + rule.params.timelineId = timelineId; + rule.params.timelineTitle = timelineTitle; + break; } return rule; From 92aea763cbc4c68bd86b601711c7569aee48f0e3 Mon Sep 17 00:00:00 2001 From: Oliver Gupte Date: Tue, 29 Mar 2022 08:10:00 -0400 Subject: [PATCH 081/160] [APM] ensure rum_allow_origins setting only saves valid YAML strings (#128703) (#128704) --- .../fleet/create_cloud_apm_package_policy.ts | 3 ++- .../get_apm_package_policy_definition.ts | 23 +++++++++++++++++-- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts b/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts index 797bce77facdb..670932ea6dbbd 100644 --- a/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts +++ b/x-pack/plugins/apm/server/routes/fleet/create_cloud_apm_package_policy.ts @@ -23,6 +23,7 @@ import { import { getApmPackagePolicyDefinition } from './get_apm_package_policy_definition'; import { Setup } from '../../lib/helpers/setup_request'; import { mergePackagePolicyWithApm } from './merge_package_policy_with_apm'; +import { ELASTIC_CLOUD_APM_AGENT_POLICY_ID } from '../../../common/fleet'; export async function createCloudApmPackgePolicy({ cloudPluginSetup, @@ -65,7 +66,7 @@ export async function createCloudApmPackgePolicy({ savedObjectsClient, esClient, mergedAPMPackagePolicy, - { force: true, bumpRevision: true } + { id: ELASTIC_CLOUD_APM_AGENT_POLICY_ID, force: true, bumpRevision: true } ); logger.info(`Fleet migration on Cloud - apmPackagePolicy create end`); return apmPackagePolicy; diff --git a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts b/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts index 85ac03697019c..28b40447136ce 100644 --- a/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts +++ b/x-pack/plugins/apm/server/routes/fleet/get_apm_package_policy_definition.ts @@ -5,12 +5,12 @@ * 2.0. */ +import yaml from 'js-yaml'; import { KibanaRequest } from 'kibana/server'; import { RegistryVarsEntry } from '../../../../fleet/common'; import { POLICY_ELASTIC_AGENT_ON_CLOUD, INPUT_VAR_NAME_TO_SCHEMA_PATH, - ELASTIC_CLOUD_APM_AGENT_POLICY_ID, } from '../../../common/fleet'; import { APMPluginSetupDependencies, @@ -36,7 +36,6 @@ export async function getApmPackagePolicyDefinition({ }); return { - id: ELASTIC_CLOUD_APM_AGENT_POLICY_ID, name: 'Elastic APM', namespace: 'default', enabled: true, @@ -73,6 +72,9 @@ function getApmPackageInputVars({ }): Record { const overrideValues: Record = { url: cloudPluginSetup?.apm?.url, // overrides 'apm-server.url' to be the cloud APM host + rum_allow_origins: ensureValidMultiText( + apmServerSchema[INPUT_VAR_NAME_TO_SCHEMA_PATH.rum_allow_origins] + ), // fixes issue where "*" needs to be wrapped in quotes to be parsed as a YAML string }; return policyTemplateInputVars.reduce((acc, registryVarsEntry) => { @@ -90,3 +92,20 @@ function getApmPackageInputVars({ }; }, {}); } + +function ensureValidMultiText(textMultiValue: string[] | undefined) { + if (!textMultiValue) { + return undefined; + } + return textMultiValue.map(escapeInvalidYamlString); +} +function escapeInvalidYamlString(yamlString: string) { + try { + yaml.load(yamlString); + } catch (error) { + if (error instanceof yaml.YAMLException) { + return `"${yamlString}"`; + } + } + return yamlString; +} From 99ec409646dd3878b3352b8139c3098887aa1469 Mon Sep 17 00:00:00 2001 From: Katerina Patticha Date: Tue, 29 Mar 2022 14:24:13 +0200 Subject: [PATCH 082/160] Fix synthrace command (#128729) --- x-pack/plugins/apm/dev_docs/local_setup.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/plugins/apm/dev_docs/local_setup.md b/x-pack/plugins/apm/dev_docs/local_setup.md index f021f41b17c80..e41ee4390d58c 100644 --- a/x-pack/plugins/apm/dev_docs/local_setup.md +++ b/x-pack/plugins/apm/dev_docs/local_setup.md @@ -29,7 +29,7 @@ node ./scripts/es_archiver load "x-pack/plugins/apm/ftr_e2e/cypress/fixtures/es_ **Run Synthtrace** ``` -node packages/elastic-apm-synthtrace/src/scripts/run packages/elastic-apm-synthtrace/src/scripts/examples/01_simple_trace.ts --target=http://elastic:changeme@localhost:9200 +node packages/elastic-apm-synthtrace/src/scripts/run packages/elastic-apm-synthtrace/src/scripts/examples/01_simple_trace.ts --target=http://localhost:9200 --username=elastic --password=changeme ``` **Connect Kibana to ES** From 569e4e8458d91f05a9ae3c3f8192640230ac25c1 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Tue, 29 Mar 2022 13:37:53 +0100 Subject: [PATCH 083/160] skip flaky suite (#127077) --- .../server/integration_tests/cloud_preconfiguration.test.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/x-pack/plugins/fleet/server/integration_tests/cloud_preconfiguration.test.ts b/x-pack/plugins/fleet/server/integration_tests/cloud_preconfiguration.test.ts index b55a95aec6103..5fa3bb118b0ed 100644 --- a/x-pack/plugins/fleet/server/integration_tests/cloud_preconfiguration.test.ts +++ b/x-pack/plugins/fleet/server/integration_tests/cloud_preconfiguration.test.ts @@ -108,7 +108,8 @@ describe.skip('Fleet preconfiguration reset', () => { await stopServers(); }); - describe('Preconfigred cloud policy', () => { + // FLAKY: https://github.com/elastic/kibana/issues/127077 + describe.skip('Preconfigred cloud policy', () => { it('Works and preconfigure correctly agent policies', async () => { const agentPolicies = await kbnServer.coreStart.savedObjects .createInternalRepository() From 91394d41e7d9cbe2eefa242aeb21c8523a369111 Mon Sep 17 00:00:00 2001 From: Dmitry Tomashevich <39378793+Dmitriynj@users.noreply.github.com> Date: Tue, 29 Mar 2022 17:48:49 +0500 Subject: [PATCH 084/160] [Graph] Clean up deprecated APIs (#128579) * [Discover] clean up deprecated apis * [Graph] apply suggestions * [Discover] replace the last DataView occurrence Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/graph/public/application.tsx | 4 ++-- .../graph/public/components/inspect_panel.tsx | 4 ++-- .../graph/public/components/search_bar.test.tsx | 7 ++++--- .../graph/public/components/search_bar.tsx | 15 ++++++--------- .../workspace_layout/workspace_layout.tsx | 6 +++--- .../graph/public/services/index_pattern_cache.ts | 6 +++--- .../services/persistence/deserialize.test.ts | 6 +++--- .../public/services/persistence/deserialize.ts | 15 +++++---------- .../public/state_management/datasource.sagas.ts | 4 ++-- .../public/state_management/datasource.test.ts | 4 ++-- .../graph/public/state_management/mocks.ts | 4 ++-- .../graph/public/state_management/persistence.ts | 4 ++-- x-pack/plugins/graph/public/types/app_state.ts | 4 ++-- 13 files changed, 38 insertions(+), 45 deletions(-) diff --git a/x-pack/plugins/graph/public/application.tsx b/x-pack/plugins/graph/public/application.tsx index 235c9aa843797..adc396965f6a7 100644 --- a/x-pack/plugins/graph/public/application.tsx +++ b/x-pack/plugins/graph/public/application.tsx @@ -21,7 +21,7 @@ import { } from 'kibana/public'; import ReactDOM from 'react-dom'; import React from 'react'; -import { DataPlugin, IndexPatternsContract } from '../../../../src/plugins/data/public'; +import { DataPlugin, DataViewsContract } from '../../../../src/plugins/data/public'; import { LicensingPluginStart } from '../../licensing/public'; import { checkLicense } from '../common/check_license'; import { NavigationPublicPluginStart as NavigationStart } from '../../../../src/plugins/navigation/public'; @@ -52,7 +52,7 @@ export interface GraphDependencies { licensing: LicensingPluginStart; chrome: ChromeStart; toastNotifications: ToastsStart; - indexPatterns: IndexPatternsContract; + indexPatterns: DataViewsContract; data: ReturnType; savedObjectsClient: SavedObjectsClientContract; addBasePath: (url: string) => string; diff --git a/x-pack/plugins/graph/public/components/inspect_panel.tsx b/x-pack/plugins/graph/public/components/inspect_panel.tsx index 5a0ad8b5f291c..6881a750f76ed 100644 --- a/x-pack/plugins/graph/public/components/inspect_panel.tsx +++ b/x-pack/plugins/graph/public/components/inspect_panel.tsx @@ -9,12 +9,12 @@ import React, { useMemo, useState } from 'react'; import { EuiTab, EuiTabs, EuiText } from '@elastic/eui'; import { monaco, XJsonLang } from '@kbn/monaco'; import { FormattedMessage } from '@kbn/i18n-react'; -import { IndexPattern } from '../../../../../src/plugins/data/public'; import { CodeEditor } from '../../../../../src/plugins/kibana_react/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; interface InspectPanelProps { showInspect: boolean; - indexPattern?: IndexPattern; + indexPattern?: DataView; lastRequest?: string; lastResponse?: string; } diff --git a/x-pack/plugins/graph/public/components/search_bar.test.tsx b/x-pack/plugins/graph/public/components/search_bar.test.tsx index 72f95ecb0dc10..7feab56b2e272 100644 --- a/x-pack/plugins/graph/public/components/search_bar.test.tsx +++ b/x-pack/plugins/graph/public/components/search_bar.test.tsx @@ -17,7 +17,8 @@ import { SavedObjectsStart, } from 'kibana/public'; import { act } from 'react-dom/test-utils'; -import { IndexPattern, QueryStringInput } from '../../../../../src/plugins/data/public'; +import { QueryStringInput } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; import { KibanaContextProvider } from '../../../../../src/plugins/kibana_react/public'; import { I18nProvider, InjectedIntl } from '@kbn/i18n-react'; @@ -87,12 +88,12 @@ describe('search_bar', () => { const defaultProps = { isLoading: false, indexPatternProvider: { - get: jest.fn(() => Promise.resolve({ fields: [] } as unknown as IndexPattern)), + get: jest.fn(() => Promise.resolve({ fields: [] } as unknown as DataView)), }, confirmWipeWorkspace: (callback: () => void) => { callback(); }, - onIndexPatternChange: (indexPattern?: IndexPattern) => { + onIndexPatternChange: (indexPattern?: DataView) => { instance.setProps({ ...defaultProps, currentIndexPattern: indexPattern, diff --git a/x-pack/plugins/graph/public/components/search_bar.tsx b/x-pack/plugins/graph/public/components/search_bar.tsx index 0760fb4fd2c13..89a82b5eb8483 100644 --- a/x-pack/plugins/graph/public/components/search_bar.tsx +++ b/x-pack/plugins/graph/public/components/search_bar.tsx @@ -10,6 +10,7 @@ import React, { useState, useEffect } from 'react'; import { i18n } from '@kbn/i18n'; import { connect } from 'react-redux'; +import { toElasticsearchQuery, fromKueryExpression } from '@kbn/es-query'; import { IndexPatternSavedObject, IndexPatternProvider, WorkspaceField } from '../types'; import { openSourceModal } from '../services/source_modal'; import { @@ -23,19 +24,18 @@ import { import { useKibana } from '../../../../../src/plugins/kibana_react/public'; import { - IndexPattern, QueryStringInput, IDataPluginServices, Query, - esKuery, } from '../../../../../src/plugins/data/public'; import { TooltipWrapper } from './tooltip_wrapper'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; export interface SearchBarProps { isLoading: boolean; urlQuery: string | null; - currentIndexPattern?: IndexPattern; - onIndexPatternChange: (indexPattern?: IndexPattern) => void; + currentIndexPattern?: DataView; + onIndexPatternChange: (indexPattern?: DataView) => void; confirmWipeWorkspace: ( onConfirm: () => void, text?: string, @@ -51,12 +51,9 @@ export interface SearchBarStateProps { submit: (searchTerm: string) => void; } -function queryToString(query: Query, indexPattern: IndexPattern) { +function queryToString(query: Query, indexPattern: DataView) { if (query.language === 'kuery' && typeof query.query === 'string') { - const dsl = esKuery.toElasticsearchQuery( - esKuery.fromKueryExpression(query.query as string), - indexPattern - ); + const dsl = toElasticsearchQuery(fromKueryExpression(query.query as string), indexPattern); // JSON representation of query will be handled by existing logic. // TODO clean this up and handle it in the data fetch layer once // it moved to typescript. diff --git a/x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx b/x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx index 5426ae9228518..3e7ff634eef0e 100644 --- a/x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx +++ b/x-pack/plugins/graph/public/components/workspace_layout/workspace_layout.tsx @@ -17,7 +17,7 @@ import { workspaceInitializedSelector, } from '../../state_management'; import { FieldManager } from '../field_manager'; -import { IndexPattern } from '../../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../../src/plugins/data_views/public'; import { ControlType, IndexPatternProvider, @@ -89,7 +89,7 @@ export const WorkspaceLayoutComponent = ({ sharingSavedObjectProps, spaces, }: WorkspaceLayoutProps & WorkspaceLayoutStateProps) => { - const [currentIndexPattern, setCurrentIndexPattern] = useState(); + const [currentIndexPattern, setCurrentIndexPattern] = useState(); const [showInspect, setShowInspect] = useState(false); const [pickerOpen, setPickerOpen] = useState(false); const [mergeCandidates, setMergeCandidates] = useState([]); @@ -112,7 +112,7 @@ export const WorkspaceLayoutComponent = ({ }, []); const onIndexPatternChange = useCallback( - (indexPattern?: IndexPattern) => setCurrentIndexPattern(indexPattern), + (indexPattern?: DataView) => setCurrentIndexPattern(indexPattern), [] ); diff --git a/x-pack/plugins/graph/public/services/index_pattern_cache.ts b/x-pack/plugins/graph/public/services/index_pattern_cache.ts index ddf630388a4f3..d6156bc9d0626 100644 --- a/x-pack/plugins/graph/public/services/index_pattern_cache.ts +++ b/x-pack/plugins/graph/public/services/index_pattern_cache.ts @@ -6,12 +6,12 @@ */ import { IndexPatternProvider } from '../types'; -import { IndexPattern } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; export function createCachedIndexPatternProvider( - indexPatternGetter: (id: string) => Promise + indexPatternGetter: (id: string) => Promise ): IndexPatternProvider { - const cache = new Map(); + const cache = new Map(); return { get: async (id: string) => { diff --git a/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts b/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts index 31826c3b3a747..cc180065d3aca 100644 --- a/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts +++ b/x-pack/plugins/graph/public/services/persistence/deserialize.test.ts @@ -9,7 +9,7 @@ import { GraphWorkspaceSavedObject, IndexPatternSavedObject, Workspace } from '. import { migrateLegacyIndexPatternRef, savedWorkspaceToAppState, mapFields } from './deserialize'; import { createWorkspace } from '../../services/workspace/graph_client_workspace'; import { outlinkEncoders } from '../../helpers/outlink_encoders'; -import { IndexPattern } from '../../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../../src/plugins/data_views/public'; describe('deserialize', () => { let savedWorkspace: GraphWorkspaceSavedObject; @@ -124,7 +124,7 @@ describe('deserialize', () => { { name: 'field2', type: 'string', aggregatable: true, isMapped: true }, { name: 'field3', type: 'string', aggregatable: true, isMapped: true }, ], - } as IndexPattern, + } as DataView, workspace ); } @@ -247,7 +247,7 @@ describe('deserialize', () => { { name: 'runtimeField', type: 'string', aggregatable: true, isMapped: false }, { name: 'field3', type: 'string', aggregatable: true, isMapped: true }, ], - } as IndexPattern; + } as DataView; expect(mapFields(indexPattern).map(({ name }) => name)).toEqual([ 'field1', 'field2', diff --git a/x-pack/plugins/graph/public/services/persistence/deserialize.ts b/x-pack/plugins/graph/public/services/persistence/deserialize.ts index d76a07ab0fc32..1223c03b6f6c1 100644 --- a/x-pack/plugins/graph/public/services/persistence/deserialize.ts +++ b/x-pack/plugins/graph/public/services/persistence/deserialize.ts @@ -25,10 +25,8 @@ import { colorChoices, iconChoicesByClass, } from '../../helpers/style_choices'; -import { - IndexPattern, - indexPatterns as indexPatternsUtils, -} from '../../../../../../src/plugins/data/public'; +import { indexPatterns as indexPatternsUtils } from '../../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../../src/plugins/data_views/public'; const defaultAdvancedSettings: AdvancedSettings = { useSignificance: true, @@ -98,7 +96,7 @@ export function lookupIndexPatternId(savedWorkspace: GraphWorkspaceSavedObject) } // returns all graph fields mapped out of the index pattern -export function mapFields(indexPattern: IndexPattern): WorkspaceField[] { +export function mapFields(indexPattern: DataView): WorkspaceField[] { const blockedFieldNames = ['_id', '_index', '_score', '_source', '_type']; const defaultHopSize = 5; @@ -131,10 +129,7 @@ export function mapFields(indexPattern: IndexPattern): WorkspaceField[] { }); } -function getFieldsWithWorkspaceSettings( - indexPattern: IndexPattern, - selectedFields: SerializedField[] -) { +function getFieldsWithWorkspaceSettings(indexPattern: DataView, selectedFields: SerializedField[]) { const allFields = mapFields(indexPattern); // merge in selected information into all fields @@ -216,7 +211,7 @@ export function makeNodeId(field: string, term: string) { export function savedWorkspaceToAppState( savedWorkspace: GraphWorkspaceSavedObject, - indexPattern: IndexPattern, + indexPattern: DataView, workspaceInstance: Workspace ): { urlTemplates: UrlTemplate[]; diff --git a/x-pack/plugins/graph/public/state_management/datasource.sagas.ts b/x-pack/plugins/graph/public/state_management/datasource.sagas.ts index 55e23c5e7c7c1..bbab3cd13b7a9 100644 --- a/x-pack/plugins/graph/public/state_management/datasource.sagas.ts +++ b/x-pack/plugins/graph/public/state_management/datasource.sagas.ts @@ -18,7 +18,7 @@ import { setDatasource, requestDatasource, } from './datasource'; -import { IndexPattern } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; /** * Saga loading field information when the datasource is switched. This will overwrite current settings @@ -34,7 +34,7 @@ export const datasourceSaga = ({ }: GraphStoreDependencies) => { function* fetchFields(action: Action) { try { - const indexPattern: IndexPattern = yield call(indexPatternProvider.get, action.payload.id); + const indexPattern: DataView = yield call(indexPatternProvider.get, action.payload.id); yield put(loadFields(mapFields(indexPattern))); yield put(datasourceLoaded()); const advancedSettings = settingsSelector(yield select()); diff --git a/x-pack/plugins/graph/public/state_management/datasource.test.ts b/x-pack/plugins/graph/public/state_management/datasource.test.ts index 00efe0c154732..ab37ed76ac08b 100644 --- a/x-pack/plugins/graph/public/state_management/datasource.test.ts +++ b/x-pack/plugins/graph/public/state_management/datasource.test.ts @@ -11,7 +11,7 @@ import { datasourceSelector, requestDatasource } from './datasource'; import { datasourceSaga } from './datasource.sagas'; import { fieldsSelector } from './fields'; import { updateSettings } from './advanced_settings'; -import { IndexPattern } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; const waitForPromise = () => new Promise((r) => setTimeout(r)); @@ -27,7 +27,7 @@ describe('datasource saga', () => { Promise.resolve({ title: 'test-pattern', getNonScriptedFields: () => [{ name: 'field1', type: 'string', isMapped: true }], - } as IndexPattern) + } as DataView) ), }, }, diff --git a/x-pack/plugins/graph/public/state_management/mocks.ts b/x-pack/plugins/graph/public/state_management/mocks.ts index 906bcde9070fc..06f9fe52f936a 100644 --- a/x-pack/plugins/graph/public/state_management/mocks.ts +++ b/x-pack/plugins/graph/public/state_management/mocks.ts @@ -16,7 +16,7 @@ import { createStore, applyMiddleware, AnyAction } from 'redux'; import { ChromeStart } from 'kibana/public'; import { GraphStoreDependencies, createRootReducer, GraphStore, GraphState } from './store'; import { Workspace } from '../types'; -import { IndexPattern } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; export interface MockedGraphEnvironment { store: GraphStore; @@ -63,7 +63,7 @@ export function createMockGraphStore({ if (id === 'missing-dataview') { throw Error('No data view with this id'); } - return { id: '123', title: 'test-pattern' } as unknown as IndexPattern; + return { id: '123', title: 'test-pattern' } as unknown as DataView; }), }, I18nContext: jest diff --git a/x-pack/plugins/graph/public/state_management/persistence.ts b/x-pack/plugins/graph/public/state_management/persistence.ts index d1e038bbb2102..d043df2510ed6 100644 --- a/x-pack/plugins/graph/public/state_management/persistence.ts +++ b/x-pack/plugins/graph/public/state_management/persistence.ts @@ -25,7 +25,7 @@ import { updateMetaData, metaDataSelector } from './meta_data'; import { openSaveModal, SaveWorkspaceHandler } from '../services/save_modal'; import { getEditPath } from '../services/url'; import { saveSavedWorkspace } from '../helpers/saved_workspace_utils'; -import type { IndexPattern } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; export interface LoadSavedWorkspacePayload { indexPatterns: IndexPatternSavedObject[]; @@ -68,7 +68,7 @@ export const loadingSaga = ({ const selectedIndexPatternId = lookupIndexPatternId(savedWorkspace); let indexPattern; try { - indexPattern = (yield call(indexPatternProvider.get, selectedIndexPatternId)) as IndexPattern; + indexPattern = (yield call(indexPatternProvider.get, selectedIndexPatternId)) as DataView; } catch (e) { notifications.toasts.addDanger( i18n.translate('xpack.graph.loadWorkspace.missingDataViewErrorMessage', { diff --git a/x-pack/plugins/graph/public/types/app_state.ts b/x-pack/plugins/graph/public/types/app_state.ts index 1ec21c4991a1b..0d707cef9543b 100644 --- a/x-pack/plugins/graph/public/types/app_state.ts +++ b/x-pack/plugins/graph/public/types/app_state.ts @@ -8,7 +8,7 @@ import { SimpleSavedObject } from 'src/core/public'; import { FontawesomeIcon } from '../helpers/style_choices'; import { OutlinkEncoder } from '../helpers/outlink_encoders'; -import type { IndexPattern } from '../../../../../src/plugins/data/public'; +import type { DataView } from '../../../../../src/plugins/data_views/public'; export interface UrlTemplate { url: string; @@ -41,5 +41,5 @@ export interface AdvancedSettings { export type IndexPatternSavedObject = SimpleSavedObject<{ title: string }>; export interface IndexPatternProvider { - get(id: string): Promise; + get(id: string): Promise; } From bc6a6e444ff12a37b7b267e0eb1a9302d2cbafb0 Mon Sep 17 00:00:00 2001 From: Sandra G Date: Tue, 29 Mar 2022 09:04:56 -0400 Subject: [PATCH 085/160] [Stack Monitoring] add monitoring.ui.elasticsearch.serviceAccountToken to docs (#128488) * monitoring.ui.elasticsearch.serviceAccountToken to docs * update description * update * update to make clearer * Update docs/settings/monitoring-settings.asciidoc Co-authored-by: Joe Portner <5295965+jportner@users.noreply.github.com> * Update docs/settings/monitoring-settings.asciidoc Co-authored-by: Joe Portner <5295965+jportner@users.noreply.github.com> Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> Co-authored-by: Joe Portner <5295965+jportner@users.noreply.github.com> --- docs/settings/monitoring-settings.asciidoc | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/docs/settings/monitoring-settings.asciidoc b/docs/settings/monitoring-settings.asciidoc index 8b469b1a90194..e78aeb6bac00b 100644 --- a/docs/settings/monitoring-settings.asciidoc +++ b/docs/settings/monitoring-settings.asciidoc @@ -50,10 +50,10 @@ cluster. `monitoring.ui.elasticsearch.username`:: Specifies the username used by {kib} monitoring to establish a persistent connection -in {kib} to the {es} monitoring cluster and to verify licensing status on the {es} -monitoring cluster. +in {kib} to the {es} monitoring cluster and to verify licensing status on the {es} +monitoring cluster when using `monitoring.ui.elasticsearch.hosts`. + -Every other request performed by *{stack-monitor-app}* to the monitoring {es} +All other requests performed by *{stack-monitor-app}* to the monitoring {es} cluster uses the authenticated user's credentials, which must be the same on both the {es} monitoring cluster and the {es} production cluster. + @@ -62,14 +62,17 @@ If not set, {kib} uses the value of the <> setting. +`monitoring.ui.elasticsearch.serviceAccountToken`:: +Specifies a {ref}/security-api-create-service-token.html[service account token] for the {es} cluster where your monitoring data is stored when using `monitoring.ui.elasticsearch.hosts`. This setting is an alternative to using `monitoring.ui.elasticsearch.username` and `monitoring.ui.elasticsearch.password`. + `monitoring.ui.elasticsearch.pingTimeout`:: Specifies the time in milliseconds to wait for {es} to respond to internal health checks. By default, it matches the <> setting, From 95ba4f8d93829bca37970b87e18bec9a7b43a062 Mon Sep 17 00:00:00 2001 From: Matthias Wilhelm Date: Tue, 29 Mar 2022 15:54:03 +0200 Subject: [PATCH 086/160] [Discover] Cleanup usage of deprecated APIs (#128713) --- .../actions/explore_data/explore_data_chart_action.test.ts | 3 +-- .../public/actions/explore_data/explore_data_chart_action.ts | 4 ++-- .../actions/explore_data/explore_data_context_menu_action.ts | 4 ++-- 3 files changed, 5 insertions(+), 6 deletions(-) diff --git a/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts b/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts index b8f44bdbc9a25..f4c6e89280274 100644 --- a/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts +++ b/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.test.ts @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ - +import type { Filter, RangeFilter } from '@kbn/es-query'; import { ExploreDataChartAction } from './explore_data_chart_action'; import { Params, PluginDeps } from './abstract_explore_data_action'; import { coreMock } from '../../../../../../src/core/public/mocks'; @@ -15,7 +15,6 @@ import { VISUALIZE_EMBEDDABLE_TYPE, } from '../../../../../../src/plugins/visualizations/public'; import { ViewMode } from '../../../../../../src/plugins/embeddable/public'; -import { Filter, RangeFilter } from '../../../../../../src/plugins/data/public'; import { DiscoverAppLocator } from '../../../../../../src/plugins/discover/public'; import { sharePluginMock } from '../../../../../../src/plugins/share/public/mocks'; diff --git a/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.ts b/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.ts index 4ab9146a06c55..df85390ba0493 100644 --- a/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.ts +++ b/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_chart_action.ts @@ -12,7 +12,7 @@ import { } from '../../../../../../src/plugins/discover/public'; import { ApplyGlobalFilterActionContext, - esFilters, + extractTimeRange, } from '../../../../../../src/plugins/data/public'; import { IEmbeddable } from '../../../../../../src/plugins/embeddable/public'; import { KibanaLocation } from '../../../../../../src/plugins/share/public'; @@ -55,7 +55,7 @@ export class ExploreDataChartAction } const { embeddable } = context; - const { restOfFilters: filters, timeRange } = esFilters.extractTimeRange( + const { restOfFilters: filters, timeRange } = extractTimeRange( context.filters, context.timeFieldName ); diff --git a/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts b/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts index 3580a3f191e6c..28f41fdb18711 100644 --- a/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts +++ b/x-pack/plugins/discover_enhanced/public/actions/explore_data/explore_data_context_menu_action.ts @@ -4,14 +4,14 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ - +import type { Filter } from '@kbn/es-query'; import { Action } from '../../../../../../src/plugins/ui_actions/public'; import { EmbeddableContext, EmbeddableInput, IEmbeddable, } from '../../../../../../src/plugins/embeddable/public'; -import { Query, Filter, TimeRange } from '../../../../../../src/plugins/data/public'; +import { Query, TimeRange } from '../../../../../../src/plugins/data/public'; import { DiscoverAppLocatorParams } from '../../../../../../src/plugins/discover/public'; import { KibanaLocation } from '../../../../../../src/plugins/share/public'; import * as shared from './shared'; From 3fc2a3940f1afc96ebad2b8bb2ce7545548ec5ae Mon Sep 17 00:00:00 2001 From: Milton Hultgren Date: Tue, 29 Mar 2022 16:29:50 +0200 Subject: [PATCH 087/160] [Infra Monitoring UI] Add docs for Stack Monitoring template versioning (#128762) * [Infra Monitoring UI] Add doc notes for Stack Monitoring template versioning * Add link to reference PR --- x-pack/plugins/monitoring/dev_docs/reference/indices.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/x-pack/plugins/monitoring/dev_docs/reference/indices.md b/x-pack/plugins/monitoring/dev_docs/reference/indices.md index 5f4fd5d498d9a..c1c95d26842a7 100644 --- a/x-pack/plugins/monitoring/dev_docs/reference/indices.md +++ b/x-pack/plugins/monitoring/dev_docs/reference/indices.md @@ -29,6 +29,10 @@ The index templates for `.monitoring-*` are shipped with and managed by Elastics To verify changes to these templates, either make them in place on a running cluster or run elasticsearch from source. +When updating the templates, it is important to increment the version number [here](https://github.com/elastic/elasticsearch/blob/main/x-pack/plugin/monitoring/src/main/java/org/elasticsearch/xpack/monitoring/MonitoringTemplateRegistry.java#L81). Elasticsearch uses this version number to decide if it should re-install the templates. +PRs should add the labels ":Data Management/Monitoring" and "Team:Data Management" to involve the right Elasticsearch members. +[Reference PR](https://github.com/elastic/elasticsearch/pull/85447) + The `metrics-*` and `metricbeat-*` mappings are managed by metricbeat and elastic agent, **code locations TBD**. ## Aliasing From 06fd7e76acef7a4d590cc40bf7ba61bba7cfe213 Mon Sep 17 00:00:00 2001 From: Or Ouziel Date: Tue, 29 Mar 2022 17:32:54 +0300 Subject: [PATCH 088/160] [Cloud Posture] add rules table flyout (#127887) --- .../public/pages/rules/rules_bottom_bar.tsx | 7 +- .../pages/rules/rules_container.test.tsx | 40 ++++- .../public/pages/rules/rules_container.tsx | 3 +- .../public/pages/rules/rules_flyout.tsx | 146 +++++++++++++++++- .../public/pages/rules/rules_table.tsx | 20 +-- .../public/pages/rules/test_subjects.ts | 6 + .../public/pages/rules/translations.ts | 24 +++ 7 files changed, 218 insertions(+), 28 deletions(-) diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_bottom_bar.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_bottom_bar.tsx index ebf4913f895c3..1cd860f74fbbe 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_bottom_bar.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_bottom_bar.tsx @@ -16,7 +16,12 @@ interface RulesBottomBarProps { } export const RulesBottomBar = ({ onSave, onCancel, isLoading }: RulesBottomBarProps) => ( - + diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.test.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.test.tsx index bcbc4d5c4bd44..7782be9c4917e 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.test.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.test.tsx @@ -7,7 +7,7 @@ import React from 'react'; import { RulesContainer } from './rules_container'; -import { render, screen, fireEvent } from '@testing-library/react'; +import { render, screen, fireEvent, within } from '@testing-library/react'; import { QueryClient } from 'react-query'; import { useFindCspRules, useBulkUpdateCspRules, type RuleSavedObject } from './use_csp_rules'; import * as TEST_SUBJECTS from './test_subjects'; @@ -38,7 +38,7 @@ const getRuleMock = ({ id = chance.guid(), enabled }: { id?: string; enabled: bo updatedAt: chance.date().toISOString(), attributes: { id, - name: chance.word(), + name: chance.sentence(), enabled, }, } as RuleSavedObject); @@ -336,4 +336,40 @@ describe('', () => { })) ); }); + + it('updates the rules from within the flyout', () => { + const Wrapper = getWrapper(); + const enabled = true; + const rules = Array.from({ length: 20 }, () => getRuleMock({ enabled })); + + (useFindCspRules as jest.Mock).mockReturnValue({ + status: 'success', + data: { + total: rules.length, + savedObjects: rules, + }, + }); + + render( + + + + ); + + const rule = rules[0]; + const rowId = TEST_SUBJECTS.getCspRulesTableRowItemTestId(rule.id); + const switchId = TEST_SUBJECTS.getCspRulesTableItemSwitchTestId(rule.id); + + fireEvent.click(screen.getByTestId(rowId)); // open flyout + + const flyout = screen.getByTestId(TEST_SUBJECTS.CSP_RULES_FLYOUT_CONTAINER); + + fireEvent.click(within(flyout).getByTestId(switchId)); // change to !enabled + fireEvent.click(screen.getByTestId(TEST_SUBJECTS.CSP_RULES_SAVE_BUTTON)); // save + + const { mutate } = useBulkUpdateCspRules(); + + expect(mutate).toHaveBeenCalledTimes(1); + expect(mutate).toHaveBeenCalledWith([{ ...rule.attributes, enabled: !enabled }]); + }); }); diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.tsx index 9780f9ecd3778..96659337e0c1a 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_container.tsx @@ -214,8 +214,9 @@ export const RulesContainer = () => { )} {selectedRuleId && ( setSelectedRuleId(null)} + toggleRule={toggleRule} /> )} diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_flyout.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_flyout.tsx index 8e8e0e37eed0d..54657660c7aa4 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_flyout.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_flyout.tsx @@ -4,23 +4,155 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import React from 'react'; -import { EuiSpacer, EuiFlyout, EuiFlyoutHeader, EuiFlyoutBody } from '@elastic/eui'; +import React, { useState } from 'react'; +import { + EuiSpacer, + EuiFlyout, + type EuiDescriptionListProps, + EuiToolTip, + EuiFlyoutHeader, + EuiFlyoutBody, + EuiTab, + EuiTabs, + EuiTitle, + EuiDescriptionList, + EuiFlexItem, + EuiFlexGroup, + EuiSwitch, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; import type { RuleSavedObject } from './use_csp_rules'; +import * as TEXT from './translations'; +import * as TEST_SUBJECTS from './test_subjects'; -interface FindingFlyoutProps { +interface RuleFlyoutProps { onClose(): void; + toggleRule(rule: RuleSavedObject): void; rule: RuleSavedObject; } -export const RuleFlyout = ({ onClose, rule }: FindingFlyoutProps) => { +const tabs = [ + { label: TEXT.OVERVIEW, id: 'overview', disabled: false }, + { label: TEXT.REMEDIATION, id: 'remediation', disabled: false }, + { label: TEXT.REGO_CODE, id: 'rego', disabled: true }, +] as const; + +type RuleTab = typeof tabs[number]['id']; + +const getOverviewCard = (rule: RuleSavedObject): EuiDescriptionListProps['listItems'] => [ + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.frameworkSourcesLabel', { + defaultMessage: 'Framework Sources', + }), + description: '-', // TODO: add value + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.sectionsLabel', { + defaultMessage: 'Sections', + }), + description: '-', // TODO: add value + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.profileApplicabilityLabel', { + defaultMessage: 'Profile Applicability', + }), + description: rule.attributes.description || '', + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.auditLabel', { + defaultMessage: 'Audit', + }), + description: '-', // TODO: add value + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.referencesLabel', { + defaultMessage: 'References', + }), + description: '-', // TODO: add value + }, +]; + +const getRemediationCard = (rule: RuleSavedObject): EuiDescriptionListProps['listItems'] => [ + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.remediationLabel', { + defaultMessage: 'Remediation', + }), + description: rule.attributes.remediation, + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.impactLabel', { + defaultMessage: 'Impact', + }), + description: rule.attributes.impact, + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.defaultValueLabel', { + defaultMessage: 'Default Value', + }), + description: rule.attributes.default_value, + }, + { + title: i18n.translate('xpack.csp.rules.ruleFlyout.rationaleLabel', { + defaultMessage: 'Rationale', + }), + description: rule.attributes.rationale, + }, +]; + +export const RuleFlyout = ({ onClose, rule, toggleRule }: RuleFlyoutProps) => { + const [tab, setTab] = useState('overview'); + return ( - + -

{rule.attributes.name}

+ +

{rule.attributes.name}

+
+ + {tabs.map((item) => ( + setTab(item.id)} + disabled={item.disabled} + > + {item.label} + + ))} +
- + + {tab === 'overview' && toggleRule(rule)} />} + {tab === 'remediation' && ( + + )} +
); }; + +const RuleOverviewTab = ({ rule, toggleRule }: { rule: RuleSavedObject; toggleRule(): void }) => ( + + + + + + + + + + + + +); diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_table.tsx b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_table.tsx index e8fd704e124f4..c577daebb58a6 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_table.tsx +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/rules_table.tsx @@ -16,7 +16,6 @@ import { useEuiTheme, } from '@elastic/eui'; import moment from 'moment'; -import { FormattedMessage } from '@kbn/i18n-react'; import type { RulesState } from './rules_container'; import * as TEST_SUBJECTS from './test_subjects'; import * as TEXT from './translations'; @@ -60,7 +59,6 @@ export const RulesTable = ({ pageSize, totalItemCount: total, pageSizeOptions: [1, 5, 10, 25], - showPerPageOptions: true, }; const selection: EuiBasicTableProps['selection'] = { @@ -74,6 +72,7 @@ export const RulesTable = ({ }; const rowProps = (row: RuleSavedObject) => ({ + ['data-test-subj']: TEST_SUBJECTS.getCspRulesTableRowItemTestId(row.id), style: { background: row.id === selectedRuleId ? euiTheme.colors.highlight : undefined }, onClick: (e: MouseEvent) => { const tag = (e.target as HTMLDivElement).tagName; @@ -122,6 +121,7 @@ const getColumns = ({ e.stopPropagation(); setSelectedRuleId(rule.id); }} + data-test-subj={TEST_SUBJECTS.CSP_RULES_TABLE_ROW_ITEM_NAME} > {name} @@ -142,21 +142,7 @@ const getColumns = ({ field: 'attributes.enabled', name: TEXT.ENABLED, render: (enabled, rule) => ( - - ) : ( - - ) - } - > + `${CSP_RULES_TABLE_ITEM_SWITCH}_${id}`; + +export const getCspRulesTableRowItemTestId = (id: string) => + `${CSP_RULES_TABLE_ROW_ITEM_NAME}_${id}`; diff --git a/x-pack/plugins/cloud_security_posture/public/pages/rules/translations.ts b/x-pack/plugins/cloud_security_posture/public/pages/rules/translations.ts index 8523e0afc06c5..a10e4b2efc1fb 100644 --- a/x-pack/plugins/cloud_security_posture/public/pages/rules/translations.ts +++ b/x-pack/plugins/cloud_security_posture/public/pages/rules/translations.ts @@ -56,6 +56,18 @@ export const ENABLE = i18n.translate('xpack.csp.rules.enableLabel', { defaultMessage: 'Enable', }); +export const DEACTIVATE = i18n.translate('xpack.csp.rules.deactivateLabel', { + defaultMessage: 'Deactivate', +}); + +export const ACTIVATE = i18n.translate('xpack.csp.rules.activateLabel', { + defaultMessage: 'Activate', +}); + +export const ACTIVATED = i18n.translate('xpack.csp.rules.activatedLabel', { + defaultMessage: 'Activated', +}); + export const MISSING_RULES = i18n.translate('xpack.csp.rules.missingRulesMessage', { defaultMessage: 'Rules are missing', }); @@ -63,3 +75,15 @@ export const MISSING_RULES = i18n.translate('xpack.csp.rules.missingRulesMessage export const UPDATE_FAILED = i18n.translate('xpack.csp.rules.updateFailedMessage', { defaultMessage: 'Update failed', }); + +export const OVERVIEW = i18n.translate('xpack.csp.rules.ruleFlyout.tabs.overviewTabLabel', { + defaultMessage: 'Overview', +}); + +export const REGO_CODE = i18n.translate('xpack.csp.rules.ruleFlyout.tabs.regoCodeTabLabel', { + defaultMessage: 'Rego Code', +}); + +export const REMEDIATION = i18n.translate('xpack.csp.rules.ruleFlyout.tabs.remediationTabLabel', { + defaultMessage: 'Remediation', +}); From 5cf462bad7e0bbc020daadedd53d611534bfc427 Mon Sep 17 00:00:00 2001 From: Madison Caldwell Date: Tue, 29 Mar 2022 10:35:31 -0400 Subject: [PATCH 089/160] Add fixtures generated by kbn-gen-fixtures (#128419) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../tests/alerts/alerts_compatibility.ts | 416 +- .../security_solution/alerts/7.16.0/data.json | 3590 ++++++++++ .../alerts/7.16.0/mappings.json | 5819 +++++++++++++++++ 3 files changed, 9608 insertions(+), 217 deletions(-) create mode 100644 x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/data.json create mode 100644 x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/mappings.json diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/alerts/alerts_compatibility.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/alerts/alerts_compatibility.ts index 889396c2b6125..953dfb42b7b46 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/alerts/alerts_compatibility.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/alerts/alerts_compatibility.ts @@ -46,21 +46,6 @@ export default ({ getService }: FtrProviderContext) => { const supertest = getService('supertest'); describe('Alerts Compatibility', function () { - beforeEach(async () => { - await esArchiver.load( - 'x-pack/test/functional/es_archives/security_solution/legacy_cti_signals' - ); - await createSignalsIndex(supertest, log); - }); - - afterEach(async () => { - await esArchiver.unload( - 'x-pack/test/functional/es_archives/security_solution/legacy_cti_signals' - ); - await deleteSignalsIndex(supertest, log); - await deleteAllAlerts(supertest, log); - }); - describe('CTI', () => { const expectedDomain = 'elastic.local'; const expectedProvider = 'provider1'; @@ -72,6 +57,21 @@ export default ({ getService }: FtrProviderContext) => { type: 'indicator_match_rule', }; + beforeEach(async () => { + await esArchiver.load( + 'x-pack/test/functional/es_archives/security_solution/legacy_cti_signals' + ); + await createSignalsIndex(supertest, log); + }); + + afterEach(async () => { + await esArchiver.unload( + 'x-pack/test/functional/es_archives/security_solution/legacy_cti_signals' + ); + await deleteSignalsIndex(supertest, log); + await deleteAllAlerts(supertest, log); + }); + it('allows querying of legacy enriched signals by threat.indicator', async () => { const { body: { @@ -208,6 +208,19 @@ export default ({ getService }: FtrProviderContext) => { }); describe('Query', () => { + beforeEach(async () => { + await esArchiver.load('x-pack/test/functional/es_archives/security_solution/alerts/7.16.0'); + await createSignalsIndex(supertest, log); + }); + + afterEach(async () => { + await esArchiver.unload( + 'x-pack/test/functional/es_archives/security_solution/alerts/7.16.0' + ); + await deleteSignalsIndex(supertest, log); + await deleteAllAlerts(supertest, log); + }); + it('should generate a signal-on-legacy-signal with legacy index pattern', async () => { const rule: QueryCreateSchema = getRuleForSignalTesting([`.siem-signals-*`]); const { id } = await createRule(supertest, log, rule); @@ -236,121 +249,87 @@ export default ({ getService }: FtrProviderContext) => { 'kibana.space_ids': ['default'], 'kibana.alert.rule.tags': [], agent: { - ephemeral_id: '07c24b1e-3663-4372-b982-f2d831e033eb', - hostname: 'elastic.local', - id: 'ce7741d9-3f0a-466d-8ae6-d7d8f883fcec', - name: 'elastic.local', - type: 'auditbeat', - version: '7.14.0', + name: 'security-linux-1.example.dev', + id: 'd8f66724-3cf2-437c-b124-6ac9fb0e2311', + type: 'filebeat', + version: '7.16.0', }, - ecs: { version: '1.10.0' }, - host: { - architecture: 'x86_64', - hostname: 'elastic.local', - id: '1633D595-A115-5BF5-870B-A471B49446C3', - ip: ['192.168.1.1'], - mac: ['aa:bb:cc:dd:ee:ff'], - name: 'elastic.local', - os: { - build: '20G80', - family: 'darwin', - kernel: '20.6.0', - name: 'Mac OS X', - platform: 'darwin', - type: 'macos', - version: '10.16', + log: { + file: { + path: '/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson', }, + offset: 148938, }, - message: 'Process mdworker_shared (PID: 32306) by user elastic STARTED', - process: { - args: [ - '/System/Library/Frameworks/CoreServices.framework/Frameworks/Metadata.framework/Versions/A/Support/mdworker_shared', - '-s', - 'mdworker', - '-c', - 'MDSImporterWorker', - '-m', - 'com.apple.mdworker.shared', - ], - entity_id: 'wfc7zUuEinqxUbZ6', - executable: - '/System/Library/Frameworks/CoreServices.framework/Frameworks/Metadata.framework/Versions/A/Support/mdworker_shared', - hash: { sha1: '5f3233fd75c14b315731684d59b632df36a731a6' }, - name: 'mdworker_shared', - pid: 32306, - ppid: 1, - start: '2021-08-04T04:14:48.830Z', - working_directory: '/', + cloud: { + availability_zone: 'us-central1-c', + instance: { + name: 'security-linux-1', + id: '8995531128842994872', + }, + provider: 'gcp', + service: { + name: 'GCE', + }, + machine: { + type: 'g1-small', + }, + project: { + id: 'elastic-siem', + }, + account: { + id: 'elastic-siem', + }, }, - service: { type: 'system' }, - threat: { - indicator: [ - { - domain: 'elastic.local', - event: { - category: 'threat', - created: '2021-08-04T03:53:30.761Z', - dataset: 'ti_abusech.malware', - ingested: '2021-08-04T03:53:37.514040Z', - kind: 'enrichment', - module: 'threatintel', - reference: 'https://urlhaus.abuse.ch/url/12345/', - type: 'indicator', - }, - first_seen: '2021-08-03T20:35:17.000Z', - matched: { - atomic: 'elastic.local', - field: 'host.name', - id: '_tdUD3sBcVT20cvWAkpd', - index: 'filebeat-7.14.0-2021.08.04-000001', - type: 'indicator_match_rule', - }, - provider: 'provider1', - type: 'url', - url: { - domain: 'elastic.local', - extension: 'php', - full: 'http://elastic.local/thing', - original: 'http://elastic.local/thing', - path: '/thing', - scheme: 'http', - }, - }, - ], + ecs: { + version: '7.16.0', + }, + host: { + hostname: 'security-linux-1', + os: { + kernel: '4.19.0-18-cloud-amd64', + codename: 'buster', + name: 'Debian GNU/Linux', + type: 'linux', + family: 'debian', + version: '10 (buster)', + platform: 'debian', + }, + containerized: false, + ip: '11.200.0.194', + name: 'security-linux-1', + architecture: 'x86_64', }, - user: { - effective: { group: { id: '20' }, id: '501' }, - group: { id: '20', name: 'staff' }, - id: '501', - name: 'elastic', - saved: { group: { id: '20' }, id: '501' }, + 'service.name': 'filebeat', + message: 'Status message.', + data_stream: { + namespace: 'default', + type: 'logs', + dataset: 'elastic_agent.filebeat', }, - 'event.action': 'process_started', - 'event.category': ['process'], - 'event.dataset': 'process', + 'event.agent_id_status': 'verified', + 'event.ingested': '2022-03-23T16:50:28.994Z', + 'event.dataset': 'elastic_agent.filebeat', 'event.kind': 'signal', - 'event.module': 'system', - 'event.type': ['start'], 'kibana.alert.ancestors': [ { - depth: 0, - id: 'yNdfD3sBcVT20cvWFEs2', - index: 'auditbeat-7.14.0-2021.08.04-000001', + id: 'Nmyvt38BIyEvspK02HTJ', type: 'event', + index: 'events-index-000001', + depth: 0, }, { - id: '0527411874b23bcea85daf5bf7dcacd144536ba6d92d3230a4a0acfb7de7f512', + id: '5cddda6852c5f8b6c32d4bfa5e876aa51884e0c7a2d4faaababf91ec9cb68de7', type: 'signal', - index: '.siem-signals-default-000001', + index: '.siem-signals-default-000001-7.16.0', depth: 1, - rule: '832f86f0-f4da-11eb-989d-b758d09dbc85', + rule: '5b7cd9a0-aac9-11ec-bb53-fd375b7a173a', }, ], 'kibana.alert.status': 'active', 'kibana.alert.workflow_status': 'open', 'kibana.alert.depth': 2, 'kibana.alert.reason': - 'process event with process mdworker_shared, by elastic on elastic.local created high alert Signal Testing Query.', + 'event on security-linux-1 created high alert Signal Testing Query.', 'kibana.alert.severity': 'high', 'kibana.alert.risk_score': 1, 'kibana.alert.rule.parameters': { @@ -397,13 +376,11 @@ export default ({ getService }: FtrProviderContext) => { 'kibana.alert.rule.version': 1, 'kibana.alert.rule.exceptions_list': [], 'kibana.alert.rule.immutable': false, - 'kibana.alert.original_time': '2021-08-04T04:14:58.973Z', - 'kibana.alert.original_event.action': 'process_started', - 'kibana.alert.original_event.category': ['process'], - 'kibana.alert.original_event.dataset': 'process', + 'kibana.alert.original_time': '2022-03-23T16:50:40.440Z', + 'kibana.alert.original_event.agent_id_status': 'verified', + 'kibana.alert.original_event.ingested': '2022-03-23T16:50:28.994Z', + 'kibana.alert.original_event.dataset': 'elastic_agent.filebeat', 'kibana.alert.original_event.kind': 'signal', - 'kibana.alert.original_event.module': 'system', - 'kibana.alert.original_event.type': ['start'], }); }); @@ -437,121 +414,87 @@ export default ({ getService }: FtrProviderContext) => { 'kibana.space_ids': ['default'], 'kibana.alert.rule.tags': [], agent: { - ephemeral_id: '07c24b1e-3663-4372-b982-f2d831e033eb', - hostname: 'elastic.local', - id: 'ce7741d9-3f0a-466d-8ae6-d7d8f883fcec', - name: 'elastic.local', - type: 'auditbeat', - version: '7.14.0', + name: 'security-linux-1.example.dev', + id: 'd8f66724-3cf2-437c-b124-6ac9fb0e2311', + type: 'filebeat', + version: '7.16.0', }, - ecs: { version: '1.10.0' }, - host: { - architecture: 'x86_64', - hostname: 'elastic.local', - id: '1633D595-A115-5BF5-870B-A471B49446C3', - ip: ['192.168.1.1'], - mac: ['aa:bb:cc:dd:ee:ff'], - name: 'elastic.local', - os: { - build: '20G80', - family: 'darwin', - kernel: '20.6.0', - name: 'Mac OS X', - platform: 'darwin', - type: 'macos', - version: '10.16', + log: { + file: { + path: '/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson', }, + offset: 148938, }, - message: 'Process mdworker_shared (PID: 32306) by user elastic STARTED', - process: { - args: [ - '/System/Library/Frameworks/CoreServices.framework/Frameworks/Metadata.framework/Versions/A/Support/mdworker_shared', - '-s', - 'mdworker', - '-c', - 'MDSImporterWorker', - '-m', - 'com.apple.mdworker.shared', - ], - entity_id: 'wfc7zUuEinqxUbZ6', - executable: - '/System/Library/Frameworks/CoreServices.framework/Frameworks/Metadata.framework/Versions/A/Support/mdworker_shared', - hash: { sha1: '5f3233fd75c14b315731684d59b632df36a731a6' }, - name: 'mdworker_shared', - pid: 32306, - ppid: 1, - start: '2021-08-04T04:14:48.830Z', - working_directory: '/', + cloud: { + availability_zone: 'us-central1-c', + instance: { + name: 'security-linux-1', + id: '8995531128842994872', + }, + provider: 'gcp', + service: { + name: 'GCE', + }, + machine: { + type: 'g1-small', + }, + project: { + id: 'elastic-siem', + }, + account: { + id: 'elastic-siem', + }, }, - service: { type: 'system' }, - threat: { - indicator: [ - { - domain: 'elastic.local', - event: { - category: 'threat', - created: '2021-08-04T03:53:30.761Z', - dataset: 'ti_abusech.malware', - ingested: '2021-08-04T03:53:37.514040Z', - kind: 'enrichment', - module: 'threatintel', - reference: 'https://urlhaus.abuse.ch/url/12345/', - type: 'indicator', - }, - first_seen: '2021-08-03T20:35:17.000Z', - matched: { - atomic: 'elastic.local', - field: 'host.name', - id: '_tdUD3sBcVT20cvWAkpd', - index: 'filebeat-7.14.0-2021.08.04-000001', - type: 'indicator_match_rule', - }, - provider: 'provider1', - type: 'url', - url: { - domain: 'elastic.local', - extension: 'php', - full: 'http://elastic.local/thing', - original: 'http://elastic.local/thing', - path: '/thing', - scheme: 'http', - }, - }, - ], + ecs: { + version: '7.16.0', + }, + host: { + hostname: 'security-linux-1', + os: { + kernel: '4.19.0-18-cloud-amd64', + codename: 'buster', + name: 'Debian GNU/Linux', + type: 'linux', + family: 'debian', + version: '10 (buster)', + platform: 'debian', + }, + containerized: false, + ip: '11.200.0.194', + name: 'security-linux-1', + architecture: 'x86_64', }, - user: { - effective: { group: { id: '20' }, id: '501' }, - group: { id: '20', name: 'staff' }, - id: '501', - name: 'elastic', - saved: { group: { id: '20' }, id: '501' }, + 'service.name': 'filebeat', + message: 'Status message.', + data_stream: { + namespace: 'default', + type: 'logs', + dataset: 'elastic_agent.filebeat', }, - 'event.action': 'process_started', - 'event.category': ['process'], - 'event.dataset': 'process', + 'event.agent_id_status': 'verified', + 'event.ingested': '2022-03-23T16:50:28.994Z', + 'event.dataset': 'elastic_agent.filebeat', 'event.kind': 'signal', - 'event.module': 'system', - 'event.type': ['start'], 'kibana.alert.ancestors': [ { - depth: 0, - id: 'yNdfD3sBcVT20cvWFEs2', - index: 'auditbeat-7.14.0-2021.08.04-000001', + id: 'Nmyvt38BIyEvspK02HTJ', type: 'event', + index: 'events-index-000001', + depth: 0, }, { - id: '0527411874b23bcea85daf5bf7dcacd144536ba6d92d3230a4a0acfb7de7f512', + id: '5cddda6852c5f8b6c32d4bfa5e876aa51884e0c7a2d4faaababf91ec9cb68de7', type: 'signal', - index: '.siem-signals-default-000001', + index: '.siem-signals-default-000001-7.16.0', depth: 1, - rule: '832f86f0-f4da-11eb-989d-b758d09dbc85', + rule: '5b7cd9a0-aac9-11ec-bb53-fd375b7a173a', }, ], 'kibana.alert.status': 'active', 'kibana.alert.workflow_status': 'open', 'kibana.alert.depth': 2, 'kibana.alert.reason': - 'process event with process mdworker_shared, by elastic on elastic.local created high alert Signal Testing Query.', + 'event on security-linux-1 created high alert Signal Testing Query.', 'kibana.alert.severity': 'high', 'kibana.alert.risk_score': 1, 'kibana.alert.rule.parameters': { @@ -598,18 +541,29 @@ export default ({ getService }: FtrProviderContext) => { 'kibana.alert.rule.version': 1, 'kibana.alert.rule.exceptions_list': [], 'kibana.alert.rule.immutable': false, - 'kibana.alert.original_time': '2021-08-04T04:14:58.973Z', - 'kibana.alert.original_event.action': 'process_started', - 'kibana.alert.original_event.category': ['process'], - 'kibana.alert.original_event.dataset': 'process', + 'kibana.alert.original_time': '2022-03-23T16:50:40.440Z', + 'kibana.alert.original_event.agent_id_status': 'verified', + 'kibana.alert.original_event.ingested': '2022-03-23T16:50:28.994Z', + 'kibana.alert.original_event.dataset': 'elastic_agent.filebeat', 'kibana.alert.original_event.kind': 'signal', - 'kibana.alert.original_event.module': 'system', - 'kibana.alert.original_event.type': ['start'], }); }); }); describe('Saved Query', () => { + beforeEach(async () => { + await esArchiver.load('x-pack/test/functional/es_archives/security_solution/alerts/7.16.0'); + await createSignalsIndex(supertest, log); + }); + + afterEach(async () => { + await esArchiver.unload( + 'x-pack/test/functional/es_archives/security_solution/alerts/7.16.0' + ); + await deleteSignalsIndex(supertest, log); + await deleteAllAlerts(supertest, log); + }); + it('should generate a signal-on-legacy-signal with legacy index pattern', async () => { const rule: SavedQueryCreateSchema = getSavedQueryRuleForSignalTesting([`.siem-signals-*`]); const { id } = await createRule(supertest, log, rule); @@ -636,6 +590,19 @@ export default ({ getService }: FtrProviderContext) => { }); describe('EQL', () => { + beforeEach(async () => { + await esArchiver.load('x-pack/test/functional/es_archives/security_solution/alerts/7.16.0'); + await createSignalsIndex(supertest, log); + }); + + afterEach(async () => { + await esArchiver.unload( + 'x-pack/test/functional/es_archives/security_solution/alerts/7.16.0' + ); + await deleteSignalsIndex(supertest, log); + await deleteAllAlerts(supertest, log); + }); + it('should generate a signal-on-legacy-signal with legacy index pattern', async () => { const rule: EqlCreateSchema = getEqlRuleForSignalTesting(['.siem-signals-*']); const { id } = await createRule(supertest, log, rule); @@ -662,6 +629,19 @@ export default ({ getService }: FtrProviderContext) => { }); describe('Threshold', () => { + beforeEach(async () => { + await esArchiver.load('x-pack/test/functional/es_archives/security_solution/alerts/7.16.0'); + await createSignalsIndex(supertest, log); + }); + + afterEach(async () => { + await esArchiver.unload( + 'x-pack/test/functional/es_archives/security_solution/alerts/7.16.0' + ); + await deleteSignalsIndex(supertest, log); + await deleteAllAlerts(supertest, log); + }); + it('should generate a signal-on-legacy-signal with legacy index pattern', async () => { const baseRule: ThresholdCreateSchema = getThresholdRuleForSignalTesting([ '.siem-signals-*', @@ -670,6 +650,7 @@ export default ({ getService }: FtrProviderContext) => { ...baseRule, threshold: { ...baseRule.threshold, + field: 'host.name', value: 1, }, }; @@ -690,6 +671,7 @@ export default ({ getService }: FtrProviderContext) => { ...baseRule, threshold: { ...baseRule.threshold, + field: 'host.name', value: 1, }, }; diff --git a/x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/data.json b/x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/data.json new file mode 100644 index 0000000000000..9f15ea353570e --- /dev/null +++ b/x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/data.json @@ -0,0 +1,3590 @@ +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "0bb0c0d5488d757907f6be6e4c27ff698666948e2cf01d53e8fa43958b36c6a8", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:32.045Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.493Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-1", + "field": "host.name", + "id": "M2yvt38BIyEvspK01XQt", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "P2yvt38BIyEvspK05HSe", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "P2yvt38BIyEvspK05HSe", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-1 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "P2yvt38BIyEvspK05HSe", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:32.045Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:32.045Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "0dd11069ba6c63ec60ac902d6fb0a8a52c4f5ab20f03babe7b861c6d34431bad", + "source": { + "agent": { + "name": "security-linux-3.example.dev", + "id": "06851da1-73e7-41e3-97d6-ff1d62c98dc5", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-3", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.196", + "name": "security-linux-3", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.654Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.495Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-3", + "field": "host.name", + "id": "NWyvt38BIyEvspK013R3", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "Pmyvt38BIyEvspK043Ri", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "Pmyvt38BIyEvspK043Ri", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-3 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "Pmyvt38BIyEvspK043Ri", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.654Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.654Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "999fef09ceb58f30dcbbe2a5fd410f8a22dda6179fa5f1041c7a759a31932ef9", + "source": { + "agent": { + "name": "security-linux-2.example.dev", + "id": "87c417dd-08d6-4e24-ad69-285cb8de84e9", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-2", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.195", + "name": "security-linux-2", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.330Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.496Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-2", + "field": "host.name", + "id": "NGyvt38BIyEvspK01nQn", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "PWyvt38BIyEvspK04XTd", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "PWyvt38BIyEvspK04XTd", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-2 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "PWyvt38BIyEvspK04XTd", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.330Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.330Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "f75bc411e6b0c30c26aa310c1e65ff8430cc0a98ddf74c335941dd7456858e85", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.001Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.497Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-1", + "field": "host.name", + "id": "M2yvt38BIyEvspK01XQt", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "PGyvt38BIyEvspK04HSX", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "PGyvt38BIyEvspK04HSX", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-1 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "PGyvt38BIyEvspK04HSX", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.001Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.001Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "b46b35ce011486304a3a1e1b1dc2b772e2b80684a3a8663e9cd101691cff7429", + "source": { + "agent": { + "name": "security-linux-3.example.dev", + "id": "06851da1-73e7-41e3-97d6-ff1d62c98dc5", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-3", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.196", + "name": "security-linux-3", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.665Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.498Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-3", + "field": "host.name", + "id": "NWyvt38BIyEvspK013R3", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "O2yvt38BIyEvspK033RN", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "O2yvt38BIyEvspK033RN", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-3 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "O2yvt38BIyEvspK033RN", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:30.665Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.665Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "570caf7637457b9721fd46ec22166adb57916298bf68ef31df07bd0bbac95d7c", + "source": { + "agent": { + "name": "security-linux-2.example.dev", + "id": "87c417dd-08d6-4e24-ad69-285cb8de84e9", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-2", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.195", + "name": "security-linux-2", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.353Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.499Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-2", + "field": "host.name", + "id": "NGyvt38BIyEvspK01nQn", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "Omyvt38BIyEvspK03nQB", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "Omyvt38BIyEvspK03nQB", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-2 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "Omyvt38BIyEvspK03nQB", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:30.353Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.353Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "0c7bfb7198c9db281b639b1044c74db2b881e3152ee863e6c9304a6fb5d0e5bb", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.031Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.501Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-1", + "field": "host.name", + "id": "M2yvt38BIyEvspK01XQt", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "OWyvt38BIyEvspK03HTF", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "OWyvt38BIyEvspK03HTF", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-1 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "OWyvt38BIyEvspK03HTF", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:30.031Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.031Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "ae1c6e5c7680cdc986ff52b1913e93ba2a010ea207364d4782550adf180e49ee", + "source": { + "agent": { + "name": "security-linux-3.example.dev", + "id": "06851da1-73e7-41e3-97d6-ff1d62c98dc5", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-3", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.196", + "name": "security-linux-3", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.715Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.502Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-3", + "field": "host.name", + "id": "NWyvt38BIyEvspK013R3", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "OGyvt38BIyEvspK023SI", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "OGyvt38BIyEvspK023SI", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-3 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "OGyvt38BIyEvspK023SI", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:29.715Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.715Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "a73fda6bdb25425c8597f63e2b87b662798ad46f195c47ac4243d9d0b9705dd8", + "source": { + "agent": { + "name": "security-linux-2.example.dev", + "id": "87c417dd-08d6-4e24-ad69-285cb8de84e9", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-2", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.195", + "name": "security-linux-2", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.387Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.503Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-2", + "field": "host.name", + "id": "NGyvt38BIyEvspK01nQn", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "N2yvt38BIyEvspK02nRK", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "N2yvt38BIyEvspK02nRK", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-2 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "N2yvt38BIyEvspK02nRK", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:29.387Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.387Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "77038fe81327ce7b578e69896fdd1869fab16d13633b5fb0cb7743bae9120ca5", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:28.994Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:51.504Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "threat": { + "enrichments": [ + { + "indicator": {}, + "matched": { + "atomic": "security-linux-1", + "field": "host.name", + "id": "M2yvt38BIyEvspK01XQt", + "index": "threat-index-000001", + "type": "indicator_match_rule" + } + } + ] + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "Nmyvt38BIyEvspK02HTJ", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "Nmyvt38BIyEvspK02HTJ", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "62f9a8c0-aac9-11ec-aa31-c9ea2cb79db7", + "actions": [], + "interval": "1m", + "name": "threat-match-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:47.264Z", + "updated_at": "2022-03-23T16:50:48.396Z", + "description": "a simple threat match rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "bef9b0da-8c2f-4b82-930f-37ffa1b57fc1", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threat_match", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threat_query": "*", + "threat_mapping": [ + { + "entries": [ + { + "field": "host.name", + "type": "mapping", + "value": "host.name" + } + ] + } + ], + "threat_language": "kuery", + "threat_index": [ + "threat-index-*" + ], + "threat_indicator_path": "threat.indicator" + }, + "reason": "event on security-linux-1 created low alert threat-match-rule.", + "depth": 1, + "parent": { + "id": "Nmyvt38BIyEvspK02HTJ", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:28.994Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:28.994Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "21d26a1ad7b01b28667638d5f8db96f6e94957394efe7a16057948095a445ac4", + "source": { + "@timestamp": "2022-03-23T16:50:48.441Z", + "host.name": "security-linux-1", + "event": { + "kind": "signal" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "8e75aa13-6b35-5d96-b52b-1d62909a9d75", + "type": "event", + "index": "events-index-*", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "8e75aa13-6b35-5d96-b52b-1d62909a9d75", + "type": "event", + "index": "events-index-*", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "60b8b970-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "threshold-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:44.260Z", + "updated_at": "2022-03-23T16:50:45.341Z", + "description": "a simple threshold rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "b97ae2a4-f188-43b2-b082-69667b563152", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threshold", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threshold": { + "field": [ + "host.name" + ], + "value": 1 + } + }, + "reason": "event created low alert threshold-rule.", + "depth": 1, + "parent": { + "id": "8e75aa13-6b35-5d96-b52b-1d62909a9d75", + "type": "event", + "index": "events-index-*", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:32.045Z", + "threshold_result": { + "terms": [ + { + "field": "host.name", + "value": "security-linux-1" + } + ], + "count": 4, + "from": "2022-03-23T06:50:48.395Z" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "4c2a3865ca7df72e4cc17b5114feb2535b2459fd52f6fbd0669d4884f5956dc2", + "source": { + "@timestamp": "2022-03-23T16:50:48.442Z", + "host.name": "security-linux-2", + "event": { + "kind": "signal" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "9c957c24-8ce5-516b-ba8e-44b582da6579", + "type": "event", + "index": "events-index-*", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "9c957c24-8ce5-516b-ba8e-44b582da6579", + "type": "event", + "index": "events-index-*", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "60b8b970-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "threshold-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:44.260Z", + "updated_at": "2022-03-23T16:50:45.341Z", + "description": "a simple threshold rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "b97ae2a4-f188-43b2-b082-69667b563152", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threshold", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threshold": { + "field": [ + "host.name" + ], + "value": 1 + } + }, + "reason": "event created low alert threshold-rule.", + "depth": 1, + "parent": { + "id": "9c957c24-8ce5-516b-ba8e-44b582da6579", + "type": "event", + "index": "events-index-*", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.330Z", + "threshold_result": { + "terms": [ + { + "field": "host.name", + "value": "security-linux-2" + } + ], + "count": 3, + "from": "2022-03-23T06:50:48.395Z" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "3754896311b1d9f9dee45ecf06aa5160f8cd3d4504ef5c856ba285edd61d059d", + "source": { + "@timestamp": "2022-03-23T16:50:48.442Z", + "host.name": "security-linux-3", + "event": { + "kind": "signal" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "326cc81c-b55f-5b69-8222-e930bcb24692", + "type": "event", + "index": "events-index-*", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "326cc81c-b55f-5b69-8222-e930bcb24692", + "type": "event", + "index": "events-index-*", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "60b8b970-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "threshold-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:44.260Z", + "updated_at": "2022-03-23T16:50:45.341Z", + "description": "a simple threshold rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "b97ae2a4-f188-43b2-b082-69667b563152", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "threshold", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [], + "threshold": { + "field": [ + "host.name" + ], + "value": 1 + } + }, + "reason": "event created low alert threshold-rule.", + "depth": 1, + "parent": { + "id": "326cc81c-b55f-5b69-8222-e930bcb24692", + "type": "event", + "index": "events-index-*", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.654Z", + "threshold_result": { + "terms": [ + { + "field": "host.name", + "value": "security-linux-3" + } + ], + "count": 3, + "from": "2022-03-23T06:50:48.395Z" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "5cddda6852c5f8b6c32d4bfa5e876aa51884e0c7a2d4faaababf91ec9cb68de7", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:28.994Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.440Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "Nmyvt38BIyEvspK02HTJ", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "Nmyvt38BIyEvspK02HTJ", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-1 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "Nmyvt38BIyEvspK02HTJ", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:28.994Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:28.994Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "5050902fa762858249c32b1d228dd71ca9217ace612b65f9669fb3a5f371ab63", + "source": { + "agent": { + "name": "security-linux-2.example.dev", + "id": "87c417dd-08d6-4e24-ad69-285cb8de84e9", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-2", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.195", + "name": "security-linux-2", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.387Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.477Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "N2yvt38BIyEvspK02nRK", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "N2yvt38BIyEvspK02nRK", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-2 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "N2yvt38BIyEvspK02nRK", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:29.387Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.387Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "525833fe5aa3cabce849adf9291b4d4009c25edbe528d5d2add1dc749c00513b", + "source": { + "agent": { + "name": "security-linux-3.example.dev", + "id": "06851da1-73e7-41e3-97d6-ff1d62c98dc5", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-3", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.196", + "name": "security-linux-3", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.715Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.499Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "OGyvt38BIyEvspK023SI", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "OGyvt38BIyEvspK023SI", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-3 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "OGyvt38BIyEvspK023SI", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:29.715Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:29.715Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "4f9c5a7581544f9dc1fa4c9f541c7e7573d7460ddeeda1875bee081e6615035b", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.031Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.510Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "OWyvt38BIyEvspK03HTF", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "OWyvt38BIyEvspK03HTF", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-1 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "OWyvt38BIyEvspK03HTF", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:30.031Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.031Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "d791d45b87a37e3b8a8388d7d6237728aa14ab6ec81bfa84f96457bd42b39e4a", + "source": { + "agent": { + "name": "security-linux-2.example.dev", + "id": "87c417dd-08d6-4e24-ad69-285cb8de84e9", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-2", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.195", + "name": "security-linux-2", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.353Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.533Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "Omyvt38BIyEvspK03nQB", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "Omyvt38BIyEvspK03nQB", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-2 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "Omyvt38BIyEvspK03nQB", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:30.353Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.353Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "747a4cfd4dbc1dd3924b341b0d3d94098252579354bf140e1621cb4b8681e911", + "source": { + "agent": { + "name": "security-linux-3.example.dev", + "id": "06851da1-73e7-41e3-97d6-ff1d62c98dc5", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-3", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.196", + "name": "security-linux-3", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.665Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.547Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "O2yvt38BIyEvspK033RN", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "O2yvt38BIyEvspK033RN", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-3 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "O2yvt38BIyEvspK033RN", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:30.665Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:30.665Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "5a217bc36610a820dbbb20f7b189065d631038a9dbb33bde1511f0f6a63183d2", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.001Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.561Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "PGyvt38BIyEvspK04HSX", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "PGyvt38BIyEvspK04HSX", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-1 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "PGyvt38BIyEvspK04HSX", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.001Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.001Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "fde1f09c4420ce5747f04ca051bcdc90762394ea019a7cc2cfee8de3bd575a59", + "source": { + "agent": { + "name": "security-linux-2.example.dev", + "id": "87c417dd-08d6-4e24-ad69-285cb8de84e9", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-2", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.195", + "name": "security-linux-2", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.330Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.593Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "PWyvt38BIyEvspK04XTd", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "PWyvt38BIyEvspK04XTd", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-2 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "PWyvt38BIyEvspK04XTd", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.330Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.330Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "337f39b1fb862a4c6910605b16e6b5b59623219e99dcb7d442cd334229ad3a7e", + "source": { + "agent": { + "name": "security-linux-3.example.dev", + "id": "06851da1-73e7-41e3-97d6-ff1d62c98dc5", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-3", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.196", + "name": "security-linux-3", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.654Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.606Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "Pmyvt38BIyEvspK043Ri", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "Pmyvt38BIyEvspK043Ri", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-3 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "Pmyvt38BIyEvspK043Ri", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:31.654Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:31.654Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + +{ + "type": "doc", + "value": { + "index": ".siem-signals-default-000001-7.16.0", + "id": "44f8d6e34631ced611f6588e7f0cdf52ac5647eff09cfbd36a38ad2a7d4bf32f", + "source": { + "agent": { + "name": "security-linux-1.example.dev", + "id": "d8f66724-3cf2-437c-b124-6ac9fb0e2311", + "type": "filebeat", + "version": "7.16.0" + }, + "log": { + "file": { + "path": "/opt/Elastic/Agent/data/elastic-agent-a13c93/logs/default/filebeat-20220301-3.ndjson" + }, + "offset": 148938 + }, + "cloud": { + "availability_zone": "us-central1-c", + "instance": { + "name": "security-linux-1", + "id": "8995531128842994872" + }, + "provider": "gcp", + "service": { + "name": "GCE" + }, + "machine": { + "type": "g1-small" + }, + "project": { + "id": "elastic-siem" + }, + "account": { + "id": "elastic-siem" + } + }, + "ecs": { + "version": "7.16.0" + }, + "host": { + "hostname": "security-linux-1", + "os": { + "kernel": "4.19.0-18-cloud-amd64", + "codename": "buster", + "name": "Debian GNU/Linux", + "type": "linux", + "family": "debian", + "version": "10 (buster)", + "platform": "debian" + }, + "containerized": false, + "ip": "11.200.0.194", + "name": "security-linux-1", + "architecture": "x86_64" + }, + "event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:32.045Z", + "dataset": "elastic_agent.filebeat", + "kind": "signal" + }, + "service.name": "filebeat", + "message": "Status message.", + "@timestamp": "2022-03-23T16:50:40.624Z", + "data_stream": { + "namespace": "default", + "type": "logs", + "dataset": "elastic_agent.filebeat" + }, + "signal": { + "_meta": { + "version": 57 + }, + "parents": [ + { + "id": "P2yvt38BIyEvspK05HSe", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "ancestors": [ + { + "id": "P2yvt38BIyEvspK05HSe", + "type": "event", + "index": "events-index-000001", + "depth": 0 + } + ], + "status": "open", + "rule": { + "id": "5b7cd9a0-aac9-11ec-bb53-fd375b7a173a", + "actions": [], + "interval": "1m", + "name": "query-rule", + "tags": [], + "enabled": true, + "created_by": "elastic", + "updated_by": "elastic", + "throttle": null, + "created_at": "2022-03-23T16:50:34.234Z", + "updated_at": "2022-03-23T16:50:36.214Z", + "description": "a simple query rule", + "risk_score": 21, + "severity": "low", + "license": "", + "output_index": ".siem-signals-default-000001", + "author": [], + "false_positives": [], + "from": "now-36000s", + "rule_id": "1fcc46ae-7e1e-4002-a4e1-e456029cb7ec", + "max_signals": 100, + "risk_score_mapping": [], + "severity_mapping": [], + "threat": [], + "to": "now", + "references": [], + "version": 1, + "exceptions_list": [], + "immutable": false, + "type": "query", + "language": "kuery", + "index": [ + "events-index-*" + ], + "query": "*", + "filters": [] + }, + "reason": "event on security-linux-1 created low alert query-rule.", + "depth": 1, + "parent": { + "id": "P2yvt38BIyEvspK05HSe", + "type": "event", + "index": "events-index-000001", + "depth": 0 + }, + "original_time": "2022-03-23T16:50:32.045Z", + "original_event": { + "agent_id_status": "verified", + "ingested": "2022-03-23T16:50:32.045Z", + "dataset": "elastic_agent.filebeat" + } + } + } + } +} + diff --git a/x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/mappings.json b/x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/mappings.json new file mode 100644 index 0000000000000..3838e29ee5aa4 --- /dev/null +++ b/x-pack/test/functional/es_archives/security_solution/alerts/7.16.0/mappings.json @@ -0,0 +1,5819 @@ +{ + "type": "index", + "value": { + "aliases": { + ".siem-signals-default": { + "is_write_index": true + } + }, + "index": ".siem-signals-default-000001-7.16.0", + "mappings": { + "dynamic": "false", + "_meta": { + "version": 57, + "aliases_version": 1 + }, + "properties": { + "@timestamp": { + "type": "date" + }, + "agent": { + "properties": { + "build": { + "properties": { + "original": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ephemeral_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "as": { + "properties": { + "number": { + "type": "long" + }, + "organization": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + } + } + }, + "client": { + "properties": { + "address": { + "type": "keyword", + "ignore_above": 1024 + }, + "as": { + "properties": { + "number": { + "type": "long" + }, + "organization": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + } + } + }, + "bytes": { + "type": "long" + }, + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ip": { + "type": "ip" + }, + "mac": { + "type": "keyword", + "ignore_above": 1024 + }, + "nat": { + "properties": { + "ip": { + "type": "ip" + }, + "port": { + "type": "long" + } + } + }, + "packets": { + "type": "long" + }, + "port": { + "type": "long" + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "user": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "cloud": { + "properties": { + "account": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "availability_zone": { + "type": "keyword", + "ignore_above": 1024 + }, + "instance": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "machine": { + "properties": { + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "project": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "provider": { + "type": "keyword", + "ignore_above": 1024 + }, + "region": { + "type": "keyword", + "ignore_above": 1024 + }, + "service": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "code_signature": { + "properties": { + "exists": { + "type": "boolean" + }, + "status": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "trusted": { + "type": "boolean" + }, + "valid": { + "type": "boolean" + } + } + }, + "container": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "image": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "tag": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "labels": { + "type": "object" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "runtime": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "data_stream": { + "properties": { + "dataset": { + "type": "keyword" + }, + "namespace": { + "type": "keyword" + }, + "type": { + "type": "keyword" + } + } + }, + "destination": { + "properties": { + "address": { + "type": "keyword", + "ignore_above": 1024 + }, + "as": { + "properties": { + "number": { + "type": "long" + }, + "organization": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + } + } + }, + "bytes": { + "type": "long" + }, + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ip": { + "type": "ip" + }, + "mac": { + "type": "keyword", + "ignore_above": 1024 + }, + "nat": { + "properties": { + "ip": { + "type": "ip" + }, + "port": { + "type": "long" + } + } + }, + "packets": { + "type": "long" + }, + "port": { + "type": "long" + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "user": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "dll": { + "properties": { + "code_signature": { + "properties": { + "exists": { + "type": "boolean" + }, + "signing_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "status": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "team_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "trusted": { + "type": "boolean" + }, + "valid": { + "type": "boolean" + } + } + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha512": { + "type": "keyword", + "ignore_above": 1024 + }, + "ssdeep": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024 + }, + "pe": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "company": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "file_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "imphash": { + "type": "keyword", + "ignore_above": 1024 + }, + "original_file_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "dns": { + "properties": { + "answers": { + "properties": { + "class": { + "type": "keyword", + "ignore_above": 1024 + }, + "data": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "ttl": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "header_flags": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "op_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "question": { + "properties": { + "class": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "resolved_ip": { + "type": "ip" + }, + "response_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ecs": { + "properties": { + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "error": { + "properties": { + "code": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "message": { + "type": "text", + "norms": false + }, + "stack_trace": { + "type": "keyword", + "index": false, + "doc_values": false, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "event": { + "properties": { + "action": { + "type": "keyword", + "ignore_above": 1024 + }, + "agent_id_status": { + "type": "keyword", + "ignore_above": 1024 + }, + "category": { + "type": "keyword", + "ignore_above": 1024 + }, + "code": { + "type": "keyword", + "ignore_above": 1024 + }, + "created": { + "type": "date" + }, + "dataset": { + "type": "keyword", + "ignore_above": 1024 + }, + "duration": { + "type": "long" + }, + "end": { + "type": "date" + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "ingested": { + "type": "date" + }, + "kind": { + "type": "keyword", + "ignore_above": 1024 + }, + "module": { + "type": "keyword", + "ignore_above": 1024 + }, + "original": { + "type": "keyword", + "index": false, + "doc_values": false + }, + "outcome": { + "type": "keyword", + "ignore_above": 1024 + }, + "provider": { + "type": "keyword", + "ignore_above": 1024 + }, + "reason": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "risk_score": { + "type": "float" + }, + "risk_score_norm": { + "type": "float" + }, + "sequence": { + "type": "long" + }, + "severity": { + "type": "long" + }, + "start": { + "type": "date" + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "url": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "file": { + "properties": { + "accessed": { + "type": "date" + }, + "attributes": { + "type": "keyword", + "ignore_above": 1024 + }, + "code_signature": { + "properties": { + "exists": { + "type": "boolean" + }, + "signing_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "status": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "team_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "trusted": { + "type": "boolean" + }, + "valid": { + "type": "boolean" + } + } + }, + "created": { + "type": "date" + }, + "ctime": { + "type": "date" + }, + "device": { + "type": "keyword", + "ignore_above": 1024 + }, + "directory": { + "type": "keyword", + "ignore_above": 1024 + }, + "drive_letter": { + "type": "keyword", + "ignore_above": 1 + }, + "elf": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "byte_order": { + "type": "keyword", + "ignore_above": 1024 + }, + "cpu_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "creation_date": { + "type": "date" + }, + "exports": { + "type": "flattened" + }, + "header": { + "properties": { + "abi_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "class": { + "type": "keyword", + "ignore_above": 1024 + }, + "data": { + "type": "keyword", + "ignore_above": 1024 + }, + "entrypoint": { + "type": "long" + }, + "object_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "os_abi": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "imports": { + "type": "flattened" + }, + "sections": { + "type": "nested", + "properties": { + "chi2": { + "type": "long" + }, + "entropy": { + "type": "long" + }, + "flags": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_offset": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_size": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "virtual_address": { + "type": "long" + }, + "virtual_size": { + "type": "long" + } + } + }, + "segments": { + "type": "nested", + "properties": { + "sections": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "shared_libraries": { + "type": "keyword", + "ignore_above": 1024 + }, + "telfhash": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "extension": { + "type": "keyword", + "ignore_above": 1024 + }, + "gid": { + "type": "keyword", + "ignore_above": 1024 + }, + "group": { + "type": "keyword", + "ignore_above": 1024 + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha512": { + "type": "keyword", + "ignore_above": 1024 + }, + "ssdeep": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "inode": { + "type": "keyword", + "ignore_above": 1024 + }, + "mime_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "mode": { + "type": "keyword", + "ignore_above": 1024 + }, + "mtime": { + "type": "date" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "owner": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "pe": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "company": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "file_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "imphash": { + "type": "keyword", + "ignore_above": 1024 + }, + "original_file_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "size": { + "type": "long" + }, + "target_path": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "uid": { + "type": "keyword", + "ignore_above": 1024 + }, + "x509": { + "properties": { + "alternative_names": { + "type": "keyword", + "ignore_above": 1024 + }, + "issuer": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "not_after": { + "type": "date" + }, + "not_before": { + "type": "date" + }, + "public_key_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_curve": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_exponent": { + "type": "long", + "index": false, + "doc_values": false + }, + "public_key_size": { + "type": "long" + }, + "serial_number": { + "type": "keyword", + "ignore_above": 1024 + }, + "signature_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "version_number": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha512": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "host": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "cpu": { + "properties": { + "usage": { + "type": "scaled_float", + "scaling_factor": 1000 + } + } + }, + "disk": { + "properties": { + "read": { + "properties": { + "bytes": { + "type": "long" + } + } + }, + "write": { + "properties": { + "bytes": { + "type": "long" + } + } + } + } + }, + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hostname": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "ip": { + "type": "ip" + }, + "mac": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "network": { + "properties": { + "egress": { + "properties": { + "bytes": { + "type": "long" + }, + "packets": { + "type": "long" + } + } + }, + "ingress": { + "properties": { + "bytes": { + "type": "long" + }, + "packets": { + "type": "long" + } + } + } + } + }, + "os": { + "properties": { + "family": { + "type": "keyword", + "ignore_above": 1024 + }, + "full": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "kernel": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "caseless": { + "type": "keyword", + "ignore_above": 1024, + "normalizer": "lowercase" + }, + "text": { + "type": "text", + "norms": false + } + } + }, + "platform": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "uptime": { + "type": "long" + }, + "user": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "http": { + "properties": { + "request": { + "properties": { + "body": { + "properties": { + "bytes": { + "type": "long" + }, + "content": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + }, + "bytes": { + "type": "long" + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "method": { + "type": "keyword", + "ignore_above": 1024 + }, + "mime_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "referrer": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "response": { + "properties": { + "body": { + "properties": { + "bytes": { + "type": "long" + }, + "content": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + }, + "bytes": { + "type": "long" + }, + "mime_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "status_code": { + "type": "long" + } + } + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "interface": { + "properties": { + "alias": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "kibana": { + "properties": { + "alert": { + "properties": { + "ancestors": { + "properties": { + "depth": { + "type": "alias", + "path": "signal.ancestors.depth" + }, + "id": { + "type": "alias", + "path": "signal.ancestors.id" + }, + "index": { + "type": "alias", + "path": "signal.ancestors.index" + }, + "type": { + "type": "alias", + "path": "signal.ancestors.type" + } + } + }, + "depth": { + "type": "alias", + "path": "signal.depth" + }, + "original_event": { + "properties": { + "action": { + "type": "alias", + "path": "signal.original_event.action" + }, + "category": { + "type": "alias", + "path": "signal.original_event.category" + }, + "code": { + "type": "alias", + "path": "signal.original_event.code" + }, + "created": { + "type": "alias", + "path": "signal.original_event.created" + }, + "dataset": { + "type": "alias", + "path": "signal.original_event.dataset" + }, + "duration": { + "type": "alias", + "path": "signal.original_event.duration" + }, + "end": { + "type": "alias", + "path": "signal.original_event.end" + }, + "hash": { + "type": "alias", + "path": "signal.original_event.hash" + }, + "id": { + "type": "alias", + "path": "signal.original_event.id" + }, + "kind": { + "type": "alias", + "path": "signal.original_event.kind" + }, + "module": { + "type": "alias", + "path": "signal.original_event.module" + }, + "outcome": { + "type": "alias", + "path": "signal.original_event.outcome" + }, + "provider": { + "type": "alias", + "path": "signal.original_event.provider" + }, + "reason": { + "type": "alias", + "path": "signal.original_event.reason" + }, + "risk_score": { + "type": "alias", + "path": "signal.original_event.risk_score" + }, + "risk_score_norm": { + "type": "alias", + "path": "signal.original_event.risk_score_norm" + }, + "sequence": { + "type": "alias", + "path": "signal.original_event.sequence" + }, + "severity": { + "type": "alias", + "path": "signal.original_event.severity" + }, + "start": { + "type": "alias", + "path": "signal.original_event.start" + }, + "timezone": { + "type": "alias", + "path": "signal.original_event.timezone" + }, + "type": { + "type": "alias", + "path": "signal.original_event.type" + } + } + }, + "original_time": { + "type": "alias", + "path": "signal.original_time" + }, + "reason": { + "type": "alias", + "path": "signal.reason" + }, + "risk_score": { + "type": "alias", + "path": "signal.rule.risk_score" + }, + "rule": { + "properties": { + "author": { + "type": "alias", + "path": "signal.rule.author" + }, + "building_block_type": { + "type": "alias", + "path": "signal.rule.building_block_type" + }, + "created_at": { + "type": "alias", + "path": "signal.rule.created_at" + }, + "created_by": { + "type": "alias", + "path": "signal.rule.created_by" + }, + "description": { + "type": "alias", + "path": "signal.rule.description" + }, + "enabled": { + "type": "alias", + "path": "signal.rule.enabled" + }, + "false_positives": { + "type": "alias", + "path": "signal.rule.false_positives" + }, + "from": { + "type": "alias", + "path": "signal.rule.from" + }, + "immutable": { + "type": "alias", + "path": "signal.rule.immutable" + }, + "index": { + "type": "alias", + "path": "signal.rule.index" + }, + "interval": { + "type": "alias", + "path": "signal.rule.interval" + }, + "language": { + "type": "alias", + "path": "signal.rule.language" + }, + "license": { + "type": "alias", + "path": "signal.rule.license" + }, + "max_signals": { + "type": "alias", + "path": "signal.rule.max_signals" + }, + "name": { + "type": "alias", + "path": "signal.rule.name" + }, + "note": { + "type": "alias", + "path": "signal.rule.note" + }, + "query": { + "type": "alias", + "path": "signal.rule.query" + }, + "references": { + "type": "alias", + "path": "signal.rule.references" + }, + "risk_score_mapping": { + "properties": { + "field": { + "type": "alias", + "path": "signal.rule.risk_score_mapping.field" + }, + "operator": { + "type": "alias", + "path": "signal.rule.risk_score_mapping.operator" + }, + "value": { + "type": "alias", + "path": "signal.rule.risk_score_mapping.value" + } + } + }, + "rule_id": { + "type": "alias", + "path": "signal.rule.rule_id" + }, + "rule_name_override": { + "type": "alias", + "path": "signal.rule.rule_name_override" + }, + "saved_id": { + "type": "alias", + "path": "signal.rule.saved_id" + }, + "severity_mapping": { + "properties": { + "field": { + "type": "alias", + "path": "signal.rule.severity_mapping.field" + }, + "operator": { + "type": "alias", + "path": "signal.rule.severity_mapping.operator" + }, + "severity": { + "type": "alias", + "path": "signal.rule.severity_mapping.severity" + }, + "value": { + "type": "alias", + "path": "signal.rule.severity_mapping.value" + } + } + }, + "tags": { + "type": "alias", + "path": "signal.rule.tags" + }, + "threat": { + "properties": { + "framework": { + "type": "alias", + "path": "signal.rule.threat.framework" + }, + "tactic": { + "properties": { + "id": { + "type": "alias", + "path": "signal.rule.threat.tactic.id" + }, + "name": { + "type": "alias", + "path": "signal.rule.threat.tactic.name" + }, + "reference": { + "type": "alias", + "path": "signal.rule.threat.tactic.reference" + } + } + }, + "technique": { + "properties": { + "id": { + "type": "alias", + "path": "signal.rule.threat.technique.id" + }, + "name": { + "type": "alias", + "path": "signal.rule.threat.technique.name" + }, + "reference": { + "type": "alias", + "path": "signal.rule.threat.technique.reference" + }, + "subtechnique": { + "properties": { + "id": { + "type": "alias", + "path": "signal.rule.threat.technique.subtechnique.id" + }, + "name": { + "type": "alias", + "path": "signal.rule.threat.technique.subtechnique.name" + }, + "reference": { + "type": "alias", + "path": "signal.rule.threat.technique.subtechnique.reference" + } + } + } + } + } + } + }, + "threat_index": { + "type": "alias", + "path": "signal.rule.threat_index" + }, + "threat_indicator_path": { + "type": "alias", + "path": "signal.rule.threat_indicator_path" + }, + "threat_language": { + "type": "alias", + "path": "signal.rule.threat_language" + }, + "threat_mapping": { + "properties": { + "entries": { + "properties": { + "field": { + "type": "alias", + "path": "signal.rule.threat_mapping.entries.field" + }, + "type": { + "type": "alias", + "path": "signal.rule.threat_mapping.entries.type" + }, + "value": { + "type": "alias", + "path": "signal.rule.threat_mapping.entries.value" + } + } + } + } + }, + "threat_query": { + "type": "alias", + "path": "signal.rule.threat_query" + }, + "threshold": { + "properties": { + "field": { + "type": "alias", + "path": "signal.rule.threshold.field" + }, + "value": { + "type": "alias", + "path": "signal.rule.threshold.value" + } + } + }, + "timeline_id": { + "type": "alias", + "path": "signal.rule.timeline_id" + }, + "timeline_title": { + "type": "alias", + "path": "signal.rule.timeline_title" + }, + "to": { + "type": "alias", + "path": "signal.rule.to" + }, + "type": { + "type": "alias", + "path": "signal.rule.type" + }, + "updated_at": { + "type": "alias", + "path": "signal.rule.updated_at" + }, + "updated_by": { + "type": "alias", + "path": "signal.rule.updated_by" + }, + "uuid": { + "type": "alias", + "path": "signal.rule.id" + }, + "version": { + "type": "alias", + "path": "signal.rule.version" + } + } + }, + "severity": { + "type": "alias", + "path": "signal.rule.severity" + }, + "threshold_result": { + "properties": { + "cardinality": { + "properties": { + "field": { + "type": "alias", + "path": "signal.threshold_result.cardinality.field" + }, + "value": { + "type": "alias", + "path": "signal.threshold_result.cardinality.value" + } + } + }, + "count": { + "type": "alias", + "path": "signal.threshold_result.count" + }, + "from": { + "type": "alias", + "path": "signal.threshold_result.from" + }, + "terms": { + "properties": { + "field": { + "type": "alias", + "path": "signal.threshold_result.terms.field" + }, + "value": { + "type": "alias", + "path": "signal.threshold_result.terms.value" + } + } + } + } + }, + "workflow_status": { + "type": "alias", + "path": "signal.status" + } + } + } + } + }, + "labels": { + "type": "object" + }, + "log": { + "properties": { + "file": { + "properties": { + "path": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "level": { + "type": "keyword", + "ignore_above": 1024 + }, + "logger": { + "type": "keyword", + "ignore_above": 1024 + }, + "origin": { + "properties": { + "file": { + "properties": { + "line": { + "type": "integer" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "function": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "original": { + "type": "keyword", + "index": false, + "doc_values": false + }, + "syslog": { + "properties": { + "facility": { + "properties": { + "code": { + "type": "long" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "priority": { + "type": "long" + }, + "severity": { + "properties": { + "code": { + "type": "long" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + } + } + }, + "message": { + "type": "text", + "norms": false + }, + "network": { + "properties": { + "application": { + "type": "keyword", + "ignore_above": 1024 + }, + "bytes": { + "type": "long" + }, + "community_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "direction": { + "type": "keyword", + "ignore_above": 1024 + }, + "forwarded_ip": { + "type": "ip" + }, + "iana_number": { + "type": "keyword", + "ignore_above": 1024 + }, + "inner": { + "properties": { + "vlan": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "packets": { + "type": "long" + }, + "protocol": { + "type": "keyword", + "ignore_above": 1024 + }, + "transport": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "vlan": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "observer": { + "properties": { + "egress": { + "properties": { + "interface": { + "properties": { + "alias": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "vlan": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "zone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hostname": { + "type": "keyword", + "ignore_above": 1024 + }, + "ingress": { + "properties": { + "interface": { + "properties": { + "alias": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "vlan": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "zone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ip": { + "type": "ip" + }, + "mac": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "os": { + "properties": { + "family": { + "type": "keyword", + "ignore_above": 1024 + }, + "full": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "kernel": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "platform": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + }, + "serial_number": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "vendor": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "orchestrator": { + "properties": { + "api_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "cluster": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "url": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "namespace": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "resource": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "organization": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + }, + "os": { + "properties": { + "family": { + "type": "keyword", + "ignore_above": 1024 + }, + "full": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "kernel": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "platform": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "package": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "build_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "checksum": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "install_scope": { + "type": "keyword", + "ignore_above": 1024 + }, + "installed": { + "type": "date" + }, + "license": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "size": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "pe": { + "properties": { + "company": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "file_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "original_file_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "process": { + "properties": { + "args": { + "type": "keyword", + "ignore_above": 1024 + }, + "args_count": { + "type": "long" + }, + "code_signature": { + "properties": { + "exists": { + "type": "boolean" + }, + "signing_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "status": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "team_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "trusted": { + "type": "boolean" + }, + "valid": { + "type": "boolean" + } + } + }, + "command_line": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "elf": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "byte_order": { + "type": "keyword", + "ignore_above": 1024 + }, + "cpu_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "creation_date": { + "type": "date" + }, + "exports": { + "type": "flattened" + }, + "header": { + "properties": { + "abi_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "class": { + "type": "keyword", + "ignore_above": 1024 + }, + "data": { + "type": "keyword", + "ignore_above": 1024 + }, + "entrypoint": { + "type": "long" + }, + "object_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "os_abi": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "imports": { + "type": "flattened" + }, + "sections": { + "type": "nested", + "properties": { + "chi2": { + "type": "long" + }, + "entropy": { + "type": "long" + }, + "flags": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_offset": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_size": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "virtual_address": { + "type": "long" + }, + "virtual_size": { + "type": "long" + } + } + }, + "segments": { + "type": "nested", + "properties": { + "sections": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "shared_libraries": { + "type": "keyword", + "ignore_above": 1024 + }, + "telfhash": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "entity_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "executable": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "exit_code": { + "type": "long" + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha512": { + "type": "keyword", + "ignore_above": 1024 + }, + "ssdeep": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "parent": { + "properties": { + "args": { + "type": "keyword", + "ignore_above": 1024 + }, + "args_count": { + "type": "long" + }, + "code_signature": { + "properties": { + "exists": { + "type": "boolean" + }, + "signing_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "status": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "team_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "trusted": { + "type": "boolean" + }, + "valid": { + "type": "boolean" + } + } + }, + "command_line": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "elf": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "byte_order": { + "type": "keyword", + "ignore_above": 1024 + }, + "cpu_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "creation_date": { + "type": "date" + }, + "exports": { + "type": "flattened" + }, + "header": { + "properties": { + "abi_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "class": { + "type": "keyword", + "ignore_above": 1024 + }, + "data": { + "type": "keyword", + "ignore_above": 1024 + }, + "entrypoint": { + "type": "long" + }, + "object_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "os_abi": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "imports": { + "type": "flattened" + }, + "sections": { + "type": "nested", + "properties": { + "chi2": { + "type": "long" + }, + "entropy": { + "type": "long" + }, + "flags": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_offset": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_size": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "virtual_address": { + "type": "long" + }, + "virtual_size": { + "type": "long" + } + } + }, + "segments": { + "type": "nested", + "properties": { + "sections": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "shared_libraries": { + "type": "keyword", + "ignore_above": 1024 + }, + "telfhash": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "entity_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "executable": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "exit_code": { + "type": "long" + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha512": { + "type": "keyword", + "ignore_above": 1024 + }, + "ssdeep": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "pe": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "company": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "file_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "imphash": { + "type": "keyword", + "ignore_above": 1024 + }, + "original_file_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "pgid": { + "type": "long" + }, + "pid": { + "type": "long" + }, + "ppid": { + "type": "long" + }, + "start": { + "type": "date" + }, + "thread": { + "properties": { + "id": { + "type": "long" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "title": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "uptime": { + "type": "long" + }, + "working_directory": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + }, + "pe": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "company": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "file_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "imphash": { + "type": "keyword", + "ignore_above": 1024 + }, + "original_file_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "pgid": { + "type": "long" + }, + "pid": { + "type": "long" + }, + "ppid": { + "type": "long" + }, + "start": { + "type": "date" + }, + "thread": { + "properties": { + "id": { + "type": "long" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "title": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "uptime": { + "type": "long" + }, + "working_directory": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + }, + "registry": { + "properties": { + "data": { + "properties": { + "bytes": { + "type": "keyword", + "ignore_above": 1024 + }, + "strings": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hive": { + "type": "keyword", + "ignore_above": 1024 + }, + "key": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024 + }, + "value": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "related": { + "properties": { + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "hosts": { + "type": "keyword", + "ignore_above": 1024 + }, + "ip": { + "type": "ip" + }, + "user": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "rule": { + "properties": { + "author": { + "type": "keyword", + "ignore_above": 1024 + }, + "category": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "license": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "ruleset": { + "type": "keyword", + "ignore_above": 1024 + }, + "uuid": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "server": { + "properties": { + "address": { + "type": "keyword", + "ignore_above": 1024 + }, + "as": { + "properties": { + "number": { + "type": "long" + }, + "organization": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + } + } + }, + "bytes": { + "type": "long" + }, + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ip": { + "type": "ip" + }, + "mac": { + "type": "keyword", + "ignore_above": 1024 + }, + "nat": { + "properties": { + "ip": { + "type": "ip" + }, + "port": { + "type": "long" + } + } + }, + "packets": { + "type": "long" + }, + "port": { + "type": "long" + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "user": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "service": { + "properties": { + "ephemeral_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "node": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "state": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "signal": { + "properties": { + "_meta": { + "properties": { + "version": { + "type": "long" + } + } + }, + "ancestors": { + "properties": { + "depth": { + "type": "long" + }, + "id": { + "type": "keyword" + }, + "index": { + "type": "keyword" + }, + "rule": { + "type": "keyword" + }, + "type": { + "type": "keyword" + } + } + }, + "depth": { + "type": "integer" + }, + "group": { + "properties": { + "id": { + "type": "keyword" + }, + "index": { + "type": "integer" + } + } + }, + "original_event": { + "properties": { + "action": { + "type": "keyword" + }, + "category": { + "type": "keyword" + }, + "code": { + "type": "keyword" + }, + "created": { + "type": "date" + }, + "dataset": { + "type": "keyword" + }, + "duration": { + "type": "long" + }, + "end": { + "type": "date" + }, + "hash": { + "type": "keyword" + }, + "id": { + "type": "keyword" + }, + "kind": { + "type": "keyword" + }, + "module": { + "type": "keyword" + }, + "original": { + "type": "keyword", + "index": false, + "doc_values": false + }, + "outcome": { + "type": "keyword" + }, + "provider": { + "type": "keyword" + }, + "reason": { + "type": "keyword" + }, + "risk_score": { + "type": "float" + }, + "risk_score_norm": { + "type": "float" + }, + "sequence": { + "type": "long" + }, + "severity": { + "type": "long" + }, + "start": { + "type": "date" + }, + "timezone": { + "type": "keyword" + }, + "type": { + "type": "keyword" + } + } + }, + "original_signal": { + "type": "object", + "dynamic": "false", + "enabled": false + }, + "original_time": { + "type": "date" + }, + "parent": { + "properties": { + "depth": { + "type": "long" + }, + "id": { + "type": "keyword" + }, + "index": { + "type": "keyword" + }, + "rule": { + "type": "keyword" + }, + "type": { + "type": "keyword" + } + } + }, + "parents": { + "properties": { + "depth": { + "type": "long" + }, + "id": { + "type": "keyword" + }, + "index": { + "type": "keyword" + }, + "rule": { + "type": "keyword" + }, + "type": { + "type": "keyword" + } + } + }, + "reason": { + "type": "keyword" + }, + "rule": { + "properties": { + "author": { + "type": "keyword" + }, + "building_block_type": { + "type": "keyword" + }, + "created_at": { + "type": "date" + }, + "created_by": { + "type": "keyword" + }, + "description": { + "type": "keyword" + }, + "enabled": { + "type": "keyword" + }, + "false_positives": { + "type": "keyword" + }, + "filters": { + "type": "object" + }, + "from": { + "type": "keyword" + }, + "id": { + "type": "keyword" + }, + "immutable": { + "type": "keyword" + }, + "index": { + "type": "keyword" + }, + "interval": { + "type": "keyword" + }, + "language": { + "type": "keyword" + }, + "license": { + "type": "keyword" + }, + "max_signals": { + "type": "keyword" + }, + "name": { + "type": "keyword" + }, + "note": { + "type": "text" + }, + "output_index": { + "type": "keyword" + }, + "query": { + "type": "keyword" + }, + "references": { + "type": "keyword" + }, + "risk_score": { + "type": "float" + }, + "risk_score_mapping": { + "properties": { + "field": { + "type": "keyword" + }, + "operator": { + "type": "keyword" + }, + "value": { + "type": "keyword" + } + } + }, + "rule_id": { + "type": "keyword" + }, + "rule_name_override": { + "type": "keyword" + }, + "saved_id": { + "type": "keyword" + }, + "severity": { + "type": "keyword" + }, + "severity_mapping": { + "properties": { + "field": { + "type": "keyword" + }, + "operator": { + "type": "keyword" + }, + "severity": { + "type": "keyword" + }, + "value": { + "type": "keyword" + } + } + }, + "size": { + "type": "keyword" + }, + "tags": { + "type": "keyword" + }, + "threat": { + "properties": { + "framework": { + "type": "keyword" + }, + "tactic": { + "properties": { + "id": { + "type": "keyword" + }, + "name": { + "type": "keyword" + }, + "reference": { + "type": "keyword" + } + } + }, + "technique": { + "properties": { + "id": { + "type": "keyword" + }, + "name": { + "type": "keyword" + }, + "reference": { + "type": "keyword" + }, + "subtechnique": { + "properties": { + "id": { + "type": "keyword" + }, + "name": { + "type": "keyword" + }, + "reference": { + "type": "keyword" + } + } + } + } + } + } + }, + "threat_filters": { + "type": "object" + }, + "threat_index": { + "type": "keyword" + }, + "threat_indicator_path": { + "type": "keyword" + }, + "threat_language": { + "type": "keyword" + }, + "threat_mapping": { + "properties": { + "entries": { + "properties": { + "field": { + "type": "keyword" + }, + "type": { + "type": "keyword" + }, + "value": { + "type": "keyword" + } + } + } + } + }, + "threat_query": { + "type": "keyword" + }, + "threshold": { + "properties": { + "field": { + "type": "keyword" + }, + "value": { + "type": "float" + } + } + }, + "timeline_id": { + "type": "keyword" + }, + "timeline_title": { + "type": "keyword" + }, + "timestamp_override": { + "type": "keyword" + }, + "to": { + "type": "keyword" + }, + "type": { + "type": "keyword" + }, + "updated_at": { + "type": "date" + }, + "updated_by": { + "type": "keyword" + }, + "version": { + "type": "keyword" + } + } + }, + "status": { + "type": "keyword" + }, + "threshold_count": { + "type": "float" + }, + "threshold_result": { + "properties": { + "cardinality": { + "properties": { + "field": { + "type": "keyword" + }, + "value": { + "type": "long" + } + } + }, + "count": { + "type": "long" + }, + "from": { + "type": "date" + }, + "terms": { + "properties": { + "field": { + "type": "keyword" + }, + "value": { + "type": "keyword" + } + } + } + } + } + } + }, + "source": { + "properties": { + "address": { + "type": "keyword", + "ignore_above": 1024 + }, + "as": { + "properties": { + "number": { + "type": "long" + }, + "organization": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + } + } + }, + "bytes": { + "type": "long" + }, + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ip": { + "type": "ip" + }, + "mac": { + "type": "keyword", + "ignore_above": 1024 + }, + "nat": { + "properties": { + "ip": { + "type": "ip" + }, + "port": { + "type": "long" + } + } + }, + "packets": { + "type": "long" + }, + "port": { + "type": "long" + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "user": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "span": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "tags": { + "type": "keyword", + "ignore_above": 1024 + }, + "threat": { + "properties": { + "enrichments": { + "type": "nested", + "properties": { + "indicator": { + "properties": { + "as": { + "properties": { + "number": { + "type": "long" + }, + "organization": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + } + } + } + } + }, + "confidence": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "properties": { + "address": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "file": { + "properties": { + "accessed": { + "type": "date" + }, + "attributes": { + "type": "keyword", + "ignore_above": 1024 + }, + "code_signature": { + "properties": { + "exists": { + "type": "boolean" + }, + "signing_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "status": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "team_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "trusted": { + "type": "boolean" + }, + "valid": { + "type": "boolean" + } + } + }, + "created": { + "type": "date" + }, + "ctime": { + "type": "date" + }, + "device": { + "type": "keyword", + "ignore_above": 1024 + }, + "directory": { + "type": "keyword", + "ignore_above": 1024 + }, + "drive_letter": { + "type": "keyword", + "ignore_above": 1 + }, + "elf": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "byte_order": { + "type": "keyword", + "ignore_above": 1024 + }, + "cpu_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "creation_date": { + "type": "date" + }, + "exports": { + "type": "flattened" + }, + "header": { + "properties": { + "abi_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "class": { + "type": "keyword", + "ignore_above": 1024 + }, + "data": { + "type": "keyword", + "ignore_above": 1024 + }, + "entrypoint": { + "type": "long" + }, + "object_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "os_abi": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "imports": { + "type": "flattened" + }, + "sections": { + "type": "nested", + "properties": { + "chi2": { + "type": "long" + }, + "entropy": { + "type": "long" + }, + "flags": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_offset": { + "type": "keyword", + "ignore_above": 1024 + }, + "physical_size": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "virtual_address": { + "type": "long" + }, + "virtual_size": { + "type": "long" + } + } + }, + "segments": { + "type": "nested", + "properties": { + "sections": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "shared_libraries": { + "type": "keyword", + "ignore_above": 1024 + }, + "telfhash": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "extension": { + "type": "keyword", + "ignore_above": 1024 + }, + "gid": { + "type": "keyword", + "ignore_above": 1024 + }, + "group": { + "type": "keyword", + "ignore_above": 1024 + }, + "inode": { + "type": "keyword", + "ignore_above": 1024 + }, + "mime_type": { + "type": "keyword", + "ignore_above": 1024 + }, + "mode": { + "type": "keyword", + "ignore_above": 1024 + }, + "mtime": { + "type": "date" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "owner": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "size": { + "type": "long" + }, + "target_path": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "uid": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "first_seen": { + "type": "date" + }, + "geo": { + "properties": { + "city_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "continent_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "country_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "location": { + "type": "geo_point" + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "postal_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_iso_code": { + "type": "keyword", + "ignore_above": 1024 + }, + "region_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "timezone": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha512": { + "type": "keyword", + "ignore_above": 1024 + }, + "ssdeep": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "ip": { + "type": "ip" + }, + "last_seen": { + "type": "date" + }, + "marking": { + "properties": { + "tlp": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "modified_at": { + "type": "date" + }, + "pe": { + "properties": { + "architecture": { + "type": "keyword", + "ignore_above": 1024 + }, + "company": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024 + }, + "file_version": { + "type": "keyword", + "ignore_above": 1024 + }, + "imphash": { + "type": "keyword", + "ignore_above": 1024 + }, + "original_file_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "product": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "port": { + "type": "long" + }, + "provider": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "registry": { + "properties": { + "data": { + "properties": { + "bytes": { + "type": "keyword", + "ignore_above": 1024 + }, + "strings": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hive": { + "type": "keyword", + "ignore_above": 1024 + }, + "key": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024 + }, + "value": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "scanner_stats": { + "type": "long" + }, + "sightings": { + "type": "long" + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "url": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "extension": { + "type": "keyword", + "ignore_above": 1024 + }, + "fragment": { + "type": "keyword", + "ignore_above": 1024 + }, + "full": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "original": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "password": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024 + }, + "port": { + "type": "long" + }, + "query": { + "type": "keyword", + "ignore_above": 1024 + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "scheme": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "username": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "x509": { + "properties": { + "alternative_names": { + "type": "keyword", + "ignore_above": 1024 + }, + "issuer": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "not_after": { + "type": "date" + }, + "not_before": { + "type": "date" + }, + "public_key_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_curve": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_exponent": { + "type": "long", + "index": false, + "doc_values": false + }, + "public_key_size": { + "type": "long" + }, + "serial_number": { + "type": "keyword", + "ignore_above": 1024 + }, + "signature_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "version_number": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "matched": { + "properties": { + "atomic": { + "type": "keyword", + "ignore_above": 1024 + }, + "field": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "index": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "framework": { + "type": "keyword", + "ignore_above": 1024 + }, + "group": { + "properties": { + "alias": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "software": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "platforms": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "tactic": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "technique": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "subtechnique": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + } + } + }, + "tls": { + "properties": { + "cipher": { + "type": "keyword", + "ignore_above": 1024 + }, + "client": { + "properties": { + "certificate": { + "type": "keyword", + "ignore_above": 1024 + }, + "certificate_chain": { + "type": "keyword", + "ignore_above": 1024 + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "issuer": { + "type": "keyword", + "ignore_above": 1024 + }, + "ja3": { + "type": "keyword", + "ignore_above": 1024 + }, + "not_after": { + "type": "date" + }, + "not_before": { + "type": "date" + }, + "server_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject": { + "type": "keyword", + "ignore_above": 1024 + }, + "supported_ciphers": { + "type": "keyword", + "ignore_above": 1024 + }, + "x509": { + "properties": { + "alternative_names": { + "type": "keyword", + "ignore_above": 1024 + }, + "issuer": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "not_after": { + "type": "date" + }, + "not_before": { + "type": "date" + }, + "public_key_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_curve": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_exponent": { + "type": "long", + "index": false, + "doc_values": false + }, + "public_key_size": { + "type": "long" + }, + "serial_number": { + "type": "keyword", + "ignore_above": 1024 + }, + "signature_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "version_number": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "curve": { + "type": "keyword", + "ignore_above": 1024 + }, + "established": { + "type": "boolean" + }, + "next_protocol": { + "type": "keyword", + "ignore_above": 1024 + }, + "resumed": { + "type": "boolean" + }, + "server": { + "properties": { + "certificate": { + "type": "keyword", + "ignore_above": 1024 + }, + "certificate_chain": { + "type": "keyword", + "ignore_above": 1024 + }, + "hash": { + "properties": { + "md5": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha1": { + "type": "keyword", + "ignore_above": 1024 + }, + "sha256": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "issuer": { + "type": "keyword", + "ignore_above": 1024 + }, + "ja3s": { + "type": "keyword", + "ignore_above": 1024 + }, + "not_after": { + "type": "date" + }, + "not_before": { + "type": "date" + }, + "subject": { + "type": "keyword", + "ignore_above": 1024 + }, + "x509": { + "properties": { + "alternative_names": { + "type": "keyword", + "ignore_above": 1024 + }, + "issuer": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "not_after": { + "type": "date" + }, + "not_before": { + "type": "date" + }, + "public_key_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_curve": { + "type": "keyword", + "ignore_above": 1024 + }, + "public_key_exponent": { + "type": "long", + "index": false, + "doc_values": false + }, + "public_key_size": { + "type": "long" + }, + "serial_number": { + "type": "keyword", + "ignore_above": 1024 + }, + "signature_algorithm": { + "type": "keyword", + "ignore_above": 1024 + }, + "subject": { + "properties": { + "common_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "country": { + "type": "keyword", + "ignore_above": 1024 + }, + "distinguished_name": { + "type": "keyword", + "ignore_above": 1024 + }, + "locality": { + "type": "keyword", + "ignore_above": 1024 + }, + "organization": { + "type": "keyword", + "ignore_above": 1024 + }, + "organizational_unit": { + "type": "keyword", + "ignore_above": 1024 + }, + "state_or_province": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "version_number": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + }, + "version_protocol": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "trace": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "transaction": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "url": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "extension": { + "type": "keyword", + "ignore_above": 1024 + }, + "fragment": { + "type": "keyword", + "ignore_above": 1024 + }, + "full": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "original": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "password": { + "type": "keyword", + "ignore_above": 1024 + }, + "path": { + "type": "keyword", + "ignore_above": 1024 + }, + "port": { + "type": "long" + }, + "query": { + "type": "keyword", + "ignore_above": 1024 + }, + "registered_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "scheme": { + "type": "keyword", + "ignore_above": 1024 + }, + "subdomain": { + "type": "keyword", + "ignore_above": 1024 + }, + "top_level_domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "username": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "user": { + "properties": { + "changes": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "effective": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + }, + "target": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "email": { + "type": "keyword", + "ignore_above": 1024 + }, + "full_name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "group": { + "properties": { + "domain": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "hash": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "roles": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "user_agent": { + "properties": { + "device": { + "properties": { + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + }, + "original": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "os": { + "properties": { + "family": { + "type": "keyword", + "ignore_above": 1024 + }, + "full": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "kernel": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "platform": { + "type": "keyword", + "ignore_above": 1024 + }, + "type": { + "type": "keyword", + "ignore_above": 1024 + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "vlan": { + "properties": { + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "name": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "vulnerability": { + "properties": { + "category": { + "type": "keyword", + "ignore_above": 1024 + }, + "classification": { + "type": "keyword", + "ignore_above": 1024 + }, + "description": { + "type": "keyword", + "ignore_above": 1024, + "fields": { + "text": { + "type": "text", + "norms": false + } + } + }, + "enumeration": { + "type": "keyword", + "ignore_above": 1024 + }, + "id": { + "type": "keyword", + "ignore_above": 1024 + }, + "reference": { + "type": "keyword", + "ignore_above": 1024 + }, + "report_id": { + "type": "keyword", + "ignore_above": 1024 + }, + "scanner": { + "properties": { + "vendor": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "score": { + "properties": { + "base": { + "type": "float" + }, + "environmental": { + "type": "float" + }, + "temporal": { + "type": "float" + }, + "version": { + "type": "keyword", + "ignore_above": 1024 + } + } + }, + "severity": { + "type": "keyword", + "ignore_above": 1024 + } + } + } + } + }, + "settings": { + "index": { + "lifecycle": { + "name": ".siem-signals-default", + "rollover_alias": ".siem-signals-default" + }, + "routing": { + "allocation": { + "include": { + "_tier_preference": "data_content" + } + } + }, + "mapping": { + "total_fields": { + "limit": "10000" + } + }, + "number_of_shards": "1", + "number_of_replicas": "1" + } + } + } +} \ No newline at end of file From 50f99676bf27ccae5d6ac97cab7b573330554a8c Mon Sep 17 00:00:00 2001 From: Chris Roberson Date: Tue, 29 Mar 2022 10:50:00 -0400 Subject: [PATCH 090/160] [Response Ops] Alerts table (#125977) * WIP * Fix some issues * WIP * Revert "WIP" This reverts commit 5583997921dca184227b9e1c84b1030bad2fbda1. * WIP * Mock data * WIP * WIP * Remove unnecessary logic * Add some basic tests * Slight rename * Fix unnecessary export * Fix types * Add ability to use externally * Add test data * Fix types and tests * LAZZYYYYYYY load * Improvements based on o11y integrations * Fix types and tests * Cleanup and unit tests * Better integration with o11y alerts * Use experimental flag * Add functional tests * Fix tests * Add unit test for home page, and stop using internal because we have the feature flag * Fix bad label * Update strategy name * Fix test * Fix test, part 2 Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/rule_registry/common/index.ts | 6 +- .../common/experimental_features.ts | 1 + .../public/application/app.tsx | 2 +- .../public/application/constants/index.ts | 3 +- .../public/application/home.test.tsx | 43 ++++ .../public/application/home.tsx | 29 ++- .../alerts_table/alerts_page/README.md | 1 + .../alerts_table/alerts_page/alerts_page.tsx | 195 ++++++++++++++++++ .../alerts_table/alerts_page/index.ts | 9 + .../alerts_table/alerts_table.test.tsx | 106 ++++++++++ .../sections/alerts_table/alerts_table.tsx | 46 +++++ .../sections/alerts_table/hooks/index.ts | 8 + .../alerts_table/hooks/use_pagination.test.ts | 45 ++++ .../alerts_table/hooks/use_pagination.ts | 38 ++++ .../alerts_table/hooks/use_sorting.test.ts | 33 +++ .../alerts_table/hooks/use_sorting.ts | 21 ++ .../sections/alerts_table/index.ts | 10 + .../sections/alerts_table/types.ts | 12 ++ .../public/common/get_alerts_table.tsx | 14 ++ .../common/get_experimental_features.test.tsx | 12 +- .../common/get_experimental_features.ts | 4 +- .../triggers_actions_ui/public/mocks.ts | 5 + .../triggers_actions_ui/public/plugin.ts | 6 + .../triggers_actions_ui/public/types.ts | 47 ++++- .../apps/triggers_actions_ui/alerts_table.ts | 157 ++++++++++++++ .../apps/triggers_actions_ui/index.ts | 1 + x-pack/test/functional_with_es_ssl/config.ts | 1 + 27 files changed, 846 insertions(+), 9 deletions(-) create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/README.md create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/alerts_page.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/index.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.test.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.tsx create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/index.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.test.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.test.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/index.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/types.ts create mode 100644 x-pack/plugins/triggers_actions_ui/public/common/get_alerts_table.tsx create mode 100644 x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts_table.ts diff --git a/x-pack/plugins/rule_registry/common/index.ts b/x-pack/plugins/rule_registry/common/index.ts index 2dd7f6bbc456e..1f6053735d9b7 100644 --- a/x-pack/plugins/rule_registry/common/index.ts +++ b/x-pack/plugins/rule_registry/common/index.ts @@ -5,5 +5,9 @@ * 2.0. */ export { parseTechnicalFields, type ParsedTechnicalFields } from './parse_technical_fields'; -export type { RuleRegistrySearchRequest, RuleRegistrySearchResponse } from './search_strategy'; +export type { + RuleRegistrySearchRequest, + RuleRegistrySearchResponse, + RuleRegistrySearchRequestPagination, +} from './search_strategy'; export { BASE_RAC_ALERTS_API_PATH } from './constants'; diff --git a/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts b/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts index c3ae062d76523..f95ce25122923 100644 --- a/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts +++ b/x-pack/plugins/triggers_actions_ui/common/experimental_features.ts @@ -13,6 +13,7 @@ export type ExperimentalFeatures = typeof allowedExperimentalValues; */ export const allowedExperimentalValues = Object.freeze({ rulesListDatagrid: true, + internalAlertsTable: false, rulesDetailLogs: true, }); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/app.tsx b/x-pack/plugins/triggers_actions_ui/public/application/app.tsx index b2c350a4f1f29..0701eac20a850 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/app.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/app.tsx @@ -59,7 +59,7 @@ export const renderApp = (deps: TriggersAndActionsUiServices) => { export const App = ({ deps }: { deps: TriggersAndActionsUiServices }) => { const { savedObjects, uiSettings, theme$ } = deps; - const sections: Section[] = ['rules', 'connectors']; + const sections: Section[] = ['rules', 'connectors', 'alerts']; const isDarkMode = useObservable(uiSettings.get$('theme:darkMode')); const sectionsRegex = sections.join('|'); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts b/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts index 0058147ca0d05..0d26abc3bc67b 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts +++ b/x-pack/plugins/triggers_actions_ui/public/application/constants/index.ts @@ -13,12 +13,13 @@ export { } from '../../../../alerting/common'; export { BASE_ACTION_API_PATH, INTERNAL_BASE_ACTION_API_PATH } from '../../../../actions/common'; -export type Section = 'connectors' | 'rules'; +export type Section = 'connectors' | 'rules' | 'alerts'; export const routeToHome = `/`; export const routeToConnectors = `/connectors`; export const routeToRules = `/rules`; export const routeToRuleDetails = `/rule/:ruleId`; +export const routeToInternalAlerts = `/alerts`; export const legacyRouteToRules = `/alerts`; export const legacyRouteToRuleDetails = `/alert/:alertId`; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/home.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/home.test.tsx index 51f80438c55cc..6236e9e2d3d27 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/home.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/home.test.tsx @@ -10,11 +10,20 @@ import { RouteComponentProps, Router } from 'react-router-dom'; import { createMemoryHistory, createLocation } from 'history'; import { mountWithIntl } from '@kbn/test-jest-helpers'; import TriggersActionsUIHome, { MatchParams } from './home'; +import { hasShowActionsCapability } from './lib/capabilities'; import { useKibana } from '../common/lib/kibana'; +import { getIsExperimentalFeatureEnabled } from '../common/get_experimental_features'; jest.mock('../common/lib/kibana'); +jest.mock('../common/get_experimental_features'); +jest.mock('./lib/capabilities'); const useKibanaMock = useKibana as jest.Mocked; describe('home', () => { + beforeEach(() => { + (hasShowActionsCapability as jest.Mock).mockClear(); + (getIsExperimentalFeatureEnabled as jest.Mock).mockClear(); + }); + it('renders the documentation link', async () => { const props: RouteComponentProps = { history: createMemoryHistory(), @@ -40,4 +49,38 @@ describe('home', () => { 'https://www.elastic.co/guide/en/kibana/mocked-test-branch/create-and-manage-rules.html' ); }); + + it('hides the internal alerts table route if the config is not set', async () => { + (hasShowActionsCapability as jest.Mock).mockImplementation(() => { + return true; + }); + const props: RouteComponentProps = { + history: createMemoryHistory(), + location: createLocation('/'), + match: { + isExact: true, + path: `/connectorss`, + url: '', + params: { + section: 'connectors', + }, + }, + }; + + let home = mountWithIntl(); + + // Just rules/connectors + expect(home.find('.euiTab__content').length).toBe(2); + + (getIsExperimentalFeatureEnabled as jest.Mock).mockImplementation((feature: string) => { + if (feature === 'internalAlertsTable') { + return true; + } + return false; + }); + + home = mountWithIntl(); + // alerts now too! + expect(home.find('.euiTab__content').length).toBe(3); + }); }); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/home.tsx b/x-pack/plugins/triggers_actions_ui/public/application/home.tsx index 1489397e1e7e3..9110ebe1f51c8 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/home.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/home.tsx @@ -6,11 +6,12 @@ */ import React, { lazy, useEffect } from 'react'; -import { Route, RouteComponentProps, Switch } from 'react-router-dom'; +import { Route, RouteComponentProps, Switch, Redirect } from 'react-router-dom'; import { FormattedMessage } from '@kbn/i18n-react'; import { EuiSpacer, EuiButtonEmpty, EuiPageHeader } from '@elastic/eui'; -import { Section, routeToConnectors, routeToRules } from './constants'; +import { getIsExperimentalFeatureEnabled } from '../common/get_experimental_features'; +import { Section, routeToConnectors, routeToRules, routeToInternalAlerts } from './constants'; import { getAlertingSectionBreadcrumb } from './lib/breadcrumb'; import { getCurrentDocTitle } from './lib/doc_title'; import { hasShowActionsCapability } from './lib/capabilities'; @@ -24,6 +25,7 @@ const ActionsConnectorsList = lazy( () => import('./sections/actions_connectors_list/components/actions_connectors_list') ); const RulesList = lazy(() => import('./sections/rules_list/components/rules_list')); +const AlertsPage = lazy(() => import('./sections/alerts_table/alerts_page')); export interface MatchParams { section: Section; @@ -38,9 +40,11 @@ export const TriggersActionsUIHome: React.FunctionComponent + ), + }); + } + const onSectionChange = (newSection: Section) => { history.push(`/${newSection}`); }; @@ -134,6 +150,15 @@ export const TriggersActionsUIHome: React.FunctionComponent + {isInternalAlertsTableEnabled ? ( + + ) : ( + + )} diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/README.md b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/README.md new file mode 100644 index 0000000000000..6e57a57f7abdf --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/README.md @@ -0,0 +1 @@ +Note: This entire folder is meant for internal, testing purposes and is not exposed to users. \ No newline at end of file diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/alerts_page.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/alerts_page.tsx new file mode 100644 index 0000000000000..c3c02dd064bcb --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/alerts_page.tsx @@ -0,0 +1,195 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React, { useState, useCallback, useEffect } from 'react'; +import { get } from 'lodash'; +import { + EuiDataGridCellValueElementProps, + EuiDataGridControlColumn, + EuiFlexItem, + EuiFlexGroup, + EuiSpacer, + EuiProgress, +} from '@elastic/eui'; +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { AlertConsumers } from '@kbn/rule-data-utils'; +import { + RuleRegistrySearchRequest, + RuleRegistrySearchResponse, + RuleRegistrySearchRequestPagination, +} from '../../../../../../rule_registry/common'; +import { AlertsTable } from '../alerts_table'; +import { useKibana } from '../../../../common/lib/kibana'; +import { AbortError } from '../../../../../../../../src/plugins/kibana_utils/common'; +import { AlertsData } from '../../../../types'; + +const consumers = [ + AlertConsumers.APM, + AlertConsumers.LOGS, + AlertConsumers.UPTIME, + AlertConsumers.INFRASTRUCTURE, +]; + +const defaultPagination = { + pageSize: 10, + pageIndex: 0, +}; + +const defaultSort: estypes.SortCombinations[] = [ + { + 'event.action': { + order: 'asc', + }, + }, +]; + +const AlertsPage: React.FunctionComponent = () => { + const { data, notifications } = useKibana().services; + const [showCheckboxes] = useState(false); + const [isLoading, setIsLoading] = useState(false); + const [isInitializing, setIsInitializing] = useState(true); + const [alertsCount, setAlertsCount] = useState(0); + const [alerts, setAlerts] = useState([]); + const [sort, setSort] = useState(defaultSort); + const [pagination, setPagination] = useState(defaultPagination); + + const onPageChange = (_pagination: RuleRegistrySearchRequestPagination) => { + setPagination(_pagination); + }; + const onSortChange = (_sort: Array<{ id: string; direction: 'asc' | 'desc' }>) => { + setSort( + _sort.map(({ id, direction }) => { + return { + [id]: { + order: direction, + }, + }; + }) + ); + }; + + const asyncSearch = useCallback(() => { + setIsLoading(true); + const abortController = new AbortController(); + const request: RuleRegistrySearchRequest = { + featureIds: consumers, + sort, + pagination, + }; + data.search + .search(request, { + strategy: 'privateRuleRegistryAlertsSearchStrategy', + abortSignal: abortController.signal, + }) + .subscribe({ + next: (res) => { + const alertsResponse = res.rawResponse.hits.hits.map( + (hit) => hit.fields as unknown as AlertsData + ) as AlertsData[]; + setAlerts(alertsResponse); + const total = !isNaN(res.rawResponse.hits.total as number) + ? (res.rawResponse.hits.total as number) + : (res.rawResponse.hits.total as estypes.SearchTotalHits).value ?? 0; + setAlertsCount(total); + setIsLoading(false); + }, + error: (e) => { + if (e instanceof AbortError) { + notifications.toasts.addWarning({ + title: e.message, + }); + } else { + notifications.toasts.addDanger({ + title: 'Failed to run search', + text: e.message, + }); + } + setIsLoading(false); + }, + }); + setIsInitializing(false); + }, [data.search, notifications.toasts, sort, pagination]); + + useEffect(() => { + asyncSearch(); + }, [asyncSearch]); + + const useFetchAlertsData = () => { + return { + activePage: pagination.pageIndex, + alerts, + alertsCount, + isInitializing, + isLoading, + getInspectQuery: () => ({ request: {}, response: {} }), + onColumnsChange: (columns: EuiDataGridControlColumn[]) => {}, + onPageChange, + onSortChange, + refresh: () => { + asyncSearch(); + }, + }; + }; + + const tableProps = { + consumers, + bulkActions: [], + columns: [ + { + id: 'event.action', + displayAsText: 'Alert status', + initialWidth: 150, + }, + { + id: '@timestamp', + displayAsText: 'Last updated', + initialWidth: 250, + }, + { + id: 'kibana.alert.duration.us', + displayAsText: 'Duration', + initialWidth: 150, + }, + { + id: 'kibana.alert.reason', + displayAsText: 'Reason', + }, + ], + deletedEventIds: [], + disabledCellActions: [], + pageSize: defaultPagination.pageSize, + pageSizeOptions: [2, 5, 10, 20, 50, 100], + leadingControlColumns: [], + renderCellValue: (rcvProps: EuiDataGridCellValueElementProps) => { + const { columnId, visibleRowIndex } = rcvProps as EuiDataGridCellValueElementProps & { + visibleRowIndex: number; + }; + const value = (get(alerts[visibleRowIndex], columnId) ?? [])[0]; + return value ?? 'N/A'; + }, + showCheckboxes, + trailingControlColumns: [], + useFetchAlertsData, + 'data-test-subj': 'internalAlertsPage', + }; + + return ( +
+

THIS IS AN INTERNAL TEST PAGE

+ + + + {isLoading && ( + + )} + + + +
+ ); +}; + +export { AlertsPage }; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/index.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/index.ts new file mode 100644 index 0000000000000..c574bda7f14ff --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_page/index.ts @@ -0,0 +1,9 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { AlertsPage } from './alerts_page'; +// eslint-disable-next-line import/no-default-export +export { AlertsPage as default }; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.test.tsx new file mode 100644 index 0000000000000..c0a50e460fe8a --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React from 'react'; +import { mountWithIntl, nextTick } from '@kbn/test-jest-helpers'; +import { act } from 'react-dom/test-utils'; +import { AlertConsumers } from '@kbn/rule-data-utils'; +import { AlertsTable } from './alerts_table'; +import { AlertsData } from '../../../types'; +jest.mock('../../../../../../../src/plugins/data/public/'); +jest.mock('../../../common/lib/kibana'); + +describe('AlertsTable', () => { + const consumers = [ + AlertConsumers.APM, + AlertConsumers.LOGS, + AlertConsumers.UPTIME, + AlertConsumers.INFRASTRUCTURE, + AlertConsumers.SIEM, + ]; + const columns = [ + { + id: 'kibana.alert.rule.name', + displayAsText: 'Name', + }, + { + id: 'kibana.alert.rule.category', + displayAsText: 'Category', + }, + ]; + + const alerts: AlertsData[] = [ + { + field1: ['one'], + field2: ['two'], + }, + { + field1: ['three'], + field2: ['four'], + }, + ]; + const fetchAlertsData = { + activePage: 0, + alerts, + alertsCount: alerts.length, + isInitializing: false, + isLoading: false, + getInspectQuery: jest.fn().mockImplementation(() => ({ request: {}, response: {} })), + onColumnsChange: jest.fn(), + onPageChange: jest.fn(), + onSortChange: jest.fn(), + refresh: jest.fn(), + }; + const useFetchAlertsData = () => { + return fetchAlertsData; + }; + + const tableProps = { + consumers, + bulkActions: [], + columns, + deletedEventIds: [], + disabledCellActions: [], + pageSize: 1, + pageSizeOptions: [1, 2, 5, 10, 20, 50, 100], + leadingControlColumns: [], + renderCellValue: jest.fn().mockImplementation((props) => { + return `${props.colIndex}:${props.rowIndex}`; + }), + showCheckboxes: false, + trailingControlColumns: [], + useFetchAlertsData, + 'data-test-subj': 'testTable', + }; + + it('should support sorting', async () => { + const wrapper = mountWithIntl(); + await act(async () => { + await nextTick(); + wrapper.update(); + }); + wrapper.find('.euiDataGridHeaderCell__button').first().simulate('click'); + wrapper.update(); + wrapper + .find(`[data-test-subj="dataGridHeaderCellActionGroup-${columns[0].id}"]`) + .first() + .simulate('click'); + wrapper.find(`.euiListGroupItem__label[title="Sort A-Z"]`).simulate('click'); + expect(fetchAlertsData.onSortChange).toHaveBeenCalledWith([ + { direction: 'asc', id: 'kibana.alert.rule.name' }, + ]); + }); + + it('should support pagination', async () => { + const wrapper = mountWithIntl(); + await act(async () => { + await nextTick(); + wrapper.update(); + }); + wrapper.find('.euiPagination__item EuiButtonEmpty').at(1).simulate('click'); + expect(fetchAlertsData.onPageChange).toHaveBeenCalledWith({ pageIndex: 1, pageSize: 1 }); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.tsx new file mode 100644 index 0000000000000..2568c5b96407b --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/alerts_table.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React, { useState } from 'react'; +import { EuiDataGrid } from '@elastic/eui'; +import { useSorting, usePagination } from './hooks'; +import { AlertsTableProps } from '../../../types'; + +const AlertsTable: React.FunctionComponent = (props: AlertsTableProps) => { + const { activePage, alertsCount, onPageChange, onSortChange } = props.useFetchAlertsData(); + const { sortingColumns, onSort } = useSorting(onSortChange); + const { pagination, onChangePageSize, onChangePageIndex } = usePagination({ + onPageChange, + pageIndex: activePage, + pageSize: props.pageSize, + }); + + const [visibleColumns, setVisibleColumns] = useState(props.columns.map(({ id }) => id)); + + return ( +
+ +
+ ); +}; + +export { AlertsTable }; +// eslint-disable-next-line import/no-default-export +export { AlertsTable as default }; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/index.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/index.ts new file mode 100644 index 0000000000000..9da3178db8c39 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +export { usePagination } from './use_pagination'; +export { useSorting } from './use_sorting'; diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.test.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.test.ts new file mode 100644 index 0000000000000..8b8ff68f106c2 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.test.ts @@ -0,0 +1,45 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { usePagination } from './use_pagination'; +import { renderHook, act } from '@testing-library/react-hooks'; + +describe('usePagination', () => { + const onPageChange = jest.fn(); + const pageIndex = 0; + const pageSize = 10; + + beforeEach(() => { + onPageChange.mockClear(); + }); + + it('should return the pagination information and callback functions', () => { + const { result } = renderHook(() => usePagination({ onPageChange, pageIndex, pageSize })); + expect(result.current.pagination).toStrictEqual({ pageIndex, pageSize }); + expect(result.current.onChangePageSize).toBeDefined(); + expect(result.current.onChangePageIndex).toBeDefined(); + }); + + it('should change the pagination when `onChangePageSize` is called', () => { + const { result } = renderHook(() => usePagination({ onPageChange, pageIndex, pageSize })); + + act(() => { + result.current.onChangePageSize(20); + }); + + expect(result.current.pagination).toStrictEqual({ pageIndex, pageSize: 20 }); + }); + + it('should change the pagination when `onChangePageIndex` is called', () => { + const { result } = renderHook(() => usePagination({ onPageChange, pageIndex, pageSize })); + + act(() => { + result.current.onChangePageIndex(1); + }); + + expect(result.current.pagination).toStrictEqual({ pageIndex: 1, pageSize }); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.ts new file mode 100644 index 0000000000000..4f00e05ed1122 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_pagination.ts @@ -0,0 +1,38 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { useCallback, useState } from 'react'; +import { RuleRegistrySearchRequestPagination } from '../../../../../../rule_registry/common'; + +type PaginationProps = RuleRegistrySearchRequestPagination & { + onPageChange: (pagination: RuleRegistrySearchRequestPagination) => void; +}; + +export function usePagination({ onPageChange, pageIndex, pageSize }: PaginationProps) { + const [pagination, setPagination] = useState({ + pageIndex, + pageSize, + }); + const onChangePageSize = useCallback( + (_pageSize) => { + setPagination((state) => ({ + ...state, + pageSize: _pageSize, + pageIndex: 0, + })); + onPageChange({ pageIndex: 0, pageSize: _pageSize }); + }, + [setPagination, onPageChange] + ); + const onChangePageIndex = useCallback( + (_pageIndex) => { + setPagination((state) => ({ ...state, pageIndex: _pageIndex })); + onPageChange({ pageIndex: _pageIndex, pageSize: pagination.pageSize }); + }, + [setPagination, onPageChange, pagination.pageSize] + ); + return { pagination, onChangePageSize, onChangePageIndex }; +} diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.test.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.test.ts new file mode 100644 index 0000000000000..487f6908a334e --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { useSorting } from './use_sorting'; +import { renderHook, act } from '@testing-library/react-hooks'; + +describe('useSorting', () => { + const onSortChange = jest.fn(); + + beforeEach(() => { + onSortChange.mockClear(); + }); + + it('should return the sorted columns and the callback function to call when sort changes', () => { + const { result } = renderHook(() => useSorting(onSortChange)); + expect(result.current.sortingColumns).toStrictEqual([]); + expect(result.current.onSort).toBeDefined(); + }); + + it('should change the columns when `onSort` is called', () => { + const { result } = renderHook(() => useSorting(onSortChange)); + + act(() => { + result.current.onSort([{ id: 'field', direction: 'asc' }]); + }); + + expect(onSortChange).toHaveBeenCalledWith([{ direction: 'asc', id: 'field' }]); + expect(result.current.sortingColumns).toStrictEqual([{ direction: 'asc', id: 'field' }]); + }); +}); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.ts new file mode 100644 index 0000000000000..cbb84c95806a0 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/hooks/use_sorting.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { useCallback, useState } from 'react'; + +export function useSorting( + onSortChange: (sort: Array<{ id: string; direction: 'asc' | 'desc' }>) => void +) { + const [sortingColumns, setSortingColumns] = useState([]); + const onSort = useCallback( + (_state) => { + onSortChange(_state); + setSortingColumns(_state); + }, + [setSortingColumns, onSortChange] + ); + return { sortingColumns, onSort }; +} diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/index.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/index.ts new file mode 100644 index 0000000000000..7fec39ad65d57 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/index.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { lazy } from 'react'; +import { suspendedComponentWithProps } from '../../lib/suspended_component_with_props'; + +export const AlertsTable = suspendedComponentWithProps(lazy(() => import('./alerts_table'))); diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/types.ts b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/types.ts new file mode 100644 index 0000000000000..9622477db3a30 --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/alerts_table/types.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { AlertConsumers } from '@kbn/rule-data-utils'; + +export interface Consumer { + id: AlertConsumers; + name: string; +} diff --git a/x-pack/plugins/triggers_actions_ui/public/common/get_alerts_table.tsx b/x-pack/plugins/triggers_actions_ui/public/common/get_alerts_table.tsx new file mode 100644 index 0000000000000..4c2727cd9976d --- /dev/null +++ b/x-pack/plugins/triggers_actions_ui/public/common/get_alerts_table.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { AlertsTable } from '../application/sections/alerts_table'; +import type { AlertsTableProps } from '../types'; + +export const getAlertsTableLazy = (props: AlertsTableProps) => { + return ; +}; diff --git a/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx b/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx index 0b865eb5b61be..aa7de97a6c889 100644 --- a/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.test.tsx @@ -5,14 +5,18 @@ * 2.0. */ +import { getExperimentalAllowedValues } from '../../common/experimental_features'; import { ExperimentalFeaturesService } from './experimental_features_service'; import { getIsExperimentalFeatureEnabled } from './get_experimental_features'; +const allowedExperimentalValueKeys = getExperimentalAllowedValues(); + describe('getIsExperimentalFeatureEnabled', () => { it('getIsExperimentalFeatureEnabled returns the flag enablement', async () => { ExperimentalFeaturesService.init({ experimentalFeatures: { rulesListDatagrid: true, + internalAlertsTable: true, rulesDetailLogs: true, }, }); @@ -25,8 +29,14 @@ describe('getIsExperimentalFeatureEnabled', () => { expect(result).toEqual(true); + result = getIsExperimentalFeatureEnabled('internalAlertsTable'); + + expect(result).toEqual(true); + expect(() => getIsExperimentalFeatureEnabled('doesNotExist' as any)).toThrowError( - 'Invalid enable value doesNotExist. Allowed values are: rulesListDatagrid, rulesDetailLogs' + `Invalid enable value doesNotExist. Allowed values are: ${allowedExperimentalValueKeys.join( + ', ' + )}` ); }); }); diff --git a/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.ts b/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.ts index 706af60579711..41a321bbd2981 100644 --- a/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.ts +++ b/x-pack/plugins/triggers_actions_ui/public/common/get_experimental_features.ts @@ -7,10 +7,10 @@ import { ExperimentalFeatures, - allowedExperimentalValues, isValidExperimentalValue, getExperimentalAllowedValues, } from '../../common/experimental_features'; +import { ExperimentalFeaturesService } from './experimental_features_service'; const allowedExperimentalValueKeys = getExperimentalAllowedValues(); @@ -23,5 +23,5 @@ export const getIsExperimentalFeatureEnabled = (feature: keyof ExperimentalFeatu ); } - return allowedExperimentalValues[feature]; + return ExperimentalFeaturesService.get()[feature]; }; diff --git a/x-pack/plugins/triggers_actions_ui/public/mocks.ts b/x-pack/plugins/triggers_actions_ui/public/mocks.ts index 7a0420594118b..706a66963e22f 100644 --- a/x-pack/plugins/triggers_actions_ui/public/mocks.ts +++ b/x-pack/plugins/triggers_actions_ui/public/mocks.ts @@ -20,7 +20,9 @@ import { RuleTypeModel, ConnectorAddFlyoutProps, ConnectorEditFlyoutProps, + AlertsTableProps, } from './types'; +import { getAlertsTableLazy } from './common/get_alerts_table'; function createStartMock(): TriggersAndActionsUIPublicPluginStart { const actionTypeRegistry = new TypeRegistry(); @@ -51,6 +53,9 @@ function createStartMock(): TriggersAndActionsUIPublicPluginStart { ruleTypeRegistry, }); }, + getAlertsTable: (props: AlertsTableProps) => { + return getAlertsTableLazy(props); + }, }; } diff --git a/x-pack/plugins/triggers_actions_ui/public/plugin.ts b/x-pack/plugins/triggers_actions_ui/public/plugin.ts index afeff4ba8364e..1993f0f931e17 100644 --- a/x-pack/plugins/triggers_actions_ui/public/plugin.ts +++ b/x-pack/plugins/triggers_actions_ui/public/plugin.ts @@ -32,6 +32,7 @@ import { getAddConnectorFlyoutLazy } from './common/get_add_connector_flyout'; import { getEditConnectorFlyoutLazy } from './common/get_edit_connector_flyout'; import { getAddAlertFlyoutLazy } from './common/get_add_alert_flyout'; import { getEditAlertFlyoutLazy } from './common/get_edit_alert_flyout'; +import { getAlertsTableLazy } from './common/get_alerts_table'; import { ExperimentalFeaturesService } from './common/experimental_features_service'; import { ExperimentalFeatures, @@ -45,6 +46,7 @@ import type { RuleTypeModel, ConnectorAddFlyoutProps, ConnectorEditFlyoutProps, + AlertsTableProps, } from './types'; import { TriggersActionsUiConfigType } from '../common/types'; @@ -68,6 +70,7 @@ export interface TriggersAndActionsUIPublicPluginStart { getEditAlertFlyout: ( props: Omit ) => ReactElement; + getAlertsTable: (props: AlertsTableProps) => ReactElement; } interface PluginsSetup { @@ -215,6 +218,9 @@ export class Plugin ruleTypeRegistry: this.ruleTypeRegistry, }); }, + getAlertsTable: (props: AlertsTableProps) => { + return getAlertsTableLazy(props); + }, }; } diff --git a/x-pack/plugins/triggers_actions_ui/public/types.ts b/x-pack/plugins/triggers_actions_ui/public/types.ts index 7a1efaed33abf..c459d118c69b9 100644 --- a/x-pack/plugins/triggers_actions_ui/public/types.ts +++ b/x-pack/plugins/triggers_actions_ui/public/types.ts @@ -8,9 +8,15 @@ import type { PublicMethodsOf } from '@kbn/utility-types'; import type { DocLinksStart } from 'kibana/public'; import { ComponentType } from 'react'; +import { AlertConsumers } from '@kbn/rule-data-utils'; import { ChartsPluginSetup } from 'src/plugins/charts/public'; import { DataPublicPluginStart } from 'src/plugins/data/public'; -import { IconType } from '@elastic/eui'; +import { + IconType, + EuiDataGridColumn, + EuiDataGridControlColumn, + EuiDataGridCellValueElementProps, +} from '@elastic/eui'; import { ActionType, AlertHistoryEsIndexConnectorId, @@ -38,6 +44,7 @@ import { ActionVariable, RuleType as CommonRuleType, } from '../../alerting/common'; +import { RuleRegistrySearchRequestPagination } from '../../rule_registry/common'; // In Triggers and Actions we treat all `Alert`s as `SanitizedRule` // so the `Params` is a black-box of Record @@ -355,3 +362,41 @@ export interface TriggersActionsUiConfig { enforce: boolean; }; } + +export type AlertsData = Record; + +export interface FetchAlertData { + activePage: number; + alerts: AlertsData[]; + alertsCount: number; + isInitializing: boolean; + isLoading: boolean; + getInspectQuery: () => { request: {}; response: {} }; + onColumnsChange: (columns: EuiDataGridControlColumn[]) => void; + onPageChange: (pagination: RuleRegistrySearchRequestPagination) => void; + onSortChange: (sort: Array<{ id: string; direction: 'asc' | 'desc' }>) => void; + refresh: () => void; +} + +export interface BulkActionsObjectProp { + alertStatusActions?: boolean; + onAlertStatusActionSuccess?: void; + onAlertStatusActionFailure?: void; +} + +export interface AlertsTableProps { + consumers: AlertConsumers[]; + bulkActions: BulkActionsObjectProp; + columns: EuiDataGridColumn[]; + // defaultCellActions: TGridCellAction[]; + deletedEventIds: string[]; + disabledCellActions: string[]; + pageSize: number; + pageSizeOptions: number[]; + leadingControlColumns: EuiDataGridControlColumn[]; + renderCellValue: (props: EuiDataGridCellValueElementProps) => React.ReactNode; + showCheckboxes: boolean; + trailingControlColumns: EuiDataGridControlColumn[]; + useFetchAlertsData: () => FetchAlertData; + 'data-test-subj': string; +} diff --git a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts_table.ts b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts_table.ts new file mode 100644 index 0000000000000..f0797ffd54d91 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts_table.ts @@ -0,0 +1,157 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import expect from '@kbn/expect'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +export default ({ getPageObjects, getService }: FtrProviderContext) => { + const testSubjects = getService('testSubjects'); + const PageObjects = getPageObjects(['common', 'triggersActionsUI', 'header']); + const retry = getService('retry'); + const esArchiver = getService('esArchiver'); + const find = getService('find'); + + describe('Alerts table', function () { + before(async () => { + await esArchiver.load('x-pack/test/functional/es_archives/observability/alerts'); + }); + after(async () => { + await esArchiver.unload('x-pack/test/functional/es_archives/observability/alerts'); + }); + + it('should load the table', async () => { + await PageObjects.common.navigateToUrlWithBrowserHistory('triggersActions', '/alerts'); + const headingText = await PageObjects.triggersActionsUI.getSectionHeadingText(); + expect(headingText).to.be('Rules and Connectors'); + + await waitTableIsLoaded(); + + const euiDataGridRows = await find.allByCssSelector('.euiDataGridRow'); + const rows = []; + for (const euiDataGridRow of euiDataGridRows) { + const $ = await euiDataGridRow.parseDomContent(); + rows.push({ + status: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="event.action"] .euiDataGridRowCell__truncate') + .text(), + lastUpdated: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="@timestamp"] .euiDataGridRowCell__truncate') + .text(), + duration: $.findTestSubjects('dataGridRowCell') + .find( + '[data-gridcell-column-id="kibana.alert.duration.us"] .euiDataGridRowCell__truncate' + ) + .text(), + reason: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="kibana.alert.reason"] .euiDataGridRowCell__truncate') + .text(), + }); + } + expect(rows.length).to.be(10); + expect(rows[0].status).to.be('active'); + expect(rows[0].lastUpdated).to.be('2021-10-19T15:20:38.749Z'); + expect(rows[0].duration).to.be('1197194000'); + expect(rows[0].reason).to.be( + 'Failed transactions rate is greater than 5.0% (current value is 31%) for elastic-co-frontend' + ); + }); + + it('should sort properly', async () => { + await PageObjects.common.navigateToUrlWithBrowserHistory('triggersActions', '/alerts'); + const headingText = await PageObjects.triggersActionsUI.getSectionHeadingText(); + expect(headingText).to.be('Rules and Connectors'); + + await waitTableIsLoaded(); + + await find.clickDisplayedByCssSelector( + '[data-test-subj="dataGridHeaderCell-event.action"] .euiDataGridHeaderCell__button' + ); + + const popoverButtons = await testSubjects.find('dataGridHeaderCellActionGroup-event.action'); + await (await popoverButtons.findAllByCssSelector('.euiListGroupItem__button'))[2].click(); + + await waitTableIsLoaded(); + + const euiDataGridRows = await find.allByCssSelector('.euiDataGridRow'); + const rows = []; + for (const euiDataGridRow of euiDataGridRows) { + const $ = await euiDataGridRow.parseDomContent(); + rows.push({ + status: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="event.action"] .euiDataGridRowCell__truncate') + .text(), + lastUpdated: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="@timestamp"] .euiDataGridRowCell__truncate') + .text(), + duration: $.findTestSubjects('dataGridRowCell') + .find( + '[data-gridcell-column-id="kibana.alert.duration.us"] .euiDataGridRowCell__truncate' + ) + .text(), + reason: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="kibana.alert.reason"] .euiDataGridRowCell__truncate') + .text(), + }); + } + expect(rows.length).to.be(10); + expect(rows[0].status).to.be('open'); + expect(rows[0].lastUpdated).to.be('2021-10-19T15:20:26.974Z'); + expect(rows[0].duration).to.be('0'); + expect(rows[0].reason).to.be( + 'CPU usage is greater than a threshold of 40 (current value is 45.2%) for gke-edge-oblt-default-pool-350b44de-c3dd' + ); + }); + + it('should paginate properly', async () => { + await PageObjects.common.navigateToUrlWithBrowserHistory('triggersActions', '/alerts'); + const headingText = await PageObjects.triggersActionsUI.getSectionHeadingText(); + expect(headingText).to.be('Rules and Connectors'); + + await waitTableIsLoaded(); + + await testSubjects.click('pagination-button-1'); + + await waitTableIsLoaded(); + + const euiDataGridRows = await find.allByCssSelector('.euiDataGridRow'); + const rows = []; + for (const euiDataGridRow of euiDataGridRows) { + const $ = await euiDataGridRow.parseDomContent(); + rows.push({ + status: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="event.action"] .euiDataGridRowCell__truncate') + .text(), + lastUpdated: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="@timestamp"] .euiDataGridRowCell__truncate') + .text(), + duration: $.findTestSubjects('dataGridRowCell') + .find( + '[data-gridcell-column-id="kibana.alert.duration.us"] .euiDataGridRowCell__truncate' + ) + .text(), + reason: $.findTestSubjects('dataGridRowCell') + .find('[data-gridcell-column-id="kibana.alert.reason"] .euiDataGridRowCell__truncate') + .text(), + }); + } + expect(rows.length).to.be(10); + expect(rows[0].status).to.be('active'); + expect(rows[0].lastUpdated).to.be('2021-10-19T15:20:26.974Z'); + expect(rows[0].duration).to.be('63291000'); + expect(rows[0].reason).to.be( + 'CPU usage is greater than a threshold of 40 (current value is 40.8%) for gke-edge-oblt-default-pool-350b44de-3v4p' + ); + }); + + async function waitTableIsLoaded() { + return await retry.try(async () => { + const exists = await testSubjects.exists('internalAlertsPageLoading'); + if (exists) throw new Error('Still loading...'); + }); + } + }); +}; 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 index e70d4fdc96f61..76a952c354ab4 100644 --- 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 @@ -15,5 +15,6 @@ export default ({ loadTestFile, getService }: FtrProviderContext) => { loadTestFile(require.resolve('./alert_create_flyout')); loadTestFile(require.resolve('./details')); loadTestFile(require.resolve('./connectors')); + loadTestFile(require.resolve('./alerts_table')); }); }; diff --git a/x-pack/test/functional_with_es_ssl/config.ts b/x-pack/test/functional_with_es_ssl/config.ts index b2b6735a99c8b..dc2f6b8618ce3 100644 --- a/x-pack/test/functional_with_es_ssl/config.ts +++ b/x-pack/test/functional_with_es_ssl/config.ts @@ -67,6 +67,7 @@ export default async function ({ readConfigFile }: FtrConfigProviderContext) { `--elasticsearch.hosts=https://${servers.elasticsearch.hostname}:${servers.elasticsearch.port}`, `--elasticsearch.ssl.certificateAuthorities=${CA_CERT_PATH}`, `--plugin-path=${join(__dirname, 'fixtures', 'plugins', 'alerts')}`, + `--xpack.trigger_actions_ui.enableExperimental=${JSON.stringify(['internalAlertsTable'])}`, `--xpack.alerting.rules.minimumScheduleInterval.value="2s"`, `--xpack.actions.enabledActionTypes=${JSON.stringify(enabledActionTypes)}`, `--xpack.actions.preconfiguredAlertHistoryEsIndex=false`, From 74450ad697f3a770f38a5123d400e0077cfe124b Mon Sep 17 00:00:00 2001 From: Candace Park <56409205+parkiino@users.noreply.github.com> Date: Tue, 29 Mar 2022 11:02:09 -0400 Subject: [PATCH 091/160] [Security Solution][Endpoint][Admin][Policy] Enable Policy list feature flag (#128698) --- .../plugins/security_solution/common/experimental_features.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/plugins/security_solution/common/experimental_features.ts b/x-pack/plugins/security_solution/common/experimental_features.ts index 3a932238f3a34..a9cf3e4a8132e 100644 --- a/x-pack/plugins/security_solution/common/experimental_features.ts +++ b/x-pack/plugins/security_solution/common/experimental_features.ts @@ -24,7 +24,7 @@ export const allowedExperimentalValues = Object.freeze({ riskyUsersEnabled: false, securityRulesCancelEnabled: false, pendingActionResponsesWithAck: true, - policyListEnabled: false, + policyListEnabled: true, /** * This is used for enabling the end to end tests for the security_solution telemetry. From e906db25664b70bded74c2c7233abc9b15d67e68 Mon Sep 17 00:00:00 2001 From: Nicolas Chaulet Date: Tue, 29 Mar 2022 11:03:04 -0400 Subject: [PATCH 092/160] [Fleet] Merge settings & mappings component template in @package (#128498) --- .../fleet/server/constants/fleet_es_assets.ts | 3 +- .../plugins/fleet/server/constants/index.ts | 3 +- .../epm/elasticsearch/template/install.ts | 34 +- .../epm/__snapshots__/install_by_upload.snap | 735 ------------------ .../apis/epm/install_by_upload.ts | 4 +- .../apis/epm/install_overrides.ts | 23 +- .../apis/epm/install_remove_assets.ts | 45 +- .../apis/epm/update_assets.ts | 69 +- 8 files changed, 52 insertions(+), 864 deletions(-) delete mode 100644 x-pack/test/fleet_api_integration/apis/epm/__snapshots__/install_by_upload.snap diff --git a/x-pack/plugins/fleet/server/constants/fleet_es_assets.ts b/x-pack/plugins/fleet/server/constants/fleet_es_assets.ts index 859a25a0ec7c7..56aaf450d46e9 100644 --- a/x-pack/plugins/fleet/server/constants/fleet_es_assets.ts +++ b/x-pack/plugins/fleet/server/constants/fleet_es_assets.ts @@ -8,9 +8,8 @@ import { getESAssetMetadata } from '../services/epm/elasticsearch/meta'; const meta = getESAssetMetadata(); -export const MAPPINGS_TEMPLATE_SUFFIX = '@mappings'; -export const SETTINGS_TEMPLATE_SUFFIX = '@settings'; +export const PACKAGE_TEMPLATE_SUFFIX = '@package'; export const USER_SETTINGS_TEMPLATE_SUFFIX = '@custom'; diff --git a/x-pack/plugins/fleet/server/constants/index.ts b/x-pack/plugins/fleet/server/constants/index.ts index ec7a4a2664882..813f381ecc4fc 100644 --- a/x-pack/plugins/fleet/server/constants/index.ts +++ b/x-pack/plugins/fleet/server/constants/index.ts @@ -66,7 +66,6 @@ export { FLEET_FINAL_PIPELINE_ID, FLEET_FINAL_PIPELINE_CONTENT, FLEET_FINAL_PIPELINE_VERSION, - MAPPINGS_TEMPLATE_SUFFIX, - SETTINGS_TEMPLATE_SUFFIX, USER_SETTINGS_TEMPLATE_SUFFIX, + PACKAGE_TEMPLATE_SUFFIX, } from './fleet_es_assets'; diff --git a/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/install.ts b/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/install.ts index f30971c0e7d5e..a77f843aef2d3 100644 --- a/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/install.ts +++ b/x-pack/plugins/fleet/server/services/epm/elasticsearch/template/install.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { merge, cloneDeep } from 'lodash'; +import { merge } from 'lodash'; import Boom from '@hapi/boom'; import type { ElasticsearchClient, Logger, SavedObjectsClientContract } from 'src/core/server'; @@ -29,8 +29,7 @@ import { getAsset, getPathParts } from '../../archive'; import { removeAssetTypesFromInstalledEs, saveInstalledEsRefs } from '../../packages/install'; import { FLEET_COMPONENT_TEMPLATES, - MAPPINGS_TEMPLATE_SUFFIX, - SETTINGS_TEMPLATE_SUFFIX, + PACKAGE_TEMPLATE_SUFFIX, USER_SETTINGS_TEMPLATE_SUFFIX, } from '../../../../constants'; @@ -245,34 +244,28 @@ function buildComponentTemplates(params: { defaultSettings: IndexTemplate['template']['settings']; }) { const { templateName, registryElasticsearch, packageName, defaultSettings, mappings } = params; - const mappingsTemplateName = `${templateName}${MAPPINGS_TEMPLATE_SUFFIX}`; - const settingsTemplateName = `${templateName}${SETTINGS_TEMPLATE_SUFFIX}`; + const packageTemplateName = `${templateName}${PACKAGE_TEMPLATE_SUFFIX}`; const userSettingsTemplateName = `${templateName}${USER_SETTINGS_TEMPLATE_SUFFIX}`; const templatesMap: TemplateMap = {}; const _meta = getESAssetMetadata({ packageName }); const indexTemplateSettings = registryElasticsearch?.['index_template.settings'] ?? {}; - // @ts-expect-error no property .mapping (yes there is) - const indexTemplateMappingSettings = indexTemplateSettings?.index?.mapping; - const indexTemplateSettingsForTemplate = cloneDeep(indexTemplateSettings); - - // index.mapping settings must go on the mapping component template otherwise - // the template may be rejected e.g if nested_fields.limit has been increased - if (indexTemplateMappingSettings) { - // @ts-expect-error no property .mapping - delete indexTemplateSettingsForTemplate.index.mapping; - } - templatesMap[mappingsTemplateName] = { + const templateSettings = merge(defaultSettings, indexTemplateSettings); + + templatesMap[packageTemplateName] = { template: { settings: { + ...templateSettings, index: { + ...templateSettings.index, mapping: { + ...templateSettings?.mapping, total_fields: { + ...templateSettings?.mapping?.total_fields, limit: '10000', }, - ...indexTemplateMappingSettings, }, }, }, @@ -281,13 +274,6 @@ function buildComponentTemplates(params: { _meta, }; - templatesMap[settingsTemplateName] = { - template: { - settings: merge(defaultSettings, indexTemplateSettingsForTemplate), - }, - _meta, - }; - // return empty/stub template templatesMap[userSettingsTemplateName] = { template: { diff --git a/x-pack/test/fleet_api_integration/apis/epm/__snapshots__/install_by_upload.snap b/x-pack/test/fleet_api_integration/apis/epm/__snapshots__/install_by_upload.snap deleted file mode 100644 index 421a5fbdf1744..0000000000000 --- a/x-pack/test/fleet_api_integration/apis/epm/__snapshots__/install_by_upload.snap +++ /dev/null @@ -1,735 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`Fleet Endpoints EPM Endpoints installs packages from direct upload should install a zip archive correctly and package info should return correctly after validation 1`] = ` -Object { - "assets": Object { - "elasticsearch": Object { - "ingest_pipeline": Array [ - Object { - "dataset": "access", - "file": "default.yml", - "path": "apache-0.1.4/data_stream/access/elasticsearch/ingest_pipeline/default.yml", - "pkgkey": "apache-0.1.4", - "service": "elasticsearch", - "type": "ingest_pipeline", - }, - Object { - "dataset": "error", - "file": "default.yml", - "path": "apache-0.1.4/data_stream/error/elasticsearch/ingest_pipeline/default.yml", - "pkgkey": "apache-0.1.4", - "service": "elasticsearch", - "type": "ingest_pipeline", - }, - ], - }, - "kibana": Object { - "dashboard": Array [ - Object { - "file": "apache-Logs-Apache-Dashboard-ecs.json", - "path": "apache-0.1.4/kibana/dashboard/apache-Logs-Apache-Dashboard-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "dashboard", - }, - Object { - "file": "apache-Metrics-Apache-HTTPD-server-status-ecs.json", - "path": "apache-0.1.4/kibana/dashboard/apache-Metrics-Apache-HTTPD-server-status-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "dashboard", - }, - ], - "search": Array [ - Object { - "file": "Apache-HTTPD-ecs.json", - "path": "apache-0.1.4/kibana/search/Apache-HTTPD-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "search", - }, - Object { - "file": "Apache-access-logs-ecs.json", - "path": "apache-0.1.4/kibana/search/Apache-access-logs-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "search", - }, - Object { - "file": "Apache-errors-log-ecs.json", - "path": "apache-0.1.4/kibana/search/Apache-errors-log-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "search", - }, - ], - "visualization": Array [ - Object { - "file": "Apache-HTTPD-CPU-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-CPU-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-HTTPD-Hostname-list-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-Hostname-list-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-HTTPD-Load1-slash-5-slash-15-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-Load1-slash-5-slash-15-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-HTTPD-Scoreboard-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-Scoreboard-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-HTTPD-Total-accesses-and-kbytes-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-Total-accesses-and-kbytes-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-HTTPD-Uptime-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-Uptime-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-HTTPD-Workers-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-HTTPD-Workers-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-access-unique-IPs-map-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-access-unique-IPs-map-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-browsers-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-browsers-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-error-logs-over-time-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-error-logs-over-time-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-operating-systems-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-operating-systems-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-response-codes-of-top-URLs-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-response-codes-of-top-URLs-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - Object { - "file": "Apache-response-codes-over-time-ecs.json", - "path": "apache-0.1.4/kibana/visualization/Apache-response-codes-over-time-ecs.json", - "pkgkey": "apache-0.1.4", - "service": "kibana", - "type": "visualization", - }, - ], - }, - }, - "categories": Array [ - "web", - ], - "conditions": Object { - "kibana": Object { - "version": "^7.9.0", - }, - }, - "data_streams": Array [ - Object { - "dataset": "apache.access", - "ingest_pipeline": "default", - "package": "apache", - "path": "access", - "release": "experimental", - "streams": Array [ - Object { - "description": "Collect Apache access logs", - "enabled": true, - "input": "logfile", - "template_path": "log.yml.hbs", - "title": "Apache access logs", - "vars": Array [ - Object { - "default": Array [ - "/var/log/apache2/access.log*", - "/var/log/apache2/other_vhosts_access.log*", - "/var/log/httpd/access_log*", - ], - "multi": true, - "name": "paths", - "required": true, - "show_user": true, - "title": "Paths", - "type": "text", - }, - ], - }, - ], - "title": "Apache access logs", - "type": "logs", - }, - Object { - "dataset": "apache.error", - "ingest_pipeline": "default", - "package": "apache", - "path": "error", - "release": "experimental", - "streams": Array [ - Object { - "description": "Collect Apache error logs", - "enabled": true, - "input": "logfile", - "template_path": "log.yml.hbs", - "title": "Apache error logs", - "vars": Array [ - Object { - "default": Array [ - "/var/log/apache2/error.log*", - "/var/log/httpd/error_log*", - ], - "multi": true, - "name": "paths", - "required": true, - "show_user": true, - "title": "Paths", - "type": "text", - }, - ], - }, - ], - "title": "Apache error logs", - "type": "logs", - }, - Object { - "dataset": "apache.status", - "package": "apache", - "path": "status", - "release": "experimental", - "streams": Array [ - Object { - "description": "Collect Apache status metrics", - "enabled": true, - "input": "apache/metrics", - "template_path": "stream.yml.hbs", - "title": "Apache status metrics", - "vars": Array [ - Object { - "default": "10s", - "multi": false, - "name": "period", - "required": true, - "show_user": true, - "title": "Period", - "type": "text", - }, - Object { - "default": "/server-status", - "multi": false, - "name": "server_status_path", - "required": true, - "show_user": false, - "title": "Server Status Path", - "type": "text", - }, - ], - }, - ], - "title": "Apache status metrics", - "type": "metrics", - }, - ], - "description": "Apache Integration", - "download": "/epr/apache/apache-0.1.4.zip", - "format_version": "1.0.0", - "icons": Array [ - Object { - "path": "/package/apache/0.1.4/img/logo_apache.svg", - "size": "32x32", - "src": "/img/logo_apache.svg", - "title": "Apache Logo", - "type": "image/svg+xml", - }, - ], - "keepPoliciesUpToDate": false, - "license": "basic", - "name": "apache", - "owner": Object { - "github": "elastic/integrations-services", - }, - "path": "/package/apache/0.1.4", - "policy_templates": Array [ - Object { - "description": "Collect logs and metrics from Apache instances", - "inputs": Array [ - Object { - "description": "Collecting Apache access and error logs", - "title": "Collect logs from Apache instances", - "type": "logfile", - }, - Object { - "description": "Collecting Apache status metrics", - "title": "Collect metrics from Apache instances", - "type": "apache/metrics", - "vars": Array [ - Object { - "default": Array [ - "http://127.0.0.1", - ], - "multi": true, - "name": "hosts", - "required": true, - "show_user": true, - "title": "Hosts", - "type": "text", - }, - ], - }, - ], - "multiple": true, - "name": "apache", - "title": "Apache logs and metrics", - }, - ], - "readme": "/package/apache/0.1.4/docs/README.md", - "release": "experimental", - "removable": true, - "savedObject": Object { - "attributes": Object { - "es_index_patterns": Object { - "access": "logs-apache.access-*", - "error": "logs-apache.error-*", - "status": "metrics-apache.status-*", - }, - "install_source": "upload", - "install_status": "installed", - "install_version": "0.1.4", - "installed_es": Array [ - Object { - "id": "logs-apache.access-0.1.4-default", - "type": "ingest_pipeline", - }, - Object { - "id": "logs-apache.error-0.1.4-default", - "type": "ingest_pipeline", - }, - Object { - "id": "logs-apache.access", - "type": "index_template", - }, - Object { - "id": "logs-apache.access@mappings", - "type": "component_template", - }, - Object { - "id": "logs-apache.access@settings", - "type": "component_template", - }, - Object { - "id": "logs-apache.access@custom", - "type": "component_template", - }, - Object { - "id": "metrics-apache.status", - "type": "index_template", - }, - Object { - "id": "metrics-apache.status@mappings", - "type": "component_template", - }, - Object { - "id": "metrics-apache.status@settings", - "type": "component_template", - }, - Object { - "id": "metrics-apache.status@custom", - "type": "component_template", - }, - Object { - "id": "logs-apache.error", - "type": "index_template", - }, - Object { - "id": "logs-apache.error@mappings", - "type": "component_template", - }, - Object { - "id": "logs-apache.error@settings", - "type": "component_template", - }, - Object { - "id": "logs-apache.error@custom", - "type": "component_template", - }, - ], - "installed_kibana": Array [ - Object { - "id": "apache-Logs-Apache-Dashboard-ecs", - "type": "dashboard", - }, - Object { - "id": "apache-Metrics-Apache-HTTPD-server-status-ecs", - "type": "dashboard", - }, - Object { - "id": "Apache-access-unique-IPs-map-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-CPU-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-Load1-slash-5-slash-15-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-response-codes-over-time-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-Workers-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-Hostname-list-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-error-logs-over-time-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-Scoreboard-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-Uptime-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-operating-systems-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-HTTPD-Total-accesses-and-kbytes-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-browsers-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-response-codes-of-top-URLs-ecs", - "type": "visualization", - }, - Object { - "id": "Apache-access-logs-ecs", - "type": "search", - }, - Object { - "id": "Apache-errors-log-ecs", - "type": "search", - }, - Object { - "id": "Apache-HTTPD-ecs", - "type": "search", - }, - ], - "installed_kibana_space_id": "default", - "name": "apache", - "package_assets": Array [ - Object { - "id": "2f1ab9c0-8cf6-5e83-afcd-0d12851c8108", - "type": "epm-packages-assets", - }, - Object { - "id": "841166f1-6db0-5f7a-a8d9-768e88ddf984", - "type": "epm-packages-assets", - }, - Object { - "id": "b12ae5e1-daf2-51a7-99d8-0888d1f13b5b", - "type": "epm-packages-assets", - }, - Object { - "id": "2f263b24-c36a-5ea8-a707-76d1f274c888", - "type": "epm-packages-assets", - }, - Object { - "id": "bd5ff9ad-ba4a-5215-b5af-cef58a3aa886", - "type": "epm-packages-assets", - }, - Object { - "id": "5fc59aa9-1d7e-50ae-8ce5-b875ab44cfc5", - "type": "epm-packages-assets", - }, - Object { - "id": "7c850453-346b-5010-a946-28b83fc69e48", - "type": "epm-packages-assets", - }, - Object { - "id": "f02f8adb-3e0c-5f2f-b4f2-a04dc645b713", - "type": "epm-packages-assets", - }, - Object { - "id": "889d88db-6214-5836-aeff-1a87f8513b27", - "type": "epm-packages-assets", - }, - Object { - "id": "06a6b940-a745-563c-abf4-83eb3335926b", - "type": "epm-packages-assets", - }, - Object { - "id": "e68fd7ac-302e-5b75-bbbb-d69b441c8848", - "type": "epm-packages-assets", - }, - Object { - "id": "2c57fe0f-3b1a-57da-a63b-28f9b9e82bce", - "type": "epm-packages-assets", - }, - Object { - "id": "13db43e8-f8f9-57f0-b131-a171c2f2070f", - "type": "epm-packages-assets", - }, - Object { - "id": "e8750081-1c0b-5c55-bcab-fa6d47f01a85", - "type": "epm-packages-assets", - }, - Object { - "id": "71af57fe-25c4-5935-9879-ca4a2fba730e", - "type": "epm-packages-assets", - }, - Object { - "id": "cc287718-9573-5c56-a9ed-6dfef6589506", - "type": "epm-packages-assets", - }, - Object { - "id": "8badd8ba-289a-5e60-a1c0-f3d39e15cda3", - "type": "epm-packages-assets", - }, - Object { - "id": "20300efc-10eb-5fac-ba90-f6aa9b467e84", - "type": "epm-packages-assets", - }, - Object { - "id": "047c89df-33c2-5d74-b0a4-8b441879761c", - "type": "epm-packages-assets", - }, - Object { - "id": "9838a13f-1b89-5c54-844e-978620d66a1d", - "type": "epm-packages-assets", - }, - Object { - "id": "e105414b-221d-5433-8b24-452625f59b7c", - "type": "epm-packages-assets", - }, - Object { - "id": "eb166c25-843b-5271-8d43-6fb005d2df5a", - "type": "epm-packages-assets", - }, - Object { - "id": "342dbf4d-d88d-53e8-b365-d3639ebbbb14", - "type": "epm-packages-assets", - }, - Object { - "id": "f98c44a3-eaea-505f-8598-3b7f1097ef59", - "type": "epm-packages-assets", - }, - Object { - "id": "12da8c6c-d0e3-589c-9244-88d857ea76b6", - "type": "epm-packages-assets", - }, - Object { - "id": "e2d151ed-709c-542d-b797-cb95f353b9b3", - "type": "epm-packages-assets", - }, - Object { - "id": "f434cffe-0b00-59de-a17f-c1e71bd4ab0f", - "type": "epm-packages-assets", - }, - Object { - "id": "5bd0c25f-04a5-5fd0-8298-ba9aa2f6fe5e", - "type": "epm-packages-assets", - }, - Object { - "id": "279da3a3-8e9b-589b-86e0-bd7364821bab", - "type": "epm-packages-assets", - }, - Object { - "id": "b8758fcb-08bf-50fa-89bd-24398955298a", - "type": "epm-packages-assets", - }, - Object { - "id": "96e4eb36-03c3-5856-af44-559fd5133f2b", - "type": "epm-packages-assets", - }, - Object { - "id": "a59a79c3-66bd-5cfc-91f5-ee84f7227855", - "type": "epm-packages-assets", - }, - Object { - "id": "395143f9-54bf-5b46-b1be-a7b2a6142ad9", - "type": "epm-packages-assets", - }, - Object { - "id": "3449b8d2-ffd5-5aec-bb32-4245f2fbcde4", - "type": "epm-packages-assets", - }, - Object { - "id": "ab44094e-6c9d-50b8-b5c4-2e518d89912e", - "type": "epm-packages-assets", - }, - Object { - "id": "b093bfc0-6e98-5a1b-a502-e838a36f6568", - "type": "epm-packages-assets", - }, - Object { - "id": "03d86823-b756-5b91-850d-7ad231d33546", - "type": "epm-packages-assets", - }, - Object { - "id": "a76af2f0-049b-5be1-8d20-e87c9d1c2709", - "type": "epm-packages-assets", - }, - Object { - "id": "bc2f0c1e-992e-5407-9435-fedb39ff74ea", - "type": "epm-packages-assets", - }, - Object { - "id": "84668ac1-d5ef-545b-88f3-1e49f8f1c8ad", - "type": "epm-packages-assets", - }, - Object { - "id": "69b41271-91a0-5a2e-a62c-60364d5a9c8f", - "type": "epm-packages-assets", - }, - Object { - "id": "8e4ec555-5fbf-55d3-bea3-3af12c9aca3f", - "type": "epm-packages-assets", - }, - Object { - "id": "aa18f3f9-f62a-5ab8-9b34-75696efa5c48", - "type": "epm-packages-assets", - }, - Object { - "id": "71c8c6b1-2116-5817-b65f-7a87ef5ef2b7", - "type": "epm-packages-assets", - }, - Object { - "id": "8f6d7a1f-1e7f-5a60-8fe7-ce19115ed460", - "type": "epm-packages-assets", - }, - Object { - "id": "c115dbbf-edad-59f2-b046-c65a0373a81c", - "type": "epm-packages-assets", - }, - Object { - "id": "b7d696c3-8106-585c-9ecc-94a75cf1e3da", - "type": "epm-packages-assets", - }, - Object { - "id": "639e6a78-59d8-5ce8-9687-64e8f9af7e71", - "type": "epm-packages-assets", - }, - Object { - "id": "ae60c853-7a90-58d2-ab6c-04d3be5f1847", - "type": "epm-packages-assets", - }, - Object { - "id": "0cd33163-2ae4-57eb-96f6-c50af6685cab", - "type": "epm-packages-assets", - }, - Object { - "id": "39e0f78f-1172-5e61-9446-65ef3c0cb46c", - "type": "epm-packages-assets", - }, - Object { - "id": "b08f10ee-6afd-5e89-b9b4-569064fbdd9f", - "type": "epm-packages-assets", - }, - Object { - "id": "efcbe1c6-b2d5-521c-b27a-2146f08a604d", - "type": "epm-packages-assets", - }, - Object { - "id": "f9422c02-d43f-5ebb-b7c5-9e32f9b77c21", - "type": "epm-packages-assets", - }, - Object { - "id": "c276e880-3ba8-58e7-a5d5-c07707dba6b7", - "type": "epm-packages-assets", - }, - Object { - "id": "561a3711-c386-541c-9a77-2d0fa256caf6", - "type": "epm-packages-assets", - }, - Object { - "id": "1378350d-2e2b-52dd-ab3a-d8b9a09df92f", - "type": "epm-packages-assets", - }, - Object { - "id": "94e40729-4aea-59c8-86ba-075137c000dc", - "type": "epm-packages-assets", - }, - ], - "removable": true, - "version": "0.1.4", - }, - "id": "apache", - "namespaces": Array [], - "references": Array [], - "type": "epm-packages", - }, - "screenshots": Array [ - Object { - "path": "/package/apache/0.1.4/img/kibana-apache.png", - "size": "1215x1199", - "src": "/img/kibana-apache.png", - "title": "Apache Integration", - "type": "image/png", - }, - Object { - "path": "/package/apache/0.1.4/img/apache_httpd_server_status.png", - "size": "1919x1079", - "src": "/img/apache_httpd_server_status.png", - "title": "Apache HTTPD Server Status", - "type": "image/png", - }, - ], - "status": "installed", - "title": "Apache", - "type": "integration", - "version": "0.1.4", -} -`; diff --git a/x-pack/test/fleet_api_integration/apis/epm/install_by_upload.ts b/x-pack/test/fleet_api_integration/apis/epm/install_by_upload.ts index 68cac70e8fed8..28b68609ce15e 100644 --- a/x-pack/test/fleet_api_integration/apis/epm/install_by_upload.ts +++ b/x-pack/test/fleet_api_integration/apis/epm/install_by_upload.ts @@ -75,7 +75,7 @@ export default function (providerContext: FtrProviderContext) { .type('application/gzip') .send(buf) .expect(200); - expect(res.body.items.length).to.be(32); + expect(res.body.items.length).to.be(29); }); it('should install a zip archive correctly and package info should return correctly after validation', async function () { @@ -86,7 +86,7 @@ export default function (providerContext: FtrProviderContext) { .type('application/zip') .send(buf) .expect(200); - expect(res.body.items.length).to.be(32); + expect(res.body.items.length).to.be(29); }); it('should throw an error if the archive is zip but content type is gzip', async function () { diff --git a/x-pack/test/fleet_api_integration/apis/epm/install_overrides.ts b/x-pack/test/fleet_api_integration/apis/epm/install_overrides.ts index eee9525a4f062..834de2432d7c8 100644 --- a/x-pack/test/fleet_api_integration/apis/epm/install_overrides.ts +++ b/x-pack/test/fleet_api_integration/apis/epm/install_overrides.ts @@ -52,8 +52,7 @@ export default function (providerContext: FtrProviderContext) { // the index template composed_of has the correct component templates in the correct order const indexTemplate = indexTemplateResponse.index_templates[0].index_template; expect(indexTemplate.composed_of).to.eql([ - `${templateName}@mappings`, - `${templateName}@settings`, + `${templateName}@package`, `${templateName}@custom`, '.fleet_globals-1', '.fleet_agent_id_verification-1', @@ -62,25 +61,17 @@ export default function (providerContext: FtrProviderContext) { ({ body } = await es.transport.request( { method: 'GET', - path: `/_component_template/${templateName}@mappings`, + path: `/_component_template/${templateName}@package`, }, { meta: true, } )); - // The mappings override provided in the package is set in the mappings component template + // The mappings override provided in the package is set in the package component template expect(body.component_templates[0].component_template.template.mappings.dynamic).to.be(false); - ({ body } = await es.transport.request( - { - method: 'GET', - path: `/_component_template/${templateName}@settings`, - }, - { meta: true } - )); - - // The settings override provided in the package is set in the settings component template + // The settings override provided in the package is set in the package component template expect( body.component_templates[0].component_template.template.settings.index.lifecycle.name ).to.be('reference'); @@ -122,11 +113,7 @@ export default function (providerContext: FtrProviderContext) { // body: indexTemplate, // I *think* this should work, but it doesn't body: { index_patterns: [`${templateName}-*`], - composed_of: [ - `${templateName}@mappings`, - `${templateName}@settings`, - `${templateName}@custom`, - ], + composed_of: [`${templateName}@package`, `${templateName}@custom`], }, }, { meta: true } diff --git a/x-pack/test/fleet_api_integration/apis/epm/install_remove_assets.ts b/x-pack/test/fleet_api_integration/apis/epm/install_remove_assets.ts index 4212ca46fc3c9..34cebed5b5d5a 100644 --- a/x-pack/test/fleet_api_integration/apis/epm/install_remove_assets.ts +++ b/x-pack/test/fleet_api_integration/apis/epm/install_remove_assets.ts @@ -91,29 +91,17 @@ export default function (providerContext: FtrProviderContext) { expect(resMetricsTemplate.statusCode).equal(404); }); it('should have uninstalled the component templates', async function () { - const resMappings = await es.transport.request( + const resPackage = await es.transport.request( { method: 'GET', - path: `/_component_template/${logsTemplateName}@mappings`, + path: `/_component_template/${logsTemplateName}@package`, }, { ignore: [404], meta: true, } ); - expect(resMappings.statusCode).equal(404); - - const resSettings = await es.transport.request( - { - method: 'GET', - path: `/_component_template/${logsTemplateName}@settings`, - }, - { - ignore: [404], - meta: true, - } - ); - expect(resSettings.statusCode).equal(404); + expect(resPackage.statusCode).equal(404); const resUserSettings = await es.transport.request( { @@ -382,22 +370,15 @@ const expectAssetsInstalled = ({ expect(res.statusCode).equal(200); }); it('should have installed the component templates', async function () { - const resMappings = await es.transport.request( + const resPackage = await es.transport.request( { method: 'GET', - path: `/_component_template/${logsTemplateName}@mappings`, + path: `/_component_template/${logsTemplateName}@package`, }, { meta: true } ); - expect(resMappings.statusCode).equal(200); - const resSettings = await es.transport.request( - { - method: 'GET', - path: `/_component_template/${logsTemplateName}@settings`, - }, - { meta: true } - ); - expect(resSettings.statusCode).equal(200); + expect(resPackage.statusCode).equal(200); + const resUserSettings = await es.transport.request( { method: 'GET', @@ -565,11 +546,7 @@ const expectAssetsInstalled = ({ installed_kibana_space_id: 'default', installed_es: [ { - id: 'logs-all_assets.test_logs@mappings', - type: 'component_template', - }, - { - id: 'logs-all_assets.test_logs@settings', + id: 'logs-all_assets.test_logs@package', type: 'component_template', }, { @@ -577,11 +554,7 @@ const expectAssetsInstalled = ({ type: 'component_template', }, { - id: 'metrics-all_assets.test_metrics@mappings', - type: 'component_template', - }, - { - id: 'metrics-all_assets.test_metrics@settings', + id: 'metrics-all_assets.test_metrics@package', type: 'component_template', }, { diff --git a/x-pack/test/fleet_api_integration/apis/epm/update_assets.ts b/x-pack/test/fleet_api_integration/apis/epm/update_assets.ts index 7a69d5635f9ac..b73ca9537990c 100644 --- a/x-pack/test/fleet_api_integration/apis/epm/update_assets.ts +++ b/x-pack/test/fleet_api_integration/apis/epm/update_assets.ts @@ -122,16 +122,16 @@ export default function (providerContext: FtrProviderContext) { }); }); it('should have populated the new component template with the correct mapping', async () => { - const resMappings = await es.transport.request( + const resPackage = await es.transport.request( { method: 'GET', - path: `/_component_template/${logsTemplateName2}@mappings`, + path: `/_component_template/${logsTemplateName2}@package`, }, { meta: true } ); - expect(resMappings.statusCode).equal(200); + expect(resPackage.statusCode).equal(200); expect( - resMappings.body.component_templates[0].component_template.template.mappings.properties + resPackage.body.component_templates[0].component_template.template.mappings.properties ).eql({ '@timestamp': { type: 'date', @@ -204,24 +204,31 @@ export default function (providerContext: FtrProviderContext) { expect(resPipeline2.statusCode).equal(404); }); it('should have updated the logs component templates', async function () { - const resMappings = await es.transport.request( + const resPackage = await es.transport.request( { method: 'GET', - path: `/_component_template/${logsTemplateName}@mappings`, + path: `/_component_template/${logsTemplateName}@package`, }, { meta: true } ); - expect(resMappings.statusCode).equal(200); - expect(resMappings.body.component_templates[0].component_template.template.settings).eql({ + expect(resPackage.statusCode).equal(200); + expect(resPackage.body.component_templates[0].component_template.template.settings).eql({ index: { + codec: 'best_compression', + lifecycle: { + name: 'reference2', + }, mapping: { total_fields: { limit: '10000', }, }, + query: { + default_field: ['logs_test_name', 'new_field_name'], + }, }, }); - expect(resMappings.body.component_templates[0].component_template.template.mappings).eql({ + expect(resPackage.body.component_templates[0].component_template.template.mappings).eql({ dynamic: true, properties: { '@timestamp': { @@ -249,23 +256,7 @@ export default function (providerContext: FtrProviderContext) { }, }, }); - const resSettings = await es.transport.request( - { - method: 'GET', - path: `/_component_template/${logsTemplateName}@settings`, - }, - { meta: true } - ); - expect(resSettings.statusCode).equal(200); - expect(resSettings.body.component_templates[0].component_template.template.settings).eql({ - index: { - lifecycle: { name: 'reference2' }, - codec: 'best_compression', - query: { - default_field: ['logs_test_name', 'new_field_name'], - }, - }, - }); + const resUserSettings = await es.transport.request( { method: 'GET', @@ -295,16 +286,16 @@ export default function (providerContext: FtrProviderContext) { }); }); it('should have updated the metrics mapping component template', async function () { - const resMappings = await es.transport.request( + const resPackage = await es.transport.request( { method: 'GET', - path: `/_component_template/${metricsTemplateName}@mappings`, + path: `/_component_template/${metricsTemplateName}@package`, }, { meta: true } ); - expect(resMappings.statusCode).equal(200); + expect(resPackage.statusCode).equal(200); expect( - resMappings.body.component_templates[0].component_template.template.mappings.properties + resPackage.body.component_templates[0].component_template.template.mappings.properties ).eql({ '@timestamp': { type: 'date', @@ -432,11 +423,7 @@ export default function (providerContext: FtrProviderContext) { type: 'index_template', }, { - id: 'logs-all_assets.test_logs@mappings', - type: 'component_template', - }, - { - id: 'logs-all_assets.test_logs@settings', + id: 'logs-all_assets.test_logs@package', type: 'component_template', }, { @@ -448,11 +435,7 @@ export default function (providerContext: FtrProviderContext) { type: 'index_template', }, { - id: 'logs-all_assets.test_logs2@mappings', - type: 'component_template', - }, - { - id: 'logs-all_assets.test_logs2@settings', + id: 'logs-all_assets.test_logs2@package', type: 'component_template', }, { @@ -464,11 +447,7 @@ export default function (providerContext: FtrProviderContext) { type: 'index_template', }, { - id: 'metrics-all_assets.test_metrics@mappings', - type: 'component_template', - }, - { - id: 'metrics-all_assets.test_metrics@settings', + id: 'metrics-all_assets.test_metrics@package', type: 'component_template', }, { From 2e4274ca88c86a6a49934602f1ebb29913397ab0 Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Tue, 29 Mar 2022 11:10:35 -0400 Subject: [PATCH 093/160] [CI] Move hourly CI tasks to on merge (#128505) --- .buildkite/pipelines/hourly.yml | 218 -------------- .buildkite/pipelines/on_merge.yml | 216 +++++++++++++- .buildkite/pipelines/pull_request/base.yml | 7 + .../scripts/lifecycle/ci_stats_ready.js | 23 ++ .buildkite/scripts/steps/build_api_docs.sh | 8 + .buildkite/scripts/steps/checks.sh | 2 +- .../scripts/steps/checks/check_types.sh | 9 + .../type_check_plugin_public_api_docs.sh | 40 --- .buildkite/scripts/steps/ci_stats_ready.sh | 7 + .../steps/on_merge_build_and_metrics.sh | 2 + .buildkite/yarn.lock | 282 ++++++++---------- 11 files changed, 388 insertions(+), 426 deletions(-) delete mode 100644 .buildkite/pipelines/hourly.yml create mode 100644 .buildkite/scripts/lifecycle/ci_stats_ready.js create mode 100755 .buildkite/scripts/steps/build_api_docs.sh create mode 100755 .buildkite/scripts/steps/checks/check_types.sh delete mode 100755 .buildkite/scripts/steps/checks/type_check_plugin_public_api_docs.sh create mode 100755 .buildkite/scripts/steps/ci_stats_ready.sh diff --git a/.buildkite/pipelines/hourly.yml b/.buildkite/pipelines/hourly.yml deleted file mode 100644 index 1335866675564..0000000000000 --- a/.buildkite/pipelines/hourly.yml +++ /dev/null @@ -1,218 +0,0 @@ -steps: - - command: .buildkite/scripts/lifecycle/pre_build.sh - label: Pre-Build - timeout_in_minutes: 10 - agents: - queue: kibana-default - - - wait - - - command: .buildkite/scripts/steps/build_kibana.sh - label: Build Kibana Distribution and Plugins - agents: - queue: c2-16 - key: build - if: "build.env('KIBANA_BUILD_ID') == null || build.env('KIBANA_BUILD_ID') == ''" - timeout_in_minutes: 60 - - - command: .buildkite/scripts/steps/functional/xpack_cigroup.sh - label: 'Default CI Group' - parallelism: 27 - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 250 - key: default-cigroup - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: CI_GROUP=Docker .buildkite/scripts/steps/functional/xpack_cigroup.sh - label: 'Docker CI Group' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - key: default-cigroup-docker - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/oss_cigroup.sh - label: 'OSS CI Group' - parallelism: 11 - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - key: oss-cigroup - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/oss_accessibility.sh - label: 'OSS Accessibility Tests' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/xpack_accessibility.sh - label: 'Default Accessibility Tests' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/oss_firefox.sh - label: 'OSS Firefox Tests' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/xpack_firefox.sh - label: 'Default Firefox Tests' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/oss_misc.sh - label: 'OSS Misc Functional Tests' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/functional/xpack_saved_object_field_metrics.sh - label: 'Saved Object Field Metrics' - agents: - queue: n2-4-spot - depends_on: build - timeout_in_minutes: 120 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - exit_status: '*' - limit: 1 - - - command: .buildkite/scripts/steps/test/jest.sh - label: 'Jest Tests' - parallelism: 8 - agents: - queue: n2-4-spot - timeout_in_minutes: 90 - key: jest - retry: - automatic: - - exit_status: '-1' - limit: 3 - - - command: .buildkite/scripts/steps/test/jest_integration.sh - label: 'Jest Integration Tests' - parallelism: 3 - agents: - queue: n2-4-spot - timeout_in_minutes: 120 - key: jest-integration - retry: - automatic: - - exit_status: '-1' - limit: 3 - - - command: .buildkite/scripts/steps/test/api_integration.sh - label: 'API Integration Tests' - agents: - queue: n2-2-spot - timeout_in_minutes: 120 - key: api-integration - retry: - automatic: - - exit_status: '-1' - limit: 3 - - - command: .buildkite/scripts/steps/lint.sh - label: 'Linting' - agents: - queue: n2-2-spot - key: linting - timeout_in_minutes: 90 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - - command: .buildkite/scripts/steps/lint_with_types.sh - label: 'Linting (with types)' - agents: - queue: c2-16 - key: linting_with_types - timeout_in_minutes: 90 - - - command: .buildkite/scripts/steps/checks.sh - label: 'Checks' - agents: - queue: c2-8 - key: checks - timeout_in_minutes: 120 - - - command: .buildkite/scripts/steps/storybooks/build_and_upload.sh - label: 'Build Storybooks' - agents: - queue: n2-4-spot - key: storybooks - timeout_in_minutes: 60 - retry: - automatic: - - exit_status: '-1' - limit: 3 - - - wait: ~ - continue_on_failure: true - - - command: .buildkite/scripts/lifecycle/post_build.sh - label: Post-Build - timeout_in_minutes: 10 - agents: - queue: kibana-default diff --git a/.buildkite/pipelines/on_merge.yml b/.buildkite/pipelines/on_merge.yml index c6acb48b3e212..a11f566b06093 100644 --- a/.buildkite/pipelines/on_merge.yml +++ b/.buildkite/pipelines/on_merge.yml @@ -7,13 +7,18 @@ steps: timeout_in_minutes: 10 agents: queue: kibana-default + retry: + automatic: + - exit_status: '*' + limit: 1 - wait - command: .buildkite/scripts/steps/on_merge_build_and_metrics.sh - label: Default Build and Metrics + label: Build Kibana Distribution and Plugins agents: - queue: c2-8 + queue: c2-16 + key: build timeout_in_minutes: 60 retry: automatic: @@ -22,6 +27,7 @@ steps: - command: .buildkite/scripts/steps/on_merge_ts_refs_api_docs.sh label: Build TS Refs and Check Public API Docs + key: public-api-docs agents: queue: c2-4 timeout_in_minutes: 80 @@ -30,6 +36,212 @@ steps: - exit_status: '*' limit: 1 + - command: .buildkite/scripts/steps/ci_stats_ready.sh + label: Mark CI Stats as ready + agents: + queue: kibana-default + timeout_in_minutes: 10 + depends_on: + - build + - public-api-docs + retry: + automatic: + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/xpack_cigroup.sh + label: 'Default CI Group' + parallelism: 27 + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 250 + key: default-cigroup + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: CI_GROUP=Docker .buildkite/scripts/steps/functional/xpack_cigroup.sh + label: 'Docker CI Group' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + key: default-cigroup-docker + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/oss_cigroup.sh + label: 'OSS CI Group' + parallelism: 11 + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + key: oss-cigroup + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/oss_accessibility.sh + label: 'OSS Accessibility Tests' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/xpack_accessibility.sh + label: 'Default Accessibility Tests' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/oss_firefox.sh + label: 'OSS Firefox Tests' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/xpack_firefox.sh + label: 'Default Firefox Tests' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/oss_misc.sh + label: 'OSS Misc Functional Tests' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/functional/xpack_saved_object_field_metrics.sh + label: 'Saved Object Field Metrics' + agents: + queue: n2-4-spot + depends_on: build + timeout_in_minutes: 120 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - exit_status: '*' + limit: 1 + + - command: .buildkite/scripts/steps/test/jest.sh + label: 'Jest Tests' + parallelism: 8 + agents: + queue: n2-4-spot + timeout_in_minutes: 90 + key: jest + retry: + automatic: + - exit_status: '-1' + limit: 3 + + - command: .buildkite/scripts/steps/test/jest_integration.sh + label: 'Jest Integration Tests' + parallelism: 3 + agents: + queue: n2-4-spot + timeout_in_minutes: 120 + key: jest-integration + retry: + automatic: + - exit_status: '-1' + limit: 3 + + - command: .buildkite/scripts/steps/test/api_integration.sh + label: 'API Integration Tests' + agents: + queue: n2-2-spot + timeout_in_minutes: 120 + key: api-integration + retry: + automatic: + - exit_status: '-1' + limit: 3 + + - command: .buildkite/scripts/steps/lint.sh + label: 'Linting' + agents: + queue: n2-2-spot + key: linting + timeout_in_minutes: 90 + retry: + automatic: + - exit_status: '-1' + limit: 3 + + - command: .buildkite/scripts/steps/lint_with_types.sh + label: 'Linting (with types)' + agents: + queue: c2-16 + key: linting_with_types + timeout_in_minutes: 90 + + - command: .buildkite/scripts/steps/checks.sh + label: 'Checks' + agents: + queue: c2-8 + key: checks + timeout_in_minutes: 120 + + - command: .buildkite/scripts/steps/storybooks/build_and_upload.sh + label: 'Build Storybooks' + agents: + queue: n2-4-spot + key: storybooks + timeout_in_minutes: 60 + retry: + automatic: + - exit_status: '-1' + limit: 3 + - wait: ~ continue_on_failure: true diff --git a/.buildkite/pipelines/pull_request/base.yml b/.buildkite/pipelines/pull_request/base.yml index 4aa9a7a49fe23..eaad8ca875545 100644 --- a/.buildkite/pipelines/pull_request/base.yml +++ b/.buildkite/pipelines/pull_request/base.yml @@ -170,6 +170,13 @@ steps: key: storybooks timeout_in_minutes: 60 + - command: .buildkite/scripts/steps/build_api_docs.sh + label: 'Build API Docs' + agents: + queue: n2-4 + key: build_api_docs + timeout_in_minutes: 60 + - command: .buildkite/scripts/steps/webpack_bundle_analyzer/build_and_upload.sh label: 'Build Webpack Bundle Analyzer reports' agents: diff --git a/.buildkite/scripts/lifecycle/ci_stats_ready.js b/.buildkite/scripts/lifecycle/ci_stats_ready.js new file mode 100644 index 0000000000000..98b03a56d0023 --- /dev/null +++ b/.buildkite/scripts/lifecycle/ci_stats_ready.js @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +// eslint-disable-next-line import/no-unresolved +const { CiStats } = require('kibana-buildkite-library'); + +(async () => { + try { + await CiStats.onMetricsViable(); + } catch (ex) { + console.error('CI Stats Error', ex.message); + if (ex.response) { + console.error('HTTP Error Response Status', ex.response.status); + console.error('HTTP Error Response Body', ex.response.data); + } + process.exit(1); + } +})(); diff --git a/.buildkite/scripts/steps/build_api_docs.sh b/.buildkite/scripts/steps/build_api_docs.sh new file mode 100755 index 0000000000000..2f63d6efa0941 --- /dev/null +++ b/.buildkite/scripts/steps/build_api_docs.sh @@ -0,0 +1,8 @@ +#!/usr/bin/env bash + +set -euo pipefail + +.buildkite/scripts/bootstrap.sh + +echo "--- Build API Docs" +node --max-old-space-size=12000 scripts/build_api_docs diff --git a/.buildkite/scripts/steps/checks.sh b/.buildkite/scripts/steps/checks.sh index bde9e82a4d1e6..cae019150b626 100755 --- a/.buildkite/scripts/steps/checks.sh +++ b/.buildkite/scripts/steps/checks.sh @@ -13,7 +13,7 @@ export DISABLE_BOOTSTRAP_VALIDATION=false .buildkite/scripts/steps/checks/doc_api_changes.sh .buildkite/scripts/steps/checks/kbn_pm_dist.sh .buildkite/scripts/steps/checks/plugin_list_docs.sh -.buildkite/scripts/steps/checks/type_check_plugin_public_api_docs.sh +.buildkite/scripts/steps/checks/check_types.sh .buildkite/scripts/steps/checks/bundle_limits.sh .buildkite/scripts/steps/checks/i18n.sh .buildkite/scripts/steps/checks/file_casing.sh diff --git a/.buildkite/scripts/steps/checks/check_types.sh b/.buildkite/scripts/steps/checks/check_types.sh new file mode 100755 index 0000000000000..3b649a73e8060 --- /dev/null +++ b/.buildkite/scripts/steps/checks/check_types.sh @@ -0,0 +1,9 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source .buildkite/scripts/common/util.sh + +echo --- Check Types +checks-reporter-with-killswitch "Check Types" \ + node scripts/type_check diff --git a/.buildkite/scripts/steps/checks/type_check_plugin_public_api_docs.sh b/.buildkite/scripts/steps/checks/type_check_plugin_public_api_docs.sh deleted file mode 100755 index e2a4bd9d9d427..0000000000000 --- a/.buildkite/scripts/steps/checks/type_check_plugin_public_api_docs.sh +++ /dev/null @@ -1,40 +0,0 @@ -#!/usr/bin/env bash - -set -euo pipefail - -source .buildkite/scripts/common/util.sh - -echo --- Build TS Refs -checks-reporter-with-killswitch "Build TS Refs" \ - node scripts/build_ts_refs \ - --clean \ - --no-cache \ - --force - -set +e; -echo "--- running check types and build api docs in parallel"; - -checks-reporter-with-killswitch "Check Types" \ - node scripts/type_check &> target/check_types.log & -check_types_pid=$! - -node --max-old-space-size=12000 scripts/build_api_docs &> target/build_api_docs.log & -api_docs_pid=$! - -wait $check_types_pid -check_types_exit=$? - -wait $api_docs_pid -api_docs_exit=$? - -echo --- Check Types -cat target/check_types.log -if [[ "$check_types_exit" != "0" ]]; then echo "^^^ +++"; fi - -echo --- Building api docs -cat target/build_api_docs.log -if [[ "$api_docs_exit" != "0" ]]; then echo "^^^ +++"; fi - -if [[ "${api_docs_exit}${check_types_exit}" != "00" ]]; then - exit 1 -fi diff --git a/.buildkite/scripts/steps/ci_stats_ready.sh b/.buildkite/scripts/steps/ci_stats_ready.sh new file mode 100755 index 0000000000000..92ea6a70fd779 --- /dev/null +++ b/.buildkite/scripts/steps/ci_stats_ready.sh @@ -0,0 +1,7 @@ +#!/usr/bin/env bash + +set -euo pipefail + +source .buildkite/scripts/common/util.sh + +node .buildkite/scripts/lifecycle/ci_stats_ready.js diff --git a/.buildkite/scripts/steps/on_merge_build_and_metrics.sh b/.buildkite/scripts/steps/on_merge_build_and_metrics.sh index 1f1e492f87bec..fb05bb99b0c54 100755 --- a/.buildkite/scripts/steps/on_merge_build_and_metrics.sh +++ b/.buildkite/scripts/steps/on_merge_build_and_metrics.sh @@ -4,5 +4,7 @@ set -euo pipefail .buildkite/scripts/bootstrap.sh .buildkite/scripts/build_kibana.sh +.buildkite/scripts/build_kibana_plugins.sh +.buildkite/scripts/post_build_kibana_plugins.sh .buildkite/scripts/post_build_kibana.sh .buildkite/scripts/saved_object_field_metrics.sh diff --git a/.buildkite/yarn.lock b/.buildkite/yarn.lock index 2c3ce924b22ea..c2d6928d30c5a 100644 --- a/.buildkite/yarn.lock +++ b/.buildkite/yarn.lock @@ -3,226 +3,178 @@ "@octokit/auth-token@^2.4.4": - version "2.4.4" - resolved "https://registry.yarnpkg.com/@octokit/auth-token/-/auth-token-2.4.4.tgz#ee31c69b01d0378c12fd3ffe406030f3d94d3b56" - integrity sha512-LNfGu3Ro9uFAYh10MUZVaT7X2CnNm2C8IDQmabx+3DygYIQjs9FwzFAHN/0t6mu5HEPhxcb1XOuxdpY82vCg2Q== + "integrity" "sha512-r5FVUJCOLl19AxiuZD2VRZ/ORjp/4IN98Of6YJoJOkY75CIBuYfmiNHGrDwXr+aLGG55igl9QrxX3hbiXlLb+g==" + "resolved" "https://registry.npmjs.org/@octokit/auth-token/-/auth-token-2.5.0.tgz" + "version" "2.5.0" dependencies: - "@octokit/types" "^6.0.0" + "@octokit/types" "^6.0.3" -"@octokit/core@^3.5.1": - version "3.5.1" - resolved "https://registry.yarnpkg.com/@octokit/core/-/core-3.5.1.tgz#8601ceeb1ec0e1b1b8217b960a413ed8e947809b" - integrity sha512-omncwpLVxMP+GLpLPgeGJBF6IWJFjXDS5flY5VbppePYX9XehevbDykRH9PdCdvqt9TS5AOTiDide7h0qrkHjw== +"@octokit/core@^3.5.1", "@octokit/core@>=2", "@octokit/core@>=3": + "integrity" "sha512-omncwpLVxMP+GLpLPgeGJBF6IWJFjXDS5flY5VbppePYX9XehevbDykRH9PdCdvqt9TS5AOTiDide7h0qrkHjw==" + "resolved" "https://registry.npmjs.org/@octokit/core/-/core-3.5.1.tgz" + "version" "3.5.1" dependencies: "@octokit/auth-token" "^2.4.4" "@octokit/graphql" "^4.5.8" "@octokit/request" "^5.6.0" "@octokit/request-error" "^2.0.5" "@octokit/types" "^6.0.3" - before-after-hook "^2.2.0" - universal-user-agent "^6.0.0" + "before-after-hook" "^2.2.0" + "universal-user-agent" "^6.0.0" "@octokit/endpoint@^6.0.1": - version "6.0.9" - resolved "https://registry.yarnpkg.com/@octokit/endpoint/-/endpoint-6.0.9.tgz#c6a772e024202b1bd19ab69f90e0536a2598b13e" - integrity sha512-3VPLbcCuqji4IFTclNUtGdp9v7g+nspWdiCUbK3+iPMjJCZ6LEhn1ts626bWLOn0GiDb6j+uqGvPpqLnY7pBgw== + "integrity" "sha512-lF3puPwkQWGfkMClXb4k/eUT/nZKQfxinRWJrdZaJO85Dqwo/G0yOC434Jr2ojwafWJMYqFGFa5ms4jJUgujdA==" + "resolved" "https://registry.npmjs.org/@octokit/endpoint/-/endpoint-6.0.12.tgz" + "version" "6.0.12" dependencies: - "@octokit/types" "^5.0.0" - is-plain-object "^5.0.0" - universal-user-agent "^6.0.0" + "@octokit/types" "^6.0.3" + "is-plain-object" "^5.0.0" + "universal-user-agent" "^6.0.0" "@octokit/graphql@^4.5.8": - version "4.5.8" - resolved "https://registry.yarnpkg.com/@octokit/graphql/-/graphql-4.5.8.tgz#d42373633c3015d0eafce64a8ce196be167fdd9b" - integrity sha512-WnCtNXWOrupfPJgXe+vSmprZJUr0VIu14G58PMlkWGj3cH+KLZEfKMmbUQ6C3Wwx6fdhzVW1CD5RTnBdUHxhhA== + "integrity" "sha512-0gv+qLSBLKF0z8TKaSKTsS39scVKF9dbMxJpj3U0vC7wjNWFuIpL/z76Qe2fiuCbDRcJSavkXsVtMS6/dtQQsg==" + "resolved" "https://registry.npmjs.org/@octokit/graphql/-/graphql-4.8.0.tgz" + "version" "4.8.0" dependencies: - "@octokit/request" "^5.3.0" - "@octokit/types" "^6.0.0" - universal-user-agent "^6.0.0" + "@octokit/request" "^5.6.0" + "@octokit/types" "^6.0.3" + "universal-user-agent" "^6.0.0" "@octokit/openapi-types@^11.2.0": - version "11.2.0" - resolved "https://registry.yarnpkg.com/@octokit/openapi-types/-/openapi-types-11.2.0.tgz#b38d7fc3736d52a1e96b230c1ccd4a58a2f400a6" - integrity sha512-PBsVO+15KSlGmiI8QAzaqvsNlZlrDlyAJYcrXBCvVUxCp7VnXjkwPoFHgjEJXx3WF9BAwkA6nfCUA7i9sODzKA== - -"@octokit/openapi-types@^2.2.0": - version "2.2.0" - resolved "https://registry.yarnpkg.com/@octokit/openapi-types/-/openapi-types-2.2.0.tgz#123e0438a0bc718ccdac3b5a2e69b3dd00daa85b" - integrity sha512-274lNUDonw10kT8wHg8fCcUc1ZjZHbWv0/TbAwb0ojhBQqZYc1cQ/4yqTVTtPMDeZ//g7xVEYe/s3vURkRghPg== + "integrity" "sha512-PBsVO+15KSlGmiI8QAzaqvsNlZlrDlyAJYcrXBCvVUxCp7VnXjkwPoFHgjEJXx3WF9BAwkA6nfCUA7i9sODzKA==" + "resolved" "https://registry.npmjs.org/@octokit/openapi-types/-/openapi-types-11.2.0.tgz" + "version" "11.2.0" "@octokit/plugin-paginate-rest@^2.16.8": - version "2.17.0" - resolved "https://registry.yarnpkg.com/@octokit/plugin-paginate-rest/-/plugin-paginate-rest-2.17.0.tgz#32e9c7cab2a374421d3d0de239102287d791bce7" - integrity sha512-tzMbrbnam2Mt4AhuyCHvpRkS0oZ5MvwwcQPYGtMv4tUa5kkzG58SVB0fcsLulOZQeRnOgdkZWkRUiyBlh0Bkyw== + "integrity" "sha512-tzMbrbnam2Mt4AhuyCHvpRkS0oZ5MvwwcQPYGtMv4tUa5kkzG58SVB0fcsLulOZQeRnOgdkZWkRUiyBlh0Bkyw==" + "resolved" "https://registry.npmjs.org/@octokit/plugin-paginate-rest/-/plugin-paginate-rest-2.17.0.tgz" + "version" "2.17.0" dependencies: "@octokit/types" "^6.34.0" "@octokit/plugin-request-log@^1.0.4": - version "1.0.4" - resolved "https://registry.yarnpkg.com/@octokit/plugin-request-log/-/plugin-request-log-1.0.4.tgz#5e50ed7083a613816b1e4a28aeec5fb7f1462e85" - integrity sha512-mLUsMkgP7K/cnFEw07kWqXGF5LKrOkD+lhCrKvPHXWDywAwuDUeDwWBpc69XK3pNX0uKiVt8g5z96PJ6z9xCFA== + "integrity" "sha512-mLUsMkgP7K/cnFEw07kWqXGF5LKrOkD+lhCrKvPHXWDywAwuDUeDwWBpc69XK3pNX0uKiVt8g5z96PJ6z9xCFA==" + "resolved" "https://registry.npmjs.org/@octokit/plugin-request-log/-/plugin-request-log-1.0.4.tgz" + "version" "1.0.4" "@octokit/plugin-rest-endpoint-methods@^5.12.0": - version "5.13.0" - resolved "https://registry.yarnpkg.com/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-5.13.0.tgz#8c46109021a3412233f6f50d28786f8e552427ba" - integrity sha512-uJjMTkN1KaOIgNtUPMtIXDOjx6dGYysdIFhgA52x4xSadQCz3b/zJexvITDVpANnfKPW/+E0xkOvLntqMYpviA== + "integrity" "sha512-uJjMTkN1KaOIgNtUPMtIXDOjx6dGYysdIFhgA52x4xSadQCz3b/zJexvITDVpANnfKPW/+E0xkOvLntqMYpviA==" + "resolved" "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-5.13.0.tgz" + "version" "5.13.0" dependencies: "@octokit/types" "^6.34.0" - deprecation "^2.3.1" - -"@octokit/request-error@^2.0.0": - version "2.0.3" - resolved "https://registry.yarnpkg.com/@octokit/request-error/-/request-error-2.0.3.tgz#b51b200052bf483f6fa56c9e7e3aa51ead36ecd8" - integrity sha512-GgD5z8Btm301i2zfvJLk/mkhvGCdjQ7wT8xF9ov5noQY8WbKZDH9cOBqXzoeKd1mLr1xH2FwbtGso135zGBgTA== - dependencies: - "@octokit/types" "^5.0.1" - deprecation "^2.0.0" - once "^1.4.0" + "deprecation" "^2.3.1" "@octokit/request-error@^2.0.5", "@octokit/request-error@^2.1.0": - version "2.1.0" - resolved "https://registry.yarnpkg.com/@octokit/request-error/-/request-error-2.1.0.tgz#9e150357831bfc788d13a4fd4b1913d60c74d677" - integrity sha512-1VIvgXxs9WHSjicsRwq8PlR2LR2x6DwsJAaFgzdi0JfJoGSO8mYI/cHJQ+9FbN21aa+DrgNLnwObmyeSC8Rmpg== + "integrity" "sha512-1VIvgXxs9WHSjicsRwq8PlR2LR2x6DwsJAaFgzdi0JfJoGSO8mYI/cHJQ+9FbN21aa+DrgNLnwObmyeSC8Rmpg==" + "resolved" "https://registry.npmjs.org/@octokit/request-error/-/request-error-2.1.0.tgz" + "version" "2.1.0" dependencies: "@octokit/types" "^6.0.3" - deprecation "^2.0.0" - once "^1.4.0" - -"@octokit/request@^5.3.0": - version "5.4.12" - resolved "https://registry.yarnpkg.com/@octokit/request/-/request-5.4.12.tgz#b04826fa934670c56b135a81447be2c1723a2ffc" - integrity sha512-MvWYdxengUWTGFpfpefBBpVmmEYfkwMoxonIB3sUGp5rhdgwjXL1ejo6JbgzG/QD9B/NYt/9cJX1pxXeSIUCkg== - dependencies: - "@octokit/endpoint" "^6.0.1" - "@octokit/request-error" "^2.0.0" - "@octokit/types" "^6.0.3" - deprecation "^2.0.0" - is-plain-object "^5.0.0" - node-fetch "^2.6.1" - once "^1.4.0" - universal-user-agent "^6.0.0" + "deprecation" "^2.0.0" + "once" "^1.4.0" "@octokit/request@^5.6.0": - version "5.6.2" - resolved "https://registry.yarnpkg.com/@octokit/request/-/request-5.6.2.tgz#1aa74d5da7b9e04ac60ef232edd9a7438dcf32d8" - integrity sha512-je66CvSEVf0jCpRISxkUcCa0UkxmFs6eGDRSbfJtAVwbLH5ceqF+YEyC8lj8ystKyZTy8adWr0qmkY52EfOeLA== + "integrity" "sha512-je66CvSEVf0jCpRISxkUcCa0UkxmFs6eGDRSbfJtAVwbLH5ceqF+YEyC8lj8ystKyZTy8adWr0qmkY52EfOeLA==" + "resolved" "https://registry.npmjs.org/@octokit/request/-/request-5.6.2.tgz" + "version" "5.6.2" dependencies: "@octokit/endpoint" "^6.0.1" "@octokit/request-error" "^2.1.0" "@octokit/types" "^6.16.1" - is-plain-object "^5.0.0" - node-fetch "^2.6.1" - universal-user-agent "^6.0.0" + "is-plain-object" "^5.0.0" + "node-fetch" "^2.6.1" + "universal-user-agent" "^6.0.0" "@octokit/rest@^18.10.0": - version "18.12.0" - resolved "https://registry.yarnpkg.com/@octokit/rest/-/rest-18.12.0.tgz#f06bc4952fc87130308d810ca9d00e79f6988881" - integrity sha512-gDPiOHlyGavxr72y0guQEhLsemgVjwRePayJ+FcKc2SJqKUbxbkvf5kAZEWA/MKvsfYlQAMVzNJE3ezQcxMJ2Q== + "integrity" "sha512-gDPiOHlyGavxr72y0guQEhLsemgVjwRePayJ+FcKc2SJqKUbxbkvf5kAZEWA/MKvsfYlQAMVzNJE3ezQcxMJ2Q==" + "resolved" "https://registry.npmjs.org/@octokit/rest/-/rest-18.12.0.tgz" + "version" "18.12.0" dependencies: "@octokit/core" "^3.5.1" "@octokit/plugin-paginate-rest" "^2.16.8" "@octokit/plugin-request-log" "^1.0.4" "@octokit/plugin-rest-endpoint-methods" "^5.12.0" -"@octokit/types@^5.0.0", "@octokit/types@^5.0.1": - version "5.5.0" - resolved "https://registry.yarnpkg.com/@octokit/types/-/types-5.5.0.tgz#e5f06e8db21246ca102aa28444cdb13ae17a139b" - integrity sha512-UZ1pErDue6bZNjYOotCNveTXArOMZQFG6hKJfOnGnulVCMcVVi7YIIuuR4WfBhjo7zgpmzn/BkPDnUXtNx+PcQ== +"@octokit/types@^6.0.3", "@octokit/types@^6.16.1", "@octokit/types@^6.34.0": + "integrity" "sha512-s1zLBjWhdEI2zwaoSgyOFoKSl109CUcVBCc7biPJ3aAf6LGLU6szDvi31JPU7bxfla2lqfhjbbg/5DdFNxOwHw==" + "resolved" "https://registry.npmjs.org/@octokit/types/-/types-6.34.0.tgz" + "version" "6.34.0" dependencies: - "@types/node" ">= 8" + "@octokit/openapi-types" "^11.2.0" -"@octokit/types@^6.0.0", "@octokit/types@^6.0.3": - version "6.2.1" - resolved "https://registry.yarnpkg.com/@octokit/types/-/types-6.2.1.tgz#7f881fe44475ab1825776a4a59ca1ae082ed1043" - integrity sha512-jHs9OECOiZxuEzxMZcXmqrEO8GYraHF+UzNVH2ACYh8e/Y7YoT+hUf9ldvVd6zIvWv4p3NdxbQ0xx3ku5BnSiA== +"axios@^0.21.4": + "integrity" "sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg==" + "resolved" "https://registry.npmjs.org/axios/-/axios-0.21.4.tgz" + "version" "0.21.4" dependencies: - "@octokit/openapi-types" "^2.2.0" - "@types/node" ">= 8" + "follow-redirects" "^1.14.0" -"@octokit/types@^6.16.1", "@octokit/types@^6.34.0": - version "6.34.0" - resolved "https://registry.yarnpkg.com/@octokit/types/-/types-6.34.0.tgz#c6021333334d1ecfb5d370a8798162ddf1ae8218" - integrity sha512-s1zLBjWhdEI2zwaoSgyOFoKSl109CUcVBCc7biPJ3aAf6LGLU6szDvi31JPU7bxfla2lqfhjbbg/5DdFNxOwHw== - dependencies: - "@octokit/openapi-types" "^11.2.0" +"before-after-hook@^2.2.0": + "integrity" "sha512-3pZEU3NT5BFUo/AD5ERPWOgQOCZITni6iavr5AUw5AUwQjMlI0kzu5btnyD39AF0gUEsDPwJT+oY1ORBJijPjQ==" + "resolved" "https://registry.npmjs.org/before-after-hook/-/before-after-hook-2.2.2.tgz" + "version" "2.2.2" -"@types/node@>= 8": - version "16.10.2" - resolved "https://registry.yarnpkg.com/@types/node/-/node-16.10.2.tgz#5764ca9aa94470adb4e1185fe2e9f19458992b2e" - integrity sha512-zCclL4/rx+W5SQTzFs9wyvvyCwoK9QtBpratqz2IYJ3O8Umrn0m3nsTv0wQBk9sRGpvUe9CwPDrQFB10f1FIjQ== +"deprecation@^2.0.0", "deprecation@^2.3.1": + "integrity" "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ==" + "resolved" "https://registry.npmjs.org/deprecation/-/deprecation-2.3.1.tgz" + "version" "2.3.1" -axios@^0.21.4: - version "0.21.4" - resolved "https://registry.yarnpkg.com/axios/-/axios-0.21.4.tgz#c67b90dc0568e5c1cf2b0b858c43ba28e2eda575" - integrity sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg== - dependencies: - follow-redirects "^1.14.0" - -before-after-hook@^2.2.0: - version "2.2.2" - resolved "https://registry.yarnpkg.com/before-after-hook/-/before-after-hook-2.2.2.tgz#a6e8ca41028d90ee2c24222f201c90956091613e" - integrity sha512-3pZEU3NT5BFUo/AD5ERPWOgQOCZITni6iavr5AUw5AUwQjMlI0kzu5btnyD39AF0gUEsDPwJT+oY1ORBJijPjQ== - -deprecation@^2.0.0, deprecation@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/deprecation/-/deprecation-2.3.1.tgz#6368cbdb40abf3373b525ac87e4a260c3a700919" - integrity sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ== - -follow-redirects@^1.14.0: - version "1.14.3" - resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.3.tgz#6ada78118d8d24caee595595accdc0ac6abd022e" - integrity sha512-3MkHxknWMUtb23apkgz/83fDoe+y+qr0TdgacGIA7bew+QLBo3vdgEN2xEsuXNivpFy4CyDhBBZnNZOtalmenw== - -is-plain-object@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-5.0.0.tgz#4427f50ab3429e9025ea7d52e9043a9ef4159344" - integrity sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q== - -kibana-buildkite-library@elastic/kibana-buildkite-library: - version "1.0.0" - resolved "https://codeload.github.com/elastic/kibana-buildkite-library/tar.gz/f67122968ea54ba14036b55c9f99906d96a3733d" +"follow-redirects@^1.14.0": + "integrity" "sha512-wtphSXy7d4/OR+MvIFbCVBDzZ5520qV8XfPklSN5QtxuMUJZ+b0Wnst1e1lCDocfzuCkHqj8k0FpZqO+UIaKNA==" + "resolved" "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.14.5.tgz" + "version" "1.14.5" + +"is-plain-object@^5.0.0": + "integrity" "sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q==" + "resolved" "https://registry.npmjs.org/is-plain-object/-/is-plain-object-5.0.0.tgz" + "version" "5.0.0" + +"kibana-buildkite-library@github:elastic/kibana-buildkite-library": + "resolved" "git+ssh://git@github.com/elastic/kibana-buildkite-library.git#ccf5b824c4294d1fdf3569d32218d3bdb0958121" + "version" "1.0.0" dependencies: "@octokit/rest" "^18.10.0" - axios "^0.21.4" + "axios" "^0.21.4" -node-fetch@^2.6.1: - version "2.6.5" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.5.tgz#42735537d7f080a7e5f78b6c549b7146be1742fd" - integrity sha512-mmlIVHJEu5rnIxgEgez6b9GgWXbkZj5YZ7fx+2r94a2E+Uirsp6HsPTPlomfdHtpt/B0cdKviwkoaM6pyvUOpQ== +"node-fetch@^2.6.1": + "integrity" "sha512-Z8/6vRlTUChSdIgMa51jxQ4lrw/Jy5SOW10ObaA47/RElsAN2c5Pn8bTgFGWn/ibwzXTE8qwr1Yzx28vsecXEA==" + "resolved" "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.6.tgz" + "version" "2.6.6" dependencies: - whatwg-url "^5.0.0" + "whatwg-url" "^5.0.0" -once@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" - integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= +"once@^1.4.0": + "integrity" "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=" + "resolved" "https://registry.npmjs.org/once/-/once-1.4.0.tgz" + "version" "1.4.0" dependencies: - wrappy "1" - -tr46@~0.0.3: - version "0.0.3" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" - integrity sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o= - -universal-user-agent@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/universal-user-agent/-/universal-user-agent-6.0.0.tgz#3381f8503b251c0d9cd21bc1de939ec9df5480ee" - integrity sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w== - -webidl-conversions@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" - integrity sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE= - -whatwg-url@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" - integrity sha1-lmRU6HZUYuN2RNNib2dCzotwll0= + "wrappy" "1" + +"tr46@~0.0.3": + "integrity" "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=" + "resolved" "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz" + "version" "0.0.3" + +"universal-user-agent@^6.0.0": + "integrity" "sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w==" + "resolved" "https://registry.npmjs.org/universal-user-agent/-/universal-user-agent-6.0.0.tgz" + "version" "6.0.0" + +"webidl-conversions@^3.0.0": + "integrity" "sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE=" + "resolved" "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz" + "version" "3.0.1" + +"whatwg-url@^5.0.0": + "integrity" "sha1-lmRU6HZUYuN2RNNib2dCzotwll0=" + "resolved" "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz" + "version" "5.0.0" dependencies: - tr46 "~0.0.3" - webidl-conversions "^3.0.0" + "tr46" "~0.0.3" + "webidl-conversions" "^3.0.0" -wrappy@1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" - integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= +"wrappy@1": + "integrity" "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + "resolved" "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz" + "version" "1.0.2" From 437adb58805e3b524851de4b9727d7e3951c3f4c Mon Sep 17 00:00:00 2001 From: Mat Schaffer Date: Wed, 30 Mar 2022 00:13:35 +0900 Subject: [PATCH 094/160] [Stack Monitoring] Rename "APM & Fleet Server" to "Integrations Server" (#128574) --- .../dev_docs/how_to/running_components_from_source.md | 2 +- .../monitoring/public/components/apm/apm_metrics.tsx | 6 ++---- .../public/components/cluster/overview/apm_panel.js | 8 ++++---- x-pack/plugins/monitoring/public/lib/apm_agent.ts | 5 +++-- 4 files changed, 10 insertions(+), 11 deletions(-) diff --git a/x-pack/plugins/monitoring/dev_docs/how_to/running_components_from_source.md b/x-pack/plugins/monitoring/dev_docs/how_to/running_components_from_source.md index fcb3bae429e7c..2008d913238f5 100644 --- a/x-pack/plugins/monitoring/dev_docs/how_to/running_components_from_source.md +++ b/x-pack/plugins/monitoring/dev_docs/how_to/running_components_from_source.md @@ -323,7 +323,7 @@ And start it with: ./apm-server -c apm-server.source.yml -e -d "*" ``` -Note that on cloud the APM server section will show up as "APM & Fleet Server", but the code paths are the same. +Note that on cloud the APM server section will show up as "Integrations Server" (previously "APM & Fleet"), but the code paths are the same. ## Logstash diff --git a/x-pack/plugins/monitoring/public/components/apm/apm_metrics.tsx b/x-pack/plugins/monitoring/public/components/apm/apm_metrics.tsx index c4e5c51856013..2f6eea57b6090 100644 --- a/x-pack/plugins/monitoring/public/components/apm/apm_metrics.tsx +++ b/x-pack/plugins/monitoring/public/components/apm/apm_metrics.tsx @@ -22,8 +22,6 @@ import { FormattedMessage } from '@kbn/i18n-react'; // @ts-ignore could not find declaration file import { MonitoringTimeseriesContainer } from '../chart'; -// @ts-ignore could not find declaration file -import { Status } from './instance/status'; import { checkAgentTypeMetric } from '../../lib/apm_agent'; interface TitleType { @@ -63,12 +61,12 @@ const getHeading = (isFleetTypeMetric: boolean) => { const titles: TitleType = {}; if (isFleetTypeMetric) { titles.title = i18n.translate('xpack.monitoring.apm.metrics.topCharts.agentTitle', { - defaultMessage: 'APM & Fleet Server - Resource Usage', + defaultMessage: 'Integrations Server - Resource Usage', }); titles.heading = ( ); return titles; diff --git a/x-pack/plugins/monitoring/public/components/cluster/overview/apm_panel.js b/x-pack/plugins/monitoring/public/components/cluster/overview/apm_panel.js index 2a2e6719ab268..24b1d508bb3c1 100644 --- a/x-pack/plugins/monitoring/public/components/cluster/overview/apm_panel.js +++ b/x-pack/plugins/monitoring/public/components/cluster/overview/apm_panel.js @@ -39,14 +39,14 @@ const getServerTitle = (isFleetTypeMetric, total) => { linkLabel.link = ( ); linkLabel.aria = i18n.translate( 'xpack.monitoring.cluster.overview.apmPanel.instancesAndFleetsTotalLinkAriaLabel', { - defaultMessage: 'APM and Fleet server instances: {apmsTotal}', + defaultMessage: 'Integrations server instances: {apmsTotal}', values: { apmsTotal }, } ); @@ -73,7 +73,7 @@ const getServerTitle = (isFleetTypeMetric, total) => { const getOverviewTitle = (isFleetTypeMetric) => { if (isFleetTypeMetric) { return i18n.translate('xpack.monitoring.cluster.overview.apmPanel.overviewFleetLinkLabel', { - defaultMessage: 'APM & Fleet server overview', + defaultMessage: 'Integrations server overview', }); } return i18n.translate('xpack.monitoring.cluster.overview.apmPanel.overviewLinkLabel', { @@ -84,7 +84,7 @@ const getOverviewTitle = (isFleetTypeMetric) => { const getHeadingTitle = (isFleetTypeMetric) => { if (isFleetTypeMetric) { return i18n.translate('xpack.monitoring.cluster.overview.apmPanel.apmFleetTitle', { - defaultMessage: 'APM & Fleet server', + defaultMessage: 'Integrations server', }); } return i18n.translate('xpack.monitoring.cluster.overview.apmPanel.apmTitle', { diff --git a/x-pack/plugins/monitoring/public/lib/apm_agent.ts b/x-pack/plugins/monitoring/public/lib/apm_agent.ts index 09419b7c91bf0..bf992cc560d1e 100644 --- a/x-pack/plugins/monitoring/public/lib/apm_agent.ts +++ b/x-pack/plugins/monitoring/public/lib/apm_agent.ts @@ -8,8 +8,9 @@ import { Legacy } from '../legacy_shims'; /** - * Possible temporary work arround to establish if APM might also be monitoring fleet: - * https://github.com/elastic/kibana/pull/95129/files#r604815886 + * Checks if on cloud and >= 7.13 + * In this configuration APM server should be running within elastic agent. + * See https://github.com/elastic/kibana/issues/97879 for details. */ export const checkAgentTypeMetric = (versions?: string[]) => { if (!Legacy.shims.isCloud || !versions) { From 5efb4b1cf62be06ce7a24361050f03208fc0bfb1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Istv=C3=A1n=20Zolt=C3=A1n=20Szab=C3=B3?= Date: Tue, 29 Mar 2022 17:22:27 +0200 Subject: [PATCH 095/160] [DOCS] Adds GET case API docs (#128606) --- docs/api/cases.asciidoc | 4 +- docs/api/cases/cases-api-get-case.asciidoc | 100 +++++++++++++++++++++ 2 files changed, 103 insertions(+), 1 deletion(-) create mode 100644 docs/api/cases/cases-api-get-case.asciidoc diff --git a/docs/api/cases.asciidoc b/docs/api/cases.asciidoc index 5aa837d35676e..273f3a0b51cc2 100644 --- a/docs/api/cases.asciidoc +++ b/docs/api/cases.asciidoc @@ -14,7 +14,7 @@ these APIs: * <> * {security-guide}/cases-api-get-case-activity.html[Get all case activity] * {security-guide}/cases-api-get-all-case-comments.html[Get all case comments] -* {security-guide}/cases-api-get-case.html[Get case] +* <> * {security-guide}/cases-api-get-comment.html[Get comment] * {security-guide}/cases-get-connector.html[Get current connector] * {security-guide}/cases-api-get-reporters.html[Get reporters] @@ -34,5 +34,7 @@ include::cases/cases-api-delete-comments.asciidoc[leveloffset=+1] //FIND include::cases/cases-api-find-cases.asciidoc[leveloffset=+1] include::cases/cases-api-find-connectors.asciidoc[leveloffset=+1] +//GET +include::cases/cases-api-get-case.asciidoc[leveloffset=+1] //UPDATE include::cases/cases-api-update.asciidoc[leveloffset=+1] diff --git a/docs/api/cases/cases-api-get-case.asciidoc b/docs/api/cases/cases-api-get-case.asciidoc new file mode 100644 index 0000000000000..6bd255f6f8326 --- /dev/null +++ b/docs/api/cases/cases-api-get-case.asciidoc @@ -0,0 +1,100 @@ +[[cases-api-get-case]] +== Get case API +++++ +Get case +++++ + +Returns a specified case. + +=== Request + +`GET :/api/cases/` + +`GET :/s//api/cases/` + +=== Prerequisite + +You must have `read` privileges for the *Cases* feature in the *Management*, +*{observability}*, or *Security* section of the +<>, depending on the +`owner` of the cases you're seeking. + +=== Path parameters + +``:: +(Required, string) An identifier for the case to retrieve. Use +<> to retrieve case IDs. + +``:: +(Optional, string) An identifier for the space. If it is not specified, the +default space is used. + +=== Query parameters + +`includeComments`:: +(Optional, boolean) Determines whether case comments are returned. Defaults to +`true`. deprecated:[8.1.0, "The `includeComments` query parameter is deprecated and will be removed in a future release."] + + +==== Response code + +`200`:: + Indicates a successful call. + +==== Example + +Returns case ID `a18b38a0-71b0-11ea-a0b2-c51ea50a58e2` without comments: + +[source,sh] +-------------------------------------------------- +GET api/cases/a18b38a0-71b0-11ea-a0b2-c51ea50a58e2 +-------------------------------------------------- +// KIBANA + +The API returns a JSON object with the retrieved case. For example: + +[source,json] +-------------------------------------------------- +{ + "id": "a18b38a0-71b0-11ea-a0b2-c51ea50a58e2", + "version": "Wzk4LDFd", + "comments": [], + "totalComment": 0, + "closed_at": null, + "closed_by": null, + "created_at": "2020-03-29T11:30:02.658Z", + "created_by": { + "email": "ahunley@imf.usa.gov", + "full_name": "Alan Hunley", + "username": "ahunley" + }, + "external_service": null, + "updated_at": "2020-03-29T12:01:50.244Z", + "updated_by": { + "full_name": "Classified", + "email": "classified@hms.oo.gov.uk", + "username": "M" + }, + "description": "James Bond clicked on a highly suspicious email banner advertising cheap holidays for underpaid civil servants. Operation bubblegum is active. Repeat - operation bubblegum is now active!", + "title": "This case will self-destruct in 5 seconds", + "status": "open", + "connector": { + "id": "131d4448-abe0-4789-939d-8ef60680b498", + "name": "My connector", + "type": ".jira", + "fields": { + "issueType": "10006", + "priority": "High", + } + }, + "settings": { + "syncAlerts": true + }, + "owner": "securitySolution", + "tags": [ + "phishing", + "social engineering", + "bubblegum" + ] +} +-------------------------------------------------- \ No newline at end of file From 5fda6d56988a549297211ecaf70b6e9885ec67c9 Mon Sep 17 00:00:00 2001 From: Esteban Beltran Date: Tue, 29 Mar 2022 17:31:28 +0200 Subject: [PATCH 096/160] [Cases] Show red color when overing the delete button in the cases table (#128718) --- x-pack/plugins/cases/public/components/all_cases/actions.tsx | 1 + 1 file changed, 1 insertion(+) diff --git a/x-pack/plugins/cases/public/components/all_cases/actions.tsx b/x-pack/plugins/cases/public/components/all_cases/actions.tsx index d9e0e0ef025c8..f978cd1b3f205 100644 --- a/x-pack/plugins/cases/public/components/all_cases/actions.tsx +++ b/x-pack/plugins/cases/public/components/all_cases/actions.tsx @@ -20,6 +20,7 @@ export const getActions = ({ { description: i18n.DELETE_CASE(), icon: 'trash', + color: 'danger', name: i18n.DELETE_CASE(), onClick: deleteCaseOnClick, type: 'icon', From 3bd3eb14c79c85991bba040f421810a90be39dbd Mon Sep 17 00:00:00 2001 From: Rickyanto Ang Date: Tue, 29 Mar 2022 08:42:03 -0700 Subject: [PATCH 097/160] UI Polish for Session viewer frame + buttons (#128188) * UI Polish for Session viewer frame + buttons * UI Update for Session Viewer + Toolbar * added Left Borders on Details panel + Fix Details panel button behaviour * Details Panel UI Polish + PR Comments * Find results interaction UI Polish, Def/Min/Max width for details panel, Timestamp bug fix * more conflict fixes * removed unused variable * fix for failed checks on buildkite #1 * Addressing PR comments * PR Comments + Search bar UI bug fix * pr comments Co-authored-by: Karl Godard --- .../detail_panel_accordion/styles.ts | 3 + .../detail_panel_description_list/styles.ts | 4 +- .../detail_panel_list_item/styles.ts | 9 +- .../public/components/process_tree/styles.ts | 2 + .../components/process_tree_node/index.tsx | 16 +- .../components/process_tree_node/styles.ts | 33 ++- .../process_tree_node/use_button_styles.ts | 20 +- .../public/components/session_view/index.tsx | 245 +++++++++--------- .../public/components/session_view/styles.ts | 19 +- .../session_view_detail_panel/index.tsx | 7 +- .../session_view_detail_panel/styles.ts | 25 ++ .../session_view_search_bar/index.tsx | 17 +- .../session_view_search_bar/styles.ts | 16 +- 13 files changed, 255 insertions(+), 161 deletions(-) create mode 100644 x-pack/plugins/session_view/public/components/session_view_detail_panel/styles.ts diff --git a/x-pack/plugins/session_view/public/components/detail_panel_accordion/styles.ts b/x-pack/plugins/session_view/public/components/detail_panel_accordion/styles.ts index c44e069c05c00..96eddb2b2bf98 100644 --- a/x-pack/plugins/session_view/public/components/detail_panel_accordion/styles.ts +++ b/x-pack/plugins/session_view/public/components/detail_panel_accordion/styles.ts @@ -22,6 +22,9 @@ export const useStyles = () => { '&:last-child': { borderBottom: euiTheme.border.thin, }, + dl: { + paddingTop: '0px', + }, }; const accordionButton: CSSObject = { diff --git a/x-pack/plugins/session_view/public/components/detail_panel_description_list/styles.ts b/x-pack/plugins/session_view/public/components/detail_panel_description_list/styles.ts index d815cb2a48283..d1f3198a10c85 100644 --- a/x-pack/plugins/session_view/public/components/detail_panel_description_list/styles.ts +++ b/x-pack/plugins/session_view/public/components/detail_panel_description_list/styles.ts @@ -14,19 +14,21 @@ export const useStyles = () => { const cached = useMemo(() => { const descriptionList: CSSObject = { - padding: euiTheme.size.s, + padding: `${euiTheme.size.base} ${euiTheme.size.s} `, }; const tabListTitle = { width: '40%', display: 'flex', alignItems: 'center', + marginTop: '0px', }; const tabListDescription = { width: '60%', display: 'flex', alignItems: 'center', + marginTop: '0px', }; return { diff --git a/x-pack/plugins/session_view/public/components/detail_panel_list_item/styles.ts b/x-pack/plugins/session_view/public/components/detail_panel_list_item/styles.ts index c370bd8adb6e2..22f5e6782288f 100644 --- a/x-pack/plugins/session_view/public/components/detail_panel_list_item/styles.ts +++ b/x-pack/plugins/session_view/public/components/detail_panel_list_item/styles.ts @@ -20,11 +20,13 @@ export const useStyles = ({ display }: StylesDeps) => { const item: CSSObject = { display, alignItems: 'center', - padding: euiTheme.size.s, + padding: `0px ${euiTheme.size.s} `, width: '100%', - fontSize: 'inherit', fontWeight: 'inherit', - minHeight: '36px', + height: euiTheme.size.xl, + lineHeight: euiTheme.size.l, + letterSpacing: '0px', + textAlign: 'left', }; const copiableItem: CSSObject = { @@ -34,6 +36,7 @@ export const useStyles = ({ display }: StylesDeps) => { '&:hover': { background: transparentize(euiTheme.colors.primary, 0.1), }, + height: '100%', }; return { diff --git a/x-pack/plugins/session_view/public/components/process_tree/styles.ts b/x-pack/plugins/session_view/public/components/process_tree/styles.ts index 207cc55e49582..ed868b7203ccd 100644 --- a/x-pack/plugins/session_view/public/components/process_tree/styles.ts +++ b/x-pack/plugins/session_view/public/components/process_tree/styles.ts @@ -22,6 +22,8 @@ export const useStyles = () => { overflow: 'auto', height: '100%', backgroundColor: colors.lightestShade, + paddingTop: size.base, + paddingLeft: size.s, }; const selectionArea: CSSObject = { diff --git a/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx b/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx index d2e5b1b899553..9d5a3b1c953cf 100644 --- a/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx +++ b/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx @@ -86,7 +86,8 @@ export function ProcessTreeNode({ ), [hasAlerts, alerts, jumpToAlertID] ); - const styles = useStyles({ depth, hasAlerts, hasInvestigatedAlert }); + const isSelected = selectedProcessId === process.id; + const styles = useStyles({ depth, hasAlerts, hasInvestigatedAlert, isSelected }); const buttonStyles = useButtonStyles({}); const nodeRef = useVisible({ @@ -249,15 +250,12 @@ export function ProcessTreeNode({ [exit_code: {exitCode}] )} - {timeStampOn && ( - - {timeStampsNormal} - - )} + {timeStampOn && ( + + {timeStampsNormal} + + )} )} diff --git a/x-pack/plugins/session_view/public/components/process_tree_node/styles.ts b/x-pack/plugins/session_view/public/components/process_tree_node/styles.ts index 55afe5c28071a..c3122294e44fd 100644 --- a/x-pack/plugins/session_view/public/components/process_tree_node/styles.ts +++ b/x-pack/plugins/session_view/public/components/process_tree_node/styles.ts @@ -13,9 +13,10 @@ interface StylesDeps { depth: number; hasAlerts: boolean; hasInvestigatedAlert: boolean; + isSelected: boolean; } -export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps) => { +export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert, isSelected }: StylesDeps) => { const { euiTheme } = useEuiTheme(); const cached = useMemo(() => { @@ -25,14 +26,11 @@ export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps const darkText: CSSObject = { color: colors.text, + fontFamily: font.familyCode, + paddingLeft: size.xxs, + paddingRight: size.xs, }; - const searchHighlight = ` - background-color: ${colors.highlight}; - color: ${colors.fullShade}; - border-radius: ${border.radius.medium}; - `; - const children: CSSObject = { position: 'relative', color: colors.ghost, @@ -48,6 +46,7 @@ export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps let bgColor = 'none'; const hoverColor = transparentize(colors.primary, 0.04); let borderColor = 'transparent'; + let searchResColor = transparentize(colors.warning, 0.32); if (hasAlerts) { borderColor = colors.danger; @@ -57,10 +56,14 @@ export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps bgColor = transparentize(colors.danger, 0.04); } - return { bgColor, borderColor, hoverColor }; + if (isSelected) { + searchResColor = colors.warning; + } + + return { bgColor, borderColor, hoverColor, searchResColor }; }; - const { bgColor, borderColor, hoverColor } = getHighlightColors(); + const { bgColor, borderColor, hoverColor, searchResColor } = getHighlightColors(); const processNode: CSSObject = { display: 'block', @@ -84,6 +87,12 @@ export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps }, }; + const searchHighlight = ` + color: ${colors.fullShade}; + border-radius: '0px'; + background-color: ${searchResColor}; + `; + const wrapper: CSSObject = { paddingLeft: size.s, position: 'relative', @@ -96,6 +105,10 @@ export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps const workingDir: CSSObject = { color: colors.successText, + fontFamily: font.familyCode, + fontWeight: font.weight.medium, + paddingLeft: size.s, + paddingRight: size.xxs, }; const timeStamp: CSSObject = { @@ -124,7 +137,7 @@ export const useStyles = ({ depth, hasAlerts, hasInvestigatedAlert }: StylesDeps timeStamp, alertDetails, }; - }, [depth, euiTheme, hasAlerts, hasInvestigatedAlert]); + }, [depth, euiTheme, hasAlerts, hasInvestigatedAlert, isSelected]); return cached; }; diff --git a/x-pack/plugins/session_view/public/components/process_tree_node/use_button_styles.ts b/x-pack/plugins/session_view/public/components/process_tree_node/use_button_styles.ts index 529a0ce5819f9..4c713b42a2d7b 100644 --- a/x-pack/plugins/session_view/public/components/process_tree_node/use_button_styles.ts +++ b/x-pack/plugins/session_view/public/components/process_tree_node/use_button_styles.ts @@ -18,7 +18,7 @@ export const useButtonStyles = ({ isExpanded }: ButtonStylesDeps) => { const { euiTheme } = useEuiTheme(); const cached = useMemo(() => { - const { colors, border, size } = euiTheme; + const { colors, border, size, font } = euiTheme; const button: CSSObject = { background: transparentize(theme.euiColorVis6, 0.04), @@ -26,14 +26,21 @@ export const useButtonStyles = ({ isExpanded }: ButtonStylesDeps) => { lineHeight: '18px', height: '20px', fontSize: size.m, - borderRadius: border.radius.medium, + fontFamily: font.family, + fontWeight: font.weight.medium, + borderRadius: border.radius.small, color: shade(theme.euiColorVis6, 0.25), - marginLeft: size.s, + marginLeft: size.xs, + marginRight: size.xs, minWidth: 0, + padding: `${size.s} ${size.xxs}`, + span: { + padding: `0px ${size.xxs} !important`, + }, }; const buttonArrow: CSSObject = { - marginLeft: size.s, + marginLeft: size.xs, }; const alertButton: CSSObject = { @@ -72,6 +79,10 @@ export const useButtonStyles = ({ isExpanded }: ButtonStylesDeps) => { textTransform: 'capitalize', }; + const buttonSize: CSSObject = { + padding: `0px ${euiTheme.size.xs}`, + }; + const expandedIcon = isExpanded ? 'arrowUp' : 'arrowDown'; return { @@ -81,6 +92,7 @@ export const useButtonStyles = ({ isExpanded }: ButtonStylesDeps) => { alertsCountNumber, userChangedButton, userChangedButtonUsername, + buttonSize, expandedIcon, }; }, [euiTheme, isExpanded]); diff --git a/x-pack/plugins/session_view/public/components/session_view/index.tsx b/x-pack/plugins/session_view/public/components/session_view/index.tsx index 1ec9441a2b1d1..2e1a598faedaa 100644 --- a/x-pack/plugins/session_view/public/components/session_view/index.tsx +++ b/x-pack/plugins/session_view/public/components/session_view/index.tsx @@ -12,6 +12,7 @@ import { EuiFlexItem, EuiResizableContainer, EuiPanel, + EuiHorizontalRule, } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n-react'; import { SectionLoading } from '../../shared_imports'; @@ -132,133 +133,137 @@ export const SessionView = ({ return ( <> - - - - - - - - - - - - + + + - - - - - - - {(EuiResizablePanel, EuiResizableButton) => ( - <> - - {renderIsLoading && ( - - - - )} +
- {hasError && ( - - -

- } - body={ -

- -

- } + + + + + + + - )} + + + +
+ + + {(EuiResizablePanel, EuiResizableButton) => ( + <> + + {renderIsLoading && ( + + + + )} - {hasData && ( -
- + + + } + body={ +

+ +

+ } /> -
- )} -
+ )} - {renderDetails ? ( - <> - - - - - - ) : ( - <> - {/* Returning an empty element here (instead of false) to avoid a bug in EuiResizableContainer */} - - )} - - )} -
+ {hasData && ( +
+ +
+ )} + + + {renderDetails ? ( + <> + + + + + + ) : ( + <> + {/* Returning an empty element here (instead of false) to avoid a bug in EuiResizableContainer */} + + )} + + )} + + ); }; diff --git a/x-pack/plugins/session_view/public/components/session_view/styles.ts b/x-pack/plugins/session_view/public/components/session_view/styles.ts index edfe2356d5aa2..3ca0594f57574 100644 --- a/x-pack/plugins/session_view/public/components/session_view/styles.ts +++ b/x-pack/plugins/session_view/public/components/session_view/styles.ts @@ -8,6 +8,7 @@ import { useMemo } from 'react'; import { useEuiTheme } from '@elastic/eui'; import { CSSObject } from '@emotion/react'; +import { euiLightVars as theme } from '@kbn/ui-theme'; interface StylesDeps { height: number | undefined; @@ -17,9 +18,7 @@ export const useStyles = ({ height = 500 }: StylesDeps) => { const { euiTheme } = useEuiTheme(); const cached = useMemo(() => { - const { border, colors } = euiTheme; - - const thinBorder = `${border.width.thin} solid ${colors.lightShade}!important`; + const { border } = euiTheme; const processTree: CSSObject = { height: `${height}px`, @@ -28,8 +27,7 @@ export const useStyles = ({ height = 500 }: StylesDeps) => { const detailPanel: CSSObject = { height: `${height}px`, - borderLeft: thinBorder, - borderRight: thinBorder, + borderRightWidth: '0px', }; const resizeHandle: CSSObject = { @@ -45,12 +43,23 @@ export const useStyles = ({ height = 500 }: StylesDeps) => { margin: `${euiTheme.size.m} ${euiTheme.size.xs} !important`, }; + const sessionViewerComponent: CSSObject = { + border: border.thin, + borderRadius: border.radius.medium, + }; + + const toolBar: CSSObject = { + backgroundColor: `${theme.euiFormBackgroundDisabledColor} !important`, + }; + return { processTree, detailPanel, resizeHandle, searchBar, buttonsEyeDetail, + sessionViewerComponent, + toolBar, }; }, [height, euiTheme]); diff --git a/x-pack/plugins/session_view/public/components/session_view_detail_panel/index.tsx b/x-pack/plugins/session_view/public/components/session_view_detail_panel/index.tsx index 51eb65a38f835..e24409a98f8fd 100644 --- a/x-pack/plugins/session_view/public/components/session_view_detail_panel/index.tsx +++ b/x-pack/plugins/session_view/public/components/session_view_detail_panel/index.tsx @@ -12,6 +12,7 @@ import { Process, ProcessEvent } from '../../../common/types/process_tree'; import { getDetailPanelProcess, getSelectedTabContent } from './helpers'; import { DetailPanelProcessTab } from '../detail_panel_process_tab'; import { DetailPanelHostTab } from '../detail_panel_host_tab'; +import { useStyles } from './styles'; import { DetailPanelAlertTab } from '../detail_panel_alert_tab'; import { ALERT_COUNT_THRESHOLD } from '../../../common/constants'; @@ -101,8 +102,10 @@ export const SessionViewDetailPanel = ({ [tabs, selectedTabId] ); + const styles = useStyles(); + return ( - <> +
{tabs.map((tab, index) => ( {tabContent} - +
); }; diff --git a/x-pack/plugins/session_view/public/components/session_view_detail_panel/styles.ts b/x-pack/plugins/session_view/public/components/session_view_detail_panel/styles.ts new file mode 100644 index 0000000000000..fbb196da3fa80 --- /dev/null +++ b/x-pack/plugins/session_view/public/components/session_view_detail_panel/styles.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { useMemo } from 'react'; +import { useEuiTheme } from '@elastic/eui'; +import { CSSObject } from '@emotion/react'; + +export const useStyles = () => { + const { euiTheme } = useEuiTheme(); + const cached = useMemo(() => { + const detailsPanelLeftBorder: CSSObject = { + borderLeft: euiTheme.border.thin, + }; + + return { + detailsPanelLeftBorder, + }; + }, [euiTheme]); + + return cached; +}; diff --git a/x-pack/plugins/session_view/public/components/session_view_search_bar/index.tsx b/x-pack/plugins/session_view/public/components/session_view_search_bar/index.tsx index f4e4dac7a94c7..05154fca40769 100644 --- a/x-pack/plugins/session_view/public/components/session_view_search_bar/index.tsx +++ b/x-pack/plugins/session_view/public/components/session_view_search_bar/index.tsx @@ -7,6 +7,7 @@ import React, { useState, useEffect } from 'react'; import { EuiSearchBar, EuiPagination } from '@elastic/eui'; import { EuiSearchBarOnChangeArgs } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; import { Process } from '../../../common/types/process_tree'; import { useStyles } from './styles'; @@ -17,6 +18,12 @@ interface SessionViewSearchBarDeps { onProcessSelected(process: Process): void; } +const translatePlaceholder = { + placeholder: i18n.translate('xpack.sessionView.searchBar.searchBarKeyPlaceholder', { + defaultMessage: 'Find...', + }), +}; + /** * The main wrapper component for the session view. */ @@ -26,7 +33,9 @@ export const SessionViewSearchBar = ({ onProcessSelected, searchResults, }: SessionViewSearchBarDeps) => { - const styles = useStyles(); + const showPagination = !!searchResults?.length; + + const styles = useStyles({ hasSearchResults: showPagination }); const [selectedResult, setSelectedResult] = useState(0); @@ -50,11 +59,9 @@ export const SessionViewSearchBar = ({ } }, [searchResults, onProcessSelected, selectedResult]); - const showPagination = !!searchResults?.length; - return ( -
- +
+ {showPagination && ( { +interface StylesDeps { + hasSearchResults: boolean; +} + +export const useStyles = ({ hasSearchResults }: StylesDeps) => { const { euiTheme } = useEuiTheme(); const cached = useMemo(() => { @@ -19,10 +23,18 @@ export const useStyles = () => { right: euiTheme.size.xxl, }; + const searchBarWithResult: CSSObject = { + position: 'relative', + 'input.euiFieldSearch.euiFieldSearch-isClearable': { + paddingRight: hasSearchResults ? '200px' : euiTheme.size.xxl, + }, + }; + return { pagination, + searchBarWithResult, }; - }, [euiTheme]); + }, [euiTheme, hasSearchResults]); return cached; }; From 9f10418f34a1984665bcdc54098204544c1a51c2 Mon Sep 17 00:00:00 2001 From: Sander Philipse <94373878+sphilipse@users.noreply.github.com> Date: Tue, 29 Mar 2022 17:43:01 +0200 Subject: [PATCH 098/160] Sort content sources and connectors by display name (#128745) * Sort content sources and connectors by display name --- .../workplace_search/utils/index.ts | 1 + .../utils/sort_by_name.test.ts | 42 +++++++++++++++++++ .../workplace_search/utils/sort_by_name.ts | 14 +++++++ .../views/content_sources/sources_logic.ts | 28 +++++++------ .../views/settings/settings_logic.ts | 3 +- 5 files changed, 74 insertions(+), 14 deletions(-) create mode 100644 x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.test.ts create mode 100644 x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.ts diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/index.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/index.ts index 86d3e4f844bbd..c66a6d1ca0fc0 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/index.ts +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/index.ts @@ -13,3 +13,4 @@ export { readUploadedFileAsText } from './read_uploaded_file_as_text'; export { handlePrivateKeyUpload } from './handle_private_key_upload'; export { hasMultipleConnectorOptions } from './has_multiple_connector_options'; export { isNotNullish } from './is_not_nullish'; +export { sortByName } from './sort_by_name'; diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.test.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.test.ts new file mode 100644 index 0000000000000..185eeedda0512 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.test.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { sortByName } from './sort_by_name'; + +describe('sortByName', () => { + it('should sort by name', () => { + const unsorted = [ + { + name: 'aba', + }, + { + name: 'aaa', + }, + { + name: 'constant', + }, + { + name: 'beta', + }, + ]; + const sorted = [ + { + name: 'aaa', + }, + { + name: 'aba', + }, + { + name: 'beta', + }, + { + name: 'constant', + }, + ]; + expect(sortByName(unsorted)).toEqual(sorted); + }); +}); diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.ts new file mode 100644 index 0000000000000..cb2f85b245166 --- /dev/null +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/utils/sort_by_name.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +interface WithName { + name: string; +} + +export function sortByName(nameItems: T[]): T[] { + return [...nameItems].sort((a, b) => a.name.localeCompare(b.name)); +} diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/sources_logic.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/sources_logic.ts index 1651411fb9c5d..868831ab7c7fb 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/sources_logic.ts +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/content_sources/sources_logic.ts @@ -15,6 +15,7 @@ import { flashAPIErrors, flashSuccessToast } from '../../../shared/flash_message import { HttpLogic } from '../../../shared/http'; import { AppLogic } from '../../app_logic'; import { Connector, ContentSourceDetails, ContentSourceStatus, SourceDataItem } from '../../types'; +import { sortByName } from '../../utils'; import { staticSourceData } from './source_data'; @@ -50,7 +51,7 @@ export interface IPermissionsModalProps { additionalConfiguration: boolean; } -type CombinedDataItem = SourceDataItem & ContentSourceDetails; +type CombinedDataItem = SourceDataItem & { connected: boolean }; export interface ISourcesValues { contentSources: ContentSourceDetails[]; @@ -144,11 +145,13 @@ export const SourcesLogic = kea>( selectors: ({ selectors }) => ({ availableSources: [ () => [selectors.sourceData], - (sourceData: SourceDataItem[]) => sourceData.filter(({ configured }) => !configured), + (sourceData: SourceDataItem[]) => + sortByName(sourceData.filter(({ configured }) => !configured)), ], configuredSources: [ () => [selectors.sourceData], - (sourceData: SourceDataItem[]) => sourceData.filter(({ configured }) => configured), + (sourceData: SourceDataItem[]) => + sortByName(sourceData.filter(({ configured }) => configured)), ], externalConfigured: [ () => [selectors.configuredSources], @@ -307,18 +310,17 @@ export const mergeServerAndStaticData = ( serverData: Connector[], staticData: SourceDataItem[], contentSources: ContentSourceDetails[] -) => { - const combined = [] as CombinedDataItem[]; - staticData.forEach((staticItem) => { - const type = staticItem.serviceType; - const serverItem = serverData.find(({ serviceType }) => serviceType === type); - const connectedSource = contentSources.find(({ serviceType }) => serviceType === type); - combined.push({ +): CombinedDataItem[] => { + const unsortedData = staticData.map((staticItem) => { + const serverItem = serverData.find(({ serviceType }) => serviceType === staticItem.serviceType); + const connectedSource = contentSources.find( + ({ serviceType }) => serviceType === staticItem.serviceType + ); + return { ...staticItem, ...serverItem, connected: !!connectedSource, - } as CombinedDataItem); + }; }); - - return combined; + return sortByName(unsortedData); }; diff --git a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/settings/settings_logic.ts b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/settings/settings_logic.ts index 64dfa3f8e13bb..8c6dee4cf7f9c 100644 --- a/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/settings/settings_logic.ts +++ b/x-pack/plugins/enterprise_search/public/applications/workplace_search/views/settings/settings_logic.ts @@ -20,6 +20,7 @@ import { AppLogic } from '../../app_logic'; import { ORG_UPDATED_MESSAGE, OAUTH_APP_UPDATED_MESSAGE } from '../../constants'; import { ORG_SETTINGS_CONNECTORS_PATH } from '../../routes'; import { Connector } from '../../types'; +import { sortByName } from '../../utils'; interface IOauthApplication { name: string; @@ -118,7 +119,7 @@ export const SettingsLogic = kea> connectors: [ [], { - onInitializeConnectors: (_, connectors) => connectors, + onInitializeConnectors: (_, connectors) => sortByName(connectors), }, ], orgNameInputValue: [ From ac4e96c606106f9abc7341b280134f01ab4f1d76 Mon Sep 17 00:00:00 2001 From: Marshall Main <55718608+marshallmain@users.noreply.github.com> Date: Tue, 29 Mar 2022 08:59:53 -0700 Subject: [PATCH 099/160] [Security Solution][Alerts] Remove dead legacy signals code (#128328) * Remove dead legacy signals code * Remove unused import * Remove extra param --- ...eate_persistence_rule_type_wrapper.mock.ts | 22 + .../create_security_rule_type_wrapper.ts | 32 +- .../build_alert_group_from_sequence.test.ts | 344 +++++++++++++- .../utils/build_alert_group_from_sequence.ts | 52 ++- .../signals/build_bulk_body.ts | 251 ---------- .../signals/build_event_type_signal.test.ts | 101 ---- .../signals/build_event_type_signal.ts | 30 -- .../signals/build_rule.test.ts | 189 -------- .../detection_engine/signals/build_rule.ts | 91 ---- .../signals/build_signal.test.ts | 376 --------------- .../detection_engine/signals/build_signal.ts | 130 ------ .../signals/bulk_create_factory.ts | 107 ----- .../signals/bulk_create_ml_signals.ts | 2 +- .../signals/executors/query.ts | 1 - .../detection_engine/signals/get_filter.ts | 4 +- .../signals/search_after_bulk_create.test.ts | 441 ++++-------------- .../signals/search_after_bulk_create.ts | 3 +- .../threat_mapping/create_event_signal.ts | 1 - .../threat_mapping/create_threat_signal.ts | 1 - .../bulk_create_threshold_signals.test.ts | 20 +- .../bulk_create_threshold_signals.ts | 31 +- .../lib/detection_engine/signals/types.ts | 13 +- .../signals/wrap_hits_factory.ts | 37 -- .../signals/wrap_sequences_factory.ts | 39 -- 24 files changed, 539 insertions(+), 1779 deletions(-) create mode 100644 x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.mock.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_bulk_body.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.test.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.test.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.test.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_factory.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_hits_factory.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_sequences_factory.ts diff --git a/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.mock.ts b/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.mock.ts new file mode 100644 index 0000000000000..86ef14e491f4e --- /dev/null +++ b/x-pack/plugins/rule_registry/server/utils/create_persistence_rule_type_wrapper.mock.ts @@ -0,0 +1,22 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { alertsMock } from '../../../alerting/server/mocks'; +import { PersistenceServices } from './persistence_types'; + +export const createPersistenceServicesMock = (): jest.Mocked => { + return { + alertWithPersistence: jest.fn(), + }; +}; + +export const createPersistenceExecutorOptionsMock = () => { + return { + ...alertsMock.createAlertServices(), + ...createPersistenceServicesMock(), + }; +}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/create_security_rule_type_wrapper.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/create_security_rule_type_wrapper.ts index 38300dff14558..f25bb16e90004 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/create_security_rule_type_wrapper.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/create_security_rule_type_wrapper.ts @@ -8,7 +8,6 @@ import { isEmpty } from 'lodash'; import { parseScheduleDates } from '@kbn/securitysolution-io-ts-utils'; -import { ListArray } from '@kbn/securitysolution-io-ts-list-types'; import agent from 'elastic-apm-node'; import { createPersistenceRuleTypeWrapper } from '../../../../../rule_registry/server'; @@ -19,11 +18,7 @@ import { getRuleRangeTuples, hasReadIndexPrivileges, hasTimestampFields, - isEqlParams, - isQueryParams, - isSavedQueryParams, - isThreatParams, - isThresholdParams, + isMachineLearningParams, } from '../signals/utils'; import { DEFAULT_MAX_SIGNALS, DEFAULT_SEARCH_AFTER_PAGE_SIZE } from '../../../../common/constants'; import { CreateSecurityRuleTypeWrapper } from './types'; @@ -133,22 +128,13 @@ export const createSecurityRuleTypeWrapper: CreateSecurityRuleTypeWrapper = ...params, name, id: alertId, - } as unknown as NotificationRuleTypeParams; + }; // check if rule has permissions to access given index pattern // move this collection of lines into a function in utils // so that we can use it in create rules route, bulk, etc. try { - // Typescript 4.1.3 can't figure out that `!isMachineLearningParams(params)` also excludes the only rule type - // of rule params that doesn't include `params.index`, but Typescript 4.3.5 does compute the stricter type correctly. - // When we update Typescript to >= 4.3.5, we can replace this logic with `!isMachineLearningParams(params)` again. - if ( - isEqlParams(params) || - isThresholdParams(params) || - isQueryParams(params) || - isSavedQueryParams(params) || - isThreatParams(params) - ) { + if (!isMachineLearningParams(params)) { const index = params.index; const hasTimestampOverride = !!timestampOverride; @@ -170,7 +156,7 @@ export const createSecurityRuleTypeWrapper: CreateSecurityRuleTypeWrapper = { index, fields: hasTimestampOverride - ? ['@timestamp', timestampOverride as string] + ? ['@timestamp', timestampOverride] : ['@timestamp'], include_unmapped: true, }, @@ -178,9 +164,7 @@ export const createSecurityRuleTypeWrapper: CreateSecurityRuleTypeWrapper = ) ); wroteWarningStatus = await hasTimestampFields({ - timestampField: hasTimestampOverride - ? (timestampOverride as string) - : '@timestamp', + timestampField: hasTimestampOverride ? timestampOverride : '@timestamp', timestampFieldCapsResponse: timestampFieldCaps, inputIndices, ruleExecutionLogger, @@ -202,8 +186,8 @@ export const createSecurityRuleTypeWrapper: CreateSecurityRuleTypeWrapper = const { tuples, remainingGap } = getRuleRangeTuples({ logger, previousStartedAt, - from: from as string, - to: to as string, + from, + to, interval, maxSignals: maxSignals ?? DEFAULT_MAX_SIGNALS, buildRuleMessage, @@ -236,7 +220,7 @@ export const createSecurityRuleTypeWrapper: CreateSecurityRuleTypeWrapper = const exceptionItems = await getExceptions({ client: exceptionsClient, - lists: (params.exceptionsList as ListArray) ?? [], + lists: params.exceptionsList, }); const bulkCreate = bulkCreateFactory( diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.test.ts index 969f7caab6456..b1b68829665fc 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.test.ts @@ -10,7 +10,11 @@ import { Logger } from 'kibana/server'; import { ALERT_RULE_CONSUMER } from '@kbn/rule-data-utils'; import { sampleDocNoSortId, sampleRuleGuid } from '../../../signals/__mocks__/es_results'; -import { buildAlertGroupFromSequence } from './build_alert_group_from_sequence'; +import { + buildAlertGroupFromSequence, + objectArrayIntersection, + objectPairIntersection, +} from './build_alert_group_from_sequence'; import { SERVER_APP_ID } from '../../../../../../common/constants'; import { getCompleteRuleMock, getQueryRuleParams } from '../../../schemas/rule_schemas.mock'; import { QueryRuleParams } from '../../../schemas/rule_schemas'; @@ -134,4 +138,342 @@ describe('buildAlert', () => { expect(groupId).toEqual(groupIds[0]); } }); + + describe('recursive intersection between objects', () => { + test('should treat numbers and strings as unequal', () => { + const a = { + field1: 1, + field2: 1, + }; + const b = { + field1: 1, + field2: '1', + }; + const intersection = objectPairIntersection(a, b); + const expected = { + field1: 1, + }; + expect(intersection).toEqual(expected); + }); + + test('should strip unequal numbers and strings', () => { + const a = { + field1: 1, + field2: 1, + field3: 'abcd', + field4: 'abcd', + }; + const b = { + field1: 1, + field2: 100, + field3: 'abcd', + field4: 'wxyz', + }; + const intersection = objectPairIntersection(a, b); + const expected = { + field1: 1, + field3: 'abcd', + }; + expect(intersection).toEqual(expected); + }); + + test('should handle null values', () => { + const a = { + field1: 1, + field2: '1', + field3: null, + }; + const b = { + field1: null, + field2: null, + field3: null, + }; + const intersection = objectPairIntersection(a, b); + const expected = { + field3: null, + }; + expect(intersection).toEqual(expected); + }); + + test('should handle explicit undefined values and return undefined if left with only undefined fields', () => { + const a = { + field1: 1, + field2: '1', + field3: undefined, + }; + const b = { + field1: undefined, + field2: undefined, + field3: undefined, + }; + const intersection = objectPairIntersection(a, b); + const expected = undefined; + expect(intersection).toEqual(expected); + }); + + test('should strip arrays out regardless of whether they are equal', () => { + const a = { + array_field1: [1, 2], + array_field2: [1, 2], + }; + const b = { + array_field1: [1, 2], + array_field2: [3, 4], + }; + const intersection = objectPairIntersection(a, b); + const expected = undefined; + expect(intersection).toEqual(expected); + }); + + test('should strip fields that are not in both objects', () => { + const a = { + field1: 1, + }; + const b = { + field2: 1, + }; + const intersection = objectPairIntersection(a, b); + const expected = undefined; + expect(intersection).toEqual(expected); + }); + + test('should work on objects within objects', () => { + const a = { + container_field: { + field1: 1, + field2: 1, + field3: 10, + field5: 1, + field6: null, + array_field: [1, 2], + nested_container_field: { + field1: 1, + field2: 1, + }, + nested_container_field2: { + field1: undefined, + }, + }, + container_field_without_intersection: { + sub_field1: 1, + }, + }; + const b = { + container_field: { + field1: 1, + field2: 2, + field4: 10, + field5: '1', + field6: null, + array_field: [1, 2], + nested_container_field: { + field1: 1, + field2: 2, + }, + nested_container_field2: { + field1: undefined, + }, + }, + container_field_without_intersection: { + sub_field2: 1, + }, + }; + const intersection = objectPairIntersection(a, b); + const expected = { + container_field: { + field1: 1, + field6: null, + nested_container_field: { + field1: 1, + }, + }, + }; + expect(intersection).toEqual(expected); + }); + + test('should work on objects with a variety of fields', () => { + const a = { + field1: 1, + field2: 1, + field3: 10, + field5: 1, + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 1, + sub_field3: 10, + }, + container_field_without_intersection: { + sub_field1: 1, + }, + }; + const b = { + field1: 1, + field2: 2, + field4: 10, + field5: '1', + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 2, + sub_field4: 10, + }, + container_field_without_intersection: { + sub_field2: 1, + }, + }; + const intersection = objectPairIntersection(a, b); + const expected = { + field1: 1, + field6: null, + container_field: { + sub_field1: 1, + }, + }; + expect(intersection).toEqual(expected); + }); + }); + + describe('objectArrayIntersection', () => { + test('should return undefined if the array is empty', () => { + const intersection = objectArrayIntersection([]); + const expected = undefined; + expect(intersection).toEqual(expected); + }); + test('should return the initial object if there is only 1', () => { + const a = { + field1: 1, + field2: 1, + field3: 10, + field5: 1, + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 1, + sub_field3: 10, + }, + container_field_without_intersection: { + sub_field1: 1, + }, + }; + const intersection = objectArrayIntersection([a]); + const expected = { + field1: 1, + field2: 1, + field3: 10, + field5: 1, + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 1, + sub_field3: 10, + }, + container_field_without_intersection: { + sub_field1: 1, + }, + }; + expect(intersection).toEqual(expected); + }); + test('should work with exactly 2 objects', () => { + const a = { + field1: 1, + field2: 1, + field3: 10, + field5: 1, + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 1, + sub_field3: 10, + }, + container_field_without_intersection: { + sub_field1: 1, + }, + }; + const b = { + field1: 1, + field2: 2, + field4: 10, + field5: '1', + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 2, + sub_field4: 10, + }, + container_field_without_intersection: { + sub_field2: 1, + }, + }; + const intersection = objectArrayIntersection([a, b]); + const expected = { + field1: 1, + field6: null, + container_field: { + sub_field1: 1, + }, + }; + expect(intersection).toEqual(expected); + }); + + test('should work with 3 or more objects', () => { + const a = { + field1: 1, + field2: 1, + field3: 10, + field5: 1, + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 1, + sub_field3: 10, + }, + container_field_without_intersection: { + sub_field1: 1, + }, + }; + const b = { + field1: 1, + field2: 2, + field4: 10, + field5: '1', + field6: null, + array_field: [1, 2], + container_field: { + sub_field1: 1, + sub_field2: 2, + sub_field4: 10, + }, + container_field_without_intersection: { + sub_field2: 1, + }, + }; + const c = { + field1: 1, + field2: 2, + field4: 10, + field5: '1', + array_field: [1, 2], + container_field: { + sub_field2: 2, + sub_field4: 10, + }, + container_field_without_intersection: { + sub_field2: 1, + }, + }; + const intersection = objectArrayIntersection([a, b, c]); + const expected = { + field1: 1, + }; + expect(intersection).toEqual(expected); + }); + }); }); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts index 180494f9209dd..26e0289732bfb 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts @@ -16,7 +16,6 @@ import { buildAlert, buildAncestors, generateAlertId } from './build_alert'; import { buildBulkBody } from './build_bulk_body'; import { EqlSequence } from '../../../../../../common/detection_engine/types'; import { generateBuildingBlockIds } from './generate_building_block_ids'; -import { objectArrayIntersection } from '../../../signals/build_bulk_body'; import { BuildReasonMessage } from '../../../signals/reason_formatters'; import { CompleteRule, RuleParams } from '../../../schemas/rule_schemas'; import { @@ -118,3 +117,54 @@ export const buildAlertRoot = ( [ALERT_GROUP_ID]: generateAlertId(doc), }; }; + +export const objectArrayIntersection = (objects: object[]) => { + if (objects.length === 0) { + return undefined; + } else if (objects.length === 1) { + return objects[0]; + } else { + return objects + .slice(1) + .reduce( + (acc: object | undefined, obj): object | undefined => objectPairIntersection(acc, obj), + objects[0] + ); + } +}; + +export const objectPairIntersection = (a: object | undefined, b: object | undefined) => { + if (a === undefined || b === undefined) { + return undefined; + } + const intersection: Record = {}; + Object.entries(a).forEach(([key, aVal]) => { + if (key in b) { + const bVal = (b as Record)[key]; + if ( + typeof aVal === 'object' && + !(aVal instanceof Array) && + aVal !== null && + typeof bVal === 'object' && + !(bVal instanceof Array) && + bVal !== null + ) { + intersection[key] = objectPairIntersection(aVal, bVal); + } else if (aVal === bVal) { + intersection[key] = aVal; + } + } + }); + // Count up the number of entries that are NOT undefined in the intersection + // If there are no keys OR all entries are undefined, return undefined + if ( + Object.values(intersection).reduce( + (acc: number, value) => (value !== undefined ? acc + 1 : acc), + 0 + ) === 0 + ) { + return undefined; + } else { + return intersection; + } +}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_bulk_body.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_bulk_body.ts deleted file mode 100644 index 21bfced47df42..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_bulk_body.ts +++ /dev/null @@ -1,251 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { TIMESTAMP } from '@kbn/rule-data-utils'; -import { getMergeStrategy } from './source_fields_merging/strategies'; -import { - SignalSourceHit, - SignalHit, - Signal, - BaseSignalHit, - SignalSource, - WrappedSignalHit, -} from './types'; -import { buildRuleWithoutOverrides, buildRuleWithOverrides } from './build_rule'; -import { additionalSignalFields, buildSignal } from './build_signal'; -import { buildEventTypeSignal } from './build_event_type_signal'; -import { EqlSequence } from '../../../../common/detection_engine/types'; -import { generateSignalId, wrapBuildingBlocks, wrapSignal } from './utils'; -import type { ConfigType } from '../../../config'; -import { BuildReasonMessage } from './reason_formatters'; -import { CompleteRule, RuleParams } from '../schemas/rule_schemas'; - -/** - * Formats the search_after result for insertion into the signals index. We first create a - * "best effort" merged "fields" with the "_source" object, then build the signal object, - * then the event object, and finally we strip away any additional temporary data that was added - * such as the "threshold_result". - * @param completeRule The rule object to build overrides - * @param doc The SignalSourceHit with "_source", "fields", and additional data such as "threshold_result" - * @returns The body that can be added to a bulk call for inserting the signal. - */ -export const buildBulkBody = ( - completeRule: CompleteRule, - doc: SignalSourceHit, - mergeStrategy: ConfigType['alertMergeStrategy'], - ignoreFields: ConfigType['alertIgnoreFields'], - buildReasonMessage: BuildReasonMessage -): SignalHit => { - const mergedDoc = getMergeStrategy(mergeStrategy)({ doc, ignoreFields }); - const rule = buildRuleWithOverrides(completeRule, mergedDoc._source ?? {}); - const timestamp = new Date().toISOString(); - const reason = buildReasonMessage({ - name: completeRule.ruleConfig.name, - severity: completeRule.ruleParams.severity, - mergedDoc, - }); - const signal: Signal = { - ...buildSignal([mergedDoc], rule, reason), - ...additionalSignalFields(mergedDoc), - }; - const event = buildEventTypeSignal(mergedDoc); - // Filter out any kibana.* fields from the generated signal - kibana.* fields are aliases - // in siem-signals so we can't write to them, but for signals-on-signals they'll be returned - // in the fields API response and merged into the mergedDoc source - const { - threshold_result: thresholdResult, - kibana, - ...filteredSource - } = mergedDoc._source || { - threshold_result: null, - }; - const signalHit: SignalHit = { - ...filteredSource, - [TIMESTAMP]: timestamp, - event, - signal, - }; - return signalHit; -}; - -/** - * Takes N raw documents from ES that form a sequence and builds them into N+1 signals ready to be indexed - - * one signal for each event in the sequence, and a "shell" signal that ties them all together. All N+1 signals - * share the same signal.group.id to make it easy to query them. - * @param sequence The raw ES documents that make up the sequence - * @param completeRule rule object representing the rule that found the sequence - * @param outputIndex Index to write the resulting signals to - */ -export const buildSignalGroupFromSequence = ( - sequence: EqlSequence, - completeRule: CompleteRule, - outputIndex: string, - mergeStrategy: ConfigType['alertMergeStrategy'], - ignoreFields: ConfigType['alertIgnoreFields'], - buildReasonMessage: BuildReasonMessage -): WrappedSignalHit[] => { - const wrappedBuildingBlocks = wrapBuildingBlocks( - sequence.events.map((event) => { - const signal = buildSignalFromEvent( - event, - completeRule, - false, - mergeStrategy, - ignoreFields, - buildReasonMessage - ); - signal.signal.rule.building_block_type = 'default'; - return signal; - }), - outputIndex - ); - - if ( - wrappedBuildingBlocks.some((block) => - block._source.signal?.ancestors.some((ancestor) => ancestor.rule === completeRule.alertId) - ) - ) { - return []; - } - - // Now that we have an array of building blocks for the events in the sequence, - // we can build the signal that links the building blocks together - // and also insert the group id (which is also the "shell" signal _id) in each building block - const sequenceSignal = wrapSignal( - buildSignalFromSequence(wrappedBuildingBlocks, completeRule, buildReasonMessage), - outputIndex - ); - wrappedBuildingBlocks.forEach((block, idx) => { - // TODO: fix type of blocks so we don't have to check existence of _source.signal - if (block._source.signal) { - block._source.signal.group = { - id: sequenceSignal._id, - index: idx, - }; - } - }); - return [...wrappedBuildingBlocks, sequenceSignal]; -}; - -export const buildSignalFromSequence = ( - events: WrappedSignalHit[], - completeRule: CompleteRule, - buildReasonMessage: BuildReasonMessage -): SignalHit => { - const rule = buildRuleWithoutOverrides(completeRule); - const timestamp = new Date().toISOString(); - const mergedEvents = objectArrayIntersection(events.map((event) => event._source)); - const reason = buildReasonMessage({ - name: completeRule.ruleConfig.name, - severity: completeRule.ruleParams.severity, - mergedDoc: mergedEvents as SignalSourceHit, - }); - const signal: Signal = buildSignal(events, rule, reason); - return { - ...mergedEvents, - [TIMESTAMP]: timestamp, - event: { - kind: 'signal', - }, - signal: { - ...signal, - group: { - // This is the same function that is used later to generate the _id for the sequence signal document, - // so _id should equal signal.group.id for the "shell" document - id: generateSignalId(signal), - }, - }, - }; -}; - -export const buildSignalFromEvent = ( - event: BaseSignalHit, - completeRule: CompleteRule, - applyOverrides: boolean, - mergeStrategy: ConfigType['alertMergeStrategy'], - ignoreFields: ConfigType['alertIgnoreFields'], - buildReasonMessage: BuildReasonMessage -): SignalHit => { - const mergedEvent = getMergeStrategy(mergeStrategy)({ doc: event, ignoreFields }); - const rule = applyOverrides - ? buildRuleWithOverrides(completeRule, mergedEvent._source ?? {}) - : buildRuleWithoutOverrides(completeRule); - const timestamp = new Date().toISOString(); - const reason = buildReasonMessage({ - name: completeRule.ruleConfig.name, - severity: completeRule.ruleParams.severity, - mergedDoc: mergedEvent, - }); - const signal: Signal = { - ...buildSignal([mergedEvent], rule, reason), - ...additionalSignalFields(mergedEvent), - }; - const eventFields = buildEventTypeSignal(mergedEvent); - // Filter out any kibana.* fields from the generated signal - kibana.* fields are aliases - // in siem-signals so we can't write to them, but for signals-on-signals they'll be returned - // in the fields API response and merged into the mergedDoc source - const { kibana, ...filteredSource } = mergedEvent._source || {}; - // TODO: better naming for SignalHit - it's really a new signal to be inserted - const signalHit: SignalHit = { - ...filteredSource, - [TIMESTAMP]: timestamp, - event: eventFields, - signal, - }; - return signalHit; -}; - -export const objectArrayIntersection = (objects: object[]) => { - if (objects.length === 0) { - return undefined; - } else if (objects.length === 1) { - return objects[0]; - } else { - return objects - .slice(1) - .reduce( - (acc: object | undefined, obj): object | undefined => objectPairIntersection(acc, obj), - objects[0] - ); - } -}; - -export const objectPairIntersection = (a: object | undefined, b: object | undefined) => { - if (a === undefined || b === undefined) { - return undefined; - } - const intersection: Record = {}; - Object.entries(a).forEach(([key, aVal]) => { - if (key in b) { - const bVal = (b as Record)[key]; - if ( - typeof aVal === 'object' && - !(aVal instanceof Array) && - aVal !== null && - typeof bVal === 'object' && - !(bVal instanceof Array) && - bVal !== null - ) { - intersection[key] = objectPairIntersection(aVal, bVal); - } else if (aVal === bVal) { - intersection[key] = aVal; - } - } - }); - // Count up the number of entries that are NOT undefined in the intersection - // If there are no keys OR all entries are undefined, return undefined - if ( - Object.values(intersection).reduce( - (acc: number, value) => (value !== undefined ? acc + 1 : acc), - 0 - ) === 0 - ) { - return undefined; - } else { - return intersection; - } -}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.test.ts deleted file mode 100644 index cc3456e7ab968..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.test.ts +++ /dev/null @@ -1,101 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { sampleDocNoSortId } from './__mocks__/es_results'; -import { buildEventTypeSignal, isEventTypeSignal } from './build_event_type_signal'; - -describe('buildEventTypeSignal', () => { - beforeEach(() => { - jest.clearAllMocks(); - }); - - test('it returns the event appended of kind signal if it does not exist', () => { - const doc = sampleDocNoSortId(); - delete doc._source.event; - const eventType = buildEventTypeSignal(doc); - const expected: object = { kind: 'signal' }; - expect(eventType).toEqual(expected); - }); - - test('it returns the event appended of kind signal if it is an empty object', () => { - const doc = sampleDocNoSortId(); - doc._source.event = {}; - const eventType = buildEventTypeSignal(doc); - const expected: object = { kind: 'signal' }; - expect(eventType).toEqual(expected); - }); - - test('it returns the event with kind signal and other properties if they exist', () => { - const doc = sampleDocNoSortId(); - doc._source.event = { - action: 'socket_opened', - module: 'system', - dataset: 'socket', - }; - const eventType = buildEventTypeSignal(doc); - const expected: object = { - action: 'socket_opened', - module: 'system', - dataset: 'socket', - kind: 'signal', - }; - expect(eventType).toEqual(expected); - }); - - test('It validates a sample doc with no signal type as "false"', () => { - const doc = sampleDocNoSortId(); - expect(isEventTypeSignal(doc)).toEqual(false); - }); - - test('It validates a sample doc with a signal type as "true"', () => { - const doc = { - ...sampleDocNoSortId(), - _source: { - ...sampleDocNoSortId()._source, - signal: { - rule: { id: 'id-123' }, - }, - }, - }; - expect(isEventTypeSignal(doc)).toEqual(true); - }); - - test('It validates a numeric signal string as "false"', () => { - const doc = { - ...sampleDocNoSortId(), - _source: { - ...sampleDocNoSortId()._source, - signal: 'something', - }, - }; - expect(isEventTypeSignal(doc)).toEqual(false); - }); - - test('It validates an empty object as "false"', () => { - const doc = { - ...sampleDocNoSortId(), - _source: { - ...sampleDocNoSortId()._source, - signal: {}, - }, - }; - expect(isEventTypeSignal(doc)).toEqual(false); - }); - - test('It validates an empty rule object as "false"', () => { - const doc = { - ...sampleDocNoSortId(), - _source: { - ...sampleDocNoSortId()._source, - signal: { - rule: {}, - }, - }, - }; - expect(isEventTypeSignal(doc)).toEqual(false); - }); -}); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.ts deleted file mode 100644 index 0dd2acfb88ffe..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_event_type_signal.ts +++ /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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import { BaseSignalHit, SimpleHit } from './types'; -import { getField } from './utils'; - -export const buildEventTypeSignal = (doc: BaseSignalHit): object => { - if (doc._source != null && doc._source.event instanceof Object) { - return { ...doc._source.event, kind: 'signal' }; - } else { - return { kind: 'signal' }; - } -}; - -/** - * Given a document this will return true if that document is a signal - * document. We can't guarantee the code will call this function with a document - * before adding the _source.event.kind = "signal" from "buildEventTypeSignal" - * so we do basic testing to ensure that if the object has the fields of: - * "signal.rule.id" then it will be one of our signals rather than a customer - * overwritten signal. - * @param doc The document which might be a signal or it might be a regular log - */ -export const isEventTypeSignal = (doc: SimpleHit): boolean => { - const ruleId = getField(doc, 'signal.rule.id'); - return ruleId != null && typeof ruleId === 'string'; -}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.test.ts deleted file mode 100644 index 9ae51688ee676..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.test.ts +++ /dev/null @@ -1,189 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { buildRuleWithOverrides, buildRuleWithoutOverrides } from './build_rule'; -import { sampleDocNoSortId, expectedRule, sampleDocSeverity } from './__mocks__/es_results'; -import { RulesSchema } from '../../../../common/detection_engine/schemas/response/rules_schema'; -import { INTERNAL_RULE_ID_KEY, INTERNAL_IMMUTABLE_KEY } from '../../../../common/constants'; -import { - getCompleteRuleMock, - getQueryRuleParams, - getThreatRuleParams, -} from '../schemas/rule_schemas.mock'; -import { - CompleteRule, - QueryRuleParams, - RuleParams, - ThreatRuleParams, -} from '../schemas/rule_schemas'; - -describe('buildRuleWithoutOverrides', () => { - let params: RuleParams; - let completeRule: CompleteRule; - - beforeEach(() => { - params = getQueryRuleParams(); - completeRule = getCompleteRuleMock(params); - }); - - test('builds a rule using rule alert', () => { - const rule = buildRuleWithoutOverrides(completeRule); - expect(rule).toEqual(expectedRule()); - }); - - test('builds a rule and removes internal tags', () => { - completeRule.ruleConfig.tags = [ - 'some fake tag 1', - 'some fake tag 2', - `${INTERNAL_RULE_ID_KEY}:rule-1`, - `${INTERNAL_IMMUTABLE_KEY}:true`, - ]; - const rule = buildRuleWithoutOverrides(completeRule); - expect(rule.tags).toEqual(['some fake tag 1', 'some fake tag 2']); - }); - - test('it builds a rule as expected with filters present', () => { - const ruleFilters = [ - { - query: 'host.name: Rebecca', - }, - { - query: 'host.name: Evan', - }, - { - query: 'host.name: Braden', - }, - ]; - completeRule.ruleParams.filters = ruleFilters; - const rule = buildRuleWithoutOverrides(completeRule); - expect(rule.filters).toEqual(ruleFilters); - }); - - test('it creates a indicator/threat_mapping/threat_matching rule', () => { - const ruleParams: ThreatRuleParams = { - ...getThreatRuleParams(), - threatMapping: [ - { - entries: [ - { - field: 'host.name', - value: 'host.name', - type: 'mapping', - }, - ], - }, - ], - threatFilters: [ - { - query: { - bool: { - must: [ - { - query_string: { - query: 'host.name: linux', - analyze_wildcard: true, - time_zone: 'Zulu', - }, - }, - ], - }, - }, - }, - ], - threatIndicatorPath: 'some.path', - threatQuery: 'threat_query', - threatIndex: ['threat_index'], - threatLanguage: 'kuery', - }; - const threatMatchCompleteRule = getCompleteRuleMock(ruleParams); - const threatMatchRule = buildRuleWithoutOverrides(threatMatchCompleteRule); - const expected: Partial = { - threat_mapping: ruleParams.threatMapping, - threat_filters: ruleParams.threatFilters, - threat_indicator_path: ruleParams.threatIndicatorPath, - threat_query: ruleParams.threatQuery, - threat_index: ruleParams.threatIndex, - threat_language: ruleParams.threatLanguage, - }; - expect(threatMatchRule).toEqual(expect.objectContaining(expected)); - }); -}); - -describe('buildRuleWithOverrides', () => { - let params: RuleParams; - let completeRule: CompleteRule; - - beforeEach(() => { - params = getQueryRuleParams(); - completeRule = getCompleteRuleMock(params); - }); - - test('it applies rule name override in buildRule', () => { - completeRule.ruleParams.ruleNameOverride = 'someKey'; - const rule = buildRuleWithOverrides(completeRule, sampleDocNoSortId()._source!); - const expected = { - ...expectedRule(), - name: 'someValue', - rule_name_override: 'someKey', - meta: { - ruleNameOverridden: true, - someMeta: 'someField', - }, - }; - expect(rule).toEqual(expected); - }); - - test('it applies risk score override in buildRule', () => { - const newRiskScore = 79; - completeRule.ruleParams.riskScoreMapping = [ - { - field: 'new_risk_score', - // value and risk_score aren't used for anything but are required in the schema - value: '', - operator: 'equals', - risk_score: undefined, - }, - ]; - const doc = sampleDocNoSortId(); - doc._source.new_risk_score = newRiskScore; - const rule = buildRuleWithOverrides(completeRule, doc._source!); - const expected = { - ...expectedRule(), - risk_score: newRiskScore, - risk_score_mapping: completeRule.ruleParams.riskScoreMapping, - meta: { - riskScoreOverridden: true, - someMeta: 'someField', - }, - }; - expect(rule).toEqual(expected); - }); - - test('it applies severity override in buildRule', () => { - const eventSeverity = '42'; - completeRule.ruleParams.severityMapping = [ - { - field: 'event.severity', - value: eventSeverity, - operator: 'equals', - severity: 'critical', - }, - ]; - const doc = sampleDocSeverity(Number(eventSeverity)); - const rule = buildRuleWithOverrides(completeRule, doc._source!); - const expected = { - ...expectedRule(), - severity: 'critical', - severity_mapping: completeRule.ruleParams.severityMapping, - meta: { - severityOverrideField: 'event.severity', - someMeta: 'someField', - }, - }; - expect(rule).toEqual(expected); - }); -}); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.ts deleted file mode 100644 index ab40ce330370c..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_rule.ts +++ /dev/null @@ -1,91 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { RulesSchema } from '../../../../common/detection_engine/schemas/response/rules_schema'; -import { buildRiskScoreFromMapping } from './mappings/build_risk_score_from_mapping'; -import { SignalSource } from './types'; -import { buildSeverityFromMapping } from './mappings/build_severity_from_mapping'; -import { buildRuleNameFromMapping } from './mappings/build_rule_name_from_mapping'; -import { CompleteRule, RuleParams } from '../schemas/rule_schemas'; -import { commonParamsCamelToSnake, typeSpecificCamelToSnake } from '../schemas/rule_converters'; -import { transformTags } from '../routes/rules/utils'; -import { transformAlertToRuleAction } from '../../../../common/detection_engine/transform_actions'; - -export const buildRuleWithoutOverrides = (completeRule: CompleteRule): RulesSchema => { - const ruleParams = completeRule.ruleParams; - const { - actions, - schedule, - name, - tags, - enabled, - createdBy, - updatedBy, - throttle, - createdAt, - updatedAt, - } = completeRule.ruleConfig; - return { - actions: actions.map(transformAlertToRuleAction), - created_at: createdAt.toISOString(), - created_by: createdBy ?? '', - enabled, - id: completeRule.alertId, - interval: schedule.interval, - name, - tags: transformTags(tags), - throttle: throttle ?? undefined, - updated_at: updatedAt.toISOString(), - updated_by: updatedBy ?? '', - ...commonParamsCamelToSnake(ruleParams), - ...typeSpecificCamelToSnake(ruleParams), - }; -}; - -export const buildRuleWithOverrides = ( - completeRule: CompleteRule, - eventSource: SignalSource -): RulesSchema => { - const ruleWithoutOverrides = buildRuleWithoutOverrides(completeRule); - return applyRuleOverrides(ruleWithoutOverrides, eventSource, completeRule.ruleParams); -}; - -export const applyRuleOverrides = ( - rule: RulesSchema, - eventSource: SignalSource, - ruleParams: RuleParams -): RulesSchema => { - const { riskScore, riskScoreMeta } = buildRiskScoreFromMapping({ - eventSource, - riskScore: ruleParams.riskScore, - riskScoreMapping: ruleParams.riskScoreMapping, - }); - - const { severity, severityMeta } = buildSeverityFromMapping({ - eventSource, - severity: ruleParams.severity, - severityMapping: ruleParams.severityMapping, - }); - - const { ruleName, ruleNameMeta } = buildRuleNameFromMapping({ - eventSource, - ruleName: rule.name, - ruleNameMapping: ruleParams.ruleNameOverride, - }); - - const meta = { ...ruleParams.meta, ...riskScoreMeta, ...severityMeta, ...ruleNameMeta }; - return { - ...rule, - risk_score: riskScore, - risk_score_mapping: ruleParams.riskScoreMapping ?? [], - severity, - severity_mapping: ruleParams.severityMapping ?? [], - name: ruleName, - rule_name_override: ruleParams.ruleNameOverride, - meta: Object.keys(meta).length > 0 ? meta : undefined, - }; -}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.test.ts deleted file mode 100644 index e06e8a5cdcf76..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.test.ts +++ /dev/null @@ -1,376 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { sampleDocNoSortId } from './__mocks__/es_results'; -import { - buildSignal, - buildParent, - buildAncestors, - additionalSignalFields, - removeClashes, -} from './build_signal'; -import { Signal, Ancestor, BaseSignalHit } from './types'; -import { - getRulesSchemaMock, - ANCHOR_DATE, -} from '../../../../common/detection_engine/schemas/response/rules_schema.mocks'; -import { getListArrayMock } from '../../../../common/detection_engine/schemas/types/lists.mock'; -import { SIGNALS_TEMPLATE_VERSION } from '../routes/index/get_signals_template'; - -describe('buildSignal', () => { - beforeEach(() => { - jest.clearAllMocks(); - }); - - test('it builds a signal as expected without original_event if event does not exist', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - delete doc._source.event; - const rule = getRulesSchemaMock(); - const reason = 'signal reasonable reason'; - - const signal = { - ...buildSignal([doc], rule, reason), - ...additionalSignalFields(doc), - }; - const expected: Signal = { - _meta: { - version: SIGNALS_TEMPLATE_VERSION, - }, - parent: { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - parents: [ - { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - ancestors: [ - { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - original_time: '2020-04-20T21:27:45.000Z', - reason: 'signal reasonable reason', - status: 'open', - rule: { - author: [], - id: '7a7065d7-6e8b-4aae-8d20-c93613dec9f9', - created_at: new Date(ANCHOR_DATE).toISOString(), - updated_at: new Date(ANCHOR_DATE).toISOString(), - created_by: 'elastic', - description: 'some description', - enabled: true, - false_positives: ['false positive 1', 'false positive 2'], - from: 'now-6m', - immutable: false, - name: 'Query with a rule id', - query: 'user.name: root or user.name: admin', - references: ['test 1', 'test 2'], - severity: 'high', - severity_mapping: [], - updated_by: 'elastic_kibana', - tags: ['some fake tag 1', 'some fake tag 2'], - to: 'now', - type: 'query', - threat: [], - version: 1, - output_index: '.siem-signals-default', - max_signals: 100, - risk_score: 55, - risk_score_mapping: [], - language: 'kuery', - rule_id: 'query-rule-id', - interval: '5m', - exceptions_list: getListArrayMock(), - }, - depth: 1, - }; - expect(signal).toEqual(expected); - }); - - test('it builds a signal as expected with original_event if is present', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - doc._source.event = { - action: 'socket_opened', - dataset: 'socket', - kind: 'event', - module: 'system', - }; - const rule = getRulesSchemaMock(); - const reason = 'signal reasonable reason'; - const signal = { - ...buildSignal([doc], rule, reason), - ...additionalSignalFields(doc), - }; - const expected: Signal = { - _meta: { - version: SIGNALS_TEMPLATE_VERSION, - }, - parent: { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - parents: [ - { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - ancestors: [ - { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - original_time: '2020-04-20T21:27:45.000Z', - reason: 'signal reasonable reason', - original_event: { - action: 'socket_opened', - dataset: 'socket', - kind: 'event', - module: 'system', - }, - status: 'open', - rule: { - author: [], - id: '7a7065d7-6e8b-4aae-8d20-c93613dec9f9', - created_at: new Date(ANCHOR_DATE).toISOString(), - updated_at: new Date(ANCHOR_DATE).toISOString(), - created_by: 'elastic', - description: 'some description', - enabled: true, - false_positives: ['false positive 1', 'false positive 2'], - from: 'now-6m', - immutable: false, - name: 'Query with a rule id', - query: 'user.name: root or user.name: admin', - references: ['test 1', 'test 2'], - severity: 'high', - severity_mapping: [], - updated_by: 'elastic_kibana', - tags: ['some fake tag 1', 'some fake tag 2'], - to: 'now', - type: 'query', - threat: [], - version: 1, - output_index: '.siem-signals-default', - max_signals: 100, - risk_score: 55, - risk_score_mapping: [], - language: 'kuery', - rule_id: 'query-rule-id', - interval: '5m', - exceptions_list: getListArrayMock(), - }, - depth: 1, - }; - expect(signal).toEqual(expected); - }); - - test('it builds a ancestor correctly if the parent does not exist', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - doc._source.event = { - action: 'socket_opened', - dataset: 'socket', - kind: 'event', - module: 'system', - }; - const signal = buildParent(doc); - const expected: Ancestor = { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }; - expect(signal).toEqual(expected); - }); - - test('it builds a ancestor correctly if the parent does exist', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - doc._source.event = { - action: 'socket_opened', - dataset: 'socket', - kind: 'event', - module: 'system', - }; - doc._source.signal = { - parents: [ - { - id: '730ddf9e-5a00-4f85-9ddf-5878ca511a87', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - ancestors: [ - { - id: '730ddf9e-5a00-4f85-9ddf-5878ca511a87', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - depth: 1, - rule: { - id: '98c0bf9e-4d38-46f4-9a6a-8a820426256b', - }, - }; - const signal = buildParent(doc); - const expected: Ancestor = { - rule: '98c0bf9e-4d38-46f4-9a6a-8a820426256b', - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'signal', - index: 'myFakeSignalIndex', - depth: 1, - }; - expect(signal).toEqual(expected); - }); - - test('it builds a signal ancestor correctly if the parent does not exist', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - doc._source.event = { - action: 'socket_opened', - dataset: 'socket', - kind: 'event', - module: 'system', - }; - const signal = buildAncestors(doc); - const expected: Ancestor[] = [ - { - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ]; - expect(signal).toEqual(expected); - }); - - test('it builds a signal ancestor correctly if the parent does exist', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - doc._source.event = { - action: 'socket_opened', - dataset: 'socket', - kind: 'event', - module: 'system', - }; - doc._source.signal = { - parents: [ - { - id: '730ddf9e-5a00-4f85-9ddf-5878ca511a87', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - ancestors: [ - { - id: '730ddf9e-5a00-4f85-9ddf-5878ca511a87', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - ], - rule: { - id: '98c0bf9e-4d38-46f4-9a6a-8a820426256b', - }, - depth: 1, - }; - const signal = buildAncestors(doc); - const expected: Ancestor[] = [ - { - id: '730ddf9e-5a00-4f85-9ddf-5878ca511a87', - type: 'event', - index: 'myFakeSignalIndex', - depth: 0, - }, - { - rule: '98c0bf9e-4d38-46f4-9a6a-8a820426256b', - id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', - type: 'signal', - index: 'myFakeSignalIndex', - depth: 1, - }, - ]; - expect(signal).toEqual(expected); - }); - - describe('removeClashes', () => { - test('it will call renameClashes with a regular doc and not mutate it if it does not have a signal clash', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - const output = removeClashes(doc); - expect(output).toBe(doc); // reference check - }); - - test('it will call renameClashes with a regular doc and not change anything', () => { - const doc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - const output = removeClashes(doc); - expect(output).toEqual(doc); // deep equal check - }); - - test('it will remove a "signal" numeric clash', () => { - const sampleDoc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - const doc = { - ...sampleDoc, - _source: { - ...sampleDoc._source, - signal: 127, - }, - } as unknown as BaseSignalHit; - const output = removeClashes(doc); - expect(output).toEqual(sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71')); - }); - - test('it will remove a "signal" object clash', () => { - const sampleDoc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - const doc = { - ...sampleDoc, - _source: { - ...sampleDoc._source, - signal: { child_1: { child_2: 'Test nesting' } }, - }, - } as unknown as BaseSignalHit; - const output = removeClashes(doc); - expect(output).toEqual(sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71')); - }); - - test('it will not remove a "signal" if that is signal is one of our signals', () => { - const sampleDoc = sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'); - const doc = { - ...sampleDoc, - _source: { - ...sampleDoc._source, - signal: { rule: { id: '123' } }, - }, - } as unknown as BaseSignalHit; - const output = removeClashes(doc); - const expected = { - ...sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71'), - _source: { - ...sampleDocNoSortId('d5e8eb51-a6a0-456d-8a15-4b79bfec3d71')._source, - signal: { rule: { id: '123' } }, - }, - }; - expect(output).toEqual(expected); - }); - }); -}); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.ts deleted file mode 100644 index 5e26466557217..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_signal.ts +++ /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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { SearchTypes } from '../../../../common/detection_engine/types'; -import { RulesSchema } from '../../../../common/detection_engine/schemas/response/rules_schema'; -import { SIGNALS_TEMPLATE_VERSION } from '../routes/index/get_signals_template'; -import { isEventTypeSignal } from './build_event_type_signal'; -import { Signal, Ancestor, BaseSignalHit, ThresholdResult, SimpleHit } from './types'; -import { getValidDateFromDoc } from './utils'; - -/** - * Takes a parent signal or event document and extracts the information needed for the corresponding entry in the child - * signal's `signal.parents` array. - * @param doc The parent signal or event - */ -export const buildParent = (doc: BaseSignalHit): Ancestor => { - if (doc._source?.signal != null) { - return { - rule: doc._source?.signal.rule.id, - id: doc._id, - type: 'signal', - index: doc._index, - // We first look for signal.depth and use that if it exists. If it doesn't exist, this should be a pre-7.10 signal - // and should have signal.parent.depth instead. signal.parent.depth in this case is treated as equivalent to signal.depth. - depth: doc._source?.signal.depth ?? doc._source?.signal.parent?.depth ?? 1, - }; - } else { - return { - id: doc._id, - type: 'event', - index: doc._index, - depth: 0, - }; - } -}; - -/** - * Takes a parent signal or event document with N ancestors and adds the parent document to the ancestry array, - * creating an array of N+1 ancestors. - * @param doc The parent signal/event for which to extend the ancestry. - */ -export const buildAncestors = (doc: BaseSignalHit): Ancestor[] => { - const newAncestor = buildParent(doc); - const existingAncestors = doc._source?.signal?.ancestors; - if (existingAncestors != null) { - return [...existingAncestors, newAncestor]; - } else { - return [newAncestor]; - } -}; - -/** - * This removes any signal named clashes such as if a source index has - * "signal" but is not a signal object we put onto the object. If this - * is our "signal object" then we don't want to remove it. - * @param doc The source index doc to a signal. - */ -export const removeClashes = (doc: BaseSignalHit): BaseSignalHit => { - // @ts-expect-error @elastic/elasticsearch _source is optional - const { signal, ...noSignal } = doc._source; - if (signal == null || isEventTypeSignal(doc as SimpleHit)) { - return doc; - } else { - return { - ...doc, - _source: { ...noSignal }, - }; - } -}; - -/** - * Builds the `signal.*` fields that are common across all signals. - * @param docs The parent signals/events of the new signal to be built. - * @param rule The rule that is generating the new signal. - */ -export const buildSignal = (docs: BaseSignalHit[], rule: RulesSchema, reason: string): Signal => { - const _meta = { - version: SIGNALS_TEMPLATE_VERSION, - }; - const removedClashes = docs.map(removeClashes); - const parents = removedClashes.map(buildParent); - const depth = parents.reduce((acc, parent) => Math.max(parent.depth, acc), 0) + 1; - const ancestors = removedClashes.reduce( - (acc: Ancestor[], doc) => acc.concat(buildAncestors(doc)), - [] - ); - return { - _meta, - parents, - ancestors, - status: 'open', - rule, - reason, - depth, - }; -}; - -const isThresholdResult = (thresholdResult: SearchTypes): thresholdResult is ThresholdResult => { - return typeof thresholdResult === 'object'; -}; - -/** - * Creates signal fields that are only available in the special case where a signal has only 1 parent signal/event. - * We copy the original time from the document as "original_time" since we override the timestamp with the current date time. - * @param doc The parent signal/event of the new signal to be built. - */ -export const additionalSignalFields = (doc: BaseSignalHit) => { - const thresholdResult = doc._source?.threshold_result; - if (thresholdResult != null && !isThresholdResult(thresholdResult)) { - throw new Error(`threshold_result failed to validate: ${thresholdResult}`); - } - const originalTime = getValidDateFromDoc({ - doc, - timestampOverride: undefined, - }); - return { - parent: buildParent(removeClashes(doc)), - original_time: originalTime != null ? originalTime.toISOString() : undefined, - original_event: doc._source?.event ?? undefined, - threshold_result: thresholdResult, - original_signal: - doc._source?.signal != null && !isEventTypeSignal(doc as SimpleHit) - ? doc._source?.signal - : undefined, - }; -}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_factory.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_factory.ts deleted file mode 100644 index a8334cf0a4396..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_factory.ts +++ /dev/null @@ -1,107 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { performance } from 'perf_hooks'; -import { countBy, isEmpty, get } from 'lodash'; - -import { ElasticsearchClient, Logger } from 'kibana/server'; -import { BuildRuleMessage } from './rule_messages'; -import { RefreshTypes } from '../types'; -import { BaseHit } from '../../../../common/detection_engine/types'; -import { errorAggregator, makeFloatString } from './utils'; -import { withSecuritySpan } from '../../../utils/with_security_span'; - -export interface GenericBulkCreateResponse { - success: boolean; - bulkCreateDuration: string; - createdItemsCount: number; - createdItems: Array; - errors: string[]; -} - -export const bulkCreateFactory = - ( - logger: Logger, - esClient: ElasticsearchClient, - buildRuleMessage: BuildRuleMessage, - refreshForBulkCreate: RefreshTypes, - indexNameOverride?: string - ) => - async (wrappedDocs: Array>): Promise> => { - if (wrappedDocs.length === 0) { - return { - errors: [], - success: true, - bulkCreateDuration: '0', - createdItemsCount: 0, - createdItems: [], - }; - } - - const bulkBody = wrappedDocs.flatMap((wrappedDoc) => [ - { - create: { - _index: indexNameOverride ?? wrappedDoc._index, - _id: wrappedDoc._id, - }, - }, - wrappedDoc._source, - ]); - const start = performance.now(); - - const response = await withSecuritySpan('writeAlertsBulk', () => - esClient.bulk({ - refresh: refreshForBulkCreate, - body: bulkBody, - }) - ); - - const end = performance.now(); - logger.debug( - buildRuleMessage( - `individual bulk process time took: ${makeFloatString(end - start)} milliseconds` - ) - ); - logger.debug(buildRuleMessage(`took property says bulk took: ${response.took} milliseconds`)); - const createdItems = wrappedDocs - .map((doc, index) => ({ - _id: response.items[index].create?._id ?? '', - _index: response.items[index].create?._index ?? '', - ...doc._source, - })) - .filter((_, index) => get(response.items[index], 'create.status') === 201); - const createdItemsCount = createdItems.length; - const duplicateSignalsCount = countBy(response.items, 'create.status')['409']; - const errorCountByMessage = errorAggregator(response, [409]); - - logger.debug(buildRuleMessage(`bulk created ${createdItemsCount} signals`)); - if (duplicateSignalsCount > 0) { - logger.debug(buildRuleMessage(`ignored ${duplicateSignalsCount} duplicate signals`)); - } - if (!isEmpty(errorCountByMessage)) { - logger.error( - buildRuleMessage( - `[-] bulkResponse had errors with responses of: ${JSON.stringify(errorCountByMessage)}` - ) - ); - return { - errors: Object.keys(errorCountByMessage), - success: false, - bulkCreateDuration: makeFloatString(end - start), - createdItemsCount, - createdItems, - }; - } else { - return { - errors: [], - success: true, - bulkCreateDuration: makeFloatString(end - start), - createdItemsCount, - createdItems, - }; - } - }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts index 2453e92dc3c0a..a757e178ea48a 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts @@ -14,7 +14,7 @@ import { AlertInstanceState, AlertServices, } from '../../../../../alerting/server'; -import { GenericBulkCreateResponse } from './bulk_create_factory'; +import { GenericBulkCreateResponse } from '../rule_types/factories'; import { AnomalyResults, Anomaly } from '../../machine_learning'; import { BuildRuleMessage } from './rule_messages'; import { BulkCreate, WrapHits } from './types'; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/query.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/query.ts index 120bf2c2ebfce..5f1ab1c2dd5ff 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/query.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/query.ts @@ -84,7 +84,6 @@ export const queryExecutor = async ({ eventsTelemetry, id: completeRule.alertId, inputIndexPattern: inputIndex, - signalsIndex: ruleParams.outputIndex, filter: esFilter, pageSize: searchAfterSize, buildReasonMessage: buildReasonMessageForQueryAlert, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/get_filter.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/get_filter.ts index f849900ec75e1..f113e84c88ba8 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/get_filter.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/get_filter.ts @@ -21,8 +21,8 @@ import { AlertServices, } from '../../../../../alerting/server'; import { PartialFilter } from '../types'; -import { QueryFilter } from './types'; import { withSecuritySpan } from '../../../utils/with_security_span'; +import { ESBoolQuery } from '../../../../common/typed_json'; interface GetFilterArgs { type: Type; @@ -53,7 +53,7 @@ export const getFilter = async ({ type, query, lists, -}: GetFilterArgs): Promise => { +}: GetFilterArgs): Promise => { const queryFilter = () => { if (query != null && language != null && index != null) { return getQueryFilter(query, language, filters || [], index, lists); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts index 7d22d58efdd6f..52d0a04eee1ec 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts @@ -15,7 +15,6 @@ import { sampleDocWithSortId, } from './__mocks__/es_results'; import { searchAfterAndBulkCreate } from './search_after_bulk_create'; -import { DEFAULT_SIGNALS_INDEX } from '../../../../common/constants'; import { alertsMock, AlertServicesMock } from '../../../../../alerting/server/mocks'; import uuid from 'uuid'; import { listMock } from '../../../../../lists/server/mocks'; @@ -27,17 +26,19 @@ import { getRuleRangeTuples } from './utils'; // eslint-disable-next-line @kbn/eslint/no-restricted-paths import { elasticsearchClientMock } from 'src/core/server/elasticsearch/client/mocks'; import { getCompleteRuleMock, getQueryRuleParams } from '../schemas/rule_schemas.mock'; -import { bulkCreateFactory } from './bulk_create_factory'; -import { wrapHitsFactory } from './wrap_hits_factory'; +import { bulkCreateFactory } from '../rule_types/factories/bulk_create_factory'; +import { wrapHitsFactory } from '../rule_types/factories/wrap_hits_factory'; import { mockBuildRuleMessage } from './__mocks__/build_rule_message.mock'; -import { errors as esErrors } from '@elastic/elasticsearch'; import { BuildReasonMessage } from './reason_formatters'; import { QueryRuleParams } from '../schemas/rule_schemas'; +import { createPersistenceServicesMock } from '../../../../../rule_registry/server/utils/create_persistence_rule_type_wrapper.mock'; +import { PersistenceServices } from '../../../../../rule_registry/server'; const buildRuleMessage = mockBuildRuleMessage; describe('searchAfterAndBulkCreate', () => { let mockService: AlertServicesMock; + let mockPersistenceServices: jest.Mocked; let buildReasonMessage: BuildReasonMessage; let bulkCreate: BulkCreate; let wrapHits: WrapHits; @@ -46,6 +47,9 @@ describe('searchAfterAndBulkCreate', () => { const someGuids = Array.from({ length: 13 }).map(() => uuid.v4()); const sampleParams = getQueryRuleParams(); const queryCompleteRule = getCompleteRuleMock(sampleParams); + const defaultFilter = { + match_all: {}, + }; sampleParams.maxSignals = 30; let tuple: RuleRangeTuple; beforeEach(() => { @@ -65,17 +69,18 @@ describe('searchAfterAndBulkCreate', () => { maxSignals: sampleParams.maxSignals, buildRuleMessage, }).tuples[0]; + mockPersistenceServices = createPersistenceServicesMock(); bulkCreate = bulkCreateFactory( mockLogger, - mockService.scopedClusterClient.asCurrentUser, + mockPersistenceServices.alertWithPersistence, buildRuleMessage, false ); wrapHits = wrapHitsFactory({ completeRule: queryCompleteRule, - signalsIndex: DEFAULT_SIGNALS_INDEX, mergeStrategy: 'missingFields', ignoreFields: [], + spaceId: 'default', }); }); @@ -86,17 +91,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -105,17 +102,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -124,17 +113,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -143,17 +124,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -185,9 +158,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -205,17 +177,9 @@ describe('searchAfterAndBulkCreate', () => { repeatedSearchResultsWithSortId(4, 1, someGuids.slice(0, 3)) ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -224,17 +188,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -243,17 +199,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -284,9 +232,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -305,35 +252,14 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [ + { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, ], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -364,9 +290,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -424,9 +349,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -439,39 +363,14 @@ describe('searchAfterAndBulkCreate', () => { }); test('should return success when empty string sortId present', async () => { - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - create: { - _id: someGuids[0], - _index: 'myfakeindex', - status: 201, - }, - }, - { - create: { - _id: someGuids[1], - _index: 'myfakeindex', - status: 201, - }, - }, - { - create: { - _id: someGuids[2], - _index: 'myfakeindex', - status: 201, - }, - }, - { - create: { - _id: someGuids[3], - _index: 'myfakeindex', - status: 201, - }, - }, + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [ + { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, ], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search .mockResolvedValueOnce( @@ -502,9 +401,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -558,9 +456,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -579,35 +476,14 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [ + { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, ], + errors: {}, }); const exceptionItem = getExceptionListItemSchemaMock(); @@ -632,9 +508,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -653,35 +528,14 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [ + { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, + { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, ], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -708,9 +562,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -722,58 +575,6 @@ describe('searchAfterAndBulkCreate', () => { expect(lastLookBackDate).toEqual(new Date('2020-04-20T21:27:45+0000')); }); - test('if unsuccessful first bulk create', async () => { - const exceptionItem = getExceptionListItemSchemaMock(); - exceptionItem.entries = [ - { - field: 'source.ip', - operator: 'included', - type: 'list', - list: { - id: 'ci-badguys.txt', - type: 'ip', - }, - }, - ]; - mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( - elasticsearchClientMock.createSuccessTransportRequestPromise( - repeatedSearchResultsWithSortId(4, 1, someGuids.slice(0, 3)) - ) - ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockReturnValue( - elasticsearchClientMock.createErrorTransportRequestPromise( - new esErrors.ResponseError( - elasticsearchClientMock.createApiResponse({ - statusCode: 400, - body: { error: { type: 'bulk_error_type' } }, - }) - ) - ) - ); - const { success, createdSignalsCount, lastLookBackDate } = await searchAfterAndBulkCreate({ - listClient, - exceptionsList: [exceptionItem], - tuple, - completeRule: queryCompleteRule, - services: mockService, - logger: mockLogger, - eventsTelemetry: undefined, - id: sampleRuleGuid, - inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, - pageSize: 1, - filter: undefined, - buildReasonMessage, - buildRuleMessage, - bulkCreate, - wrapHits, - }); - expect(mockLogger.error).toHaveBeenCalled(); - expect(success).toEqual(false); - expect(createdSignalsCount).toEqual(0); - expect(lastLookBackDate).toEqual(new Date('2020-04-20T21:27:45+0000')); - }); - test('should return success with 0 total hits', async () => { const exceptionItem = getExceptionListItemSchemaMock(); exceptionItem.entries = [ @@ -808,9 +609,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -855,9 +655,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -895,6 +694,16 @@ describe('searchAfterAndBulkCreate', () => { ) ); + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: { + 'error on creation': { + count: 1, + statusCode: 500, + }, + }, + }); + mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce(bulkItem); // adds the response with errors we are testing mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -903,17 +712,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -922,17 +723,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -941,17 +734,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -970,9 +755,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, @@ -992,17 +776,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -1011,17 +787,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -1030,17 +798,9 @@ describe('searchAfterAndBulkCreate', () => { ) ); - mockService.scopedClusterClient.asCurrentUser.bulk.mockResponseOnce({ - took: 100, - errors: false, - items: [ - { - // @ts-expect-error not full response interface - create: { - status: 201, - }, - }, - ], + mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ + createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + errors: {}, }); mockService.scopedClusterClient.asCurrentUser.search.mockResolvedValueOnce( @@ -1061,9 +821,8 @@ describe('searchAfterAndBulkCreate', () => { eventsTelemetry: undefined, id: sampleRuleGuid, inputIndexPattern, - signalsIndex: DEFAULT_SIGNALS_INDEX, pageSize: 1, - filter: undefined, + filter: defaultFilter, buildReasonMessage, buildRuleMessage, bulkCreate, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.ts index 99230627cb6b8..69c001898b217 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.ts @@ -76,7 +76,6 @@ export const searchAfterAndBulkCreate = async ({ to: tuple.to.toISOString(), services, logger, - // @ts-expect-error please, declare a type explicitly instead of unknown filter, pageSize: Math.ceil(Math.min(tuple.maxSignals, pageSize)), timestampOverride: ruleParams.timestampOverride, @@ -165,7 +164,7 @@ export const searchAfterAndBulkCreate = async ({ success: bulkSuccess, createdSignalsCount: createdCount, createdSignals: createdItems, - bulkCreateTimes: bulkDuration ? [bulkDuration] : undefined, + bulkCreateTimes: [bulkDuration], errors: bulkErrors, }), ]); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts index faa14bcbab309..c5d86c9ab460c 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_event_signal.ts @@ -135,7 +135,6 @@ export const createEventSignal = async ({ logger, pageSize: searchAfterSize, services, - signalsIndex: outputIndex, sortOrder: 'desc', trackTotalHits: false, tuple, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signal.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signal.ts index 220bebbaa4d21..a07de583d8bab 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signal.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threat_mapping/create_threat_signal.ts @@ -86,7 +86,6 @@ export const createThreatSignal = async ({ logger, pageSize: searchAfterSize, services, - signalsIndex: outputIndex, sortOrder: 'desc', trackTotalHits: false, tuple, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.test.ts index 2c14e4bed62a8..4f68be017ad67 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.test.ts @@ -5,10 +5,8 @@ * 2.0. */ -import { loggingSystemMock } from '../../../../../../../../src/core/server/mocks'; import { ThresholdNormalized } from '../../../../../common/detection_engine/schemas/common/schemas'; import { sampleDocSearchResultsNoSortId } from '../__mocks__/es_results'; -import { sampleThresholdSignalHistory } from '../__mocks__/threshold_signal_history.mock'; import { calculateThresholdSignalUuid } from '../utils'; import { transformThresholdResultsToEcs } from './bulk_create_threshold_signals'; @@ -60,12 +58,8 @@ describe('transformThresholdNormalizedResultsToEcs', () => { 'test', startedAt, from, - undefined, - loggingSystemMock.createLogger(), threshold, - '1234', - undefined, - sampleThresholdSignalHistory() + '1234' ); const _id = calculateThresholdSignalUuid( '1234', @@ -158,12 +152,8 @@ describe('transformThresholdNormalizedResultsToEcs', () => { 'test', startedAt, from, - undefined, - loggingSystemMock.createLogger(), threshold, - '1234', - undefined, - sampleThresholdSignalHistory() + '1234' ); expect(transformedResults).toEqual({ took: 10, @@ -226,12 +216,8 @@ describe('transformThresholdNormalizedResultsToEcs', () => { 'test', startedAt, from, - undefined, - loggingSystemMock.createLogger(), threshold, - '1234', - undefined, - sampleThresholdSignalHistory() + '1234' ); const _id = calculateThresholdSignalUuid('1234', startedAt, [], ''); expect(transformedResults).toEqual({ diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts index f098f33b2ffc7..2148d4feacdae 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts @@ -9,10 +9,7 @@ import { TIMESTAMP } from '@kbn/rule-data-utils'; import { get } from 'lodash/fp'; import set from 'set-value'; -import { - ThresholdNormalized, - TimestampOverrideOrUndefined, -} from '../../../../../common/detection_engine/schemas/common/schemas'; +import { ThresholdNormalized } from '../../../../../common/detection_engine/schemas/common/schemas'; import { Logger } from '../../../../../../../../src/core/server'; import { AlertInstanceContext, @@ -21,7 +18,7 @@ import { } from '../../../../../../alerting/server'; import { BaseHit } from '../../../../../common/detection_engine/types'; import { TermAggregationBucket } from '../../../types'; -import { GenericBulkCreateResponse } from '../bulk_create_factory'; +import { GenericBulkCreateResponse } from '../../rule_types/factories/bulk_create_factory'; import { calculateThresholdSignalUuid, getThresholdAggregationParts } from '../utils'; import { buildReasonMessageForThresholdAlert } from '../reason_formatters'; import type { @@ -54,12 +51,8 @@ const getTransformedHits = ( inputIndex: string, startedAt: Date, from: Date, - logger: Logger, threshold: ThresholdNormalized, - ruleId: string, - filter: unknown, - timestampOverride: TimestampOverrideOrUndefined, - signalHistory: ThresholdSignalHistory + ruleId: string ) => { if (results.aggregations == null) { return []; @@ -184,24 +177,16 @@ export const transformThresholdResultsToEcs = ( inputIndex: string, startedAt: Date, from: Date, - filter: unknown, - logger: Logger, threshold: ThresholdNormalized, - ruleId: string, - timestampOverride: TimestampOverrideOrUndefined, - signalHistory: ThresholdSignalHistory + ruleId: string ): SignalSearchResponse => { const transformedHits = getTransformedHits( results, inputIndex, startedAt, from, - logger, threshold, - ruleId, - filter, - timestampOverride, - signalHistory + ruleId ); const thresholdResults = { ...results, @@ -228,12 +213,8 @@ export const bulkCreateThresholdSignals = async ( params.inputIndexPattern.join(','), params.startedAt, params.from, - params.filter, - params.logger, ruleParams.threshold, - ruleParams.ruleId, - ruleParams.timestampOverride, - params.signalHistory + ruleParams.ruleId ); return params.bulkCreate( diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts index a5803dc354040..44154a8727f38 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts @@ -6,7 +6,6 @@ */ import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; -import { BoolQuery } from '@kbn/es-query'; import moment from 'moment'; import type { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; import { Status } from '../../../../common/detection_engine/schemas/common/schemas'; @@ -31,7 +30,7 @@ import { Logger } from '../../../../../../../src/core/server'; import { BuildRuleMessage } from './rule_messages'; import { ITelemetryEventsSender } from '../../telemetry/sender'; import { CompleteRule, RuleParams } from '../schemas/rule_schemas'; -import { GenericBulkCreateResponse } from './bulk_create_factory'; +import { GenericBulkCreateResponse } from '../rule_types/factories'; import { EcsFieldMap } from '../../../../../rule_registry/common/assets/field_maps/ecs_field_map'; import { TypeOfFieldMap } from '../../../../../rule_registry/common/field_map'; import { BuildReasonMessage } from './reason_formatters'; @@ -275,13 +274,6 @@ export interface AlertAttributes { export type BulkResponseErrorAggregation = Record; -/** - * TODO: Remove this if/when the return filter has its own type exposed - */ -export interface QueryFilter { - bool: BoolQuery; -} - export type SignalsEnrichment = (signals: SignalSearchResponse) => Promise; export type BulkCreate = >( @@ -314,9 +306,8 @@ export interface SearchAfterAndBulkCreateParams { eventsTelemetry: ITelemetryEventsSender | undefined; id: string; inputIndexPattern: string[]; - signalsIndex: string; pageSize: number; - filter: unknown; + filter: estypes.QueryDslQueryContainer; buildRuleMessage: BuildRuleMessage; buildReasonMessage: BuildReasonMessage; enrichment?: SignalsEnrichment; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_hits_factory.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_hits_factory.ts deleted file mode 100644 index 22af4dcdb9f4a..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_hits_factory.ts +++ /dev/null @@ -1,37 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { WrapHits, WrappedSignalHit } from './types'; -import { generateId } from './utils'; -import { buildBulkBody } from './build_bulk_body'; -import { filterDuplicateSignals } from './filter_duplicate_signals'; -import type { ConfigType } from '../../../config'; -import { CompleteRule, RuleParams } from '../schemas/rule_schemas'; - -export const wrapHitsFactory = - ({ - completeRule, - signalsIndex, - mergeStrategy, - ignoreFields, - }: { - completeRule: CompleteRule; - signalsIndex: string; - mergeStrategy: ConfigType['alertMergeStrategy']; - ignoreFields: ConfigType['alertIgnoreFields']; - }): WrapHits => - (events, buildReasonMessage) => { - const wrappedDocs: WrappedSignalHit[] = events.flatMap((doc) => [ - { - _index: signalsIndex, - _id: generateId(doc._index, doc._id, String(doc._version), completeRule.alertId ?? ''), - _source: buildBulkBody(completeRule, doc, mergeStrategy, ignoreFields, buildReasonMessage), - }, - ]); - - return filterDuplicateSignals(completeRule.alertId, wrappedDocs, false); - }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_sequences_factory.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_sequences_factory.ts deleted file mode 100644 index 3b93ae824849a..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/wrap_sequences_factory.ts +++ /dev/null @@ -1,39 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { WrappedSignalHit, WrapSequences } from './types'; -import { buildSignalGroupFromSequence } from './build_bulk_body'; -import { ConfigType } from '../../../config'; -import { CompleteRule, RuleParams } from '../schemas/rule_schemas'; - -export const wrapSequencesFactory = - ({ - completeRule, - signalsIndex, - mergeStrategy, - ignoreFields, - }: { - completeRule: CompleteRule; - signalsIndex: string; - mergeStrategy: ConfigType['alertMergeStrategy']; - ignoreFields: ConfigType['alertIgnoreFields']; - }): WrapSequences => - (sequences, buildReasonMessage) => - sequences.reduce( - (acc: WrappedSignalHit[], sequence) => [ - ...acc, - ...buildSignalGroupFromSequence( - sequence, - completeRule, - signalsIndex, - mergeStrategy, - ignoreFields, - buildReasonMessage - ), - ], - [] - ); From f4ed8e118f2200b56519f44461bc964e4c83be84 Mon Sep 17 00:00:00 2001 From: James Gowdy Date: Tue, 29 Mar 2022 17:06:09 +0100 Subject: [PATCH 100/160] [ML] Testing trained models in UI (#128359) * [ML] Testing trained models in UI * folder rename * code clean up * translations * adding comments * endpoint comments * small changes based on review * removing testing text * refactoring to remove duplicate code * changing misc entities * probably is now 3 sig figs * class refactor * another refactor * fixing enitiy highlighting * adding infer timeout * show class name for known types * refactoring highlighting * moving unknown entity type * removing default badge tooltips * fixing linting error * small import changes Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../plugins/ml/common/types/trained_models.ts | 22 +-- .../services/ml_api_service/index.ts | 2 + .../services/ml_api_service/trained_models.ts | 21 +++ .../models_management/models_list.tsx | 21 +++ .../models_management/test_models/index.ts | 9 + .../test_models/inference_error.tsx | 30 ++++ .../test_models/models/inference_base.ts | 30 ++++ .../models/inference_input_form.tsx | 131 ++++++++++++++ .../test_models/models/lang_ident/index.ts | 10 ++ .../models/lang_ident/lang_codes.ts | 124 +++++++++++++ .../models/lang_ident/lang_ident_inference.ts | 68 +++++++ .../models/lang_ident/lang_ident_output.tsx | 86 +++++++++ .../test_models/models/ner/index.ts | 10 ++ .../test_models/models/ner/ner_inference.ts | 59 +++++++ .../test_models/models/ner/ner_output.tsx | 167 ++++++++++++++++++ .../test_models/output_loading.tsx | 17 ++ .../test_models/selected_model.tsx | 51 ++++++ .../test_models/test_flyout.tsx | 46 +++++ .../models_management/test_models/utils.ts | 18 ++ .../ml/server/lib/ml_client/ml_client.ts | 4 + x-pack/plugins/ml/server/routes/apidoc.json | 2 + .../server/routes/schemas/inference_schema.ts | 16 ++ .../ml/server/routes/trained_models.ts | 77 ++++++++ 23 files changed, 1007 insertions(+), 14 deletions(-) create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/index.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/inference_error.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_base.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_input_form.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/index.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_codes.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_inference.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_output.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/index.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_inference.ts create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_output.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/output_loading.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/selected_model.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/test_flyout.tsx create mode 100644 x-pack/plugins/ml/public/application/trained_models/models_management/test_models/utils.ts diff --git a/x-pack/plugins/ml/common/types/trained_models.ts b/x-pack/plugins/ml/common/types/trained_models.ts index ad59b7a917c49..182cf277d93cc 100644 --- a/x-pack/plugins/ml/common/types/trained_models.ts +++ b/x-pack/plugins/ml/common/types/trained_models.ts @@ -4,7 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ - +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import type { DataFrameAnalyticsConfig } from './data_frame_analytics'; import type { FeatureImportanceBaseline, TotalFeatureImportance } from './feature_importance'; import type { XOR } from './common'; @@ -87,14 +87,12 @@ export type PutTrainedModelConfig = { } >; // compressed_definition and definition are mutually exclusive -export interface TrainedModelConfigResponse { - description?: string; - created_by: string; - create_time: string; - default_field_map: Record; - estimated_heap_memory_usage_bytes: number; - estimated_operations: number; - license_level: string; +export type TrainedModelConfigResponse = estypes.MlTrainedModelConfig & { + /** + * Associated pipelines. Extends response from the ES endpoint. + */ + pipelines?: Record | null; + metadata?: { analytics_config: DataFrameAnalyticsConfig; input: unknown; @@ -107,11 +105,7 @@ export interface TrainedModelConfigResponse { tags: string[]; version: string; inference_config?: Record; - /** - * Associated pipelines. Extends response from the ES endpoint. - */ - pipelines?: Record | null; -} +}; export interface PipelineDefinition { processors?: Array>; diff --git a/x-pack/plugins/ml/public/application/services/ml_api_service/index.ts b/x-pack/plugins/ml/public/application/services/ml_api_service/index.ts index 40187f70f1680..87f1a8eec2478 100644 --- a/x-pack/plugins/ml/public/application/services/ml_api_service/index.ts +++ b/x-pack/plugins/ml/public/application/services/ml_api_service/index.ts @@ -17,6 +17,7 @@ import { resultsApiProvider } from './results'; import { jobsApiProvider } from './jobs'; import { fileDatavisualizer } from './datavisualizer'; import { savedObjectsApiProvider } from './saved_objects'; +import { trainedModelsApiProvider } from './trained_models'; import type { MlServerDefaults, MlServerLimits, @@ -719,5 +720,6 @@ export function mlApiServicesProvider(httpService: HttpService) { jobs: jobsApiProvider(httpService), fileDatavisualizer, savedObjects: savedObjectsApiProvider(httpService), + trainedModels: trainedModelsApiProvider(httpService), }; } diff --git a/x-pack/plugins/ml/public/application/services/ml_api_service/trained_models.ts b/x-pack/plugins/ml/public/application/services/ml_api_service/trained_models.ts index 97027b86a88e1..738f5e1ace74a 100644 --- a/x-pack/plugins/ml/public/application/services/ml_api_service/trained_models.ts +++ b/x-pack/plugins/ml/public/application/services/ml_api_service/trained_models.ts @@ -5,6 +5,8 @@ * 2.0. */ +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; + import { useMemo } from 'react'; import { HttpFetchQuery } from 'kibana/public'; import { HttpService } from '../http_service'; @@ -138,6 +140,25 @@ export function trainedModelsApiProvider(httpService: HttpService) { query: { force }, }); }, + + inferTrainedModel(modelId: string, payload: any, timeout?: string) { + const body = JSON.stringify(payload); + return httpService.http({ + path: `${apiBasePath}/trained_models/infer/${modelId}`, + method: 'POST', + body, + ...(timeout ? { query: { timeout } as HttpFetchQuery } : {}), + }); + }, + + ingestPipelineSimulate(payload: estypes.IngestSimulateRequest['body']) { + const body = JSON.stringify(payload); + return httpService.http({ + path: `${apiBasePath}/trained_models/ingest_pipeline_simulate`, + method: 'POST', + body, + }); + }, }; } diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/models_list.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/models_list.tsx index bd3e3638e8310..1604e265b1617 100644 --- a/x-pack/plugins/ml/public/application/trained_models/models_management/models_list.tsx +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/models_list.tsx @@ -53,6 +53,7 @@ import { DEPLOYMENT_STATE, TRAINED_MODEL_TYPE } from '../../../../common/constan import { getUserConfirmationProvider } from './force_stop_dialog'; import { MLSavedObjectsSpacesList } from '../../components/ml_saved_objects_spaces_list'; import { SavedObjectsWarning } from '../../components/saved_objects_warning'; +import { TestTrainedModelFlyout, isTestable } from './test_models'; type Stats = Omit; @@ -134,6 +135,7 @@ export const ModelsList: FC = ({ const [itemIdToExpandedRowMap, setItemIdToExpandedRowMap] = useState>( {} ); + const [showTestFlyout, setShowTestFlyout] = useState(null); const getUserConfirmation = useMemo(() => getUserConfirmationProvider(overlays, theme), []); const navigateToPath = useNavigateToPath(); @@ -470,6 +472,19 @@ export const ModelsList: FC = ({ return !isPopulatedObject(item.pipelines); }, }, + { + name: i18n.translate('xpack.ml.inference.modelsList.testModelActionLabel', { + defaultMessage: 'Test model', + }), + description: i18n.translate('xpack.ml.inference.modelsList.testModelActionLabel', { + defaultMessage: 'Test model', + }), + icon: 'inputOutput', + type: 'icon', + isPrimary: true, + available: isTestable, + onClick: setShowTestFlyout, + }, ] as Array>) ); } @@ -769,6 +784,12 @@ export const ModelsList: FC = ({ modelIds={modelIdsToDelete} /> )} + {showTestFlyout === null ? null : ( + + )} ); }; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/index.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/index.ts new file mode 100644 index 0000000000000..da7c12c1c0c58 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/index.ts @@ -0,0 +1,9 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export { TestTrainedModelFlyout } from './test_flyout'; +export { isTestable } from './utils'; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/inference_error.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/inference_error.tsx new file mode 100644 index 0000000000000..dc7ae508ab270 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/inference_error.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { FC } from 'react'; +import { i18n } from '@kbn/i18n'; +import { EuiCallOut } from '@elastic/eui'; + +interface Props { + errorText: string | null; +} + +export const ErrorMessage: FC = ({ errorText }) => { + return errorText === null ? null : ( + <> + +

{errorText}

+
+ + ); +}; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_base.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_base.ts new file mode 100644 index 0000000000000..777ca2d314c4d --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_base.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; + +import { trainedModelsApiProvider } from '../../../../services/ml_api_service/trained_models'; + +const DEFAULT_INPUT_FIELD = 'text_field'; + +export type FormattedNerResp = Array<{ + value: string; + entity: estypes.MlTrainedModelEntities | null; +}>; + +export abstract class InferenceBase { + protected readonly inputField: string; + + constructor( + protected trainedModelsApi: ReturnType, + protected model: estypes.MlTrainedModelConfig + ) { + this.inputField = model.input?.field_names[0] ?? DEFAULT_INPUT_FIELD; + } + + protected abstract infer(inputText: string): Promise; +} diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_input_form.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_input_form.tsx new file mode 100644 index 0000000000000..6503486d98211 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/inference_input_form.tsx @@ -0,0 +1,131 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { FC, useState } from 'react'; + +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { EuiSpacer, EuiTextArea, EuiButton, EuiTabs, EuiTab } from '@elastic/eui'; + +import { LangIdentInference } from './lang_ident/lang_ident_inference'; +import { NerInference } from './ner/ner_inference'; +import type { FormattedLangIdentResp } from './lang_ident/lang_ident_inference'; +import type { FormattedNerResp } from './ner/ner_inference'; + +import { MLJobEditor } from '../../../../jobs/jobs_list/components/ml_job_editor'; +import { extractErrorMessage } from '../../../../../../common/util/errors'; +import { ErrorMessage } from '../inference_error'; +import { OutputLoadingContent } from '../output_loading'; + +interface Props { + inferrer: LangIdentInference | NerInference; + getOutputComponent(output: any): JSX.Element; +} + +enum TAB { + TEXT, + RAW, +} + +export const InferenceInputForm: FC = ({ inferrer, getOutputComponent }) => { + const [inputText, setInputText] = useState(''); + const [isRunning, setIsRunning] = useState(false); + const [output, setOutput] = useState(null); + const [rawOutput, setRawOutput] = useState(null); + const [selectedTab, setSelectedTab] = useState(TAB.TEXT); + const [showOutput, setShowOutput] = useState(false); + const [errorText, setErrorText] = useState(null); + + async function run() { + setShowOutput(true); + setOutput(null); + setRawOutput(null); + setIsRunning(true); + setErrorText(null); + try { + const { response, rawResponse } = await inferrer.infer(inputText); + setOutput(response); + setRawOutput(JSON.stringify(rawResponse, null, 2)); + } catch (e) { + setIsRunning(false); + setOutput(null); + setErrorText(extractErrorMessage(e)); + setRawOutput(JSON.stringify(e.body ?? e, null, 2)); + } + setIsRunning(false); + } + + return ( + <> + { + setInputText(e.target.value); + }} + /> + +
+ + + +
+ {showOutput === true ? ( + <> + + + + + + + + + + + + + {selectedTab === TAB.TEXT ? ( + <> + {errorText !== null ? ( + + ) : output === null ? ( + + ) : ( + <>{getOutputComponent(output)} + )} + + ) : ( + + )} + + ) : null} + + ); +}; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/index.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/index.ts new file mode 100644 index 0000000000000..b3439d90e8828 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/index.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export type { FormattedLangIdentResp } from './lang_ident_inference'; +export { LangIdentInference } from './lang_ident_inference'; +export { LangIdentOutput } from './lang_ident_output'; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_codes.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_codes.ts new file mode 100644 index 0000000000000..eff2fdcdd94e7 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_codes.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +const langCodes: Record = { + af: 'Afrikaans', + hr: 'Croatian', + pa: 'Punjabi', + am: 'Amharic', + ht: 'Haitian', + pl: 'Polish', + ar: 'Arabic', + hu: 'Hungarian', + ps: 'Pashto', + az: 'Azerbaijani', + hy: 'Armenian', + pt: 'Portuguese', + be: 'Belarusian', + id: 'Indonesian', + ro: 'Romanian', + bg: 'Bulgarian', + ig: 'Igbo', + ru: 'Russian', + 'bg-Latn': 'Bulgarian', + is: 'Icelandic', + 'ru-Latn': 'Russian', + bn: 'Bengali', + it: 'Italian', + sd: 'Sindhi', + bs: 'Bosnian', + iw: 'Hebrew', + si: 'Sinhala', + ca: 'Catalan', + ja: 'Japanese', + sk: 'Slovak', + ceb: 'Cebuano', + 'ja-Latn': 'Japanese', + sl: 'Slovenian', + co: 'Corsican', + jv: 'Javanese', + sm: 'Samoan', + cs: 'Czech', + ka: 'Georgian', + sn: 'Shona', + cy: 'Welsh', + kk: 'Kazakh', + so: 'Somali', + da: 'Danish', + km: 'Central Khmer', + sq: 'Albanian', + de: 'German', + kn: 'Kannada', + sr: 'Serbian', + el: 'Greek,modern', + ko: 'Korean', + st: 'Southern Sotho', + 'el-Latn': 'Greek,modern', + ku: 'Kurdish', + su: 'Sundanese', + en: 'English', + ky: 'Kirghiz', + sv: 'Swedish', + eo: 'Esperanto', + la: 'Latin', + sw: 'Swahili', + es: 'Spanish,Castilian', + lb: 'Luxembourgish', + ta: 'Tamil', + et: 'Estonian', + lo: 'Lao', + te: 'Telugu', + eu: 'Basque', + lt: 'Lithuanian', + tg: 'Tajik', + fa: 'Persian', + lv: 'Latvian', + th: 'Thai', + fi: 'Finnish', + mg: 'Malagasy', + tr: 'Turkish', + fil: 'Filipino', + mi: 'Maori', + uk: 'Ukrainian', + fr: 'French', + mk: 'Macedonian', + ur: 'Urdu', + fy: 'Western Frisian', + ml: 'Malayalam', + uz: 'Uzbek', + ga: 'Irish', + mn: 'Mongolian', + vi: 'Vietnamese', + gd: 'Gaelic', + mr: 'Marathi', + xh: 'Xhosa', + gl: 'Galician', + ms: 'Malay', + yi: 'Yiddish', + gu: 'Gujarati', + mt: 'Maltese', + yo: 'Yoruba', + ha: 'Hausa', + my: 'Burmese', + zh: 'Chinese', + haw: 'Hawaiian', + ne: 'Nepali', + 'zh-Latn': 'Chinese', + hi: 'Hindi', + nl: 'Dutch,Flemish', + zu: 'Zulu', + 'hi-Latn': 'Hindi', + no: 'Norwegian', + hmn: 'Hmong', + ny: 'Chichewa', + + zxx: 'unknown', +}; + +export function getLanguage(code: string) { + return langCodes[code] ?? 'unknown'; +} diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_inference.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_inference.ts new file mode 100644 index 0000000000000..9108a59197617 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_inference.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; + +import { InferenceBase } from '../inference_base'; + +export type FormattedLangIdentResp = Array<{ + className: string; + classProbability: number; + classScore: number; +}>; + +interface InferResponse { + response: FormattedLangIdentResp; + rawResponse: estypes.IngestSimulateResponse; +} + +export class LangIdentInference extends InferenceBase { + public async infer(inputText: string) { + const payload: estypes.IngestSimulateRequest['body'] = { + pipeline: { + processors: [ + { + inference: { + model_id: this.model.model_id, + inference_config: { + // @ts-expect-error classification missing from type + classification: { + num_top_classes: 3, + }, + }, + field_mappings: { + contents: this.inputField, + }, + target_field: '_ml.lang_ident', + }, + }, + ], + }, + docs: [ + { + _source: { + contents: inputText, + }, + }, + ], + }; + const resp = await this.trainedModelsApi.ingestPipelineSimulate(payload); + if (resp.docs.length) { + const topClasses = resp.docs[0].doc?._source._ml?.lang_ident?.top_classes ?? []; + + return { + response: topClasses.map((t: any) => ({ + className: t.class_name, + classProbability: t.class_probability, + classScore: t.class_score, + })), + rawResponse: resp, + }; + } + return { response: [], rawResponse: resp }; + } +} diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_output.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_output.tsx new file mode 100644 index 0000000000000..e4968bc516f83 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/lang_ident/lang_ident_output.tsx @@ -0,0 +1,86 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { FC } from 'react'; +import { i18n } from '@kbn/i18n'; +import { EuiSpacer, EuiBasicTable, EuiTitle } from '@elastic/eui'; + +import type { FormattedLangIdentResp } from './lang_ident_inference'; +import { getLanguage } from './lang_codes'; + +const PROBABILITY_SIG_FIGS = 3; + +export const LangIdentOutput: FC<{ result: FormattedLangIdentResp }> = ({ result }) => { + if (result.length === 0) { + return null; + } + + const lang = getLanguage(result[0].className); + + const items = result.map(({ className, classProbability }, i) => { + return { + noa: `${i + 1}`, + className: getLanguage(className), + classProbability: `${Number(classProbability).toPrecision(PROBABILITY_SIG_FIGS)}`, + }; + }); + + const columns = [ + { + field: 'noa', + name: '#', + width: '5%', + truncateText: false, + isExpander: false, + }, + { + field: 'className', + name: i18n.translate( + 'xpack.ml.trainedModels.testModelsFlyout.langIdent.output.language_title', + { + defaultMessage: 'Language', + } + ), + width: '30%', + truncateText: false, + isExpander: false, + }, + { + field: 'classProbability', + name: i18n.translate( + 'xpack.ml.trainedModels.testModelsFlyout.langIdent.output.probability_title', + { + defaultMessage: 'Probability', + } + ), + truncateText: false, + isExpander: false, + }, + ]; + + const title = + lang !== 'unknown' + ? i18n.translate('xpack.ml.trainedModels.testModelsFlyout.langIdent.output.title', { + defaultMessage: 'This looks like {lang}', + values: { lang }, + }) + : i18n.translate('xpack.ml.trainedModels.testModelsFlyout.langIdent.output.titleUnknown', { + defaultMessage: 'Language code unknown: {code}', + values: { code: result[0].className }, + }); + + return ( + <> + +

{title}

+
+ + + + + ); +}; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/index.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/index.ts new file mode 100644 index 0000000000000..38ddad8bdeb80 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/index.ts @@ -0,0 +1,10 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +export type { FormattedNerResp } from './ner_inference'; +export { NerInference } from './ner_inference'; +export { NerOutput } from './ner_output'; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_inference.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_inference.ts new file mode 100644 index 0000000000000..e4dcfcc2c6333 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_inference.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; + +import { InferenceBase } from '../inference_base'; + +export type FormattedNerResp = Array<{ + value: string; + entity: estypes.MlTrainedModelEntities | null; +}>; + +interface InferResponse { + response: FormattedNerResp; + rawResponse: estypes.MlInferTrainedModelDeploymentResponse; +} + +export class NerInference extends InferenceBase { + public async infer(inputText: string) { + const payload = { docs: { [this.inputField]: inputText } }; + const resp = await this.trainedModelsApi.inferTrainedModel(this.model.model_id, payload, '30s'); + + return { response: parseResponse(resp), rawResponse: resp }; + } +} + +function parseResponse(resp: estypes.MlInferTrainedModelDeploymentResponse): FormattedNerResp { + const { predicted_value: predictedValue, entities } = resp; + const splitWordsAndEntitiesRegex = /(\[.*?\]\(.*?&.*?\))/; + const matchEntityRegex = /(\[.*?\])\((.*?)&(.*?)\)/; + if (predictedValue === undefined || entities === undefined) { + return []; + } + + const sentenceChunks = (predictedValue as unknown as string).split(splitWordsAndEntitiesRegex); + let count = 0; + return sentenceChunks.map((chunk) => { + const matchedEntity = chunk.match(matchEntityRegex); + if (matchedEntity) { + const entityValue = matchedEntity[3]; + const entity = entities[count]; + if (entityValue !== entity.entity && entityValue.replaceAll('+', ' ') !== entity.entity) { + // entityValue may not equal entity.entity if the entity is comprised of + // two words as they are joined with a plus symbol + // Replace any plus symbols and check again. If they still don't match, log an error + + // eslint-disable-next-line no-console + console.error('mismatch entity', entity); + } + count++; + return { value: entity.entity, entity }; + } + return { value: chunk, entity: null }; + }); +} diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_output.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_output.tsx new file mode 100644 index 0000000000000..e9db3fa8efd36 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/models/ner/ner_output.tsx @@ -0,0 +1,167 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import React, { FC, ReactNode } from 'react'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { + EuiHorizontalRule, + EuiBadge, + EuiToolTip, + EuiFlexGroup, + EuiFlexItem, + EuiIcon, +} from '@elastic/eui'; + +import { + useCurrentEuiTheme, + EuiThemeType, +} from '../../../../../components/color_range_legend/use_color_range'; +import type { FormattedNerResp } from './ner_inference'; + +const ICON_PADDING = '2px'; +const PROBABILITY_SIG_FIGS = 3; + +const ENTITY_TYPES = { + PER: { + label: 'Person', + icon: 'user', + color: 'euiColorVis5_behindText', + borderColor: 'euiColorVis5', + }, + LOC: { + label: 'Location', + icon: 'visMapCoordinate', + color: 'euiColorVis1_behindText', + borderColor: 'euiColorVis1', + }, + ORG: { + label: 'Organization', + icon: 'home', + color: 'euiColorVis0_behindText', + borderColor: 'euiColorVis0', + }, + MISC: { + label: 'Miscellaneous', + icon: 'questionInCircle', + color: 'euiColorVis7_behindText', + borderColor: 'euiColorVis7', + }, +}; + +const UNKNOWN_ENTITY_TYPE = { + label: '', + icon: 'questionInCircle', + color: 'euiColorVis5_behindText', + borderColor: 'euiColorVis5', +}; + +export const NerOutput: FC<{ result: FormattedNerResp }> = ({ result }) => { + const { euiTheme } = useCurrentEuiTheme(); + const lineSplit: JSX.Element[] = []; + result.forEach(({ value, entity }) => { + if (entity === null) { + const lines = value + .split(/(\n)/) + .map((line) => (line === '\n' ?
: {line})); + + lineSplit.push(...lines); + } else { + lineSplit.push( + +
+ + {value} +
+ +
+
+ + : {getClassLabel(entity.class_name)} +
+
+ + : {Number(entity.class_probability).toPrecision(PROBABILITY_SIG_FIGS)} +
+
+
+ } + > + {value} + + ); + } + }); + return
{lineSplit}
; +}; + +const EntityBadge = ({ + entity, + children, +}: { + entity: estypes.MlTrainedModelEntities; + children: ReactNode; +}) => { + const { euiTheme } = useCurrentEuiTheme(); + return ( + + + + + + {children} + + + ); +}; + +function getClassIcon(className: string) { + const entity = ENTITY_TYPES[className as keyof typeof ENTITY_TYPES]; + return entity?.icon ?? UNKNOWN_ENTITY_TYPE.icon; +} + +function getClassLabel(className: string) { + const entity = ENTITY_TYPES[className as keyof typeof ENTITY_TYPES]; + return entity?.label ?? className; +} + +function getClassColor(euiTheme: EuiThemeType, className: string, border: boolean = false) { + const entity = ENTITY_TYPES[className as keyof typeof ENTITY_TYPES]; + let color = entity?.color ?? UNKNOWN_ENTITY_TYPE.color; + if (border) { + color = entity?.borderColor ?? UNKNOWN_ENTITY_TYPE.borderColor; + } + return euiTheme[color as keyof typeof euiTheme]; +} diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/output_loading.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/output_loading.tsx new file mode 100644 index 0000000000000..4cceed23edd25 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/output_loading.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { FC } from 'react'; +import { EuiLoadingContent } from '@elastic/eui'; +import { LineRange } from '@elastic/eui/src/components/loading/loading_content'; + +export const OutputLoadingContent: FC<{ text: string }> = ({ text }) => { + const actualLines = text.split(/\r\n|\r|\n/).length + 1; + const lines = actualLines > 4 && actualLines <= 10 ? actualLines : 4; + + return ; +}; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/selected_model.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/selected_model.tsx new file mode 100644 index 0000000000000..cab0826d5584a --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/selected_model.tsx @@ -0,0 +1,51 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import React, { FC } from 'react'; + +import { NerOutput, NerInference } from './models/ner'; +import type { FormattedNerResp } from './models/ner'; +import { LangIdentOutput, LangIdentInference } from './models/lang_ident'; +import type { FormattedLangIdentResp } from './models/lang_ident'; + +import { TRAINED_MODEL_TYPE } from '../../../../../common/constants/trained_models'; +import { useMlApiContext } from '../../../contexts/kibana'; +import { InferenceInputForm } from './models/inference_input_form'; + +interface Props { + model: estypes.MlTrainedModelConfig | null; +} + +export const SelectedModel: FC = ({ model }) => { + const { trainedModels } = useMlApiContext(); + + if (model === null) { + return null; + } + + if (model.model_type === TRAINED_MODEL_TYPE.PYTORCH) { + const inferrer = new NerInference(trainedModels, model); + return ( + } + /> + ); + } + if (model.model_type === TRAINED_MODEL_TYPE.LANG_IDENT) { + const inferrer = new LangIdentInference(trainedModels, model); + return ( + } + /> + ); + } + + return null; +}; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/test_flyout.tsx b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/test_flyout.tsx new file mode 100644 index 0000000000000..343cd32addce7 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/test_flyout.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import React, { FC } from 'react'; + +import { FormattedMessage } from '@kbn/i18n-react'; +import { EuiFlyout, EuiFlyoutHeader, EuiTitle, EuiFlyoutBody, EuiSpacer } from '@elastic/eui'; + +import { SelectedModel } from './selected_model'; + +interface Props { + model: estypes.MlTrainedModelConfig; + onClose: () => void; +} +export const TestTrainedModelFlyout: FC = ({ model, onClose }) => { + return ( + <> + + + +

+ +

+
+
+ + +

{model.model_id}

+
+ + + + +
+
+ + ); +}; diff --git a/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/utils.ts b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/utils.ts new file mode 100644 index 0000000000000..ccddd960349d2 --- /dev/null +++ b/x-pack/plugins/ml/public/application/trained_models/models_management/test_models/utils.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { TRAINED_MODEL_TYPE } from '../../../../../common/constants/trained_models'; + +const TESTABLE_MODEL_TYPES: estypes.MlTrainedModelType[] = [ + TRAINED_MODEL_TYPE.PYTORCH, + TRAINED_MODEL_TYPE.LANG_IDENT, +]; + +export function isTestable(model: estypes.MlTrainedModelConfig) { + return model.model_type && TESTABLE_MODEL_TYPES.includes(model.model_type); +} diff --git a/x-pack/plugins/ml/server/lib/ml_client/ml_client.ts b/x-pack/plugins/ml/server/lib/ml_client/ml_client.ts index 342a3913a6cba..122162777d9a5 100644 --- a/x-pack/plugins/ml/server/lib/ml_client/ml_client.ts +++ b/x-pack/plugins/ml/server/lib/ml_client/ml_client.ts @@ -494,6 +494,10 @@ export function getMlClient( await modelIdsCheck(p); return mlClient.stopTrainedModelDeployment(...p); }, + async inferTrainedModelDeployment(...p: Parameters) { + await modelIdsCheck(p); + return mlClient.inferTrainedModelDeployment(...p); + }, async info(...p: Parameters) { return mlClient.info(...p); }, diff --git a/x-pack/plugins/ml/server/routes/apidoc.json b/x-pack/plugins/ml/server/routes/apidoc.json index 59ed08664da3b..ac09aee7fcbb9 100644 --- a/x-pack/plugins/ml/server/routes/apidoc.json +++ b/x-pack/plugins/ml/server/routes/apidoc.json @@ -171,6 +171,8 @@ "StopTrainedModelDeployment", "PutTrainedModel", "DeleteTrainedModel", + "InferTrainedModelDeployment", + "IngestPipelineSimulate", "Alerting", "PreviewAlert" diff --git a/x-pack/plugins/ml/server/routes/schemas/inference_schema.ts b/x-pack/plugins/ml/server/routes/schemas/inference_schema.ts index 941edb31c79fa..1b9a865dcfca9 100644 --- a/x-pack/plugins/ml/server/routes/schemas/inference_schema.ts +++ b/x-pack/plugins/ml/server/routes/schemas/inference_schema.ts @@ -30,3 +30,19 @@ export const getInferenceQuerySchema = schema.object({ export const putTrainedModelQuerySchema = schema.object({ defer_definition_decompression: schema.maybe(schema.boolean()), }); + +export const pipelineSchema = schema.object({ + pipeline: schema.object({ + description: schema.maybe(schema.string()), + processors: schema.arrayOf(schema.recordOf(schema.string(), schema.any())), + version: schema.maybe(schema.number()), + on_failure: schema.maybe(schema.arrayOf(schema.recordOf(schema.string(), schema.any()))), + }), + docs: schema.arrayOf(schema.recordOf(schema.string(), schema.any())), + verbose: schema.maybe(schema.boolean()), +}); + +export const inferTrainedModelQuery = schema.object({ timeout: schema.maybe(schema.string()) }); +export const inferTrainedModelBody = schema.object({ + docs: schema.any(), +}); diff --git a/x-pack/plugins/ml/server/routes/trained_models.ts b/x-pack/plugins/ml/server/routes/trained_models.ts index 887ad47f1ceb2..27a062b45767c 100644 --- a/x-pack/plugins/ml/server/routes/trained_models.ts +++ b/x-pack/plugins/ml/server/routes/trained_models.ts @@ -5,6 +5,7 @@ * 2.0. */ +import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import { schema } from '@kbn/config-schema'; import { RouteInitialization } from '../types'; import { wrapError } from '../client/error_wrapper'; @@ -13,6 +14,9 @@ import { modelIdSchema, optionalModelIdSchema, putTrainedModelQuerySchema, + pipelineSchema, + inferTrainedModelQuery, + inferTrainedModelBody, } from './schemas/inference_schema'; import { modelsProvider } from '../models/data_frame_analytics'; import { TrainedModelConfigResponse } from '../../common/types/trained_models'; @@ -352,4 +356,77 @@ export function trainedModelsRoutes({ router, routeGuard }: RouteInitialization) } }) ); + + /** + * @apiGroup TrainedModels + * + * @api {post} /api/ml/trained_models/infer/:modelId Evaluates a trained model + * @apiName InferTrainedModelDeployment + * @apiDescription Evaluates a trained model. + */ + router.post( + { + path: '/api/ml/trained_models/infer/{modelId}', + validate: { + params: modelIdSchema, + query: inferTrainedModelQuery, + body: inferTrainedModelBody, + }, + options: { + tags: ['access:ml:canStartStopTrainedModels'], + }, + }, + routeGuard.fullLicenseAPIGuard(async ({ mlClient, request, response }) => { + try { + const { modelId } = request.params; + const body = await mlClient.inferTrainedModelDeployment({ + model_id: modelId, + docs: request.body.docs, + ...(request.query.timeout ? { timeout: request.query.timeout } : {}), + }); + return response.ok({ + body, + }); + } catch (e) { + return response.customError(wrapError(e)); + } + }) + ); + + /** + * @apiGroup TrainedModels + * + * @api {post} /api/ml/trained_models/ingest_pipeline_simulate Ingest pipeline simulate + * @apiName IngestPipelineSimulate + * @apiDescription Simulates an ingest pipeline call using supplied documents + */ + router.post( + { + path: '/api/ml/trained_models/ingest_pipeline_simulate', + validate: { + body: pipelineSchema, + }, + options: { + tags: ['access:ml:canStartStopTrainedModels'], + }, + }, + routeGuard.fullLicenseAPIGuard(async ({ client, request, response }) => { + try { + const { pipeline, docs, verbose } = request.body; + + const body = await client.asCurrentUser.ingest.simulate({ + verbose, + body: { + pipeline, + docs: docs as estypes.IngestSimulateDocument[], + }, + }); + return response.ok({ + body, + }); + } catch (e) { + return response.customError(wrapError(e)); + } + }) + ); } From 261819208dc9573f544933cf607dde9c98cf33dd Mon Sep 17 00:00:00 2001 From: Stratoula Kalafateli Date: Tue, 29 Mar 2022 19:27:48 +0300 Subject: [PATCH 101/160] [TSVB] fixes steps behavior to happen at the change point (#128741) --- .../timeseries/utils/__snapshots__/series_styles.test.js.snap | 2 +- .../visualizations/views/timeseries/utils/series_styles.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/__snapshots__/series_styles.test.js.snap b/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/__snapshots__/series_styles.test.js.snap index 8f0d602e09c7a..054ca0f0d8193 100644 --- a/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/__snapshots__/series_styles.test.js.snap +++ b/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/__snapshots__/series_styles.test.js.snap @@ -20,7 +20,7 @@ Object { "visible": true, }, }, - "curve": 6, + "curve": 7, } `; diff --git a/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/series_styles.js b/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/series_styles.js index a1e85d17bc5fa..a3076a30f69ed 100644 --- a/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/series_styles.js +++ b/src/plugins/vis_types/timeseries/public/application/visualizations/views/timeseries/utils/series_styles.js @@ -29,7 +29,7 @@ export const getAreaStyles = ({ points, lines, color }) => ({ visible: points.lineWidth > 0 && Boolean(points.show), }, }, - curve: lines.steps ? CurveType.CURVE_STEP : CurveType.LINEAR, + curve: lines.steps ? CurveType.CURVE_STEP_AFTER : CurveType.LINEAR, }); export const getBarStyles = ({ show = true, lineWidth = 0, fill = 1 }, color) => ({ From 0181e5aeb96eeae3f126cfb33d290d49a1142dc6 Mon Sep 17 00:00:00 2001 From: Mark Hopkin Date: Tue, 29 Mar 2022 17:27:55 +0100 Subject: [PATCH 102/160] add link to ilm docs (#128656) --- packages/kbn-doc-links/src/get_doc_links.ts | 1 + packages/kbn-doc-links/src/types.ts | 1 + .../step_define_package_policy.tsx | 28 +++++++++++++++++++ 3 files changed, 30 insertions(+) diff --git a/packages/kbn-doc-links/src/get_doc_links.ts b/packages/kbn-doc-links/src/get_doc_links.ts index c31aaab76e2ad..1d9406ac37447 100644 --- a/packages/kbn-doc-links/src/get_doc_links.ts +++ b/packages/kbn-doc-links/src/get_doc_links.ts @@ -584,6 +584,7 @@ export const getDocLinks = ({ kibanaBranch }: GetDocLinkOptions): DocLinks => { elasticAgent: `${FLEET_DOCS}elastic-agent-installation.html`, beatsAgentComparison: `${FLEET_DOCS}beats-agent-comparison.html`, datastreams: `${FLEET_DOCS}data-streams.html`, + datastreamsILM: `${FLEET_DOCS}data-streams.html#data-streams-ilm`, datastreamsNamingScheme: `${FLEET_DOCS}data-streams.html#data-streams-naming-scheme`, installElasticAgent: `${FLEET_DOCS}install-fleet-managed-elastic-agent.html`, installElasticAgentStandalone: `${FLEET_DOCS}install-standalone-elastic-agent.html`, diff --git a/packages/kbn-doc-links/src/types.ts b/packages/kbn-doc-links/src/types.ts index a5875ce03cf5b..c2e485e1003e6 100644 --- a/packages/kbn-doc-links/src/types.ts +++ b/packages/kbn-doc-links/src/types.ts @@ -345,6 +345,7 @@ export interface DocLinks { troubleshooting: string; elasticAgent: string; datastreams: string; + datastreamsILM: string; datastreamsNamingScheme: string; installElasticAgent: string; installElasticAgentStandalone: string; diff --git a/x-pack/plugins/fleet/public/applications/fleet/sections/agent_policy/create_package_policy_page/step_define_package_policy.tsx b/x-pack/plugins/fleet/public/applications/fleet/sections/agent_policy/create_package_policy_page/step_define_package_policy.tsx index 7fcddf4439557..7f67452e2f230 100644 --- a/x-pack/plugins/fleet/public/applications/fleet/sections/agent_policy/create_package_policy_page/step_define_package_policy.tsx +++ b/x-pack/plugins/fleet/public/applications/fleet/sections/agent_policy/create_package_policy_page/step_define_package_policy.tsx @@ -318,6 +318,34 @@ export const StepDefinePackagePolicy: React.FunctionComponent<{ /> + + + } + helpText={ + + {i18n.translate( + 'xpack.fleet.createPackagePolicy.stepConfigure.packagePolicyDataRetentionLearnMoreLink', + { defaultMessage: 'Learn more' } + )} + + ), + }} + /> + } + > +
+ + {/* Advanced vars */} {advancedVars.map((varDef) => { const { name: varName, type: varType } = varDef; From 7039878471f33ba276e5838914f5f42c1bf816b7 Mon Sep 17 00:00:00 2001 From: Marta Bondyra Date: Tue, 29 Mar 2022 18:30:10 +0200 Subject: [PATCH 103/160] [Lens] Remove unused and duplicated code for XY chart expression (#128716) * [Lens] remove unused and duplicated code * lowering the limits for page bundle --- packages/kbn-optimizer/limits.yml | 2 +- .../public/components/annotations.tsx | 132 +------------ .../public/components/reference_lines.tsx | 178 ++++------------- .../xy_chart_renderer.tsx | 8 +- .../public/helpers/annotations.tsx | 181 ++++++++++++------ 5 files changed, 170 insertions(+), 331 deletions(-) diff --git a/packages/kbn-optimizer/limits.yml b/packages/kbn-optimizer/limits.yml index 25656a3977fea..e137bd0055900 100644 --- a/packages/kbn-optimizer/limits.yml +++ b/packages/kbn-optimizer/limits.yml @@ -124,5 +124,5 @@ pageLoadAssetSize: sessionView: 77750 cloudSecurityPosture: 19109 visTypeGauge: 24113 - expressionXY: 41392 + expressionXY: 26500 eventAnnotation: 19334 diff --git a/src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx b/src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx index 4e8fa1b95775f..e8b99a36664df 100644 --- a/src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/annotations.tsx @@ -18,18 +18,12 @@ import { Position, } from '@elastic/charts'; import moment from 'moment'; -import { EuiFlexGroup, EuiFlexItem, EuiIcon, EuiIconProps, EuiText } from '@elastic/eui'; -import classnames from 'classnames'; +import { EuiFlexGroup, EuiFlexItem } from '@elastic/eui'; import type { EventAnnotationArgs } from '../../../../event_annotation/common'; import type { FieldFormat } from '../../../../field_formats/common'; import { defaultAnnotationColor } from '../../../../../../src/plugins/event_annotation/public'; -import type { - AnnotationLayerArgs, - AnnotationLayerConfigResult, - IconPosition, - YAxisMode, -} from '../../common/types'; -import { annotationsIconSet, hasIcon, isNumericalString } from '../helpers'; +import type { AnnotationLayerArgs, AnnotationLayerConfigResult } from '../../common/types'; +import { AnnotationIcon, hasIcon, Marker, MarkerBody } from '../helpers'; import { mapVerticalToHorizontalPlacement, LINES_MARKER_SIZE } from '../helpers'; const getRoundedTimestamp = (timestamp: number, firstTimestamp?: number, minInterval?: number) => { @@ -235,123 +229,3 @@ export const Annotations = ({ ); }; - -export function MarkerBody({ - label, - isHorizontal, -}: { - label: string | undefined; - isHorizontal: boolean; -}) { - if (!label) { - return null; - } - if (isHorizontal) { - return ( -
- {label} -
- ); - } - return ( -
-
- {label} -
-
- ); -} - -function NumberIcon({ number }: { number: number }) { - return ( - - - {number < 10 ? number : `9+`} - - - ); -} - -export const AnnotationIcon = ({ - type, - rotateClassName = '', - isHorizontal, - renderedInChart, - ...rest -}: { - type: string; - rotateClassName?: string; - isHorizontal?: boolean; - renderedInChart?: boolean; -} & EuiIconProps) => { - if (isNumericalString(type)) { - return ; - } - const iconConfig = annotationsIconSet.find((i) => i.value === type); - if (!iconConfig) { - return null; - } - return ( - - ); -}; - -interface MarkerConfig { - axisMode?: YAxisMode; - icon?: string; - textVisibility?: boolean; - iconPosition?: IconPosition; -} - -export function Marker({ - config, - isHorizontal, - hasReducedPadding, - label, - rotateClassName, -}: { - config: MarkerConfig; - isHorizontal: boolean; - hasReducedPadding: boolean; - label?: string; - rotateClassName?: string; -}) { - if (hasIcon(config.icon)) { - return ( - - ); - } - - // if there's some text, check whether to show it as marker, or just show some padding for the icon - if (config.textVisibility) { - if (hasReducedPadding) { - return ; - } - return ; - } - return null; -} diff --git a/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx index 65bc91c06efe5..d71e56bcef6d0 100644 --- a/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/components/reference_lines.tsx @@ -10,15 +10,17 @@ import './reference_lines.scss'; import React from 'react'; import { groupBy } from 'lodash'; -import { EuiIcon } from '@elastic/eui'; import { RectAnnotation, AnnotationDomainType, LineAnnotation, Position } from '@elastic/charts'; import { euiLightVars } from '@kbn/ui-theme'; import type { FieldFormat } from '../../../../field_formats/common'; import type { IconPosition, ReferenceLineLayerArgs, YAxisMode } from '../../common/types'; import type { LensMultiTable } from '../../common/types'; -import { hasIcon } from '../helpers'; - -export const REFERENCE_LINE_MARKER_SIZE = 20; +import { + LINES_MARKER_SIZE, + mapVerticalToHorizontalPlacement, + Marker, + MarkerBody, +} from '../helpers'; export const computeChartMargins = ( referenceLinePaddings: Partial>, @@ -54,66 +56,24 @@ export const computeChartMargins = ( return result; }; -// Note: it does not take into consideration whether the reference line is in view or not -export const getReferenceLineRequiredPaddings = ( - referenceLineLayers: ReferenceLineLayerArgs[], - axesMap: Record<'left' | 'right', unknown> -) => { - // collect all paddings for the 4 axis: if any text is detected double it. - const paddings: Partial> = {}; - const icons: Partial> = {}; - referenceLineLayers.forEach((layer) => { - layer.yConfig?.forEach(({ axisMode, icon, iconPosition, textVisibility }) => { - if (axisMode && (hasIcon(icon) || textVisibility)) { - const placement = getBaseIconPlacement(iconPosition, axisMode, axesMap); - paddings[placement] = Math.max( - paddings[placement] || 0, - REFERENCE_LINE_MARKER_SIZE * (textVisibility ? 2 : 1) // double the padding size if there's text - ); - icons[placement] = (icons[placement] || 0) + (hasIcon(icon) ? 1 : 0); - } - }); - }); - // post-process the padding based on the icon presence: - // if no icon is present for the placement, just reduce the padding - (Object.keys(paddings) as Position[]).forEach((placement) => { - if (!icons[placement]) { - paddings[placement] = REFERENCE_LINE_MARKER_SIZE; - } - }); - - return paddings; -}; - -function mapVerticalToHorizontalPlacement(placement: Position) { - switch (placement) { - case Position.Top: - return Position.Right; - case Position.Bottom: - return Position.Left; - case Position.Left: - return Position.Bottom; - case Position.Right: - return Position.Top; - } -} - // if there's just one axis, put it on the other one // otherwise use the same axis // this function assume the chart is vertical -function getBaseIconPlacement( +export function getBaseIconPlacement( iconPosition: IconPosition | undefined, - axisMode: YAxisMode | undefined, - axesMap: Record + axesMap?: Record, + axisMode?: YAxisMode ) { if (iconPosition === 'auto') { if (axisMode === 'bottom') { return Position.Top; } - if (axisMode === 'left') { - return axesMap.right ? Position.Left : Position.Right; + if (axesMap) { + if (axisMode === 'left') { + return axesMap.right ? Position.Left : Position.Right; + } + return axesMap.left ? Position.Right : Position.Left; } - return axesMap.left ? Position.Right : Position.Left; } if (iconPosition === 'left') { @@ -128,65 +88,6 @@ function getBaseIconPlacement( return Position.Top; } -function getMarkerBody(label: string | undefined, isHorizontal: boolean) { - if (!label) { - return; - } - if (isHorizontal) { - return ( -
- {label} -
- ); - } - return ( -
-
- {label} -
-
- ); -} - -interface MarkerConfig { - axisMode?: YAxisMode; - icon?: string; - textVisibility?: boolean; -} - -function getMarkerToShow( - markerConfig: MarkerConfig, - label: string | undefined, - isHorizontal: boolean, - hasReducedPadding: boolean -) { - // show an icon if present - if (hasIcon(markerConfig.icon)) { - return ; - } - // if there's some text, check whether to show it as marker, or just show some padding for the icon - if (markerConfig.textVisibility) { - if (hasReducedPadding) { - return getMarkerBody( - label, - (!isHorizontal && markerConfig.axisMode === 'bottom') || - (isHorizontal && markerConfig.axisMode !== 'bottom') - ); - } - return ; - } -} - export interface ReferenceLineAnnotationsProps { layers: ReferenceLineLayerArgs[]; data: LensMultiTable; @@ -243,27 +144,34 @@ export const ReferenceLineAnnotations = ({ // get the position for vertical chart const markerPositionVertical = getBaseIconPlacement( yConfig.iconPosition, - yConfig.axisMode, - axesMap + axesMap, + yConfig.axisMode ); // the padding map is built for vertical chart - const hasReducedPadding = - paddingMap[markerPositionVertical] === REFERENCE_LINE_MARKER_SIZE; + const hasReducedPadding = paddingMap[markerPositionVertical] === LINES_MARKER_SIZE; const props = { groupId, - marker: getMarkerToShow( - yConfig, - columnToLabelMap[yConfig.forAccessor], - isHorizontal, - hasReducedPadding + marker: ( + ), - markerBody: getMarkerBody( - yConfig.textVisibility && !hasReducedPadding - ? columnToLabelMap[yConfig.forAccessor] - : undefined, - (!isHorizontal && yConfig.axisMode === 'bottom') || - (isHorizontal && yConfig.axisMode !== 'bottom') + markerBody: ( + ), // rotate the position if required markerPosition: isHorizontal @@ -272,17 +180,15 @@ export const ReferenceLineAnnotations = ({ }; const annotations = []; - const dashStyle = - yConfig.lineStyle === 'dashed' - ? [(yConfig.lineWidth || 1) * 3, yConfig.lineWidth || 1] - : yConfig.lineStyle === 'dotted' - ? [yConfig.lineWidth || 1, yConfig.lineWidth || 1] - : undefined; - const sharedStyle = { strokeWidth: yConfig.lineWidth || 1, stroke: yConfig.color || defaultColor, - dash: dashStyle, + dash: + yConfig.lineStyle === 'dashed' + ? [(yConfig.lineWidth || 1) * 3, yConfig.lineWidth || 1] + : yConfig.lineStyle === 'dotted' + ? [yConfig.lineWidth || 1, yConfig.lineWidth || 1] + : undefined, }; annotations.push( diff --git a/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx b/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx index 70acc25330b87..5e4921e85af62 100644 --- a/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/expression_renderers/xy_chart_renderer.tsx @@ -11,14 +11,14 @@ import { I18nProvider } from '@kbn/i18n-react'; import { ThemeServiceStart } from 'kibana/public'; import React from 'react'; import ReactDOM from 'react-dom'; -import { ChartsPluginStart, PaletteRegistry } from '../../../../charts/public'; +import type { ChartsPluginStart, PaletteRegistry } from '../../../../charts/public'; import { EventAnnotationServiceType } from '../../../../event_annotation/public'; import { ExpressionRenderDefinition } from '../../../../expressions'; import { FormatFactory } from '../../../../field_formats/common'; import { KibanaThemeProvider } from '../../../../kibana_react/public'; -import { XYChartProps } from '../../common'; -import { calculateMinInterval } from '../helpers'; -import { BrushEvent, FilterEvent } from '../types'; +import type { XYChartProps } from '../../common'; +import { calculateMinInterval } from '../helpers/interval'; +import type { BrushEvent, FilterEvent } from '../types'; export type GetStartDepsFn = () => Promise<{ formatFactory: FormatFactory; diff --git a/src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx b/src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx index 8da38af10f5d9..5035855647147 100644 --- a/src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx +++ b/src/plugins/chart_expressions/expression_xy/public/helpers/annotations.tsx @@ -5,46 +5,17 @@ * in compliance with, at your election, the Elastic License 2.0 or the Server * Side Public License, v 1. */ +import React from 'react'; import { Position } from '@elastic/charts'; +import { EuiFlexGroup, EuiIcon, EuiIconProps, EuiText } from '@elastic/eui'; +import classnames from 'classnames'; import type { IconPosition, YAxisMode, YConfig } from '../../common/types'; +import { getBaseIconPlacement } from '../components'; import { hasIcon } from './icon'; +import { annotationsIconSet } from './annotations_icon_set'; export const LINES_MARKER_SIZE = 20; -export const computeChartMargins = ( - referenceLinePaddings: Partial>, - labelVisibility: Partial>, - titleVisibility: Partial>, - axesMap: Record<'left' | 'right', unknown>, - isHorizontal: boolean -) => { - const result: Partial> = {}; - if (!labelVisibility?.x && !titleVisibility?.x && referenceLinePaddings.bottom) { - const placement = isHorizontal ? mapVerticalToHorizontalPlacement('bottom') : 'bottom'; - result[placement] = referenceLinePaddings.bottom; - } - if ( - referenceLinePaddings.left && - (isHorizontal || (!labelVisibility?.yLeft && !titleVisibility?.yLeft)) - ) { - const placement = isHorizontal ? mapVerticalToHorizontalPlacement('left') : 'left'; - result[placement] = referenceLinePaddings.left; - } - if ( - referenceLinePaddings.right && - (isHorizontal || !axesMap.right || (!labelVisibility?.yRight && !titleVisibility?.yRight)) - ) { - const placement = isHorizontal ? mapVerticalToHorizontalPlacement('right') : 'right'; - result[placement] = referenceLinePaddings.right; - } - // there's no top axis, so just check if a margin has been computed - if (referenceLinePaddings.top) { - const placement = isHorizontal ? mapVerticalToHorizontalPlacement('top') : 'top'; - result[placement] = referenceLinePaddings.top; - } - return result; -}; - // Note: it does not take into consideration whether the reference line is in view or not export const getLinesCausedPaddings = ( @@ -93,36 +64,124 @@ export function mapVerticalToHorizontalPlacement(placement: Position) { } } -// if there's just one axis, put it on the other one -// otherwise use the same axis -// this function assume the chart is vertical -export function getBaseIconPlacement( - iconPosition: IconPosition | undefined, - axesMap?: Record, - axisMode?: YAxisMode -) { - if (iconPosition === 'auto') { - if (axisMode === 'bottom') { - return Position.Top; - } - if (axesMap) { - if (axisMode === 'left') { - return axesMap.right ? Position.Left : Position.Right; - } - return axesMap.left ? Position.Right : Position.Left; - } +export function MarkerBody({ + label, + isHorizontal, +}: { + label: string | undefined; + isHorizontal: boolean; +}) { + if (!label) { + return null; } - - if (iconPosition === 'left') { - return Position.Left; + if (isHorizontal) { + return ( +
+ {label} +
+ ); } - if (iconPosition === 'right') { - return Position.Right; + return ( +
+
+ {label} +
+
+ ); +} + +function NumberIcon({ number }: { number: number }) { + return ( + + + {number < 10 ? number : `9+`} + + + ); +} + +const isNumericalString = (value: string) => !isNaN(Number(value)); + +export const AnnotationIcon = ({ + type, + rotateClassName = '', + isHorizontal, + renderedInChart, + ...rest +}: { + type: string; + rotateClassName?: string; + isHorizontal?: boolean; + renderedInChart?: boolean; +} & EuiIconProps) => { + if (isNumericalString(type)) { + return ; } - if (iconPosition === 'below') { - return Position.Bottom; + const iconConfig = annotationsIconSet.find((i) => i.value === type); + if (!iconConfig) { + return null; } - return Position.Top; + return ( + + ); +}; + +interface MarkerConfig { + axisMode?: YAxisMode; + icon?: string; + textVisibility?: boolean; + iconPosition?: IconPosition; } -export const isNumericalString = (value: string) => !isNaN(Number(value)); +export function Marker({ + config, + isHorizontal, + hasReducedPadding, + label, + rotateClassName, +}: { + config: MarkerConfig; + isHorizontal: boolean; + hasReducedPadding: boolean; + label?: string; + rotateClassName?: string; +}) { + if (hasIcon(config.icon)) { + return ( + + ); + } + + // if there's some text, check whether to show it as marker, or just show some padding for the icon + if (config.textVisibility) { + if (hasReducedPadding) { + return ; + } + return ; + } + return null; +} From c3fba606d26b3c136cab2450aa30747beb00de6a Mon Sep 17 00:00:00 2001 From: Lisa Cawley Date: Tue, 29 Mar 2022 10:07:51 -0700 Subject: [PATCH 104/160] [DOCS] Add get case comments API (#128694) --- docs/api/cases.asciidoc | 4 +- .../cases/cases-api-delete-comments.asciidoc | 6 +- .../api/cases/cases-api-get-comments.asciidoc | 80 +++++++++++++++++++ docs/api/cases/cases-api-update.asciidoc | 3 +- 4 files changed, 86 insertions(+), 7 deletions(-) create mode 100644 docs/api/cases/cases-api-get-comments.asciidoc diff --git a/docs/api/cases.asciidoc b/docs/api/cases.asciidoc index 273f3a0b51cc2..a92951d7d6d1a 100644 --- a/docs/api/cases.asciidoc +++ b/docs/api/cases.asciidoc @@ -13,9 +13,8 @@ these APIs: * {security-guide}/cases-api-find-cases-by-alert.html[Find cases by alert] * <> * {security-guide}/cases-api-get-case-activity.html[Get all case activity] -* {security-guide}/cases-api-get-all-case-comments.html[Get all case comments] * <> -* {security-guide}/cases-api-get-comment.html[Get comment] +* <> * {security-guide}/cases-get-connector.html[Get current connector] * {security-guide}/cases-api-get-reporters.html[Get reporters] * {security-guide}/cases-api-get-status.html[Get status] @@ -36,5 +35,6 @@ include::cases/cases-api-find-cases.asciidoc[leveloffset=+1] include::cases/cases-api-find-connectors.asciidoc[leveloffset=+1] //GET include::cases/cases-api-get-case.asciidoc[leveloffset=+1] +include::cases/cases-api-get-comments.asciidoc[leveloffset=+1] //UPDATE include::cases/cases-api-update.asciidoc[leveloffset=+1] diff --git a/docs/api/cases/cases-api-delete-comments.asciidoc b/docs/api/cases/cases-api-delete-comments.asciidoc index 66421944ac1be..0b02786e6659d 100644 --- a/docs/api/cases/cases-api-delete-comments.asciidoc +++ b/docs/api/cases/cases-api-delete-comments.asciidoc @@ -30,9 +30,9 @@ You must have `all` privileges for the *Cases* feature in the *Management*, <>. ``:: -(Optional, string) The identifier for the comment. -//To retrieve comment IDs, use <>. -If it is not specified, all comments are deleted. +(Optional, string) The identifier for the comment. To retrieve comment IDs, use +<> or <>. If it is not specified, all +comments are deleted. :: (Optional, string) An identifier for the space. If it is not specified, the diff --git a/docs/api/cases/cases-api-get-comments.asciidoc b/docs/api/cases/cases-api-get-comments.asciidoc new file mode 100644 index 0000000000000..6e88b6ffdf004 --- /dev/null +++ b/docs/api/cases/cases-api-get-comments.asciidoc @@ -0,0 +1,80 @@ +[[cases-api-get-comments]] +== Get comments API +++++ +Get comments +++++ + +Gets a comment or all comments for a case. + +=== Request + +`GET :/api/cases//comments/` + +`GET :/s//api/cases//comments/` + +`GET :/api/cases//comments` deprecated:[8.1.0] + +`GET :/s//api/cases//comments` deprecated:[8.1.0] + +=== Prerequisite + +You must have `read` privileges for the *Cases* feature in the *Management*, +*{observability}*, or *Security* section of the +<>, depending on the +`owner` of the cases with the comments you're seeking. + +=== Path parameters + +``:: +(Required, string) The identifier for the case. To retrieve case IDs, use +<>. + +``:: +(Optional, string) The identifier for the comment. To retrieve comment IDs, use +<>. ++ +If it is not specified, all comments are retrieved. +deprecated:[8.1.0,The comment identifier will no longer be optional.] + +``:: +(Optional, string) An identifier for the space. If it is not specified, the +default space is used. + +=== Response code + +`200`:: + Indicates a successful call. + +=== Example + +Retrieves comment ID `71ec1870-725b-11ea-a0b2-c51ea50a58e2` from case ID +`a18b38a0-71b0-11ea-a0b2-c51ea50a58e2`: + +[source,sh] +-------------------------------------------------- +GET api/cases/a18b38a0-71b0-11ea-a0b2-c51ea50a58e2/comments/71ec1870-725b-11ea-a0b2-c51ea50a58e2 +-------------------------------------------------- +// KIBANA + +The API returns the requested comment JSON object. For example: + +[source,json] +-------------------------------------------------- +{ + "id":"8acb3a80-ab0a-11ec-985f-97e55adae8b9", + "version":"Wzc5NzYsM10=", + "comment":"Start operation bubblegum immediately! And chew fast!", + "type":"user", + "owner":"cases", + "created_at":"2022-03-24T00:37:10.832Z", + "created_by": { + "email": "classified@hms.oo.gov.uk", + "full_name": "Classified", + "username": "M" + }, + "pushed_at": null, + "pushed_by": null, + "updated_at": null, + "updated_by": null +} +-------------------------------------------------- \ No newline at end of file diff --git a/docs/api/cases/cases-api-update.asciidoc b/docs/api/cases/cases-api-update.asciidoc index ed0ef069e15f4..522300591d8b7 100644 --- a/docs/api/cases/cases-api-update.asciidoc +++ b/docs/api/cases/cases-api-update.asciidoc @@ -156,8 +156,7 @@ and `open`. (Optional, string) A title for the case. `version`:: -(Required, string) The current version of the case. -//To determine this value, use <> or <> +(Required, string) The current version of the case. To determine this value, use <> or <>. ==== === Response code From da0294cd5a60ea80e0afe13ffd900106288d219e Mon Sep 17 00:00:00 2001 From: James Gowdy Date: Tue, 29 Mar 2022 18:11:40 +0100 Subject: [PATCH 105/160] [ML] Changing ML management page title (#128767) * [ML] Changing ML management page title * updating sync callout text * reverting link id change to fix tests Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../saved_objects_warning/saved_objects_warning.tsx | 4 ++-- x-pack/plugins/ml/public/application/management/index.ts | 2 +- .../jobs_list/components/jobs_list_page/jobs_list_page.tsx | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/x-pack/plugins/ml/public/application/components/saved_objects_warning/saved_objects_warning.tsx b/x-pack/plugins/ml/public/application/components/saved_objects_warning/saved_objects_warning.tsx index ccbf0c1082d0f..9e5123fa275f2 100644 --- a/x-pack/plugins/ml/public/application/components/saved_objects_warning/saved_objects_warning.tsx +++ b/x-pack/plugins/ml/public/application/components/saved_objects_warning/saved_objects_warning.tsx @@ -108,7 +108,7 @@ export const SavedObjectsWarning: FC = ({ ), @@ -117,7 +117,7 @@ export const SavedObjectsWarning: FC = ({ ) : ( )} {showSyncFlyout && } diff --git a/x-pack/plugins/ml/public/application/management/index.ts b/x-pack/plugins/ml/public/application/management/index.ts index 9d6376a668c1d..9dd71f915e03e 100644 --- a/x-pack/plugins/ml/public/application/management/index.ts +++ b/x-pack/plugins/ml/public/application/management/index.ts @@ -22,7 +22,7 @@ export function registerManagementSection( return management.sections.section.insightsAndAlerting.registerApp({ id: 'jobsListLink', title: i18n.translate('xpack.ml.management.jobsListTitle', { - defaultMessage: 'Machine Learning Jobs', + defaultMessage: 'Machine Learning', }), order: 2, async mount(params: ManagementAppMountParams) { diff --git a/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx b/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx index 5620902ee768b..e107e5bfcdfe6 100644 --- a/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx +++ b/x-pack/plugins/ml/public/application/management/jobs_list/components/jobs_list_page/jobs_list_page.tsx @@ -271,13 +271,13 @@ export const JobsListPage: FC<{ pageTitle={ } description={ } rightSideItems={[docsLink]} From 14b0cde1ca04e134c265cff973500aed12e80e93 Mon Sep 17 00:00:00 2001 From: Ashokaditya <1849116+ashokaditya@users.noreply.github.com> Date: Tue, 29 Mar 2022 19:27:59 +0200 Subject: [PATCH 106/160] [Security Solution][Endpoint] Show event filter duplicate fields warning (#128736) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Show warning on duplicate field entries Since conditions are conjuntive (ANDed) it implies having multiple entries of the idential fields with different values would result in an ineffective exception. For instance a (a ^ ¬a) would never be true. fixes elastic/security-team/issues/3199 * typo --- .../view/components/form/index.test.tsx | 62 ++++++++++++++++++- .../view/components/form/index.tsx | 26 ++++++++ 2 files changed, 87 insertions(+), 1 deletion(-) diff --git a/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.test.tsx b/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.test.tsx index b5d9f1fd2cecf..96cdef21244d0 100644 --- a/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.test.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.test.tsx @@ -202,7 +202,7 @@ describe('Event filter form', () => { expect(component.getByTestId('effectedPolicies-select-policiesSelectable')).toBeTruthy(); }); - it('should call onChange when a policy is selected from the policy selectiion', async () => { + it('should call onChange when a policy is selected from the policy selection', async () => { component = await renderWithData(); const policyId = policiesRequest.items[0].id; @@ -274,4 +274,64 @@ describe('Event filter form', () => { expect(component.queryByTestId('effectedPolicies-select-policiesSelectable')).toBeFalsy(); expect(getState().form.entry?.tags).toEqual([`policy:all`]); }); + + it('should not show warning text when unique fields are added', async () => { + component = await renderWithData({ + entries: [ + { + field: 'event.category', + operator: 'included', + type: 'match', + value: 'some value', + }, + { + field: 'file.name', + operator: 'excluded', + type: 'match', + value: 'some other value', + }, + ], + }); + expect(component.queryByTestId('duplicate-fields-warning-message')).toBeNull(); + }); + + it('should not show warning text when field values are not added', async () => { + component = await renderWithData({ + entries: [ + { + field: 'event.category', + operator: 'included', + type: 'match', + value: '', + }, + { + field: 'event.category', + operator: 'excluded', + type: 'match', + value: '', + }, + ], + }); + expect(component.queryByTestId('duplicate-fields-warning-message')).toBeNull(); + }); + + it('should show warning text when duplicate fields are added with values', async () => { + component = await renderWithData({ + entries: [ + { + field: 'event.category', + operator: 'included', + type: 'match', + value: 'some value', + }, + { + field: 'event.category', + operator: 'excluded', + type: 'match', + value: 'some other value', + }, + ], + }); + expect(component.queryByTestId('duplicate-fields-warning-message')).not.toBeNull(); + }); }); diff --git a/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.tsx b/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.tsx index 6d24b9558ea53..027d6e2bacfa6 100644 --- a/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/event_filters/view/components/form/index.tsx @@ -69,6 +69,18 @@ const OPERATING_SYSTEMS: readonly OperatingSystem[] = [ OperatingSystem.LINUX, ]; +const getAddedFieldsCounts = (formFields: string[]): { [k: string]: number } => + formFields.reduce<{ [k: string]: number }>((allFields, field) => { + if (field in allFields) { + allFields[field]++; + } else { + allFields[field] = 1; + } + return allFields; + }, {}); + +const computeHasDuplicateFields = (formFieldsList: Record): boolean => + Object.values(formFieldsList).some((e) => e > 1); interface EventFiltersFormProps { allowSelectOs?: boolean; policies: PolicyData[]; @@ -85,6 +97,7 @@ export const EventFiltersForm: React.FC = memo( const [hasBeenInputNameVisited, setHasBeenInputNameVisited] = useState(false); const isPlatinumPlus = useLicense().isPlatinumPlus(); const [hasFormChanged, setHasFormChanged] = useState(false); + const [hasDuplicateFields, setHasDuplicateFields] = useState(false); // This value has to be memoized to avoid infinite useEffect loop on useFetchIndex const indexNames = useMemo(() => ['logs-endpoint.events.*'], []); @@ -131,6 +144,8 @@ export const EventFiltersForm: React.FC = memo( (!hasFormChanged && arg.exceptionItems[0] === undefined) || isEqual(arg.exceptionItems[0]?.entries, exception?.entries) ) { + const addedFields = arg.exceptionItems[0]?.entries.map((e) => e.field) || ['']; + setHasDuplicateFields(computeHasDuplicateFields(getAddedFieldsCounts(addedFields))); setHasFormChanged(true); return; } @@ -446,6 +461,17 @@ export const EventFiltersForm: React.FC = memo( {detailsSection} {criteriaSection} + {hasDuplicateFields && ( + <> + + + + + + )} {showAssignmentSection && ( <> {policiesSection} From 6c27fb8c2ad52041fbc3a59a35d7f5a7616651b6 Mon Sep 17 00:00:00 2001 From: Christos Nasikas Date: Tue, 29 Mar 2022 20:32:45 +0300 Subject: [PATCH 107/160] [Cases] Add more e2e tests (#128347) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .github/CODEOWNERS | 2 + .../all_cases/all_cases_list.test.tsx | 2 +- .../public/components/all_cases/columns.tsx | 2 +- .../public/components/all_cases/header.tsx | 2 +- .../all_cases/table_filters.test.tsx | 12 +- .../cases/public/components/app/index.tsx | 2 +- .../components/filter_popover/index.tsx | 2 +- .../integration/cases/creation.spec.ts | 4 +- .../cypress/screens/all_cases.ts | 4 +- x-pack/test/functional/services/cases/api.ts | 11 +- .../test/functional/services/cases/common.ts | 142 ++---------- .../test/functional/services/cases/create.ts | 63 ++++++ .../test/functional/services/cases/index.ts | 6 + x-pack/test/functional/services/cases/list.ts | 121 +++++++++++ .../functional/services/cases/navigation.ts | 25 +++ .../apps/cases/configure.ts | 52 +++++ .../apps/cases/create_case_form.ts | 8 +- .../apps/cases/edit_case_form.ts | 169 --------------- .../apps/cases/index.ts | 3 +- .../apps/cases/list_view.ts | 204 ++++++++++++------ .../apps/cases/view_case.ts | 192 +++++++++++++++++ x-pack/test/functional_with_es_ssl/config.ts | 3 + 22 files changed, 655 insertions(+), 376 deletions(-) create mode 100644 x-pack/test/functional/services/cases/create.ts create mode 100644 x-pack/test/functional/services/cases/list.ts create mode 100644 x-pack/test/functional/services/cases/navigation.ts create mode 100644 x-pack/test/functional_with_es_ssl/apps/cases/configure.ts delete mode 100644 x-pack/test/functional_with_es_ssl/apps/cases/edit_case_form.ts create mode 100644 x-pack/test/functional_with_es_ssl/apps/cases/view_case.ts diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 1d4eb2ba39cd5..c89fe8be4a654 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -353,6 +353,8 @@ #CC# /x-pack/plugins/stack_alerts @elastic/response-ops /x-pack/plugins/cases/ @elastic/response-ops /x-pack/test/cases_api_integration/ @elastic/response-ops +/x-pack/test/functional/services/cases/ @elastic/response-ops +/x-pack/test/functional_with_es_ssl/apps/cases/ @elastic/response-ops # Enterprise Search /x-pack/plugins/enterprise_search @elastic/enterprise-search-frontend diff --git a/x-pack/plugins/cases/public/components/all_cases/all_cases_list.test.tsx b/x-pack/plugins/cases/public/components/all_cases/all_cases_list.test.tsx index 43a36188fcf52..88aad5fb64408 100644 --- a/x-pack/plugins/cases/public/components/all_cases/all_cases_list.test.tsx +++ b/x-pack/plugins/cases/public/components/all_cases/all_cases_list.test.tsx @@ -189,7 +189,7 @@ describe('AllCasesListGeneric', () => { useGetCasesMockState.data.cases[0].title ); expect( - wrapper.find(`span[data-test-subj="case-table-column-tags-0"]`).first().prop('title') + wrapper.find(`span[data-test-subj="case-table-column-tags-coke"]`).first().prop('title') ).toEqual(useGetCasesMockState.data.cases[0].tags[0]); expect(wrapper.find(`[data-test-subj="case-table-column-createdBy"]`).first().text()).toEqual( useGetCasesMockState.data.cases[0].createdBy.username diff --git a/x-pack/plugins/cases/public/components/all_cases/columns.tsx b/x-pack/plugins/cases/public/components/all_cases/columns.tsx index f92f1605c4c51..a05673d3e095a 100644 --- a/x-pack/plugins/cases/public/components/all_cases/columns.tsx +++ b/x-pack/plugins/cases/public/components/all_cases/columns.tsx @@ -230,7 +230,7 @@ export const useCasesColumns = ({ {tag} diff --git a/x-pack/plugins/cases/public/components/all_cases/header.tsx b/x-pack/plugins/cases/public/components/all_cases/header.tsx index 19a1a897221e7..4e66083711e2b 100644 --- a/x-pack/plugins/cases/public/components/all_cases/header.tsx +++ b/x-pack/plugins/cases/public/components/all_cases/header.tsx @@ -42,7 +42,7 @@ export const CasesTableHeader: FunctionComponent = ({ refresh, userCanCrud, }) => ( - + {userCanCrud ? ( <> diff --git a/x-pack/plugins/cases/public/components/all_cases/table_filters.test.tsx b/x-pack/plugins/cases/public/components/all_cases/table_filters.test.tsx index 8089c85ee578b..b6dc66e6dee49 100644 --- a/x-pack/plugins/cases/public/components/all_cases/table_filters.test.tsx +++ b/x-pack/plugins/cases/public/components/all_cases/table_filters.test.tsx @@ -64,7 +64,7 @@ describe('CasesTableFilters ', () => { ); wrapper.find(`[data-test-subj="options-filter-popover-button-Tags"]`).last().simulate('click'); - wrapper.find(`[data-test-subj="options-filter-popover-item-0"]`).last().simulate('click'); + wrapper.find(`[data-test-subj="options-filter-popover-item-coke"]`).last().simulate('click'); expect(onFilterChanged).toBeCalledWith({ tags: ['coke'] }); }); @@ -80,7 +80,10 @@ describe('CasesTableFilters ', () => { .last() .simulate('click'); - wrapper.find(`[data-test-subj="options-filter-popover-item-0"]`).last().simulate('click'); + wrapper + .find(`[data-test-subj="options-filter-popover-item-casetester"]`) + .last() + .simulate('click'); expect(onFilterChanged).toBeCalledWith({ reporters: [{ username: 'casetester' }] }); }); @@ -212,7 +215,10 @@ describe('CasesTableFilters ', () => { .last() .simulate('click'); - wrapper.find(`[data-test-subj="options-filter-popover-item-0"]`).last().simulate('click'); + wrapper + .find(`[data-test-subj="options-filter-popover-item-${SECURITY_SOLUTION_OWNER}"]`) + .last() + .simulate('click'); expect(onFilterChanged).toBeCalledWith({ owner: [SECURITY_SOLUTION_OWNER] }); }); diff --git a/x-pack/plugins/cases/public/components/app/index.tsx b/x-pack/plugins/cases/public/components/app/index.tsx index ba2a61ec6691f..c98c40ed9ba78 100644 --- a/x-pack/plugins/cases/public/components/app/index.tsx +++ b/x-pack/plugins/cases/public/components/app/index.tsx @@ -19,7 +19,7 @@ const CasesAppComponent: React.FC = () => { const userCapabilities = useApplicationCapabilities(); return ( - + {getCasesLazy({ owner: [APP_OWNER], useFetchAlertData: () => [false, {}], diff --git a/x-pack/plugins/cases/public/components/filter_popover/index.tsx b/x-pack/plugins/cases/public/components/filter_popover/index.tsx index c28d00b08912a..bd4f665bcd7fd 100644 --- a/x-pack/plugins/cases/public/components/filter_popover/index.tsx +++ b/x-pack/plugins/cases/public/components/filter_popover/index.tsx @@ -91,7 +91,7 @@ export const FilterPopoverComponent = ({ {options.map((option, index) => ( diff --git a/x-pack/plugins/security_solution/cypress/integration/cases/creation.spec.ts b/x-pack/plugins/security_solution/cypress/integration/cases/creation.spec.ts index 32121537aacdd..d13f97d6cd6f3 100644 --- a/x-pack/plugins/security_solution/cypress/integration/cases/creation.spec.ts +++ b/x-pack/plugins/security_solution/cypress/integration/cases/creation.spec.ts @@ -87,8 +87,8 @@ describe('Cases', () => { cy.get(ALL_CASES_TAGS_COUNT).should('have.text', 'Tags2'); cy.get(ALL_CASES_NAME).should('have.text', this.mycase.name); cy.get(ALL_CASES_REPORTER).should('have.text', this.mycase.reporter); - (this.mycase as TestCase).tags.forEach((tag, index) => { - cy.get(ALL_CASES_TAGS(index)).should('have.text', tag); + (this.mycase as TestCase).tags.forEach((tag) => { + cy.get(ALL_CASES_TAGS(tag)).should('have.text', tag); }); cy.get(ALL_CASES_COMMENTS_COUNT).should('have.text', '0'); cy.get(ALL_CASES_OPENED_ON).should('include.text', 'ago'); diff --git a/x-pack/plugins/security_solution/cypress/screens/all_cases.ts b/x-pack/plugins/security_solution/cypress/screens/all_cases.ts index 58b496a651f3b..3f5bcb912ee44 100644 --- a/x-pack/plugins/security_solution/cypress/screens/all_cases.ts +++ b/x-pack/plugins/security_solution/cypress/screens/all_cases.ts @@ -44,8 +44,8 @@ export const ALL_CASES_SERVICE_NOW_INCIDENT = export const ALL_CASES_IN_PROGRESS_STATUS = '[data-test-subj="status-badge-in-progress"]'; -export const ALL_CASES_TAGS = (index: number) => { - return `[data-test-subj="case-table-column-tags-${index}"]`; +export const ALL_CASES_TAGS = (tag: string) => { + return `[data-test-subj="case-table-column-tags-${tag}"]`; }; export const ALL_CASES_TAGS_COUNT = '[data-test-subj="options-filter-popover-button-Tags"]'; diff --git a/x-pack/test/functional/services/cases/api.ts b/x-pack/test/functional/services/cases/api.ts index bacb08cd19b2d..e863504c2add3 100644 --- a/x-pack/test/functional/services/cases/api.ts +++ b/x-pack/test/functional/services/cases/api.ts @@ -7,7 +7,10 @@ import pMap from 'p-map'; import { CasePostRequest } from '../../../../plugins/cases/common/api'; -import { createCase, deleteAllCaseItems } from '../../../cases_api_integration/common/lib/utils'; +import { + createCase as createCaseAPI, + deleteAllCaseItems, +} from '../../../cases_api_integration/common/lib/utils'; import { FtrProviderContext } from '../../ftr_provider_context'; import { generateRandomCaseWithoutConnector } from './helpers'; @@ -16,12 +19,12 @@ export function CasesAPIServiceProvider({ getService }: FtrProviderContext) { const es = getService('es'); return { - async createCaseWithData(overwrites: { title?: string } = {}) { + async createCase(overwrites: Partial = {}) { const caseData = { ...generateRandomCaseWithoutConnector(), ...overwrites, } as CasePostRequest; - await createCase(kbnSupertest, caseData); + await createCaseAPI(kbnSupertest, caseData); }, async createNthRandomCases(amount: number = 3) { @@ -32,7 +35,7 @@ export function CasesAPIServiceProvider({ getService }: FtrProviderContext) { await pMap( cases, (caseData) => { - return createCase(kbnSupertest, caseData); + return createCaseAPI(kbnSupertest, caseData); }, { concurrency: 4 } ); diff --git a/x-pack/test/functional/services/cases/common.ts b/x-pack/test/functional/services/cases/common.ts index ad5fbb7be7233..bf5b8e6e8b0be 100644 --- a/x-pack/test/functional/services/cases/common.ts +++ b/x-pack/test/functional/services/cases/common.ts @@ -6,15 +6,14 @@ */ import expect from '@kbn/expect'; -import { WebElementWrapper } from 'test/functional/services/lib/web_element_wrapper'; -import uuid from 'uuid'; +import { CaseStatuses } from '../../../../plugins/cases/common'; import { FtrProviderContext } from '../../ftr_provider_context'; export function CasesCommonServiceProvider({ getService, getPageObject }: FtrProviderContext) { const testSubjects = getService('testSubjects'); const find = getService('find'); - const comboBox = getService('comboBox'); const header = getPageObject('header'); + return { /** * Opens the create case page pressing the "create case" button. @@ -29,125 +28,11 @@ export function CasesCommonServiceProvider({ getService, getPageObject }: FtrPro }); }, - /** - * it creates a new case from the create case page - * and leaves the navigation in the case view page - * - * Doesn't do navigation. Only works if you are already inside a cases app page. - * Does not work with the cases flyout. - */ - async createCaseFromCreateCasePage({ - title = 'test-' + uuid.v4(), - description = 'desc' + uuid.v4(), - tag = 'tagme', - }: { - title: string; - description: string; - tag: string; - }) { - await this.openCreateCasePage(); - - // case name - await testSubjects.setValue('input', title); - - // case tag - await comboBox.setCustom('comboBoxInput', tag); - - // case description - const descriptionArea = await find.byCssSelector('textarea.euiMarkdownEditorTextArea'); - await descriptionArea.focus(); - await descriptionArea.type(description); - - // save - await testSubjects.click('create-case-submit'); - - await testSubjects.existOrFail('case-view-title'); - }, - - /** - * Goes to the first case listed on the table. - * - * This will fail if the table doesn't have any case - */ - async goToFirstListedCase() { - await testSubjects.existOrFail('cases-table'); - await testSubjects.click('case-details-link'); - await testSubjects.existOrFail('case-view-title'); - }, - - /** - * Marks a case in progress via the status dropdown - */ - async markCaseInProgressViaDropdown() { - await this.openCaseSetStatusDropdown(); - - await testSubjects.click('case-view-status-dropdown-in-progress'); - - // wait for backend response - await testSubjects.existOrFail('header-page-supplements > status-badge-in-progress', { - timeout: 5000, - }); - }, - - /** - * Marks a case closed via the status dropdown - */ - async markCaseClosedViaDropdown() { - this.openCaseSetStatusDropdown(); - - await testSubjects.click('case-view-status-dropdown-closed'); - - // wait for backend response - await testSubjects.existOrFail('header-page-supplements > status-badge-closed', { - timeout: 5000, - }); - }, - - /** - * Marks a case open via the status dropdown - */ - async markCaseOpenViaDropdown() { + async changeCaseStatusViaDropdownAndVerify(status: CaseStatuses) { this.openCaseSetStatusDropdown(); - - await testSubjects.click('case-view-status-dropdown-open'); - - // wait for backend response - await testSubjects.existOrFail('header-page-supplements > status-badge-open', { - timeout: 5000, - }); - }, - - async bulkDeleteAllCases() { - await testSubjects.setCheckbox('checkboxSelectAll', 'check'); - const button = await find.byCssSelector('[aria-label="Bulk actions"]'); - await button.click(); - await testSubjects.click('cases-bulk-delete-button'); - await testSubjects.click('confirmModalConfirmButton'); - }, - - async selectAndDeleteAllCases() { + await testSubjects.click(`case-view-status-dropdown-${status}`); await header.waitUntilLoadingHasFinished(); - await testSubjects.existOrFail('cases-table', { timeout: 20 * 1000 }); - let rows: WebElementWrapper[]; - do { - await header.waitUntilLoadingHasFinished(); - await testSubjects.missingOrFail('cases-table-loading', { timeout: 5000 }); - rows = await find.allByCssSelector('[data-test-subj*="cases-table-row-"', 100); - if (rows.length > 0) { - await this.bulkDeleteAllCases(); - // wait for a second - await new Promise((r) => setTimeout(r, 1000)); - await header.waitUntilLoadingHasFinished(); - } - } while (rows.length > 0); - }, - - async validateCasesTableHasNthRows(nrRows: number) { - await header.waitUntilLoadingHasFinished(); - await testSubjects.existOrFail('cases-table', { timeout: 20 * 1000 }); - await testSubjects.missingOrFail('cases-table-loading', { timeout: 5000 }); - const rows = await find.allByCssSelector('[data-test-subj*="cases-table-row-"', 100); - expect(rows.length).equal(nrRows); + await testSubjects.existOrFail(`status-badge-${status}`); }, async openCaseSetStatusDropdown() { @@ -156,5 +41,22 @@ export function CasesCommonServiceProvider({ getService, getPageObject }: FtrPro ); await button.click(); }, + + async assertRadioGroupValue(testSubject: string, expectedValue: string) { + const assertRadioGroupValue = await testSubjects.find(testSubject); + const input = await assertRadioGroupValue.findByCssSelector(':checked'); + const selectedOptionId = await input.getAttribute('id'); + expect(selectedOptionId).to.eql( + expectedValue, + `Expected the radio group value to equal "${expectedValue}" (got "${selectedOptionId}")` + ); + }, + + async selectRadioGroupValue(testSubject: string, value: string) { + const radioGroup = await testSubjects.find(testSubject); + const label = await radioGroup.findByCssSelector(`label[for="${value}"]`); + await label.click(); + await this.assertRadioGroupValue(testSubject, value); + }, }; } diff --git a/x-pack/test/functional/services/cases/create.ts b/x-pack/test/functional/services/cases/create.ts new file mode 100644 index 0000000000000..f1a54aec75438 --- /dev/null +++ b/x-pack/test/functional/services/cases/create.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import uuid from 'uuid'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +export function CasesCreateViewServiceProvider({ getService, getPageObject }: FtrProviderContext) { + const testSubjects = getService('testSubjects'); + const find = getService('find'); + const comboBox = getService('comboBox'); + + return { + /** + * Opens the create case page pressing the "create case" button. + * + * Doesn't do navigation. Only works if you are already inside a cases app page. + * Does not work with the cases flyout. + */ + async openCreateCasePage() { + await testSubjects.click('createNewCaseBtn'); + await testSubjects.existOrFail('create-case-submit', { + timeout: 5000, + }); + }, + + /** + * it creates a new case from the create case page + * and leaves the navigation in the case view page + * + * Doesn't do navigation. Only works if you are already inside a cases app page. + * Does not work with the cases flyout. + */ + async createCaseFromCreateCasePage({ + title = 'test-' + uuid.v4(), + description = 'desc' + uuid.v4(), + tag = 'tagme', + }: { + title: string; + description: string; + tag: string; + }) { + // case name + await testSubjects.setValue('input', title); + + // case tag + await comboBox.setCustom('comboBoxInput', tag); + + // case description + const descriptionArea = await find.byCssSelector('textarea.euiMarkdownEditorTextArea'); + await descriptionArea.focus(); + await descriptionArea.type(description); + + // save + await testSubjects.click('create-case-submit'); + + await testSubjects.existOrFail('case-view-title'); + }, + }; +} diff --git a/x-pack/test/functional/services/cases/index.ts b/x-pack/test/functional/services/cases/index.ts index afe244a21842e..886750c4ebfab 100644 --- a/x-pack/test/functional/services/cases/index.ts +++ b/x-pack/test/functional/services/cases/index.ts @@ -8,10 +8,16 @@ import { FtrProviderContext } from '../../ftr_provider_context'; import { CasesAPIServiceProvider } from './api'; import { CasesCommonServiceProvider } from './common'; +import { CasesCreateViewServiceProvider } from './create'; +import { CasesTableServiceProvider } from './list'; +import { CasesNavigationProvider } from './navigation'; export function CasesServiceProvider(context: FtrProviderContext) { return { api: CasesAPIServiceProvider(context), common: CasesCommonServiceProvider(context), + casesTable: CasesTableServiceProvider(context), + create: CasesCreateViewServiceProvider(context), + navigation: CasesNavigationProvider(context), }; } diff --git a/x-pack/test/functional/services/cases/list.ts b/x-pack/test/functional/services/cases/list.ts new file mode 100644 index 0000000000000..87e2fdcb91edc --- /dev/null +++ b/x-pack/test/functional/services/cases/list.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import expect from '@kbn/expect'; +import { WebElementWrapper } from 'test/functional/services/lib/web_element_wrapper'; +import { CaseStatuses } from '../../../../plugins/cases/common'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +export function CasesTableServiceProvider({ getService, getPageObject }: FtrProviderContext) { + const common = getPageObject('common'); + const testSubjects = getService('testSubjects'); + const find = getService('find'); + const header = getPageObject('header'); + const retry = getService('retry'); + + return { + /** + * Goes to the first case listed on the table. + * + * This will fail if the table doesn't have any case + */ + async goToFirstListedCase() { + await testSubjects.existOrFail('cases-table'); + await testSubjects.click('case-details-link'); + await testSubjects.existOrFail('case-view-title'); + }, + + async bulkDeleteAllCases() { + await testSubjects.setCheckbox('checkboxSelectAll', 'check'); + const button = await find.byCssSelector('[aria-label="Bulk actions"]'); + await button.click(); + await testSubjects.click('cases-bulk-delete-button'); + await testSubjects.click('confirmModalConfirmButton'); + }, + + async selectAndDeleteAllCases() { + await header.waitUntilLoadingHasFinished(); + await testSubjects.existOrFail('cases-table', { timeout: 20 * 1000 }); + let rows: WebElementWrapper[]; + do { + await header.waitUntilLoadingHasFinished(); + await testSubjects.missingOrFail('cases-table-loading', { timeout: 5000 }); + rows = await find.allByCssSelector('[data-test-subj*="cases-table-row-"', 100); + if (rows.length > 0) { + await this.bulkDeleteAllCases(); + // wait for a second + await new Promise((r) => setTimeout(r, 1000)); + await header.waitUntilLoadingHasFinished(); + } + } while (rows.length > 0); + }, + + async validateCasesTableHasNthRows(nrRows: number) { + await retry.tryForTime(2000, async () => { + const rows = await find.allByCssSelector('[data-test-subj*="cases-table-row-"', 100); + expect(rows.length).equal(nrRows); + }); + }, + + async waitForCasesToBeListed() { + await retry.waitFor('cases to appear on the all cases table', async () => { + this.refreshTable(); + return await testSubjects.exists('case-details-link'); + }); + }, + + async waitForCasesToBeDeleted() { + await retry.waitFor('the cases table to be empty', async () => { + this.refreshTable(); + const rows = await find.allByCssSelector('[data-test-subj*="cases-table-row-"', 100); + return rows.length === 0; + }); + }, + + async waitForTableToFinishLoading() { + await testSubjects.missingOrFail('cases-table-loading', { timeout: 5000 }); + }, + + async getCaseFromTable(index: number) { + const rows = await find.allByCssSelector('[data-test-subj*="cases-table-row-"', 100); + + if (index > rows.length) { + throw new Error('Cannot get case from table. Index is greater than the length of all rows'); + } + + return rows[index] ?? null; + }, + + async filterByTag(tag: string) { + await common.clickAndValidate( + 'options-filter-popover-button-Tags', + `options-filter-popover-item-${tag}` + ); + + await testSubjects.click(`options-filter-popover-item-${tag}`); + }, + + async filterByStatus(status: CaseStatuses) { + await common.clickAndValidate('case-status-filter', `case-status-filter-${status}`); + + await testSubjects.click(`case-status-filter-${status}`); + }, + + async filterByReporter(reporter: string) { + await common.clickAndValidate( + 'options-filter-popover-button-Reporter', + `options-filter-popover-item-${reporter}` + ); + + await testSubjects.click(`options-filter-popover-item-${reporter}`); + }, + + async refreshTable() { + await testSubjects.click('all-cases-refresh'); + }, + }; +} diff --git a/x-pack/test/functional/services/cases/navigation.ts b/x-pack/test/functional/services/cases/navigation.ts new file mode 100644 index 0000000000000..4aca20c01aaf1 --- /dev/null +++ b/x-pack/test/functional/services/cases/navigation.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { FtrProviderContext } from '../../ftr_provider_context'; + +export function CasesNavigationProvider({ getPageObject, getService }: FtrProviderContext) { + const common = getPageObject('common'); + const testSubjects = getService('testSubjects'); + + return { + async navigateToApp() { + await common.navigateToApp('cases'); + await testSubjects.existOrFail('cases-app', { timeout: 2000 }); + }, + + async navigateToConfigurationPage() { + await this.navigateToApp(); + await common.clickAndValidate('configure-case-button', 'case-configure-title'); + }, + }; +} diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/configure.ts b/x-pack/test/functional_with_es_ssl/apps/cases/configure.ts new file mode 100644 index 0000000000000..0c826baa252b1 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/cases/configure.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import expect from '@kbn/expect'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +export default ({ getPageObject, getService }: FtrProviderContext) => { + const common = getPageObject('common'); + const testSubjects = getService('testSubjects'); + const cases = getService('cases'); + const toasts = getService('toasts'); + + describe('Configure', function () { + before(async () => { + await cases.navigation.navigateToConfigurationPage(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + }); + + describe('Closure options', function () { + it('defaults the closure option correctly', async () => { + await cases.common.assertRadioGroupValue('closure-options-radio-group', 'close-by-user'); + }); + + it('change closure option successfully', async () => { + await cases.common.selectRadioGroupValue('closure-options-radio-group', 'close-by-pushing'); + const toast = await toasts.getToastElement(1); + expect(await toast.getVisibleText()).to.be('Saved external connection settings'); + await toasts.dismissAllToasts(); + }); + }); + + describe('Connectors', function () { + it('defaults the connector to none correctly', async () => { + expect(await testSubjects.exists('dropdown-connector-no-connector')).to.be(true); + }); + + it('opens and closes the connectors flyout correctly', async () => { + await common.clickAndValidate('dropdown-connectors', 'dropdown-connector-add-connector'); + await common.clickAndValidate('dropdown-connector-add-connector', 'euiFlyoutCloseButton'); + await testSubjects.click('euiFlyoutCloseButton'); + expect(await testSubjects.exists('euiFlyoutCloseButton')).to.be(false); + }); + }); + }); +}; diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/create_case_form.ts b/x-pack/test/functional_with_es_ssl/apps/cases/create_case_form.ts index 252f639feef48..c5aed361aba3e 100644 --- a/x-pack/test/functional_with_es_ssl/apps/cases/create_case_form.ts +++ b/x-pack/test/functional_with_es_ssl/apps/cases/create_case_form.ts @@ -9,15 +9,14 @@ import expect from '@kbn/expect'; import uuid from 'uuid'; import { FtrProviderContext } from '../../ftr_provider_context'; -export default ({ getPageObject, getService }: FtrProviderContext) => { +export default ({ getService }: FtrProviderContext) => { describe('Create case', function () { - const common = getPageObject('common'); const find = getService('find'); const cases = getService('cases'); const testSubjects = getService('testSubjects'); before(async () => { - await common.navigateToApp('cases'); + await cases.navigation.navigateToApp(); }); after(async () => { @@ -26,7 +25,8 @@ export default ({ getPageObject, getService }: FtrProviderContext) => { it('creates a case from the stack management page', async () => { const caseTitle = 'test-' + uuid.v4(); - await cases.common.createCaseFromCreateCasePage({ + await cases.create.openCreateCasePage(); + await cases.create.createCaseFromCreateCasePage({ title: caseTitle, description: 'test description', tag: 'tagme', diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/edit_case_form.ts b/x-pack/test/functional_with_es_ssl/apps/cases/edit_case_form.ts deleted file mode 100644 index adc7c3401aa96..0000000000000 --- a/x-pack/test/functional_with_es_ssl/apps/cases/edit_case_form.ts +++ /dev/null @@ -1,169 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import expect from '@kbn/expect'; -import uuid from 'uuid'; -import { FtrProviderContext } from '../../ftr_provider_context'; - -export default ({ getPageObject, getService }: FtrProviderContext) => { - const common = getPageObject('common'); - const header = getPageObject('header'); - const testSubjects = getService('testSubjects'); - const find = getService('find'); - const cases = getService('cases'); - const retry = getService('retry'); - const comboBox = getService('comboBox'); - - describe('Edit case', () => { - // create the case to test on - before(async () => { - await common.navigateToApp('cases'); - await cases.api.createNthRandomCases(1); - }); - - after(async () => { - await cases.api.deleteAllCases(); - }); - - beforeEach(async () => { - await common.navigateToApp('cases'); - await cases.common.goToFirstListedCase(); - await header.waitUntilLoadingHasFinished(); - }); - - it('edits a case title from the case view page', async () => { - const newTitle = `test-${uuid.v4()}`; - - await testSubjects.click('editable-title-edit-icon'); - await testSubjects.setValue('editable-title-input-field', newTitle); - await testSubjects.click('editable-title-submit-btn'); - - // wait for backend response - await retry.tryForTime(5000, async () => { - const title = await find.byCssSelector('[data-test-subj="header-page-title"]'); - expect(await title.getVisibleText()).equal(newTitle); - }); - - // validate user action - await find.byCssSelector('[data-test-subj*="title-update-action"]'); - }); - - it('adds a comment to a case', async () => { - const commentArea = await find.byCssSelector( - '[data-test-subj="add-comment"] textarea.euiMarkdownEditorTextArea' - ); - await commentArea.focus(); - await commentArea.type('Test comment from automation'); - await testSubjects.click('submit-comment'); - - // validate user action - const newComment = await find.byCssSelector( - '[data-test-subj*="comment-create-action"] [data-test-subj="user-action-markdown"]' - ); - expect(await newComment.getVisibleText()).equal('Test comment from automation'); - }); - - it('adds a tag to a case', async () => { - const tag = uuid.v4(); - await testSubjects.click('tag-list-edit-button'); - await comboBox.setCustom('comboBoxInput', tag); - await testSubjects.click('edit-tags-submit'); - - // validate tag was added - await testSubjects.existOrFail('tag-' + tag); - - // validate user action - await find.byCssSelector('[data-test-subj*="tags-add-action"]'); - }); - - it('deletes a tag from a case', async () => { - await testSubjects.click('tag-list-edit-button'); - // find the tag button and click the close button - const button = await find.byCssSelector('[data-test-subj="comboBoxInput"] button'); - await button.click(); - await testSubjects.click('edit-tags-submit'); - - // validate user action - await find.byCssSelector('[data-test-subj*="tags-delete-action"]'); - }); - - it('changes a case status to in-progress via dropdown menu', async () => { - await cases.common.markCaseInProgressViaDropdown(); - // validate user action - await find.byCssSelector( - '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-in-progress"]' - ); - // validates dropdown tag - await testSubjects.existOrFail('case-view-status-dropdown > status-badge-in-progress'); - }); - - it('changes a case status to closed via dropdown-menu', async () => { - await cases.common.markCaseClosedViaDropdown(); - - // validate user action - await find.byCssSelector( - '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-closed"]' - ); - // validates dropdown tag - await testSubjects.existOrFail('case-view-status-dropdown > status-badge-closed'); - }); - - it("reopens a case from the 'reopen case' button", async () => { - await cases.common.markCaseClosedViaDropdown(); - await header.waitUntilLoadingHasFinished(); - await testSubjects.click('case-view-status-action-button'); - await header.waitUntilLoadingHasFinished(); - - await testSubjects.existOrFail('header-page-supplements > status-badge-open', { - timeout: 5000, - }); - - // validate user action - await find.byCssSelector( - '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-open"]' - ); - // validates dropdown tag - await testSubjects.existOrFail('case-view-status-dropdown > status-badge-open'); - }); - - it("marks in progress a case from the 'mark in progress' button", async () => { - await cases.common.markCaseOpenViaDropdown(); - await header.waitUntilLoadingHasFinished(); - await testSubjects.click('case-view-status-action-button'); - await header.waitUntilLoadingHasFinished(); - - await testSubjects.existOrFail('header-page-supplements > status-badge-in-progress', { - timeout: 5000, - }); - - // validate user action - await find.byCssSelector( - '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-in-progress"]' - ); - // validates dropdown tag - await testSubjects.existOrFail('case-view-status-dropdown > status-badge-in-progress'); - }); - - it("closes a case from the 'close case' button", async () => { - await cases.common.markCaseInProgressViaDropdown(); - await header.waitUntilLoadingHasFinished(); - await testSubjects.click('case-view-status-action-button'); - await header.waitUntilLoadingHasFinished(); - - await testSubjects.existOrFail('header-page-supplements > status-badge-closed', { - timeout: 5000, - }); - - // validate user action - await find.byCssSelector( - '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-closed"]' - ); - // validates dropdown tag - await testSubjects.existOrFail('case-view-status-dropdown > status-badge-closed'); - }); - }); -}; diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/index.ts b/x-pack/test/functional_with_es_ssl/apps/cases/index.ts index 583fce960fbbd..53d2c2d9767f1 100644 --- a/x-pack/test/functional_with_es_ssl/apps/cases/index.ts +++ b/x-pack/test/functional_with_es_ssl/apps/cases/index.ts @@ -11,7 +11,8 @@ export default ({ loadTestFile }: FtrProviderContext) => { describe('Cases', function () { this.tags('ciGroup27'); loadTestFile(require.resolve('./create_case_form')); - loadTestFile(require.resolve('./edit_case_form')); + loadTestFile(require.resolve('./view_case')); loadTestFile(require.resolve('./list_view')); + loadTestFile(require.resolve('./configure')); }); }; diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/list_view.ts b/x-pack/test/functional_with_es_ssl/apps/cases/list_view.ts index 40fd69246710b..c1ec21b694b49 100644 --- a/x-pack/test/functional_with_es_ssl/apps/cases/list_view.ts +++ b/x-pack/test/functional_with_es_ssl/apps/cases/list_view.ts @@ -5,118 +5,190 @@ * 2.0. */ +import expect from '@kbn/expect'; import uuid from 'uuid'; import { FtrProviderContext } from '../../ftr_provider_context'; +import { CaseStatuses } from '../../../../plugins/cases/common'; export default ({ getPageObject, getService }: FtrProviderContext) => { - const common = getPageObject('common'); const header = getPageObject('header'); const testSubjects = getService('testSubjects'); const cases = getService('cases'); const retry = getService('retry'); const browser = getService('browser'); - // Failing: See https://github.com/elastic/kibana/issues/128468 - describe.skip('cases list', () => { + describe('cases list', () => { before(async () => { - await common.navigateToApp('cases'); - await cases.api.deleteAllCases(); + await cases.navigation.navigateToApp(); }); after(async () => { await cases.api.deleteAllCases(); + await cases.casesTable.waitForCasesToBeDeleted(); }); - beforeEach(async () => { - await common.navigateToApp('cases'); + describe('empty state', () => { + it('displays an empty list with an add button correctly', async () => { + await testSubjects.existOrFail('cases-table-add-case'); + }); }); - it('displays an empty list with an add button correctly', async () => { - await testSubjects.existOrFail('cases-table-add-case'); - }); + describe('listing', () => { + before(async () => { + await cases.api.createNthRandomCases(2); + await header.waitUntilLoadingHasFinished(); + await cases.casesTable.waitForCasesToBeListed(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + await cases.casesTable.waitForCasesToBeDeleted(); + }); - it('lists cases correctly', async () => { - const NUMBER_CASES = 2; - await cases.api.createNthRandomCases(NUMBER_CASES); - await common.navigateToApp('cases'); - await cases.common.validateCasesTableHasNthRows(NUMBER_CASES); + it('lists cases correctly', async () => { + await cases.casesTable.validateCasesTableHasNthRows(2); + }); }); - it('deletes a case correctly from the list', async () => { - await cases.api.createNthRandomCases(1); - await common.navigateToApp('cases'); - await testSubjects.click('action-delete'); - await testSubjects.click('confirmModalConfirmButton'); - await testSubjects.existOrFail('euiToastHeader'); + describe('deleting', () => { + before(async () => { + await cases.api.createNthRandomCases(8); + await cases.api.createCase({ title: 'delete me', tags: ['one'] }); + await header.waitUntilLoadingHasFinished(); + await cases.casesTable.waitForCasesToBeListed(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + await cases.casesTable.waitForCasesToBeDeleted(); + }); + + it('deletes a case correctly from the list', async () => { + await testSubjects.click('action-delete'); + await testSubjects.click('confirmModalConfirmButton'); + await testSubjects.existOrFail('euiToastHeader'); + await cases.casesTable.waitForTableToFinishLoading(); + + await retry.tryForTime(2000, async () => { + const firstRow = await testSubjects.find('case-details-link'); + expect(await firstRow.getVisibleText()).not.to.be('delete me'); + }); + }); + + it('bulk delete cases from the list', async () => { + await cases.casesTable.selectAndDeleteAllCases(); + await cases.casesTable.waitForTableToFinishLoading(); + await cases.casesTable.validateCasesTableHasNthRows(0); + }); }); - it('filters cases from the list with partial match', async () => { - await cases.api.deleteAllCases(); - await cases.api.createNthRandomCases(5); + describe('filtering', () => { const id = uuid.v4(); const caseTitle = 'matchme-' + id; - await cases.api.createCaseWithData({ title: caseTitle }); - await common.navigateToApp('cases'); - await testSubjects.missingOrFail('cases-table-loading', { timeout: 5000 }); - // search - const input = await testSubjects.find('search-cases'); - await input.type(caseTitle); - await input.pressKeys(browser.keys.ENTER); + before(async () => { + await cases.api.createNthRandomCases(2); + await cases.api.createCase({ title: caseTitle, tags: ['one'] }); + await cases.api.createCase({ tags: ['two'] }); + await header.waitUntilLoadingHasFinished(); + await cases.casesTable.waitForCasesToBeListed(); + }); - await retry.tryForTime(20000, async () => { - await cases.common.validateCasesTableHasNthRows(1); + beforeEach(async () => { + /** + * There is no easy way to clear the filtering. + * Refreshing the page seems to be easier. + */ + await cases.navigation.navigateToApp(); }); - }); - it('paginates cases correctly', async () => { - await cases.api.deleteAllCases(); - await cases.api.createNthRandomCases(8); - await common.navigateToApp('cases'); - await testSubjects.click('tablePaginationPopoverButton'); - await testSubjects.click('tablePagination-5-rows'); - await testSubjects.isEnabled('pagination-button-1'); - await testSubjects.click('pagination-button-1'); - await testSubjects.isEnabled('pagination-button-0'); + after(async () => { + await cases.api.deleteAllCases(); + await cases.casesTable.waitForCasesToBeDeleted(); + }); + + it('filters cases from the list with partial match', async () => { + await testSubjects.missingOrFail('cases-table-loading', { timeout: 5000 }); + + // search + const input = await testSubjects.find('search-cases'); + await input.type(caseTitle); + await input.pressKeys(browser.keys.ENTER); + + await cases.casesTable.validateCasesTableHasNthRows(1); + await testSubjects.click('clearSearchButton'); + await cases.casesTable.validateCasesTableHasNthRows(4); + }); + + it('filters cases by tags', async () => { + await cases.casesTable.filterByTag('one'); + await cases.casesTable.refreshTable(); + await cases.casesTable.validateCasesTableHasNthRows(1); + const row = await cases.casesTable.getCaseFromTable(0); + const tags = await row.findByCssSelector('[data-test-subj="case-table-column-tags-one"]'); + expect(await tags.getVisibleText()).to.be('one'); + }); + + it('filters cases by status', async () => { + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses['in-progress']); + await cases.casesTable.filterByStatus(CaseStatuses['in-progress']); + await cases.casesTable.validateCasesTableHasNthRows(1); + }); + + /** + * TODO: Improve the test by creating a case from a + * different user and filter by the new user + * and not the default one + */ + it('filters cases by reporter', async () => { + await cases.casesTable.filterByReporter('elastic'); + await cases.casesTable.validateCasesTableHasNthRows(4); + }); }); - it('bulk delete cases from the list', async () => { - // deletes them from the API - await cases.api.deleteAllCases(); - await cases.api.createNthRandomCases(8); - await common.navigateToApp('cases'); - // deletes them from the UI - await cases.common.selectAndDeleteAllCases(); - await cases.common.validateCasesTableHasNthRows(0); + describe('pagination', () => { + before(async () => { + await cases.api.createNthRandomCases(8); + await header.waitUntilLoadingHasFinished(); + await cases.casesTable.waitForCasesToBeListed(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + await cases.casesTable.waitForCasesToBeDeleted(); + }); + + it('paginates cases correctly', async () => { + await testSubjects.click('tablePaginationPopoverButton'); + await testSubjects.click('tablePagination-5-rows'); + await testSubjects.isEnabled('pagination-button-1'); + await testSubjects.click('pagination-button-1'); + await testSubjects.isEnabled('pagination-button-0'); + }); }); describe('changes status from the list', () => { before(async () => { - await common.navigateToApp('cases'); - await cases.api.deleteAllCases(); await cases.api.createNthRandomCases(1); - await common.navigateToApp('cases'); + await header.waitUntilLoadingHasFinished(); + await cases.casesTable.waitForCasesToBeListed(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + await cases.casesTable.waitForCasesToBeDeleted(); }); it('to in progress', async () => { - await cases.common.openCaseSetStatusDropdown(); - await testSubjects.click('case-view-status-dropdown-in-progress'); - await header.waitUntilLoadingHasFinished(); - await testSubjects.existOrFail('status-badge-in-progress'); + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses['in-progress']); }); it('to closed', async () => { - await cases.common.openCaseSetStatusDropdown(); - await testSubjects.click('case-view-status-dropdown-closed'); - await header.waitUntilLoadingHasFinished(); - await testSubjects.existOrFail('status-badge-closed'); + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses.closed); }); it('to open', async () => { - await cases.common.openCaseSetStatusDropdown(); - await testSubjects.click('case-view-status-dropdown-open'); - await header.waitUntilLoadingHasFinished(); - await testSubjects.existOrFail('status-badge-open'); + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses.open); }); }); }); diff --git a/x-pack/test/functional_with_es_ssl/apps/cases/view_case.ts b/x-pack/test/functional_with_es_ssl/apps/cases/view_case.ts new file mode 100644 index 0000000000000..8c14e7e1263ee --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/cases/view_case.ts @@ -0,0 +1,192 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import expect from '@kbn/expect'; +import uuid from 'uuid'; +import { FtrProviderContext } from '../../ftr_provider_context'; +import { CaseStatuses } from '../../../../plugins/cases/common'; + +export default ({ getPageObject, getService }: FtrProviderContext) => { + const common = getPageObject('common'); + const header = getPageObject('header'); + const testSubjects = getService('testSubjects'); + const find = getService('find'); + const cases = getService('cases'); + const retry = getService('retry'); + const comboBox = getService('comboBox'); + + describe('View case', () => { + describe('properties', () => { + // create the case to test on + before(async () => { + await cases.navigation.navigateToApp(); + await cases.api.createNthRandomCases(1); + await cases.casesTable.waitForCasesToBeListed(); + await cases.casesTable.goToFirstListedCase(); + await header.waitUntilLoadingHasFinished(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + }); + + it('edits a case title from the case view page', async () => { + const newTitle = `test-${uuid.v4()}`; + + await testSubjects.click('editable-title-edit-icon'); + await testSubjects.setValue('editable-title-input-field', newTitle); + await testSubjects.click('editable-title-submit-btn'); + + // wait for backend response + await retry.tryForTime(5000, async () => { + const title = await find.byCssSelector('[data-test-subj="header-page-title"]'); + expect(await title.getVisibleText()).equal(newTitle); + }); + + // validate user action + await find.byCssSelector('[data-test-subj*="title-update-action"]'); + }); + + it('adds a comment to a case', async () => { + const commentArea = await find.byCssSelector( + '[data-test-subj="add-comment"] textarea.euiMarkdownEditorTextArea' + ); + await commentArea.focus(); + await commentArea.type('Test comment from automation'); + await testSubjects.click('submit-comment'); + + // validate user action + const newComment = await find.byCssSelector( + '[data-test-subj*="comment-create-action"] [data-test-subj="user-action-markdown"]' + ); + expect(await newComment.getVisibleText()).equal('Test comment from automation'); + }); + + it('adds a tag to a case', async () => { + const tag = uuid.v4(); + await testSubjects.click('tag-list-edit-button'); + await comboBox.setCustom('comboBoxInput', tag); + await testSubjects.click('edit-tags-submit'); + + // validate tag was added + await testSubjects.existOrFail('tag-' + tag); + + // validate user action + await find.byCssSelector('[data-test-subj*="tags-add-action"]'); + }); + + it('deletes a tag from a case', async () => { + await testSubjects.click('tag-list-edit-button'); + // find the tag button and click the close button + const button = await find.byCssSelector('[data-test-subj="comboBoxInput"] button'); + await button.click(); + await testSubjects.click('edit-tags-submit'); + + // validate user action + await find.byCssSelector('[data-test-subj*="tags-delete-action"]'); + }); + + it('changes a case status to in-progress via dropdown menu', async () => { + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses['in-progress']); + // validate user action + await find.byCssSelector( + '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-in-progress"]' + ); + // validates dropdown tag + await testSubjects.existOrFail('case-view-status-dropdown > status-badge-in-progress'); + }); + + it('changes a case status to closed via dropdown-menu', async () => { + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses.closed); + + // validate user action + await find.byCssSelector( + '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-closed"]' + ); + // validates dropdown tag + await testSubjects.existOrFail('case-view-status-dropdown > status-badge-closed'); + }); + + it("reopens a case from the 'reopen case' button", async () => { + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses.closed); + await header.waitUntilLoadingHasFinished(); + await testSubjects.click('case-view-status-action-button'); + await header.waitUntilLoadingHasFinished(); + + await testSubjects.existOrFail('header-page-supplements > status-badge-open', { + timeout: 5000, + }); + + // validate user action + await find.byCssSelector( + '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-open"]' + ); + // validates dropdown tag + await testSubjects.existOrFail('case-view-status-dropdown > status-badge-open'); + }); + + it("marks in progress a case from the 'mark in progress' button", async () => { + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses.open); + await header.waitUntilLoadingHasFinished(); + await testSubjects.click('case-view-status-action-button'); + await header.waitUntilLoadingHasFinished(); + + await testSubjects.existOrFail('header-page-supplements > status-badge-in-progress', { + timeout: 5000, + }); + + // validate user action + await find.byCssSelector( + '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-in-progress"]' + ); + // validates dropdown tag + await testSubjects.existOrFail('case-view-status-dropdown > status-badge-in-progress'); + }); + + it("closes a case from the 'close case' button", async () => { + await cases.common.changeCaseStatusViaDropdownAndVerify(CaseStatuses['in-progress']); + await header.waitUntilLoadingHasFinished(); + await testSubjects.click('case-view-status-action-button'); + await header.waitUntilLoadingHasFinished(); + + await testSubjects.existOrFail('header-page-supplements > status-badge-closed', { + timeout: 5000, + }); + + // validate user action + await find.byCssSelector( + '[data-test-subj*="status-update-action"] [data-test-subj="status-badge-closed"]' + ); + // validates dropdown tag + await testSubjects.existOrFail('case-view-status-dropdown > status-badge-closed'); + }); + }); + + describe('actions', () => { + // create the case to test on + before(async () => { + await cases.navigation.navigateToApp(); + await cases.api.createNthRandomCases(1); + await cases.casesTable.waitForCasesToBeListed(); + await cases.casesTable.goToFirstListedCase(); + await header.waitUntilLoadingHasFinished(); + }); + + after(async () => { + await cases.api.deleteAllCases(); + }); + + it('deletes the case successfully', async () => { + await common.clickAndValidate('property-actions-ellipses', 'property-actions-trash'); + await common.clickAndValidate('property-actions-trash', 'confirmModalConfirmButton'); + await testSubjects.click('confirmModalConfirmButton'); + await testSubjects.existOrFail('cases-all-title', { timeout: 2000 }); + await cases.casesTable.validateCasesTableHasNthRows(0); + }); + }); + }); +}; diff --git a/x-pack/test/functional_with_es_ssl/config.ts b/x-pack/test/functional_with_es_ssl/config.ts index dc2f6b8618ce3..cee793c8c8bb9 100644 --- a/x-pack/test/functional_with_es_ssl/config.ts +++ b/x-pack/test/functional_with_es_ssl/config.ts @@ -17,7 +17,10 @@ const enabledActionTypes = [ '.index', '.pagerduty', '.swimlane', + '.jira', + '.resilient', '.servicenow', + '.servicenow-sir', '.slack', '.webhook', 'test.authorization', From 196061e8ab850aa1b515814f6a70379162244eb5 Mon Sep 17 00:00:00 2001 From: Lisa Cawley Date: Tue, 29 Mar 2022 11:02:37 -0700 Subject: [PATCH 108/160] [DOCS] Case comment APIs (#128443) --- docs/api/cases.asciidoc | 7 +- docs/api/cases/cases-api-add-comment.asciidoc | 164 ++++++++++++++++ .../cases/cases-api-update-comment.asciidoc | 178 ++++++++++++++++++ 3 files changed, 347 insertions(+), 2 deletions(-) create mode 100644 docs/api/cases/cases-api-add-comment.asciidoc create mode 100644 docs/api/cases/cases-api-update-comment.asciidoc diff --git a/docs/api/cases.asciidoc b/docs/api/cases.asciidoc index a92951d7d6d1a..88d4f4d668baa 100644 --- a/docs/api/cases.asciidoc +++ b/docs/api/cases.asciidoc @@ -4,7 +4,7 @@ You can create, manage, configure, and send cases to external systems with these APIs: -* {security-guide}/cases-api-add-comment.html[Add comment] +* <> * <> * <> * <> @@ -23,8 +23,10 @@ these APIs: * {security-guide}/assign-connector.html[Set default Elastic Security UI connector] * {security-guide}/case-api-update-connector.html[Update case configurations] * <> -* {security-guide}/cases-api-update-comment.html[Update comment] +* <> +//ADD +include::cases/cases-api-add-comment.asciidoc[leveloffset=+1] //CREATE include::cases/cases-api-create.asciidoc[leveloffset=+1] //DELETE @@ -38,3 +40,4 @@ include::cases/cases-api-get-case.asciidoc[leveloffset=+1] include::cases/cases-api-get-comments.asciidoc[leveloffset=+1] //UPDATE include::cases/cases-api-update.asciidoc[leveloffset=+1] +include::cases/cases-api-update-comment.asciidoc[leveloffset=+1] diff --git a/docs/api/cases/cases-api-add-comment.asciidoc b/docs/api/cases/cases-api-add-comment.asciidoc new file mode 100644 index 0000000000000..20b558a89c683 --- /dev/null +++ b/docs/api/cases/cases-api-add-comment.asciidoc @@ -0,0 +1,164 @@ +[[cases-api-add-comment]] +== Add comment to case API +++++ +Add comment +++++ + +Adds a comment to a case. + +=== Request + +`POST :/api/cases//comments` + +`POST :/s//api/cases//comments` + +=== Prerequisite + +You must have `all` privileges for the *Cases* feature in the *Management*, +*{observability}*, or *Security* section of the +<>, depending on the +`owner` of the case you're updating. + + +=== Path parameters + +``:: +(Required,string) The identifier for the case. To retrieve case IDs, use +<>. + +``:: +(Optional, string) An identifier for the space. If it is not specified, the +default space is used. + +=== Request body + +`alertId`:: +(Required*, string) The alert identifier. It is required only when `type` is +`alert`. preview:[] + +`comment`:: +(Required*, string) The new comment. It is required only when `type` is `user`. + +`index`:: +(Required*, string) The alert index. It is required only when `type` is `alert`. +preview:[] + +`owner`:: +(Required, string) The application that owns the case. Valid values are: +`cases`, `observability`, or `securitySolution`. + +`rule`:: +(Required*, object) The rule that is associated with the alert. It is required +only when `type` is `alert`. preview:[] ++ +.Properties of `rule` +[%collapsible%open] +==== +`id`:: +(Required, string) The rule identifier. preview:[] + +`name`:: +(Required, string) The rule name. preview:[] + +==== + +`type`:: +(Required, string) The comment type, which must be `user` or `alert`. + +=== Response code + +`200`:: + Indicates a successful call. + +=== Example + +Add a comment to case ID `293f1bc0-74f6-11ea-b83a-553aecdb28b6`: + +[source,sh] +-------------------------------------------------- +POST api/cases/293f1bc0-74f6-11ea-b83a-553aecdb28b6/comments +{ + "type": "user", + "comment": "That is nothing - Ethan Hunt answered a targeted social media campaign promoting phishy pension schemes to IMF operatives.", + "owner": "cases" +} +-------------------------------------------------- +// KIBANA + +The API returns details about the case and its comments. For example: + +[source,json] +-------------------------------------------------- +{ + "comments":[ + { + "id": "8af6ac20-74f6-11ea-b83a-553aecdb28b6", + "version": "WzIwNDMxLDFd", + "type":"user", + "owner":"cases", + "comment":"That is nothing - Ethan Hunt answered a targeted social media campaign promoting phishy pension schemes to IMF operatives.", + "created_at":"2022-03-24T00:49:47.716Z", + "created_by": { + "email": "moneypenny@hms.gov.uk", + "full_name": "Ms Moneypenny", + "username": "moneypenny" + }, + "pushed_at":null, + "pushed_by":null, + "updated_at":null, + "updated_by":null + } + ], + "totalAlerts":0, + "id":"293f1bc0-74f6-11ea-b83a-553aecdb28b6", + "version":"WzIzMzgsMV0=", + "totalComment":1, + "title": "This case will self-destruct in 5 seconds", + "tags": ["phishing","social engineering"], + "description": "James Bond clicked on a highly suspicious email banner advertising cheap holidays for underpaid civil servants.", + "settings": { + "syncAlerts":false + }, + "owner": "cases", + "closed_at": null, + "closed_by": null, + "created_at": "2022-03-24T00:37:03.906Z", + "created_by": { + "email": "ahunley@imf.usa.gov", + "full_name": "Alan Hunley", + "username": "ahunley" + }, + "status": "open", + "updated_at": "2022-03-24T00:49:47.716Z", + "updated_by": { + "email": "moneypenny@hms.gov.uk", + "full_name": "Ms Moneypenny", + "username": "moneypenny" + }, + "connector": { + "id": "none", + "name": "none", + "type": ".none", + "fields": null + }, + "external_service": null +} +-------------------------------------------------- + +Add an alert to the case: + +[source,sh] +-------------------------------------------------- +POST api/cases/293f1bc0-74f6-11ea-b83a-553aecdb28b6/comments +{ +"alertId": "6b24c4dc44bc720cfc92797f3d61fff952f2b2627db1fb4f8cc49f4530c4ff42", +"index": ".internal.alerts-security.alerts-default-000001", +"type": "alert", +"owner": "cases", +"rule": { + "id":"94d80550-aaf4-11ec-985f-97e55adae8b9", + "name":"security_rule" + } +} +-------------------------------------------------- +// KIBANA diff --git a/docs/api/cases/cases-api-update-comment.asciidoc b/docs/api/cases/cases-api-update-comment.asciidoc new file mode 100644 index 0000000000000..98d426cb0c86d --- /dev/null +++ b/docs/api/cases/cases-api-update-comment.asciidoc @@ -0,0 +1,178 @@ +[[cases-api-update-comment]] +== Update case comment API +++++ +Update comment +++++ + +Updates a comment in a case. + +=== Request + +`PATCH :/api/cases//comments` + +`PATCH :/s//api/cases//comments` + +=== Prerequisite + +You must have `all` privileges for the *Cases* feature in the *Management*, +*{observability}*, or *Security* section of the +<>, depending on the +`owner` of the case you're updating. + +=== Path parameters + +``:: +The identifier for the case. To retrieve case IDs, use +<>. + +``:: +(Optional, string) An identifier for the space. If it is not specified, the +default space is used. + +=== Request body + +`alertId`:: +(Required*, string) The identifier for the alert. It is required only when +`type` is `alert`. preview:[] + +`comment`:: +(Required*, string) The updated comment. It is required only when `type` is +`user`. + +`id`:: +(Required, string) The identifier for the comment. +//To retrieve comment IDs, use <>. + +`index`:: +(Required*, string) The alert index. It is required only when `type` is `alert`. +preview:[] + +`owner`:: +(Required, string) The application that owns the case. It can be `cases`, +`observability`, or `securitySolution`. ++ +NOTE: You cannot change the owner of a comment. + +`rule`:: +(Required*, object) +The rule that is associated with the alert. It is required only when `type` is +`alert`. preview:[] ++ +.Properties of `rule` +[%collapsible%open] +==== +`id`:: +(Required, string) The rule identifier. preview:[] + +`name`:: +(Required, string) The rule name. preview:[] + +==== + +`type`:: +(Required, string) The comment type, which must be `user` or `alert`. ++ +NOTE: You cannot change the comment type. + +`version`:: +(Required, string) The current comment version. +//To retrieve version values, use <>. + +=== Response code + +`200`:: + Indicates a successful call. + +=== Example + +Update comment ID `8af6ac20-74f6-11ea-b83a-553aecdb28b6` (associated with case +ID `293f1bc0-74f6-11ea-b83a-553aecdb28b6`): + +[source,sh] +-------------------------------------------------- +PATCH api/cases/293f1bc0-74f6-11ea-b83a-553aecdb28b6/comments +{ + "id": "8af6ac20-74f6-11ea-b83a-553aecdb28b6", + "version": "Wzk1LDFd", + "type": "user", + "comment": "That is nothing - Ethan Hunt answered a targeted social media campaign promoting phishy pension schemes to IMF operatives. Even worse, he likes baked beans." +} +-------------------------------------------------- +// KIBANA + +The API returns details about the case and its comments. For example: + +[source,json] +-------------------------------------------------- +{ + "comments":[{ + "id": "8af6ac20-74f6-11ea-b83a-553aecdb28b6", + "version": "WzIwNjM3LDFd", + "comment":"That is nothing - Ethan Hunt answered a targeted social media campaign promoting phishy pension schemes to IMF operatives. Even worse, he likes baked beans.", + "type":"user", + "owner":"cases", + "created_at":"2022-03-24T00:37:10.832Z", + "created_by": { + "email": "moneypenny@hms.gov.uk", + "full_name": "Ms Moneypenny", + "username": "moneypenny" + }, + "pushed_at":null, + "pushed_by":null, + "updated_at":"2022-03-24T01:27:06.210Z", + "updated_by": { + "email": "jbond@hms.gov.uk", + "full_name": "James Bond", + "username": "_007" + } + } + ], + "totalAlerts":0, + "id": "293f1bc0-74f6-11ea-b83a-553aecdb28b6", + "version": "WzIwNjM2LDFd", + "totalComment": 1, + "title": "This case will self-destruct in 5 seconds", + "tags": ["phishing","social engineering"], + "description": "James Bond clicked on a highly suspicious email banner advertising cheap holidays for underpaid civil servants.", + "settings": {"syncAlerts":false}, + "owner": "cases"," + closed_at": null, + "closed_by": null, + "created_at": "2022-03-24T00:37:03.906Z", + "created_by": { + "email": "ahunley@imf.usa.gov", + "full_name": "Alan Hunley", + "username": "ahunley" + }, + "status": "open", + "updated_at": "2022-03-24T01:27:06.210Z", + "updated_by": { + "email": "jbond@hms.gov.uk", + "full_name": "James Bond", + "username": "_007" + }, + "connector": {"id":"none","name":"none","type":".none","fields":null}, + "external_service": null +} +-------------------------------------------------- + +Update an alert in the case: + +[source,sh] +-------------------------------------------------- +PATCH api/cases/293f1bc0-74f6-11ea-b83a-553aecdb28b6/comments +{ +"id": "73362370-ab1a-11ec-985f-97e55adae8b9", +"version": "WzMwNDgsMV0=", +"type": "alert", +"owner": "cases", +"alertId": "c8789278659fdf88b7bf7709b90a082be070d0ba4c23c9c4b552e476c2a667c4", +"index": ".internal.alerts-security.alerts-default-000001", +"rule": +{ + "id":"94d80550-aaf4-11ec-985f-97e55adae8b9", + "name":"security_rule" + } +} +-------------------------------------------------- +// KIBANA From c11a44eb3b19a662e34a58aface197f0418fe6c6 Mon Sep 17 00:00:00 2001 From: Dima Arnautov Date: Tue, 29 Mar 2022 20:19:56 +0200 Subject: [PATCH 109/160] [Transform] Extend Transform Health alerting rule with error messages check (#128731) --- x-pack/plugins/transform/common/constants.ts | 11 ++ .../transform/common/types/alerting.ts | 3 + .../plugins/transform/common/utils/alerts.ts | 3 + .../register_transform_health_rule.ts | 20 +++- .../tests_selection_control.tsx | 1 - .../register_transform_health_rule_type.ts | 8 +- .../transform_health_rule_type/schema.ts | 5 + .../transform_health_service.ts | 104 +++++++++++++++++- .../routes/api/transforms_audit_messages.ts | 2 +- 9 files changed, 149 insertions(+), 8 deletions(-) diff --git a/x-pack/plugins/transform/common/constants.ts b/x-pack/plugins/transform/common/constants.ts index ab25b73fa9555..b378b1ac4ef13 100644 --- a/x-pack/plugins/transform/common/constants.ts +++ b/x-pack/plugins/transform/common/constants.ts @@ -132,4 +132,15 @@ export const TRANSFORM_HEALTH_CHECK_NAMES: Record< } ), }, + errorMessages: { + name: i18n.translate('xpack.transform.alertTypes.transformHealth.errorMessagesCheckName', { + defaultMessage: 'Errors in transform messages', + }), + description: i18n.translate( + 'xpack.transform.alertTypes.transformHealth.errorMessagesCheckDescription', + { + defaultMessage: 'Get alerts if a transform contains errors in the transform messages.', + } + ), + }, }; diff --git a/x-pack/plugins/transform/common/types/alerting.ts b/x-pack/plugins/transform/common/types/alerting.ts index dde9a360d9473..07d6bbdbe4152 100644 --- a/x-pack/plugins/transform/common/types/alerting.ts +++ b/x-pack/plugins/transform/common/types/alerting.ts @@ -14,6 +14,9 @@ export type TransformHealthRuleParams = { notStarted?: { enabled: boolean; } | null; + errorMessages?: { + enabled: boolean; + } | null; } | null; } & AlertTypeParams; diff --git a/x-pack/plugins/transform/common/utils/alerts.ts b/x-pack/plugins/transform/common/utils/alerts.ts index 9b3cb2757100a..88c6fc64a35b2 100644 --- a/x-pack/plugins/transform/common/utils/alerts.ts +++ b/x-pack/plugins/transform/common/utils/alerts.ts @@ -12,5 +12,8 @@ export function getResultTestConfig(config: TransformHealthRuleTestsConfig) { notStarted: { enabled: config?.notStarted?.enabled ?? true, }, + errorMessages: { + enabled: config?.errorMessages?.enabled ?? true, + }, }; } diff --git a/x-pack/plugins/transform/public/alerting/transform_health_rule_type/register_transform_health_rule.ts b/x-pack/plugins/transform/public/alerting/transform_health_rule_type/register_transform_health_rule.ts index 779496da59501..ffbc0f6021481 100644 --- a/x-pack/plugins/transform/public/alerting/transform_health_rule_type/register_transform_health_rule.ts +++ b/x-pack/plugins/transform/public/alerting/transform_health_rule_type/register_transform_health_rule.ts @@ -10,6 +10,7 @@ import { i18n } from '@kbn/i18n'; import { TRANSFORM_RULE_TYPE } from '../../../common'; import type { TransformHealthRuleParams } from '../../../common/types/alerting'; import type { RuleTypeModel } from '../../../../triggers_actions_ui/public'; +import { getResultTestConfig } from '../../../common/utils/alerts'; export function getTransformHealthRuleType(): RuleTypeModel { return { @@ -26,11 +27,12 @@ export function getTransformHealthRuleType(): RuleTypeModel(), + testsConfig: new Array(), } as Record, }; if (!ruleParams.includeTransforms?.length) { - validationResult.errors.includeTransforms?.push( + validationResult.errors.includeTransforms.push( i18n.translate( 'xpack.transform.alertTypes.transformHealth.includeTransforms.errorMessage', { @@ -40,6 +42,19 @@ export function getTransformHealthRuleType(): RuleTypeModel !v.enabled); + if (allTestDisabled) { + validationResult.errors.testsConfig.push( + i18n.translate( + 'xpack.transform.alertTypes.transformHealth.testsConfigTransforms.errorMessage', + { + defaultMessage: 'At least one health check has to be selected', + } + ) + ); + } + return validationResult; }, requiresAppContext: false, @@ -56,7 +71,8 @@ export function getTransformHealthRuleType(): RuleTypeModel = React.memo( > ; +} + +export type TransformHealthResult = NotStartedTransformResponse | ErrorMessagesTransformResponse; export type TransformHealthAlertContext = { results: TransformHealthResult[]; @@ -105,7 +109,7 @@ export function getTransformHealthRuleType(): RuleType< } = options; const transformHealthService = transformHealthServiceProvider( - scopedClusterClient.asInternalUser + scopedClusterClient.asCurrentUser ); const executionResult = await transformHealthService.getHealthChecksResults(params); diff --git a/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/schema.ts b/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/schema.ts index 5a7af83b120d6..e98d6edd294ac 100644 --- a/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/schema.ts +++ b/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/schema.ts @@ -17,6 +17,11 @@ export const transformHealthRuleParams = schema.object({ enabled: schema.boolean({ defaultValue: true }), }) ), + errorMessages: schema.nullable( + schema.object({ + enabled: schema.boolean({ defaultValue: true }), + }) + ), }) ), }); diff --git a/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/transform_health_service.ts b/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/transform_health_service.ts index 7aebf83b27cca..90b6c2fbcba60 100644 --- a/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/transform_health_service.ts +++ b/x-pack/plugins/transform/server/lib/alerting/transform_health_rule_type/transform_health_service.ts @@ -14,15 +14,18 @@ import { ALL_TRANSFORMS_SELECTION, TRANSFORM_HEALTH_CHECK_NAMES, TRANSFORM_RULE_TYPE, + TRANSFORM_STATE, } from '../../../../common/constants'; import { getResultTestConfig } from '../../../../common/utils/alerts'; import { + ErrorMessagesTransformResponse, NotStartedTransformResponse, TransformHealthAlertContext, } from './register_transform_health_rule_type'; import type { RulesClient } from '../../../../../alerting/server'; import type { TransformHealthAlertRule } from '../../../../common/types/alerting'; import { isContinuousTransform } from '../../../../common/types/transform'; +import { ML_DF_NOTIFICATION_INDEX_PATTERN } from '../../../routes/api/transforms_audit_messages'; interface TestResult { name: string; @@ -101,7 +104,7 @@ export function transformHealthServiceProvider( ).transforms; return transformsStats - .filter((t) => t.state !== 'started' && t.state !== 'indexing') + .filter((t) => t.state !== TRANSFORM_STATE.STARTED && t.state !== TRANSFORM_STATE.INDEXING) .map((t) => ({ transform_id: t.id, description: transformsDict.get(t.id)?.description, @@ -109,6 +112,80 @@ export function transformHealthServiceProvider( node_name: t.node?.name, })); }, + /** + * Returns report about transforms that contain error messages + * @param transformIds + */ + async getErrorMessagesReport( + transformIds: string[] + ): Promise { + interface TransformErrorsBucket { + key: string; + doc_count: number; + error_messages: estypes.AggregationsTopHitsAggregate; + } + + const response = await esClient.search< + unknown, + Record<'by_transform', estypes.AggregationsMultiBucketAggregateBase> + >({ + index: ML_DF_NOTIFICATION_INDEX_PATTERN, + size: 0, + query: { + bool: { + filter: [ + { + term: { + level: 'error', + }, + }, + { + terms: { + transform_id: transformIds, + }, + }, + ], + }, + }, + aggs: { + by_transform: { + terms: { + field: 'transform_id', + size: transformIds.length, + }, + aggs: { + error_messages: { + top_hits: { + size: 10, + _source: { + includes: ['message', 'level', 'timestamp', 'node_name'], + }, + }, + }, + }, + }, + }, + }); + + // If transform contains errors, it's in a failed state + const transformsStats = ( + await esClient.transform.getTransformStats({ + transform_id: transformIds.join(','), + }) + ).transforms; + const failedTransforms = new Set( + transformsStats.filter((t) => t.state === TRANSFORM_STATE.FAILED).map((t) => t.id) + ); + + return (response.aggregations?.by_transform.buckets as TransformErrorsBucket[]) + .map(({ key, error_messages: errorMessages }) => { + return { + transform_id: key, + error_messages: errorMessages.hits.hits.map((v) => v._source), + } as ErrorMessagesTransformResponse; + }) + .filter((v) => failedTransforms.has(v.transform_id)); + }, /** * Returns results of the transform health checks * @param params @@ -137,7 +214,30 @@ export function transformHealthServiceProvider( 'xpack.transform.alertTypes.transformHealth.notStartedMessage', { defaultMessage: - '{count, plural, one {Transform} other {Transforms}} {transformsString} {count, plural, one {is} other {are}} not started.', + '{count, plural, one {Transform} other {Transform}} {transformsString} {count, plural, one {is} other {are}} not started.', + values: { count, transformsString }, + } + ), + }, + }); + } + } + + if (testsConfig.errorMessages.enabled) { + const response = await this.getErrorMessagesReport(transformIds); + if (response.length > 0) { + const count = response.length; + const transformsString = response.map((t) => t.transform_id).join(', '); + + result.push({ + name: TRANSFORM_HEALTH_CHECK_NAMES.errorMessages.name, + context: { + results: response, + message: i18n.translate( + 'xpack.transform.alertTypes.transformHealth.errorMessagesMessage', + { + defaultMessage: + '{count, plural, one {Transform} other {Transforms}} {transformsString} {count, plural, one {contains} other {contain}} error messages.', values: { count, transformsString }, } ), diff --git a/x-pack/plugins/transform/server/routes/api/transforms_audit_messages.ts b/x-pack/plugins/transform/server/routes/api/transforms_audit_messages.ts index a6d732b1208b3..4be207a21ac29 100644 --- a/x-pack/plugins/transform/server/routes/api/transforms_audit_messages.ts +++ b/x-pack/plugins/transform/server/routes/api/transforms_audit_messages.ts @@ -14,7 +14,7 @@ import { addBasePath } from '../index'; import { wrapError, wrapEsError } from './error_utils'; -const ML_DF_NOTIFICATION_INDEX_PATTERN = '.transform-notifications-read'; +export const ML_DF_NOTIFICATION_INDEX_PATTERN = '.transform-notifications-read'; const SIZE = 500; interface BoolQuery { From 490cd51abcc5e49e636516308ac6b2e284cf3394 Mon Sep 17 00:00:00 2001 From: Kyle Pollich Date: Tue, 29 Mar 2022 14:40:41 -0400 Subject: [PATCH 110/160] Fix Windows Expand-Archive command for agent install (#128785) --- .../agent_enrollment_flyout/standalone_instructions.tsx | 2 +- .../public/components/enrollment_instructions/manual/index.tsx | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx index 9dd787d74a6e2..4fabb36b99a45 100644 --- a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx @@ -66,7 +66,7 @@ tar xzvf elastic-agent-${kibanaVersion}-darwin-x86_64.tar.gz sudo ./elastic-agent install`; const STANDALONE_RUN_INSTRUCTIONS_WINDOWS = `wget https://artifacts.elastic.co/downloads/beats/elastic-agent/elastic-agent-${kibanaVersion}-windows-x86_64.zip -OutFile elastic-agent-${kibanaVersion}-windows-x86_64.zip -Expand-Archive .\elastic-agent-${kibanaVersion}-windows-x86_64.zip +Expand-Archive .\\elastic-agent-${kibanaVersion}-windows-x86_64.zip .\\elastic-agent.exe install`; const linuxDebCommand = `curl -L -O https://artifacts.elastic.co/downloads/beats/elastic-agent/elastic-agent-${kibanaVersion}-amd64.deb diff --git a/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx b/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx index 39ad23a859900..4279e46cbcd66 100644 --- a/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx +++ b/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx @@ -40,7 +40,7 @@ cd elastic-agent-${kibanaVersion}-darwin-x86_64 sudo ./elastic-agent install ${enrollArgs}`; const windowsCommand = `wget https://artifacts.elastic.co/downloads/beats/elastic-agent/elastic-agent-${kibanaVersion}-windows-x86_64.zip -OutFile elastic-agent-${kibanaVersion}-windows-x86_64.zip -Expand-Archive .\elastic-agent-${kibanaVersion}-windows-x86_64.zip +Expand-Archive .\\elastic-agent-${kibanaVersion}-windows-x86_64.zip .\\elastic-agent.exe install ${enrollArgs}`; const linuxDebCommand = `curl -L -O https://artifacts.elastic.co/downloads/beats/elastic-agent/elastic-agent-${kibanaVersion}-amd64.deb From 038f091311f9b469dd2333bb40b8069954faaef4 Mon Sep 17 00:00:00 2001 From: Dominique Clarke Date: Tue, 29 Mar 2022 14:47:23 -0400 Subject: [PATCH 111/160] [Uptime] allow an administrator to enable and disable monitor management (#128223) * uptime - allow an administrator to enable monitor management Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> Co-authored-by: shahzad31 --- .../uptime/common/constants/rest_api.ts | 1 + .../runtime_types/monitor_management/state.ts | 14 +- x-pack/plugins/uptime/e2e/journeys/index.ts | 1 + .../journeys/monitor_management.journey.ts | 30 +- .../monitor_management_enablement.journey.ts | 76 +++++ .../e2e/journeys/monitor_name.journey.ts | 14 +- .../read_only_user/monitor_management.ts | 2 +- .../e2e/page_objects/monitor_management.tsx | 71 +++- .../uptime/e2e/tasks/uptime_monitor.ndjson | 3 +- .../common/header/action_menu_content.tsx | 4 +- .../monitor_management/add_monitor_btn.tsx | 198 ++++++++++- .../monitor_management/content/index.ts | 36 ++ .../hooks/use_enablement.ts | 45 +++ .../hooks/use_inline_errors.test.tsx | 5 +- .../hooks/use_inline_errors_count.test.tsx | 5 +- .../hooks/use_locations.test.tsx | 3 + .../monitor_management/loader/loader.tsx | 1 + .../monitor_list/enablement_empty_state.tsx | 133 ++++++++ .../monitor_list/invalid_monitors.tsx | 5 +- .../monitor_list/monitor_list.test.tsx | 3 + .../monitor_list/monitor_list.tsx | 2 +- .../monitor_list/monitor_list_container.tsx | 119 +++++++ .../monitor_list/columns/test_now_col.tsx | 2 +- .../public/lib/__mocks__/uptime_store.mock.ts | 3 + .../pages/monitor_management/add_monitor.tsx | 2 +- .../pages/monitor_management/edit_monitor.tsx | 4 +- .../monitor_management/monitor_management.tsx | 205 +++++++----- .../service_allowed_wrapper.test.tsx | 4 +- .../service_allowed_wrapper.tsx | 6 +- .../use_monitor_management_breadcrumbs.tsx | 2 +- .../state/actions/monitor_management.ts | 16 + .../public/state/api/monitor_management.ts | 19 ++ .../state/effects/monitor_management.ts | 34 +- .../state/reducers/monitor_management.ts | 132 +++++++- .../uptime/server/lib/requests/index.ts | 10 + .../lib/saved_objects/service_api_key.ts | 9 + .../synthetics_service/get_api_key.test.ts | 35 +- .../lib/synthetics_service/get_api_key.ts | 120 +++++-- .../synthetics_service/synthetics_service.ts | 77 +++-- .../plugins/uptime/server/rest_api/index.ts | 16 +- .../synthetics_service/add_monitor.ts | 2 +- .../synthetics_service/delete_monitor.ts | 2 +- .../synthetics_service/edit_monitor.ts | 2 +- .../rest_api/synthetics_service/enablement.ts | 81 +++++ .../synthetics_service/run_once_monitor.ts | 2 +- .../telemetry/monitor_upgrade_sender.ts | 6 +- .../apis/uptime/rest/get_monitor.ts | 4 +- .../api_integration/apis/uptime/rest/index.ts | 1 + .../apis/uptime/rest/synthetics_enablement.ts | 316 ++++++++++++++++++ 49 files changed, 1633 insertions(+), 250 deletions(-) create mode 100644 x-pack/plugins/uptime/e2e/journeys/monitor_management_enablement.journey.ts create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/content/index.ts create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/hooks/use_enablement.ts create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/enablement_empty_state.tsx create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx create mode 100644 x-pack/plugins/uptime/server/rest_api/synthetics_service/enablement.ts create mode 100644 x-pack/test/api_integration/apis/uptime/rest/synthetics_enablement.ts diff --git a/x-pack/plugins/uptime/common/constants/rest_api.ts b/x-pack/plugins/uptime/common/constants/rest_api.ts index c163718e0fc13..fba2c2b750a4a 100644 --- a/x-pack/plugins/uptime/common/constants/rest_api.ts +++ b/x-pack/plugins/uptime/common/constants/rest_api.ts @@ -40,6 +40,7 @@ export enum API_URLS { INDEX_TEMPLATES = '/internal/uptime/service/index_templates', SERVICE_LOCATIONS = '/internal/uptime/service/locations', SYNTHETICS_MONITORS = '/internal/uptime/service/monitors', + SYNTHETICS_ENABLEMENT = '/internal/uptime/service/enablement', RUN_ONCE_MONITOR = '/internal/uptime/service/monitors/run_once', TRIGGER_MONITOR = '/internal/uptime/service/monitors/trigger', SERVICE_ALLOWED = '/internal/uptime/service/allowed', diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/state.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/state.ts index 8119fbca4b9e7..c95ec2f50a529 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/state.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/state.ts @@ -7,7 +7,7 @@ import * as t from 'io-ts'; -export const FetchMonitorManagementListQueryArgsType = t.partial({ +export const FetchMonitorManagementListQueryArgsCodec = t.partial({ page: t.number, perPage: t.number, sortField: t.string, @@ -17,5 +17,15 @@ export const FetchMonitorManagementListQueryArgsType = t.partial({ }); export type FetchMonitorManagementListQueryArgs = t.TypeOf< - typeof FetchMonitorManagementListQueryArgsType + typeof FetchMonitorManagementListQueryArgsCodec +>; + +export const MonitorManagementEnablementResultCodec = t.type({ + isEnabled: t.boolean, + canEnable: t.boolean, + areApiKeysEnabled: t.boolean, +}); + +export type MonitorManagementEnablementResult = t.TypeOf< + typeof MonitorManagementEnablementResultCodec >; diff --git a/x-pack/plugins/uptime/e2e/journeys/index.ts b/x-pack/plugins/uptime/e2e/journeys/index.ts index a01502eb84f58..8430dfec98642 100644 --- a/x-pack/plugins/uptime/e2e/journeys/index.ts +++ b/x-pack/plugins/uptime/e2e/journeys/index.ts @@ -13,4 +13,5 @@ export * from './read_only_user'; export * from './monitor_details.journey'; export * from './monitor_name.journey'; export * from './monitor_management.journey'; +export * from './monitor_management_enablement.journey'; export * from './monitor_details'; diff --git a/x-pack/plugins/uptime/e2e/journeys/monitor_management.journey.ts b/x-pack/plugins/uptime/e2e/journeys/monitor_management.journey.ts index 309cc5eb0ec6d..7dfc7e4e6ab66 100644 --- a/x-pack/plugins/uptime/e2e/journeys/monitor_management.journey.ts +++ b/x-pack/plugins/uptime/e2e/journeys/monitor_management.journey.ts @@ -96,18 +96,14 @@ const createMonitorJourney = ({ async ({ page, params }: { page: Page; params: any }) => { const uptime = monitorManagementPageProvider({ page, kibanaUrl: params.kibanaUrl }); const isRemote = process.env.SYNTHETICS_REMOTE_ENABLED; - const deleteMonitor = async () => { - await uptime.navigateToMonitorManagement(); - const isSuccessful = await uptime.deleteMonitor(); - expect(isSuccessful).toBeTruthy(); - }; before(async () => { await uptime.waitForLoadingToFinish(); }); after(async () => { - await deleteMonitor(); + await uptime.navigateToMonitorManagement(); + await uptime.enableMonitorManagement(false); }); step('Go to monitor-management', async () => { @@ -123,13 +119,14 @@ const createMonitorJourney = ({ }); step(`create ${monitorType} monitor`, async () => { + await uptime.enableMonitorManagement(); await uptime.clickAddMonitor(); await uptime.createMonitor({ monitorConfig, monitorType }); const isSuccessful = await uptime.confirmAndSave(); expect(isSuccessful).toBeTruthy(); }); - step(`view ${monitorType} details in monitor management UI`, async () => { + step(`view ${monitorType} details in Monitor Management UI`, async () => { await uptime.navigateToMonitorManagement(); const hasFailure = await uptime.findMonitorConfiguration(monitorDetails); expect(hasFailure).toBeFalsy(); @@ -141,6 +138,12 @@ const createMonitorJourney = ({ await page.waitForSelector(`text=${monitorName}`, { timeout: 160 * 1000 }); }); } + + step('delete monitor', async () => { + await uptime.navigateToMonitorManagement(); + const isSuccessful = await uptime.deleteMonitors(); + expect(isSuccessful).toBeTruthy(); + }); } ); }; @@ -167,6 +170,10 @@ journey('Monitor Management breadcrumbs', async ({ page, params }: { page: Page; await uptime.waitForLoadingToFinish(); }); + after(async () => { + await uptime.enableMonitorManagement(false); + }); + step('Go to monitor-management', async () => { await uptime.navigateToMonitorManagement(); }); @@ -177,13 +184,14 @@ journey('Monitor Management breadcrumbs', async ({ page, params }: { page: Page; step('Check breadcrumb', async () => { const lastBreadcrumb = await (await uptime.findByTestSubj('"breadcrumb last"')).textContent(); - expect(lastBreadcrumb).toEqual('Monitor management'); + expect(lastBreadcrumb).toEqual('Monitor Management'); }); step('check breadcrumbs', async () => { + await uptime.enableMonitorManagement(); await uptime.clickAddMonitor(); const breadcrumbs = await page.$$('[data-test-subj="breadcrumb"]'); - expect(await breadcrumbs[1].textContent()).toEqual('Monitor management'); + expect(await breadcrumbs[1].textContent()).toEqual('Monitor Management'); const lastBreadcrumb = await (await uptime.findByTestSubj('"breadcrumb last"')).textContent(); expect(lastBreadcrumb).toEqual('Add monitor'); }); @@ -204,14 +212,14 @@ journey('Monitor Management breadcrumbs', async ({ page, params }: { page: Page; // breadcrumb is available before edit page is loaded, make sure its edit view await page.waitForSelector(byTestId('monitorManagementMonitorName'), { timeout: 60 * 1000 }); const breadcrumbs = await page.$$('[data-test-subj=breadcrumb]'); - expect(await breadcrumbs[1].textContent()).toEqual('Monitor management'); + expect(await breadcrumbs[1].textContent()).toEqual('Monitor Management'); const lastBreadcrumb = await (await uptime.findByTestSubj('"breadcrumb last"')).textContent(); expect(lastBreadcrumb).toEqual('Edit monitor'); }); step('delete monitor', async () => { await uptime.navigateToMonitorManagement(); - const isSuccessful = await uptime.deleteMonitor(); + const isSuccessful = await uptime.deleteMonitors(); expect(isSuccessful).toBeTruthy(); }); }); diff --git a/x-pack/plugins/uptime/e2e/journeys/monitor_management_enablement.journey.ts b/x-pack/plugins/uptime/e2e/journeys/monitor_management_enablement.journey.ts new file mode 100644 index 0000000000000..14232336799d4 --- /dev/null +++ b/x-pack/plugins/uptime/e2e/journeys/monitor_management_enablement.journey.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { journey, step, expect, before, after, Page } from '@elastic/synthetics'; +import { monitorManagementPageProvider } from '../page_objects/monitor_management'; + +journey( + 'Monitor Management-enablement-superuser', + async ({ page, params }: { page: Page; params: any }) => { + const uptime = monitorManagementPageProvider({ page, kibanaUrl: params.kibanaUrl }); + + before(async () => { + await uptime.waitForLoadingToFinish(); + }); + + after(async () => { + await uptime.enableMonitorManagement(false); + }); + + step('Go to monitor-management', async () => { + await uptime.navigateToMonitorManagement(); + }); + + step('login to Kibana', async () => { + await uptime.loginToKibana(); + const invalid = await page.locator( + `text=Username or password is incorrect. Please try again.` + ); + expect(await invalid.isVisible()).toBeFalsy(); + }); + + step('check add monitor button', async () => { + expect(await uptime.checkIsEnabled()).toBe(false); + }); + + step('enable Monitor Management', async () => { + await uptime.enableMonitorManagement(); + expect(await uptime.checkIsEnabled()).toBe(true); + }); + } +); + +journey( + 'MonitorManagement-enablement-obs-admin', + async ({ page, params }: { page: Page; params: any }) => { + const uptime = monitorManagementPageProvider({ page, kibanaUrl: params.kibanaUrl }); + + before(async () => { + await uptime.waitForLoadingToFinish(); + }); + + step('Go to monitor-management', async () => { + await uptime.navigateToMonitorManagement(); + }); + + step('login to Kibana', async () => { + await uptime.loginToKibana('obs_admin_user', 'changeme'); + const invalid = await page.locator( + `text=Username or password is incorrect. Please try again.` + ); + expect(await invalid.isVisible()).toBeFalsy(); + }); + + step('check add monitor button', async () => { + expect(await uptime.checkIsEnabled()).toBe(false); + }); + + step('check that enabled toggle does not appear', async () => { + expect(await page.$(`[data-test-subj=syntheticsEnableSwitch]`)).toBeFalsy(); + }); + } +); diff --git a/x-pack/plugins/uptime/e2e/journeys/monitor_name.journey.ts b/x-pack/plugins/uptime/e2e/journeys/monitor_name.journey.ts index 456d219adef05..624538244e6d1 100644 --- a/x-pack/plugins/uptime/e2e/journeys/monitor_name.journey.ts +++ b/x-pack/plugins/uptime/e2e/journeys/monitor_name.journey.ts @@ -12,7 +12,7 @@ * 2.0. */ -import { journey, step, expect, after, before, Page } from '@elastic/synthetics'; +import { journey, step, expect, before, Page } from '@elastic/synthetics'; import { monitorManagementPageProvider } from '../page_objects/monitor_management'; import { byTestId } from './utils'; @@ -23,11 +23,6 @@ journey(`MonitorName`, async ({ page, params }: { page: Page; params: any }) => await uptime.waitForLoadingToFinish(); }); - after(async () => { - await uptime.navigateToMonitorManagement(); - await uptime.deleteMonitor(); - }); - step('Go to monitor-management', async () => { await uptime.navigateToMonitorManagement(); }); @@ -39,6 +34,7 @@ journey(`MonitorName`, async ({ page, params }: { page: Page; params: any }) => }); step(`shows error if name already exists`, async () => { + await uptime.enableMonitorManagement(); await uptime.clickAddMonitor(); await uptime.createBasicMonitorDetails({ name: 'Test monitor', @@ -61,4 +57,10 @@ journey(`MonitorName`, async ({ page, params }: { page: Page; params: any }) => expect(await page.isEnabled(byTestId('monitorTestNowRunBtn'))).toBeTruthy(); }); + + step('delete monitor', async () => { + await uptime.navigateToMonitorManagement(); + await uptime.deleteMonitors(); + await uptime.enableMonitorManagement(false); + }); }); diff --git a/x-pack/plugins/uptime/e2e/journeys/read_only_user/monitor_management.ts b/x-pack/plugins/uptime/e2e/journeys/read_only_user/monitor_management.ts index 89d394e945cee..da2958c3775dd 100644 --- a/x-pack/plugins/uptime/e2e/journeys/read_only_user/monitor_management.ts +++ b/x-pack/plugins/uptime/e2e/journeys/read_only_user/monitor_management.ts @@ -27,7 +27,7 @@ journey( }); step('Adding monitor is disabled', async () => { - expect(await page.isEnabled(byTestId('addMonitorBtn'))).toBeFalsy(); + expect(await page.isEnabled(byTestId('syntheticsAddMonitorBtn'))).toBeFalsy(); }); } ); diff --git a/x-pack/plugins/uptime/e2e/page_objects/monitor_management.tsx b/x-pack/plugins/uptime/e2e/page_objects/monitor_management.tsx index b56cd8a361684..eb13c3678f47e 100644 --- a/x-pack/plugins/uptime/e2e/page_objects/monitor_management.tsx +++ b/x-pack/plugins/uptime/e2e/page_objects/monitor_management.tsx @@ -4,7 +4,6 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ - import { Page } from '@elastic/synthetics'; import { DataStream } from '../../common/runtime_types/monitor_management'; import { getQuerystring } from '../journeys/utils'; @@ -39,6 +38,60 @@ export function monitorManagementPageProvider({ await page.goto(monitorManagement, { waitUntil: 'networkidle', }); + await this.waitForMonitorManagementLoadingToFinish(); + }, + + async waitForMonitorManagementLoadingToFinish() { + while (true) { + if ((await page.$(this.byTestId('uptimeLoader'))) === null) break; + await page.waitForTimeout(5 * 1000); + } + }, + + async enableMonitorManagement(shouldEnable: boolean = true) { + const isEnabled = await this.checkIsEnabled(); + if (isEnabled === shouldEnable) { + return; + } + const [toggle, button] = await Promise.all([ + page.$(this.byTestId('syntheticsEnableSwitch')), + page.$(this.byTestId('syntheticsEnableButton')), + ]); + + if (toggle === null && button === null) { + return null; + } + if (toggle) { + if (isEnabled !== shouldEnable) { + await toggle.click(); + } + } else { + await button?.click(); + } + if (shouldEnable) { + await this.findByText('Monitor Management enabled successfully.'); + } else { + await this.findByText('Monitor Management disabled successfully.'); + } + }, + + async getEnableToggle() { + return await this.findByTestSubj('syntheticsEnableSwitch'); + }, + + async getEnableButton() { + return await this.findByTestSubj('syntheticsEnableSwitch'); + }, + + async getAddMonitorButton() { + return await this.findByTestSubj('syntheticsAddMonitorBtn'); + }, + + async checkIsEnabled() { + await page.waitForTimeout(5 * 1000); + const addMonitorBtn = await this.getAddMonitorButton(); + const isDisabled = await addMonitorBtn.isDisabled(); + return !isDisabled; }, async navigateToAddMonitor() { @@ -57,10 +110,18 @@ export function monitorManagementPageProvider({ await page.click('text=Add monitor'); }, - async deleteMonitor() { - await this.clickByTestSubj('monitorManagementDeleteMonitor'); - await this.clickByTestSubj('confirmModalConfirmButton'); - return await this.findByTestSubj('uptimeDeleteMonitorSuccess'); + async deleteMonitors() { + let isSuccessful: boolean = false; + await page.waitForSelector('[data-test-subj="monitorManagementDeleteMonitor"]'); + while (true) { + if ((await page.$(this.byTestId('monitorManagementDeleteMonitor'))) === null) break; + await page.click(this.byTestId('monitorManagementDeleteMonitor'), { delay: 800 }); + await page.waitForSelector('[data-test-subj="confirmModalTitleText"]'); + await this.clickByTestSubj('confirmModalConfirmButton'); + isSuccessful = Boolean(await this.findByTestSubj('uptimeDeleteMonitorSuccess')); + await page.waitForTimeout(5 * 1000); + } + return isSuccessful; }, async editMonitor() { diff --git a/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson b/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson index 308be283a86b8..bb8acca240094 100644 --- a/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson +++ b/x-pack/plugins/uptime/e2e/tasks/uptime_monitor.ndjson @@ -1,3 +1,2 @@ {"attributes":{"__ui":{"is_tls_enabled":false,"is_zip_url_tls_enabled":false},"check.request.method":"GET","check.response.status":[],"enabled":true,"locations":[{"geo":{"lat":41.25,"lon":-95.86},"id":"us_central","label":"US Central","url":"https://us-central.synthetics.elastic.dev"}],"max_redirects":"0","name":"Test Monitor","proxy_url":"","response.include_body":"on_error","response.include_headers":true,"schedule":{"number":"3","unit":"m"},"service.name":"","tags":[],"timeout":"16","type":"http","urls":"https://www.google.com", "secrets": "{}"},"coreMigrationVersion":"8.1.0","id":"832b9980-7fba-11ec-b360-25a79ce3f496","references":[],"sort":[1643319958480,20371],"type":"synthetics-monitor","updated_at":"2022-01-27T21:45:58.480Z","version":"WzExOTg3ODYsMl0="} -{"attributes":{"__ui":{"is_tls_enabled":false,"is_zip_url_tls_enabled":false},"check.request.method":"GET","check.response.status":[],"enabled":true,"locations":[{"geo":{"lat":41.25,"lon":-95.86},"id":"us_central","label":"US Central","url":"https://us-central.synthetics.elastic.dev"}],"max_redirects":"0","name":"Test Monito","proxy_url":"","response.include_body":"on_error","response.include_headers":true,"schedule":{"number":"3","unit":"m"},"service.name":"","tags":[],"timeout":"16","type":"http","urls":"https://www.google.com", "secrets": "{}"},"coreMigrationVersion":"8.1.0","id":"b28380d0-7fba-11ec-b360-25a79ce3f496","references":[],"sort":[1643320037906,20374],"type":"synthetics-monitor","updated_at":"2022-01-27T21:47:17.906Z","version":"WzExOTg4MDAsMl0="} -{"excludedObjects":[],"excludedObjectsCount":0,"exportedCount":2,"missingRefCount":0,"missingReferences":[]} \ No newline at end of file +{"excludedObjects":[],"excludedObjectsCount":0,"exportedCount":2,"missingRefCount":0,"missingReferences":[]} diff --git a/x-pack/plugins/uptime/public/components/common/header/action_menu_content.tsx b/x-pack/plugins/uptime/public/components/common/header/action_menu_content.tsx index f83c71ada73a9..54d53ec6d4b1e 100644 --- a/x-pack/plugins/uptime/public/components/common/header/action_menu_content.tsx +++ b/x-pack/plugins/uptime/public/components/common/header/action_menu_content.tsx @@ -78,7 +78,7 @@ export function ActionMenuContent(): React.ReactElement { diff --git a/x-pack/plugins/uptime/public/components/monitor_management/add_monitor_btn.tsx b/x-pack/plugins/uptime/public/components/monitor_management/add_monitor_btn.tsx index ddf0f009aeefe..f7ff56cd2f095 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/add_monitor_btn.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/add_monitor_btn.tsx @@ -5,39 +5,203 @@ * 2.0. */ -import React from 'react'; +import React, { useEffect, useState } from 'react'; import { i18n } from '@kbn/i18n'; -import { EuiButton, EuiFlexItem } from '@elastic/eui'; +import { EuiButton, EuiFlexItem, EuiFlexGroup, EuiToolTip, EuiSwitch } from '@elastic/eui'; import { useHistory } from 'react-router-dom'; +import { kibanaService } from '../../state/kibana_service'; import { MONITOR_ADD_ROUTE } from '../../../common/constants'; +import { useEnablement } from './hooks/use_enablement'; import { useSyntheticsServiceAllowed } from './hooks/use_service_allowed'; import { useKibana } from '../../../../../../src/plugins/kibana_react/public'; export const AddMonitorBtn = () => { const history = useHistory(); + const [isEnabling, setIsEnabling] = useState(false); + const [isDisabling, setIsDisabling] = useState(false); + const { + error, + loading: enablementLoading, + enablement, + disableSynthetics, + enableSynthetics, + totalMonitors, + } = useEnablement(); + const { isEnabled, canEnable, areApiKeysEnabled } = enablement || {}; - const { isAllowed, loading } = useSyntheticsServiceAllowed(); + useEffect(() => { + if (isEnabling && isEnabled) { + setIsEnabling(false); + kibanaService.toasts.addSuccess({ + title: SYNTHETICS_ENABLE_SUCCESS, + toastLifeTimeMs: 3000, + }); + } else if (isDisabling && !isEnabled) { + setIsDisabling(false); + kibanaService.toasts.addSuccess({ + title: SYNTHETICS_DISABLE_SUCCESS, + toastLifeTimeMs: 3000, + }); + } else if (isEnabling && error) { + setIsEnabling(false); + kibanaService.toasts.addDanger({ + title: SYNTHETICS_ENABLE_FAILURE, + toastLifeTimeMs: 3000, + }); + } else if (isDisabling && error) { + kibanaService.toasts.addDanger({ + title: SYNTHETICS_DISABLE_FAILURE, + toastLifeTimeMs: 3000, + }); + } + }, [isEnabled, isEnabling, isDisabling, error]); + + const handleSwitch = () => { + if (isEnabled) { + setIsDisabling(true); + disableSynthetics(); + } else { + setIsEnabling(true); + enableSynthetics(); + } + }; + + const getShowSwitch = () => { + if (isEnabled) { + return canEnable; + } else if (!isEnabled) { + return canEnable && (totalMonitors || 0) > 0; + } + }; + + const getSwitchToolTipContent = () => { + if (!isEnabled) { + return SYNTHETICS_ENABLE_TOOL_TIP_MESSAGE; + } else if (isEnabled) { + return SYNTHETICS_DISABLE_TOOL_TIP_MESSAGE; + } else if (!areApiKeysEnabled) { + return API_KEYS_DISABLED_TOOL_TIP_MESSAGE; + } else { + return ''; + } + }; + + const { isAllowed, loading: allowedLoading } = useSyntheticsServiceAllowed(); + + const loading = allowedLoading || enablementLoading; const canSave: boolean = !!useKibana().services?.application?.capabilities.uptime.save; return ( - - - {ADD_MONITOR_LABEL} - - + + + {getShowSwitch() && !loading && ( + + handleSwitch()} + data-test-subj="syntheticsEnableSwitch" + /> + + )} + {getShowSwitch() && loading && ( + {}} + /> + )} + + + + + {ADD_MONITOR_LABEL} + + + + ); }; const ADD_MONITOR_LABEL = i18n.translate('xpack.uptime.monitorManagement.addMonitorLabel', { defaultMessage: 'Add monitor', }); + +const SYNTHETICS_ENABLE_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnableLabel', + { + defaultMessage: 'Enable', + } +); + +const SYNTHETICS_ENABLE_FAILURE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnabledFailure', + { + defaultMessage: 'Monitor Management was not able to be enabled. Please contact support.', + } +); + +const SYNTHETICS_DISABLE_FAILURE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsDisabledFailure', + { + defaultMessage: 'Monitor Management was not able to be disabled. Please contact support.', + } +); + +const SYNTHETICS_ENABLE_SUCCESS = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnableSuccess', + { + defaultMessage: 'Monitor Management enabled successfully.', + } +); + +const SYNTHETICS_DISABLE_SUCCESS = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsDisabledSuccess', + { + defaultMessage: 'Monitor Management disabled successfully.', + } +); + +const SYNTHETICS_DISABLED_MESSAGE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsDisabled', + { + defaultMessage: + 'Monitor Management is currently disabled. Please contact an administrator to enable Monitor Management.', + } +); + +const SYNTHETICS_ENABLE_TOOL_TIP_MESSAGE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnableToolTip', + { + defaultMessage: + 'Enable Monitor Management to create lightweight and real-browser monitors from locations around the world.', + } +); + +const SYNTHETICS_DISABLE_TOOL_TIP_MESSAGE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsDisableToolTip', + { + defaultMessage: + 'Disabling Monitor Management with immediately stop the execution of monitors in all test locations and prevent the creation of new monitors.', + } +); + +const API_KEYS_DISABLED_TOOL_TIP_MESSAGE = i18n.translate( + 'xpack.uptime.monitorManagement.apiKeysDisabledToolTip', + { + defaultMessage: + 'API Keys are disabled for this cluster. Monitor Management requires the use of API keys to write back to your Elasticsearch cluster. To enable API keys, please contact an administrator.', + } +); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/content/index.ts b/x-pack/plugins/uptime/public/components/monitor_management/content/index.ts new file mode 100644 index 0000000000000..369506a12b3d9 --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/content/index.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { i18n } from '@kbn/i18n'; + +export const SYNTHETICS_ENABLE_FAILURE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnabledFailure', + { + defaultMessage: 'Monitor Management was not able to be enabled. Please contact support.', + } +); + +export const SYNTHETICS_DISABLE_FAILURE = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsDisabledFailure', + { + defaultMessage: 'Monitor Management was not able to be disabled. Please contact support.', + } +); + +export const SYNTHETICS_ENABLE_SUCCESS = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnableSuccess', + { + defaultMessage: 'Monitor Management enabled successfully.', + } +); + +export const SYNTHETICS_DISABLE_SUCCESS = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsDisabledSuccess', + { + defaultMessage: 'Monitor Management disabled successfully.', + } +); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_enablement.ts b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_enablement.ts new file mode 100644 index 0000000000000..f4c17a767c4e3 --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_enablement.ts @@ -0,0 +1,45 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { useEffect, useCallback } from 'react'; +import { useDispatch, useSelector } from 'react-redux'; +import { monitorManagementListSelector } from '../../../state/selectors'; +import { + getSyntheticsEnablement, + disableSynthetics, + enableSynthetics, +} from '../../../state/actions'; + +export function useEnablement() { + const dispatch = useDispatch(); + + const { + loading: { enablement: loading }, + error: { enablement: error }, + enablement, + list: { total }, + } = useSelector(monitorManagementListSelector); + + useEffect(() => { + if (!enablement) { + dispatch(getSyntheticsEnablement()); + } + }, [dispatch, enablement]); + + return { + enablement: { + areApiKeysEnabled: enablement?.areApiKeysEnabled, + canEnable: enablement?.canEnable, + isEnabled: enablement?.isEnabled, + }, + error, + loading, + totalMonitors: total, + enableSynthetics: useCallback(() => dispatch(enableSynthetics()), [dispatch]), + disableSynthetics: useCallback(() => dispatch(disableSynthetics()), [dispatch]), + }; +} diff --git a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors.test.tsx index 4eabc1fa1eb64..49c069bc3757f 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors.test.tsx @@ -68,9 +68,10 @@ describe('useInlineErrors', function () { [ 'heartbeat-8*,heartbeat-7*,synthetics-*', { - error: { monitorList: null, serviceLocations: null }, + error: { monitorList: null, serviceLocations: null, enablement: null }, + enablement: null, list: { monitors: [], page: 1, perPage: 10, total: null }, - loading: { monitorList: false, serviceLocations: false }, + loading: { monitorList: false, serviceLocations: false, enablement: false }, locations: [], syntheticsService: { loading: false, diff --git a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors_count.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors_count.test.tsx index 66961fe66b0f7..8a9115b1490ad 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors_count.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_inline_errors_count.test.tsx @@ -67,9 +67,10 @@ describe('useInlineErrorsCount', function () { [ 'heartbeat-8*,heartbeat-7*,synthetics-*', { - error: { monitorList: null, serviceLocations: null }, + error: { monitorList: null, serviceLocations: null, enablement: null }, list: { monitors: [], page: 1, perPage: 10, total: null }, - loading: { monitorList: false, serviceLocations: false }, + enablement: null, + loading: { monitorList: false, serviceLocations: false, enablement: false }, locations: [], syntheticsService: { loading: false, diff --git a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_locations.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_locations.test.tsx index 8c58a4a28ea8c..8d272baa88e95 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_locations.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/hooks/use_locations.test.tsx @@ -42,13 +42,16 @@ describe('useExpViewTimeRange', function () { monitors: [], }, locations: [], + enablement: null, error: { serviceLocations: error, monitorList: null, + enablement: null, }, loading: { monitorList: false, serviceLocations: loading, + enablement: false, }, syntheticsService: { loading: false, diff --git a/x-pack/plugins/uptime/public/components/monitor_management/loader/loader.tsx b/x-pack/plugins/uptime/public/components/monitor_management/loader/loader.tsx index 8b3b64a3f91c8..fbaf5c1d536cf 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/loader/loader.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/loader/loader.tsx @@ -44,6 +44,7 @@ export const Loader = ({ color="subdued" icon={} title={

{loadingTitle}

} + data-test-subj="uptimeLoader" /> ) : null} diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/enablement_empty_state.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/enablement_empty_state.tsx new file mode 100644 index 0000000000000..c1ed29e999569 --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/enablement_empty_state.tsx @@ -0,0 +1,133 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useState, useEffect, useRef } from 'react'; +import { i18n } from '@kbn/i18n'; +import { EuiEmptyPrompt, EuiButton, EuiTitle, EuiLink } from '@elastic/eui'; +import { useEnablement } from '..//hooks/use_enablement'; +import { kibanaService } from '../../../state/kibana_service'; +import { SYNTHETICS_ENABLE_SUCCESS, SYNTHETICS_DISABLE_SUCCESS } from '../content'; + +export const EnablementEmptyState = ({ focusButton }: { focusButton: boolean }) => { + const { error, enablement, enableSynthetics, loading } = useEnablement(); + const [isEnabling, setIsEnabling] = useState(false); + const { isEnabled, canEnable } = enablement; + const buttonRef = useRef(null); + + useEffect(() => { + if (isEnabling && isEnabled) { + setIsEnabling(false); + kibanaService.toasts.addSuccess({ + title: SYNTHETICS_ENABLE_SUCCESS, + toastLifeTimeMs: 3000, + }); + } else if (isEnabling && error) { + setIsEnabling(false); + kibanaService.toasts.addSuccess({ + title: SYNTHETICS_DISABLE_SUCCESS, + toastLifeTimeMs: 3000, + }); + } + }, [isEnabled, isEnabling, error]); + + const handleEnableSynthetics = () => { + enableSynthetics(); + setIsEnabling(true); + }; + + useEffect(() => { + if (focusButton) { + buttonRef.current?.focus(); + } + }, [focusButton]); + + return !isEnabled && !loading ? ( + + {canEnable ? MONITOR_MANAGEMENT_ENABLEMENT_LABEL : MONITOR_MANAGEMENT_DISABLED_LABEL} + + } + body={ +

+ {canEnable ? MONITOR_MANAGEMENT_ENABLEMENT_MESSAGE : MONITOR_MANAGEMENT_DISABLED_MESSAGE} +

+ } + actions={ + canEnable ? ( + + {MONITOR_MANAGEMENT_ENABLEMENT_BTN_LABEL} + + ) : null + } + footer={ + <> + +

{LEARN_MORE_LABEL}

+
+ + {DOCS_LABEL} + + + } + /> + ) : null; +}; + +const MONITOR_MANAGEMENT_ENABLEMENT_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.emptyState.enablement.enabled.title', + { + defaultMessage: 'Enable Monitor Management', + } +); + +const MONITOR_MANAGEMENT_DISABLED_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.emptyState.enablement.disabled.title', + { + defaultMessage: 'Monitor Management is disabled', + } +); + +const MONITOR_MANAGEMENT_ENABLEMENT_MESSAGE = i18n.translate( + 'xpack.uptime.monitorManagement.emptyState.enablement', + { + defaultMessage: + 'Enable Monitor Management to run lightweight checks and real-browser monitors from hosted testing locations around the world. Enabling Monitor Management will generate an API key to allow the Synthetics Service to write back to your Elasticsearch cluster.', + } +); + +const MONITOR_MANAGEMENT_DISABLED_MESSAGE = i18n.translate( + 'xpack.uptime.monitorManagement.emptyState.enablement.disabledDescription', + { + defaultMessage: + 'Monitor Management is currently disabled. Monitor Management allows you to run lightweight checks and real-browser monitors from hosted testing locations around the world. To enable Monitor Management, please contact an administrator.', + } +); + +const MONITOR_MANAGEMENT_ENABLEMENT_BTN_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.emptyState.enablement.title', + { + defaultMessage: 'Enable', + } +); + +const DOCS_LABEL = i18n.translate('xpack.uptime.monitorManagement.emptyState.enablement.doc', { + defaultMessage: 'Read the docs', +}); + +const LEARN_MORE_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.emptyState.enablement.learnMore', + { + defaultMessage: 'Want to learn more?', + } +); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/invalid_monitors.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/invalid_monitors.tsx index 11f7317c785c4..87a6cf2dc1d2b 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/invalid_monitors.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/invalid_monitors.tsx @@ -49,8 +49,9 @@ export const InvalidMonitors = ({ perPage: pageState.pageSize, total: invalidTotal ?? 0, }, - error: { monitorList: null, serviceLocations: null }, - loading: { monitorList: summariesLoading, serviceLocations: false }, + enablement: null, + error: { monitorList: null, serviceLocations: null, enablement: null }, + loading: { monitorList: summariesLoading, serviceLocations: false, enablement: false }, locations: monitorList.locations, syntheticsService: monitorList.syntheticsService, throttling: DEFAULT_THROTTLING, diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.test.tsx index 5543904b6a3c4..ba06cf4ad30f7 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.test.tsx @@ -50,13 +50,16 @@ describe('', () => { monitors, }, locations: [], + enablement: null, error: { serviceLocations: null, monitorList: null, + enablement: null, }, loading: { monitorList: true, serviceLocations: false, + enablement: false, }, syntheticsService: { loading: false, diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx index 559e84d2dd827..2138c452f8053 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list.tsx @@ -207,7 +207,7 @@ export const MonitorManagementList = ({ { + const [pageState, dispatchPageAction] = useReducer( + monitorManagementPageReducer, + { + pageIndex: 1, // saved objects page index is base 1 + pageSize: 10, + sortOrder: 'asc', + sortField: ConfigKey.NAME, + } + ); + + const onPageStateChange = useCallback( + (state) => { + dispatchPageAction({ type: 'update', payload: state }); + }, + [dispatchPageAction] + ); + + const onUpdate = useCallback(() => { + dispatchPageAction({ type: 'refresh' }); + }, [dispatchPageAction]); + + useTrackPageview({ app: 'uptime', path: 'manage-monitors' }); + useTrackPageview({ app: 'uptime', path: 'manage-monitors', delay: 15000 }); + + const dispatch = useDispatch(); + const monitorList = useSelector(monitorManagementListSelector); + + const { pageIndex, pageSize, sortField, sortOrder } = pageState as MonitorManagementListPageState; + + const { type: viewType } = useParams<{ type: 'all' | 'invalid' }>(); + const { errorSummaries, loading, count } = useInlineErrors({ + onlyInvalidMonitors: viewType === 'invalid', + sortField: pageState.sortField, + sortOrder: pageState.sortOrder, + }); + + useEffect(() => { + if (viewType === 'all') { + dispatch(getMonitors({ page: pageIndex, perPage: pageSize, sortField, sortOrder })); + } + }, [dispatch, pageState, pageIndex, pageSize, sortField, sortOrder, viewType]); + + const { data: monitorSavedObjects, loading: objectsLoading } = useInvalidMonitors(errorSummaries); + + return ( + <> + + {viewType === 'all' ? ( + + ) : ( + + )} + + ); +}; + +type MonitorManagementPageAction = + | { + type: 'update'; + payload: MonitorManagementListPageState; + } + | { type: 'refresh' }; + +const monitorManagementPageReducer: Reducer< + MonitorManagementListPageState, + MonitorManagementPageAction +> = (state: MonitorManagementListPageState, action: MonitorManagementPageAction) => { + switch (action.type) { + case 'update': + return { + ...state, + ...action.payload, + }; + case 'refresh': + return { ...state }; + default: + throw new Error(`Action "${(action as MonitorManagementPageAction)?.type}" not recognizable`); + } +}; diff --git a/x-pack/plugins/uptime/public/components/overview/monitor_list/columns/test_now_col.tsx b/x-pack/plugins/uptime/public/components/overview/monitor_list/columns/test_now_col.tsx index 68845067f1275..3248f65963d77 100644 --- a/x-pack/plugins/uptime/public/components/overview/monitor_list/columns/test_now_col.tsx +++ b/x-pack/plugins/uptime/public/components/overview/monitor_list/columns/test_now_col.tsx @@ -58,7 +58,7 @@ export const TEST_NOW_ARIA_LABEL = i18n.translate('xpack.uptime.monitorList.test export const TEST_NOW_AVAILABLE_LABEL = i18n.translate( 'xpack.uptime.monitorList.testNow.available', { - defaultMessage: 'Test now is only available for monitors added via Monitor management.', + defaultMessage: 'Test now is only available for monitors added via Monitor Management.', } ); diff --git a/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts b/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts index 378345116d176..298f3d17575f1 100644 --- a/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts +++ b/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts @@ -74,11 +74,14 @@ export const mockState: AppState = { loading: { monitorList: false, serviceLocations: false, + enablement: false, }, error: { monitorList: null, serviceLocations: null, + enablement: null, }, + enablement: null, syntheticsService: { loading: false, }, diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/add_monitor.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/add_monitor.tsx index b3b0f0d611c8c..1cb3a023adbc1 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/add_monitor.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/add_monitor.tsx @@ -52,7 +52,7 @@ const LOADING_LABEL = i18n.translate('xpack.uptime.monitorManagement.addMonitorL const ERROR_HEADING_LABEL = i18n.translate( 'xpack.uptime.monitorManagement.addMonitorLoadingError', { - defaultMessage: 'Error loading monitor management', + defaultMessage: 'Error loading Monitor Management', } ); diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx index 7ebfbb2297d0a..3d36d507ee917 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/edit_monitor.tsx @@ -49,8 +49,8 @@ const LOADING_LABEL = i18n.translate('xpack.uptime.monitorManagement.editMonitor defaultMessage: 'Loading monitor', }); -const ERROR_HEADING_LABEL = i18n.translate('xpack.uptime.monitorManagement.editMonitorError', { - defaultMessage: 'Error loading monitor management', +const ERROR_HEADING_LABEL = i18n.translate('xpack.uptime.monitorManagement.manageMonitorError', { + defaultMessage: 'Error loading Monitor Management', }); const SERVICE_LOCATIONS_ERROR_LABEL = i18n.translate( diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx index d826db82517fc..3e0e9b955f31f 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx @@ -5,116 +5,151 @@ * 2.0. */ -import React, { useEffect, useReducer, useCallback, Reducer } from 'react'; +import React, { useEffect, useRef, useState } from 'react'; +import { i18n } from '@kbn/i18n'; import { useDispatch, useSelector } from 'react-redux'; -import { useParams } from 'react-router-dom'; +import { EuiCallOut, EuiButton, EuiSpacer, EuiLink } from '@elastic/eui'; import { useTrackPageview } from '../../../../observability/public'; import { ConfigKey } from '../../../common/runtime_types'; import { getMonitors } from '../../state/actions'; import { monitorManagementListSelector } from '../../state/selectors'; -import { MonitorManagementListPageState } from '../../components/monitor_management/monitor_list/monitor_list'; import { useMonitorManagementBreadcrumbs } from './use_monitor_management_breadcrumbs'; -import { useInlineErrors } from '../../components/monitor_management/hooks/use_inline_errors'; -import { MonitorListTabs } from '../../components/monitor_management/monitor_list/list_tabs'; -import { AllMonitors } from '../../components/monitor_management/monitor_list/all_monitors'; -import { InvalidMonitors } from '../../components/monitor_management/monitor_list/invalid_monitors'; -import { useInvalidMonitors } from '../../components/monitor_management/hooks/use_invalid_monitors'; +import { MonitorListContainer } from '../../components/monitor_management/monitor_list/monitor_list_container'; +import { EnablementEmptyState } from '../../components/monitor_management/monitor_list/enablement_empty_state'; +import { useEnablement } from '../../components/monitor_management/hooks/use_enablement'; +import { Loader } from '../../components/monitor_management/loader/loader'; export const MonitorManagementPage: React.FC = () => { - const [pageState, dispatchPageAction] = useReducer( - monitorManagementPageReducer, - { - pageIndex: 1, // saved objects page index is base 1 - pageSize: 10, - sortOrder: 'asc', - sortField: ConfigKey.NAME, - } - ); - - const onPageStateChange = useCallback( - (state) => { - dispatchPageAction({ type: 'update', payload: state }); - }, - [dispatchPageAction] - ); - - const onUpdate = useCallback(() => { - dispatchPageAction({ type: 'refresh' }); - }, [dispatchPageAction]); - useTrackPageview({ app: 'uptime', path: 'manage-monitors' }); useTrackPageview({ app: 'uptime', path: 'manage-monitors', delay: 15000 }); useMonitorManagementBreadcrumbs(); const dispatch = useDispatch(); - const monitorList = useSelector(monitorManagementListSelector); + const [shouldFocusEnablementButton, setShouldFocusEnablementButton] = useState(false); - const { pageIndex, pageSize, sortField, sortOrder } = pageState as MonitorManagementListPageState; + const { + error: enablementError, + enablement, + loading: enablementLoading, + enableSynthetics, + } = useEnablement(); + const { list: monitorList } = useSelector(monitorManagementListSelector); + const { isEnabled } = enablement; - const { type: viewType } = useParams<{ type: 'all' | 'invalid' }>(); - const { errorSummaries, loading, count } = useInlineErrors({ - onlyInvalidMonitors: viewType === 'invalid', - sortField: pageState.sortField, - sortOrder: pageState.sortOrder, - }); + const isEnabledRef = useRef(isEnabled); useEffect(() => { - if (viewType === 'all') { - dispatch(getMonitors({ page: pageIndex, perPage: pageSize, sortField, sortOrder })); + if (monitorList.total === null) { + dispatch( + getMonitors({ + page: 1, // saved objects page index is base 1 + perPage: 10, + sortOrder: 'asc', + sortField: ConfigKey.NAME, + }) + ); } - }, [dispatch, pageState, pageIndex, pageSize, sortField, sortOrder, viewType]); + }, [dispatch, monitorList.total]); - const { data: monitorSavedObjects, loading: objectsLoading } = useInvalidMonitors(errorSummaries); + useEffect(() => { + if (!isEnabled && isEnabledRef.current === true) { + /* shift focus to enable button when enable toggle disappears. Prevent + * focus loss on the page */ + setShouldFocusEnablementButton(true); + } + isEnabledRef.current = Boolean(isEnabled); + }, [isEnabled]); return ( <> - - {viewType === 'all' ? ( - - ) : ( - + + {!isEnabled && monitorList.total && monitorList.total > 0 ? ( + <> + +

{CALLOUT_MANAGEMENT_DESCRIPTION}

+ {enablement.canEnable ? ( + { + enableSynthetics(); + }} + > + {SYNTHETICS_ENABLE_LABEL} + + ) : ( +

+ {CALLOUT_MANAGEMENT_CONTACT_ADMIN}{' '} + + {LEARN_MORE_LABEL} + +

+ )} +
+ + + ) : null} + {isEnabled || (!isEnabled && monitorList.total) ? : null} +
+ {isEnabled !== undefined && monitorList.total === 0 && ( + )} ); }; -type MonitorManagementPageAction = - | { - type: 'update'; - payload: MonitorManagementListPageState; - } - | { type: 'refresh' }; +const LOADING_LABEL = i18n.translate('xpack.uptime.monitorManagement.manageMonitorLoadingLabel', { + defaultMessage: 'Loading Monitor Management', +}); -const monitorManagementPageReducer: Reducer< - MonitorManagementListPageState, - MonitorManagementPageAction -> = (state: MonitorManagementListPageState, action: MonitorManagementPageAction) => { - switch (action.type) { - case 'update': - return { - ...state, - ...action.payload, - }; - case 'refresh': - return { ...state }; - default: - throw new Error(`Action "${(action as MonitorManagementPageAction)?.type}" not recognizable`); +const LEARN_MORE_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.manageMonitorLoadingLabel.callout.learnMore', + { + defaultMessage: 'Learn more.', } -}; +); + +const CALLOUT_MANAGEMENT_DISABLED = i18n.translate( + 'xpack.uptime.monitorManagement.callout.disabled', + { + defaultMessage: 'Monitor Management is disabled', + } +); + +const CALLOUT_MANAGEMENT_CONTACT_ADMIN = i18n.translate( + 'xpack.uptime.monitorManagement.callout.disabled.adminContact', + { + defaultMessage: 'Please contact your administrator to enable Monitor Management.', + } +); + +const CALLOUT_MANAGEMENT_DESCRIPTION = i18n.translate( + 'xpack.uptime.monitorManagement.callout.description.disabled', + { + defaultMessage: + 'Monitor Management is currently disabled. To run your monitors on Elastic managed Synthetics service, enable Monitor Management. Your existing monitors are paused.', + } +); + +const ERROR_HEADING_LABEL = i18n.translate('xpack.uptime.monitorManagement.editMonitorError', { + defaultMessage: 'Error loading Monitor Management', +}); + +const ERROR_HEADING_BODY = i18n.translate( + 'xpack.uptime.monitorManagement.editMonitorError.description', + { + defaultMessage: 'Monitor Management settings could not be loaded. Please contact Support.', + } +); + +const SYNTHETICS_ENABLE_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.syntheticsEnableLabel.management', + { + defaultMessage: 'Enable Monitor Management', + } +); diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx index a8aac213186d3..77e64f70d48e3 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx @@ -31,7 +31,7 @@ describe('ServiceAllowedWrapper', () => { ); - expect(await findByText('Loading monitor management')).toBeInTheDocument(); + expect(await findByText('Loading Monitor Management')).toBeInTheDocument(); }); it('renders when enabled state is false', async () => { @@ -45,7 +45,7 @@ describe('ServiceAllowedWrapper', () => { ); - expect(await findByText('Monitor management')).toBeInTheDocument(); + expect(await findByText('Monitor Management')).toBeInTheDocument(); }); it('renders when enabled state is true', async () => { diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx index 3092b8f5f1c3b..8f6cd7d3f0eb5 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx @@ -45,13 +45,13 @@ const REQUEST_ACCESS_LABEL = i18n.translate('xpack.uptime.monitorManagement.requ }); const MONITOR_MANAGEMENT_LABEL = i18n.translate('xpack.uptime.monitorManagement.label', { - defaultMessage: 'Monitor management', + defaultMessage: 'Monitor Management', }); const LOADING_MONITOR_MANAGEMENT_LABEL = i18n.translate( 'xpack.uptime.monitorManagement.loading.label', { - defaultMessage: 'Loading monitor management', + defaultMessage: 'Loading Monitor Management', } ); @@ -59,7 +59,7 @@ const PUBLIC_BETA_DESCRIPTION = i18n.translate( 'xpack.uptime.monitorManagement.publicBetaDescription', { defaultMessage: - 'Monitor management is available only for selected public beta users. With public\n' + + 'Monitor Management is available only for selected public beta users. With public\n' + 'beta access, you will be able to add HTTP, TCP, ICMP and Browser checks which will\n' + "run on Elastic's managed synthetics service nodes.", } diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/use_monitor_management_breadcrumbs.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/use_monitor_management_breadcrumbs.tsx index 834752c996153..d013af54c38f6 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/use_monitor_management_breadcrumbs.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/use_monitor_management_breadcrumbs.tsx @@ -48,7 +48,7 @@ export const useMonitorManagementBreadcrumbs = ({ export const MONITOR_MANAGEMENT_CRUMB = i18n.translate( 'xpack.uptime.monitorManagement.monitorManagementCrumb', { - defaultMessage: 'Monitor management', + defaultMessage: 'Monitor Management', } ); diff --git a/x-pack/plugins/uptime/public/state/actions/monitor_management.ts b/x-pack/plugins/uptime/public/state/actions/monitor_management.ts index 68ca48b5cf22d..278f8fe9a4b99 100644 --- a/x-pack/plugins/uptime/public/state/actions/monitor_management.ts +++ b/x-pack/plugins/uptime/public/state/actions/monitor_management.ts @@ -30,6 +30,22 @@ export const getServiceLocationsSuccess = createAction<{ }>('GET_SERVICE_LOCATIONS_LIST_SUCCESS'); export const getServiceLocationsFailure = createAction('GET_SERVICE_LOCATIONS_LIST_FAILURE'); +export const getSyntheticsEnablement = createAction('GET_SYNTHETICS_ENABLEMENT'); +export const getSyntheticsEnablementSuccess = createAction( + 'GET_SYNTHETICS_ENABLEMENT_SUCCESS' +); +export const getSyntheticsEnablementFailure = createAction( + 'GET_SYNTHETICS_ENABLEMENT_FAILURE' +); + +export const disableSynthetics = createAction('DISABLE_SYNTHETICS'); +export const disableSyntheticsSuccess = createAction('DISABLE_SYNTEHTICS_SUCCESS'); +export const disableSyntheticsFailure = createAction('DISABLE_SYNTHETICS_FAILURE'); + +export const enableSynthetics = createAction('ENABLE_SYNTHETICS'); +export const enableSyntheticsSuccess = createAction('ENABLE_SYNTEHTICS_SUCCESS'); +export const enableSyntheticsFailure = createAction('ENABLE_SYNTHETICS_FAILURE'); + export const getSyntheticsServiceAllowed = createAsyncAction( 'GET_SYNTHETICS_SERVICE_ALLOWED' ); diff --git a/x-pack/plugins/uptime/public/state/api/monitor_management.ts b/x-pack/plugins/uptime/public/state/api/monitor_management.ts index f9e08e3020936..58cc0217c298c 100644 --- a/x-pack/plugins/uptime/public/state/api/monitor_management.ts +++ b/x-pack/plugins/uptime/public/state/api/monitor_management.ts @@ -10,6 +10,8 @@ import { FetchMonitorManagementListQueryArgs, MonitorManagementListResultCodec, MonitorManagementListResult, + MonitorManagementEnablementResultCodec, + MonitorManagementEnablementResult, ServiceLocations, SyntheticsMonitor, EncryptedSyntheticsMonitor, @@ -91,6 +93,23 @@ export const testNowMonitor = async (configId: string): Promise => { + return await apiService.get( + API_URLS.SYNTHETICS_ENABLEMENT, + undefined, + MonitorManagementEnablementResultCodec + ); + }; + +export const fetchDisableSynthetics = async (): Promise => { + return await apiService.delete(API_URLS.SYNTHETICS_ENABLEMENT); +}; + +export const fetchEnableSynthetics = async (): Promise => { + return await apiService.post(API_URLS.SYNTHETICS_ENABLEMENT); +}; + export const fetchServiceAllowed = async (): Promise => { return await apiService.get(API_URLS.SERVICE_ALLOWED); }; diff --git a/x-pack/plugins/uptime/public/state/effects/monitor_management.ts b/x-pack/plugins/uptime/public/state/effects/monitor_management.ts index 5839d5d9ca30f..e09f275a8817d 100644 --- a/x-pack/plugins/uptime/public/state/effects/monitor_management.ts +++ b/x-pack/plugins/uptime/public/state/effects/monitor_management.ts @@ -13,9 +13,25 @@ import { getServiceLocations, getServiceLocationsSuccess, getServiceLocationsFailure, + getSyntheticsEnablement, + getSyntheticsEnablementSuccess, + getSyntheticsEnablementFailure, + disableSynthetics, + disableSyntheticsSuccess, + disableSyntheticsFailure, + enableSynthetics, + enableSyntheticsSuccess, + enableSyntheticsFailure, getSyntheticsServiceAllowed, } from '../actions'; -import { fetchMonitorManagementList, fetchServiceAllowed, fetchServiceLocations } from '../api'; +import { + fetchMonitorManagementList, + fetchServiceLocations, + fetchServiceAllowed, + fetchGetSyntheticsEnablement, + fetchDisableSynthetics, + fetchEnableSynthetics, +} from '../api'; import { fetchEffectFactory } from './fetch_effect'; export function* fetchMonitorManagementEffect() { @@ -31,6 +47,22 @@ export function* fetchMonitorManagementEffect() { getServiceLocationsFailure ) ); + yield takeLatest( + getSyntheticsEnablement, + fetchEffectFactory( + fetchGetSyntheticsEnablement, + getSyntheticsEnablementSuccess, + getSyntheticsEnablementFailure + ) + ); + yield takeLatest( + disableSynthetics, + fetchEffectFactory(fetchDisableSynthetics, disableSyntheticsSuccess, disableSyntheticsFailure) + ); + yield takeLatest( + enableSynthetics, + fetchEffectFactory(fetchEnableSynthetics, enableSyntheticsSuccess, enableSyntheticsFailure) + ); } export function* fetchSyntheticsServiceAllowedEffect() { diff --git a/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts b/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts index 58f7079067652..419c43db20ccf 100644 --- a/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts +++ b/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts @@ -14,23 +14,32 @@ import { getServiceLocations, getServiceLocationsSuccess, getServiceLocationsFailure, + getSyntheticsEnablement, + getSyntheticsEnablementSuccess, + getSyntheticsEnablementFailure, + disableSynthetics, + disableSyntheticsSuccess, + disableSyntheticsFailure, + enableSynthetics, + enableSyntheticsSuccess, + enableSyntheticsFailure, getSyntheticsServiceAllowed, } from '../actions'; - -import { SyntheticsServiceAllowed } from '../../../common/types'; - import { + MonitorManagementEnablementResult, MonitorManagementListResult, ServiceLocations, ThrottlingOptions, DEFAULT_THROTTLING, } from '../../../common/runtime_types'; +import { SyntheticsServiceAllowed } from '../../../common/types'; export interface MonitorManagementList { - error: Record<'monitorList' | 'serviceLocations', Error | null>; - loading: Record<'monitorList' | 'serviceLocations', boolean>; + error: Record<'monitorList' | 'serviceLocations' | 'enablement', Error | null>; + loading: Record<'monitorList' | 'serviceLocations' | 'enablement', boolean>; list: MonitorManagementListResult; locations: ServiceLocations; + enablement: MonitorManagementEnablementResult | null; syntheticsService: { isAllowed?: boolean; loading: boolean }; throttling: ThrottlingOptions; } @@ -43,13 +52,16 @@ export const initialState: MonitorManagementList = { monitors: [], }, locations: [], + enablement: null, loading: { monitorList: false, serviceLocations: false, + enablement: false, }, error: { monitorList: null, serviceLocations: null, + enablement: null, }, syntheticsService: { loading: false, @@ -141,6 +153,116 @@ export const monitorManagementListReducer = createReducer(initialState, (builder }, }) ) + .addCase(getSyntheticsEnablement, (state: WritableDraft) => ({ + ...state, + loading: { + ...state.loading, + enablement: true, + }, + })) + .addCase( + getSyntheticsEnablementSuccess, + (state: WritableDraft, action: PayloadAction) => ({ + ...state, + loading: { + ...state.loading, + enablement: false, + }, + error: { + ...state.error, + enablement: null, + }, + enablement: action.payload, + }) + ) + .addCase( + getSyntheticsEnablementFailure, + (state: WritableDraft, action: PayloadAction) => ({ + ...state, + loading: { + ...state.loading, + enablement: false, + }, + error: { + ...state.error, + enablement: action.payload, + }, + }) + ) + .addCase(disableSynthetics, (state: WritableDraft) => ({ + ...state, + loading: { + ...state.loading, + enablement: true, + }, + })) + .addCase(disableSyntheticsSuccess, (state: WritableDraft) => ({ + ...state, + loading: { + ...state.loading, + enablement: false, + }, + error: { + ...state.error, + enablement: null, + }, + enablement: { + canEnable: state.enablement?.canEnable || false, + areApiKeysEnabled: state.enablement?.areApiKeysEnabled || false, + isEnabled: false, + }, + })) + .addCase( + disableSyntheticsFailure, + (state: WritableDraft, action: PayloadAction) => ({ + ...state, + loading: { + ...state.loading, + enablement: false, + }, + error: { + ...state.error, + enablement: action.payload, + }, + }) + ) + .addCase(enableSynthetics, (state: WritableDraft) => ({ + ...state, + loading: { + ...state.loading, + enablement: true, + }, + })) + .addCase(enableSyntheticsSuccess, (state: WritableDraft) => ({ + ...state, + loading: { + ...state.loading, + enablement: false, + }, + error: { + ...state.error, + enablement: null, + }, + enablement: { + canEnable: state.enablement?.canEnable || false, + areApiKeysEnabled: state.enablement?.areApiKeysEnabled || false, + isEnabled: true, + }, + })) + .addCase( + enableSyntheticsFailure, + (state: WritableDraft, action: PayloadAction) => ({ + ...state, + loading: { + ...state.loading, + enablement: false, + }, + error: { + ...state.error, + enablement: action.payload, + }, + }) + ) .addCase( String(getSyntheticsServiceAllowed.get), (state: WritableDraft) => ({ diff --git a/x-pack/plugins/uptime/server/lib/requests/index.ts b/x-pack/plugins/uptime/server/lib/requests/index.ts index 2c2633095c8e2..979a914fdfb62 100644 --- a/x-pack/plugins/uptime/server/lib/requests/index.ts +++ b/x-pack/plugins/uptime/server/lib/requests/index.ts @@ -26,6 +26,12 @@ import { getJourneyFailedSteps } from './get_journey_failed_steps'; import { getLastSuccessfulCheck } from './get_last_successful_check'; import { getJourneyScreenshotBlocks } from './get_journey_screenshot_blocks'; import { getSyntheticsMonitor } from './get_monitor'; +import { + getSyntheticsEnablement, + deleteServiceApiKey, + generateAndSaveServiceAPIKey, + getAPIKeyForSyntheticsService, +} from '../synthetics_service/get_api_key'; export const requests = { getCerts, @@ -49,6 +55,10 @@ export const requests = { getJourneyScreenshotBlocks, getJourneyDetails, getNetworkEvents, + getSyntheticsEnablement, + getAPIKeyForSyntheticsService, + deleteServiceApiKey, + generateAndSaveServiceAPIKey, }; export type UptimeRequests = typeof requests; diff --git a/x-pack/plugins/uptime/server/lib/saved_objects/service_api_key.ts b/x-pack/plugins/uptime/server/lib/saved_objects/service_api_key.ts index db63008c35017..43fee5ecd6dad 100644 --- a/x-pack/plugins/uptime/server/lib/saved_objects/service_api_key.ts +++ b/x-pack/plugins/uptime/server/lib/saved_objects/service_api_key.ts @@ -63,6 +63,7 @@ export const getSyntheticsServiceAPIKey = async (client: EncryptedSavedObjectsCl throw getErr; } }; + export const setSyntheticsServiceApiKey = async ( client: SavedObjectsClientContract, apiKey: SyntheticsServiceApiKey @@ -72,3 +73,11 @@ export const setSyntheticsServiceApiKey = async ( overwrite: true, }); }; + +export const deleteSyntheticsServiceApiKey = async (client: SavedObjectsClientContract) => { + try { + return await client.delete(syntheticsServiceApiKey.name, syntheticsApiKeyID); + } catch (e) { + throw e; + } +}; diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.test.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.test.ts index f9ba0ce545bad..7ad3d0b1e2e67 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.test.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.test.ts @@ -12,6 +12,7 @@ import { coreMock } from '../../../../../../src/core/server/mocks'; import { syntheticsServiceApiKey } from '../saved_objects/service_api_key'; import { KibanaRequest } from 'kibana/server'; import { UptimeServerSetup } from '../adapters'; +import { getUptimeESMockClient } from '../requests/helper'; describe('getAPIKeyTest', function () { const core = coreMock.createStart(); @@ -23,6 +24,7 @@ describe('getAPIKeyTest', function () { security, encryptedSavedObjects, savedObjectsClient: core.savedObjects.getScopedClient(request), + uptimeEsClient: getUptimeESMockClient().uptimeEsClient, } as unknown as UptimeServerSetup; security.authc.apiKeys.areAPIKeysEnabled = jest.fn().mockReturnValue(true); @@ -33,38 +35,6 @@ describe('getAPIKeyTest', function () { encoded: '@#$%^&', }); - it('should generate an api key and return it', async () => { - const apiKey = await getAPIKeyForSyntheticsService({ - request, - server, - }); - - expect(security.authc.apiKeys.areAPIKeysEnabled).toHaveBeenCalledTimes(1); - expect(security.authc.apiKeys.create).toHaveBeenCalledTimes(1); - expect(security.authc.apiKeys.create).toHaveBeenCalledWith( - {}, - { - name: 'synthetics-api-key', - role_descriptors: { - synthetics_writer: { - cluster: ['monitor', 'read_ilm', 'read_pipeline'], - index: [ - { - names: ['synthetics-*'], - privileges: ['view_index_metadata', 'create_doc', 'auto_configure'], - }, - ], - }, - }, - metadata: { - description: - 'Created for synthetics service to be passed to the heartbeat to communicate with ES', - }, - } - ); - expect(apiKey).toEqual({ apiKey: 'qwerty', id: 'test', name: 'service-api-key' }); - }); - it('should return existing api key', async () => { const getObject = jest .fn() @@ -74,7 +44,6 @@ describe('getAPIKeyTest', function () { getDecryptedAsInternalUser: getObject, }); const apiKey = await getAPIKeyForSyntheticsService({ - request, server, }); diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.ts index cd90828f93ccf..766f26a0aeca7 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/get_api_key.ts @@ -4,25 +4,42 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ - +import type { + SecurityClusterPrivilege, + SecurityIndexPrivilege, +} from '@elastic/elasticsearch/lib/api/types'; import { KibanaRequest, SavedObjectsClientContract } from '../../../../../../src/core/server'; + import { SecurityPluginStart } from '../../../../security/server'; import { getSyntheticsServiceAPIKey, + deleteSyntheticsServiceApiKey, setSyntheticsServiceApiKey, syntheticsServiceApiKey, } from '../saved_objects/service_api_key'; import { SyntheticsServiceApiKey } from '../../../common/runtime_types/synthetics_service_api_key'; import { UptimeServerSetup } from '../adapters'; +export const serviceApiKeyPrivileges = { + cluster: ['monitor', 'read_ilm', 'read_pipeline'] as SecurityClusterPrivilege[], + index: [ + { + names: ['synthetics-*'], + privileges: [ + 'view_index_metadata', + 'create_doc', + 'auto_configure', + ] as SecurityIndexPrivilege[], + }, + ], +}; + export const getAPIKeyForSyntheticsService = async ({ - request, server, }: { server: UptimeServerSetup; - request?: KibanaRequest; }): Promise => { - const { security, encryptedSavedObjects, authSavedObjectsClient } = server; + const { encryptedSavedObjects } = server; const encryptedClient = encryptedSavedObjects.getClient({ includedHiddenTypes: [syntheticsServiceApiKey.name], @@ -36,19 +53,15 @@ export const getAPIKeyForSyntheticsService = async ({ } catch (err) { // TODO: figure out how to handle decryption errors } - - return await generateAndSaveAPIKey({ - request, - security, - authSavedObjectsClient, - }); }; -export const generateAndSaveAPIKey = async ({ +export const generateAndSaveServiceAPIKey = async ({ + server, security, request, authSavedObjectsClient, }: { + server: UptimeServerSetup; request?: KibanaRequest; security: SecurityPluginStart; // authSavedObject is needed for write operations @@ -64,18 +77,15 @@ export const generateAndSaveAPIKey = async ({ throw new Error('User authorization is needed for api key generation'); } + const { canEnable } = await getSyntheticsEnablement({ request, server }); + if (!canEnable) { + throw new SyntheticsForbiddenError(); + } + const apiKeyResult = await security.authc.apiKeys?.create(request, { name: 'synthetics-api-key', role_descriptors: { - synthetics_writer: { - cluster: ['monitor', 'read_ilm', 'read_pipeline'], - index: [ - { - names: ['synthetics-*'], - privileges: ['view_index_metadata', 'create_doc', 'auto_configure'], - }, - ], - }, + synthetics_writer: serviceApiKeyPrivileges, }, metadata: { description: @@ -93,3 +103,73 @@ export const generateAndSaveAPIKey = async ({ return apiKeyObject; } }; + +export const deleteServiceApiKey = async ({ + request, + server, + savedObjectsClient, +}: { + server: UptimeServerSetup; + request?: KibanaRequest; + savedObjectsClient: SavedObjectsClientContract; +}) => { + await deleteSyntheticsServiceApiKey(savedObjectsClient); +}; + +export const getSyntheticsEnablement = async ({ + request, + server: { uptimeEsClient, security, encryptedSavedObjects }, +}: { + server: UptimeServerSetup; + request?: KibanaRequest; +}) => { + const encryptedClient = encryptedSavedObjects.getClient({ + includedHiddenTypes: [syntheticsServiceApiKey.name], + }); + + const [apiKey, hasPrivileges, areApiKeysEnabled] = await Promise.all([ + getSyntheticsServiceAPIKey(encryptedClient), + uptimeEsClient.baseESClient.security.hasPrivileges({ + body: { + cluster: [ + 'manage_security', + 'manage_api_key', + 'manage_own_api_key', + ...serviceApiKeyPrivileges.cluster, + ], + index: serviceApiKeyPrivileges.index, + }, + }), + security.authc.apiKeys.areAPIKeysEnabled(), + ]); + + const { cluster } = hasPrivileges; + const { + manage_security: manageSecurity, + manage_api_key: manageApiKey, + manage_own_api_key: manageOwnApiKey, + monitor, + read_ilm: readILM, + read_pipeline: readPipeline, + } = cluster || {}; + + const canManageApiKeys = manageSecurity || manageApiKey || manageOwnApiKey; + const hasClusterPermissions = readILM && readPipeline && monitor; + const hasIndexPermissions = !Object.values(hasPrivileges.index?.['synthetics-*'] || []).includes( + false + ); + + return { + canEnable: canManageApiKeys && hasClusterPermissions && hasIndexPermissions, + isEnabled: Boolean(apiKey), + areApiKeysEnabled, + }; +}; + +export class SyntheticsForbiddenError extends Error { + constructor() { + super(); + this.message = 'Forbidden'; + this.name = 'SyntheticsForbiddenError'; + } +} diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts index 4a86725d137ac..21d5fa6760983 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts @@ -191,32 +191,25 @@ export class SyntheticsService { } } - async getOutput(request?: KibanaRequest) { - if (!this.apiKey) { - try { - this.apiKey = await getAPIKeyForSyntheticsService({ server: this.server, request }); - } catch (err) { - this.logger.error(err); - throw err; - } - } - - if (!this.apiKey) { - const error = new APIKeyMissingError(); - this.logger.error(error); - throw error; + async getApiKey() { + try { + this.apiKey = await getAPIKeyForSyntheticsService({ server: this.server }); + } catch (err) { + this.logger.error(err); + throw err; } - this.logger.debug('Found api key and esHosts for service.'); + return this.apiKey; + } + async getOutput(apiKey: SyntheticsServiceApiKey) { return { hosts: this.esHosts, - api_key: `${this.apiKey.id}:${this.apiKey.apiKey}`, + api_key: `${apiKey?.id}:${apiKey?.apiKey}`, }; } async pushConfigs( - request?: KibanaRequest, configs?: Array< SyntheticsMonitorWithId & { fields_under_root?: boolean; @@ -229,9 +222,16 @@ export class SyntheticsService { this.logger.debug('No monitor found which can be pushed to service.'); return; } + + this.apiKey = await this.getApiKey(); + + if (!this.apiKey) { + return null; + } + const data = { monitors, - output: await this.getOutput(request), + output: await this.getOutput(this.apiKey), }; this.logger.debug(`${monitors.length} monitors will be pushed to synthetics service.`); @@ -245,7 +245,6 @@ export class SyntheticsService { } async runOnceConfigs( - request?: KibanaRequest, configs?: Array< SyntheticsMonitorWithId & { fields_under_root?: boolean; @@ -257,9 +256,15 @@ export class SyntheticsService { if (monitors.length === 0) { return; } + this.apiKey = await this.getApiKey(); + + if (!this.apiKey) { + return null; + } + const data = { monitors, - output: await this.getOutput(request), + output: await this.getOutput(this.apiKey), }; try { @@ -283,9 +288,16 @@ export class SyntheticsService { if (monitors.length === 0) { return; } + + this.apiKey = await this.getApiKey(); + + if (!this.apiKey) { + return null; + } + const data = { monitors, - output: await this.getOutput(request), + output: await this.getOutput(this.apiKey), }; try { @@ -296,14 +308,25 @@ export class SyntheticsService { } } - async deleteConfigs(request: KibanaRequest, configs: SyntheticsMonitorWithId[]) { + async deleteConfigs(configs: SyntheticsMonitorWithId[]) { + this.apiKey = await this.getApiKey(); + + if (!this.apiKey) { + return null; + } + const data = { monitors: this.formatConfigs(configs), - output: await this.getOutput(request), + output: await this.getOutput(this.apiKey), }; return await this.apiClient.delete(data); } + async deleteAllConfigs() { + const configs = await this.getMonitorConfigs(); + return await this.deleteConfigs(configs); + } + async getMonitorConfigs() { const savedObjectsClient = this.server.savedObjectsClient; const encryptedClient = this.server.encryptedSavedObjects.getClient(); @@ -362,14 +385,6 @@ export class SyntheticsService { } } -class APIKeyMissingError extends Error { - constructor() { - super(); - this.message = 'API key is needed for synthetics service.'; - this.name = 'APIKeyMissingError'; - } -} - class IndexTemplateInstallationError extends Error { constructor() { super(); diff --git a/x-pack/plugins/uptime/server/rest_api/index.ts b/x-pack/plugins/uptime/server/rest_api/index.ts index 8b0775b6ed31a..b95e929416713 100644 --- a/x-pack/plugins/uptime/server/rest_api/index.ts +++ b/x-pack/plugins/uptime/server/rest_api/index.ts @@ -38,6 +38,11 @@ import { editSyntheticsMonitorRoute } from './synthetics_service/edit_monitor'; import { deleteSyntheticsMonitorRoute } from './synthetics_service/delete_monitor'; import { runOnceSyntheticsMonitorRoute } from './synthetics_service/run_once_monitor'; import { testNowMonitorRoute } from './synthetics_service/test_now_monitor'; +import { + getSyntheticsEnablementRoute, + disableSyntheticsRoute, + enableSyntheticsRoute, +} from './synthetics_service/enablement'; import { getServiceAllowedRoute } from './synthetics_service/get_service_allowed'; export * from './types'; @@ -45,6 +50,8 @@ export { createRouteWithAuth } from './create_route_with_auth'; export { uptimeRouteWrapper } from './uptime_route_wrapper'; export const restApiRoutes: UMRestApiRouteFactory[] = [ + addSyntheticsMonitorRoute, + getSyntheticsEnablementRoute, createGetPingsRoute, createGetIndexStatusRoute, createGetDynamicSettingsRoute, @@ -63,13 +70,14 @@ export const restApiRoutes: UMRestApiRouteFactory[] = [ createJourneyFailedStepsRoute, createLastSuccessfulCheckRoute, createJourneyScreenshotBlocksRoute, - installIndexTemplatesRoute, + deleteSyntheticsMonitorRoute, + disableSyntheticsRoute, + editSyntheticsMonitorRoute, + enableSyntheticsRoute, getServiceLocationsRoute, getSyntheticsMonitorRoute, getAllSyntheticsMonitorRoute, - addSyntheticsMonitorRoute, - editSyntheticsMonitorRoute, - deleteSyntheticsMonitorRoute, + installIndexTemplatesRoute, runOnceSyntheticsMonitorRoute, testNowMonitorRoute, getServiceAllowedRoute, diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts index d5beeb9967b18..19bc5050ddfcc 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/add_monitor.ts @@ -45,7 +45,7 @@ export const addSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ const { syntheticsService } = server; - const errors = await syntheticsService.pushConfigs(request, [ + const errors = await syntheticsService.pushConfigs([ { ...monitor, id: newMonitor.id, diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts index 6e94e1a802897..17f34b0d82ec0 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/delete_monitor.ts @@ -59,7 +59,7 @@ export const deleteSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ const normalizedMonitor = normalizeSecrets(monitor); await savedObjectsClient.delete(syntheticsMonitorType, monitorId); - const errors = await syntheticsService.deleteConfigs(request, [ + const errors = await syntheticsService.deleteConfigs([ { ...normalizedMonitor.attributes, id: monitorId }, ]); diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts index f590c45166fd5..9ad9084b72ba5 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/edit_monitor.ts @@ -91,7 +91,7 @@ export const editSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ monitor.type === 'browser' ? { ...monitorWithRevision, urls: '' } : monitorWithRevision ); - const errors = await syntheticsService.pushConfigs(request, [ + const errors = await syntheticsService.pushConfigs([ { ...editedMonitor, id: editMonitor.id, diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/enablement.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/enablement.ts new file mode 100644 index 0000000000000..5fa7a8b24a495 --- /dev/null +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/enablement.ts @@ -0,0 +1,81 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { UMRestApiRouteFactory } from '../types'; +import { API_URLS } from '../../../common/constants'; +import { SyntheticsForbiddenError } from '../../lib/synthetics_service/get_api_key'; + +export const getSyntheticsEnablementRoute: UMRestApiRouteFactory = (libs) => ({ + method: 'GET', + path: API_URLS.SYNTHETICS_ENABLEMENT, + validate: {}, + handler: async ({ request, response, server }): Promise => { + try { + return response.ok({ + body: await libs.requests.getSyntheticsEnablement({ + request, + server, + }), + }); + } catch (e) { + server.logger.error(e); + throw e; + } + }, +}); + +export const disableSyntheticsRoute: UMRestApiRouteFactory = (libs) => ({ + method: 'DELETE', + path: API_URLS.SYNTHETICS_ENABLEMENT, + validate: {}, + handler: async ({ response, request, server, savedObjectsClient }): Promise => { + const { syntheticsService, security } = server; + try { + const { canEnable } = await libs.requests.getSyntheticsEnablement({ request, server }); + if (!canEnable) { + return response.forbidden(); + } + await syntheticsService.deleteAllConfigs(); + const apiKey = await libs.requests.getAPIKeyForSyntheticsService({ + server, + }); + await libs.requests.deleteServiceApiKey({ + request, + server, + savedObjectsClient, + }); + await security.authc.apiKeys?.invalidate(request, { ids: [apiKey?.id || ''] }); + return response.ok({}); + } catch (e) { + server.logger.error(e); + throw e; + } + }, +}); + +export const enableSyntheticsRoute: UMRestApiRouteFactory = (libs) => ({ + method: 'POST', + path: API_URLS.SYNTHETICS_ENABLEMENT, + validate: {}, + handler: async ({ request, response, server }): Promise => { + const { authSavedObjectsClient, logger, security } = server; + try { + await libs.requests.generateAndSaveServiceAPIKey({ + request, + authSavedObjectsClient, + security, + server, + }); + return response.ok({}); + } catch (e) { + logger.error(e); + if (e instanceof SyntheticsForbiddenError) { + return response.forbidden(); + } + throw e; + } + }, +}); diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/run_once_monitor.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/run_once_monitor.ts index 409990a12fcf0..e4e3e1f1bd518 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/run_once_monitor.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/run_once_monitor.ts @@ -32,7 +32,7 @@ export const runOnceSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ const { syntheticsService } = server; - const errors = await syntheticsService.runOnceConfigs(request, [ + const errors = await syntheticsService.runOnceConfigs([ { ...monitor, id: monitorId, diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts index 2fe8d9eba761c..29f28e5ab36a6 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/telemetry/monitor_upgrade_sender.ts @@ -53,7 +53,7 @@ export function formatTelemetryEvent({ lastUpdatedAt?: string; durationSinceLastUpdated?: number; deletedAt?: string; - errors?: ServiceLocationErrors; + errors?: ServiceLocationErrors | null; }) { const { attributes } = monitor; @@ -91,7 +91,7 @@ export function formatTelemetryUpdateEvent( currentMonitor: SavedObjectsUpdateResponse, previousMonitor: SavedObject, kibanaVersion: string, - errors?: ServiceLocationErrors + errors?: ServiceLocationErrors | null ) { let durationSinceLastUpdated: number = 0; if (currentMonitor.updated_at && previousMonitor.updated_at) { @@ -113,7 +113,7 @@ export function formatTelemetryDeleteEvent( previousMonitor: SavedObject, kibanaVersion: string, deletedAt: string, - errors?: ServiceLocationErrors + errors?: ServiceLocationErrors | null ) { let durationSinceLastUpdated: number = 0; if (deletedAt && previousMonitor.updated_at) { diff --git a/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts b/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts index b24a83769caa9..0fd67b8cb3663 100644 --- a/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts +++ b/x-pack/test/api_integration/apis/uptime/rest/get_monitor.ts @@ -30,7 +30,9 @@ export default function ({ getService }: FtrProviderContext) { return res.body as SimpleSavedObject; }; - before(() => { + before(async () => { + await supertest.post(API_URLS.SYNTHETICS_ENABLEMENT).set('kbn-xsrf', 'true').expect(200); + _monitors = [ getFixtureJson('icmp_monitor'), getFixtureJson('tcp_monitor'), diff --git a/x-pack/test/api_integration/apis/uptime/rest/index.ts b/x-pack/test/api_integration/apis/uptime/rest/index.ts index f674879552d6a..61b1666b3e559 100644 --- a/x-pack/test/api_integration/apis/uptime/rest/index.ts +++ b/x-pack/test/api_integration/apis/uptime/rest/index.ts @@ -77,6 +77,7 @@ export default function ({ getService, loadTestFile }: FtrProviderContext) { loadTestFile(require.resolve('./add_monitor')); loadTestFile(require.resolve('./edit_monitor')); loadTestFile(require.resolve('./delete_monitor')); + loadTestFile(require.resolve('./synthetics_enablement')); }); }); } diff --git a/x-pack/test/api_integration/apis/uptime/rest/synthetics_enablement.ts b/x-pack/test/api_integration/apis/uptime/rest/synthetics_enablement.ts new file mode 100644 index 0000000000000..e9eff005afa3c --- /dev/null +++ b/x-pack/test/api_integration/apis/uptime/rest/synthetics_enablement.ts @@ -0,0 +1,316 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import expect from '@kbn/expect'; +import { FtrProviderContext } from '../../../ftr_provider_context'; +import { API_URLS } from '../../../../../plugins/uptime/common/constants'; +import { serviceApiKeyPrivileges } from '../../../../../plugins/uptime/server/lib/synthetics_service/get_api_key'; + +export default function ({ getService }: FtrProviderContext) { + describe('/internal/uptime/service/enablement', () => { + const supertestWithAuth = getService('supertest'); + const supertest = getService('supertestWithoutAuth'); + const security = getService('security'); + + before(async () => { + await supertestWithAuth.delete(API_URLS.SYNTHETICS_ENABLEMENT).set('kbn-xsrf', 'true'); + }); + + describe('[GET] - /internal/uptime/service/enablement', () => { + ['manage_security', 'manage_api_key', 'manage_own_api_key'].forEach((privilege) => { + it(`returns response for an admin with priviledge ${privilege}`, async () => { + const username = 'admin'; + const roleName = `synthetics_admin-${privilege}`; + const password = `${username}-password`; + try { + await security.role.create(roleName, { + kibana: [ + { + feature: { + uptime: ['all'], + }, + spaces: ['*'], + }, + ], + elasticsearch: { + cluster: [privilege, ...serviceApiKeyPrivileges.cluster], + indices: serviceApiKeyPrivileges.index, + }, + }); + + await security.user.create(username, { + password, + roles: [roleName], + full_name: 'a kibana user', + }); + + const apiResponse = await supertest + .get(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + + expect(apiResponse.body).eql({ + areApiKeysEnabled: true, + canEnable: true, + isEnabled: false, + }); + } finally { + await security.user.delete(username); + await security.role.delete(roleName); + } + }); + }); + + it('returns response for an uptime all user without admin privileges', async () => { + const username = 'uptime'; + const roleName = 'uptime_user'; + const password = `${username}-password`; + try { + await security.role.create(roleName, { + kibana: [ + { + feature: { + uptime: ['all'], + }, + spaces: ['*'], + }, + ], + elasticsearch: {}, + }); + + await security.user.create(username, { + password, + roles: [roleName], + full_name: 'a kibana user', + }); + + const apiResponse = await supertest + .get(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + + expect(apiResponse.body).eql({ + areApiKeysEnabled: true, + canEnable: false, + isEnabled: false, + }); + } finally { + await security.role.delete(roleName); + await security.user.delete(username); + } + }); + }); + + describe('[POST] - /internal/uptime/service/enablement', () => { + it('with an admin', async () => { + const username = 'admin'; + const roleName = `synthetics_admin`; + const password = `${username}-password`; + try { + await security.role.create(roleName, { + kibana: [ + { + feature: { + uptime: ['all'], + }, + spaces: ['*'], + }, + ], + elasticsearch: { + cluster: ['manage_security', ...serviceApiKeyPrivileges.cluster], + indices: serviceApiKeyPrivileges.index, + }, + }); + + await security.user.create(username, { + password, + roles: [roleName], + full_name: 'a kibana user', + }); + + await supertest + .post(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + const apiResponse = await supertest + .get(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + + expect(apiResponse.body).eql({ + areApiKeysEnabled: true, + canEnable: true, + isEnabled: true, + }); + } finally { + await supertest + .delete(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + await security.user.delete(username); + await security.role.delete(roleName); + } + }); + + it('with an uptime user', async () => { + const username = 'uptime'; + const roleName = `uptime_user`; + const password = `${username}-password`; + try { + await security.role.create(roleName, { + kibana: [ + { + feature: { + uptime: ['all'], + }, + spaces: ['*'], + }, + ], + elasticsearch: {}, + }); + + await security.user.create(username, { + password, + roles: [roleName], + full_name: 'a kibana user', + }); + + await supertest + .post(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(403); + const apiResponse = await supertest + .get(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + expect(apiResponse.body).eql({ + areApiKeysEnabled: true, + canEnable: false, + isEnabled: false, + }); + } finally { + await security.user.delete(username); + await security.role.delete(roleName); + } + }); + }); + + describe('[DELETE] - /internal/uptime/service/enablement', () => { + it('with an admin', async () => { + const username = 'admin'; + const roleName = `synthetics_admin`; + const password = `${username}-password`; + try { + await security.role.create(roleName, { + kibana: [ + { + feature: { + uptime: ['all'], + }, + spaces: ['*'], + }, + ], + elasticsearch: { + cluster: ['manage_security', ...serviceApiKeyPrivileges.cluster], + indices: serviceApiKeyPrivileges.index, + }, + }); + + await security.user.create(username, { + password, + roles: [roleName], + full_name: 'a kibana user', + }); + + await supertest + .post(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + await supertest + .delete(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + const apiResponse = await supertest + .get(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + + expect(apiResponse.body).eql({ + areApiKeysEnabled: true, + canEnable: true, + isEnabled: false, + }); + } finally { + await security.user.delete(username); + await security.role.delete(roleName); + } + }); + + it('with an uptime user', async () => { + const username = 'uptime'; + const roleName = `uptime_user`; + const password = `${username}-password`; + try { + await security.role.create(roleName, { + kibana: [ + { + feature: { + uptime: ['all'], + }, + spaces: ['*'], + }, + ], + elasticsearch: {}, + }); + + await security.user.create(username, { + password, + roles: [roleName], + full_name: 'a kibana user', + }); + + await supertestWithAuth + .post(API_URLS.SYNTHETICS_ENABLEMENT) + .set('kbn-xsrf', 'true') + .expect(200); + await supertest + .delete(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(403); + const apiResponse = await supertest + .get(API_URLS.SYNTHETICS_ENABLEMENT) + .auth(username, password) + .set('kbn-xsrf', 'true') + .expect(200); + expect(apiResponse.body).eql({ + areApiKeysEnabled: true, + canEnable: false, + isEnabled: true, + }); + } finally { + await supertestWithAuth + .delete(API_URLS.SYNTHETICS_ENABLEMENT) + .set('kbn-xsrf', 'true') + .expect(200); + await security.user.delete(username); + await security.role.delete(roleName); + } + }); + }); + }); +} From dbaf6305358ad3a6770fb833b17430a776ad4c58 Mon Sep 17 00:00:00 2001 From: Quynh Nguyen <43350163+qn895@users.noreply.github.com> Date: Tue, 29 Mar 2022 13:55:32 -0500 Subject: [PATCH 112/160] [ML] Combines annotations into one block if multiple of them overlap (#128782) * Add logic for stacking/merging overlapping annotations * Add logic for stacking/merging overlapping annotations * Add stacking to explorer charts * Fix annotation without block * Make formatting consistent between two views --- .../swimlane_annotation_container.tsx | 157 +++++++++---- .../timeseries_chart/timeseries_chart.js | 207 ++++++++++++------ 2 files changed, 250 insertions(+), 114 deletions(-) diff --git a/x-pack/plugins/ml/public/application/explorer/swimlane_annotation_container.tsx b/x-pack/plugins/ml/public/application/explorer/swimlane_annotation_container.tsx index 511bb772360c1..c8ab280d465e0 100644 --- a/x-pack/plugins/ml/public/application/explorer/swimlane_annotation_container.tsx +++ b/x-pack/plugins/ml/public/application/explorer/swimlane_annotation_container.tsx @@ -9,8 +9,8 @@ import React, { FC, useEffect } from 'react'; import d3 from 'd3'; import { scaleTime } from 'd3-scale'; import { i18n } from '@kbn/i18n'; -import { formatHumanReadableDateTimeSeconds } from '../../../common/util/date_utils'; -import { AnnotationsTable } from '../../../common/types/annotations'; +import moment from 'moment'; +import type { Annotation, AnnotationsTable } from '../../../common/types/annotations'; import { ChartTooltipService } from '../components/chart_tooltip'; import { useCurrentEuiTheme } from '../components/color_range_legend'; @@ -83,17 +83,54 @@ export const SwimlaneAnnotationContainer: FC = .style('fill', 'none') .style('stroke-width', 1); + // Merging overlapping annotations into bigger blocks + let mergedAnnotations: Array<{ start: number; end: number; annotations: Annotation[] }> = []; + const sortedAnnotationsData = [...annotationsData].sort((a, b) => a.timestamp - b.timestamp); + + if (sortedAnnotationsData.length > 0) { + let lastEndTime = + sortedAnnotationsData[0].end_timestamp ?? sortedAnnotationsData[0].timestamp; + + mergedAnnotations = [ + { + start: sortedAnnotationsData[0].timestamp, + end: lastEndTime, + annotations: [sortedAnnotationsData[0]], + }, + ]; + + for (let i = 1; i < sortedAnnotationsData.length; i++) { + if (sortedAnnotationsData[i].timestamp < lastEndTime) { + const itemToMerge = mergedAnnotations.pop(); + if (itemToMerge) { + const newMergedItem = { + ...itemToMerge, + end: lastEndTime, + annotations: [...itemToMerge.annotations, sortedAnnotationsData[i]], + }; + mergedAnnotations.push(newMergedItem); + } + } else { + lastEndTime = + sortedAnnotationsData[i].end_timestamp ?? sortedAnnotationsData[i].timestamp; + + mergedAnnotations.push({ + start: sortedAnnotationsData[i].timestamp, + end: lastEndTime, + annotations: [sortedAnnotationsData[i]], + }); + } + } + } + // Add annotation marker - annotationsData.forEach((d) => { + mergedAnnotations.forEach((d) => { const annotationWidth = Math.max( - d.end_timestamp - ? xScale(Math.min(d.end_timestamp, domain.max)) - - Math.max(xScale(d.timestamp), startingXPos) - : 0, + d.end ? xScale(Math.min(d.end, domain.max)) - Math.max(xScale(d.start), startingXPos) : 0, ANNOTATION_MIN_WIDTH ); - const xPos = d.timestamp >= domain.min ? xScale(d.timestamp) : startingXPos; + const xPos = d.start >= domain.min ? xScale(d.start) : startingXPos; svg .append('rect') .classed('mlAnnotationRect', true) @@ -103,42 +140,74 @@ export const SwimlaneAnnotationContainer: FC = .attr('height', ANNOTATION_CONTAINER_HEIGHT) .attr('width', annotationWidth) .on('mouseover', function () { - const startingTime = formatHumanReadableDateTimeSeconds(d.timestamp); - const endingTime = - d.end_timestamp !== undefined - ? formatHumanReadableDateTimeSeconds(d.end_timestamp) - : undefined; - - const timeLabel = endingTime ? `${startingTime} - ${endingTime}` : startingTime; - - const tooltipData = [ - { - label: `${d.annotation}`, - seriesIdentifier: { - key: 'anomaly_timeline', - specId: d._id ?? `${d.annotation}-${d.timestamp}-label`, - }, - valueAccessor: 'label', - }, - { - label: `${timeLabel}`, - seriesIdentifier: { - key: 'anomaly_timeline', - specId: d._id ?? `${d.annotation}-${d.timestamp}-ts`, - }, - valueAccessor: 'time', - }, - ]; - if (d.partition_field_name !== undefined && d.partition_field_value !== undefined) { - tooltipData.push({ - label: `${d.partition_field_name}: ${d.partition_field_value}`, - seriesIdentifier: { - key: 'anomaly_timeline', - specId: d._id - ? `${d._id}-partition` - : `${d.partition_field_name}-${d.partition_field_value}-label`, - }, - valueAccessor: 'partition', + const tooltipData: Array<{ + label: string; + seriesIdentifier: { key: string; specId: string } | { key: string; specId: string }; + valueAccessor: string; + skipHeader?: boolean; + value?: string; + }> = []; + if (Array.isArray(d.annotations)) { + const hasMergedAnnotations = d.annotations.length > 1; + if (hasMergedAnnotations) { + // @ts-ignore skipping header so it doesn't have other params + tooltipData.push({ skipHeader: true }); + } + d.annotations.forEach((item) => { + let timespan = moment(item.timestamp).format('MMMM Do YYYY, HH:mm'); + + if (typeof item.end_timestamp !== 'undefined') { + timespan += ` - ${moment(item.end_timestamp).format( + hasMergedAnnotations ? 'HH:mm' : 'MMMM Do YYYY, HH:mm' + )}`; + } + + if (hasMergedAnnotations) { + tooltipData.push({ + label: timespan, + value: `${item.annotation}`, + seriesIdentifier: { + key: 'anomaly_timeline', + specId: item._id ?? `${item.annotation}-${item.timestamp}-label`, + }, + valueAccessor: 'annotation', + }); + } else { + tooltipData.push( + { + label: `${item.annotation}`, + seriesIdentifier: { + key: 'anomaly_timeline', + specId: item._id ?? `${item.annotation}-${item.timestamp}-label`, + }, + valueAccessor: 'label', + }, + { + label: `${timespan}`, + seriesIdentifier: { + key: 'anomaly_timeline', + specId: item._id ?? `${item.annotation}-${item.timestamp}-ts`, + }, + valueAccessor: 'time', + } + ); + } + + if ( + item.partition_field_name !== undefined && + item.partition_field_value !== undefined + ) { + tooltipData.push({ + label: `${item.partition_field_name}: ${item.partition_field_value}`, + seriesIdentifier: { + key: 'anomaly_timeline', + specId: item._id + ? `${item._id}-partition` + : `${item.partition_field_name}-${item.partition_field_value}-label`, + }, + valueAccessor: 'partition', + }); + } }); } // @ts-ignore we don't need all the fields for tooltip to show diff --git a/x-pack/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js b/x-pack/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js index 31cdfa5df0576..9a95cf787c70d 100644 --- a/x-pack/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js +++ b/x-pack/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js @@ -975,6 +975,48 @@ class TimeseriesChartIntl extends Component { this.props; const data = contextChartData; + const focusAnnotationData = Array.isArray(annotationData) + ? [...annotationData].sort((a, b) => a.timestamp - b.timestamp) + : []; + + // Since there might be lots of annotations which is hard to view + // we should merge overlapping annotations into bigger annotation "blocks" + let mergedAnnotations = []; + if (focusAnnotationData.length > 0) { + mergedAnnotations = [ + { + start: focusAnnotationData[0].timestamp, + end: focusAnnotationData[0].end_timestamp, + annotations: [focusAnnotationData[0]], + }, + ]; + let lastEndTime = focusAnnotationData[0].end_timestamp; + + // Since annotations/intervals are already sorted from earliest to latest + // we can keep checking if next annotation starts before the last merged end_timestamp + for (let i = 1; i < focusAnnotationData.length; i++) { + if (focusAnnotationData[i].timestamp < lastEndTime) { + // If it overlaps with last annotation block, update block with latest end_timestamp + const itemToMerge = mergedAnnotations.pop(); + const newMergedItem = { + ...itemToMerge, + end: lastEndTime, + // and add to list of annotations for that block + annotations: [...itemToMerge.annotations, focusAnnotationData[i]], + }; + mergedAnnotations.push(newMergedItem); + } else { + // If annotation does not overlap with previous block, add it as a new block + mergedAnnotations.push({ + start: focusAnnotationData[i].timestamp, + end: focusAnnotationData[i].end_timestamp, + annotations: [focusAnnotationData[i]], + }); + } + lastEndTime = focusAnnotationData[i].end_timestamp; + } + } + const showFocusChartTooltip = this.showFocusChartTooltip.bind(this); const hideFocusChartTooltip = this.props.tooltipService.hide.bind(this.props.tooltipService); @@ -1101,7 +1143,7 @@ class TimeseriesChartIntl extends Component { const ctxAnnotations = cxtGroup .select('.mlContextAnnotations') .selectAll('g.mlContextAnnotation') - .data(annotationData, (d) => d._id || ''); + .data(mergedAnnotations, (d) => `${d.start}-${d.end}` || ''); ctxAnnotations.enter().append('g').classed('mlContextAnnotation', true); @@ -1113,14 +1155,14 @@ class TimeseriesChartIntl extends Component { .enter() .append('rect') .on('mouseover', function (d) { - showFocusChartTooltip(d, this); + showFocusChartTooltip(d.annotations.length === 1 ? d.annotations[0] : d, this); }) .on('mouseout', () => hideFocusChartTooltip()) .classed('mlContextAnnotationRect', true); ctxAnnotationRects - .attr('x', (d) => { - const date = moment(d.timestamp); + .attr('x', (item) => { + const date = moment(item.start); let xPos = this.contextXScale(date); if (xPos - ANNOTATION_SYMBOL_HEIGHT <= contextXRangeStart) { @@ -1135,11 +1177,11 @@ class TimeseriesChartIntl extends Component { .attr('y', cxtChartHeight + swlHeight + 2) .attr('height', ANNOTATION_SYMBOL_HEIGHT) .attr('width', (d) => { - const start = Math.max(this.contextXScale(moment(d.timestamp)) + 1, contextXRangeStart); + const start = Math.max(this.contextXScale(moment(d.start)) + 1, contextXRangeStart); const end = Math.min( contextXRangeEnd, - typeof d.end_timestamp !== 'undefined' - ? this.contextXScale(moment(d.end_timestamp)) - 1 + typeof d.end !== 'undefined' + ? this.contextXScale(moment(d.end)) - 1 : start + ANNOTATION_MIN_WIDTH ); const width = Math.max(ANNOTATION_MIN_WIDTH, end - start); @@ -1514,16 +1556,18 @@ class TimeseriesChartIntl extends Component { valueAccessor: 'typical', }); } else { - tooltipData.push({ - label: i18n.translate('xpack.ml.timeSeriesExplorer.timeSeriesChart.valueLabel', { - defaultMessage: 'value', - }), - value: formatValue(marker.value, marker.function, fieldFormat), - seriesIdentifier: { - key: seriesKey, - }, - valueAccessor: 'value', - }); + if (marker.value !== undefined) { + tooltipData.push({ + label: i18n.translate('xpack.ml.timeSeriesExplorer.timeSeriesChart.valueLabel', { + defaultMessage: 'value', + }), + value: formatValue(marker.value, marker.function, fieldFormat), + seriesIdentifier: { + key: seriesKey, + }, + valueAccessor: 'value', + }); + } if (marker.byFieldName !== undefined && marker.numberOfCauses !== undefined) { const numberOfCauses = marker.numberOfCauses; // If numberOfCauses === 1, won't go into this block as actual/typical copied to top level fields. @@ -1549,45 +1593,47 @@ class TimeseriesChartIntl extends Component { } } } else { - tooltipData.push({ - label: i18n.translate( - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.actualLabel', - { - defaultMessage: 'actual', - } - ), - value: formatValue(marker.actual, marker.function, fieldFormat), - seriesIdentifier: { - key: seriesKey, - }, - valueAccessor: 'actual', - }); - tooltipData.push({ - label: i18n.translate( - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.upperBoundsLabel', - { - defaultMessage: 'upper bounds', - } - ), - value: formatValue(marker.upper, marker.function, fieldFormat), - seriesIdentifier: { - key: seriesKey, - }, - valueAccessor: 'upper_bounds', - }); - tooltipData.push({ - label: i18n.translate( - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.lowerBoundsLabel', - { - defaultMessage: 'lower bounds', - } - ), - value: formatValue(marker.lower, marker.function, fieldFormat), - seriesIdentifier: { - key: seriesKey, - }, - valueAccessor: 'lower_bounds', - }); + if (!marker.annotations) { + tooltipData.push({ + label: i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.actualLabel', + { + defaultMessage: 'actual', + } + ), + value: formatValue(marker.actual, marker.function, fieldFormat), + seriesIdentifier: { + key: seriesKey, + }, + valueAccessor: 'actual', + }); + tooltipData.push({ + label: i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.upperBoundsLabel', + { + defaultMessage: 'upper bounds', + } + ), + value: formatValue(marker.upper, marker.function, fieldFormat), + seriesIdentifier: { + key: seriesKey, + }, + valueAccessor: 'upper_bounds', + }); + tooltipData.push({ + label: i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.lowerBoundsLabel', + { + defaultMessage: 'lower bounds', + } + ), + value: formatValue(marker.lower, marker.function, fieldFormat), + seriesIdentifier: { + key: seriesKey, + }, + valueAccessor: 'lower_bounds', + }); + } } } else { // TODO - need better formatting for small decimals. @@ -1606,22 +1652,24 @@ class TimeseriesChartIntl extends Component { valueAccessor: 'prediction', }); } else { - tooltipData.push({ - label: i18n.translate( - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.valueLabel', - { - defaultMessage: 'value', - } - ), - value: formatValue(marker.value, marker.function, fieldFormat), - seriesIdentifier: { - key: seriesKey, - }, - valueAccessor: 'value', - }); + if (marker.value !== undefined) { + tooltipData.push({ + label: i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.valueLabel', + { + defaultMessage: 'value', + } + ), + value: formatValue(marker.value, marker.function, fieldFormat), + seriesIdentifier: { + key: seriesKey, + }, + valueAccessor: 'value', + }); + } } - if (modelPlotEnabled === true) { + if (!marker.annotations && modelPlotEnabled === true) { tooltipData.push({ label: i18n.translate( 'xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.upperBoundsLabel', @@ -1692,6 +1740,25 @@ class TimeseriesChartIntl extends Component { }); } + if (marker.annotations?.length > 1) { + marker.annotations.forEach((annotation) => { + let timespan = moment(annotation.timestamp).format('MMMM Do YYYY, HH:mm'); + + if (typeof annotation.end_timestamp !== 'undefined') { + timespan += ` - ${moment(annotation.end_timestamp).format('HH:mm')}`; + } + tooltipData.push({ + label: timespan, + value: `${annotation.annotation}`, + seriesIdentifier: { + key: 'anomaly_timeline', + specId: annotation._id ?? `${annotation.annotation}-${annotation.timestamp}-label`, + }, + valueAccessor: 'annotation', + }); + }); + } + let xOffset = LINE_CHART_ANOMALY_RADIUS * 2; // When the annotation area is hovered From 11bba0a04b2b8ef362825702d6a414d5823f32fc Mon Sep 17 00:00:00 2001 From: Madison Caldwell Date: Tue, 29 Mar 2022 15:09:55 -0400 Subject: [PATCH 113/160] [Security Solution] Consider exceptions when loading threshold alert timelines (#128495) * Add exceptions to threshold timeline * Tests and error handling * Fix unit tests * Add alias for exceptions filter * Fix tests * Type fixes Co-authored-by: Marshall Main --- .../src/technical_field_names.ts | 3 + .../src/use_exception_list_items/index.ts | 2 +- .../src/build_exception_filter/index.ts | 6 +- .../build_exceptions_filter.test.ts | 5 + .../detection_engine/get_query_filter.ts | 1 + .../components/alerts_table/actions.test.tsx | 486 +++++++++++------- .../components/alerts_table/actions.tsx | 51 +- .../components/alerts_table/helpers.ts | 6 +- .../investigate_in_timeline_action.test.tsx | 5 + .../use_investigate_in_timeline.test.tsx | 5 + .../use_investigate_in_timeline.tsx | 69 ++- .../components/alerts_table/types.ts | 4 + .../take_action_dropdown/index.test.tsx | 6 + .../signals/build_events_query.ts | 1 + .../server/lib/machine_learning/index.ts | 1 + 15 files changed, 458 insertions(+), 193 deletions(-) diff --git a/packages/kbn-rule-data-utils/src/technical_field_names.ts b/packages/kbn-rule-data-utils/src/technical_field_names.ts index e49b47c712780..f76043c2a6afc 100644 --- a/packages/kbn-rule-data-utils/src/technical_field_names.ts +++ b/packages/kbn-rule-data-utils/src/technical_field_names.ts @@ -47,6 +47,7 @@ const ALERT_RULE_CREATED_AT = `${ALERT_RULE_NAMESPACE}.created_at` as const; const ALERT_RULE_CREATED_BY = `${ALERT_RULE_NAMESPACE}.created_by` as const; const ALERT_RULE_DESCRIPTION = `${ALERT_RULE_NAMESPACE}.description` as const; const ALERT_RULE_ENABLED = `${ALERT_RULE_NAMESPACE}.enabled` as const; +const ALERT_RULE_EXCEPTIONS_LIST = `${ALERT_RULE_NAMESPACE}.exceptions_list` as const; const ALERT_RULE_EXECUTION_UUID = `${ALERT_RULE_NAMESPACE}.execution.uuid` as const; const ALERT_RULE_FROM = `${ALERT_RULE_NAMESPACE}.from` as const; const ALERT_RULE_INTERVAL = `${ALERT_RULE_NAMESPACE}.interval` as const; @@ -104,6 +105,7 @@ const fields = { ALERT_RULE_CREATED_BY, ALERT_RULE_DESCRIPTION, ALERT_RULE_ENABLED, + ALERT_RULE_EXCEPTIONS_LIST, ALERT_RULE_EXECUTION_UUID, ALERT_RULE_FROM, ALERT_RULE_INTERVAL, @@ -158,6 +160,7 @@ export { ALERT_RULE_CREATED_BY, ALERT_RULE_DESCRIPTION, ALERT_RULE_ENABLED, + ALERT_RULE_EXCEPTIONS_LIST, ALERT_RULE_EXECUTION_UUID, ALERT_RULE_FROM, ALERT_RULE_INTERVAL, diff --git a/packages/kbn-securitysolution-list-hooks/src/use_exception_list_items/index.ts b/packages/kbn-securitysolution-list-hooks/src/use_exception_list_items/index.ts index 4962ecee58016..623e1e76a7f53 100644 --- a/packages/kbn-securitysolution-list-hooks/src/use_exception_list_items/index.ts +++ b/packages/kbn-securitysolution-list-hooks/src/use_exception_list_items/index.ts @@ -27,7 +27,7 @@ export type ReturnExceptionListAndItems = [ ]; /** - * Hook for using to get an ExceptionList and it's ExceptionListItems + * Hook for using to get an ExceptionList and its ExceptionListItems * * @param http Kibana http service * @param lists array of ExceptionListIdentifiers for all lists to fetch diff --git a/packages/kbn-securitysolution-list-utils/src/build_exception_filter/index.ts b/packages/kbn-securitysolution-list-utils/src/build_exception_filter/index.ts index dc00314ece266..966cf4281ad75 100644 --- a/packages/kbn-securitysolution-list-utils/src/build_exception_filter/index.ts +++ b/packages/kbn-securitysolution-list-utils/src/build_exception_filter/index.ts @@ -141,10 +141,12 @@ export const buildExceptionFilter = ({ lists, excludeExceptions, chunkSize, + alias = null, }: { lists: Array; excludeExceptions: boolean; chunkSize: number; + alias: string | null; }): Filter | undefined => { // Remove exception items with large value lists. These are evaluated // elsewhere for the moment being. @@ -154,7 +156,7 @@ export const buildExceptionFilter = ({ const exceptionFilter: Filter = { meta: { - alias: null, + alias, disabled: false, negate: excludeExceptions, }, @@ -195,7 +197,7 @@ export const buildExceptionFilter = ({ return { meta: { - alias: null, + alias, disabled: false, negate: excludeExceptions, }, diff --git a/x-pack/plugins/lists/common/exceptions/build_exceptions_filter.test.ts b/x-pack/plugins/lists/common/exceptions/build_exceptions_filter.test.ts index feee231f232b0..31d5715512d7b 100644 --- a/x-pack/plugins/lists/common/exceptions/build_exceptions_filter.test.ts +++ b/x-pack/plugins/lists/common/exceptions/build_exceptions_filter.test.ts @@ -45,6 +45,7 @@ describe('build_exceptions_filter', () => { describe('buildExceptionFilter', () => { test('it should return undefined if no exception items', () => { const booleanFilter = buildExceptionFilter({ + alias: null, chunkSize: 1, excludeExceptions: false, lists: [], @@ -54,6 +55,7 @@ describe('build_exceptions_filter', () => { test('it should build a filter given an exception list', () => { const booleanFilter = buildExceptionFilter({ + alias: null, chunkSize: 1, excludeExceptions: false, lists: [getExceptionListItemSchemaMock()], @@ -109,6 +111,7 @@ describe('build_exceptions_filter', () => { entries: [{ field: 'user.name', operator: 'included', type: 'match', value: 'name' }], }; const exceptionFilter = buildExceptionFilter({ + alias: null, chunkSize: 2, excludeExceptions: true, lists: [exceptionItem1, exceptionItem2], @@ -187,6 +190,7 @@ describe('build_exceptions_filter', () => { entries: [{ field: 'file.path', operator: 'included', type: 'match', value: '/safe/path' }], }; const exceptionFilter = buildExceptionFilter({ + alias: null, chunkSize: 2, excludeExceptions: true, lists: [exceptionItem1, exceptionItem2, exceptionItem3], @@ -284,6 +288,7 @@ describe('build_exceptions_filter', () => { ]; const booleanFilter = buildExceptionFilter({ + alias: null, chunkSize: 1, excludeExceptions: true, lists: exceptions, diff --git a/x-pack/plugins/security_solution/common/detection_engine/get_query_filter.ts b/x-pack/plugins/security_solution/common/detection_engine/get_query_filter.ts index e033dfb5b0177..326dc88a1ebd6 100644 --- a/x-pack/plugins/security_solution/common/detection_engine/get_query_filter.ts +++ b/x-pack/plugins/security_solution/common/detection_engine/get_query_filter.ts @@ -43,6 +43,7 @@ export const getQueryFilter = ( lists, excludeExceptions, chunkSize: 1024, + alias: null, }); const initialQuery = { query, language }; const allFilters = getAllFilters(filters as Filter[], exceptionFilter); diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx index b1226e5b59190..4f8882ee823b3 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx @@ -8,6 +8,8 @@ import sinon from 'sinon'; import moment from 'moment'; +import { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; + import { sendAlertToTimelineAction, determineToAndFrom } from './actions'; import { defaultTimelineProps, @@ -34,6 +36,18 @@ import { DEFAULT_FROM_MOMENT, DEFAULT_TO_MOMENT, } from '../../../common/utils/default_date_settings'; +import { + COMMENTS, + DATE_NOW, + DESCRIPTION, + ENTRIES, + ITEM_TYPE, + META, + NAME, + NAMESPACE_TYPE, + TIE_BREAKER, + USER, +} from '../../../../../lists/common/constants.mock'; jest.mock('../../../timelines/containers/api', () => ({ getTimelineTemplate: jest.fn(), @@ -41,6 +55,30 @@ jest.mock('../../../timelines/containers/api', () => ({ jest.mock('../../../common/lib/kibana'); +export const getExceptionListItemSchemaMock = ( + overrides?: Partial +): ExceptionListItemSchema => ({ + _version: undefined, + comments: COMMENTS, + created_at: DATE_NOW, + created_by: USER, + description: DESCRIPTION, + entries: ENTRIES, + id: '1', + item_id: 'endpoint_list_item', + list_id: 'endpoint_list_id', + meta: META, + name: NAME, + namespace_type: NAMESPACE_TYPE, + os_types: [], + tags: ['user added string for a tag', 'malware'], + tie_breaker_id: TIE_BREAKER, + type: ITEM_TYPE, + updated_at: DATE_NOW, + updated_by: USER, + ...(overrides || {}), +}); + describe('alert actions', () => { const anchor = '2020-03-01T17:59:46.349Z'; const unix = moment(anchor).valueOf(); @@ -49,9 +87,51 @@ describe('alert actions', () => { let searchStrategyClient: jest.Mocked; let clock: sinon.SinonFakeTimers; let mockKibanaServices: jest.Mock; + let mockGetExceptions: jest.Mock; let fetchMock: jest.Mock; let toastMock: jest.Mock; + const ecsDataMockWithNoTemplateTimeline = getThresholdDetectionAlertAADMock({ + ...mockAADEcsDataWithAlert, + kibana: { + alert: { + ...mockAADEcsDataWithAlert.kibana?.alert, + rule: { + ...mockAADEcsDataWithAlert.kibana?.alert?.rule, + parameters: { + ...mockAADEcsDataWithAlert.kibana?.alert?.rule?.parameters, + threshold: { + field: ['destination.ip'], + value: 1, + }, + }, + name: ['mock threshold rule'], + saved_id: [], + type: ['threshold'], + uuid: ['c5ba41ab-aaf3-4f43-971b-bdf9434ce0ea'], + timeline_id: undefined, + timeline_title: undefined, + }, + threshold_result: { + count: 99, + from: '2021-01-10T21:11:45.839Z', + cardinality: [ + { + field: 'source.ip', + value: 1, + }, + ], + terms: [ + { + field: 'destination.ip', + value: 1, + }, + ], + }, + }, + }, + }); + beforeEach(() => { // jest carries state between mocked implementations when using // spyOn. So now we're doing all three of these. @@ -59,6 +139,7 @@ describe('alert actions', () => { jest.resetAllMocks(); jest.restoreAllMocks(); jest.clearAllMocks(); + mockGetExceptions = jest.fn().mockResolvedValue([]); createTimeline = jest.fn() as jest.Mocked; updateTimelineIsLoading = jest.fn() as jest.Mocked; @@ -98,8 +179,10 @@ describe('alert actions', () => { ecsData: mockEcsDataWithAlert, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(updateTimelineIsLoading).toHaveBeenCalledTimes(1); expect(updateTimelineIsLoading).toHaveBeenCalledWith({ id: TimelineId.active, @@ -113,6 +196,7 @@ describe('alert actions', () => { ecsData: mockEcsDataWithAlert, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); const expected = { from: '2018-11-05T18:58:25.937Z', @@ -248,6 +332,7 @@ describe('alert actions', () => { ruleNote: '# this is some markdown documentation', }; + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledWith(expected); }); @@ -269,9 +354,11 @@ describe('alert actions', () => { ecsData: mockEcsDataWithAlert, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); const createTimelineArg = (createTimeline as jest.Mock).mock.calls[0][0]; + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledTimes(1); expect(createTimelineArg.timeline.kqlQuery.filterQuery.kuery.kind).toEqual('kuery'); }); @@ -286,6 +373,7 @@ describe('alert actions', () => { ecsData: mockEcsDataWithAlert, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); const defaultTimelinePropsWithoutNote = { ...defaultTimelineProps }; @@ -299,6 +387,7 @@ describe('alert actions', () => { id: TimelineId.active, isLoading: false, }); + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledTimes(1); expect(createTimeline).toHaveBeenCalledWith({ ...defaultTimelinePropsWithoutNote, @@ -331,9 +420,11 @@ describe('alert actions', () => { ecsData: ecsDataMock, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); expect(updateTimelineIsLoading).not.toHaveBeenCalled(); + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledTimes(1); expect(createTimeline).toHaveBeenCalledWith(defaultTimelineProps); }); @@ -356,9 +447,11 @@ describe('alert actions', () => { ecsData: ecsDataMock, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); expect(updateTimelineIsLoading).not.toHaveBeenCalled(); + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledTimes(1); expect(createTimeline).toHaveBeenCalledWith(defaultTimelineProps); }); @@ -385,9 +478,11 @@ describe('alert actions', () => { ecsData: ecsDataMock, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); expect(updateTimelineIsLoading).not.toHaveBeenCalled(); + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledTimes(1); expect(createTimeline).toHaveBeenCalledWith({ ...defaultTimelineProps, @@ -426,215 +521,260 @@ describe('alert actions', () => { ecsData: ecsDataMock, updateTimelineIsLoading, searchStrategyClient, + getExceptions: mockGetExceptions, }); expect(updateTimelineIsLoading).not.toHaveBeenCalled(); + expect(mockGetExceptions).not.toHaveBeenCalled(); expect(createTimeline).toHaveBeenCalledTimes(1); expect(createTimeline).toHaveBeenCalledWith(defaultTimelineProps); }); }); - }); - describe('determineToAndFrom', () => { - const ecsDataMockWithNoTemplateTimeline = getThresholdDetectionAlertAADMock({ - ...mockAADEcsDataWithAlert, - kibana: { - alert: { - ...mockAADEcsDataWithAlert.kibana?.alert, - rule: { - ...mockAADEcsDataWithAlert.kibana?.alert?.rule, - parameters: { - ...mockAADEcsDataWithAlert.kibana?.alert?.rule?.parameters, - threshold: { - field: ['destination.ip'], - value: 1, - }, - }, - name: ['mock threshold rule'], - saved_id: [], - type: ['threshold'], - uuid: ['c5ba41ab-aaf3-4f43-971b-bdf9434ce0ea'], - timeline_id: undefined, - timeline_title: undefined, - }, - threshold_result: { - count: 99, - from: '2021-01-10T21:11:45.839Z', - cardinality: [ - { - field: 'source.ip', - value: 1, - }, - ], - terms: [ + describe('Threshold', () => { + beforeEach(() => { + fetchMock.mockResolvedValue({ + hits: { + hits: [ { - field: 'destination.ip', - value: 1, + _id: ecsDataMockWithNoTemplateTimeline[0]._id, + _index: 'mock', + _source: ecsDataMockWithNoTemplateTimeline[0], }, ], }, - }, - }, - }); - beforeEach(() => { - fetchMock.mockResolvedValue({ - hits: { - hits: [ - { - _id: ecsDataMockWithNoTemplateTimeline[0]._id, - _index: 'mock', - _source: ecsDataMockWithNoTemplateTimeline[0], - }, - ], - }, + }); }); - }); - test('it uses ecs.Data.timestamp if one is provided', () => { - const ecsDataMock: Ecs = { - ...mockEcsDataWithAlert, - timestamp: '2020-03-20T17:59:46.349Z', - }; - const result = determineToAndFrom({ ecs: ecsDataMock }); - - expect(result.from).toEqual('2020-03-20T17:54:46.349Z'); - expect(result.to).toEqual('2020-03-20T17:59:46.349Z'); - }); - test('it uses current time timestamp if ecsData.timestamp is not provided', () => { - const { timestamp, ...ecsDataMock } = mockEcsDataWithAlert; - const result = determineToAndFrom({ ecs: ecsDataMock }); - - expect(result.from).toEqual('2020-03-01T17:54:46.349Z'); - expect(result.to).toEqual('2020-03-01T17:59:46.349Z'); - }); + test('Exceptions are included', async () => { + mockGetExceptions.mockResolvedValue([getExceptionListItemSchemaMock()]); + await sendAlertToTimelineAction({ + createTimeline, + ecsData: ecsDataMockWithNoTemplateTimeline, + updateTimelineIsLoading, + searchStrategyClient, + getExceptions: mockGetExceptions, + }); - test('it uses original_time and threshold_result.from for threshold alerts', async () => { - const expectedFrom = '2021-01-10T21:11:45.839Z'; - const expectedTo = '2021-01-10T21:12:45.839Z'; + const expectedFrom = '2021-01-10T21:11:45.839Z'; + const expectedTo = '2021-01-10T21:12:45.839Z'; - await sendAlertToTimelineAction({ - createTimeline, - ecsData: ecsDataMockWithNoTemplateTimeline, - updateTimelineIsLoading, - searchStrategyClient, - }); - expect(createTimeline).toHaveBeenCalledTimes(1); - expect(createTimeline).toHaveBeenCalledWith({ - ...defaultTimelineProps, - timeline: { - ...defaultTimelineProps.timeline, - dataProviders: [ - { - and: [], - enabled: true, - excluded: false, - id: 'send-alert-to-timeline-action-default-draggable-event-details-value-formatted-field-value-timeline-1-destination-ip-1', - kqlQuery: '', - name: 'destination.ip', - queryMatch: { field: 'destination.ip', operator: ':', value: 1 }, + expect(updateTimelineIsLoading).not.toHaveBeenCalled(); + expect(mockGetExceptions).toHaveBeenCalled(); + expect(createTimeline).toHaveBeenCalledTimes(1); + expect(createTimeline).toHaveBeenCalledWith({ + ...defaultTimelineProps, + timeline: { + ...defaultTimelineProps.timeline, + dataProviders: [ + { + and: [], + enabled: true, + excluded: false, + id: 'send-alert-to-timeline-action-default-draggable-event-details-value-formatted-field-value-timeline-1-destination-ip-1', + kqlQuery: '', + name: 'destination.ip', + queryMatch: { field: 'destination.ip', operator: ':', value: 1 }, + }, + ], + dateRange: { + start: expectedFrom, + end: expectedTo, }, - ], - dateRange: { - start: expectedFrom, - end: expectedTo, - }, - description: '_id: 1', - kqlQuery: { - filterQuery: { - kuery: { - expression: ['user.id:1'], - kind: ['kuery'], + description: '_id: 1', + filters: [ + { + meta: { + alias: 'Exceptions', + disabled: false, + negate: true, + }, + query: { + bool: { + should: [ + { + bool: { + filter: [ + { + nested: { + path: 'some.parentField', + query: { + bool: { + minimum_should_match: 1, + should: [ + { + match_phrase: { + 'some.parentField.nested.field': 'some value', + }, + }, + ], + }, + }, + score_mode: 'none', + }, + }, + { + bool: { + minimum_should_match: 1, + should: [ + { + match_phrase: { + 'some.not.nested.field': 'some value', + }, + }, + ], + }, + }, + ], + }, + }, + ], + }, + }, + }, + ], + kqlQuery: { + filterQuery: { + kuery: { + expression: ['user.id:1'], + kind: ['kuery'], + }, + serializedQuery: ['user.id:1'], }, - serializedQuery: ['user.id:1'], }, + resolveTimelineConfig: undefined, }, - resolveTimelineConfig: undefined, - }, - from: expectedFrom, - to: expectedTo, + from: expectedFrom, + to: expectedTo, + }); }); }); - }); - describe('show toasts when data is malformed', () => { - const ecsDataMockWithNoTemplateTimeline = getThresholdDetectionAlertAADMock({ - ...mockAADEcsDataWithAlert, - kibana: { - alert: { - ...mockAADEcsDataWithAlert.kibana?.alert, - rule: { - ...mockAADEcsDataWithAlert.kibana?.alert?.rule, - parameters: { - ...mockAADEcsDataWithAlert.kibana?.alert?.rule?.parameters, - threshold: { - field: ['destination.ip'], - value: 1, - }, - }, - name: ['mock threshold rule'], - saved_id: [], - type: ['threshold'], - uuid: ['c5ba41ab-aaf3-4f43-971b-bdf9434ce0ea'], - timeline_id: undefined, - timeline_title: undefined, - }, - threshold_result: { - count: 99, - from: '2021-01-10T21:11:45.839Z', - cardinality: [ + describe('determineToAndFrom', () => { + beforeEach(() => { + fetchMock.mockResolvedValue({ + hits: { + hits: [ { - field: 'source.ip', - value: 1, + _id: ecsDataMockWithNoTemplateTimeline[0]._id, + _index: 'mock', + _source: ecsDataMockWithNoTemplateTimeline[0], }, ], - terms: [ + }, + }); + }); + + test('it uses ecs.Data.timestamp if one is provided', () => { + const ecsDataMock: Ecs = { + ...mockEcsDataWithAlert, + timestamp: '2020-03-20T17:59:46.349Z', + }; + const result = determineToAndFrom({ ecs: ecsDataMock }); + + expect(result.from).toEqual('2020-03-20T17:54:46.349Z'); + expect(result.to).toEqual('2020-03-20T17:59:46.349Z'); + }); + + test('it uses current time timestamp if ecsData.timestamp is not provided', () => { + const { timestamp, ...ecsDataMock } = mockEcsDataWithAlert; + const result = determineToAndFrom({ ecs: ecsDataMock }); + + expect(result.from).toEqual('2020-03-01T17:54:46.349Z'); + expect(result.to).toEqual('2020-03-01T17:59:46.349Z'); + }); + + test('it uses original_time and threshold_result.from for threshold alerts', async () => { + const expectedFrom = '2021-01-10T21:11:45.839Z'; + const expectedTo = '2021-01-10T21:12:45.839Z'; + + await sendAlertToTimelineAction({ + createTimeline, + ecsData: ecsDataMockWithNoTemplateTimeline, + updateTimelineIsLoading, + searchStrategyClient, + getExceptions: mockGetExceptions, + }); + expect(createTimeline).toHaveBeenCalledTimes(1); + expect(createTimeline).toHaveBeenCalledWith({ + ...defaultTimelineProps, + timeline: { + ...defaultTimelineProps.timeline, + dataProviders: [ { - field: 'destination.ip', - value: 1, + and: [], + enabled: true, + excluded: false, + id: 'send-alert-to-timeline-action-default-draggable-event-details-value-formatted-field-value-timeline-1-destination-ip-1', + kqlQuery: '', + name: 'destination.ip', + queryMatch: { field: 'destination.ip', operator: ':', value: 1 }, }, ], + dateRange: { + start: expectedFrom, + end: expectedTo, + }, + description: '_id: 1', + kqlQuery: { + filterQuery: { + kuery: { + expression: ['user.id:1'], + kind: ['kuery'], + }, + serializedQuery: ['user.id:1'], + }, + }, + resolveTimelineConfig: undefined, }, - }, - }, - }); - beforeEach(() => { - fetchMock.mockResolvedValue({ - hits: 'not correctly formed doc', + from: expectedFrom, + to: expectedTo, + }); }); }); - test('renders a toast and calls create timeline with basic defaults', async () => { - const expectedFrom = DEFAULT_FROM_MOMENT.toISOString(); - const expectedTo = DEFAULT_TO_MOMENT.toISOString(); - const timelineProps = { - ...defaultTimelineProps, - timeline: { - ...defaultTimelineProps.timeline, - dataProviders: [], - dateRange: { - start: expectedFrom, - end: expectedTo, - }, - description: '', - kqlQuery: { - filterQuery: null, + + describe('show toasts when data is malformed', () => { + beforeEach(() => { + fetchMock.mockResolvedValue({ + hits: 'not correctly formed doc', + }); + }); + + test('renders a toast and calls create timeline with basic defaults', async () => { + const expectedFrom = DEFAULT_FROM_MOMENT.toISOString(); + const expectedTo = DEFAULT_TO_MOMENT.toISOString(); + const timelineProps = { + ...defaultTimelineProps, + timeline: { + ...defaultTimelineProps.timeline, + dataProviders: [], + dateRange: { + start: expectedFrom, + end: expectedTo, + }, + description: '', + kqlQuery: { + filterQuery: null, + }, + resolveTimelineConfig: undefined, }, - resolveTimelineConfig: undefined, - }, - from: expectedFrom, - to: expectedTo, - }; + from: expectedFrom, + to: expectedTo, + }; - delete timelineProps.ruleNote; + delete timelineProps.ruleNote; - await sendAlertToTimelineAction({ - createTimeline, - ecsData: ecsDataMockWithNoTemplateTimeline, - updateTimelineIsLoading, - searchStrategyClient, + await sendAlertToTimelineAction({ + createTimeline, + ecsData: ecsDataMockWithNoTemplateTimeline, + updateTimelineIsLoading, + searchStrategyClient, + getExceptions: mockGetExceptions, + }); + expect(createTimeline).toHaveBeenCalledTimes(1); + expect(createTimeline).toHaveBeenCalledWith(timelineProps); + expect(toastMock).toHaveBeenCalled(); }); - expect(createTimeline).toHaveBeenCalledTimes(1); - expect(createTimeline).toHaveBeenCalledWith(timelineProps); - expect(toastMock).toHaveBeenCalled(); }); }); }); diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.tsx index 46e439d38f81e..ac47032acc539 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.tsx @@ -11,9 +11,11 @@ import { getOr, isEmpty } from 'lodash/fp'; import moment from 'moment'; import dateMath from '@elastic/datemath'; +import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import { FilterStateStore, Filter } from '@kbn/es-query'; import { i18n } from '@kbn/i18n'; + import { ALERT_RULE_FROM, ALERT_RULE_TYPE, @@ -21,7 +23,9 @@ import { ALERT_RULE_PARAMETERS, } from '@kbn/rule-data-utils'; -import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; +import { buildExceptionFilter } from '@kbn/securitysolution-list-utils'; + import { ALERT_ORIGINAL_TIME, ALERT_GROUP_ID, @@ -265,14 +269,14 @@ export const getThresholdAggregationData = (ecsData: Ecs | Ecs[]): ThresholdAggr ); }; -export const isEqlRuleWithGroupId = (ecsData: Ecs): boolean => { +export const isEqlAlertWithGroupId = (ecsData: Ecs): boolean => { const ruleType = getField(ecsData, ALERT_RULE_TYPE); const groupId = getField(ecsData, ALERT_GROUP_ID); const isEql = ruleType === 'eql' || (Array.isArray(ruleType) && ruleType[0] === 'eql'); return isEql && groupId?.length > 0; }; -export const isThresholdRule = (ecsData: Ecs): boolean => { +export const isThresholdAlert = (ecsData: Ecs): boolean => { const ruleType = getField(ecsData, ALERT_RULE_TYPE); return ( ruleType === 'threshold' || @@ -396,7 +400,8 @@ const createThresholdTimeline = async ( ecsData: Ecs, createTimeline: ({ from, timeline, to }: CreateTimelineProps) => void, noteContent: string, - templateValues: { filters?: Filter[]; query?: string; dataProviders?: DataProvider[] } + templateValues: { filters?: Filter[]; query?: string; dataProviders?: DataProvider[] }, + getExceptions: (ecs: Ecs) => Promise ) => { try { const alertResponse = await KibanaServices.get().http.fetch< @@ -417,6 +422,7 @@ const createThresholdTimeline = async ( }, ]; }, []) ?? []; + const alertDoc = formattedAlertData[0]; const params = getField(alertDoc, ALERT_RULE_PARAMETERS); const filters = getFiltersFromRule(params.filters ?? alertDoc.signal?.rule?.filters) ?? []; @@ -425,13 +431,23 @@ const createThresholdTimeline = async ( const indexNames = params.index ?? alertDoc.signal?.rule?.index ?? []; const { thresholdFrom, thresholdTo, dataProviders } = getThresholdAggregationData(alertDoc); + const exceptions = await getExceptions(ecsData); + const exceptionsFilter = + buildExceptionFilter({ + lists: exceptions, + excludeExceptions: true, + chunkSize: 10000, + alias: 'Exceptions', + }) ?? []; + const allFilters = (templateValues.filters ?? filters).concat(exceptionsFilter); + return createTimeline({ from: thresholdFrom, notes: null, timeline: { ...timelineDefaults, description: `_id: ${alertDoc._id}`, - filters: templateValues.filters ?? filters, + filters: allFilters, dataProviders: templateValues.dataProviders ?? dataProviders, id: TimelineId.active, indexNames, @@ -495,6 +511,7 @@ export const sendAlertToTimelineAction = async ({ ecsData: ecs, updateTimelineIsLoading, searchStrategyClient, + getExceptions, }: SendAlertToTimelineActionProps) => { /* FUTURE DEVELOPER * We are making an assumption here that if you have an array of ecs data they are all coming from the same rule @@ -554,12 +571,18 @@ export const sendAlertToTimelineAction = async ({ timeline.timelineType ); // threshold with template - if (isThresholdRule(ecsData)) { - return createThresholdTimeline(ecsData, createTimeline, noteContent, { - filters, - query, - dataProviders, - }); + if (isThresholdAlert(ecsData)) { + return createThresholdTimeline( + ecsData, + createTimeline, + noteContent, + { + filters, + query, + dataProviders, + }, + getExceptions + ); } else { return createTimeline({ from, @@ -612,11 +635,11 @@ export const sendAlertToTimelineAction = async ({ to, }); } - } else if (isThresholdRule(ecsData)) { - return createThresholdTimeline(ecsData, createTimeline, noteContent, {}); + } else if (isThresholdAlert(ecsData)) { + return createThresholdTimeline(ecsData, createTimeline, noteContent, {}, getExceptions); } else { let { dataProviders, filters } = buildTimelineDataProviderOrFilter(alertIds ?? [], ecsData._id); - if (isEqlRuleWithGroupId(ecsData)) { + if (isEqlAlertWithGroupId(ecsData)) { const tempEql = buildEqlDataProviderOrFilter(alertIds ?? [], ecs); dataProviders = tempEql.dataProviders; filters = tempEql.filters; diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/helpers.ts b/x-pack/plugins/security_solution/public/detections/components/alerts_table/helpers.ts index de1a061ab7dac..37edd3ecab3e5 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/helpers.ts +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/helpers.ts @@ -6,14 +6,16 @@ */ import { isEmpty } from 'lodash/fp'; + import { Filter, FilterStateStore, KueryNode, fromKueryExpression } from '@kbn/es-query'; + +import { TimelineEventsDetailsItem } from '../../../../common/search_strategy'; +import { TimelineType } from '../../../../common/types/timeline'; import { DataProvider, DataProviderType, DataProvidersAnd, } from '../../../timelines/components/timeline/data_providers/data_provider'; -import { TimelineEventsDetailsItem } from '../../../../common/search_strategy'; -import { TimelineType } from '../../../../common/types/timeline'; interface FindValueToChangeInQuery { field: string; diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/investigate_in_timeline_action.test.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/investigate_in_timeline_action.test.tsx index 24433e2f2ca99..9564347e88ccd 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/investigate_in_timeline_action.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/investigate_in_timeline_action.test.tsx @@ -13,6 +13,7 @@ import * as actions from '../actions'; import { coreMock } from '../../../../../../../../src/core/public/mocks'; import type { SendAlertToTimelineActionProps } from '../types'; import { InvestigateInTimelineAction } from './investigate_in_timeline_action'; +import { useAppToasts } from '../../../../common/hooks/use_app_toasts'; const ecsRowData: Ecs = { _id: '1', @@ -29,6 +30,7 @@ const ecsRowData: Ecs = { }; jest.mock('../../../../common/lib/kibana'); +jest.mock('../../../../common/hooks/use_app_toasts'); jest.mock('../actions'); const props = { @@ -54,6 +56,9 @@ describe('use investigate in timeline hook', () => { }, }, }); + (useAppToasts as jest.Mock).mockReturnValue({ + addError: jest.fn(), + }); }); afterEach(() => { jest.resetAllMocks(); diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.test.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.test.tsx index fc413a6f4f814..7dea1581e9f0f 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.test.tsx @@ -13,6 +13,7 @@ import { useInvestigateInTimeline } from './use_investigate_in_timeline'; import * as actions from '../actions'; import { coreMock } from '../../../../../../../../src/core/public/mocks'; import type { SendAlertToTimelineActionProps } from '../types'; +import { useAppToasts } from '../../../../common/hooks/use_app_toasts'; const ecsRowData: Ecs = { _id: '1', @@ -29,6 +30,7 @@ const ecsRowData: Ecs = { }; jest.mock('../../../../common/lib/kibana'); +jest.mock('../../../../common/hooks/use_app_toasts'); jest.mock('../actions'); const props = { @@ -53,6 +55,9 @@ describe('use investigate in timeline hook', () => { }, }, }); + (useAppToasts as jest.Mock).mockReturnValue({ + addError: jest.fn(), + }); }); afterEach(() => { jest.resetAllMocks(); diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.tsx index 301395eb5b963..58163029667e6 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/timeline_actions/use_investigate_in_timeline.tsx @@ -8,8 +8,17 @@ import React, { useCallback, useMemo } from 'react'; import { useDispatch } from 'react-redux'; import { EuiContextMenuItem } from '@elastic/eui'; -import { useKibana } from '../../../../common/lib/kibana'; +import { i18n } from '@kbn/i18n'; +import { ALERT_RULE_EXCEPTIONS_LIST } from '@kbn/rule-data-utils'; +import { + ExceptionListIdentifiers, + ExceptionListItemSchema, + ReadExceptionListSchema, +} from '@kbn/securitysolution-io-ts-list-types'; +import { useApi } from '@kbn/securitysolution-list-hooks'; + +import { useKibana } from '../../../../common/lib/kibana'; import { TimelineId, TimelineType } from '../../../../../common/types/timeline'; import { Ecs } from '../../../../../common/ecs'; import { timelineActions, timelineSelectors } from '../../../../timelines/store/timeline'; @@ -19,6 +28,8 @@ import { useCreateTimeline } from '../../../../timelines/components/timeline/pro import { CreateTimelineProps } from '../types'; import { ACTION_INVESTIGATE_IN_TIMELINE } from '../translations'; import { useDeepEqualSelector } from '../../../../common/hooks/use_selector'; +import { getField } from '../../../../helpers'; +import { useAppToasts } from '../../../../common/hooks/use_app_toasts'; interface UseInvestigateInTimelineActionProps { ecsRowData?: Ecs | Ecs[] | null; @@ -29,11 +40,65 @@ export const useInvestigateInTimeline = ({ ecsRowData, onInvestigateInTimelineAlertClick, }: UseInvestigateInTimelineActionProps) => { + const { addError } = useAppToasts(); const { data: { search: searchStrategyClient, query }, } = useKibana().services; const dispatch = useDispatch(); + const { services } = useKibana(); + const { getExceptionListsItems } = useApi(services.http); + + const getExceptions = useCallback( + async (ecsData: Ecs): Promise => { + const exceptionsLists: ReadExceptionListSchema[] = ( + getField(ecsData, ALERT_RULE_EXCEPTIONS_LIST) ?? [] + ) + .map((list: string) => JSON.parse(list)) + .filter((list: ExceptionListIdentifiers) => list.type === 'detection'); + + const allExceptions: ExceptionListItemSchema[] = []; + + if (exceptionsLists.length > 0) { + for (const list of exceptionsLists) { + if (list.id && list.list_id && list.namespace_type) { + await getExceptionListsItems({ + lists: [ + { + id: list.id, + listId: list.list_id, + type: 'detection', + namespaceType: list.namespace_type, + }, + ], + filterOptions: [], + pagination: { + page: 0, + perPage: 10000, + total: 10000, + }, + showDetectionsListsOnly: true, + showEndpointListsOnly: false, + onSuccess: ({ exceptions }) => { + allExceptions.push(...exceptions); + }, + onError: (err: string[]) => { + addError(err, { + title: i18n.translate( + 'xpack.securitySolution.detectionEngine.alerts.fetchExceptionsFailure', + { defaultMessage: 'Error fetching exceptions.' } + ), + }); + }, + }); + } + } + } + return allExceptions; + }, + [addError, getExceptionListsItems] + ); + const filterManagerBackup = useMemo(() => query.filterManager, [query.filterManager]); const getManageTimeline = useMemo(() => timelineSelectors.getManageTimelineById(), []); const { filterManager: activeFilterManager } = useDeepEqualSelector((state) => @@ -86,6 +151,7 @@ export const useInvestigateInTimeline = ({ ecsData: ecsRowData, searchStrategyClient, updateTimelineIsLoading, + getExceptions, }); } }, [ @@ -94,6 +160,7 @@ export const useInvestigateInTimeline = ({ onInvestigateInTimelineAlertClick, searchStrategyClient, updateTimelineIsLoading, + getExceptions, ]); const investigateInTimelineActionItems = useMemo( diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/types.ts b/x-pack/plugins/security_solution/public/detections/components/alerts_table/types.ts index 1ca0fc9b7ca23..6773a4fddaeaf 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/types.ts +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/types.ts @@ -5,6 +5,8 @@ * 2.0. */ +import { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; + import type { ISearchStart } from '../../../../../../../src/plugins/data/public'; import { Status } from '../../../../common/detection_engine/schemas/common/schemas'; import { Ecs } from '../../../../common/ecs'; @@ -55,6 +57,7 @@ export interface SendAlertToTimelineActionProps { ecsData: Ecs | Ecs[]; updateTimelineIsLoading: UpdateTimelineLoading; searchStrategyClient: ISearchStart; + getExceptions: GetExceptions; } export type UpdateTimelineLoading = ({ id, isLoading }: { id: string; isLoading: boolean }) => void; @@ -68,6 +71,7 @@ export interface CreateTimelineProps { } export type CreateTimeline = ({ from, timeline, to }: CreateTimelineProps) => void; +export type GetExceptions = (ecsData: Ecs) => Promise; export interface ThresholdAggregationData { thresholdFrom: string; diff --git a/x-pack/plugins/security_solution/public/detections/components/take_action_dropdown/index.test.tsx b/x-pack/plugins/security_solution/public/detections/components/take_action_dropdown/index.test.tsx index 8aa8986d3e563..bbc10fcb2dfd4 100644 --- a/x-pack/plugins/security_solution/public/detections/components/take_action_dropdown/index.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/take_action_dropdown/index.test.tsx @@ -35,6 +35,12 @@ jest.mock('../../containers/detection_engine/alerts/use_alerts_privileges', () = })); jest.mock('../../../cases/components/use_insert_timeline'); +jest.mock('../../../common/hooks/use_app_toasts', () => ({ + useAppToasts: jest.fn().mockReturnValue({ + addError: jest.fn(), + }), +})); + jest.mock('../../../common/hooks/use_experimental_features', () => ({ useIsExperimentalFeatureEnabled: jest.fn().mockReturnValue(true), })); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_events_query.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_events_query.ts index 1a664261215c2..346abaea66dd6 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_events_query.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/build_events_query.ts @@ -193,6 +193,7 @@ export const buildEqlSearchRequest = ( lists: exceptionLists, excludeExceptions: true, chunkSize: 1024, + alias: null, }); const rangeFilter = buildTimeRangeFilter({ to, from, timestampOverride }); diff --git a/x-pack/plugins/security_solution/server/lib/machine_learning/index.ts b/x-pack/plugins/security_solution/server/lib/machine_learning/index.ts index 27a3d376ece92..5beba022d8614 100644 --- a/x-pack/plugins/security_solution/server/lib/machine_learning/index.ts +++ b/x-pack/plugins/security_solution/server/lib/machine_learning/index.ts @@ -57,6 +57,7 @@ export const getAnomalies = async ( lists: params.exceptionItems, excludeExceptions: true, chunkSize: 1024, + alias: null, })?.query, }, }, From 1e33587b68b8852474b2a63c8d78845cf7d62a7f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cau=C3=AA=20Marcondes?= <55978943+cauemarcondes@users.noreply.github.com> Date: Tue, 29 Mar 2022 15:16:32 -0400 Subject: [PATCH 114/160] [APM] fix cypress (#128411) * Fix synthtrace, some broken tests * fixing comparison test * fixing error count e2e * fixing error details test * Fix APM deep links * Add default environment to /apm/services request in home.spec.ts * fixing service overview filter test * Fix accessibility test in transactions overview page * testing CI * removing time arg * removing unused import * Fix e2e tests for infrastructure feature flag * fixing and skipping tests * fixing test * skipping flaky test Co-authored-by: Dario Gieselaar Co-authored-by: gbamparop Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- packages/elastic-apm-synthtrace/src/index.ts | 1 + .../power_user/feature_flag/comparison.ts | 8 +++ .../power_user/feature_flag/infrastructure.ts | 12 ++--- .../power_user/rules/error_count.spec.ts | 12 +---- .../errors/error_details.spec.ts | 4 +- .../integration/read_only_user/home.spec.ts | 7 +-- .../service_inventory.spec.ts | 5 +- .../service_overview/header_filters.spec.ts | 7 +-- .../service_overview/service_overview.spec.ts | 51 +++++++------------ .../service_overview/time_comparison.spec.ts | 3 +- .../transactions_overview.spec.ts | 7 +-- .../apm/ftr_e2e/cypress/plugins/index.ts | 6 +-- .../apm/ftr_e2e/cypress/support/commands.ts | 18 ++++--- x-pack/plugins/apm/ftr_e2e/ftr_config_run.ts | 2 +- x-pack/plugins/apm/ftr_e2e/synthtrace.ts | 2 +- x-pack/plugins/apm/public/plugin.ts | 34 ++++--------- x-pack/plugins/apm/scripts/test/e2e.js | 26 +--------- 17 files changed, 77 insertions(+), 128 deletions(-) diff --git a/packages/elastic-apm-synthtrace/src/index.ts b/packages/elastic-apm-synthtrace/src/index.ts index 0138a6525baf5..9c44f1902789c 100644 --- a/packages/elastic-apm-synthtrace/src/index.ts +++ b/packages/elastic-apm-synthtrace/src/index.ts @@ -15,3 +15,4 @@ export { createLogger, LogLevel } from './lib/utils/create_logger'; export type { Fields } from './lib/entity'; export type { ApmException, ApmSynthtraceEsClient } from './lib/apm'; export type { SpanIterable } from './lib/span_iterable'; +export { SpanArrayIterable } from './lib/span_iterable'; diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/comparison.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/comparison.ts index 1bc4ad0a478b6..d5a28b6d85bb4 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/comparison.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/comparison.ts @@ -62,6 +62,14 @@ describe('Comparison feature flag', () => { }); describe('when comparison feature is disabled', () => { + // Reverts to default state, which is comparison enabled + after(() => { + cy.visit(settingsPath); + cy.get(comparisonToggle).click(); + cy.contains('Save changes').should('not.be.disabled'); + cy.contains('Save changes').click(); + }); + it('shows the flag as disabled in kibana advanced settings', () => { cy.visit(settingsPath); cy.get(comparisonToggle).click(); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/infrastructure.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/infrastructure.ts index 0b142e41ab607..1fade825bc4cb 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/infrastructure.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/feature_flag/infrastructure.ts @@ -41,12 +41,12 @@ describe('Infrastracture feature flag', () => { cy.get(infraToggle) .should('have.attr', 'aria-checked') - .and('equal', 'true'); + .and('equal', 'false'); }); - it('shows infrastructure tab in service overview page', () => { + it('hides infrastructure tab in service overview page', () => { cy.visit(serviceOverviewPath); - cy.contains('a[role="tab"]', 'Infrastructure').click(); + cy.contains('a[role="tab"]', 'Infrastructure').should('not.exist'); }); }); @@ -59,12 +59,12 @@ describe('Infrastracture feature flag', () => { cy.get(infraToggle) .should('have.attr', 'aria-checked') - .and('equal', 'false'); + .and('equal', 'true'); }); - it('hides infrastructure tab in service overview page', () => { + it('shows infrastructure tab in service overview page', () => { cy.visit(serviceOverviewPath); - cy.contains('a[role="tab"]', 'Infrastructure').should('not.exist'); + cy.contains('a[role="tab"]', 'Infrastructure').click(); }); }); }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/rules/error_count.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/rules/error_count.spec.ts index 89e203860179f..e53b84ca76496 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/rules/error_count.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/power_user/rules/error_count.spec.ts @@ -49,8 +49,7 @@ describe('Rules', () => { // Create a rule in APM cy.visit('/app/apm/services'); cy.contains('Alerts and rules').click(); - cy.contains('Error count').click(); - cy.contains('Create threshold rule').click(); + cy.contains('Create error count rule').click(); // Check for the existence of this element to make sure the form // has loaded. @@ -69,10 +68,6 @@ describe('Rules', () => { before(() => { cy.loginAsPowerUser(); deleteAllRules(); - cy.intercept( - 'GET', - '/api/alerting/rules/_find?page=1&per_page=10&default_search_operator=AND&sort_field=name&sort_order=asc' - ).as('list rules API call'); }); after(() => { @@ -83,11 +78,6 @@ describe('Rules', () => { // Go to stack management cy.visit('/app/management/insightsAndAlerting/triggersActions/rules'); - // Wait for this call to finish so the create rule button does not disappear. - // The timeout is set high because at this point we're also waiting for the - // full page load. - cy.wait('@list rules API call', { timeout: 30000 }); - // Create a rule cy.contains('button', 'Create rule').click(); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/errors/error_details.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/errors/error_details.spec.ts index beaf1837c834c..c131cb2dd36d7 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/errors/error_details.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/errors/error_details.spec.ts @@ -14,7 +14,7 @@ const start = '2021-10-10T00:00:00.000Z'; const end = '2021-10-10T00:15:00.000Z'; const errorDetailsPageHref = url.format({ pathname: - '/app/apm/services/opbeans-java/errors/0000000000000000000000000Error%201', + '/app/apm/services/opbeans-java/errors/0000000000000000000000000Error%200', query: { rangeFrom: start, rangeTo: end, @@ -89,7 +89,7 @@ describe('Error details', () => { describe('when clicking on View x occurences in discover', () => { it('should redirects the user to discover', () => { cy.visit(errorDetailsPageHref); - cy.contains('span', 'Discover').click(); + cy.contains('View 1 occurrence in Discover.').click(); cy.url().should('include', 'app/discover'); }); }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/home.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/home.spec.ts index 1e09ec6dbf7c1..f0f306a538331 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/home.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/home.spec.ts @@ -28,7 +28,8 @@ const apisToIntercept = [ }, ]; -describe('Home page', () => { +// flaky test +describe.skip('Home page', () => { before(async () => { await synthtrace.index( opbeans({ @@ -46,12 +47,12 @@ describe('Home page', () => { cy.loginAsReadOnlyUser(); }); - it('Redirects to service page with rangeFrom and rangeTo added to the URL', () => { + it('Redirects to service page with environment, rangeFrom and rangeTo added to the URL', () => { cy.visit('/app/apm'); cy.url().should( 'include', - 'app/apm/services?rangeFrom=now-15m&rangeTo=now' + 'app/apm/services?environment=ENVIRONMENT_ALL&rangeFrom=now-15m&rangeTo=now' ); }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_inventory/service_inventory.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_inventory/service_inventory.spec.ts index 40afece0ce908..ecee9c3c4f63e 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_inventory/service_inventory.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_inventory/service_inventory.spec.ts @@ -4,6 +4,7 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ +import moment from 'moment'; import url from 'url'; import { synthtrace } from '../../../../synthtrace'; import { opbeans } from '../../../fixtures/synthtrace/opbeans'; @@ -104,8 +105,8 @@ describe('When navigating to the service inventory', () => { cy.wait(aliasNames); cy.selectAbsoluteTimeRange( - 'Oct 10, 2021 @ 01:00:00.000', - 'Oct 10, 2021 @ 01:30:00.000' + moment(timeRange.rangeFrom).subtract(5, 'm').toISOString(), + moment(timeRange.rangeTo).subtract(5, 'm').toISOString() ); cy.contains('Update').click(); cy.wait(aliasNames); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/header_filters.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/header_filters.spec.ts index 49d7104f44a88..9caf8ede5e527 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/header_filters.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/header_filters.spec.ts @@ -46,11 +46,6 @@ const apisToIntercept = [ '/internal/apm/services/opbeans-node/service_overview_instances/main_statistics?*', name: 'instancesMainStatisticsRequest', }, - { - endpoint: - '/internal/apm/services/opbeans-node/errors/groups/main_statistics?*', - name: 'errorGroupsMainStatisticsRequest', - }, { endpoint: '/internal/apm/services/opbeans-node/transaction/charts/breakdown?*', @@ -144,7 +139,7 @@ describe('Service overview - header filters', () => { .find('li') .first() .click(); - cy.get('[data-test-subj="suggestionContainer"]').realPress('{enter}'); + cy.get('[data-test-subj="headerFilterKuerybar"]').type('{enter}'); cy.url().should('include', '&kuery=transaction.name'); }); }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts index 4dd66f6dd9311..0935d23d02696 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/service_overview.spec.ts @@ -5,6 +5,7 @@ * 2.0. */ +import moment from 'moment'; import url from 'url'; import { synthtrace } from '../../../../synthtrace'; import { opbeans } from '../../../fixtures/synthtrace/opbeans'; @@ -23,12 +24,12 @@ const apiRequestsToIntercept = [ { endpoint: '/internal/apm/services/opbeans-node/transactions/groups/main_statistics?*', - aliasName: 'transactionsGroupsMainStadisticsRequest', + aliasName: 'transactionsGroupsMainStatisticsRequest', }, { endpoint: '/internal/apm/services/opbeans-node/errors/groups/main_statistics?*', - aliasName: 'errorsGroupsMainStadisticsRequest', + aliasName: 'errorsGroupsMainStatisticsRequest', }, { endpoint: @@ -59,18 +60,18 @@ const apiRequestsToInterceptWithComparison = [ { endpoint: '/internal/apm/services/opbeans-node/transactions/groups/detailed_statistics?*', - aliasName: 'transactionsGroupsDetailedStadisticsRequest', + aliasName: 'transactionsGroupsDetailedStatisticsRequest', }, { endpoint: '/internal/apm/services/opbeans-node/service_overview_instances/main_statistics?*', - aliasName: 'instancesMainStadisticsRequest', + aliasName: 'instancesMainStatisticsRequest', }, { endpoint: '/internal/apm/services/opbeans-node/service_overview_instances/detailed_statistics?*', - aliasName: 'instancesDetailedStadisticsRequest', + aliasName: 'instancesDetailedStatisticsRequest', }, ]; @@ -84,7 +85,8 @@ const aliasNamesWithComparison = apiRequestsToInterceptWithComparison.map( const aliasNames = [...aliasNamesNoComparison, ...aliasNamesWithComparison]; -describe('Service Overview', () => { +// flaky test +describe.skip('Service Overview', () => { before(async () => { await synthtrace.index( opbeans({ @@ -104,37 +106,16 @@ describe('Service Overview', () => { cy.visit(baseUrl); }); - it('has no detectable a11y violations on load', () => { + it('renders all components on the page', () => { cy.contains('opbeans-node'); // set skipFailures to true to not fail the test when there are accessibility failures checkA11y({ skipFailures: true }); - }); - - it('transaction latency chart', () => { cy.get('[data-test-subj="latencyChart"]'); - }); - - it('throughput chart', () => { cy.get('[data-test-subj="throughput"]'); - }); - - it('transactions group table', () => { cy.get('[data-test-subj="transactionsGroupTable"]'); - }); - - it('error table', () => { cy.get('[data-test-subj="serviceOverviewErrorsTable"]'); - }); - - it('dependencies table', () => { cy.get('[data-test-subj="dependenciesTable"]'); - }); - - it('instances latency distribution chart', () => { cy.get('[data-test-subj="instancesLatencyDistribution"]'); - }); - - it('instances table', () => { cy.get('[data-test-subj="serviceOverviewInstancesTable"]'); }); }); @@ -241,16 +222,18 @@ describe('Service Overview', () => { it('when selecting a different time range and clicking the update button', () => { cy.wait(aliasNames, { requestTimeout: 10000 }); - cy.selectAbsoluteTimeRange( - 'Oct 10, 2021 @ 01:00:00.000', - 'Oct 10, 2021 @ 01:30:00.000' - ); + const timeStart = moment(start).subtract(5, 'm').toISOString(); + const timeEnd = moment(end).subtract(5, 'm').toISOString(); + + cy.selectAbsoluteTimeRange(timeStart, timeEnd); + cy.contains('Update').click(); cy.expectAPIsToHaveBeenCalledWith({ apisIntercepted: aliasNames, - value: - 'start=2021-10-10T00%3A00%3A00.000Z&end=2021-10-10T00%3A30%3A00.000Z', + value: `start=${encodeURIComponent( + new Date(timeStart).toISOString() + )}&end=${encodeURIComponent(new Date(timeEnd).toISOString())}`, }); }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts index 955b429a567a7..f844969850b84 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/service_overview/time_comparison.spec.ts @@ -50,7 +50,8 @@ const apisToIntercept = [ }, ]; -describe('Service overview: Time Comparison', () => { +// Skipping tests since it's flaky. +describe.skip('Service overview: Time Comparison', () => { before(async () => { await synthtrace.index( opbeans({ diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/transactions_overview/transactions_overview.spec.ts b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/transactions_overview/transactions_overview.spec.ts index fb8468f42474e..c5676dfb9c532 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/transactions_overview/transactions_overview.spec.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/integration/read_only_user/transactions_overview/transactions_overview.spec.ts @@ -38,9 +38,10 @@ describe('Transactions Overview', () => { it('has no detectable a11y violations on load', () => { cy.visit(serviceTransactionsHref); - cy.contains('aria-selected="true"', 'Transactions').should( - 'have.class', - 'euiTab-isSelected' + cy.get('a:contains(Transactions)').should( + 'have.attr', + 'aria-selected', + 'true' ); // set skipFailures to true to not fail the test when there are accessibility failures checkA11y({ skipFailures: true }); diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/plugins/index.ts b/x-pack/plugins/apm/ftr_e2e/cypress/plugins/index.ts index 6b6aff63976d5..093ededbcc247 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/plugins/index.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/plugins/index.ts @@ -8,7 +8,7 @@ import { apm, createLogger, LogLevel, - SpanIterable, + SpanArrayIterable, } from '@elastic/apm-synthtrace'; import { createEsClientForTesting } from '@kbn/test'; @@ -46,8 +46,8 @@ const plugin: Cypress.PluginConfig = (on, config) => { ); on('task', { - 'synthtrace:index': async (events: SpanIterable) => { - await synthtraceEsClient.index(events); + 'synthtrace:index': async (events: Array>) => { + await synthtraceEsClient.index(new SpanArrayIterable(events)); return null; }, 'synthtrace:clean': async () => { diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts b/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts index 89d8fa620c183..3d8d86145cdac 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts @@ -7,7 +7,9 @@ import 'cypress-real-events/support'; import { Interception } from 'cypress/types/net-stubbing'; import 'cypress-axe'; -import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; +import moment from 'moment'; +// Commenting this out since it's breaking the tests. It was caused by https://github.com/elastic/kibana/commit/bef90a58663b6c4b668a7fe0ce45a002fb68c474#diff-8a4659c6955a712376fe5ca0d81636164d1b783a63fe9d1a23da4850bd0dfce3R10 +// import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; Cypress.Commands.add('loginAsReadOnlyUser', () => { cy.loginAs({ username: 'apm_read_user', password: 'changeme' }); @@ -47,16 +49,18 @@ Cypress.Commands.add('changeTimeRange', (value: string) => { Cypress.Commands.add( 'selectAbsoluteTimeRange', (start: string, end: string) => { + const format = 'MMM D, YYYY @ HH:mm:ss.SSS'; + cy.get('[data-test-subj="superDatePickerstartDatePopoverButton"]').click(); cy.get('[data-test-subj="superDatePickerAbsoluteDateInput"]') .eq(0) .clear() - .type(start, { force: true }); + .type(moment(start).format(format), { force: true }); cy.get('[data-test-subj="superDatePickerendDatePopoverButton"]').click(); cy.get('[data-test-subj="superDatePickerAbsoluteDateInput"]') .eq(1) .clear() - .type(end, { force: true }); + .type(moment(end).format(format), { force: true }); } ); @@ -84,11 +88,13 @@ Cypress.Commands.add( // A11y configuration const axeConfig = { - ...AXE_CONFIG, + // See comment on line 11 + // ...AXE_CONFIG, }; const axeOptions = { - ...AXE_OPTIONS, - runOnly: [...AXE_OPTIONS.runOnly, 'best-practice'], + // See comment on line 11 + // ...AXE_OPTIONS, + // runOnly: [...AXE_OPTIONS.runOnly, 'best-practice'], }; export const checkA11y = ({ skipFailures }: { skipFailures: boolean }) => { diff --git a/x-pack/plugins/apm/ftr_e2e/ftr_config_run.ts b/x-pack/plugins/apm/ftr_e2e/ftr_config_run.ts index 768ad9b3f79f6..34d6da688de82 100644 --- a/x-pack/plugins/apm/ftr_e2e/ftr_config_run.ts +++ b/x-pack/plugins/apm/ftr_e2e/ftr_config_run.ts @@ -23,7 +23,7 @@ async function testRunner({ getService }: FtrProviderContext) { const result = await cypressStart(getService, cypress.run); if (result && (result.status === 'failed' || result.totalFailed > 0)) { - throw new Error(`APM Cypress tests failed`); + process.exit(1); } } diff --git a/x-pack/plugins/apm/ftr_e2e/synthtrace.ts b/x-pack/plugins/apm/ftr_e2e/synthtrace.ts index 2409dded17780..775951dfe85c7 100644 --- a/x-pack/plugins/apm/ftr_e2e/synthtrace.ts +++ b/x-pack/plugins/apm/ftr_e2e/synthtrace.ts @@ -9,7 +9,7 @@ import { SpanIterable } from '@elastic/apm-synthtrace'; export const synthtrace = { index: (events: SpanIterable) => new Promise((resolve) => { - cy.task('synthtrace:index', events).then(resolve); + cy.task('synthtrace:index', events.toArray()).then(resolve); }), clean: () => new Promise((resolve) => { diff --git a/x-pack/plugins/apm/public/plugin.ts b/x-pack/plugins/apm/public/plugin.ts index 1968f35791f40..83aad1b3b4fe6 100644 --- a/x-pack/plugins/apm/public/plugin.ts +++ b/x-pack/plugins/apm/public/plugin.ts @@ -263,30 +263,16 @@ export class ApmPlugin implements Plugin { icon: 'plugins/apm/public/icon.svg', category: DEFAULT_APP_CATEGORIES.observability, deepLinks: [ - { - id: 'services', - title: servicesTitle, - // path: serviceGroupsEnabled ? '/service-groups' : '/services', - deepLinks: serviceGroupsEnabled - ? [ - { - id: 'service-groups-list', - title: 'Service groups', - path: '/service-groups', - }, - { - id: 'service-groups-services', - title: servicesTitle, - path: '/services', - }, - { - id: 'service-groups-service-map', - title: serviceMapTitle, - path: '/service-map', - }, - ] - : [], - }, + ...(serviceGroupsEnabled + ? [ + { + id: 'service-groups-list', + title: 'Service groups', + path: '/service-groups', + }, + ] + : []), + { id: 'services', title: servicesTitle, path: '/services' }, { id: 'traces', title: tracesTitle, path: '/traces' }, { id: 'service-map', title: serviceMapTitle, path: '/service-map' }, { id: 'backends', title: dependenciesTitle, path: '/backends' }, diff --git a/x-pack/plugins/apm/scripts/test/e2e.js b/x-pack/plugins/apm/scripts/test/e2e.js index 8f3461af238bf..148d5011b1ecb 100644 --- a/x-pack/plugins/apm/scripts/test/e2e.js +++ b/x-pack/plugins/apm/scripts/test/e2e.js @@ -7,7 +7,6 @@ /* eslint-disable no-console */ -const { times } = require('lodash'); const path = require('path'); const yargs = require('yargs'); const childProcess = require('child_process'); @@ -46,11 +45,6 @@ const { argv } = yargs(process.argv.slice(2)) type: 'boolean', description: 'stop tests after the first failure', }) - .option('times', { - default: 1, - type: 'number', - description: 'Repeat the test n number of times', - }) .help(); const { server, runner, open, grep, bail, kibanaInstallDir } = argv; @@ -70,22 +64,4 @@ const bailArg = bail ? `--bail` : ''; const cmd = `node ../../../../scripts/${ftrScript} --config ${config} ${grepArg} ${bailArg} --kibana-install-dir '${kibanaInstallDir}'`; console.log(`Running "${cmd}"`); - -if (argv.times > 1) { - console.log(`The command will be executed ${argv.times} times`); -} - -const runCounter = { succeeded: 0, failed: 0, remaining: argv.times }; -times(argv.times, () => { - try { - childProcess.execSync(cmd, { cwd: e2eDir, stdio: 'inherit' }); - runCounter.succeeded++; - } catch (e) { - runCounter.failed++; - } - runCounter.remaining--; - - if (argv.times > 1) { - console.log(runCounter); - } -}); +childProcess.execSync(cmd, { cwd: e2eDir, stdio: 'inherit' }); From 92d65484a5deff0a8da8b4661fc72ae97f574537 Mon Sep 17 00:00:00 2001 From: Spencer Date: Tue, 29 Mar 2022 13:19:58 -0600 Subject: [PATCH 115/160] [plugin-discovery] move logic to a package (#128684) --- .github/CODEOWNERS | 1 + package.json | 2 + packages/BUILD.bazel | 2 + packages/kbn-dev-utils/BUILD.bazel | 3 +- packages/kbn-dev-utils/src/index.ts | 1 - .../src/plugin_list/discover_plugins.ts | 2 +- .../src/api_docs/find_plugins.ts | 2 +- .../src/optimizer/kibana_platform_plugins.ts | 2 +- packages/kbn-plugin-discovery/BUILD.bazel | 124 ++++++++++++++++++ packages/kbn-plugin-discovery/README.md | 3 + packages/kbn-plugin-discovery/jest.config.js | 13 ++ packages/kbn-plugin-discovery/package.json | 7 + .../src}/index.ts | 1 + .../src}/parse_kibana_platform_plugin.ts | 6 +- .../src/plugin_search_paths.ts | 26 ++++ ...simple_kibana_platform_plugin_discovery.ts | 7 +- packages/kbn-plugin-discovery/tsconfig.json | 18 +++ .../src/load_kibana_platform_plugin.ts | 3 +- .../src/lib/bazel_cli_config.ts | 1 + src/dev/plugin_discovery/find_plugins.ts | 2 +- src/dev/plugin_discovery/get_plugin_deps.ts | 2 +- ...n_find_plugins_ready_migrate_to_ts_refs.ts | 3 +- yarn.lock | 8 ++ 23 files changed, 225 insertions(+), 14 deletions(-) create mode 100644 packages/kbn-plugin-discovery/BUILD.bazel create mode 100644 packages/kbn-plugin-discovery/README.md create mode 100644 packages/kbn-plugin-discovery/jest.config.js create mode 100644 packages/kbn-plugin-discovery/package.json rename packages/{kbn-dev-utils/src/plugins => kbn-plugin-discovery/src}/index.ts (92%) rename packages/{kbn-dev-utils/src/plugins => kbn-plugin-discovery/src}/parse_kibana_platform_plugin.ts (94%) create mode 100644 packages/kbn-plugin-discovery/src/plugin_search_paths.ts rename packages/{kbn-dev-utils/src/plugins => kbn-plugin-discovery/src}/simple_kibana_platform_plugin_discovery.ts (86%) create mode 100644 packages/kbn-plugin-discovery/tsconfig.json diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index c89fe8be4a654..c07121d3bc07f 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -232,6 +232,7 @@ /packages/kbn-utils/ @elastic/kibana-operations /packages/kbn-cli-dev-mode/ @elastic/kibana-operations /packages/kbn-generate/ @elastic/kibana-operations +/packages/kbn-plugin-discovery/ @elastic/kibana-operations /src/cli/keystore/ @elastic/kibana-operations /.ci/es-snapshots/ @elastic/kibana-operations /.github/workflows/ @elastic/kibana-operations diff --git a/package.json b/package.json index 35edc14f01325..8b434d291013e 100644 --- a/package.json +++ b/package.json @@ -148,6 +148,7 @@ "@kbn/logging-mocks": "link:bazel-bin/packages/kbn-logging-mocks", "@kbn/mapbox-gl": "link:bazel-bin/packages/kbn-mapbox-gl", "@kbn/monaco": "link:bazel-bin/packages/kbn-monaco", + "@kbn/plugin-discovery": "link:bazel-bin/packages/kbn-plugin-discovery", "@kbn/react-field": "link:bazel-bin/packages/kbn-react-field", "@kbn/rule-data-utils": "link:bazel-bin/packages/kbn-rule-data-utils", "@kbn/securitysolution-autocomplete": "link:bazel-bin/packages/kbn-securitysolution-autocomplete", @@ -199,6 +200,7 @@ "@turf/helpers": "6.0.1", "@turf/length": "^6.0.2", "@types/jsonwebtoken": "^8.5.6", + "@types/kbn__plugin-discovery": "link:bazel-bin/packages/kbn-plugin-discovery/npm_module_types", "@types/kbn__shared-ux-components": "link:bazel-bin/packages/kbn-shared-ux-components/npm_module_types", "@types/kbn__shared-ux-services": "link:bazel-bin/packages/kbn-shared-ux-services/npm_module_types", "@types/kbn__shared-ux-storybook": "link:bazel-bin/packages/kbn-shared-ux-storybook/npm_module_types", diff --git a/packages/BUILD.bazel b/packages/BUILD.bazel index e880df5f55782..f2ca181877883 100644 --- a/packages/BUILD.bazel +++ b/packages/BUILD.bazel @@ -46,6 +46,7 @@ filegroup( "//packages/kbn-mapbox-gl:build", "//packages/kbn-monaco:build", "//packages/kbn-optimizer:build", + "//packages/kbn-plugin-discovery:build", "//packages/kbn-plugin-generator:build", "//packages/kbn-plugin-helpers:build", "//packages/kbn-react-field:build", @@ -123,6 +124,7 @@ filegroup( "//packages/kbn-mapbox-gl:build_types", "//packages/kbn-monaco:build_types", "//packages/kbn-optimizer:build_types", + "//packages/kbn-plugin-discovery:build_types", "//packages/kbn-plugin-generator:build_types", "//packages/kbn-plugin-helpers:build_types", "//packages/kbn-react-field:build_types", diff --git a/packages/kbn-dev-utils/BUILD.bazel b/packages/kbn-dev-utils/BUILD.bazel index 5f31a8ba07481..7b60e46d030a3 100644 --- a/packages/kbn-dev-utils/BUILD.bazel +++ b/packages/kbn-dev-utils/BUILD.bazel @@ -46,6 +46,7 @@ NPM_MODULE_EXTRA_FILES = [ RUNTIME_DEPS = [ "//packages/kbn-std", "//packages/kbn-utils", + "//packages/kbn-plugin-discovery", "@npm//@babel/core", "@npm//axios", "@npm//chalk", @@ -54,7 +55,6 @@ RUNTIME_DEPS = [ "@npm//execa", "@npm//exit-hook", "@npm//getopts", - "@npm//globby", "@npm//jest-diff", "@npm//load-json-file", "@npm//markdown-it", @@ -72,6 +72,7 @@ RUNTIME_DEPS = [ TYPES_DEPS = [ "//packages/kbn-std:npm_module_types", "//packages/kbn-utils:npm_module_types", + "//packages/kbn-plugin-discovery:npm_module_types", "@npm//@babel/parser", "@npm//@babel/types", "@npm//@types/babel__core", diff --git a/packages/kbn-dev-utils/src/index.ts b/packages/kbn-dev-utils/src/index.ts index db96db46bde71..cb75cbdf62782 100644 --- a/packages/kbn-dev-utils/src/index.ts +++ b/packages/kbn-dev-utils/src/index.ts @@ -27,7 +27,6 @@ export * from './axios'; export * from './stdio'; export * from './ci_stats_reporter'; export * from './plugin_list'; -export * from './plugins'; export * from './streams'; export * from './babel'; export * from './extract'; diff --git a/packages/kbn-dev-utils/src/plugin_list/discover_plugins.ts b/packages/kbn-dev-utils/src/plugin_list/discover_plugins.ts index 966d27e6dc620..5f0b623b29b18 100644 --- a/packages/kbn-dev-utils/src/plugin_list/discover_plugins.ts +++ b/packages/kbn-dev-utils/src/plugin_list/discover_plugins.ts @@ -12,8 +12,8 @@ import Fs from 'fs'; import MarkdownIt from 'markdown-it'; import cheerio from 'cheerio'; import { REPO_ROOT } from '@kbn/utils'; +import { simpleKibanaPlatformPluginDiscovery } from '@kbn/plugin-discovery'; -import { simpleKibanaPlatformPluginDiscovery } from '../plugins'; import { extractAsciidocInfo } from './extract_asciidoc_info'; export interface Plugin { diff --git a/packages/kbn-docs-utils/src/api_docs/find_plugins.ts b/packages/kbn-docs-utils/src/api_docs/find_plugins.ts index 774452a6f1f9f..ebe329029302c 100644 --- a/packages/kbn-docs-utils/src/api_docs/find_plugins.ts +++ b/packages/kbn-docs-utils/src/api_docs/find_plugins.ts @@ -12,7 +12,7 @@ import globby from 'globby'; import loadJsonFile from 'load-json-file'; import { getPluginSearchPaths } from '@kbn/config'; -import { simpleKibanaPlatformPluginDiscovery } from '@kbn/dev-utils'; +import { simpleKibanaPlatformPluginDiscovery } from '@kbn/plugin-discovery'; import { REPO_ROOT } from '@kbn/utils'; import { ApiScope, PluginOrPackage } from './types'; diff --git a/packages/kbn-optimizer/src/optimizer/kibana_platform_plugins.ts b/packages/kbn-optimizer/src/optimizer/kibana_platform_plugins.ts index ec7b08a009b32..833d4cd8b8110 100644 --- a/packages/kbn-optimizer/src/optimizer/kibana_platform_plugins.ts +++ b/packages/kbn-optimizer/src/optimizer/kibana_platform_plugins.ts @@ -6,7 +6,7 @@ * Side Public License, v 1. */ -import { simpleKibanaPlatformPluginDiscovery } from '@kbn/dev-utils'; +import { simpleKibanaPlatformPluginDiscovery } from '@kbn/plugin-discovery'; export interface KibanaPlatformPlugin { readonly directory: string; diff --git a/packages/kbn-plugin-discovery/BUILD.bazel b/packages/kbn-plugin-discovery/BUILD.bazel new file mode 100644 index 0000000000000..b2e5ecde9c426 --- /dev/null +++ b/packages/kbn-plugin-discovery/BUILD.bazel @@ -0,0 +1,124 @@ +load("@npm//@bazel/typescript:index.bzl", "ts_config") +load("@build_bazel_rules_nodejs//:index.bzl", "js_library") +load("//src/dev/bazel:index.bzl", "jsts_transpiler", "pkg_npm", "pkg_npm_types", "ts_project") + +PKG_DIRNAME = "kbn-plugin-discovery" +PKG_REQUIRE_NAME = "@kbn/plugin-discovery" + +SOURCE_FILES = glob( + [ + "src/**/*.ts", + ], + exclude = [ + "**/*.test.*", + ], +) + +SRCS = SOURCE_FILES + +filegroup( + name = "srcs", + srcs = SRCS, +) + +NPM_MODULE_EXTRA_FILES = [ + "package.json", +] + +# In this array place runtime dependencies, including other packages and NPM packages +# which must be available for this code to run. +# +# To reference other packages use: +# "//repo/relative/path/to/package" +# eg. "//packages/kbn-utils" +# +# To reference a NPM package use: +# "@npm//name-of-package" +# eg. "@npm//lodash" +RUNTIME_DEPS = [ + "@npm//globby", + "@npm//load-json-file", + "@npm//normalize-path", + "@npm//tslib", +] + +# In this array place dependencies necessary to build the types, which will include the +# :npm_module_types target of other packages and packages from NPM, including @types/* +# packages. +# +# To reference the types for another package use: +# "//repo/relative/path/to/package:npm_module_types" +# eg. "//packages/kbn-utils:npm_module_types" +# +# References to NPM packages work the same as RUNTIME_DEPS +TYPES_DEPS = [ + "@npm//@types/jest", + "@npm//@types/node", + "@npm//@types/normalize-path", + "@npm//globby", + "@npm//load-json-file", + "@npm//normalize-path", + "@npm//tslib", +] + +jsts_transpiler( + name = "target_node", + srcs = SRCS, + build_pkg_name = package_name(), +) + +ts_config( + name = "tsconfig", + src = "tsconfig.json", + deps = [ + "//:tsconfig.base.json", + "//:tsconfig.bazel.json", + ], +) + +ts_project( + name = "tsc_types", + args = ['--pretty'], + srcs = SRCS, + deps = TYPES_DEPS, + declaration = True, + declaration_map = True, + emit_declaration_only = True, + out_dir = "target_types", + root_dir = "src", + tsconfig = ":tsconfig", +) + +js_library( + name = PKG_DIRNAME, + srcs = NPM_MODULE_EXTRA_FILES, + deps = RUNTIME_DEPS + [":target_node"], + package_name = PKG_REQUIRE_NAME, + visibility = ["//visibility:public"], +) + +pkg_npm( + name = "npm_module", + deps = [":" + PKG_DIRNAME], +) + +filegroup( + name = "build", + srcs = [":npm_module"], + visibility = ["//visibility:public"], +) + +pkg_npm_types( + name = "npm_module_types", + srcs = SRCS, + deps = [":tsc_types"], + package_name = PKG_REQUIRE_NAME, + tsconfig = ":tsconfig", + visibility = ["//visibility:public"], +) + +filegroup( + name = "build_types", + srcs = [":npm_module_types"], + visibility = ["//visibility:public"], +) diff --git a/packages/kbn-plugin-discovery/README.md b/packages/kbn-plugin-discovery/README.md new file mode 100644 index 0000000000000..7b433b0fdec72 --- /dev/null +++ b/packages/kbn-plugin-discovery/README.md @@ -0,0 +1,3 @@ +# @kbn/plugin-discovery + +Logic used to find plugins in the repository. diff --git a/packages/kbn-plugin-discovery/jest.config.js b/packages/kbn-plugin-discovery/jest.config.js new file mode 100644 index 0000000000000..37d7a4f2b63a2 --- /dev/null +++ b/packages/kbn-plugin-discovery/jest.config.js @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +module.exports = { + preset: '@kbn/test/jest_node', + rootDir: '../..', + roots: ['/packages/kbn-plugin-discovery'], +}; diff --git a/packages/kbn-plugin-discovery/package.json b/packages/kbn-plugin-discovery/package.json new file mode 100644 index 0000000000000..7758cd5773215 --- /dev/null +++ b/packages/kbn-plugin-discovery/package.json @@ -0,0 +1,7 @@ +{ + "name": "@kbn/plugin-discovery", + "private": true, + "version": "1.0.0", + "main": "./target_node/index.js", + "license": "SSPL-1.0 OR Elastic License 2.0" +} diff --git a/packages/kbn-dev-utils/src/plugins/index.ts b/packages/kbn-plugin-discovery/src/index.ts similarity index 92% rename from packages/kbn-dev-utils/src/plugins/index.ts rename to packages/kbn-plugin-discovery/src/index.ts index e9ca66a892ebf..a382b45515e53 100644 --- a/packages/kbn-dev-utils/src/plugins/index.ts +++ b/packages/kbn-plugin-discovery/src/index.ts @@ -7,4 +7,5 @@ */ export * from './parse_kibana_platform_plugin'; +export * from './plugin_search_paths'; export * from './simple_kibana_platform_plugin_discovery'; diff --git a/packages/kbn-dev-utils/src/plugins/parse_kibana_platform_plugin.ts b/packages/kbn-plugin-discovery/src/parse_kibana_platform_plugin.ts similarity index 94% rename from packages/kbn-dev-utils/src/plugins/parse_kibana_platform_plugin.ts rename to packages/kbn-plugin-discovery/src/parse_kibana_platform_plugin.ts index c34192a8396e8..d7cab724cde6b 100644 --- a/packages/kbn-dev-utils/src/plugins/parse_kibana_platform_plugin.ts +++ b/packages/kbn-plugin-discovery/src/parse_kibana_platform_plugin.ts @@ -12,7 +12,7 @@ import loadJsonFile from 'load-json-file'; export interface KibanaPlatformPlugin { readonly directory: string; readonly manifestPath: string; - readonly manifest: Manifest; + readonly manifest: KibanaPlatformPluginManifest; } function isValidDepsDeclaration(input: unknown, type: string): string[] { @@ -23,7 +23,7 @@ function isValidDepsDeclaration(input: unknown, type: string): string[] { throw new TypeError(`The "${type}" in plugin manifest should be an array of strings.`); } -interface Manifest { +export interface KibanaPlatformPluginManifest { id: string; ui: boolean; server: boolean; @@ -50,7 +50,7 @@ export function parseKibanaPlatformPlugin(manifestPath: string): KibanaPlatformP throw new TypeError('expected new platform manifest path to be absolute'); } - const manifest: Partial = loadJsonFile.sync(manifestPath); + const manifest: Partial = loadJsonFile.sync(manifestPath); if (!manifest || typeof manifest !== 'object' || Array.isArray(manifest)) { throw new TypeError('expected new platform plugin manifest to be a JSON encoded object'); } diff --git a/packages/kbn-plugin-discovery/src/plugin_search_paths.ts b/packages/kbn-plugin-discovery/src/plugin_search_paths.ts new file mode 100644 index 0000000000000..fe6f0a44b044e --- /dev/null +++ b/packages/kbn-plugin-discovery/src/plugin_search_paths.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { resolve } from 'path'; + +export interface SearchOptions { + rootDir: string; + oss: boolean; + examples: boolean; +} + +export function getPluginSearchPaths({ rootDir, oss, examples }: SearchOptions) { + return [ + resolve(rootDir, 'src', 'plugins'), + ...(oss ? [] : [resolve(rootDir, 'x-pack', 'plugins')]), + resolve(rootDir, 'plugins'), + ...(examples ? [resolve(rootDir, 'examples')] : []), + ...(examples && !oss ? [resolve(rootDir, 'x-pack', 'examples')] : []), + resolve(rootDir, '..', 'kibana-extra'), + ]; +} diff --git a/packages/kbn-dev-utils/src/plugins/simple_kibana_platform_plugin_discovery.ts b/packages/kbn-plugin-discovery/src/simple_kibana_platform_plugin_discovery.ts similarity index 86% rename from packages/kbn-dev-utils/src/plugins/simple_kibana_platform_plugin_discovery.ts rename to packages/kbn-plugin-discovery/src/simple_kibana_platform_plugin_discovery.ts index 2381faefbff29..ebf476a668851 100644 --- a/packages/kbn-dev-utils/src/plugins/simple_kibana_platform_plugin_discovery.ts +++ b/packages/kbn-plugin-discovery/src/simple_kibana_platform_plugin_discovery.ts @@ -11,12 +11,15 @@ import Path from 'path'; import globby from 'globby'; import normalize from 'normalize-path'; -import { parseKibanaPlatformPlugin } from './parse_kibana_platform_plugin'; +import { parseKibanaPlatformPlugin, KibanaPlatformPlugin } from './parse_kibana_platform_plugin'; /** * Helper to find the new platform plugins. */ -export function simpleKibanaPlatformPluginDiscovery(scanDirs: string[], pluginPaths: string[]) { +export function simpleKibanaPlatformPluginDiscovery( + scanDirs: string[], + pluginPaths: string[] +): KibanaPlatformPlugin[] { const patterns = Array.from( new Set([ // find kibana.json files up to 5 levels within the scan dir diff --git a/packages/kbn-plugin-discovery/tsconfig.json b/packages/kbn-plugin-discovery/tsconfig.json new file mode 100644 index 0000000000000..789c6b3111115 --- /dev/null +++ b/packages/kbn-plugin-discovery/tsconfig.json @@ -0,0 +1,18 @@ +{ + "extends": "../../tsconfig.bazel.json", + "compilerOptions": { + "declaration": true, + "declarationMap": true, + "emitDeclarationOnly": true, + "outDir": "target_types", + "rootDir": "src", + "stripInternal": false, + "types": [ + "jest", + "node" + ] + }, + "include": [ + "src/**/*" + ] +} diff --git a/packages/kbn-plugin-helpers/src/load_kibana_platform_plugin.ts b/packages/kbn-plugin-helpers/src/load_kibana_platform_plugin.ts index c1b074540158d..f258747350520 100644 --- a/packages/kbn-plugin-helpers/src/load_kibana_platform_plugin.ts +++ b/packages/kbn-plugin-helpers/src/load_kibana_platform_plugin.ts @@ -9,7 +9,8 @@ import Path from 'path'; import { REPO_ROOT } from '@kbn/utils'; -import { parseKibanaPlatformPlugin, KibanaPlatformPlugin, createFailError } from '@kbn/dev-utils'; +import { parseKibanaPlatformPlugin, KibanaPlatformPlugin } from '@kbn/plugin-discovery'; +import { createFailError } from '@kbn/dev-utils'; export type Plugin = KibanaPlatformPlugin; diff --git a/packages/kbn-type-summarizer/src/lib/bazel_cli_config.ts b/packages/kbn-type-summarizer/src/lib/bazel_cli_config.ts index 6f02160a1cb3f..7527ae35d4357 100644 --- a/packages/kbn-type-summarizer/src/lib/bazel_cli_config.ts +++ b/packages/kbn-type-summarizer/src/lib/bazel_cli_config.ts @@ -22,6 +22,7 @@ const TYPE_SUMMARIZER_PACKAGES = [ '@kbn/analytics', '@kbn/apm-config-loader', '@kbn/apm-utils', + '@kbn/plugin-discovery', ]; type TypeSummarizerType = 'api-extractor' | 'type-summarizer'; diff --git a/src/dev/plugin_discovery/find_plugins.ts b/src/dev/plugin_discovery/find_plugins.ts index 53a53bc08e15b..7e46894813f0e 100644 --- a/src/dev/plugin_discovery/find_plugins.ts +++ b/src/dev/plugin_discovery/find_plugins.ts @@ -8,7 +8,7 @@ import Path from 'path'; import { getPluginSearchPaths } from '@kbn/config'; -import { KibanaPlatformPlugin, simpleKibanaPlatformPluginDiscovery } from '@kbn/dev-utils'; +import { KibanaPlatformPlugin, simpleKibanaPlatformPluginDiscovery } from '@kbn/plugin-discovery'; import { REPO_ROOT } from '@kbn/utils'; diff --git a/src/dev/plugin_discovery/get_plugin_deps.ts b/src/dev/plugin_discovery/get_plugin_deps.ts index ec158e38a99d1..291c9de71b480 100644 --- a/src/dev/plugin_discovery/get_plugin_deps.ts +++ b/src/dev/plugin_discovery/get_plugin_deps.ts @@ -6,7 +6,7 @@ * Side Public License, v 1. */ -import { KibanaPlatformPlugin } from '@kbn/dev-utils'; +import { KibanaPlatformPlugin } from '@kbn/plugin-discovery'; interface AllOptions { id: string; diff --git a/src/dev/run_find_plugins_ready_migrate_to_ts_refs.ts b/src/dev/run_find_plugins_ready_migrate_to_ts_refs.ts index a71ada6f03fbf..39fc75fc2e379 100644 --- a/src/dev/run_find_plugins_ready_migrate_to_ts_refs.ts +++ b/src/dev/run_find_plugins_ready_migrate_to_ts_refs.ts @@ -10,7 +10,8 @@ import Path from 'path'; import Fs from 'fs'; import JSON5 from 'json5'; import { get } from 'lodash'; -import { run, KibanaPlatformPlugin } from '@kbn/dev-utils'; +import { run } from '@kbn/dev-utils'; +import { KibanaPlatformPlugin } from '@kbn/plugin-discovery'; import { getPluginDeps, findPlugins } from './plugin_discovery'; interface AllOptions { diff --git a/yarn.lock b/yarn.lock index ce7e815915a8b..d097eefeb7485 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3033,6 +3033,10 @@ version "0.0.0" uid "" +"@kbn/plugin-discovery@link:bazel-bin/packages/kbn-plugin-discovery": + version "0.0.0" + uid "" + "@kbn/plugin-generator@link:bazel-bin/packages/kbn-plugin-generator": version "0.0.0" uid "" @@ -6023,6 +6027,10 @@ version "0.0.0" uid "" +"@types/kbn__plugin-discovery@link:bazel-bin/packages/kbn-plugin-discovery/npm_module_types": + version "0.0.0" + uid "" + "@types/kbn__plugin-generator@link:bazel-bin/packages/kbn-plugin-generator/npm_module_types": version "0.0.0" uid "" From 59db86b3c772753b7bec6e46d41ee018af36dcfc Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Tue, 29 Mar 2022 15:28:05 -0400 Subject: [PATCH 116/160] [CI] Build TS Refs before api docs --- .buildkite/scripts/steps/build_api_docs.sh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.buildkite/scripts/steps/build_api_docs.sh b/.buildkite/scripts/steps/build_api_docs.sh index 2f63d6efa0941..dcb9a2aea7d37 100755 --- a/.buildkite/scripts/steps/build_api_docs.sh +++ b/.buildkite/scripts/steps/build_api_docs.sh @@ -2,6 +2,8 @@ set -euo pipefail +export BUILD_TS_REFS_DISABLE=false + .buildkite/scripts/bootstrap.sh echo "--- Build API Docs" From 7d94876df49c373e17ffdf7024c7f1af23ae7570 Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Tue, 29 Mar 2022 19:30:00 +0000 Subject: [PATCH 117/160] Revert "[CI] Build TS Refs before api docs" This reverts commit 59db86b3c772753b7bec6e46d41ee018af36dcfc. --- .buildkite/scripts/steps/build_api_docs.sh | 2 -- 1 file changed, 2 deletions(-) diff --git a/.buildkite/scripts/steps/build_api_docs.sh b/.buildkite/scripts/steps/build_api_docs.sh index dcb9a2aea7d37..2f63d6efa0941 100755 --- a/.buildkite/scripts/steps/build_api_docs.sh +++ b/.buildkite/scripts/steps/build_api_docs.sh @@ -2,8 +2,6 @@ set -euo pipefail -export BUILD_TS_REFS_DISABLE=false - .buildkite/scripts/bootstrap.sh echo "--- Build API Docs" From 4ce6f20fec7233be830142f1a232d20bddf8e56d Mon Sep 17 00:00:00 2001 From: Robert Austin Date: Tue, 29 Mar 2022 15:40:33 -0400 Subject: [PATCH 118/160] Security Solution: reimplement filterBrowserFieldsByFieldName (#128779) The function filterBrowserFieldsByFieldName is being run 4+ times when loading pages in the Security app. With a large number of fields, such as is found in production environment, this function can take 10+ seconds to completed. With this implementation, it should run a bit quicker. --- .../t_grid/toolbar/fields_browser/helpers.tsx | 75 ++++++++++++------- 1 file changed, 48 insertions(+), 27 deletions(-) diff --git a/x-pack/plugins/timelines/public/components/t_grid/toolbar/fields_browser/helpers.tsx b/x-pack/plugins/timelines/public/components/t_grid/toolbar/fields_browser/helpers.tsx index c0e1076073026..293121a4d3a61 100644 --- a/x-pack/plugins/timelines/public/components/t_grid/toolbar/fields_browser/helpers.tsx +++ b/x-pack/plugins/timelines/public/components/t_grid/toolbar/fields_browser/helpers.tsx @@ -37,42 +37,63 @@ export const getFieldCount = (category: Partial | undefined): numb * Filters the specified `BrowserFields` to return a new collection where every * category contains at least one field name that matches the specified substring. */ -export const filterBrowserFieldsByFieldName = ({ +export function filterBrowserFieldsByFieldName({ browserFields, substring, }: { browserFields: BrowserFields; substring: string; -}): BrowserFields => { +}): BrowserFields { const trimmedSubstring = substring.trim(); + // an empty search param will match everything, so return the original browserFields if (trimmedSubstring === '') { return browserFields; } - - // filter each category such that it only contains fields with field names - // that contain the specified substring: - const filteredBrowserFields: BrowserFields = Object.keys(browserFields).reduce( - (filteredCategories, categoryId) => ({ - ...filteredCategories, - [categoryId]: { - ...browserFields[categoryId], - fields: pickBy( - ({ name }) => name != null && name.includes(trimmedSubstring), - browserFields[categoryId].fields - ), - }, - }), - {} - ); - - // only pick non-empty categories from the filtered browser fields - const nonEmptyCategories: BrowserFields = pickBy( - (category) => categoryHasFields(category), - filteredBrowserFields - ); - - return nonEmptyCategories; -}; + const result: Record> = {}; + for (const [categoryName, categoryDescriptor] of Object.entries(browserFields)) { + if (!categoryDescriptor.fields) { + // ignore any category that is missing fields. This is not expected to happen. + // eslint-disable-next-line no-continue + continue; + } + + // keep track of whether this category had a matching field, if so, we should emit it into the result + let hadAMatch = false; + + // The fields that matched, for this `categoryName` + const filteredFields: Record> = {}; + + for (const [fieldName, fieldDescriptor] of Object.entries(categoryDescriptor.fields)) { + // For historical reasons, we consider the name as it appears on the field descriptor, not the `fieldName` (attribute name) itself. + // It is unclear if there is any point in continuing to do this. + const fieldNameFromDescriptor = fieldDescriptor.name; + + if (!fieldNameFromDescriptor) { + // Ignore any field that is missing a name in its descriptor. This is not expected to happen. + // eslint-disable-next-line no-continue + continue; + } + + // Check if this field matches (via substring comparison) the passed substring + if (fieldNameFromDescriptor !== null && fieldNameFromDescriptor.includes(trimmedSubstring)) { + // this field is a match, so we should emit this category into the result object. + hadAMatch = true; + + // emit this field + filteredFields[fieldName] = fieldDescriptor; + } + } + + if (hadAMatch) { + // if at least one field matches, emit the category, but replace the `fields` attribute with the filtered fields + result[categoryName] = { + ...browserFields[categoryName], + fields: filteredFields, + }; + } + } + return result; +} /** * Filters the selected `BrowserFields` to return a new collection where every From 37952e8d29f5e60fc5f0dea40b8a817c8e1d1508 Mon Sep 17 00:00:00 2001 From: Kevin Logan <56395104+kevinlog@users.noreply.github.com> Date: Tue, 29 Mar 2022 15:48:46 -0400 Subject: [PATCH 119/160] [Security Solution] Update documents_volume types in telemetry to match Endpoint output (#128169) Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../plugins/security_solution/server/lib/telemetry/types.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/x-pack/plugins/security_solution/server/lib/telemetry/types.ts b/x-pack/plugins/security_solution/server/lib/telemetry/types.ts index c1c65a428f62d..15c92740e3a71 100644 --- a/x-pack/plugins/security_solution/server/lib/telemetry/types.ts +++ b/x-pack/plugins/security_solution/server/lib/telemetry/types.ts @@ -208,6 +208,10 @@ export interface EndpointMetrics { registry_events: DocumentsVolumeMetrics; network_events: DocumentsVolumeMetrics; overall: DocumentsVolumeMetrics; + alerts: DocumentsVolumeMetrics; + diagnostic_alerts: DocumentsVolumeMetrics; + dns_events: DocumentsVolumeMetrics; + security_events: DocumentsVolumeMetrics; }; malicious_behavior_rules: Array<{ id: string; endpoint_uptime_percent: number }>; system_impact: Array<{ From b1608537204d51a10e9b71457a7b33bf57039a5c Mon Sep 17 00:00:00 2001 From: Michael Katsoulis Date: Tue, 29 Mar 2022 22:49:48 +0300 Subject: [PATCH 120/160] [Fleet] Update add agent instructions in fleet managed mode for Kubernetes (#127703) --- .../plugins/fleet/common/constants/routes.ts | 7 + .../plugins/fleet/common/services/routes.ts | 9 + .../common/types/rest_spec/agent_policy.ts | 4 + .../agent_enrollment_flyout/hooks.tsx | 66 ++++++ .../agent_enrollment_flyout/index.tsx | 40 ++-- .../managed_instructions.tsx | 18 +- .../standalone_instructions.tsx | 40 +--- .../agent_enrollment_flyout/steps.tsx | 184 ++++++++++++--- .../agent_enrollment_flyout/types.ts | 4 + .../enrollment_instructions/manual/index.tsx | 6 +- .../manual/platform_selector.tsx | 5 +- .../fleet/public/hooks/use_request/k8s.ts | 20 ++ .../server/routes/agent_policy/handlers.ts | 57 +++++ .../fleet/server/routes/agent_policy/index.ts | 29 +++ .../fleet/server/services/agent_policy.ts | 26 ++- .../server/services/elastic_agent_manifest.ts | 220 +++++++++++++++++- .../server/types/rest_spec/agent_policy.ts | 8 + 17 files changed, 654 insertions(+), 89 deletions(-) create mode 100644 x-pack/plugins/fleet/public/components/agent_enrollment_flyout/hooks.tsx create mode 100644 x-pack/plugins/fleet/public/hooks/use_request/k8s.ts diff --git a/x-pack/plugins/fleet/common/constants/routes.ts b/x-pack/plugins/fleet/common/constants/routes.ts index f2d170a35b0a8..dcc7092356a96 100644 --- a/x-pack/plugins/fleet/common/constants/routes.ts +++ b/x-pack/plugins/fleet/common/constants/routes.ts @@ -14,6 +14,7 @@ export const EPM_API_ROOT = `${API_ROOT}/epm`; export const DATA_STREAM_API_ROOT = `${API_ROOT}/data_streams`; export const PACKAGE_POLICY_API_ROOT = `${API_ROOT}/package_policies`; export const AGENT_POLICY_API_ROOT = `${API_ROOT}/agent_policies`; +export const K8S_API_ROOT = `${API_ROOT}/kubernetes`; export const LIMITED_CONCURRENCY_ROUTE_TAG = 'ingest:limited-concurrency'; @@ -67,6 +68,12 @@ export const AGENT_POLICY_API_ROUTES = { FULL_INFO_DOWNLOAD_PATTERN: `${AGENT_POLICY_API_ROOT}/{agentPolicyId}/download`, }; +// Kubernetes Manifest API routes +export const K8S_API_ROUTES = { + K8S_DOWNLOAD_PATTERN: `${K8S_API_ROOT}/download`, + K8S_INFO_PATTERN: `${K8S_API_ROOT}`, +}; + // Output API routes export const OUTPUT_API_ROUTES = { LIST_PATTERN: `${API_ROOT}/outputs`, diff --git a/x-pack/plugins/fleet/common/services/routes.ts b/x-pack/plugins/fleet/common/services/routes.ts index 06a853c6c186d..d4e8375bbaa5d 100644 --- a/x-pack/plugins/fleet/common/services/routes.ts +++ b/x-pack/plugins/fleet/common/services/routes.ts @@ -18,6 +18,7 @@ import { OUTPUT_API_ROUTES, SETTINGS_API_ROUTES, APP_API_ROUTES, + K8S_API_ROUTES, } from '../constants'; export const epmRouteService = { @@ -141,6 +142,14 @@ export const agentPolicyRouteService = { agentPolicyId ); }, + + getK8sInfoPath: () => { + return K8S_API_ROUTES.K8S_INFO_PATTERN; + }, + + getK8sFullDownloadPath: () => { + return K8S_API_ROUTES.K8S_DOWNLOAD_PATTERN; + }, }; export const dataStreamRouteService = { diff --git a/x-pack/plugins/fleet/common/types/rest_spec/agent_policy.ts b/x-pack/plugins/fleet/common/types/rest_spec/agent_policy.ts index cbf3c9806d388..d53da769c754b 100644 --- a/x-pack/plugins/fleet/common/types/rest_spec/agent_policy.ts +++ b/x-pack/plugins/fleet/common/types/rest_spec/agent_policy.ts @@ -77,3 +77,7 @@ export interface GetFullAgentPolicyResponse { export interface GetFullAgentConfigMapResponse { item: string; } + +export interface GetFullAgentManifestResponse { + item: string; +} diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/hooks.tsx b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/hooks.tsx new file mode 100644 index 0000000000000..d7b48b5a961c2 --- /dev/null +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/hooks.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import { useState, useEffect } from 'react'; +import { i18n } from '@kbn/i18n'; + +import type { PackagePolicy, AgentPolicy } from '../../types'; +import { sendGetOneAgentPolicy, useStartServices } from '../../hooks'; +import { FLEET_KUBERNETES_PACKAGE } from '../../../common'; + +export function useAgentPolicyWithPackagePolicies(policyId?: string) { + const [agentPolicyWithPackagePolicies, setAgentPolicy] = useState(null); + const core = useStartServices(); + const { notifications } = core; + + useEffect(() => { + async function loadPolicy(policyIdToLoad?: string) { + if (!policyIdToLoad) { + return; + } + try { + const agentPolicyRequest = await sendGetOneAgentPolicy(policyIdToLoad); + + setAgentPolicy(agentPolicyRequest.data ? agentPolicyRequest.data.item : null); + } catch (err) { + notifications.toasts.addError(err, { + title: i18n.translate('xpack.fleet.agentEnrollment.loadPolicyErrorMessage', { + defaultMessage: 'An error happened while loading the policy', + }), + }); + } + } + + loadPolicy(policyId); + }, [policyId, notifications.toasts]); + + return { agentPolicyWithPackagePolicies }; +} + +export function useIsK8sPolicy(agentPolicy?: AgentPolicy) { + const [isK8s, setIsK8s] = useState<'IS_LOADING' | 'IS_KUBERNETES' | 'IS_NOT_KUBERNETES'>( + 'IS_LOADING' + ); + useEffect(() => { + async function checkifK8s() { + if (!agentPolicy) { + setIsK8s('IS_LOADING'); + return; + } + + setIsK8s( + (agentPolicy.package_policies as PackagePolicy[]).some(isK8sPackage) + ? 'IS_KUBERNETES' + : 'IS_NOT_KUBERNETES' + ); + } + checkifK8s(); + }, [agentPolicy]); + + return { isK8s }; +} + +const isK8sPackage = (pkg: PackagePolicy) => pkg.package?.name === FLEET_KUBERNETES_PACKAGE; diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/index.tsx b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/index.tsx index 4be8eb8a03cd4..ed4cc15aec196 100644 --- a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/index.tsx +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/index.tsx @@ -22,12 +22,7 @@ import { } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n-react'; -import { - useGetSettings, - sendGetOneAgentPolicy, - useFleetStatus, - useAgentEnrollmentFlyoutData, -} from '../../hooks'; +import { useGetSettings, useFleetStatus, useAgentEnrollmentFlyoutData } from '../../hooks'; import { FLEET_SERVER_PACKAGE } from '../../constants'; import type { PackagePolicy } from '../../types'; @@ -37,6 +32,7 @@ import { ManagedInstructions } from './managed_instructions'; import { StandaloneInstructions } from './standalone_instructions'; import { MissingFleetServerHostCallout } from './missing_fleet_server_host_callout'; import type { BaseProps } from './types'; +import { useIsK8sPolicy, useAgentPolicyWithPackagePolicies } from './hooks'; type FlyoutMode = 'managed' | 'standalone'; @@ -72,26 +68,24 @@ export const AgentEnrollmentFlyout: React.FunctionComponent = ({ isLoadingAgentPolicies, refreshAgentPolicies, } = useAgentEnrollmentFlyoutData(); - + const { agentPolicyWithPackagePolicies } = useAgentPolicyWithPackagePolicies(policyId); useEffect(() => { - async function checkPolicyIsFleetServer() { - if (policyId && setIsFleetServerPolicySelected) { - const agentPolicyRequest = await sendGetOneAgentPolicy(policyId); - if ( - agentPolicyRequest.data?.item && - (agentPolicyRequest.data.item.package_policies as PackagePolicy[]).some( - (packagePolicy) => packagePolicy.package?.name === FLEET_SERVER_PACKAGE - ) - ) { - setIsFleetServerPolicySelected(true); - } else { - setIsFleetServerPolicySelected(false); - } + if (agentPolicyWithPackagePolicies && setIsFleetServerPolicySelected) { + if ( + (agentPolicyWithPackagePolicies.package_policies as PackagePolicy[]).some( + (packagePolicy) => packagePolicy.package?.name === FLEET_SERVER_PACKAGE + ) + ) { + setIsFleetServerPolicySelected(true); + } else { + setIsFleetServerPolicySelected(false); } } + }, [agentPolicyWithPackagePolicies]); - checkPolicyIsFleetServer(); - }, [policyId]); + const { isK8s } = useIsK8sPolicy( + agentPolicyWithPackagePolicies ? agentPolicyWithPackagePolicies : undefined + ); const isLoadingInitialRequest = settings.isLoading && settings.isInitialRequest; @@ -154,10 +148,12 @@ export const AgentEnrollmentFlyout: React.FunctionComponent = ({ diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/managed_instructions.tsx b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/managed_instructions.tsx index ba0da6c7ec83a..1e2141ea3827f 100644 --- a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/managed_instructions.tsx +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/managed_instructions.tsx @@ -63,15 +63,15 @@ export const ManagedInstructions = React.memo( agentPolicies, viewDataStep, setSelectedPolicyId, + policyId, isFleetServerPolicySelected, + isK8s, settings, refreshAgentPolicies, isLoadingAgentPolicies, }) => { const fleetStatus = useFleetStatus(); - const [selectedApiKeyId, setSelectedAPIKeyId] = useState(); - const apiKey = useGetOneEnrollmentAPIKey(selectedApiKeyId); const fleetServerInstructions = useFleetServerInstructions(apiKey?.data?.item?.policy_id); @@ -111,6 +111,8 @@ export const ManagedInstructions = React.memo( ]; }, [fleetServerInstructions]); + const enrolToken = apiKey.data ? apiKey.data.item.api_key : ''; + const steps = useMemo(() => { const fleetServerHosts = settings?.fleet_server_hosts || []; const baseSteps: EuiContainedStepProps[] = [ @@ -123,7 +125,7 @@ export const ManagedInstructions = React.memo( refreshAgentPolicies, }) : AgentEnrollmentKeySelectionStep({ agentPolicy, selectedApiKeyId, setSelectedAPIKeyId }), - DownloadStep(isFleetServerPolicySelected || false), + DownloadStep(isFleetServerPolicySelected || false, isK8s || '', enrolToken || ''), ]; if (isFleetServerPolicySelected) { baseSteps.push(...fleetServerSteps); @@ -133,7 +135,12 @@ export const ManagedInstructions = React.memo( defaultMessage: 'Enroll and start the Elastic Agent', }), children: selectedApiKeyId && apiKey.data && ( - + ), }); } @@ -155,6 +162,9 @@ export const ManagedInstructions = React.memo( isFleetServerPolicySelected, settings?.fleet_server_hosts, viewDataStep, + enrolToken, + isK8s, + policyId, ]); if (fleetStatus.isReady && settings?.fleet_server_hosts.length === 0) { diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx index 4fabb36b99a45..4df0431252135 100644 --- a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/standalone_instructions.tsx @@ -27,19 +27,15 @@ import { useStartServices, useLink, sendGetOneAgentPolicyFull, - sendGetOneAgentPolicy, useKibanaVersion, } from '../../hooks'; import { fullAgentPolicyToYaml, agentPolicyRouteService } from '../../services'; -import type { PackagePolicy } from '../../../common'; - -import { FLEET_KUBERNETES_PACKAGE } from '../../../common'; - import { PlatformSelector } from '../enrollment_instructions/manual/platform_selector'; import { DownloadStep, AgentPolicySelectionStep } from './steps'; import type { InstructionProps } from './types'; +import { useIsK8sPolicy, useAgentPolicyWithPackagePolicies } from './hooks'; export const StandaloneInstructions = React.memo( ({ agentPolicy, agentPolicies, refreshAgentPolicies }) => { @@ -49,12 +45,14 @@ export const StandaloneInstructions = React.memo( const [selectedPolicyId, setSelectedPolicyId] = useState(agentPolicy?.id); const [fullAgentPolicy, setFullAgentPolicy] = useState(); - const [isK8s, setIsK8s] = useState<'IS_LOADING' | 'IS_KUBERNETES' | 'IS_NOT_KUBERNETES'>( - 'IS_LOADING' - ); const [yaml, setYaml] = useState(''); const kibanaVersion = useKibanaVersion(); + const { agentPolicyWithPackagePolicies } = useAgentPolicyWithPackagePolicies(selectedPolicyId); + const { isK8s } = useIsK8sPolicy( + agentPolicyWithPackagePolicies ? agentPolicyWithPackagePolicies : undefined + ); + const KUBERNETES_RUN_INSTRUCTIONS = 'kubectl apply -f elastic-agent-standalone-kubernetes.yaml'; const STANDALONE_RUN_INSTRUCTIONS_LINUX = `curl -L -O https://artifacts.elastic.co/downloads/beats/elastic-agent/elastic-agent-${kibanaVersion}-linux-x86_64.tar.gz @@ -84,28 +82,6 @@ sudo rpm -vi elastic-agent-${kibanaVersion}-x86_64.rpm \nsudo systemctl enable e const { docLinks } = useStartServices(); - useEffect(() => { - async function checkifK8s() { - if (!selectedPolicyId) { - return; - } - const agentPolicyRequest = await sendGetOneAgentPolicy(selectedPolicyId); - const agentPol = agentPolicyRequest.data ? agentPolicyRequest.data.item : null; - - if (!agentPol) { - setIsK8s('IS_NOT_KUBERNETES'); - return; - } - const k8s = (pkg: PackagePolicy) => pkg.package?.name === FLEET_KUBERNETES_PACKAGE; - setIsK8s( - (agentPol.package_policies as PackagePolicy[]).some(k8s) - ? 'IS_KUBERNETES' - : 'IS_NOT_KUBERNETES' - ); - } - checkifK8s(); - }, [selectedPolicyId, notifications.toasts]); - useEffect(() => { async function fetchFullPolicy() { try { @@ -178,7 +154,9 @@ sudo rpm -vi elastic-agent-${kibanaVersion}-x86_64.rpm \nsudo systemctl enable e downloadLink = isK8s === 'IS_KUBERNETES' ? core.http.basePath.prepend( - `${agentPolicyRouteService.getInfoFullDownloadPath(selectedPolicyId)}?kubernetes=true` + `${agentPolicyRouteService.getInfoFullDownloadPath( + selectedPolicyId + )}?kubernetes=true&standalone=true` ) : core.http.basePath.prepend( `${agentPolicyRouteService.getInfoFullDownloadPath(selectedPolicyId)}?standalone=true` diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/steps.tsx b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/steps.tsx index 31a56056c0bcc..54c449f74cc60 100644 --- a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/steps.tsx +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/steps.tsx @@ -5,8 +5,17 @@ * 2.0. */ -import React, { useCallback, useMemo, useState } from 'react'; -import { EuiText, EuiButton, EuiSpacer } from '@elastic/eui'; +import React, { useCallback, useEffect, useMemo, useState } from 'react'; +import { + EuiText, + EuiButton, + EuiSpacer, + EuiCode, + EuiFlexGroup, + EuiFlexItem, + EuiCopy, + EuiCodeBlock, +} from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n-react'; import { i18n } from '@kbn/i18n'; import semverMajor from 'semver/functions/major'; @@ -14,36 +23,159 @@ import semverMinor from 'semver/functions/minor'; import semverPatch from 'semver/functions/patch'; import type { AgentPolicy } from '../../types'; -import { useKibanaVersion } from '../../hooks'; +import { useGetSettings, useKibanaVersion, useStartServices } from '../../hooks'; + +import { agentPolicyRouteService } from '../../../common'; + +import { sendGetK8sManifest } from '../../hooks/use_request/k8s'; import { AdvancedAgentAuthenticationSettings } from './advanced_agent_authentication_settings'; import { SelectCreateAgentPolicy } from './agent_policy_select_create'; -export const DownloadStep = (hasFleetServer: boolean) => { +export const DownloadStep = ( + hasFleetServer: boolean, + isK8s?: string, + enrollmentAPIKey?: string +) => { const kibanaVersion = useKibanaVersion(); + const core = useStartServices(); + const settings = useGetSettings(); const kibanaVersionURLString = useMemo( () => `${semverMajor(kibanaVersion)}-${semverMinor(kibanaVersion)}-${semverPatch(kibanaVersion)}`, [kibanaVersion] ); + const { notifications } = core; + + const [yaml, setYaml] = useState(); + const [fleetServer, setFleetServer] = useState(); + useEffect(() => { + async function fetchK8sManifest() { + try { + if (isK8s !== 'IS_KUBERNETES') { + return; + } + const fleetServerHosts = settings.data?.item.fleet_server_hosts; + let host = ''; + if (fleetServerHosts !== undefined && fleetServerHosts.length !== 0) { + setFleetServer(fleetServerHosts[0]); + host = fleetServerHosts[0]; + } + const query = { fleetServer: host, enrolToken: enrollmentAPIKey }; + const res = await sendGetK8sManifest(query); + if (res.error) { + throw res.error; + } + + if (!res.data) { + throw new Error('No data while fetching agent manifest'); + } + + setYaml(res.data.item); + } catch (error) { + notifications.toasts.addError(error, { + title: i18n.translate('xpack.fleet.agentEnrollment.loadk8sManifestErrorTitle', { + defaultMessage: 'Error while fetching agent manifest', + }), + }); + } + } + fetchK8sManifest(); + }, [isK8s, notifications.toasts, enrollmentAPIKey, settings.data?.item.fleet_server_hosts]); + + const altTitle = + isK8s === 'IS_KUBERNETES' + ? i18n.translate('xpack.fleet.agentEnrollment.stepDownloadAgentForK8sTitle', { + defaultMessage: 'Download the Elastic Agent Manifest', + }) + : i18n.translate('xpack.fleet.agentEnrollment.stepDownloadAgentTitle', { + defaultMessage: 'Download the Elastic Agent to your host', + }); const title = hasFleetServer ? i18n.translate('xpack.fleet.agentEnrollment.stepDownloadAgentForFleetServerTitle', { defaultMessage: 'Download the Fleet Server to a centralized host', }) - : i18n.translate('xpack.fleet.agentEnrollment.stepDownloadAgentTitle', { - defaultMessage: 'Download the Elastic Agent to your host', - }); + : altTitle; + + const altDownloadDescription = + isK8s === 'IS_KUBERNETES' ? ( + FLEET_URL, + FleetTokenVariable: FLEET_ENROLLMENT_TOKEN, + }} + /> + ) : ( + + ); + const downloadDescription = hasFleetServer ? ( ) : ( - + altDownloadDescription ); + + const linuxUsers = + isK8s !== 'IS_KUBERNETES' ? ( + + ) : ( + '' + ); + const k8sCopyYaml = + isK8s === 'IS_KUBERNETES' ? ( + + {(copy) => ( + + + + )} + + ) : ( + '' + ); + const k8sYaml = + isK8s === 'IS_KUBERNETES' ? ( + + {yaml} + + ) : ( + '' + ); + + const downloadLink = + isK8s === 'IS_KUBERNETES' + ? core.http.basePath.prepend( + `${agentPolicyRouteService.getK8sFullDownloadPath()}?fleetServer=${fleetServer}&enrolToken=${enrollmentAPIKey}` + ) + : `https://www.elastic.co/downloads/past-releases/elastic-agent-${kibanaVersionURLString}`; + + const downloadMsg = + isK8s === 'IS_KUBERNETES' ? ( + + ) : ( + + ); + return { title, children: ( @@ -51,23 +183,21 @@ export const DownloadStep = (hasFleetServer: boolean) => { {downloadDescription} - + <>{linuxUsers} - - - - + + + + + <>{downloadMsg} + + + + <>{k8sCopyYaml} + + + + <>{k8sYaml} ), }; diff --git a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/types.ts b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/types.ts index 0c447ad0870ff..edb34e876e7c8 100644 --- a/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/types.ts +++ b/x-pack/plugins/fleet/public/components/agent_enrollment_flyout/types.ts @@ -25,7 +25,11 @@ export interface BaseProps { setSelectedPolicyId?: (policyId?: string) => void; + policyId?: string; + isFleetServerPolicySelected?: boolean; + + isK8s?: string; } export interface InstructionProps extends BaseProps { diff --git a/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx b/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx index 4279e46cbcd66..62b7cb6fac5a1 100644 --- a/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx +++ b/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/index.tsx @@ -15,6 +15,8 @@ import { PlatformSelector } from './platform_selector'; interface Props { fleetServerHosts: string[]; apiKey: EnrollmentAPIKey; + policyId: string | undefined; + isK8s: string | undefined; } function getfleetServerHostsEnrollArgs(apiKey: EnrollmentAPIKey, fleetServerHosts: string[]) { @@ -24,6 +26,8 @@ function getfleetServerHostsEnrollArgs(apiKey: EnrollmentAPIKey, fleetServerHost export const ManualInstructions: React.FunctionComponent = ({ apiKey, fleetServerHosts, + policyId, + isK8s, }) => { const { docLinks } = useStartServices(); const enrollArgs = getfleetServerHostsEnrollArgs(apiKey, fleetServerHosts); @@ -59,7 +63,7 @@ sudo elastic-agent enroll ${enrollArgs} \nsudo systemctl enable elastic-agent \n linuxDebCommand={linuxDebCommand} linuxRpmCommand={linuxRpmCommand} troubleshootLink={docLinks.links.fleet.troubleshooting} - isK8s={false} + isK8s={isK8s === 'IS_KUBERNETES'} /> ); }; diff --git a/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/platform_selector.tsx b/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/platform_selector.tsx index 76fbd7f712b6f..7fc1c827596e9 100644 --- a/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/platform_selector.tsx +++ b/x-pack/plugins/fleet/public/components/enrollment_instructions/manual/platform_selector.tsx @@ -36,6 +36,8 @@ const CommandCode = styled.pre({ overflow: 'auto', }); +const K8S_COMMAND = `kubectl apply -f elastic-agent-managed-kubernetes.yaml`; + export const PlatformSelector: React.FunctionComponent = ({ linuxCommand, macCommand, @@ -74,9 +76,10 @@ export const PlatformSelector: React.FunctionComponent = ({ )} + {isK8s ? ( - {linuxCommand} + {K8S_COMMAND} ) : ( <> diff --git a/x-pack/plugins/fleet/public/hooks/use_request/k8s.ts b/x-pack/plugins/fleet/public/hooks/use_request/k8s.ts new file mode 100644 index 0000000000000..72e9c668f918b --- /dev/null +++ b/x-pack/plugins/fleet/public/hooks/use_request/k8s.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { agentPolicyRouteService } from '../../services'; + +import type { GetFullAgentManifestResponse } from '../../../common'; + +import { sendRequest } from './use_request'; + +export const sendGetK8sManifest = (query: { fleetServer?: string; enrolToken?: string } = {}) => { + return sendRequest({ + path: agentPolicyRouteService.getK8sInfoPath(), + method: 'get', + query, + }); +}; diff --git a/x-pack/plugins/fleet/server/routes/agent_policy/handlers.ts b/x-pack/plugins/fleet/server/routes/agent_policy/handlers.ts index dbf1db0f68f28..f0ed469ad8443 100644 --- a/x-pack/plugins/fleet/server/routes/agent_policy/handlers.ts +++ b/x-pack/plugins/fleet/server/routes/agent_policy/handlers.ts @@ -22,6 +22,7 @@ import type { CopyAgentPolicyRequestSchema, DeleteAgentPolicyRequestSchema, GetFullAgentPolicyRequestSchema, + GetK8sManifestRequestSchema, FleetRequestHandler, } from '../../types'; @@ -35,6 +36,7 @@ import type { DeleteAgentPolicyResponse, GetFullAgentPolicyResponse, GetFullAgentConfigMapResponse, + GetFullAgentManifestResponse, } from '../../../common'; import { defaultIngestErrorHandler } from '../../errors'; import { createAgentPolicyWithPackages } from '../../services/agent_policy_create'; @@ -328,3 +330,58 @@ export const downloadFullAgentPolicy: FleetRequestHandler< } } }; + +export const getK8sManifest: FleetRequestHandler< + undefined, + TypeOf +> = async (context, request, response) => { + try { + const fleetServer = request.query.fleetServer ?? ''; + const token = request.query.enrolToken ?? ''; + const fullAgentManifest = await agentPolicyService.getFullAgentManifest(fleetServer, token); + if (fullAgentManifest) { + const body: GetFullAgentManifestResponse = { + item: fullAgentManifest, + }; + return response.ok({ + body, + }); + } else { + return response.customError({ + statusCode: 404, + body: { message: 'Agent manifest not found' }, + }); + } + } catch (error) { + return defaultIngestErrorHandler({ error, response }); + } +}; + +export const downloadK8sManifest: FleetRequestHandler< + undefined, + TypeOf +> = async (context, request, response) => { + try { + const fleetServer = request.query.fleetServer ?? ''; + const token = request.query.enrolToken ?? ''; + const fullAgentManifest = await agentPolicyService.getFullAgentManifest(fleetServer, token); + if (fullAgentManifest) { + const body = fullAgentManifest; + const headers: ResponseHeaders = { + 'content-type': 'text/x-yaml', + 'content-disposition': `attachment; filename="elastic-agent-managed-kubernetes.yaml"`, + }; + return response.ok({ + body, + headers, + }); + } else { + return response.customError({ + statusCode: 404, + body: { message: 'Agent manifest not found' }, + }); + } + } catch (error) { + return defaultIngestErrorHandler({ error, response }); + } +}; diff --git a/x-pack/plugins/fleet/server/routes/agent_policy/index.ts b/x-pack/plugins/fleet/server/routes/agent_policy/index.ts index 3819b009f2763..66540e019e5a3 100644 --- a/x-pack/plugins/fleet/server/routes/agent_policy/index.ts +++ b/x-pack/plugins/fleet/server/routes/agent_policy/index.ts @@ -14,9 +14,12 @@ import { CopyAgentPolicyRequestSchema, DeleteAgentPolicyRequestSchema, GetFullAgentPolicyRequestSchema, + GetK8sManifestRequestSchema, } from '../../types'; import type { FleetAuthzRouter } from '../security'; +import { K8S_API_ROUTES } from '../../../common'; + import { getAgentPoliciesHandler, getOneAgentPolicyHandler, @@ -26,6 +29,8 @@ import { deleteAgentPoliciesHandler, getFullAgentPolicy, downloadFullAgentPolicy, + downloadK8sManifest, + getK8sManifest, } from './handlers'; export const registerRoutes = (router: FleetAuthzRouter) => { @@ -124,4 +129,28 @@ export const registerRoutes = (router: FleetAuthzRouter) => { }, downloadFullAgentPolicy ); + + // Get agent manifest + router.get( + { + path: K8S_API_ROUTES.K8S_INFO_PATTERN, + validate: GetK8sManifestRequestSchema, + fleetAuthz: { + fleet: { all: true }, + }, + }, + getK8sManifest + ); + + // Download agent manifest + router.get( + { + path: K8S_API_ROUTES.K8S_DOWNLOAD_PATTERN, + validate: GetK8sManifestRequestSchema, + fleetAuthz: { + fleet: { all: true }, + }, + }, + downloadK8sManifest + ); }; diff --git a/x-pack/plugins/fleet/server/services/agent_policy.ts b/x-pack/plugins/fleet/server/services/agent_policy.ts index c34104e491da8..37af4e646658b 100644 --- a/x-pack/plugins/fleet/server/services/agent_policy.ts +++ b/x-pack/plugins/fleet/server/services/agent_policy.ts @@ -53,7 +53,10 @@ import type { FullAgentConfigMap } from '../../common/types/models/agent_cm'; import { fullAgentConfigMapToYaml } from '../../common/services/agent_cm_to_yaml'; -import { elasticAgentManifest } from './elastic_agent_manifest'; +import { + elasticAgentStandaloneManifest, + elasticAgentManagedManifest, +} from './elastic_agent_manifest'; import { getPackageInfo } from './epm/packages'; import { getAgentsByKuery } from './agents'; @@ -785,7 +788,7 @@ class AgentPolicyService { }; const configMapYaml = fullAgentConfigMapToYaml(fullAgentConfigMap, safeDump); - const updateManifestVersion = elasticAgentManifest.replace( + const updateManifestVersion = elasticAgentStandaloneManifest.replace( 'VERSION', appContextService.getKibanaVersion() ); @@ -796,6 +799,25 @@ class AgentPolicyService { } } + public async getFullAgentManifest( + fleetServer: string, + enrolToken: string + ): Promise { + const updateManifestVersion = elasticAgentManagedManifest.replace( + 'VERSION', + appContextService.getKibanaVersion() + ); + let updateManifest = updateManifestVersion; + if (fleetServer !== '') { + updateManifest = updateManifest.replace('https://fleet-server:8220', fleetServer); + } + if (enrolToken !== '') { + updateManifest = updateManifest.replace('token-id', enrolToken); + } + + return updateManifest; + } + public async getFullAgentPolicy( soClient: SavedObjectsClientContract, id: string, diff --git a/x-pack/plugins/fleet/server/services/elastic_agent_manifest.ts b/x-pack/plugins/fleet/server/services/elastic_agent_manifest.ts index 392ee170d02ad..4ce39483f09a3 100644 --- a/x-pack/plugins/fleet/server/services/elastic_agent_manifest.ts +++ b/x-pack/plugins/fleet/server/services/elastic_agent_manifest.ts @@ -5,7 +5,7 @@ * 2.0. */ -export const elasticAgentManifest = ` +export const elasticAgentStandaloneManifest = ` --- apiVersion: apps/v1 kind: DaemonSet @@ -168,6 +168,7 @@ rules: - apiGroups: ["batch"] resources: - jobs + - cronjobs verbs: ["get", "list", "watch"] - apiGroups: - "" @@ -220,3 +221,220 @@ metadata: k8s-app: elastic-agent --- `; + +export const elasticAgentManagedManifest = ` +apiVersion: apps/v1 +kind: DaemonSet +metadata: + name: elastic-agent + namespace: kube-system + labels: + app: elastic-agent +spec: + selector: + matchLabels: + app: elastic-agent + template: + metadata: + labels: + app: elastic-agent + spec: + tolerations: + - key: node-role.kubernetes.io/master + effect: NoSchedule + serviceAccountName: elastic-agent + hostNetwork: true + dnsPolicy: ClusterFirstWithHostNet + containers: + - name: elastic-agent + image: docker.elastic.co/beats/elastic-agent:VERSION + env: + - name: FLEET_ENROLL + value: "1" + # Set to true in case of insecure or unverified HTTP + - name: FLEET_INSECURE + value: "true" + # The ip:port pair of fleet server + - name: FLEET_URL + value: "https://fleet-server:8220" + # If left empty KIBANA_HOST, KIBANA_FLEET_USERNAME, KIBANA_FLEET_PASSWORD are needed + - name: FLEET_ENROLLMENT_TOKEN + value: "token-id" + - name: KIBANA_HOST + value: "http://kibana:5601" + - name: KIBANA_FLEET_USERNAME + value: "elastic" + - name: KIBANA_FLEET_PASSWORD + value: "changeme" + - name: NODE_NAME + valueFrom: + fieldRef: + fieldPath: spec.nodeName + - name: POD_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + securityContext: + runAsUser: 0 + resources: + limits: + memory: 500Mi + requests: + cpu: 100m + memory: 200Mi + volumeMounts: + - name: proc + mountPath: /hostfs/proc + readOnly: true + - name: cgroup + mountPath: /hostfs/sys/fs/cgroup + readOnly: true + - name: varlibdockercontainers + mountPath: /var/lib/docker/containers + readOnly: true + - name: varlog + mountPath: /var/log + readOnly: true + volumes: + - name: proc + hostPath: + path: /proc + - name: cgroup + hostPath: + path: /sys/fs/cgroup + - name: varlibdockercontainers + hostPath: + path: /var/lib/docker/containers + - name: varlog + hostPath: + path: /var/log +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: elastic-agent +subjects: + - kind: ServiceAccount + name: elastic-agent + namespace: kube-system +roleRef: + kind: ClusterRole + name: elastic-agent + apiGroup: rbac.authorization.k8s.io +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + namespace: kube-system + name: elastic-agent +subjects: + - kind: ServiceAccount + name: elastic-agent + namespace: kube-system +roleRef: + kind: Role + name: elastic-agent + apiGroup: rbac.authorization.k8s.io +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: elastic-agent-kubeadm-config + namespace: kube-system +subjects: + - kind: ServiceAccount + name: elastic-agent + namespace: kube-system +roleRef: + kind: Role + name: elastic-agent-kubeadm-config + apiGroup: rbac.authorization.k8s.io +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: elastic-agent + labels: + k8s-app: elastic-agent +rules: + - apiGroups: [""] + resources: + - nodes + - namespaces + - events + - pods + - services + - configmaps + verbs: ["get", "list", "watch"] + # Enable this rule only if planing to use kubernetes_secrets provider + #- apiGroups: [""] + # resources: + # - secrets + # verbs: ["get"] + - apiGroups: ["extensions"] + resources: + - replicasets + verbs: ["get", "list", "watch"] + - apiGroups: ["apps"] + resources: + - statefulsets + - deployments + - replicasets + verbs: ["get", "list", "watch"] + - apiGroups: + - "" + resources: + - nodes/stats + verbs: + - get + - apiGroups: [ "batch" ] + resources: + - jobs + - cronjobs + verbs: [ "get", "list", "watch" ] + # required for apiserver + - nonResourceURLs: + - "/metrics" + verbs: + - get +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: elastic-agent + # should be the namespace where elastic-agent is running + namespace: kube-system + labels: + k8s-app: elastic-agent +rules: + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: ["get", "create", "update"] +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: elastic-agent-kubeadm-config + namespace: kube-system + labels: + k8s-app: elastic-agent +rules: + - apiGroups: [""] + resources: + - configmaps + resourceNames: + - kubeadm-config + verbs: ["get"] +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: elastic-agent + namespace: kube-system + labels: + k8s-app: elastic-agent +--- + +`; diff --git a/x-pack/plugins/fleet/server/types/rest_spec/agent_policy.ts b/x-pack/plugins/fleet/server/types/rest_spec/agent_policy.ts index 042129e1e0914..257cc90d453c8 100644 --- a/x-pack/plugins/fleet/server/types/rest_spec/agent_policy.ts +++ b/x-pack/plugins/fleet/server/types/rest_spec/agent_policy.ts @@ -61,3 +61,11 @@ export const GetFullAgentPolicyRequestSchema = { kubernetes: schema.maybe(schema.boolean()), }), }; + +export const GetK8sManifestRequestSchema = { + query: schema.object({ + download: schema.maybe(schema.boolean()), + fleetServer: schema.maybe(schema.string()), + enrolToken: schema.maybe(schema.string()), + }), +}; From 3eaef136d5fbb9a1194a095dcc0f15dd6198f2b6 Mon Sep 17 00:00:00 2001 From: Xavier Mouligneau Date: Tue, 29 Mar 2022 15:58:05 -0400 Subject: [PATCH 121/160] [RAM] SIimplify error banner on rules (#128705) * wip - clean up error banner * add expand error * fix lint+ * fix typo * my lint is not nice * add functional test * fix check * review + i18n fix * fix functional test --- .../translations/translations/ja-JP.json | 3 - .../translations/translations/zh-CN.json | 3 - .../components/rule_status_dropdown.tsx | 7 +- .../rules_list/components/rules_list.tsx | 352 ++++++++++++------ .../apps/triggers_actions_ui/alerts_list.ts | 36 +- 5 files changed, 271 insertions(+), 130 deletions(-) diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index cc840ab4a3534..c22beedbb4e27 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -27854,7 +27854,6 @@ "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.lastExecutionDateTitle": "前回の実行の開始時間。", "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.nameTitle": "名前", "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.scheduleTitle": "間隔", - "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.statusTitle": "ステータス", "xpack.triggersActionsUI.sections.rulesList.ruleStatusActive": "アクティブ", "xpack.triggersActionsUI.sections.rulesList.ruleStatusError": "エラー", "xpack.triggersActionsUI.sections.rulesList.ruleStatusFilterLabel": "ステータス", @@ -27880,7 +27879,6 @@ "xpack.triggersActionsUI.sections.rulesList.collapsedItemActons.muteTitle": "ミュート", "xpack.triggersActionsUI.sections.rulesList.collapsedItemActons.popoverButtonTitle": "アクション", "xpack.triggersActionsUI.sections.rulesList.collapsedItemActons.unmuteTitle": "ミュート解除", - "xpack.triggersActionsUI.sections.rulesList.dismissBunnerButtonLabel": "閉じる", "xpack.triggersActionsUI.sections.rulesList.fixLicenseLink": "修正", "xpack.triggersActionsUI.sections.rulesList.multipleTitle": "ルール", "xpack.triggersActionsUI.sections.rulesList.noPermissionToCreateDescription": "システム管理者にお問い合わせください。", @@ -27900,7 +27898,6 @@ "xpack.triggersActionsUI.sections.rulesList.unableToLoadRulesMessage": "ルールを読み込めません", "xpack.triggersActionsUI.sections.rulesList.unableToLoadRuleStatusInfoMessage": "ルールステータス情報を読み込めません", "xpack.triggersActionsUI.sections.rulesList.unableToLoadRuleTypesMessage": "ルールタイプを読み込めません", - "xpack.triggersActionsUI.sections.rulesList.viewBunnerButtonLabel": "表示", "xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.addBccButton": "Bcc", "xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.addCcButton": "Cc", "xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.authenticationLabel": "認証", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 8697109f3b927..3b85ad51fdb3d 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -27883,7 +27883,6 @@ "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.lastExecutionDateTitle": "上次执行的开始时间。", "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.nameTitle": "名称", "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.scheduleTitle": "时间间隔", - "xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.statusTitle": "状态", "xpack.triggersActionsUI.sections.rulesList.ruleStatusActive": "活动", "xpack.triggersActionsUI.sections.rulesList.ruleStatusError": "错误", "xpack.triggersActionsUI.sections.rulesList.ruleStatusFilterLabel": "状态", @@ -27910,7 +27909,6 @@ "xpack.triggersActionsUI.sections.rulesList.collapsedItemActons.muteTitle": "静音", "xpack.triggersActionsUI.sections.rulesList.collapsedItemActons.popoverButtonTitle": "操作", "xpack.triggersActionsUI.sections.rulesList.collapsedItemActons.unmuteTitle": "取消静音", - "xpack.triggersActionsUI.sections.rulesList.dismissBunnerButtonLabel": "关闭", "xpack.triggersActionsUI.sections.rulesList.fixLicenseLink": "修复", "xpack.triggersActionsUI.sections.rulesList.multipleTitle": "规则", "xpack.triggersActionsUI.sections.rulesList.noPermissionToCreateDescription": "请联系您的系统管理员。", @@ -27931,7 +27929,6 @@ "xpack.triggersActionsUI.sections.rulesList.unableToLoadRulesMessage": "无法加载规则", "xpack.triggersActionsUI.sections.rulesList.unableToLoadRuleStatusInfoMessage": "无法加载规则状态信息", "xpack.triggersActionsUI.sections.rulesList.unableToLoadRuleTypesMessage": "无法加载规则类型", - "xpack.triggersActionsUI.sections.rulesList.viewBunnerButtonLabel": "查看", "xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.addBccButton": "密送", "xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.addCcButton": "抄送", "xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.authenticationLabel": "身份验证", diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rule_status_dropdown.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rule_status_dropdown.tsx index 97652c5ab45aa..ff76abef65b60 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rule_status_dropdown.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rules_list/components/rule_status_dropdown.tsx @@ -127,7 +127,12 @@ export const RuleStatusDropdown: React.FunctionComponent = ({ ); return ( - + { const [actionTypesFilter, setActionTypesFilter] = useState([]); const [ruleStatusesFilter, setRuleStatusesFilter] = useState([]); const [ruleFlyoutVisible, setRuleFlyoutVisibility] = useState(false); - const [dismissRuleErrors, setDismissRuleErrors] = useState(false); const [editFlyoutVisible, setEditFlyoutVisibility] = useState(false); const [currentRuleToEdit, setCurrentRuleToEdit] = useState(null); const [tagPopoverOpenIndex, setTagPopoverOpenIndex] = useState(-1); + const [itemIdToExpandedRowMap, setItemIdToExpandedRowMap] = useState>( + {} + ); + const [showErrors, setShowErrors] = useState(false); useEffect(() => { (async () => { @@ -455,7 +464,73 @@ export const RulesList: React.FunctionComponent = () => { }; }; - const getRulesTableColumns = () => { + const buildErrorListItems = (_executionStatus: AlertExecutionStatus) => { + const hasErrorMessage = _executionStatus.status === 'error'; + const errorMessage = _executionStatus?.error?.message; + const isLicenseError = + _executionStatus.error?.reason === AlertExecutionStatusErrorReasons.License; + const statusMessage = isLicenseError ? ALERT_STATUS_LICENSE_ERROR : null; + + return [ + { + title: ( + + ), + description: ( + <> + {errorMessage} + {hasErrorMessage && statusMessage && } + {statusMessage} + + ), + }, + ]; + }; + + const toggleErrorMessage = (_executionStatus: AlertExecutionStatus, ruleItem: RuleTableItem) => { + setItemIdToExpandedRowMap((itemToExpand) => { + const _itemToExpand = { ...itemToExpand }; + if (_itemToExpand[ruleItem.id]) { + delete _itemToExpand[ruleItem.id]; + } else { + _itemToExpand[ruleItem.id] = ( + + ); + } + return _itemToExpand; + }); + }; + + const toggleRuleErrors = useCallback(() => { + setShowErrors((prevValue) => { + if (!prevValue) { + const rulesToExpand = rulesState.data.reduce((acc, ruleItem) => { + if (ruleItem.executionStatus.status === 'error') { + return { + ...acc, + [ruleItem.id]: ( + + ), + }; + } + return acc; + }, {}); + setItemIdToExpandedRowMap(rulesToExpand); + } else { + setItemIdToExpandedRowMap({}); + } + return !prevValue; + }); + }, [showErrors, rulesState]); + + const getRulesTableColumns = (): Array< + | EuiTableFieldDataColumnType + | EuiTableComputedColumnType + | EuiTableActionsColumnType + > => { return [ { field: 'name', @@ -755,13 +830,10 @@ export const RulesList: React.FunctionComponent = () => { }, { field: 'enabled', - name: i18n.translate( - 'xpack.triggersActionsUI.sections.rulesList.rulesListTable.columns.statusTitle', - { defaultMessage: 'Status' } - ), + name: '', sortable: true, truncateText: false, - width: '200px', + width: '10%', 'data-test-subj': 'rulesTableCell-status', render: (_enabled: boolean | undefined, item: RuleTableItem) => { return renderRuleStatusDropdown(item.enabled, item); @@ -769,12 +841,12 @@ export const RulesList: React.FunctionComponent = () => { }, { name: '', - width: '10%', + width: '90px', render(item: RuleTableItem) { return ( - + - + {item.isEditable && isRuleTypeEditableInContext(item.ruleTypeId) ? ( { ); }, }, + { + align: RIGHT_ALIGNMENT, + width: '40px', + isExpander: true, + name: ( + + Expand rows + + ), + render: (item: RuleTableItem) => { + const _executionStatus = item.executionStatus; + const hasErrorMessage = _executionStatus.status === 'error'; + const isLicenseError = + _executionStatus.error?.reason === AlertExecutionStatusErrorReasons.License; + + return isLicenseError || hasErrorMessage ? ( + toggleErrorMessage(_executionStatus, item)} + aria-label={itemIdToExpandedRowMap[item.id] ? 'Collapse' : 'Expand'} + iconType={itemIdToExpandedRowMap[item.id] ? 'arrowUp' : 'arrowDown'} + /> + ) : null; + }, + }, ]; }; @@ -906,6 +1002,34 @@ export const RulesList: React.FunctionComponent = () => { const table = ( <> + {rulesStatusesTotal.error > 0 ? ( + <> + +

+ +   + +   + setRuleStatusesFilter(['error'])}> + + +

+
+ + + ) : null} {selectedIds.length > 0 && authorizedToModifySelectedRules && ( @@ -974,122 +1098,110 @@ export const RulesList: React.FunctionComponent = () => {
- - {!dismissRuleErrors && rulesStatusesTotal.error > 0 ? ( - - - + + + + + - } - iconType="rule" - data-test-subj="rulesErrorBanner" - > - setRuleStatusesFilter(['error'])} - > + + + + - - setDismissRuleErrors(true)}> + + + + - - - - - ) : null} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
+ {rulesStatusesTotal.error > 0 && ( + + + {!showErrors && ( + + )} + {showErrors && ( + + )} + + + )}
@@ -1148,6 +1260,8 @@ export const RulesList: React.FunctionComponent = () => { setSort(changedSort); } }} + itemIdToExpandedRowMap={itemIdToExpandedRowMap} + isExpandable={true} /> {manageLicenseModalOpts && ( { ); expect(alertsErrorBannerExistErrors).to.have.length(1); expect( - await ( - await alertsErrorBannerExistErrors[0].findByCssSelector('.euiCallOutHeader') - ).getVisibleText() - ).to.equal('Error found in 1 rule.'); + await (await alertsErrorBannerExistErrors[0].findByTagName('p')).getVisibleText() + ).to.equal(' Error found in 1 rule. Show rule with error'); }); await refreshAlertsList(); @@ -515,6 +513,36 @@ export default ({ getPageObjects, getService }: FtrProviderContext) => { expect(await testSubjects.getVisibleText('totalUnknownRulesCount')).to.be('Unknown: 0'); }); + it('Expand error in rules table when there is rule with an error associated', async () => { + const createdAlert = await createAlert({ supertest, objectRemover }); + await retry.try(async () => { + await refreshAlertsList(); + const refreshResults = await pageObjects.triggersActionsUI.getAlertsListWithStatus(); + expect(refreshResults.length).to.equal(1); + expect(refreshResults[0].name).to.equal(`${createdAlert.name}Test: Noop`); + expect(refreshResults[0].interval).to.equal('1 min'); + expect(refreshResults[0].status).to.equal('Ok'); + expect(refreshResults[0].duration).to.match(/\d{2,}:\d{2}/); + }); + + let expandRulesErrorLink = await find.allByCssSelector('[data-test-subj="expandRulesError"]'); + expect(expandRulesErrorLink).to.have.length(0); + + await createFailingAlert({ supertest, objectRemover }); + await retry.try(async () => { + await refreshAlertsList(); + expandRulesErrorLink = await find.allByCssSelector('[data-test-subj="expandRulesError"]'); + expect(expandRulesErrorLink).to.have.length(1); + }); + await refreshAlertsList(); + await testSubjects.click('expandRulesError'); + const expandedRow = await find.allByCssSelector('.euiTableRow-isExpandedRow'); + expect(expandedRow).to.have.length(1); + expect(await (await expandedRow[0].findByTagName('div')).getVisibleText()).to.equal( + 'Error from last run\nFailed to execute alert type' + ); + }); + it('should filter alerts by the alert type', async () => { await createAlert({ supertest, objectRemover }); const failingAlert = await createFailingAlert({ supertest, objectRemover }); From bde0262191ceb8d4b88ad4e56531ad0bf9af960b Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Tue, 29 Mar 2022 14:01:55 -0600 Subject: [PATCH 122/160] Update babel (main) (#128572) Co-authored-by: Renovate Bot Co-authored-by: spalger --- package.json | 16 +-- yarn.lock | 276 +++++++++++++++++++++++++++------------------------ 2 files changed, 154 insertions(+), 138 deletions(-) diff --git a/package.json b/package.json index 8b434d291013e..9a4c3b9faef37 100644 --- a/package.json +++ b/package.json @@ -73,7 +73,7 @@ "yarn": "^1.21.1" }, "resolutions": { - "**/@babel/runtime": "^7.17.2", + "**/@babel/runtime": "^7.17.8", "**/@types/node": "16.11.7", "**/chokidar": "^3.4.3", "**/deepmerge": "^4.2.2", @@ -97,7 +97,7 @@ "puppeteer/node-fetch": "^2.6.7" }, "dependencies": { - "@babel/runtime": "^7.17.2", + "@babel/runtime": "^7.17.8", "@dnd-kit/core": "^3.1.1", "@dnd-kit/sortable": "^4.0.0", "@dnd-kit/utilities": "^2.0.0", @@ -435,11 +435,11 @@ "devDependencies": { "@apidevtools/swagger-parser": "^10.0.3", "@babel/cli": "^7.17.6", - "@babel/core": "^7.17.5", + "@babel/core": "^7.17.8", "@babel/eslint-parser": "^7.17.0", - "@babel/eslint-plugin": "^7.16.5", - "@babel/generator": "^7.17.3", - "@babel/parser": "^7.17.3", + "@babel/eslint-plugin": "^7.17.7", + "@babel/generator": "^7.17.7", + "@babel/parser": "^7.17.8", "@babel/plugin-proposal-class-properties": "^7.16.7", "@babel/plugin-proposal-export-namespace-from": "^7.16.7", "@babel/plugin-proposal-nullish-coalescing-operator": "^7.16.7", @@ -450,7 +450,7 @@ "@babel/preset-env": "^7.16.11", "@babel/preset-react": "^7.16.7", "@babel/preset-typescript": "^7.16.7", - "@babel/register": "^7.17.0", + "@babel/register": "^7.17.7", "@babel/traverse": "^7.17.3", "@babel/types": "^7.17.0", "@bazel/ibazel": "^0.16.2", @@ -521,7 +521,7 @@ "@testing-library/user-event": "^13.1.1", "@types/apidoc": "^0.22.3", "@types/archiver": "^5.1.0", - "@types/babel__core": "^7.1.18", + "@types/babel__core": "^7.1.19", "@types/base64-js": "^1.2.5", "@types/chance": "^1.0.0", "@types/chroma-js": "^1.4.2", diff --git a/yarn.lock b/yarn.lock index d097eefeb7485..0b6f13bc96b94 100644 --- a/yarn.lock +++ b/yarn.lock @@ -79,10 +79,10 @@ dependencies: "@babel/highlight" "^7.16.7" -"@babel/compat-data@^7.13.11", "@babel/compat-data@^7.16.4", "@babel/compat-data@^7.16.8", "@babel/compat-data@^7.17.0": - version "7.17.0" - resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.17.0.tgz#86850b8597ea6962089770952075dcaabb8dba34" - integrity sha512-392byTlpGWXMv4FbyWw3sAZ/FrW/DrwqLGXpy0mbyNe9Taqv1mg9yON5/o0cnr8XYCkFTZbC1eV+c+LAROgrng== +"@babel/compat-data@^7.13.11", "@babel/compat-data@^7.16.8", "@babel/compat-data@^7.17.0", "@babel/compat-data@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.17.7.tgz#078d8b833fbbcc95286613be8c716cef2b519fa2" + integrity sha512-p8pdE6j0a29TNGebNm7NzYZWB3xVZJBZ7XGs42uAKzQo8VQ3F0By/cQCtUEABwIqw5zo6WA4NbmxsfzADzMKnQ== "@babel/core@7.12.9": version "7.12.9" @@ -106,18 +106,18 @@ semver "^5.4.1" source-map "^0.5.0" -"@babel/core@>=7.9.0", "@babel/core@^7.1.0", "@babel/core@^7.12.10", "@babel/core@^7.12.3", "@babel/core@^7.16.0", "@babel/core@^7.17.5", "@babel/core@^7.7.5": - version "7.17.5" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.17.5.tgz#6cd2e836058c28f06a4ca8ee7ed955bbf37c8225" - integrity sha512-/BBMw4EvjmyquN5O+t5eh0+YqB3XXJkYD2cjKpYtWOfFy4lQ4UozNSmxAcWT8r2XtZs0ewG+zrfsqeR15i1ajA== +"@babel/core@>=7.9.0", "@babel/core@^7.1.0", "@babel/core@^7.12.10", "@babel/core@^7.12.3", "@babel/core@^7.16.0", "@babel/core@^7.17.8", "@babel/core@^7.7.5": + version "7.17.8" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.17.8.tgz#3dac27c190ebc3a4381110d46c80e77efe172e1a" + integrity sha512-OdQDV/7cRBtJHLSOBqqbYNkOcydOgnX59TZx4puf41fzcVtN3e/4yqY8lMQsK+5X2lJtAdmA+6OHqsj1hBJ4IQ== dependencies: "@ampproject/remapping" "^2.1.0" "@babel/code-frame" "^7.16.7" - "@babel/generator" "^7.17.3" - "@babel/helper-compilation-targets" "^7.16.7" - "@babel/helper-module-transforms" "^7.16.7" - "@babel/helpers" "^7.17.2" - "@babel/parser" "^7.17.3" + "@babel/generator" "^7.17.7" + "@babel/helper-compilation-targets" "^7.17.7" + "@babel/helper-module-transforms" "^7.17.7" + "@babel/helpers" "^7.17.8" + "@babel/parser" "^7.17.8" "@babel/template" "^7.16.7" "@babel/traverse" "^7.17.3" "@babel/types" "^7.17.0" @@ -136,17 +136,17 @@ eslint-visitor-keys "^2.1.0" semver "^6.3.0" -"@babel/eslint-plugin@^7.16.5": - version "7.16.5" - resolved "https://registry.yarnpkg.com/@babel/eslint-plugin/-/eslint-plugin-7.16.5.tgz#d1770685160922059f5d8f101055e799b7cff391" - integrity sha512-R1p6RMyU1Xl1U/NNr+D4+HjkQzN5dQOX0MpjW9WLWhHDjhzN9gso96MxxOFvPh0fKF/mMH8TGW2kuqQ2eK2s9A== +"@babel/eslint-plugin@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/eslint-plugin/-/eslint-plugin-7.17.7.tgz#4ee1d5b29b79130f3bb5a933358376bcbee172b8" + integrity sha512-JATUoJJXSgwI0T8juxWYtK1JSgoLpIGUsCHIv+NMXcUDA2vIe6nvAHR9vnuJgs/P1hOFw7vPwibixzfqBBLIVw== dependencies: eslint-rule-composer "^0.3.0" -"@babel/generator@^7.12.11", "@babel/generator@^7.12.5", "@babel/generator@^7.17.3": - version "7.17.3" - resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.17.3.tgz#a2c30b0c4f89858cb87050c3ffdfd36bdf443200" - integrity sha512-+R6Dctil/MgUsZsZAkYgK+ADNSZzJRRy0TvY65T71z/CR854xHQ1EweBYXdfT+HNeN7w0cSJJEzgxZMv40pxsg== +"@babel/generator@^7.12.11", "@babel/generator@^7.12.5", "@babel/generator@^7.17.3", "@babel/generator@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.17.7.tgz#8da2599beb4a86194a3b24df6c085931d9ee45ad" + integrity sha512-oLcVCTeIFadUoArDTwpluncplrYBmTCCZZgXCbgNGvOBBiSDDK3eWO4b/+eOTli5tKv1lg+a5/NAXg+nTcei1w== dependencies: "@babel/types" "^7.17.0" jsesc "^2.5.1" @@ -167,20 +167,20 @@ "@babel/helper-explode-assignable-expression" "^7.16.7" "@babel/types" "^7.16.7" -"@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.16.7.tgz#06e66c5f299601e6c7da350049315e83209d551b" - integrity sha512-mGojBwIWcwGD6rfqgRXVlVYmPAv7eOpIemUG3dGnDdCY4Pae70ROij3XmfrH6Fa1h1aiDylpglbZyktfzyo/hA== +"@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.16.7", "@babel/helper-compilation-targets@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.17.7.tgz#a3c2924f5e5f0379b356d4cfb313d1414dc30e46" + integrity sha512-UFzlz2jjd8kroj0hmCFV5zr+tQPi1dpC2cRsDV/3IEW8bJfCPrPpmcSN6ZS8RqIq4LXcmpipCQFPddyFA5Yc7w== dependencies: - "@babel/compat-data" "^7.16.4" + "@babel/compat-data" "^7.17.7" "@babel/helper-validator-option" "^7.16.7" browserslist "^4.17.5" semver "^6.3.0" -"@babel/helper-create-class-features-plugin@^7.13.0", "@babel/helper-create-class-features-plugin@^7.16.10", "@babel/helper-create-class-features-plugin@^7.16.7": - version "7.16.10" - resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.16.10.tgz#8a6959b9cc818a88815ba3c5474619e9c0f2c21c" - integrity sha512-wDeej0pu3WN/ffTxMNCPW5UCiOav8IcLRxSIyp/9+IF2xJUM9h/OYjg0IJLHaL6F8oU8kqMz9nc1vryXhMsgXg== +"@babel/helper-create-class-features-plugin@^7.13.0", "@babel/helper-create-class-features-plugin@^7.16.10", "@babel/helper-create-class-features-plugin@^7.16.7", "@babel/helper-create-class-features-plugin@^7.17.6": + version "7.17.6" + resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.17.6.tgz#3778c1ed09a7f3e65e6d6e0f6fbfcc53809d92c9" + integrity sha512-SogLLSxXm2OkBbSsHZMM4tUi8fUzjs63AT/d0YQIzr6GSd8Hxsbk2KYDX0k0DweAzGMj/YWeiCsorIdtdcW8Eg== dependencies: "@babel/helper-annotate-as-pure" "^7.16.7" "@babel/helper-environment-visitor" "^7.16.7" @@ -191,12 +191,12 @@ "@babel/helper-split-export-declaration" "^7.16.7" "@babel/helper-create-regexp-features-plugin@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.16.7.tgz#0cb82b9bac358eb73bfbd73985a776bfa6b14d48" - integrity sha512-fk5A6ymfp+O5+p2yCkXAu5Kyj6v0xh0RBeNcAkYUMDvvAAoxvSKXn+Jb37t/yWFiQVDFK1ELpUTD8/aLhCPu+g== + version "7.17.0" + resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.17.0.tgz#1dcc7d40ba0c6b6b25618997c5dbfd310f186fe1" + integrity sha512-awO2So99wG6KnlE+TPs6rn83gCz5WlEePJDTnLEqbchMVrBeAujURVphRdigsk094VhvZehFoNOihSlcBjwsXA== dependencies: "@babel/helper-annotate-as-pure" "^7.16.7" - regexpu-core "^4.7.1" + regexpu-core "^5.0.1" "@babel/helper-define-polyfill-provider@^0.1.5": version "0.1.5" @@ -264,11 +264,11 @@ "@babel/types" "^7.16.7" "@babel/helper-member-expression-to-functions@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.16.7.tgz#42b9ca4b2b200123c3b7e726b0ae5153924905b0" - integrity sha512-VtJ/65tYiU/6AbMTDwyoXGPKHgTsfRarivm+YbB5uAzKUyuPjgZSgAFeG87FCigc7KNHu2Pegh1XIT3lXjvz3Q== + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.17.7.tgz#a34013b57d8542a8c4ff8ba3f747c02452a4d8c4" + integrity sha512-thxXgnQ8qQ11W2wVUObIqDL4p148VMxkt5T/qpN5k2fboRyzFGFmKsTGViquyM5QHKUy48OZoca8kw4ajaDPyw== dependencies: - "@babel/types" "^7.16.7" + "@babel/types" "^7.17.0" "@babel/helper-module-imports@^7.0.0", "@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.16.0", "@babel/helper-module-imports@^7.16.7", "@babel/helper-module-imports@^7.7.0": version "7.16.7" @@ -277,19 +277,19 @@ dependencies: "@babel/types" "^7.16.7" -"@babel/helper-module-transforms@^7.12.1", "@babel/helper-module-transforms@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.16.7.tgz#7665faeb721a01ca5327ddc6bba15a5cb34b6a41" - integrity sha512-gaqtLDxJEFCeQbYp9aLAefjhkKdjKcdh6DB7jniIGU3Pz52WAmP268zK0VgPz9hUNkMSYeH976K2/Y6yPadpng== +"@babel/helper-module-transforms@^7.12.1", "@babel/helper-module-transforms@^7.16.7", "@babel/helper-module-transforms@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.17.7.tgz#3943c7f777139e7954a5355c815263741a9c1cbd" + integrity sha512-VmZD99F3gNTYB7fJRDTi+u6l/zxY0BE6OIxPSU7a50s6ZUQkHwSDmV92FfM+oCG0pZRVojGYhkR8I0OGeCVREw== dependencies: "@babel/helper-environment-visitor" "^7.16.7" "@babel/helper-module-imports" "^7.16.7" - "@babel/helper-simple-access" "^7.16.7" + "@babel/helper-simple-access" "^7.17.7" "@babel/helper-split-export-declaration" "^7.16.7" "@babel/helper-validator-identifier" "^7.16.7" "@babel/template" "^7.16.7" - "@babel/traverse" "^7.16.7" - "@babel/types" "^7.16.7" + "@babel/traverse" "^7.17.3" + "@babel/types" "^7.17.0" "@babel/helper-optimise-call-expression@^7.16.7": version "7.16.7" @@ -328,12 +328,12 @@ "@babel/traverse" "^7.16.7" "@babel/types" "^7.16.7" -"@babel/helper-simple-access@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.16.7.tgz#d656654b9ea08dbb9659b69d61063ccd343ff0f7" - integrity sha512-ZIzHVyoeLMvXMN/vok/a4LWRy8G2v205mNP0XOuf9XRLyX5/u9CnVulUtDgUTama3lT+bf/UqucuZjqiGuTS1g== +"@babel/helper-simple-access@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.17.7.tgz#aaa473de92b7987c6dfa7ce9a7d9674724823367" + integrity sha512-txyMCGroZ96i+Pxr3Je3lzEJjqwaRC9buMUgtomcrLe5Nd0+fk1h0LLA+ixUF5OW7AhHuQ7Es1WcQJZmZsz2XA== dependencies: - "@babel/types" "^7.16.7" + "@babel/types" "^7.17.0" "@babel/helper-skip-transparent-expression-wrappers@^7.16.0": version "7.16.0" @@ -369,13 +369,13 @@ "@babel/traverse" "^7.16.8" "@babel/types" "^7.16.8" -"@babel/helpers@^7.12.5", "@babel/helpers@^7.17.2": - version "7.17.2" - resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.17.2.tgz#23f0a0746c8e287773ccd27c14be428891f63417" - integrity sha512-0Qu7RLR1dILozr/6M0xgj+DFPmi6Bnulgm9M8BVa9ZCWxDqlSnqt3cf8IDPB5m45sVXUZ0kuQAgUrdSFFH79fQ== +"@babel/helpers@^7.12.5", "@babel/helpers@^7.17.8": + version "7.17.8" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.17.8.tgz#288450be8c6ac7e4e44df37bcc53d345e07bc106" + integrity sha512-QcL86FGxpfSJwGtAvv4iG93UL6bmqBdmoVY0CMCU2g+oD2ezQse3PT5Pa+jiD6LJndBQi0EDlpzOWNlLuhz5gw== dependencies: "@babel/template" "^7.16.7" - "@babel/traverse" "^7.17.0" + "@babel/traverse" "^7.17.3" "@babel/types" "^7.17.0" "@babel/highlight@^7.10.4", "@babel/highlight@^7.16.7": @@ -387,10 +387,10 @@ chalk "^2.0.0" js-tokens "^4.0.0" -"@babel/parser@^7.1.0", "@babel/parser@^7.12.11", "@babel/parser@^7.12.7", "@babel/parser@^7.14.7", "@babel/parser@^7.16.7", "@babel/parser@^7.17.3": - version "7.17.3" - resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.17.3.tgz#b07702b982990bf6fdc1da5049a23fece4c5c3d0" - integrity sha512-7yJPvPV+ESz2IUTPbOL+YkIGyCqOyNIzdguKQuJGnH7bg1WTIifuM21YqokFt/THWh1AkCRn9IgoykTRCBVpzA== +"@babel/parser@^7.1.0", "@babel/parser@^7.12.11", "@babel/parser@^7.12.7", "@babel/parser@^7.14.7", "@babel/parser@^7.16.7", "@babel/parser@^7.17.3", "@babel/parser@^7.17.8": + version "7.17.8" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.17.8.tgz#2817fb9d885dd8132ea0f8eb615a6388cca1c240" + integrity sha512-BoHhDJrJXqcg+ZL16Xv39H9n+AqJ4pcDrQBGZN+wHxIysrLZ3/ECwCBUch/1zUNhnsXULcONU3Ei5Hmkfk6kiQ== "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.16.7": version "7.16.7" @@ -426,11 +426,11 @@ "@babel/helper-plugin-utils" "^7.16.7" "@babel/plugin-proposal-class-static-block@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.16.7.tgz#712357570b612106ef5426d13dc433ce0f200c2a" - integrity sha512-dgqJJrcZoG/4CkMopzhPJjGxsIe9A8RlkQLnL/Vhhx8AA9ZuaRwGSlscSh42hazc7WSrya/IK7mTeoF0DP9tEw== + version "7.17.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.17.6.tgz#164e8fd25f0d80fa48c5a4d1438a6629325ad83c" + integrity sha512-X/tididvL2zbs7jZCeeRJ8167U/+Ac135AM6jCAx6gYXDUviZV5Ku9UDvWS2NCuWlFjIRXklYhwo6HhAC7ETnA== dependencies: - "@babel/helper-create-class-features-plugin" "^7.16.7" + "@babel/helper-create-class-features-plugin" "^7.17.6" "@babel/helper-plugin-utils" "^7.16.7" "@babel/plugin-syntax-class-static-block" "^7.14.5" @@ -768,9 +768,9 @@ "@babel/helper-plugin-utils" "^7.16.7" "@babel/plugin-transform-destructuring@^7.12.1", "@babel/plugin-transform-destructuring@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.16.7.tgz#ca9588ae2d63978a4c29d3f33282d8603f618e23" - integrity sha512-VqAwhTHBnu5xBVDCvrvqJbtLUa++qZaWC0Fgr2mqokBlulZARGyIvZDoqbPlPaKImQ9dKAcCzbv+ul//uqu70A== + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.17.7.tgz#49dc2675a7afa9a5e4c6bdee636061136c3408d1" + integrity sha512-XVh0r5yq9sLR4vZ6eVZe8FKfIcSgaTBxVBRSYokRj2qksf6QerYnTxz9/GTuKTH/n/HwLP7t6gtlybHetJ/6hQ== dependencies: "@babel/helper-plugin-utils" "^7.16.7" @@ -845,22 +845,22 @@ babel-plugin-dynamic-import-node "^2.3.3" "@babel/plugin-transform-modules-commonjs@^7.16.8": - version "7.16.8" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.16.8.tgz#cdee19aae887b16b9d331009aa9a219af7c86afe" - integrity sha512-oflKPvsLT2+uKQopesJt3ApiaIS2HW+hzHFcwRNtyDGieAeC/dIHZX8buJQ2J2X1rxGPy4eRcUijm3qcSPjYcA== + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.17.7.tgz#d86b217c8e45bb5f2dbc11eefc8eab62cf980d19" + integrity sha512-ITPmR2V7MqioMJyrxUo2onHNC3e+MvfFiFIR0RP21d3PtlVb6sfzoxNKiphSZUOM9hEIdzCcZe83ieX3yoqjUA== dependencies: - "@babel/helper-module-transforms" "^7.16.7" + "@babel/helper-module-transforms" "^7.17.7" "@babel/helper-plugin-utils" "^7.16.7" - "@babel/helper-simple-access" "^7.16.7" + "@babel/helper-simple-access" "^7.17.7" babel-plugin-dynamic-import-node "^2.3.3" "@babel/plugin-transform-modules-systemjs@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.16.7.tgz#887cefaef88e684d29558c2b13ee0563e287c2d7" - integrity sha512-DuK5E3k+QQmnOqBR9UkusByy5WZWGRxfzV529s9nPra1GE7olmxfqO2FHobEOYSPIjPBTr4p66YDcjQnt8cBmw== + version "7.17.8" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.17.8.tgz#81fd834024fae14ea78fbe34168b042f38703859" + integrity sha512-39reIkMTUVagzgA5x88zDYXPCMT6lcaRKs1+S9K6NKBPErbgO/w/kP8GlNQTC87b412ZTlmNgr3k2JrWgHH+Bw== dependencies: "@babel/helper-hoist-variables" "^7.16.7" - "@babel/helper-module-transforms" "^7.16.7" + "@babel/helper-module-transforms" "^7.17.7" "@babel/helper-plugin-utils" "^7.16.7" "@babel/helper-validator-identifier" "^7.16.7" babel-plugin-dynamic-import-node "^2.3.3" @@ -924,15 +924,15 @@ "@babel/plugin-transform-react-jsx" "^7.16.7" "@babel/plugin-transform-react-jsx@^7.12.1", "@babel/plugin-transform-react-jsx@^7.12.12", "@babel/plugin-transform-react-jsx@^7.16.7": - version "7.16.7" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.16.7.tgz#86a6a220552afd0e4e1f0388a68a372be7add0d4" - integrity sha512-8D16ye66fxiE8m890w0BpPpngG9o9OVBBy0gH2E+2AR7qMR2ZpTYJEqLxAsoroenMId0p/wMW+Blc0meDgu0Ag== + version "7.17.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.17.3.tgz#eac1565da176ccb1a715dae0b4609858808008c1" + integrity sha512-9tjBm4O07f7mzKSIlEmPdiE6ub7kfIe6Cd+w+oQebpATfTQMAgW+YOuWxogbKVTulA+MEO7byMeIUtQ1z+z+ZQ== dependencies: "@babel/helper-annotate-as-pure" "^7.16.7" "@babel/helper-module-imports" "^7.16.7" "@babel/helper-plugin-utils" "^7.16.7" "@babel/plugin-syntax-jsx" "^7.16.7" - "@babel/types" "^7.16.7" + "@babel/types" "^7.17.0" "@babel/plugin-transform-react-pure-annotations@^7.16.7": version "7.16.7" @@ -1148,7 +1148,7 @@ "@babel/helper-validator-option" "^7.16.7" "@babel/plugin-transform-typescript" "^7.16.7" -"@babel/register@^7.12.1", "@babel/register@^7.17.0": +"@babel/register@^7.12.1": version "7.17.0" resolved "https://registry.yarnpkg.com/@babel/register/-/register-7.17.0.tgz#8051e0b7cb71385be4909324f072599723a1f084" integrity sha512-UNZsMAZ7uKoGHo1HlEXfteEOYssf64n/PNLHGqOKq/bgYcu/4LrQWAHJwSCb3BRZK8Hi5gkJdRcwrGTO2wtRCg== @@ -1159,6 +1159,17 @@ pirates "^4.0.5" source-map-support "^0.5.16" +"@babel/register@^7.17.7": + version "7.17.7" + resolved "https://registry.yarnpkg.com/@babel/register/-/register-7.17.7.tgz#5eef3e0f4afc07e25e847720e7b987ae33f08d0b" + integrity sha512-fg56SwvXRifootQEDQAu1mKdjh5uthPzdO0N6t358FktfL4XjAVXuH58ULoiW8mesxiOgNIrxiImqEwv0+hRRA== + dependencies: + clone-deep "^4.0.1" + find-cache-dir "^2.0.0" + make-dir "^2.1.0" + pirates "^4.0.5" + source-map-support "^0.5.16" + "@babel/runtime-corejs3@^7.10.2": version "7.11.2" resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.11.2.tgz#02c3029743150188edeb66541195f54600278419" @@ -1167,10 +1178,10 @@ core-js-pure "^3.0.0" regenerator-runtime "^0.13.4" -"@babel/runtime@^7.0.0", "@babel/runtime@^7.1.2", "@babel/runtime@^7.10.2", "@babel/runtime@^7.11.2", "@babel/runtime@^7.12.0", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.13.10", "@babel/runtime@^7.14.0", "@babel/runtime@^7.16.0", "@babel/runtime@^7.17.2", "@babel/runtime@^7.3.1", "@babel/runtime@^7.4.4", "@babel/runtime@^7.4.5", "@babel/runtime@^7.5.0", "@babel/runtime@^7.5.5", "@babel/runtime@^7.6.2", "@babel/runtime@^7.6.3", "@babel/runtime@^7.7.2", "@babel/runtime@^7.7.6", "@babel/runtime@^7.8.4", "@babel/runtime@^7.8.7", "@babel/runtime@^7.9.2": - version "7.17.2" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.17.2.tgz#66f68591605e59da47523c631416b18508779941" - integrity sha512-hzeyJyMA1YGdJTuWU0e/j4wKXrU4OMFvY2MSlaI9B7VQb0r5cxTE3EAIS2Q7Tn2RIcDkRvTA/v2JsAEhxe99uw== +"@babel/runtime@^7.0.0", "@babel/runtime@^7.1.2", "@babel/runtime@^7.10.2", "@babel/runtime@^7.11.2", "@babel/runtime@^7.12.0", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.13.10", "@babel/runtime@^7.14.0", "@babel/runtime@^7.16.0", "@babel/runtime@^7.17.8", "@babel/runtime@^7.3.1", "@babel/runtime@^7.4.4", "@babel/runtime@^7.4.5", "@babel/runtime@^7.5.0", "@babel/runtime@^7.5.5", "@babel/runtime@^7.6.2", "@babel/runtime@^7.6.3", "@babel/runtime@^7.7.2", "@babel/runtime@^7.7.6", "@babel/runtime@^7.8.4", "@babel/runtime@^7.8.7", "@babel/runtime@^7.9.2": + version "7.17.8" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.17.8.tgz#3e56e4aff81befa55ac3ac6a0967349fd1c5bca2" + integrity sha512-dQpEpK0O9o6lj6oPu0gRDbbnk+4LeHlNcBpspf6Olzt3GIX4P1lWF1gS+pHLDFlaJvbR6q7jCfQ08zA4QJBnmA== dependencies: regenerator-runtime "^0.13.4" @@ -1183,7 +1194,7 @@ "@babel/parser" "^7.16.7" "@babel/types" "^7.16.7" -"@babel/traverse@^7.1.0", "@babel/traverse@^7.12.11", "@babel/traverse@^7.12.9", "@babel/traverse@^7.13.0", "@babel/traverse@^7.16.7", "@babel/traverse@^7.16.8", "@babel/traverse@^7.17.0", "@babel/traverse@^7.17.3", "@babel/traverse@^7.4.5": +"@babel/traverse@^7.1.0", "@babel/traverse@^7.12.11", "@babel/traverse@^7.12.9", "@babel/traverse@^7.13.0", "@babel/traverse@^7.16.7", "@babel/traverse@^7.16.8", "@babel/traverse@^7.17.3", "@babel/traverse@^7.4.5": version "7.17.3" resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.17.3.tgz#0ae0f15b27d9a92ba1f2263358ea7c4e7db47b57" integrity sha512-5irClVky7TxRWIRtxlh2WPUUOLhcPN06AGgaQSB8AEwuyEBgJVuJ5imdHm5zxk8w0QS5T+tDfnDxAlhWjpb7cw== @@ -5286,10 +5297,10 @@ "@types/babel__template" "*" "@types/babel__traverse" "*" -"@types/babel__core@^7.1.18": - version "7.1.18" - resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.18.tgz#1a29abcc411a9c05e2094c98f9a1b7da6cdf49f8" - integrity sha512-S7unDjm/C7z2A2R9NzfKCK1I+BAALDtxEmsJBwlB3EzNfb929ykjL++1CK9LO++EIp2fQrC8O+BwjKvz6UeDyQ== +"@types/babel__core@^7.1.19": + version "7.1.19" + resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.19.tgz#7b497495b7d1b4812bdb9d02804d0576f43ee460" + integrity sha512-WEOTgRsbYkvA/KCsDwVEGkd7WAr1e3g31VHQ8zy5gul/V1qKullU/BU5I68X5v7V3GnB9eotmom4v5a5gjxorw== dependencies: "@babel/parser" "^7.1.0" "@babel/types" "^7.0.0" @@ -24605,18 +24616,23 @@ regedit@^5.0.0: stream-slicer "0.0.6" through2 "^0.6.3" -regenerate-unicode-properties@^8.2.0: - version "8.2.0" - resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-8.2.0.tgz#e5de7111d655e7ba60c057dbe9ff37c87e65cdec" - integrity sha512-F9DjY1vKLo/tPePDycuH3dn9H1OTPIkVD9Kz4LODu+F2C75mgjAJ7x/gwy6ZcSNRAAkhNlJSOHRe8k3p+K9WhA== +regenerate-unicode-properties@^10.0.1: + version "10.0.1" + resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz#7f442732aa7934a3740c779bb9b3340dccc1fb56" + integrity sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw== dependencies: - regenerate "^1.4.0" + regenerate "^1.4.2" regenerate@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.0.tgz#4a856ec4b56e4077c557589cae85e7a4c8869a11" integrity sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg== +regenerate@^1.4.2: + version "1.4.2" + resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.2.tgz#b9346d8827e8f5a32f7ba29637d398b69014848a" + integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== + regenerator-runtime@^0.10.5: version "0.10.5" resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz#336c3efc1220adcedda2c9fab67b5a7955a33658" @@ -24661,17 +24677,17 @@ regexpp@^3.0.0, regexpp@^3.1.0, regexpp@^3.2.0: resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.2.0.tgz#0425a2768d8f23bad70ca4b90461fa2f1213e1b2" integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== -regexpu-core@^4.7.1: - version "4.7.1" - resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-4.7.1.tgz#2dea5a9a07233298fbf0db91fa9abc4c6e0f8ad6" - integrity sha512-ywH2VUraA44DZQuRKzARmw6S66mr48pQVva4LBeRhcOltJ6hExvWly5ZjFLYo67xbIxb6W1q4bAGtgfEl20zfQ== +regexpu-core@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.0.1.tgz#c531122a7840de743dcf9c83e923b5560323ced3" + integrity sha512-CriEZlrKK9VJw/xQGJpQM5rY88BtuL8DM+AEwvcThHilbxiTAy8vq4iJnd2tqq8wLmjbGZzP7ZcKFjbGkmEFrw== dependencies: - regenerate "^1.4.0" - regenerate-unicode-properties "^8.2.0" - regjsgen "^0.5.1" - regjsparser "^0.6.4" - unicode-match-property-ecmascript "^1.0.4" - unicode-match-property-value-ecmascript "^1.2.0" + regenerate "^1.4.2" + regenerate-unicode-properties "^10.0.1" + regjsgen "^0.6.0" + regjsparser "^0.8.2" + unicode-match-property-ecmascript "^2.0.0" + unicode-match-property-value-ecmascript "^2.0.0" registry-auth-token@^4.0.0: version "4.1.1" @@ -24694,15 +24710,15 @@ registry-url@^5.0.0: dependencies: rc "^1.2.8" -regjsgen@^0.5.1: - version "0.5.1" - resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.5.1.tgz#48f0bf1a5ea205196929c0d9798b42d1ed98443c" - integrity sha512-5qxzGZjDs9w4tzT3TPhCJqWdCc3RLYwy9J2NB0nm5Lz+S273lvWcpjaTGHsT1dc6Hhfq41uSEOw8wBmxrKOuyg== +regjsgen@^0.6.0: + version "0.6.0" + resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.6.0.tgz#83414c5354afd7d6627b16af5f10f41c4e71808d" + integrity sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA== -regjsparser@^0.6.4: - version "0.6.4" - resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.6.4.tgz#a769f8684308401a66e9b529d2436ff4d0666272" - integrity sha512-64O87/dPDgfk8/RQqC4gkZoGyyWFIEUTTh80CU6CWuK5vkCGyekIx+oKcEIYtP/RAxSQltCZHCNu/mdd7fqlJw== +regjsparser@^0.8.2: + version "0.8.4" + resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.8.4.tgz#8a14285ffcc5de78c5b95d62bbf413b6bc132d5f" + integrity sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA== dependencies: jsesc "~0.5.0" @@ -28464,23 +28480,23 @@ unicode-byte-truncate@^1.0.0: is-integer "^1.0.6" unicode-substring "^0.1.0" -unicode-canonical-property-names-ecmascript@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz#2619800c4c825800efdd8343af7dd9933cbe2818" - integrity sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ== +unicode-canonical-property-names-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz#301acdc525631670d39f6146e0e77ff6bbdebddc" + integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== -unicode-match-property-ecmascript@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz#8ed2a32569961bce9227d09cd3ffbb8fed5f020c" - integrity sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg== +unicode-match-property-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz#54fd16e0ecb167cf04cf1f756bdcc92eba7976c3" + integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== dependencies: - unicode-canonical-property-names-ecmascript "^1.0.4" - unicode-property-aliases-ecmascript "^1.0.4" + unicode-canonical-property-names-ecmascript "^2.0.0" + unicode-property-aliases-ecmascript "^2.0.0" -unicode-match-property-value-ecmascript@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.2.0.tgz#0d91f600eeeb3096aa962b1d6fc88876e64ea531" - integrity sha512-wjuQHGQVofmSJv1uVISKLE5zO2rNGzM/KCYZch/QQvez7C1hUhBIuZ701fYXExuufJFMPhv2SyL8CyoIfMLbIQ== +unicode-match-property-value-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz#1a01aa57247c14c568b89775a54938788189a714" + integrity sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw== unicode-properties@^1.2.2: version "1.3.1" @@ -28490,10 +28506,10 @@ unicode-properties@^1.2.2: base64-js "^1.3.0" unicode-trie "^2.0.0" -unicode-property-aliases-ecmascript@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.0.4.tgz#5a533f31b4317ea76f17d807fa0d116546111dd0" - integrity sha512-2WSLa6OdYd2ng8oqiGIWnJqyFArvhn+5vgx5GTxMbUYjCYKUcuKS62YLFF0R/BDGlB1yzXjQOLtPAfHsgirEpg== +unicode-property-aliases-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz#0a36cb9a585c4f6abd51ad1deddb285c165297c8" + integrity sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ== unicode-substring@^0.1.0: version "0.1.0" From 33b85f8968756183d5cd04e402e28209094bc343 Mon Sep 17 00:00:00 2001 From: Kevin Qualters <56408403+kqualters-elastic@users.noreply.github.com> Date: Tue, 29 Mar 2022 16:06:42 -0400 Subject: [PATCH 123/160] [Security Solution] Use session view plugin to render session viewer in alerts, events and timeline (#127520) --- .../common/ecs/process/index.ts | 9 + .../common/types/timeline/index.ts | 1 + x-pack/plugins/security_solution/kibana.json | 1 + .../components/alerts_viewer/alerts_table.tsx | 2 +- .../events_tab/events_query_tab_body.tsx | 2 +- .../components/events_viewer/index.test.tsx | 25 +- .../common/components/events_viewer/index.tsx | 30 +- .../public/common/mock/global_state.ts | 1 + .../public/common/mock/timeline_results.ts | 2 + .../components/alerts_table/actions.test.tsx | 1 + .../alerts_table/default_config.tsx | 1 + .../components/alerts_table/index.tsx | 2 +- .../components/graph_overlay/index.test.tsx | 119 +++- .../components/graph_overlay/index.tsx | 167 ++--- .../__snapshots__/index.test.tsx.snap | 598 +++++++++--------- .../side_panel/event_details/index.tsx | 4 +- .../hooks/use_detail_panel.test.tsx | 150 +++++ .../side_panel/hooks/use_detail_panel.tsx | 138 ++++ .../timeline/body/actions/index.tsx | 45 ++ .../components/timeline/body/index.tsx | 2 +- .../components/timeline/body/translations.ts | 7 + .../timeline/eql_tab_content/index.tsx | 2 +- .../timeline/graph_tab_content/index.tsx | 31 +- .../timelines/components/timeline/index.tsx | 12 +- .../timeline/pinned_tab_content/index.tsx | 2 +- .../timeline/query_tab_content/index.tsx | 2 +- .../timeline/session_tab_content/index.tsx | 58 ++ .../session_tab_content}/translations.ts | 7 + .../use_session_view.test.tsx | 137 ++++ .../session_tab_content/use_session_view.tsx | 230 +++++++ .../timeline/tabs_content/index.tsx | 63 +- .../timeline/tabs_content/translations.ts | 7 + .../timelines/store/timeline/actions.ts | 5 + .../timelines/store/timeline/defaults.ts | 1 + .../timelines/store/timeline/epic.test.ts | 1 + .../timelines/store/timeline/helpers.ts | 20 + .../public/timelines/store/timeline/model.ts | 2 + .../timelines/store/timeline/reducer.test.ts | 1 + .../timelines/store/timeline/reducer.ts | 6 + .../plugins/security_solution/public/types.ts | 4 +- .../public/components/process_tree/helpers.ts | 11 +- .../public/components/process_tree/hooks.ts | 9 +- .../components/process_tree_alerts/styles.ts | 2 +- .../components/process_tree_node/index.tsx | 2 +- .../public/components/session_view/index.tsx | 2 +- .../public/components/session_view/styles.ts | 12 +- x-pack/plugins/session_view/public/index.ts | 2 +- x-pack/plugins/session_view/public/types.ts | 12 +- .../timelines/common/ecs/process/index.ts | 9 + .../timelines/common/types/timeline/index.ts | 1 + .../components/t_grid/integrated/index.tsx | 1 + .../timeline/factory/helpers/constants.ts | 9 + 52 files changed, 1434 insertions(+), 536 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/timelines/components/side_panel/hooks/use_detail_panel.test.tsx create mode 100644 x-pack/plugins/security_solution/public/timelines/components/side_panel/hooks/use_detail_panel.tsx create mode 100644 x-pack/plugins/security_solution/public/timelines/components/timeline/session_tab_content/index.tsx rename x-pack/plugins/security_solution/public/timelines/components/{graph_overlay => timeline/session_tab_content}/translations.ts (73%) create mode 100644 x-pack/plugins/security_solution/public/timelines/components/timeline/session_tab_content/use_session_view.test.tsx create mode 100644 x-pack/plugins/security_solution/public/timelines/components/timeline/session_tab_content/use_session_view.tsx diff --git a/x-pack/plugins/security_solution/common/ecs/process/index.ts b/x-pack/plugins/security_solution/common/ecs/process/index.ts index 2a58c6d5b47d0..02122c776e95d 100644 --- a/x-pack/plugins/security_solution/common/ecs/process/index.ts +++ b/x-pack/plugins/security_solution/common/ecs/process/index.ts @@ -11,6 +11,9 @@ export interface ProcessEcs { Ext?: Ext; command_line?: string[]; entity_id?: string[]; + entry_leader?: ProcessSessionData; + session_leader?: ProcessSessionData; + group_leader?: ProcessSessionData; exit_code?: number[]; hash?: ProcessHashData; parent?: ProcessParentData; @@ -25,6 +28,12 @@ export interface ProcessEcs { working_directory?: string[]; } +export interface ProcessSessionData { + entity_id?: string[]; + pid?: string[]; + name?: string[]; +} + export interface ProcessHashData { md5?: string[]; sha1?: string[]; diff --git a/x-pack/plugins/security_solution/common/types/timeline/index.ts b/x-pack/plugins/security_solution/common/types/timeline/index.ts index 93dd6f9efb671..d2e9c2a6715fe 100644 --- a/x-pack/plugins/security_solution/common/types/timeline/index.ts +++ b/x-pack/plugins/security_solution/common/types/timeline/index.ts @@ -482,6 +482,7 @@ export enum TimelineTabs { notes = 'notes', pinned = 'pinned', eql = 'eql', + session = 'session', } /** diff --git a/x-pack/plugins/security_solution/kibana.json b/x-pack/plugins/security_solution/kibana.json index bd18b5d4acc31..cf13586a1a03f 100644 --- a/x-pack/plugins/security_solution/kibana.json +++ b/x-pack/plugins/security_solution/kibana.json @@ -22,6 +22,7 @@ "licensing", "maps", "ruleRegistry", + "sessionView", "taskManager", "timelines", "triggersActionsUi", diff --git a/x-pack/plugins/security_solution/public/common/components/alerts_viewer/alerts_table.tsx b/x-pack/plugins/security_solution/public/common/components/alerts_viewer/alerts_table.tsx index 0dd137a2321c6..7e71174c85a14 100644 --- a/x-pack/plugins/security_solution/public/common/components/alerts_viewer/alerts_table.tsx +++ b/x-pack/plugins/security_solution/public/common/components/alerts_viewer/alerts_table.tsx @@ -80,7 +80,7 @@ const AlertsTableComponent: React.FC = ({ const dispatch = useDispatch(); const alertsFilter = useMemo(() => [...defaultAlertsFilters, ...pageFilters], [pageFilters]); const { filterManager } = useKibana().services.data.query; - const ACTION_BUTTON_COUNT = 4; + const ACTION_BUTTON_COUNT = 5; const tGridEnabled = useIsExperimentalFeatureEnabled('tGridEnabled'); diff --git a/x-pack/plugins/security_solution/public/common/components/events_tab/events_query_tab_body.tsx b/x-pack/plugins/security_solution/public/common/components/events_tab/events_query_tab_body.tsx index cfd6546470d4a..30b7bd4f53e60 100644 --- a/x-pack/plugins/security_solution/public/common/components/events_tab/events_query_tab_body.tsx +++ b/x-pack/plugins/security_solution/public/common/components/events_tab/events_query_tab_body.tsx @@ -84,7 +84,7 @@ const EventsQueryTabBodyComponent: React.FC = }) => { const dispatch = useDispatch(); const { globalFullScreen } = useGlobalFullScreen(); - const ACTION_BUTTON_COUNT = 4; + const ACTION_BUTTON_COUNT = 5; const tGridEnabled = useIsExperimentalFeatureEnabled('tGridEnabled'); useEffect(() => { diff --git a/x-pack/plugins/security_solution/public/common/components/events_viewer/index.test.tsx b/x-pack/plugins/security_solution/public/common/components/events_viewer/index.test.tsx index bd3321511156d..9da27bc470a94 100644 --- a/x-pack/plugins/security_solution/public/common/components/events_viewer/index.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/events_viewer/index.test.tsx @@ -9,9 +9,8 @@ import React from 'react'; import useResizeObserver from 'use-resize-observer/polyfilled'; import '../../mock/match_media'; -import { waitFor } from '@testing-library/react'; +import { render } from '@testing-library/react'; import { TestProviders } from '../../mock'; -import { useMountAppended } from '../../utils/use_mount_appended'; import { mockEventViewerResponse } from './mock'; import { StatefulEventsViewer } from '.'; @@ -61,37 +60,27 @@ const testProps = { start: from, }; describe('StatefulEventsViewer', () => { - const mount = useMountAppended(); - (useTimelineEvents as jest.Mock).mockReturnValue([false, mockEventViewerResponse]); test('it renders the events viewer', async () => { - const wrapper = mount( + const wrapper = render( ); - await waitFor(() => { - wrapper.update(); - - expect(wrapper.text()).toMatchInlineSnapshot(`"hello grid"`); - }); + expect(wrapper.getByText('hello grid')).toBeTruthy(); }); // InspectButtonContainer controls displaying InspectButton components test('it renders InspectButtonContainer', async () => { - const wrapper = mount( + const wrapper = render( ); - await waitFor(() => { - wrapper.update(); - - expect(wrapper.find(`InspectButtonContainer`).exists()).toBe(true); - }); + expect(wrapper.getByTestId(`hoverVisibilityContainer`)).toBeTruthy(); }); test('it closes field editor when unmounted', async () => { @@ -101,14 +90,14 @@ describe('StatefulEventsViewer', () => { return {}; }); - const wrapper = mount( + const { unmount } = render( ); expect(mockCloseEditor).not.toHaveBeenCalled(); - wrapper.unmount(); + unmount(); expect(mockCloseEditor).toHaveBeenCalled(); }); }); diff --git a/x-pack/plugins/security_solution/public/common/components/events_viewer/index.tsx b/x-pack/plugins/security_solution/public/common/components/events_viewer/index.tsx index 0053ed13923d4..d46ab4b62be68 100644 --- a/x-pack/plugins/security_solution/public/common/components/events_viewer/index.tsx +++ b/x-pack/plugins/security_solution/public/common/components/events_viewer/index.tsx @@ -24,7 +24,6 @@ import { SourcererScopeName } from '../../store/sourcerer/model'; import { useSourcererDataView } from '../../containers/sourcerer'; import type { EntityType } from '../../../../../timelines/common'; import { TGridCellAction } from '../../../../../timelines/common/types'; -import { DetailsPanel } from '../../../timelines/components/side_panel'; import { CellValueElementProps } from '../../../timelines/components/timeline/cell_rendering'; import { FIELDS_WITHOUT_CELL_ACTIONS } from '../../lib/cell_actions/constants'; import { useGetUserCasesPermissions, useKibana } from '../../lib/kibana'; @@ -33,6 +32,7 @@ import { useFieldBrowserOptions, FieldEditorActions, } from '../../../timelines/components/fields_browser'; +import { useSessionView } from '../../../timelines/components/timeline/session_tab_content/use_session_view'; const EMPTY_CONTROL_COLUMNS: ControlColumnProps[] = []; @@ -105,6 +105,7 @@ const StatefulEventsViewerComponent: React.FC = ({ itemsPerPage, itemsPerPageOptions, kqlMode, + sessionViewId, showCheckboxes, sort, } = defaultModel, @@ -155,11 +156,19 @@ const StatefulEventsViewerComponent: React.FC = ({ const globalFilters = useMemo(() => [...filters, ...(pageFilters ?? [])], [filters, pageFilters]); const trailingControlColumns: ControlColumnProps[] = EMPTY_CONTROL_COLUMNS; - const graphOverlay = useMemo( - () => - graphEventId != null && graphEventId.length > 0 ? : null, - [graphEventId, id] - ); + + const { DetailsPanel, SessionView, Navigation } = useSessionView({ + entityType, + timelineId: id, + }); + + const graphOverlay = useMemo(() => { + const shouldShowOverlay = + (graphEventId != null && graphEventId.length > 0) || sessionViewId !== null; + return shouldShowOverlay ? ( + + ) : null; + }, [graphEventId, id, sessionViewId, SessionView, Navigation]); const setQuery = useCallback( (inspect, loading, refetch) => { dispatch(inputsActions.setQuery({ id, inputId: 'global', inspect, loading, refetch })); @@ -239,14 +248,7 @@ const StatefulEventsViewerComponent: React.FC = ({ })} - + {DetailsPanel} ); diff --git a/x-pack/plugins/security_solution/public/common/mock/global_state.ts b/x-pack/plugins/security_solution/public/common/mock/global_state.ts index bd90892a43fc6..31948a13db0f1 100644 --- a/x-pack/plugins/security_solution/public/common/mock/global_state.ts +++ b/x-pack/plugins/security_solution/public/common/mock/global_state.ts @@ -321,6 +321,7 @@ export const mockGlobalState: State = { end: '2020-07-08T08:20:18.966Z', }, selectedEventIds: {}, + sessionViewId: null, show: false, showCheckboxes: false, pinnedEventIds: {}, diff --git a/x-pack/plugins/security_solution/public/common/mock/timeline_results.ts b/x-pack/plugins/security_solution/public/common/mock/timeline_results.ts index 2de29a8c3acf8..4bbdca8564a8e 100644 --- a/x-pack/plugins/security_solution/public/common/mock/timeline_results.ts +++ b/x-pack/plugins/security_solution/public/common/mock/timeline_results.ts @@ -2011,6 +2011,7 @@ export const mockTimelineModel: TimelineModel = { savedObjectId: 'ef579e40-jibber-jabber', selectAll: false, selectedEventIds: {}, + sessionViewId: null, show: false, showCheckboxes: false, sort: [ @@ -2132,6 +2133,7 @@ export const defaultTimelineProps: CreateTimelineProps = { savedObjectId: null, selectAll: false, selectedEventIds: {}, + sessionViewId: null, show: false, showCheckboxes: false, sort: [{ columnId: '@timestamp', columnType: 'number', sortDirection: Direction.desc }], diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx index 4f8882ee823b3..e75cfcd6befa9 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/actions.test.tsx @@ -312,6 +312,7 @@ describe('alert actions', () => { savedObjectId: null, selectAll: false, selectedEventIds: {}, + sessionViewId: null, show: true, showCheckboxes: false, sort: [ diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/default_config.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/default_config.tsx index dc8c5bf4de65e..7dc3561628193 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/default_config.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/default_config.tsx @@ -176,4 +176,5 @@ export const requiredFieldsForActions = [ 'file.hash.sha256', 'host.os.family', 'event.code', + 'process.entry_leader.entity_id', ]; diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx index c82c0c11237ee..b4f81e3e5f0e4 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_table/index.tsx @@ -104,7 +104,7 @@ export const AlertsTableComponent: React.FC = ({ const kibana = useKibana(); const [, dispatchToaster] = useStateToaster(); const { addWarning } = useAppToasts(); - const ACTION_BUTTON_COUNT = 4; + const ACTION_BUTTON_COUNT = 5; const getGlobalQuery = useCallback( (customFilters: Filter[]) => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.test.tsx index e8d144f07827f..90a5798108d88 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.test.tsx @@ -5,10 +5,10 @@ * 2.0. */ -import { waitFor } from '@testing-library/react'; -import { mount } from 'enzyme'; +import { render } from '@testing-library/react'; import React from 'react'; +import '@testing-library/jest-dom'; import { useGlobalFullScreen, useTimelineFullScreen, @@ -37,6 +37,24 @@ jest.mock('../../../resolver/view/use_state_syncing_actions'); const useStateSyncingActionsMock = useStateSyncingActions as jest.Mock; jest.mock('../../../resolver/view/use_sync_selected_node'); +jest.mock('../../../common/lib/kibana', () => { + const original = jest.requireActual('../../../common/lib/kibana'); + return { + ...original, + useKibana: () => ({ + services: { + sessionView: { + getSessionView: () =>
, + }, + data: { + search: { + search: jest.fn(), + }, + }, + }, + }), + }; +}); describe('GraphOverlay', () => { const { storage } = createSecuritySolutionStorageMock(); @@ -54,20 +72,18 @@ describe('GraphOverlay', () => { }); describe('when used in an events viewer (i.e. in the Detections view, or the Host > Events view)', () => { - test('it has 100% width when NOT in full screen mode', async () => { - const wrapper = mount( + test('it has 100% width when NOT in full screen mode', () => { + const wrapper = render( - + } Navigation={
} /> ); - await waitFor(() => { - const overlayContainer = wrapper.find('[data-test-subj="overlayContainer"]').first(); - expect(overlayContainer).toHaveStyleRule('width', '100%'); - }); + const overlayContainer = wrapper.getByTestId('overlayContainer'); + expect(overlayContainer).toHaveStyleRule('width', '100%'); }); - test('it has a fixed position when in full screen mode', async () => { + test('it has a fixed position when in full screen mode', () => { (useGlobalFullScreen as jest.Mock).mockReturnValue({ globalFullScreen: true, setGlobalFullScreen: jest.fn(), @@ -77,20 +93,18 @@ describe('GraphOverlay', () => { setTimelineFullScreen: jest.fn(), }); - const wrapper = mount( + const wrapper = render( - + } Navigation={
} /> ); - await waitFor(() => { - const overlayContainer = wrapper.find('[data-test-subj="overlayContainer"]').first(); - expect(overlayContainer).toHaveStyleRule('position', 'fixed'); - }); + const overlayContainer = wrapper.getByTestId('overlayContainer'); + expect(overlayContainer).toHaveStyleRule('position', 'fixed'); }); test('it gets index pattern from default data view', () => { - mount( + render( { storage )} > - + } Navigation={
} /> ); @@ -123,20 +137,18 @@ describe('GraphOverlay', () => { describe('when used in the active timeline', () => { const timelineId = TimelineId.active; - test('it has 100% width when NOT in full screen mode', async () => { - const wrapper = mount( + test('it has 100% width when NOT in full screen mode', () => { + const wrapper = render( - + } Navigation={
} /> ); - await waitFor(() => { - const overlayContainer = wrapper.find('[data-test-subj="overlayContainer"]').first(); - expect(overlayContainer).toHaveStyleRule('width', '100%'); - }); + const overlayContainer = wrapper.getByTestId('overlayContainer'); + expect(overlayContainer).toHaveStyleRule('width', '100%'); }); - test('it has 100% width when the active timeline is in full screen mode', async () => { + test('it has 100% width when the active timeline is in full screen mode', () => { (useGlobalFullScreen as jest.Mock).mockReturnValue({ globalFullScreen: false, setGlobalFullScreen: jest.fn(), @@ -146,20 +158,18 @@ describe('GraphOverlay', () => { setTimelineFullScreen: jest.fn(), }); - const wrapper = mount( + const wrapper = render( - + } Navigation={
} /> ); - await waitFor(() => { - const overlayContainer = wrapper.find('[data-test-subj="overlayContainer"]').first(); - expect(overlayContainer).toHaveStyleRule('width', '100%'); - }); + const overlayContainer = wrapper.getByTestId('overlayContainer'); + expect(overlayContainer).toHaveStyleRule('width', '100%'); }); test('it gets index pattern from Timeline data view', () => { - mount( + render( { storage )} > - + } Navigation={
} /> ); expect(useStateSyncingActionsMock.mock.calls[0][0].indices).toEqual(mockIndexNames); }); + + test('it renders session view controls', () => { + (useGlobalFullScreen as jest.Mock).mockReturnValue({ + globalFullScreen: false, + setGlobalFullScreen: jest.fn(), + }); + (useTimelineFullScreen as jest.Mock).mockReturnValue({ + timelineFullScreen: true, + setTimelineFullScreen: jest.fn(), + }); + + const wrapper = render( + + } + Navigation={
{'Close Session'}
} + /> +
+ ); + + expect(wrapper.getByText('Close Session')).toBeTruthy(); + }); }); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.tsx b/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.tsx index 64475147edc9d..694003311e6c8 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/graph_overlay/index.tsx @@ -5,25 +5,10 @@ * 2.0. */ -import { - EuiButtonEmpty, - EuiButtonIcon, - EuiFlexGroup, - EuiFlexItem, - EuiHorizontalRule, - EuiToolTip, - EuiLoadingSpinner, -} from '@elastic/eui'; -import React, { useCallback, useMemo, useEffect } from 'react'; +import React, { useMemo, useEffect } from 'react'; +import { EuiFlexGroup, EuiFlexItem, EuiHorizontalRule, EuiLoadingSpinner } from '@elastic/eui'; import { useDispatch } from 'react-redux'; import styled from 'styled-components'; - -import { FULL_SCREEN } from '../timeline/body/column_headers/translations'; -import { EXIT_FULL_SCREEN } from '../../../common/components/exit_full_screen/translations'; -import { - FULL_SCREEN_TOGGLED_CLASS_NAME, - SCROLLING_DISABLED_CLASS_NAME, -} from '../../../../common/constants'; import { useGlobalFullScreen, useTimelineFullScreen, @@ -33,7 +18,6 @@ import { TimelineId } from '../../../../common/types/timeline'; import { timelineSelectors } from '../../store/timeline'; import { timelineDefaults } from '../../store/timeline/defaults'; import { isFullScreen } from '../timeline/body/column_headers'; -import { updateTimelineGraphEventId } from '../../../timelines/store/timeline/actions'; import { inputsActions } from '../../../common/store/actions'; import { Resolver } from '../../../resolver/view'; import { @@ -41,7 +25,6 @@ import { startSelector, endSelector, } from '../../../common/components/super_date_picker/selectors'; -import * as i18n from './translations'; import { SourcererScopeName } from '../../../common/store/sourcerer/model'; import { useSourcererDataView } from '../../../common/containers/sourcerer'; import { sourcererSelectors } from '../../../common/store'; @@ -66,71 +49,35 @@ const StyledResolver = styled(Resolver)` height: 100%; `; -const FullScreenButtonIcon = styled(EuiButtonIcon)` - margin: 4px 0 4px 0; +const ScrollableFlexItem = styled(EuiFlexItem)` + ${({ theme }) => `margin: 0 ${theme.eui.euiSizeM};`} + overflow: hidden; + width: 100%; `; -interface OwnProps { - timelineId: TimelineId; -} - -interface NavigationProps { - fullScreen: boolean; - globalFullScreen: boolean; - onCloseOverlay: () => void; +interface GraphOverlayProps { timelineId: TimelineId; - timelineFullScreen: boolean; - toggleFullScreen: () => void; + SessionView: JSX.Element | null; + Navigation: JSX.Element | null; } -const NavigationComponent: React.FC = ({ - fullScreen, - globalFullScreen, - onCloseOverlay, +const GraphOverlayComponent: React.FC = ({ timelineId, - timelineFullScreen, - toggleFullScreen, -}) => ( - - - - {i18n.CLOSE_ANALYZER} - - - {timelineId !== TimelineId.active && ( - - - - - - )} - -); - -NavigationComponent.displayName = 'NavigationComponent'; - -const Navigation = React.memo(NavigationComponent); - -const GraphOverlayComponent: React.FC = ({ timelineId }) => { + SessionView, + Navigation, +}) => { const dispatch = useDispatch(); - const { globalFullScreen, setGlobalFullScreen } = useGlobalFullScreen(); - const { timelineFullScreen, setTimelineFullScreen } = useTimelineFullScreen(); + const { globalFullScreen } = useGlobalFullScreen(); + const { timelineFullScreen } = useTimelineFullScreen(); const getTimeline = useMemo(() => timelineSelectors.getTimelineByIdSelector(), []); const graphEventId = useDeepEqualSelector( (state) => (getTimeline(state, timelineId) ?? timelineDefaults).graphEventId ); + const sessionViewId = useDeepEqualSelector( + (state) => (getTimeline(state, timelineId) ?? timelineDefaults).sessionViewId + ); + const getStartSelector = useMemo(() => startSelector(), []); const getEndSelector = useMemo(() => endSelector(), []); const getIsLoadingSelector = useMemo(() => isLoadingSelector(), []); @@ -163,24 +110,6 @@ const GraphOverlayComponent: React.FC = ({ timelineId }) => { ); const isInTimeline = timelineId === TimelineId.active; - const onCloseOverlay = useCallback(() => { - const isDataGridFullScreen = document.querySelector('.euiDataGrid--fullScreen') !== null; - // Since EUI changes these values directly as a side effect, need to add them back on close. - if (isDataGridFullScreen) { - if (timelineId === TimelineId.active) { - document.body.classList.add('euiDataGrid__restrictBody'); - } else { - document.body.classList.add(SCROLLING_DISABLED_CLASS_NAME, 'euiDataGrid__restrictBody'); - } - } else { - if (timelineId === TimelineId.active) { - setTimelineFullScreen(false); - } else { - setGlobalFullScreen(false); - } - } - dispatch(updateTimelineGraphEventId({ id: timelineId, graphEventId: '' })); - }, [dispatch, timelineId, setTimelineFullScreen, setGlobalFullScreen]); useEffect(() => { return () => { @@ -192,20 +121,6 @@ const GraphOverlayComponent: React.FC = ({ timelineId }) => { }; }, [dispatch, timelineId]); - const toggleFullScreen = useCallback(() => { - if (timelineId === TimelineId.active) { - setTimelineFullScreen(!timelineFullScreen); - } else { - setGlobalFullScreen(!globalFullScreen); - } - }, [ - timelineId, - setTimelineFullScreen, - timelineFullScreen, - setGlobalFullScreen, - globalFullScreen, - ]); - const getDefaultDataViewSelector = useMemo( () => sourcererSelectors.defaultDataViewSelector(), [] @@ -219,21 +134,32 @@ const GraphOverlayComponent: React.FC = ({ timelineId }) => { [defaultDataView.patternList, isInTimeline, timelinePatterns] ); - if (fullScreen && !isInTimeline) { + if (!isInTimeline && sessionViewId !== null) { + if (fullScreen) { + return ( + + + {Navigation} + {SessionView} + + + ); + } else { + return ( + + + {Navigation} + {SessionView} + + + ); + } + } else if (fullScreen && !isInTimeline) { return ( - - - + {Navigation} {graphEventId !== undefined ? ( @@ -256,16 +182,7 @@ const GraphOverlayComponent: React.FC = ({ timelineId }) => { - - - + {Navigation} {graphEventId !== undefined ? ( diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap index 01089552be251..6ea24e5ca57f6 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap @@ -380,6 +380,313 @@ Array [ runtimeMappings={Object {}} tabType="query" timelineId="test" + > + + +
+ + + +
+ +
+ +
+ + + +
+ + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+
+
+
+ + + +
+ +
+ +
+ +
+ +
+ + + + + +
+ , + .c0 { + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; + margin-top: 8px; +} + +.c1 .euiFlyoutBody__overflow { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex: 1; + -ms-flex: 1; + flex: 1; + overflow: hidden; +} + +.c1 .euiFlyoutBody__overflow .euiFlyoutBody__overflowContent { + -webkit-flex: 1; + -ms-flex: 1; + flex: 1; + overflow: hidden; + padding: 0 16px 16px; +} + +
+
- , - .c0 { - -webkit-flex: 0 1 auto; - -ms-flex: 0 1 auto; - flex: 0 1 auto; - margin-top: 8px; -} - -.c1 .euiFlyoutBody__overflow { - display: -webkit-box; - display: -webkit-flex; - display: -ms-flexbox; - display: flex; - -webkit-flex: 1; - -ms-flex: 1; - flex: 1; - overflow: hidden; -} - -.c1 .euiFlyoutBody__overflow .euiFlyoutBody__overflowContent { - -webkit-flex: 1; - -ms-flex: 1; - flex: 1; - overflow: hidden; - padding: 0 16px 16px; -} - -
-
@@ -157,7 +161,9 @@ exports[`Storyshots renderers/DropdownFilter with choices and new value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -218,7 +224,9 @@ exports[`Storyshots renderers/DropdownFilter with choices and value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -261,7 +269,9 @@ exports[`Storyshots renderers/DropdownFilter with new value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
diff --git a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot index 5abd1e9fd05b6..e82b6bf082b05 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot @@ -42,13 +42,17 @@ exports[`Storyshots renderers/TimeFilter default 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -91,7 +95,9 @@ exports[`Storyshots renderers/TimeFilter default 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -150,13 +156,17 @@ exports[`Storyshots renderers/TimeFilter with absolute time bounds 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -235,7 +245,9 @@ exports[`Storyshots renderers/TimeFilter with absolute time bounds 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -294,13 +306,17 @@ exports[`Storyshots renderers/TimeFilter with commonlyUsedRanges 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -343,7 +359,9 @@ exports[`Storyshots renderers/TimeFilter with commonlyUsedRanges 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -402,13 +420,17 @@ exports[`Storyshots renderers/TimeFilter with dateFormat 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -451,7 +473,9 @@ exports[`Storyshots renderers/TimeFilter with dateFormat 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -510,13 +534,17 @@ exports[`Storyshots renderers/TimeFilter with relative time bounds 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -595,7 +623,9 @@ exports[`Storyshots renderers/TimeFilter with relative time bounds 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot index e3badfa833090..7c0a2ad18c3dc 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot @@ -65,7 +65,9 @@ exports[`Storyshots arguments/AxisConfig extended 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -143,7 +145,9 @@ exports[`Storyshots arguments/AxisConfig/components extended 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot index 238fe7c259c6e..9755e1b53b868 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot @@ -47,7 +47,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -120,7 +122,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -192,7 +196,9 @@ exports[`Storyshots arguments/DateFormat with preset format 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot index 2159e49e2bcf1..ecd8e53ce1d25 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot @@ -57,7 +57,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -140,7 +142,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -222,7 +226,9 @@ exports[`Storyshots arguments/NumberFormat with preset format 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot index 6db24bd0b984c..587b07ca4f932 100644 --- a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot @@ -81,7 +81,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + + @@ -111,7 +113,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -142,7 +146,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + + @@ -169,7 +175,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -260,7 +268,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + + @@ -290,7 +300,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -321,7 +333,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + + @@ -348,7 +362,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot index dd650e9f4c697..5409f9c444df0 100644 --- a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot @@ -26,7 +26,9 @@ exports[`Storyshots components/Assets/AssetManager no assets 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -122,7 +126,9 @@ exports[`Storyshots components/Assets/AssetManager no assets 1`] = ` color="subdued" data-euiicon-type="importAction" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -380,7 +390,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + +
@@ -410,7 +422,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + +
@@ -441,7 +455,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + +
@@ -468,7 +484,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + +
@@ -548,7 +566,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + + @@ -578,7 +598,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -609,7 +631,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + + @@ -636,7 +660,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot b/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot index 056b87294f245..5d83b2718f916 100644 --- a/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot @@ -129,7 +129,9 @@ Array [ + > + + ,
+ > + +
,
+ > + +
,
+ > + +
, ] diff --git a/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot b/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot index cb3598430c7ef..057bd37b71c20 100644 --- a/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot @@ -394,7 +394,9 @@ exports[`Storyshots components/Color/ColorManager interactive 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -805,7 +809,9 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + , @@ -886,7 +894,9 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + , @@ -965,7 +977,9 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + , diff --git a/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot b/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot index a0d27eafb23dc..53651c8fe33f2 100644 --- a/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot @@ -393,7 +393,9 @@ Array [ className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -758,7 +760,9 @@ exports[`Storyshots components/Color/ColorPalette six colors, wrap at 4 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -1040,7 +1044,9 @@ Array [ className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot b/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot index 6ef3eec47e701..557f94c26fac9 100644 --- a/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot @@ -237,7 +237,9 @@ exports[`Storyshots components/Color/ColorPicker interactive 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -318,7 +322,9 @@ exports[`Storyshots components/Color/ColorPicker six colors 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -526,7 +532,9 @@ exports[`Storyshots components/Color/ColorPicker six colors 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -786,7 +796,9 @@ exports[`Storyshots components/Color/ColorPicker six colors, value missing 1`] = color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -846,7 +860,9 @@ exports[`Storyshots components/Color/ColorPicker three colors 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -970,7 +986,9 @@ exports[`Storyshots components/Color/ColorPicker three colors 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot b/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot index d8c660923e3d7..feb04e68ca1d3 100644 --- a/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot @@ -27,7 +27,9 @@ exports[`Storyshots components/Elements/CustomElementModal with description 1`] color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -224,7 +228,9 @@ exports[`Storyshots components/Elements/CustomElementModal with description 1`] className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -646,7 +656,9 @@ exports[`Storyshots components/Elements/CustomElementModal with name 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -843,7 +857,9 @@ exports[`Storyshots components/Elements/CustomElementModal with name 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -1146,7 +1166,9 @@ exports[`Storyshots components/Elements/CustomElementModal with title 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + + + > + + Test Datasource @@ -70,14 +74,18 @@ exports[`Storyshots components/datasource/DatasourceComponent simple datasource color="inherit" data-euiicon-type="arrowRight" size="m" - /> + > + + + > + + Test Datasource diff --git a/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot b/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot index 14640fe266839..05cec59522ae7 100644 --- a/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot @@ -19,7 +19,9 @@ exports[`Storyshots components/Elements/ElementCard with click handler 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + +
+ > + +
+ > + +
diff --git a/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot b/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot index d3ab369dcc32c..0863fd13af607 100644 --- a/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot @@ -59,7 +59,9 @@ exports[`Storyshots Home Home Page 1`] = ` color="inherit" data-euiicon-type="plusInCircleFilled" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot b/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot index 8f00060a1dd1c..fa3789124ce81 100644 --- a/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot @@ -28,7 +28,9 @@ exports[`Storyshots Home/Components/Empty Prompt Empty Prompt 1`] = ` color="subdued" data-euiicon-type="importAction" size="xxl" - /> + > + +
+ > + +
@@ -73,7 +75,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` className="euiFilePicker__icon" data-euiicon-type="importAction" size="m" - /> + > + +
@@ -150,7 +154,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -296,7 +302,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` className="euiTableSortIcon" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -460,7 +468,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - /> + > + +
@@ -486,7 +496,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - /> + > + +
@@ -632,7 +644,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - /> + > + +
@@ -658,7 +672,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - /> + > + +
@@ -804,7 +820,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - /> + > + +
@@ -830,7 +848,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - /> + > + +
@@ -873,7 +893,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -915,7 +937,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
    + > + +
diff --git a/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot b/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot index dbb591582e909..e96302525aea4 100644 --- a/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot @@ -73,7 +73,9 @@ exports[`Storyshots components/ItemGrid complex grid 1`] = ` + > + +
+ > + +
+ > + +
@@ -125,13 +131,19 @@ exports[`Storyshots components/ItemGrid icon grid 1`] = ` > + > + + + > + + + > + + `; diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot index 6f139df7c8773..9f462d9a4d6cd 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot @@ -34,7 +34,9 @@ exports[`Storyshots components/SavedElementsModal/ElementControls has two button color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -61,7 +63,9 @@ exports[`Storyshots components/SavedElementsModal/ElementControls has two button color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot index 70ee9f543d768..fbab31e5c8c5b 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot @@ -85,7 +85,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -112,7 +114,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -192,7 +196,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -219,7 +225,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -299,7 +307,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -326,7 +336,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot index fd6f29178aa91..e0b7f40657cf8 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot @@ -26,7 +26,9 @@ exports[`Storyshots components/SavedElementsModal no custom elements 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -99,7 +103,9 @@ exports[`Storyshots components/SavedElementsModal no custom elements 1`] = ` color="subdued" data-euiicon-type="vector" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -327,7 +337,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -354,7 +366,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -434,7 +448,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -461,7 +477,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -541,7 +559,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -568,7 +588,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -634,7 +656,9 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
+ > + +
@@ -787,7 +815,9 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -814,7 +844,9 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot b/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot index 6bf2535131afc..d5e5af856909b 100644 --- a/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot @@ -72,7 +72,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="sortUp" size="m" - /> + > + + @@ -98,7 +100,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="arrowUp" size="m" - /> + > + + @@ -124,7 +128,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="m" - /> + > + + @@ -150,7 +156,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot b/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot index f21ffcf1a70ea..2a1e12c1e0b74 100644 --- a/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot @@ -57,7 +57,9 @@ exports[`Storyshots components/Tags/Tag as health 1`] = ` + > + +
+ > + +
+ > + +
+ > + +
+ > + +
+ > + +
@@ -244,7 +246,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorBold" size="m" - /> + > + + @@ -274,7 +278,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorItalic" size="m" - /> + > + + @@ -304,7 +310,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorUnderline" size="m" - /> + > + + @@ -348,7 +356,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignLeft" size="m" - /> + > + + @@ -384,7 +394,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignCenter" size="m" - /> + > + + @@ -420,7 +432,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignRight" size="m" - /> + > + + @@ -598,7 +612,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -690,7 +706,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorBold" size="m" - /> + > + + @@ -720,7 +738,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorItalic" size="m" - /> + > + + @@ -750,7 +770,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorUnderline" size="m" - /> + > + + @@ -794,7 +816,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignLeft" size="m" - /> + > + + @@ -830,7 +854,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignCenter" size="m" - /> + > + + @@ -866,7 +892,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignRight" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot index f5351b0d8ea5f..0d8a5c0cf4e5d 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot @@ -20,7 +20,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot index 6c70364f9679c..72e1b4d6ef909 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot @@ -20,7 +20,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + @@ -255,7 +259,9 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - /> + > + + @@ -310,7 +316,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + @@ -486,7 +496,9 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - /> + > + + @@ -541,7 +553,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + @@ -717,7 +733,9 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - /> + > + + @@ -772,7 +790,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot index 7d43840e431ab..ac27b0443585a 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot @@ -28,7 +28,9 @@ exports[`Storyshots components/Variables/VarConfig default 1`] = ` color="inherit" data-euiicon-type="arrowRight" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot b/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot index b6d842ac44e21..57fbd4c2109cd 100644 --- a/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot @@ -33,7 +33,9 @@ exports[`Storyshots components/WorkpadFilters/FiltersGroupComponent default 1`] color="inherit" data-euiicon-type="arrowRight" size="m" - /> + > + +
+ > + +
@@ -1467,7 +1473,9 @@ exports[`Storyshots shareables/Canvas component 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + @@ -2809,7 +2817,9 @@ exports[`Storyshots shareables/Canvas contextual: austin 1`] = ` + > + +
+ > + +
+ > + +
@@ -2949,7 +2963,9 @@ exports[`Storyshots shareables/Canvas contextual: austin 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + @@ -3107,7 +3123,9 @@ exports[`Storyshots shareables/Canvas contextual: hello 1`] = ` + > + +
+ > + +
+ > + +
@@ -3247,7 +3269,9 @@ exports[`Storyshots shareables/Canvas contextual: hello 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot index 90ebc1900d731..6a8d67a70ad1a 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot @@ -1280,7 +1280,9 @@ exports[`Storyshots shareables/Footer contextual: austin 1`] = ` + > + +
+ > + +
+ > + +
@@ -1420,7 +1426,9 @@ exports[`Storyshots shareables/Footer contextual: austin 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + @@ -1532,7 +1540,9 @@ exports[`Storyshots shareables/Footer contextual: hello 1`] = ` + > + +
+ > + +
+ > + +
@@ -1672,7 +1686,9 @@ exports[`Storyshots shareables/Footer contextual: hello 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot index 9edb6f1fda62f..f2b92754b6d6f 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot @@ -34,7 +34,9 @@ exports[`Storyshots shareables/Footer/PageControls component 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
+ > + +
@@ -131,7 +135,9 @@ exports[`Storyshots shareables/Footer/PageControls contextual: austin 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
+ > + +
@@ -228,7 +236,9 @@ exports[`Storyshots shareables/Footer/PageControls contextual: hello 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
+ > + +
diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot index 2b326fd0ec51a..ea19100f6da87 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot @@ -34,7 +34,9 @@ exports[`Storyshots shareables/Footer/Title component 1`] = ` + > + +
+ > + +
+ > + +
+ > + + + > + + @@ -212,12 +216,16 @@ exports[`Storyshots shareables/Footer/Settings/AutoplaySettings component: on, 5 className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + @@ -376,12 +384,16 @@ exports[`Storyshots shareables/Footer/Settings/AutoplaySettings contextual 1`] = className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot index 265cbe460607d..3c3f26bce7e9e 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot @@ -39,7 +39,9 @@ exports[`Storyshots shareables/Footer/Settings component 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + +
@@ -87,7 +89,9 @@ exports[`Storyshots shareables/Footer/Settings contextual 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot index 1aafb9cc6b664..d07e5a9edc8ad 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot @@ -59,12 +59,16 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings component: off 1` className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + @@ -147,12 +151,16 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings component: on 1`] className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + @@ -235,12 +243,16 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings contextual 1`] = className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + diff --git a/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx b/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx index 4fd56525541a6..63fc2e2695a3a 100644 --- a/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx +++ b/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx @@ -264,7 +264,7 @@ describe('ConnectorsDropdown', () => { wrapper: ({ children }) => {children}, }); - const tooltips = screen.getAllByLabelText( + const tooltips = screen.getAllByText( 'This connector is deprecated. Update it, or create a new one.' ); expect(tooltips[0]).toBeInTheDocument(); diff --git a/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx b/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx index af803cfc14e05..8cb8b7f23b439 100644 --- a/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx +++ b/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx @@ -25,7 +25,7 @@ describe('Markdown', () => { test('it renders the expected link text', () => { const result = appMockRender.render({markdownWithLink}); - expect(removeExternalLinkText(result.getByTestId('markdown-link').textContent)).toEqual( + expect(removeExternalLinkText(result.getByTestId('markdown-link').textContent)).toContain( 'External Site' ); }); diff --git a/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx b/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx index 863e5e85d9ef3..eb1f82cc01e37 100644 --- a/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx +++ b/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx @@ -138,7 +138,7 @@ describe('Background Search Session Management Table', () => { expect(table.find('tbody td').map((node) => node.text())).toMatchInlineSnapshot(` Array [ "App", - "Namevery background search ", + "Namevery background search Info", "# Searches0", "StatusExpired", "Created2 Dec, 2020, 00:19:32", diff --git a/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx b/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx index 0626a946f8848..d44625b1641ac 100644 --- a/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx +++ b/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx @@ -65,7 +65,6 @@ export const IndexSetupDatasetFilter: React.FC<{ isSelected={isVisible} onClick={show} iconType="arrowDown" - size="s" > { // Dropdown should be visible and processor status should equal "success" expect(exists('documentsDropdown')).toBe(true); - const initialProcessorStatusLabel = find('processors>0.processorStatusIcon').props()[ - 'aria-label' - ]; + const initialProcessorStatusLabel = find('processors>0.processorStatusIcon').props() + .children; expect(initialProcessorStatusLabel).toEqual('Success'); // Open flyout and click clear all button @@ -320,9 +319,8 @@ describe('Test pipeline', () => { // Verify documents and processors were reset expect(exists('documentsDropdown')).toBe(false); expect(exists('addDocumentsButton')).toBe(true); - const resetProcessorStatusIconLabel = find('processors>0.processorStatusIcon').props()[ - 'aria-label' - ]; + const resetProcessorStatusIconLabel = find('processors>0.processorStatusIcon').props() + .children; expect(resetProcessorStatusIconLabel).toEqual('Not run'); }); }); @@ -332,7 +330,7 @@ describe('Test pipeline', () => { it('should show "inactive" processor status by default', async () => { const { find } = testBed; - const statusIconLabel = find('processors>0.processorStatusIcon').props()['aria-label']; + const statusIconLabel = find('processors>0.processorStatusIcon').props().children; expect(statusIconLabel).toEqual('Not run'); }); @@ -352,7 +350,7 @@ describe('Test pipeline', () => { actions.closeTestPipelineFlyout(); // Verify status - const statusIconLabel = find('processors>0.processorStatusIcon').props()['aria-label']; + const statusIconLabel = find('processors>0.processorStatusIcon').props().children; expect(statusIconLabel).toEqual('Success'); }); diff --git a/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx b/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx index 36fd1581cb9b6..2ad20bf0a43e2 100644 --- a/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx +++ b/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx @@ -617,7 +617,9 @@ describe('DatatableComponent', () => { wrapper.setProps({ data: newData }); wrapper.update(); - expect(wrapper.find('[data-test-subj="dataGridHeader"]').children().first().text()).toEqual( + // Using .toContain over .toEqual because this element includes text from + // which can't be seen, but shows in the text content + expect(wrapper.find('[data-test-subj="dataGridHeader"]').children().first().text()).toContain( 'new a' ); }); diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx index c86fdcc33b15f..c20f1c37c6c67 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx @@ -120,7 +120,10 @@ describe('IndexPattern Field Item', () => { it('should display displayName of a field', () => { const wrapper = mountWithIntl(); - expect(wrapper.find('[data-test-subj="lnsFieldListPanelField"]').first().text()).toEqual( + + // Using .toContain over .toEqual because this element includes text from + // which can't be seen, but shows in the text content + expect(wrapper.find('[data-test-subj="lnsFieldListPanelField"]').first().text()).toContain( 'bytesLabel' ); }); diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap index fda479f2888ce..0fd589e4886e3 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap @@ -1,9 +1,9 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`RequestTrialExtension component should display when enterprise license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when enterprise license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when license is active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when license is active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when platinum license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when platinum license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap index 4fa45c4bec5ce..cf977731ee452 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap @@ -1,7 +1,7 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`RevertToBasic component should display when license is about to expire 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when license is about to expire 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; -exports[`RevertToBasic component should display when license is expired 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when license is expired 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; -exports[`RevertToBasic component should display when trial is active 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when trial is active 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap index 622bff86ead16..0880eddcc1683 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap @@ -1,9 +1,9 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`StartTrial component when trial is allowed display for basic license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed display for basic license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for expired enterprise license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for expired enterprise license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for expired platinum license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for expired platinum license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for gold license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for gold license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; diff --git a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap index c5b5e5e65ab38..41501a7eedb62 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap @@ -87,10 +87,11 @@ Array [ > Elasticsearch Service Console + > + External link + @@ -106,10 +107,11 @@ Array [ > Logs and metrics + > + External link + @@ -125,10 +127,11 @@ Array [ > the documentation page. + > + External link + diff --git a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap index dda853a28239f..faab608e7af14 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap @@ -158,10 +158,11 @@ Array [ > Elasticsearch Service Console + > + External link + @@ -177,10 +178,11 @@ Array [ > Logs and metrics + > + External link + @@ -196,10 +198,11 @@ Array [ > the documentation page. + > + External link + diff --git a/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js b/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js index a6987fa19d1ee..26af30ba17c04 100644 --- a/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js +++ b/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js @@ -252,7 +252,7 @@ describe('', () => { ], [ '', - remoteCluster2.name, + remoteCluster2.name.concat('Info'), //Tests include the word "info" to account for the rendered text coming from EuiIcon 'Not connected', PROXY_MODE, remoteCluster2.proxyAddress, @@ -261,7 +261,7 @@ describe('', () => { ], [ '', - remoteCluster3.name, + remoteCluster3.name.concat('Info'), //Tests include the word "info" to account for the rendered text coming from EuiIcon 'Not connected', PROXY_MODE, remoteCluster2.proxyAddress, @@ -360,7 +360,7 @@ describe('', () => { ({ rows } = table.getMetaData('remoteClusterListTable')); expect(rows.length).toBe(2); - expect(rows[0].columns[1].value).toEqual(remoteCluster2.name); + expect(rows[0].columns[1].value).toContain(remoteCluster2.name); }); }); diff --git a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx index 7052f724cd1cc..006ae053940d8 100644 --- a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx +++ b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx @@ -40,7 +40,7 @@ describe('FeatureTableCell', () => { ); - expect(wrapper.text()).toMatchInlineSnapshot(`"Test Feature "`); + expect(wrapper.text()).toMatchInlineSnapshot(`"Test Feature Info"`); expect(wrapper.find(EuiIconTip).props().content).toMatchInlineSnapshot(` diff --git a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts index 3a70ff5713bd9..f375263c960c3 100644 --- a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts +++ b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts @@ -60,7 +60,7 @@ export function getDisplayedFeaturePrivileges( acc[feature.id][key] = { ...acc[feature.id][key], - primaryFeaturePrivilege: primary.text().trim(), + primaryFeaturePrivilege: primary.text().replaceAll('Info', '').trim(), // Removing the word "info" to account for the rendered text coming from EuiIcon hasCustomizedSubFeaturePrivileges: findTestSubject(primary, 'additionalPrivilegesGranted').length > 0, }; diff --git a/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx b/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx index 6070924523f63..a53be08380698 100644 --- a/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx @@ -158,7 +158,7 @@ describe('ExceptionEntries', () => { expect(parentValue.text()).toEqual(getEmptyValue()); expect(nestedField.exists('.euiToolTipAnchor')).toBeTruthy(); - expect(nestedField.text()).toEqual('host.name'); + expect(nestedField.text()).toContain('host.name'); expect(nestedOperator.text()).toEqual('is'); expect(nestedValue.text()).toEqual('some name'); }); diff --git a/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx b/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx index 7a9c36a986afd..9796ae2624a73 100644 --- a/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx @@ -58,7 +58,7 @@ describe('Modal Inspect', () => { expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="index-pattern-title"]').text() - ).toBe('Index pattern '); + ).toContain('Index pattern '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="index-pattern-description"]') @@ -66,7 +66,7 @@ describe('Modal Inspect', () => { ).toBe('auditbeat-*, filebeat-*, packetbeat-*, winlogbeat-*'); expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="query-time-title"]').text() - ).toBe('Query time '); + ).toContain('Query time '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="query-time-description"]') @@ -76,7 +76,7 @@ describe('Modal Inspect', () => { wrapper .find('.euiDescriptionList__title span[data-test-subj="request-timestamp-title"]') .text() - ).toBe('Request timestamp '); + ).toContain('Request timestamp '); }); test('Click on request Tab', () => { diff --git a/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx b/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx index 97f93b9732c02..adab4db904d6a 100644 --- a/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx @@ -105,7 +105,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders props passed in as link', () => { @@ -463,7 +463,7 @@ describe('Custom Links', () => { describe('WhoisLink', () => { test('it renders ip passed in as domain', () => { const wrapper = mountWithIntl({'Example Link'}); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href', () => { @@ -488,7 +488,7 @@ describe('Custom Links', () => { {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href', () => { @@ -519,7 +519,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href', () => { @@ -548,7 +548,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href when port is a number', () => { diff --git a/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx b/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx index da3785648de62..68588c9338b4c 100644 --- a/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx @@ -20,7 +20,7 @@ describe('Markdown', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="markdown-link"]').first().text()) - ).toEqual('External Site'); + ).toContain('External Site'); }); test('it renders the expected href', () => { diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx new file mode 100644 index 0000000000000..e08389ba250a3 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { FC } from 'react'; + +import { EuiTourStepProps, EuiTourStep, DistributiveOmit } from '@elastic/eui'; + +/** + * This component can be used for tour steps, when tour step is optional + * If stepProps are not supplied, step will not be rendered, only children component will be + */ +export const OptionalEuiTourStep: FC<{ + stepProps: DistributiveOmit | undefined; +}> = ({ children, stepProps }) => { + if (!stepProps) { + return <>{children}; + } + + return ( + + <>{children} + + ); +}; diff --git a/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx b/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx index 480d200c6756f..ec56dd6934463 100644 --- a/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx @@ -54,9 +54,9 @@ describe('Port', () => { ); - expect(removeExternalLinkText(wrapper.find('[data-test-subj="port"]').first().text())).toEqual( - '443' - ); + expect( + removeExternalLinkText(wrapper.find('[data-test-subj="port"]').first().text()) + ).toContain('443'); }); test('it hyperlinks links destination.port to an external service that describes the purpose of the port', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx b/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx index 3332111d14f8b..bb8b4683c9d30 100644 --- a/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx @@ -205,7 +205,7 @@ describe('SourceDestination', () => { removeExternalLinkText( wrapper.find('[data-test-subj="destination-ip-and-port"]').first().text() ) - ).toEqual('10.1.2.3:80'); + ).toContain('10.1.2.3:80'); }); test('it renders destination.packets', () => { @@ -329,7 +329,7 @@ describe('SourceDestination', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="source-ip-and-port"]').first().text()) - ).toEqual('192.168.1.2:9987'); + ).toContain('192.168.1.2:9987'); }); test('it renders source.packets', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx b/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx index f16cd7dbb109f..6168d98765253 100644 --- a/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx @@ -984,7 +984,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-source.port"]').first().text() ) - ).toEqual('9987'); + ).toContain('9987'); }); test('it renders the expected destination port when type is `destination`, and both destinationIp and destinationPort are populated', () => { @@ -1038,7 +1038,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-destination.port"]').first().text() ) - ).toEqual('80'); + ).toContain('80'); }); test('it renders the expected source port when type is `source`, but only sourcePort is populated', () => { @@ -1092,7 +1092,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-source.port"]').first().text() ) - ).toEqual('9987'); + ).toContain('9987'); }); test('it renders the expected destination port when type is `destination`, and only destinationPort is populated', () => { @@ -1147,7 +1147,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-destination.port"]').first().text() ) - ).toEqual('80'); + ).toContain('80'); }); test('it does NOT render the badge when type is `source`, but both sourceIp and sourcePort are undefined', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx index 4ebb804eab8a4..8b3f0bfdb107a 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx @@ -51,7 +51,7 @@ describe('CertificateFingerprint', () => { removeExternalLinkText( wrapper.find('[data-test-subj="certificate-fingerprint-link"]').first().text() ) - ).toEqual('3f4c57934e089f02ae7511200aee2d7e7aabd272'); + ).toContain('3f4c57934e089f02ae7511200aee2d7e7aabd272'); }); test('it renders a hyperlink to an external site to compare the fingerprint against a known set of signatures', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx index 31f2fec942490..ddbba7f2bc9f3 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx @@ -48,7 +48,7 @@ describe('Ja3Fingerprint', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="ja3-fingerprint-link"]').first().text()) - ).toEqual('fff799d91b7c01ae3fe6787cfc895552'); + ).toContain('fff799d91b7c01ae3fe6787cfc895552'); }); test('it renders a hyperlink to an external site to compare the fingerprint against a known set of signatures', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx index 8a88a7182af03..9ccabf2f47d44 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx @@ -204,7 +204,7 @@ describe('Netflow', () => { removeExternalLinkText( wrapper.find('[data-test-subj="destination-ip-and-port"]').first().text() ) - ).toEqual('10.1.2.3:80'); + ).toContain('10.1.2.3:80'); }); test('it renders destination.packets', () => { @@ -340,7 +340,7 @@ describe('Netflow', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="source-ip-and-port"]').first().text()) - ).toEqual('192.168.1.2:9987'); + ).toContain('192.168.1.2:9987'); }); test('it renders source.packets', () => { @@ -374,7 +374,7 @@ describe('Netflow', () => { .first() .text() ) - ).toEqual('tls.client_certificate.fingerprint.sha1-value'); + ).toContain('tls.client_certificate.fingerprint.sha1-value'); }); test('it hyperlinks tls.fingerprints.ja3.hash site to compare the fingerprint against a known set of signatures', () => { @@ -390,7 +390,7 @@ describe('Netflow', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="ja3-fingerprint-link"]').first().text()) - ).toEqual('tls.fingerprints.ja3.hash-value'); + ).toContain('tls.fingerprints.ja3.hash-value'); }); test('it hyperlinks tls.server_certificate.fingerprint.sha1 site to compare the fingerprint against a known set of signatures', () => { @@ -418,7 +418,7 @@ describe('Netflow', () => { .first() .text() ) - ).toEqual('tls.server_certificate.fingerprint.sha1-value'); + ).toContain('tls.server_certificate.fingerprint.sha1-value'); }); test('it renders network.transport', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap index 6ea24e5ca57f6..ebb807a590124 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap @@ -2686,11 +2686,12 @@ exports[`Details Panel Component DetailsPanel:NetworkDetails: rendering it shoul type="popout" > + > + External link + { + return str.replaceAll('External link', ''); +}; + jest.mock('../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -90,7 +96,7 @@ describe('get_column_renderer', () => { {row} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); @@ -109,7 +115,7 @@ describe('get_column_renderer', () => { {row} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); @@ -128,7 +134,7 @@ describe('get_column_renderer', () => { {row} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx index 2d06c040c5b00..f8693d4a4f8ea 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx @@ -53,7 +53,11 @@ describe('SuricataDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + const removeEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(removeEuiIconText).toEqual( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx index 61ea659964e4d..2022904e548aa 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx @@ -72,7 +72,12 @@ describe('suricata_row_renderer', () => { {children} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + + const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(extractEuiIconText).toContain( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx index ae2caa8ce8401..4b93c5accb590 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx @@ -83,6 +83,12 @@ import { import * as i18n from './translations'; import { RowRenderer } from '../../../../../../../common/types'; +// EuiIcons coming from .testenv render the icon's aria-label as a span +// extractEuiIcon removes the aria-label before checking for equality +const extractEuiIconText = (str: string) => { + return str.replaceAll('External link', ''); +}; + jest.mock('../../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -1130,7 +1136,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'NETWORK SERVICE\\NT AUTHORITY@windows-endpoint-1accepted a connection viasvchost.exe(328)with resultsuccessEndpoint network eventincomingtcpSource10.1.2.3:64557North AmericaUnited States🇺🇸USNorth CarolinaConcordDestination10.50.60.70:3389' ); }); @@ -1214,7 +1220,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'NETWORK SERVICE\\NT AUTHORITY@win2019-endpoint-1made a http request viasvchost.exe(2232)Endpoint network eventoutgoinghttptcpSource10.1.2.3:51570Destination10.11.12.13:80North AmericaUnited States🇺🇸USArizonaPhoenix' ); }); @@ -1243,7 +1249,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'SYSTEM\\NT AUTHORITY@HD-gqf-0af7b4feaccepted a connection viaAmSvc.exe(1084)tcp1:network-community_idSource127.0.0.1:49306Destination127.0.0.1:49305' ); }); @@ -1272,7 +1278,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'SYSTEM\\NT AUTHORITY@HD-55b-3ec87f66accepted a connection via(4)tcp1:network-community_idSource::1:51324Destination::1:5357' ); }); @@ -1298,7 +1304,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'NETWORK SERVICE\\NT AUTHORITY@windows-endpoint-1disconnected viasvchost.exe(328)Endpoint network eventincomingtcpSource10.20.30.40:64557North AmericaUnited States🇺🇸USNorth CarolinaConcord(42.47%)1.2KB(57.53%)1.6KBDestination10.11.12.13:3389' ); }); @@ -1327,7 +1333,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'Arun\\Anvi-Acer@HD-obe-8bf77f54disconnected viachrome.exe(11620)8.1KBtcp1:LxYHJJv98b2O0fNccXu6HheXmwk=Source192.168.0.6:59356(25.78%)2.1KB(74.22%)6KBDestination10.156.162.53:443' ); }); @@ -1356,7 +1362,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'SYSTEM\\NT AUTHORITY@HD-55b-3ec87f66disconnected via(4)7.9KBtcp1:ZylzQhsB1dcptA2t4DY8S6l9o8E=Source::1:51338(96.92%)7.7KB(3.08%)249BDestination::1:2869' ); }); @@ -1385,7 +1391,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'root@foohostopened a socket withgoogle_accounts(2166)Outbound socket (10.4.20.1:59554 -> 10.1.2.3:80) Ooutboundtcp1:network-community_idSource10.4.20.1:59554Destination10.1.2.3:80' ); }); @@ -1414,7 +1420,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'root@foohostclosed a socket withgoogle_accounts(2166)Outbound socket (10.4.20.1:59508 -> 10.1.2.3:80) Coutboundtcp1:network-community_idSource10.4.20.1:59508Destination10.1.2.3:80' ); }); @@ -1722,7 +1728,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'iot.example.comasked forlookup.example.comwith question typeA, which resolved to10.1.2.3(response code:NOERROR)viaan unknown process6.937500msOct 8, 2019 @ 10:05:23.241Oct 8, 2019 @ 10:05:23.248outbounddns177Budp1:network-community_idSource10.9.9.9:58732(22.60%)40B(77.40%)137BDestination10.1.1.1:53OceaniaAustralia🇦🇺AU' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx index 62836cbffb2b5..9af22fca0c707 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx @@ -14,6 +14,12 @@ import { mockTimelineData, TestProviders } from '../../../../../../common/mock'; import { useMountAppended } from '../../../../../../common/utils/use_mount_appended'; import { ZeekDetails } from './zeek_details'; +// EuiIcons coming from .testenv render the icon's aria-label as a span +// extractEuiIcon removes the aria-label before checking for equality +const extractEuiIconText = (str: string) => { + return str.replaceAll('External link', ''); +}; + jest.mock('../../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -53,7 +59,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); @@ -68,7 +74,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'CyIrMA1L1JtLqdIuoldnsudpSource206.189.35.240:57475Destination67.207.67.3:53' ); }); @@ -83,7 +89,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'CZLkpC22NquQJOpkwehttp302Source206.189.35.240:36220Destination192.241.164.26:80' ); }); @@ -98,7 +104,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'noticeDropped:falseScan::Port_Scan8.42.77.171 scanned at least 15 unique ports of host 207.154.238.205 in 0m0sSource8.42.77.171' ); }); @@ -113,7 +119,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'CmTxzt2OVXZLkGDaResslTLSv12TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256Source188.166.66.184:34514Destination91.189.95.15:443' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx index b60a2965bfd70..fda83c0ade12b 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx @@ -71,7 +71,12 @@ describe('zeek_row_renderer', () => { {children} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + + const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(extractEuiIconText).toContain( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx index 3f27b80359131..726716c7f53ab 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx @@ -101,7 +101,11 @@ describe('ZeekSignature', () => { test('should render value', () => { const wrapper = mount(); - expect(removeExternalLinkText(wrapper.text())).toEqual('abc'); + const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(extractEuiIconText).toEqual('abc'); }); test('should render value and link', () => { diff --git a/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts b/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts index 60fe9d2bd7128..a99a6fdb81167 100644 --- a/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts +++ b/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts @@ -769,7 +769,7 @@ describe('', () => { const stateMessage = find('snapshotDetail.state.value').text(); try { - expect(stateMessage).toBe(expectedMessage); + expect(stateMessage).toContain(expectedMessage); // Messages may include the word "Info" to account for the rendered text coming from EuiIcon } catch { throw new Error( `Expected snapshot state message "${expectedMessage}" for state "${state}, but got "${stateMessage}".` diff --git a/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx b/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx index 5ac75f92ea45f..f3846cd784ccc 100644 --- a/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx +++ b/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx @@ -110,7 +110,7 @@ describe('Modal Inspect', () => { expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="index-pattern-title"]').text() - ).toBe('Index pattern '); + ).toContain('Index pattern '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="index-pattern-description"]') @@ -118,7 +118,7 @@ describe('Modal Inspect', () => { ).toBe('auditbeat-*, filebeat-*, packetbeat-*, winlogbeat-*'); expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="query-time-title"]').text() - ).toBe('Query time '); + ).toContain('Query time '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="query-time-description"]') @@ -128,7 +128,7 @@ describe('Modal Inspect', () => { wrapper .find('.euiDescriptionList__title span[data-test-subj="request-timestamp-title"]') .text() - ).toBe('Request timestamp '); + ).toContain('Request timestamp '); }); test('Click on request Tab', () => { diff --git a/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx index d23f1cfacf94b..6942a7708db78 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx @@ -107,10 +107,12 @@ describe('health check', () => { const [action] = queryAllByText(/Learn more/i); expect(description.textContent).toMatchInlineSnapshot( - `"You must enable API keys to use Alerting. Learn more.(opens in a new tab or window)"` + `"You must enable API keys to use Alerting. Learn more.External link(opens in a new tab or window)"` ); - expect(action.textContent).toMatchInlineSnapshot(`"Learn more.(opens in a new tab or window)"`); + expect(action.textContent).toMatchInlineSnapshot( + `"Learn more.External link(opens in a new tab or window)"` + ); expect(action.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/elasticsearch/reference/mocked-test-branch/security-settings.html#api-key-service-settings"` @@ -141,12 +143,12 @@ describe('health check', () => { const description = queryByRole(/banner/i); expect(description!.textContent).toMatchInlineSnapshot( - `"You must configure an encryption key to use Alerting. Learn more.(opens in a new tab or window)"` + `"You must configure an encryption key to use Alerting. Learn more.External link(opens in a new tab or window)"` ); const action = queryByText(/Learn/i); expect(action!.textContent).toMatchInlineSnapshot( - `"Learn more.(opens in a new tab or window)"` + `"Learn more.External link(opens in a new tab or window)"` ); expect(action!.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/kibana/mocked-test-branch/alert-action-settings-kb.html#general-alert-action-settings"` @@ -179,12 +181,12 @@ describe('health check', () => { const description = queryByText(/You must enable/i); expect(description!.textContent).toMatchInlineSnapshot( - `"You must enable API keys and configure an encryption key to use Alerting. Learn more.(opens in a new tab or window)"` + `"You must enable API keys and configure an encryption key to use Alerting. Learn more.External link(opens in a new tab or window)"` ); const action = queryByText(/Learn/i); expect(action!.textContent).toMatchInlineSnapshot( - `"Learn more.(opens in a new tab or window)"` + `"Learn more.External link(opens in a new tab or window)"` ); expect(action!.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/kibana/mocked-test-branch/alerting-setup.html#alerting-prerequisites"` diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx index 737501f444300..e7cafb23ee0fa 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx @@ -373,9 +373,12 @@ describe('execution duration overview', () => { const avgExecutionDurationPanel = wrapper.find('[data-test-subj="avgExecutionDurationPanel"]'); expect(avgExecutionDurationPanel.exists()).toBeTruthy(); expect(avgExecutionDurationPanel.first().prop('color')).toEqual('warning'); - expect(wrapper.find('EuiStat[data-test-subj="avgExecutionDurationStat"]').text()).toEqual( - 'Average duration16:44:44.345' - ); + + const avgExecutionDurationStat = wrapper + .find('EuiStat[data-test-subj="avgExecutionDurationStat"]') + .text() + .replaceAll('Info', ''); + expect(avgExecutionDurationStat).toEqual('Average duration16:44:44.345'); expect(wrapper.find('[data-test-subj="ruleDurationWarning"]').exists()).toBeTruthy(); }); diff --git a/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx b/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx index ee485f8aee0c0..3576d7e34fd0b 100644 --- a/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx +++ b/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx @@ -63,5 +63,5 @@ test('Can delete drilldowns', () => { test('Error is displayed', () => { const screen = render(); - expect(screen.getByLabelText('an error')).toBeInTheDocument(); + expect(screen.getByText('an error')).toBeInTheDocument(); }); diff --git a/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap b/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap index 51753d2ce8bb3..bf25513a6bc2c 100644 --- a/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap +++ b/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap @@ -179,10 +179,11 @@ exports[`PingListExpandedRow renders link to docs if body is not recorded but it > docs + > + External link + diff --git a/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap b/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap index 80b751d8e243b..29d1ba922de8f 100644 --- a/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap +++ b/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap @@ -72,10 +72,11 @@ Array [ > Set tags + > + External link + diff --git a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx index 63b4d2945a51c..671371093c819 100644 --- a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx @@ -11,7 +11,7 @@ import { render } from '../../../../../lib/helper/rtl_helpers'; describe('NetworkRequestsTotal', () => { it('message in case total is greater than fetched', () => { - const { getByText, getByLabelText } = render( + const { getByText } = render( { ); expect(getByText('First 1000/1100 network requests')).toBeInTheDocument(); - expect(getByLabelText('Info')).toBeInTheDocument(); + expect(getByText('Info')).toBeInTheDocument(); }); it('message in case total is equal to fetched requests', () => { diff --git a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx index 7558a82e45df4..4241a7238ecd6 100644 --- a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx @@ -13,8 +13,8 @@ import { TestWrapper } from './waterfall_marker_test_helper'; describe('', () => { it('renders a dot icon when `field` is an empty string', () => { - const { getByLabelText } = render(); - expect(getByLabelText('An icon indicating that this marker has no field associated with it')); + const { getByText } = render(); + expect(getByText('An icon indicating that this marker has no field associated with it')); }); it('renders an embeddable when opened', async () => { diff --git a/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx b/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx index 2b899aad783d7..d232b12f3a47b 100644 --- a/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx +++ b/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx @@ -45,20 +45,22 @@ describe('KeyUXMetrics', () => { }; }; + // Tests include the word "info" between the task and time to account for the rendered text coming from + // the EuiIcon (tooltip) embedded within each stat description expect( - getAllByText(checkText('Longest long task duration271 ms'))[0] + getAllByText(checkText('Longest long task durationInfo271 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('Total long tasks duration520 ms'))[0] + getAllByText(checkText('Total long tasks durationInfo520 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('No. of long tasks3'))[0] + getAllByText(checkText('No. of long tasksInfo3'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('Total blocking time271 ms'))[0] + getAllByText(checkText('Total blocking timeInfo271 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('First contentful paint1.27 s'))[0] + getAllByText(checkText('First contentful paintInfo1.27 s'))[0] ).toBeInTheDocument(); }); }); diff --git a/yarn.lock b/yarn.lock index 0b6f13bc96b94..d78a3567a18c0 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1516,10 +1516,10 @@ resolved "https://registry.yarnpkg.com/@elastic/eslint-plugin-eui/-/eslint-plugin-eui-0.0.2.tgz#56b9ef03984a05cc213772ae3713ea8ef47b0314" integrity sha512-IoxURM5zraoQ7C8f+mJb9HYSENiZGgRVcG4tLQxE61yHNNRDXtGDWTZh8N1KIHcsqN1CEPETjuzBXkJYF/fDiQ== -"@elastic/eui@51.1.0": - version "51.1.0" - resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-51.1.0.tgz#338b710ae7a819bb7c3b8e1916080610e0b8e691" - integrity sha512-pjbBSkfDPAjXBRCMk4zsyZ3sPpf70XVcbOzr4BzT0MW38uKjEgEh6nu1aCdnOi+jVSHRtziJkX9rD8BRDWfsnw== +"@elastic/eui@52.2.0": + version "52.2.0" + resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-52.2.0.tgz#761101a29b96a4b5270ef93541dab7bb27f5ca50" + integrity sha512-XboYerntCOTHWHYMWJGzJtu5JYO6pk5IWh0ZHJEQ4SEjmLbTV2bFrVBTO/8uaU7GhV9/RNIo7BU5wHRyYP7z1g== dependencies: "@types/chroma-js" "^2.0.0" "@types/lodash" "^4.14.160" From 865f7fc1e121e8a21483c93e4941b076507ed0a6 Mon Sep 17 00:00:00 2001 From: Maja Grubic Date: Tue, 29 Mar 2022 22:41:00 +0200 Subject: [PATCH 126/160] [SharedUX] Add url-loader to BAZEL.build (#128650) * [SharedUX] Fix url path * Add url-loader as bazel dependency --- packages/kbn-shared-ux-components/BUILD.bazel | 2 ++ .../src/solution_avatar/solution_avatar.scss | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/packages/kbn-shared-ux-components/BUILD.bazel b/packages/kbn-shared-ux-components/BUILD.bazel index 16dfe9e0620e1..d2ce1a7d2e0f6 100644 --- a/packages/kbn-shared-ux-components/BUILD.bazel +++ b/packages/kbn-shared-ux-components/BUILD.bazel @@ -11,6 +11,7 @@ SOURCE_FILES = glob( "src/**/*.tsx", "src/**/*.scss", "src/**/*.mdx", + "src/**/*.svg", ], exclude = [ "**/*.test.*", @@ -50,6 +51,7 @@ RUNTIME_DEPS = [ "@npm//classnames", "@npm//react-use", "@npm//react", + "@npm//url-loader", ] # In this array place dependencies necessary to build the types, which will include the diff --git a/packages/kbn-shared-ux-components/src/solution_avatar/solution_avatar.scss b/packages/kbn-shared-ux-components/src/solution_avatar/solution_avatar.scss index 3064ef0a04a67..1402f272a15cf 100644 --- a/packages/kbn-shared-ux-components/src/solution_avatar/solution_avatar.scss +++ b/packages/kbn-shared-ux-components/src/solution_avatar/solution_avatar.scss @@ -7,7 +7,7 @@ line-height: 100px; border-radius: 100px; display: inline-block; - background: $euiColorEmptyShade url('/assets/texture.svg') no-repeat; + background: $euiColorEmptyShade url('assets/texture.svg') no-repeat; background-size: cover, 125%; text-align: center; } From 02a146f7e4fd069c51d964da37460d63d980e829 Mon Sep 17 00:00:00 2001 From: Dmitrii Shevchenko Date: Tue, 29 Mar 2022 22:46:39 +0200 Subject: [PATCH 127/160] Add a tour showing new rules search capabilities (#128759) --- .../security_solution/common/constants.ts | 2 +- .../detection_engine/rules/api.test.ts | 6 +- .../detection_engine/rules/utils.test.ts | 6 +- .../detection_engine/rules/utils.ts | 2 + .../rules_feature_tour_context.tsx | 74 +++++----- .../rules/all/feature_tour/translations.ts | 15 ++ .../detection_engine/rules/all/index.test.tsx | 7 +- .../rules_table_filters.test.tsx | 9 +- .../rules_table_filters.tsx | 32 +++-- .../pages/detection_engine/rules/index.tsx | 135 +++++++++--------- .../detection_engine/rules/translations.ts | 3 +- 11 files changed, 164 insertions(+), 127 deletions(-) diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index 591c7d68e17cb..f7bdc889f9c33 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -443,7 +443,7 @@ export const RULES_TABLE_PAGE_SIZE_OPTIONS = [5, 10, 20, 50, RULES_TABLE_MAX_PAG * we will need to update this constant with the corresponding version. */ export const RULES_MANAGEMENT_FEATURE_TOUR_STORAGE_KEY = - 'securitySolution.rulesManagementPage.newFeaturesTour.v8.1'; + 'securitySolution.rulesManagementPage.newFeaturesTour.v8.2'; export const RULE_DETAILS_EXECUTION_LOG_TABLE_SHOW_METRIC_COLUMNS_STORAGE_KEY = 'securitySolution.ruleDetails.ruleExecutionLog.showMetrics.v8.2'; diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts index c8d8b5bb6ffd0..3c534ca7294a5 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts @@ -143,7 +143,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - '(alert.attributes.name: "hello world" OR alert.attributes.params.index: "hello world" OR alert.attributes.params.threat.tactic.id: "hello world" OR alert.attributes.params.threat.tactic.name: "hello world" OR alert.attributes.params.threat.technique.id: "hello world" OR alert.attributes.params.threat.technique.name: "hello world")', + '(alert.attributes.name: "hello world" OR alert.attributes.params.index: "hello world" OR alert.attributes.params.threat.tactic.id: "hello world" OR alert.attributes.params.threat.tactic.name: "hello world" OR alert.attributes.params.threat.technique.id: "hello world" OR alert.attributes.params.threat.technique.name: "hello world" OR alert.attributes.params.threat.technique.subtechnique.id: "hello world" OR alert.attributes.params.threat.technique.subtechnique.name: "hello world")', page: 1, per_page: 20, sort_field: 'enabled', @@ -172,7 +172,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - '(alert.attributes.name: "\\" OR (foo:bar)" OR alert.attributes.params.index: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo:bar)")', + '(alert.attributes.name: "\\" OR (foo:bar)" OR alert.attributes.params.index: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.subtechnique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.subtechnique.name: "\\" OR (foo:bar)")', page: 1, per_page: 20, sort_field: 'enabled', @@ -383,7 +383,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - 'alert.attributes.tags: "__internal_immutable:false" AND alert.attributes.tags: "__internal_immutable:true" AND alert.attributes.tags:("hello" AND "world") AND (alert.attributes.name: "ruleName" OR alert.attributes.params.index: "ruleName" OR alert.attributes.params.threat.tactic.id: "ruleName" OR alert.attributes.params.threat.tactic.name: "ruleName" OR alert.attributes.params.threat.technique.id: "ruleName" OR alert.attributes.params.threat.technique.name: "ruleName")', + 'alert.attributes.tags: "__internal_immutable:false" AND alert.attributes.tags: "__internal_immutable:true" AND alert.attributes.tags:("hello" AND "world") AND (alert.attributes.name: "ruleName" OR alert.attributes.params.index: "ruleName" OR alert.attributes.params.threat.tactic.id: "ruleName" OR alert.attributes.params.threat.tactic.name: "ruleName" OR alert.attributes.params.threat.technique.id: "ruleName" OR alert.attributes.params.threat.technique.name: "ruleName" OR alert.attributes.params.threat.technique.subtechnique.id: "ruleName" OR alert.attributes.params.threat.technique.subtechnique.name: "ruleName")', page: 1, per_page: 20, sort_field: 'enabled', diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts index e3d2300972a51..a26a4aec3ec02 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts @@ -27,7 +27,7 @@ describe('convertRulesFilterToKQL', () => { const kql = convertRulesFilterToKQL({ ...filterOptions, filter: 'foo' }); expect(kql).toBe( - '(alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo")' + '(alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo" OR alert.attributes.params.threat.technique.subtechnique.id: "foo" OR alert.attributes.params.threat.technique.subtechnique.name: "foo")' ); }); @@ -35,7 +35,7 @@ describe('convertRulesFilterToKQL', () => { const kql = convertRulesFilterToKQL({ ...filterOptions, filter: '" OR (foo: bar)' }); expect(kql).toBe( - '(alert.attributes.name: "\\" OR (foo: bar)" OR alert.attributes.params.index: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo: bar)")' + '(alert.attributes.name: "\\" OR (foo: bar)" OR alert.attributes.params.index: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.subtechnique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.subtechnique.name: "\\" OR (foo: bar)")' ); }); @@ -66,7 +66,7 @@ describe('convertRulesFilterToKQL', () => { }); expect(kql).toBe( - `alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true" AND alert.attributes.tags:(\"tag1\" AND \"tag2\") AND (alert.attributes.name: \"foo\" OR alert.attributes.params.index: \"foo\" OR alert.attributes.params.threat.tactic.id: \"foo\" OR alert.attributes.params.threat.tactic.name: \"foo\" OR alert.attributes.params.threat.technique.id: \"foo\" OR alert.attributes.params.threat.technique.name: \"foo\")` + `alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true" AND alert.attributes.tags:("tag1" AND "tag2") AND (alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo" OR alert.attributes.params.threat.technique.subtechnique.id: "foo" OR alert.attributes.params.threat.technique.subtechnique.name: "foo")` ); }); }); diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts index f5e52fd6362c1..069746223731c 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts @@ -16,6 +16,8 @@ const SEARCHABLE_RULE_PARAMS = [ 'alert.attributes.params.threat.tactic.name', 'alert.attributes.params.threat.technique.id', 'alert.attributes.params.threat.technique.name', + 'alert.attributes.params.threat.technique.subtechnique.id', + 'alert.attributes.params.threat.technique.subtechnique.name', ]; /** diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx index aaa483e49fca7..b0f0b0f17923c 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx @@ -43,23 +43,13 @@ const tourConfig: EuiTourState = { const stepsConfig: EuiStatelessTourStep[] = [ { step: 1, - title: 'A new feature', - content:

{'This feature allows for...'}

, - stepsTotal: 2, + title: i18n.SEARCH_CAPABILITIES_TITLE, + content:

{i18n.SEARCH_CAPABILITIES_DESCRIPTION}

, + stepsTotal: 1, children: <>, onFinish: noop, maxWidth: TOUR_POPOVER_WIDTH, }, - { - step: 2, - title: 'Another feature', - content:

{'This another feature allows for...'}

, - stepsTotal: 2, - children: <>, - onFinish: noop, - anchorPosition: 'rightUp', - maxWidth: TOUR_POPOVER_WIDTH, - }, ]; const RulesFeatureTourContext = createContext(null); @@ -82,39 +72,43 @@ export const RulesFeatureTourContextProvider: FC = ({ children }) => { const [tourSteps, tourActions, tourState] = useEuiTour(stepsConfig, restoredState); - const enhancedSteps = useMemo(() => { - return tourSteps.map((item, index, array) => { - return { + const enhancedSteps = useMemo( + () => + tourSteps.map((item, index) => ({ ...item, content: ( <> {item.content} - - - - - - - - - + {tourSteps.length > 1 && ( + <> + + + + + + + + + + + )} ), - }; - }); - }, [tourSteps, tourActions]); + })), + [tourSteps, tourActions] + ); const providerValue = useMemo( () => ({ steps: enhancedSteps, actions: tourActions }), diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts index bfcda64bb13dd..88b5489b01eaa 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts @@ -13,3 +13,18 @@ export const TOUR_TITLE = i18n.translate( defaultMessage: "What's new", } ); + +export const SEARCH_CAPABILITIES_TITLE = i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.featureTour.searchCapabilitiesTitle', + { + defaultMessage: 'Enhanced search capabilities', + } +); + +export const SEARCH_CAPABILITIES_DESCRIPTION = i18n.translate( + 'xpack.securitySolution.detectionEngine.rules.allRules.featureTour.searchCapabilitiesDescription', + { + defaultMessage: + 'It is now possible to search rules by index patterns, like "filebeat-*", or by MITRE ATT&CK™ tactics or techniques, like "Defense Evasion" or "TA0005".', + } +); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx index 3b24dda539174..8e44475a7992e 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx @@ -12,6 +12,7 @@ import { useKibana } from '../../../../../common/lib/kibana'; import { TestProviders } from '../../../../../common/mock'; import '../../../../../common/mock/formatted_relative'; import '../../../../../common/mock/match_media'; +import { RulesFeatureTourContextProvider } from './feature_tour/rules_feature_tour_context'; import { AllRules } from './index'; jest.mock('../../../../../common/components/link_to'); @@ -67,7 +68,8 @@ describe('AllRules', () => { rulesNotInstalled={0} rulesNotUpdated={0} /> - + , + { wrappingComponent: RulesFeatureTourContextProvider } ); await waitFor(() => { @@ -90,7 +92,8 @@ describe('AllRules', () => { rulesNotInstalled={0} rulesNotUpdated={0} /> - + , + { wrappingComponent: RulesFeatureTourContextProvider } ); await waitFor(() => { diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx index 816ffdfa9dad6..88b8e952d215a 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx @@ -10,13 +10,16 @@ import { mount } from 'enzyme'; import { RulesTableFilters } from './rules_table_filters'; import { TestProviders } from '../../../../../../common/mock'; +import { RulesFeatureTourContextProvider } from '../feature_tour/rules_feature_tour_context'; jest.mock('../rules_table/rules_table_context'); describe('RulesTableFilters', () => { it('renders no numbers next to rule type button filter if none exist', async () => { const wrapper = mount( - , + + + , { wrappingComponent: TestProviders } ); @@ -30,7 +33,9 @@ describe('RulesTableFilters', () => { it('renders number of custom and prepackaged rules', async () => { const wrapper = mount( - , + + + , { wrappingComponent: TestProviders } ); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx index b4c81ae5a177d..7e3263f6bb26a 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx @@ -11,11 +11,13 @@ import { EuiFilterGroup, EuiFlexGroup, EuiFlexItem, + EuiTourStep, } from '@elastic/eui'; import { isEqual } from 'lodash/fp'; import React, { useCallback } from 'react'; import styled from 'styled-components'; import * as i18n from '../../translations'; +import { useRulesFeatureTourContext } from '../feature_tour/rules_feature_tour_context'; import { useRulesTableContext } from '../rules_table/rules_table_context'; import { TagsFilterPopover } from './tags_filter_popover'; @@ -23,6 +25,14 @@ const FilterWrapper = styled(EuiFlexGroup)` margin-bottom: ${({ theme }) => theme.eui.euiSizeXS}; `; +const SearchBarWrapper = styled(EuiFlexItem)` + & .euiPopover__anchor { + // This is needed to "cancel" styles passed down from EuiTourStep that + // interfere with EuiFieldSearch and don't allow it to take the full width + display: block; + } +`; + interface RulesTableFiltersProps { rulesCustomInstalled: number | null; rulesInstalled: number | null; @@ -45,6 +55,8 @@ const RulesTableFiltersComponent = ({ const { showCustomRules, showElasticRules, tags: selectedTags } = filterOptions; + const { steps } = useRulesFeatureTourContext(); + const handleOnSearch = useCallback( (filterString) => setFilterOptions({ filter: filterString.trim() }), [setFilterOptions] @@ -69,15 +81,17 @@ const RulesTableFiltersComponent = ({ return ( - - - + + + + + { const [isImportModalVisible, showImportModal, hideImportModal] = useBoolState(); @@ -177,77 +178,79 @@ const RulesPageComponent: React.FC = () => { showCheckBox /> - - - - - {loadPrebuiltRulesAndTemplatesButton && ( - {loadPrebuiltRulesAndTemplatesButton} - )} - {reloadPrebuiltRulesAndTemplatesButton && ( - {reloadPrebuiltRulesAndTemplatesButton} - )} - - + + + + + + {loadPrebuiltRulesAndTemplatesButton && ( + {loadPrebuiltRulesAndTemplatesButton} + )} + {reloadPrebuiltRulesAndTemplatesButton && ( + {reloadPrebuiltRulesAndTemplatesButton} + )} + + + + {i18n.UPLOAD_VALUE_LISTS} + + + + - {i18n.UPLOAD_VALUE_LISTS} + {i18n.IMPORT_RULE} - - - - - {i18n.IMPORT_RULE} - - - - - {i18n.ADD_NEW_RULE} - - - - - {(prePackagedRuleStatus === 'ruleNeedUpdate' || - prePackagedTimelineStatus === 'timelineNeedUpdate') && ( - + + + {i18n.ADD_NEW_RULE} + + + + + {(prePackagedRuleStatus === 'ruleNeedUpdate' || + prePackagedTimelineStatus === 'timelineNeedUpdate') && ( + + )} + - )} - - - + + + diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts index f99ebc2c72c26..09949cc5c1a09 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts @@ -408,7 +408,8 @@ export const SEARCH_RULES = i18n.translate( export const SEARCH_PLACEHOLDER = i18n.translate( 'xpack.securitySolution.detectionEngine.rules.allRules.searchPlaceholder', { - defaultMessage: 'Search by rule name, index pattern, or MITRE ATT&CK tactic or technique', + defaultMessage: + 'Rule name, index pattern (e.g., "filebeat-*"), or MITRE ATT&CK™ tactic or technique (e.g., "Defense Evasion" or "TA0005")', } ); From fefb24b7170358b9772d1009926cf4ab3b05a8b3 Mon Sep 17 00:00:00 2001 From: Andrew Tate Date: Tue, 29 Mar 2022 16:05:57 -0500 Subject: [PATCH 128/160] [Lens] Disable auto apply design updates (#128412) --- .../lens/public/app_plugin/app.test.tsx | 3 +- x-pack/plugins/lens/public/app_plugin/app.tsx | 2 + .../lens/public/app_plugin/lens_top_nav.tsx | 25 +++ .../lens/public/app_plugin/mounter.tsx | 1 + .../lens/public/app_plugin/settings_menu.tsx | 108 +++++++++++ .../plugins/lens/public/app_plugin/types.ts | 5 + .../lens/public/assets/render_dark@2x.png | Bin 0 -> 10732 bytes .../lens/public/assets/render_light@2x.png | Bin 0 -> 10795 bytes .../editor_frame/suggestion_panel.scss | 8 + .../editor_frame/suggestion_panel.test.tsx | 2 +- .../editor_frame/suggestion_panel.tsx | 63 +++---- .../geo_field_workspace_panel.tsx | 2 +- .../workspace_panel/workspace_panel.test.tsx | 103 ++++++++--- .../workspace_panel/workspace_panel.tsx | 138 ++++++++++---- .../workspace_panel_wrapper.scss | 26 ++- .../workspace_panel_wrapper.test.tsx | 38 +--- .../workspace_panel_wrapper.tsx | 175 +++++++----------- .../apps/lens/disable_auto_apply.ts | 18 +- .../test/functional/apps/lens/smokescreen.ts | 2 +- .../test/functional/page_objects/lens_page.ts | 56 ++++-- 20 files changed, 510 insertions(+), 265 deletions(-) create mode 100644 x-pack/plugins/lens/public/app_plugin/settings_menu.tsx create mode 100644 x-pack/plugins/lens/public/assets/render_dark@2x.png create mode 100644 x-pack/plugins/lens/public/assets/render_light@2x.png diff --git a/x-pack/plugins/lens/public/app_plugin/app.test.tsx b/x-pack/plugins/lens/public/app_plugin/app.test.tsx index e7cdcfe4707cb..f5da098e028f9 100644 --- a/x-pack/plugins/lens/public/app_plugin/app.test.tsx +++ b/x-pack/plugins/lens/public/app_plugin/app.test.tsx @@ -6,7 +6,7 @@ */ import React from 'react'; -import { Subject } from 'rxjs'; +import { Observable, Subject } from 'rxjs'; import { ReactWrapper } from 'enzyme'; import { act } from 'react-dom/test-utils'; import { App } from './app'; @@ -83,6 +83,7 @@ describe('Lens App', () => { datasourceMap, visualizationMap, topNavMenuEntryGenerators: [], + theme$: new Observable(), }; } diff --git a/x-pack/plugins/lens/public/app_plugin/app.tsx b/x-pack/plugins/lens/public/app_plugin/app.tsx index 6312225af579b..19b213815145a 100644 --- a/x-pack/plugins/lens/public/app_plugin/app.tsx +++ b/x-pack/plugins/lens/public/app_plugin/app.tsx @@ -58,6 +58,7 @@ export function App({ contextOriginatingApp, topNavMenuEntryGenerators, initialContext, + theme$, }: LensAppProps) { const lensAppServices = useKibana().services; @@ -402,6 +403,7 @@ export function App({ initialContextIsEmbedded={initialContextIsEmbedded} topNavMenuEntryGenerators={topNavMenuEntryGenerators} initialContext={initialContext} + theme$={theme$} /> {getLegacyUrlConflictCallout()} {(!isLoading || persistedDoc) && ( diff --git a/x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx b/x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx index e30ea0d44aef3..b48b16074c55e 100644 --- a/x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx +++ b/x-pack/plugins/lens/public/app_plugin/lens_top_nav.tsx @@ -8,6 +8,7 @@ import { isEqual } from 'lodash'; import { i18n } from '@kbn/i18n'; import React, { useCallback, useEffect, useMemo, useState } from 'react'; +import { useStore } from 'react-redux'; import { TopNavMenuData } from '../../../../../src/plugins/navigation/public'; import { LensAppServices, @@ -21,6 +22,7 @@ import { tableHasFormulas } from '../../../../../src/plugins/data/common'; import { exporters } from '../../../../../src/plugins/data/public'; import type { DataView } from '../../../../../src/plugins/data_views/public'; import { useKibana } from '../../../../../src/plugins/kibana_react/public'; +import { toggleSettingsMenuOpen } from './settings_menu'; import { setState, useLensSelector, @@ -140,6 +142,17 @@ function getLensTopNavConfig(options: { tooltip: tooltips.showExportWarning, }); + topNavMenu.push({ + label: i18n.translate('xpack.lens.app.settings', { + defaultMessage: 'Settings', + }), + run: actions.openSettings, + testId: 'lnsApp_settingsButton', + description: i18n.translate('xpack.lens.app.settingsAriaLabel', { + defaultMessage: 'Open the Lens settings menu', + }), + }); + if (showCancel) { topNavMenu.push({ label: i18n.translate('xpack.lens.app.cancel', { @@ -200,6 +213,7 @@ export const LensTopNavMenu = ({ initialContextIsEmbedded, topNavMenuEntryGenerators, initialContext, + theme$, }: LensTopNavMenuProps) => { const { data, @@ -233,6 +247,7 @@ export const LensTopNavMenu = ({ visualization, filters, } = useLensSelector((state) => state.lens); + const allLoaded = Object.values(datasourceStates).every(({ isLoading }) => isLoading === false); useEffect(() => { @@ -337,6 +352,8 @@ export const LensTopNavMenu = ({ application.capabilities, ]); + const lensStore = useStore(); + const topNavConfig = useMemo(() => { const baseMenuEntries = getLensTopNavConfig({ showSaveAndReturn: @@ -465,6 +482,12 @@ export const LensTopNavMenu = ({ columns: meta.columns, }); }, + openSettings: (anchorElement: HTMLElement) => + toggleSettingsMenuOpen({ + lensStore, + anchorElement, + theme$, + }), }, }); return [...(additionalMenuEntries || []), ...baseMenuEntries]; @@ -497,6 +520,8 @@ export const LensTopNavMenu = ({ filters, indexPatterns, data.query.timefilter.timefilter, + lensStore, + theme$, ]); const onQuerySubmitWrapped = useCallback( diff --git a/x-pack/plugins/lens/public/app_plugin/mounter.tsx b/x-pack/plugins/lens/public/app_plugin/mounter.tsx index 10337c26f14ef..e1419c8fe96f2 100644 --- a/x-pack/plugins/lens/public/app_plugin/mounter.tsx +++ b/x-pack/plugins/lens/public/app_plugin/mounter.tsx @@ -249,6 +249,7 @@ export async function mountApp( initialContext={initialContext} contextOriginatingApp={historyLocationState?.originatingApp} topNavMenuEntryGenerators={topNavMenuEntryGenerators} + theme$={core.theme.theme$} /> ); diff --git a/x-pack/plugins/lens/public/app_plugin/settings_menu.tsx b/x-pack/plugins/lens/public/app_plugin/settings_menu.tsx new file mode 100644 index 0000000000000..37f4feb5f5520 --- /dev/null +++ b/x-pack/plugins/lens/public/app_plugin/settings_menu.tsx @@ -0,0 +1,108 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useCallback } from 'react'; +import ReactDOM from 'react-dom'; +import type { CoreTheme } from 'kibana/public'; +import { EuiPopoverTitle, EuiSwitch, EuiWrappingPopover } from '@elastic/eui'; +import { Observable } from 'rxjs'; +import { FormattedMessage, I18nProvider } from '@kbn/i18n-react'; +import { i18n } from '@kbn/i18n'; +import { Store } from 'redux'; +import { Provider } from 'react-redux'; +import { Storage } from '../../../../../src/plugins/kibana_utils/public'; +import { KibanaThemeProvider } from '../../../../../src/plugins/kibana_react/public'; +import { + disableAutoApply, + enableAutoApply, + LensAppState, + selectAutoApplyEnabled, + useLensDispatch, + useLensSelector, +} from '../state_management'; +import { trackUiEvent } from '../lens_ui_telemetry'; +import { writeToStorage } from '../settings_storage'; +import { AUTO_APPLY_DISABLED_STORAGE_KEY } from '../editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper'; + +const container = document.createElement('div'); +let isOpen = false; + +function SettingsMenu({ + anchorElement, + onClose, +}: { + anchorElement: HTMLElement; + onClose: () => void; +}) { + const autoApplyEnabled = useLensSelector(selectAutoApplyEnabled); + + const dispatch = useLensDispatch(); + + const toggleAutoApply = useCallback(() => { + trackUiEvent('toggle_autoapply'); + + writeToStorage( + new Storage(localStorage), + AUTO_APPLY_DISABLED_STORAGE_KEY, + String(autoApplyEnabled) + ); + dispatch(autoApplyEnabled ? disableAutoApply() : enableAutoApply()); + }, [dispatch, autoApplyEnabled]); + + return ( + + + + + toggleAutoApply()} + data-test-subj="lnsToggleAutoApply" + /> + + ); +} + +function closeSettingsMenu() { + ReactDOM.unmountComponentAtNode(container); + document.body.removeChild(container); + isOpen = false; +} + +export function toggleSettingsMenuOpen(props: { + lensStore: Store; + anchorElement: HTMLElement; + theme$: Observable; +}) { + if (isOpen) { + closeSettingsMenu(); + return; + } + + isOpen = true; + document.body.appendChild(container); + + const element = ( + + + + + + + + ); + ReactDOM.render(element, container); +} diff --git a/x-pack/plugins/lens/public/app_plugin/types.ts b/x-pack/plugins/lens/public/app_plugin/types.ts index ff6092c42eaa5..1812e7dd8cdb0 100644 --- a/x-pack/plugins/lens/public/app_plugin/types.ts +++ b/x-pack/plugins/lens/public/app_plugin/types.ts @@ -8,11 +8,13 @@ import type { History } from 'history'; import type { OnSaveProps } from 'src/plugins/saved_objects/public'; import { DiscoverStart } from 'src/plugins/discover/public'; +import { Observable } from 'rxjs'; import { SpacesApi } from '../../../spaces/public'; import type { ApplicationStart, AppMountParameters, ChromeStart, + CoreTheme, ExecutionContextStart, HttpStart, IUiSettingsClient, @@ -73,6 +75,7 @@ export interface LensAppProps { initialContext?: VisualizeEditorContext | VisualizeFieldContext; contextOriginatingApp?: string; topNavMenuEntryGenerators: LensTopNavMenuEntryGenerator[]; + theme$: Observable; } export type RunSave = ( @@ -107,6 +110,7 @@ export interface LensTopNavMenuProps { initialContextIsEmbedded?: boolean; topNavMenuEntryGenerators: LensTopNavMenuEntryGenerator[]; initialContext?: VisualizeFieldContext | VisualizeEditorContext; + theme$: Observable; } export interface HistoryLocationState { @@ -157,4 +161,5 @@ export interface LensTopNavActions { cancel: () => void; exportToCSV: () => void; getUnderlyingDataUrl: () => string | undefined; + openSettings: (anchorElement: HTMLElement) => void; } diff --git a/x-pack/plugins/lens/public/assets/render_dark@2x.png b/x-pack/plugins/lens/public/assets/render_dark@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..553fc827c9429eca7a0bc7ffb9ca37af094cd272 GIT binary patch literal 10732 zcmX9^1yCH%)4k(x*TX%*EqKrnEO>B-g9LY%AQ#*5cL}cH4hX?Dxc&Kk z-`4Kz^qbfHx~pbtrfN6(y}BYEHWfAi0KijvC#MAf03rW9n4o8*zDqj@06^h+uc{;e zY$}>0%A3ZhsF-s^4@(xRBny0`M9E zcnq)ybfl4_P+-E$T%+JUm1Wo#b>QFh5j1gC*5{&n0PI@`)BgZm;hX;+v13+9bN5egAK9xf0q%WxNr-{n2OZc| z`T8Bet~q}8mb~~xq~TJu@e&mH3t;~6Qo8EA3*r5G9A{aFo zJaN;F_!l*L=2^8^R9@EpJY(!VwbZo%l%ybG3<6wiqJdKv)`1Pw0b#A6jkxLZ?DcF5 zs9aYIJ)!U$NK#>3tc$ajhH&e9*3*G(PKI^YjsEgzv(uRt7Z=v!@7Z#7H9;+&dNLgS zHQx)eXZpL!-km;Q{Vg@+*~xKnLFV#&{%1dh0RUEzlAMf=@A5(RsPhURp}dgK8+~P9l_P79ncJ%E7HEsFp-L{(<7AQw-Oz>T+c~@)G#IP!k75 zM5O(grp!ALp8js4T!tXh&TK8{v19#^Zrw58ISP`%0Suv#QJqb(*-7C=ae6f2#kZ+9 zS(AJ$l$xigWcG>sTYsY@c(Ut?HOiX(mNRjC!%!R?X5i2&Y0_u;K;HXxbZO&+%Of1r zl*#w#*BZAVn9wq>jUpmHa4v8#?YQI~T!gS*BsNl+E+Hvl@ z#^`qX!7@$eCT1x0lXX@I^SADKWD~2ysTbyM&Vzi2KGhTVDh1d{@(lbEm&Q@Z1$E1S z5EX-&#(pXCPk)H~x9Sp?A5ra$ZPSY+S(N%@#6S22d$MI94R`L~z6bRPkNjg{zLg9evg>KfAQAIp1B29u)hSYIE6To-ttTr*jO(W^v5NOA^tL zbLLsoK5!W4@g!r8sAH}AUt{svuTxv)-!TMZG&Nju!V~aE=+BA_gw+>rycCNO?W2isR zjCW!h@XdJwXTANz3z?ila!bu)%pfBbbbqo|)7$UVFYIQ+#Xdhnu^jdh z5knF#LnoZz#g#KV= z9N1bH&t7#BM_-`rL>~8+TnH^W3#SDuO3Ha0dZO+Jj^p9tPtdMB!47Mw#AUm^x1?AN zDeq6`hJKdjyH=-G9iWmt`4{()X%J>$s~6L_D(SzN3s%J&kDw~=CEyNC`@u@^upuIB zJcQbHE4$Y8PXP~PA(3uwq>H+Y)<=yU6)ssz#;f}ltsE_kkiiY0&ftbXm_z$M7bHxx z-0;`ssi6)>9KXLvUK1@C6j&cyG^PkbS#{C$BcJ&)P+wuMo^KKB+G~qTMkIu(PBy{g zRA+fJN7c=DkNR$SS!ds#DlKIMc|`djQr~J)$nXkv;gOFilXo)ybu(pm`KMW~6h|+C zPaLr(+wV{_ZEHUSQeEzp@{{1hoO$uLM@x*e5$FAadu)TvF+QcpD)ErUJP46?8YT4~ z^U(S>^qX7=@}o0EoZD0c!T;#by}jG?YZ3ak^Icgq`71nC);%!SnCwbzDvh_$q&XSm z(dKatGq!3va}keZ>3dG_)D73K#uWVc?9kX-!5Lqg-nN0^ophFK4>ok#f#UZLu?!R? zT)#2qrC;f*GGTLx$QMe%yD?ojdJCXU*9U`#)DA_e2MuBVZc-;F+f_iqmFK-2ic z=}A?KhDs#oY<+KtQaP3%cnd6#VaMH#rNU*^w>ntsxRk=QB)KNHRf{x%U+Rz-5%@*G z2mz5%ruIq0C{bgBBZ{XiLfj@IBt$Tu9MZms%3=SuDx+(!@PN#h+8>~C3A>1WCj3

8fJe$5qpp47?2=+^l0SB@wfZHQJ460pyNV@sE^A#sKuUETmSeSe43Om=Cma>d^f z`-VAsW`7VCH}BDynX}I#rC}vT&CmOyL}ubY2s=C)>WTnKihRtjqid4~TI&vRiH3LV ze9PFDx$a0TIhBpj#7)DCpsEK8sz|A3R?kDXE3zu$ z2p`0zFJ@1SqveJ5X)%L={wob|u6Xmoa-Cn06A_3^V10>9LV>zU2X!f+z2oT!c6HZ2 z_bfzzYobt7v?q#7&8Y588Zr3h35w*vP+%4 z#HU*ry!!R+q?A3Q|^A2NGBx7vzzQ^Eq;%2-jq^GFhlLJ%i|?CiOLSHmqE zJByT6Nik3hg-qqhTMZP#^yBu*3fNc)wON!wBi-{kF5Ru>-H^f80Py#dS^a zd3dQCtDOvF@o|GC+TIAPn!2p1Wq1uyVXJ2PpWR(SGvIuVA8fedlLS{LvKc$sV-#De zh=j^VoP;lW-q~{1=l^p^>25R zys0Vr5Q~+C0KcQ>Me;%J0f7O(NB?ACbC%_mz2Q}b_Zl;kmm^gYq8aYcPw4CmGZs{V zlxwZbMkA7GQO87R*K%LAk#vvPpSp~sbp<_6oK`kKYqQ*Ca#D*cRpWOVATT>O>vk@* zHA7e4g_OIvWSz8nEZ;JoZt0DF%bqx1# z_L^VH5kDeA3}Sg*_WAkNV3uy%sZ`GW6v=}fW}Jj|T!#UlW$pFeWhxS)MAsP9uvO!v0=$!h+q^9O%KW?3qXn!eDAUjT%J>mV; zn_*=>4^I8XyV|^qi{UVEy%qP9#~3Z3%VR>P6e6 zFv@WqY(83hwJkh`XeY|C#V@3wfnWz@+2=3nnVxAOK0eTM(GMwhRX|P|! zPUpf~*~BqB@ziVZ!Zg5wrl_HoRg(GOFb5?+UnAJk!SVh3G$i_fkV_}@7)McQX#*&( z((t)R;PKj3Q(uH)_5!ew+oDH>XsZW$D)47%p^j0dt_V2mcrpq6HX}MbZmPD(wcZsu zS$GK82F{dNkF8V|%K!5^Ls_~MBe6c)nioecBjZtjp(O2;x1uOFQOei^|VnI}X8@T>Wmq-rI zu-%%_5Rg`-CR95Mt1bUXE5a#87-Go*k+Ek@k|+0JZpxtgp4XZd}kf((bJl-0Qd*}9m`~C?7 zlX;Ugs7Gh-&#=(>hkxJOJIKdE{C{+EMF%4PaCHLFnT$Tjfu}yyHV`tcq8UiN?(aU# z+sGG?gl;a0PLA^DB_&Pa2nCQZwDlJ&yCd{1TEb-2-1ruW8gjsJJCuP@Becm=oLnrI za++YOlo(z>#0S$@neLa75FB*z=Q!L@{gko*;+C@jBk=eja9|HT!R({oYhW9|;F8BU z!$i&(V$Rr31ki>dz7QI**kujx#C_>ecOVj$SHfC!^3 zPA=+rqNfi~tC~$`dd6nvOI=hGCZu+M`197*eX{{YUJ%9wlp>hIFpv_lU^o`+MI2{B zl4T|pR6res8;Xfy;p@$hVh~^TnheQ?do`@R2HV# zw0z9DF-r|9)5f-_CTvclKzZ9(hKe`#wxqR__Lo<cYowC!$JE*w~>E9h9~0T)c^OJ#f7{d;@5Rw}57Xrxf6a4H1599{zpXGF&mM?p?5T5F zsn0cc>t>|AU5%GF7efe6+PK}((!X}fwsI#tZQOsKlF}{5q*$;hpsDg$|H>&mOW;4xILLIJWKp{dOajKW~K=Dt^ zNo?za&u<4;)SOLO(W!%64ZiL7LZTI&gobSwckuz=;5Ya29p3Rk69=^a4L~>{R^cgb zUp%Dl6cwXw9nTeQ-hl$!rE(y}7*KEFW6&hN^&Du(a zV-|3~vfB959`AkuP)AuCdCiuOzAb2na=>$#(+n^e4Yw-5U+nnIIGM#7&{d~u95g^l zvKkv@2b3WA$B9(H0-5)9)A`rgF>g1C0cucLzFfW$RkR^e!*4uMk#*vRj>5yRopVoY z5`gH#v}17~aGTJsa9QSHs^PEd1MHu{x#7l?{(}ADhugp78tKuL; znl}c;g>YAU@&D??;ExvF#J=x1ZtK&c+4()gszHx843*&#B{79~mqT}rrv!S^&Dpvd zX)8X7e~H4S=nG&$wT`CIh5MSmY0aau#}AC$ld=WGjWX-lDc>=@?Sp5AGs5y z11z9!PfGF1CqQgJ-%mzAO9e-8TDtmB%`YCUbwS3}a3P3HJn9U7L>!hp^L=X$ zr~neIEI;3+eBoQ$A`Zkb*`-H~`(kI{-gdWhj4HtgqDTzWRCN^0zt4j@$wE(6Q?)Y!X&CY?(UC4_u-ulPHt3~8={!$m*ET?L0HmJ=GIw( zW@iIX^w}@BsM!X!QSw}L*fGWClcUxipX?e_HyoR$q)k%4wD&xSjZKUlO{fz9eG^n+ zi3R9}1psEJvZRogZI*u=y-?!X)?4w(F4$#tFR=KI=q#~_34TR{X+V?H64{Uo;^g@{ zl_Ze9pk$B4x-#u!b?BAtZ^>X$M}-i(H0)ZWA{Zm`7Bro(WkJtdZDonGU6}Yn7k`)H zcl=gI_Vo!eR{z{hJW-kzy~-r$1vGFt+3bSo2I3Fj&3UbZh5njswTA4H;m-)WZf1H< zSOylrVQ2*h`jxwtHJ|@hX0k;&(-spjWCvtU&3{7bEnB^XQ$pVl3RMOatU?nj!O1~Z zlex>#avFdMwsdt*Btfnv6v?X|Ge(;+rEv(0%}iQMqcjG2&Q!EfJ&7KeEkXGDy6hU zLI|6lv}W$tnOY+1B2g^^qlS97iu~|Jz2!dWIy2s=EpSjyHWYKA@JI>p9;Cn@-w1Um z?e}GZYp%9OL5+bFsaAjpI7Z1gI~vpz>|M+Z8a{1efC>3ydWWCNFL@$?Qbt94c-33{ z!!_#K<#uqgO*T6ctYl9_Qfi~&4)4;){L2hH@218V#P?;JK_gyv*MiRk<6W;MJT9;y zBCO59Zw}CN$(%YfaDLwju*sUft=Kk%6#)atUULb(M!48&HA6dGqpe#1sOSa@6QA$AGIyP<;J+7gsgxF0-Hqu(m4>?+UO!lEwNNOfw zoM_-6AJc0DZ^_CC3{89sm{;3 zPZ4%K3xO}*{gP6~F;(S?Nr5EwCK%+uK&80=x^>%Tf_n`c=pmpy2_$X^jRmP2nZr~r z-3gTlgr*jZ0*LXjCB|44K^pAUl|f@ijMTMVyAqlxGzffk@s!i9F43xhg-wW61hnLU z1j~$r%4;YahYG%vh1dl)_zQ^MIBCFR$liZ9Nj&dfK5=4Buf|a%)gQ0)c!S~_(Fj*Z zH}C*k!Gg_%{hwgfpYB>Cp#m8FJ)!R(bt?&fU`Yw9a{7DZuby*H2G?`J4gv4sq^vXQ zLqMD9Z<-xf8p=e+J|Hl;Y|2RuP|tcG($3NW`!z58^wOir9EB}!JbRrH824|uKntX2 zfjNwDPpF(VfV;hOmpV`R^(g_3MyimPr@P6}g3Szj;+>Y&!J?NvoCd`(2d~c6Vi3er zq(rWo3r)laVc>RoY=YsQ7guPSncirUkX0lJg;cAukFXRrN6kXrj#bG$~&g& zftKsHr*1?Ne(wq8`!tGtr-H6T*~Y90DOYPTq@kZy8w#eff>bX=9Tq;?fKmSjFRIon z*_^4AwN%I7P$>4Cp_y|BBA3^WyTZuDD&ns3VJjIGvjv!5BNa)qZNjmRyW+p zTRF`o*hG8O;hBi*YVlRfwbK(1&VUs;M#Nu^j&Ja``*Zy&*;EJrrmZXdSi1U0?0>}C z<^lqilQ-s?a0V(Jr|ATX<-hh?Dx4LZR5}44O8|Z1fFPI@LamhM6$J!HkJTs)u{Zgq zVoto=*w!(g;7~#6wBTBIvzr2i}Q_r`L zK@o;HRVDeSh9?^YMlxlsrdPu~;rl+@jW1G-d%(8sm!A`rR=ed4jC z_mT1T%aZsL;}T^7Bk+fJ*-3}Cn^-`@;A(gLzpUXG1|8bmmTp&LOG}O(M)n?;h=X$h zA6}De{U=dLJCFj0eJ4QM!IZ%&r~(CG>@(C=Mf5c-Wtz&VUS7?dHLd&(R6zq7Y@2 zSLJ%%(KGoNoKLpKXFJ-}xh@+Pd^>$IT$Ir-c)u6)ma~E}?o)?ju$;U~DC@+c{|opvuLl=3UTYYv8!XCGPYI=e9HUNHhgzoU=xY(O1WjD;vXuC%X8Nn|$1 zgYj!E%OO&p6L>cAZ#Yq1ZLVBTi>2WeM-RZ*FJ<`nY*vp^2q@!nTFO^rubys5QzTPA zozZnopM13N1=7eW8@eb3G|zs_GWCTg)?G$DLM?hpquh_ODn%hmZ?JP)n2u0T$BGg` z+hMI(DNE#>f2TM%Sgf!<$0T^Kk$9)J$SI@QGcYG?#KIOTKdeIXvxq@iW4 zV$@@`a=jg@y`x1VBy3B6vsVM=`^0|+VFJt*!3np3N6W_ZHQT|}Q;d@+&5ubn?JH`B zLBN}$F_{;cJQ_W@(SG{A=I2o}6PK6Yt{Dc48>ns1_lne^i9VqFryYY9#MM`|HRrZ= zedgFvW&{}G>78?}bO^@3?!%-2uJV}k(EIsI;U@?c#z8+oExbXd)tutwMMjjbkVLMe zCzfYd%eST0bOO&7h>yQr4dp{89jAUsLL5{UemXs|odaE!_r2GwS_(wHCx;)79N*v} z&|ifq{jp?`K*0wLa&&zoC|D&xZ2qT>86-2K@@Sdn1Yg+9t9nKdm&*^1Ab-6D)BtzX zdsale;izO|O|w5G2>03D8O5w|wHGD38psEhhhil{siBjHf9N`Zp&=AU9L)s~R9xua zPd_pEAXCI@g77d!xDevT>=%gQ&d zGGsQx*;+YV%xKxxcTtvJx5o*#GOJKyRI};^n={7KW{=BE;n|6Cq&e6a2(^DNoko_m z<>UTkUf%5w#dCCd;J0;s8dSZ$z)13fHL}?*c2;mBUN|~4qxqPH{N&79y;ED8tCS#; z)3hu@WsdqD9)it*i4_uWSvxhYKHF0u(mJ-5wMN;j+>n+e5$^3>9PaY%?$c@>p7`cb z#IPNVUTckJBKMQc_LwEr;!Nb9A4otcbwUZICpBxY2TCb2pERoxMivYD5oxdx>Ag54 z_;h3aim2_de|!|*WlzFU$X(`#$7BQ@ZHh_yQgufXI!3fKH%m{6Rb_{M-n1H>;N5lb z6Q=TuLP7vN6W`Ccl!jh10YdcNfwJ8#q{e zW*@A?+TAYz`X8S@)ORpO_o=kL62E!#HYU1>BQz^qr~Dd2DeTxnJR4@aYJ%3I@Sf>3 zZfN#_BI8CX**+%Q+a5;Zu5XJ$NHV(Z-eZp&_}M{9=1}-8ar7#x&0W2($-eV4b-TTw zrk;782uoV=PbbvL4mw5i1MC}|FzNfv!ND9zpInmD%w?1;(-ui)Ti`@P@9%_fyj$JQ zukH!qs+O|g#$86f1wF>!w5sfkLyK@$rU4Tvb0Oe@z_) z=jIK#?}3z%f%|n5o|ckw=5Z{8lEoy|hQ`01dUPad=|T}v79}|9(v)9$ zCl2BSZ7uL4%~LQ)o8VrrD?i^&*rPWY(O<#f#AkdXh2f%Uz6x}Ncfom(G&-4QM zgZS%ZI|ZOw_|5u6^eo|iEVjmnU-w1C)%P_l0Lm4--$wtM6m5Wlt_?cAYMVq2Ry^49 z=<}C;UPHZ1i?`~UNE<;s(P%L=Flt9bJ!FbH(q#RV?Dw=>lJ4N=VJkUQ$2z+M39-<} z+gTAV-nydbLL)NWxpO0UES_-uN~c@lKDFyB)Xxmc{JpcFgb~mg=hRif?`zz>yOwV_ zZx|9na>^f?i+IP54QH=h!g=Fd2?cr)bUTp=H-U{qM6>r66-!h`afU>LF>)SsFCTA8 z2Jg`Y3UW(&YV7cB)oO_i&-tRkXU2&)cpqR#?~y9qn6*UMp9&X;62lfBn#WuS?_>oi zH!ke0CCX24J|&oU!GfRmgm3zVwvtXFI~$DcC@_m%+bn`3${GdxmCKdoWjcPTn0Kqt z_g!_Rz26gDLs(~2Wep$sh4l_*2{gPE!pZI#o#_9Qp%myEl393C?;*5?DM|3ko1!3` z$6G}Gq8rQ7NX+0$JdkFS+=@*mu9Eu5S#>kxqpB#qW;4e8=^HMVqu|s2-2n-@i4;@@ zGg!c&x=0~4fz6!#tE}3b*BMGdqttVTk(Kg3ZJNRD2$a+A?ge2S>lWG`!cBW3Si4)d zk8)JYe4cZI@_O_hYBl)CGe^xY6Gr0Vbl^!c+s+%FyVJb@n{a7G>xg0*^bt8(i?=Ws@#}1lvjIoQnE_ObvUnmlN1*>Ec|71Lu z*>86mXuO@$nGp9bv1ZNM!G#km`t(9Wq<{ZA$*W^I{(y%WHP_$E=%a6l|Lcy6QY-XQ zoZ?9wz5$;Uml8ik)l7}?;wRH7N*kl52^2L%M`(&V>oNYp<@dfSZHm}Y{J>@N(nk@+ zuVKHprEp(Ap5-oxZ&$iXRw|rJRV(!5z9Hwhmgh_UO@(mCDE95<)#ao+%bTo?Lx@sI zQS7<%*3Pq_p1ku4IR=n|_i>nT7H)zo^ b0f2bvie76Emw(Sc;Q^H7)#a++LPGurtp1JY literal 0 HcmV?d00001 diff --git a/x-pack/plugins/lens/public/assets/render_light@2x.png b/x-pack/plugins/lens/public/assets/render_light@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..497f50866a294d1bd14c6bf351d446784b8a5533 GIT binary patch literal 10795 zcmV+`D%919P)jC(%_e+ zy|B8^#?IYBRFz6$hr`R;zQ)@4Hf|b0t5vJ&(`7zbHfP> z6e(+}0(Qy;Z@vZy4bIfx0C&sL*yPI5-ve~W0t5vD0t3(3-=nX{$j;mrY`HFi!2x&6 z0d~s+X0Q!glN1^$9A2e^m9WFh;XbkO5|!eXyW0SD$^di51|BS8wdbM3;hVwWyTa3> zuEZK6J{zg^00000cg)Y$;s9o`0BE!Tb;$sB$^dP?0BX1ZaKHd?!T@Z%5SHZ^l-2-m zzW{W{0BgDf6&?zT+W>OI6rAe@DLomV<^XfW0CL3*kl+-5xEG@E0BN=jRC)ml4+DMC z5NVkdnB)pSTm&F42ZPoSklYcI;0#J@6^X|WUy1-qfC)cai^b^)f6NkesR%Vp42RSc zn&$xu5V+9f06S&?EKLAenE)O$01p}f4;cUl4HI;z0AZ#Vq3$$|&lZWs4_}D@HCg}` zCIC{534_rKN^1f|a|=pr#M0t)tk_PO(i(xwZr-O!0001MbW%=J02vem1q}!b5ymz) z;_+`M#>O^Mnhy_*e$o(rMB-t9zcnDJ5Vt__V5y*tQ&J+tuy1bSn>HuL-?+AZaN?7g+Z|Z04GOD zL_t(|+U%J-lhZI1g>@f#6wYMwav)@2hX4aquq_2YfMFY`sj2e+OU90@D>-sVsIa52 zN$mC7@$u2oy|OA43WY+UP$(1%g+ie)B8ZLQumJ+1-=_-y1RGr=LW2(bAi^m@qc*B= zC1kW~m1XD6syq&$Qyde4EdaG{W>Xw}iC^Dd9Tru~^TpxS`_&#AxR(&8?-V&0ASeyR z&3V}VUL4PvE!JOFzuE&3JdLyn*nAlO7yl5tLvUA|oWcm7kHb_CA3q+p+sBuy{Tu+z zNlHXOYiz6P&O13y=#m$n#(nf-cD#~m@$~ou`s|oB1nkMrs9D`NHU#F^<1JKs7$g|l zr^Wq7vPJK;hKJ)#%$9#qm<@U}8{~V;ithe9e|H6QZ|E4_gpOiOjKf$*u|hJD-T>|8T1vNfhU>RkYq@NZ5y^AfYa)u z$w35nW7UZHF7YDQMX%&^u}xuTZ4D8K5U^}zKhb0)CI=}ylP;wbTwuOF=GgZOJq^Ri zfwT!*lX)GYVF)qbFsp%C4+NA^a1oRK9CY;*vbeh+XU%5lp7DD7KKaj?LkO6w3~ZC( zGLh-dVC+?$U-mNB+xM{aUmlvl9x$vys2$`O7*ROlpkPd$N{}K&ahCbpOl{`BeH}DD zQlz2N+DVWM1kz|cRp*kK#nEb2>d?kPgqejP$&qj)1ShFHQ`2$55mEqvygz!d2x(CN@r`| z!yI}78yOzaRj4zm?p+dD)`1dGjSmYw(6XURbz7|hlxf{&zH{4)z=R>jDXJ12)*@S) zyQp>De&$LUHKIizLI7u}uQFZgD~uA(?fZNQC#q0Iu*kHNWeC=pCzj>{Qm=bfp3$^+ zwi}+C0S)u7DLY<2WZn-UVmtALT}w!DeIZjrnnYi(aP8XGuGt=ui3tJo9h%PANs0hX ztQx+b*|%C@7pyY#JhjR#772LiIBDJ%8n{N?9j33d0l zMEob{p?lfSIe}%rWCJ02%`NHwzU|n=-Z7A}$p}wTDkHtCGV7AE!nur6*;wo^AsO8h zTyTIksn#NwBbuly(&|5k(Wjv}H5(E(GqUpwXVpG5TbKx3{h{t!cAEyGXy(pyK@_2q zAObCfSA?Q8K&uE9Hf>NBAR!P-#1EkP1r}`iYLsN^>+8AWj8!=?XM>cwO?-TO?$ZH< zp8)kO2=5X;gT|;Ji>_wp8MbtDS0@`T3MvGr8fW(gq*?xm5X`0{d{5npQE?fKlI6`< z1^-Q2JS5UlP%A52wnRzfOKM|+BT6v#k|FtwXt zalh1i2U)cUT_W6pNCFD-!B`Bv;l&ZI0(Av4$L#=ROu;-m@bRbEO|TGSjl2+oH<(`> z6D+Ptb0{=GBogdOa)vIYYawCC8963Mqv(GocZ7EAv2Q|vw1S`C&wPY)5y9d9fW#Xv zXr?1`eZvdZN(E67m&5Oqr#(rdx#12*6REt%woCfMGnk1KjIy+pQ=J)fSkhG2^iiua z6l)RBs`CASH!C_KL+~U1vfdni;TcSqNdp@>db6qRtG$Cm(>v6VhXs?VCZ=amZ2`^^ zQKkq^DDftZIQAUoH48A3yr=6(I;<%ds6CaD=wo_D=0XG@%cuSx(`3P79InUGv-p&X z5Axj4cx}y- z>Igt@{?Q_z;KTDQ{B*vtNdq@LocaW&bnFK6srMU( zje)Ws>+Q7Ta0<4fF;o}~zaTTAT|3#f@>cKfY((Gdsle|Rvk}>B_~uhslC7VwMS3wI zIkAG9xQd@+uTY{nU?Yr&{kp^#&t2nrL8UtRjxCT?LEP18uY{FP;kqQqG3FY`@Q}{$ z)j=kqvO2!y8*0wc!!#V-P1J1&6FsWw*gOv^+3q`J7zG^T3VZ&i??{S#8cYJnrIx7d z{q@!)L?^77DNJ?k7bTbzAP}14#oFTmwMWY*ONaijzT&^Y90>gF_KBNML@&I(k_IsB~ zWJ2Nb=ngnCPK`P+Xr_S<+5*G0wF9*AqkC!Waez#N)!=@=e&Yd@iegwj=55Fq^I=&f z7)&_x_DvW>KE_5VKzG38_qMq7E#iu_&Tz)DpK3#kh8Vnvh8DNSv2PRetp{5!W9qdG zBO2mizwXP93_~+_ zxF0>L8PD;X10?pq+Q3;QOrst&M05ND8ZZX8=Ftsc2g4V>1z;8dCApgNw*s{L;J9ie z-+TPFdhT$@Qc5+Yc-dN*o1SXGXUjorGB0R#J}05Md=dHb)p5ZHQFNXAmhd%Mu0rvu zYUh7Ha82b)qgyV3GyHLMac902%xc^a0ApVZ44bC%rL|i&bY?_d_!e;Xi=3>pLkPi* z{fPTF2$V1FOg4bQE?h0zu;H^w7?z+FNNt%Xf?I&gmv1_{IctYm1mhUvw(ZKlzyGZ9 zH#>naO1Ws82iPwLF#9wJly5pYvpKhd&Q7@JJIVdW-nqOw4MbsFCz&)TD&hltfr^MI zqFY4}Q54+iQn%`6Qn*VaL`c9$N^BQxy>bic^$ou8@dx^7?P)rhoSe)|sp7W~TzIj+ z`}Mr$6%Ru(QIhtf0MP~Ic~4eyy9hTq`f(W9zVf;oN51>Wtdbgr<6$C-8g!8<52$b; zn5+IjzP$i}+gBbv)XZLNcinJ*IZ!J~MTtT{jGo|NH9ov+%D{B{%Eg&aYPdCHM3#th zg%BvP0~`+i|7A935V(D}m0x}-m+vvyM>8wOPKLwpKs+P&7A`G9G_KQniKtetAbidB zm~tPT%4&-0BH&DmLu>l(Zi=yAJ&zV(G<69JHx@6F+MqCoUgv`MvjlKg%dp(Ckgs^4c9ea>#N+_Z?Zgc~K!T?lV7`OhEQLM#( z{RwHwnt`FUkXvJmf~pKRFs@PU1$>R@ehR*o=lcH{KwWu2bu92v%G{ALh zE9i=1GNlQaRVKG*!m8**-irF_(0*T=D#mG!c>|C4^H~N=kD7_7uP*_rRRJmm%%>Np zHxyGRw}k^va3HZDC~pLq0g{>8ZLcW=^e3kOShvgGvH8A6bG0x0h&p21^*eTfnhu9asz&E9k9G|;Ee6On;wQ8xpP}~ zz~mTA2MiY;xU+v@4VE^1^jX3!cLYWD0q3+Tf(RJIc#HGdl{?;GX~R+47dDk_7IsAk zLQv8WFi7tNlBcvUOwN`K@Q60spjQzbc81Gpl;Xg?@}`mn10LW&I>PQOg3Ybka=wc- z9SysRC3#pEvI!V>oPL(;(E?=RcvUtE@U^GT_16mB00rLVZpPb_0_D*@vnHj*z+hLaFdHSA&gkGrOn*h-* z7Lz0geg(jju)Ld^;$W~NXE!5&Q|P3gc54OCVGm~_YAVCO4RI*u0W;3a_N8%h2zFqw zBkwsg0yvy&RJ%zn&!>66`Z&M`eFJxTt64q(x&T=9mMte25gyoA%5DhYrXR3J2rYv& z@2cp8THz)huE7sL0E27&32&DWA)t7WiZc^{dq@RYaE^pe9T)cLJqz$90ET0~jC`cvFoXx`Jc|*)F}@^>D^UdFtZ4x53L0P-L=XtW ztEKX*^2Pv%$hcgy637}Rxc3CWI!6jFDS8WYfY;0bP8v0I=~Jvrp#x@wQ!z&lDtZfp zfWK&M%K>%J7C}}Ysi9H8J}cSZ3vMc(%#sG``SV;DGg=*D+>bP~0EpX`1K#(bJ~mWB}|JX61~t>CteHO)g9(^9B1F z1iYsDiqiN3GP>w}_NKYcc$eg4kIr}d{*5*OX9NQw)vRIl5;frQU6G#SaCm8#bm;Ri z7Jcb}(=2^2;vD%F7}XjI z7 zMQK>adz}H8H=D^}ed`Gh6gLLU$AFdH^3fT*&{|Lcs{;YpIO$jV=Ru_Qb_Mg)umf~WE7YK&Pg8fE>}r^pw#8(36N3vjEVTswUFr+Lpq?9~Ds z+Wg}70-H+cfMFKwS9Z%s;6>vGfUTM=U4Fnn%Vf^biKS}>a2gm^l%O@5{SYA!E4jzy z%Xcf)G6OgcOe+(h#HNJ@Re<^2zG(-VjhYL~J{_=q14Ev(PdKkE)8@b9j7jcA#EbwQ z1?CkCtAv3s;@}o~v1ujdjV1txfeob#Ae^DIh$;s<_@$w)5x{w1Lw#YL@K@1%RT-8u zn6Za4HaFZn4%?Ixkqp-Q^;kthO&ES;Iz$ufo98c9-hEyVBt5@R2ki4*bA+9$4L;lm z;ME#AD@&w%QBlAM;m#z0=GC3_`n~pVt-K0~dfcW1X2r^jwY*m4lW4x35P@Ib8Fq=? z91xb*>Ia=bt>4ggAP5xgYSox+txrU?OA=C#^o1n3Sf|1QXKeL5uxA7j zIrE6pnuYkwc2SStjQPH6(*T1?zWU4}U>sHyHu$x~%74@?{Z4#AA_VB&E8yD*@ZOTx zidSg{2JTUVb1L5&EQe;jNWSkn$5I?<<@x&adu=jc5C>z|won7#$QOW5)Y<(IKT zb)VY`kpY7kjMy;1yL18LbphpeYN$Dk9jbfR956v1p-R)*7ZD)_#w-l+)zrqz_Cf%+ zYyrjtF%$!66DXIr`ukEoEe0^xEQ0|snJ{(VS}dAr6{*tf0^V&KFeoMRN@~<}8V9vL z+60Vu8jg9uA|`IKj!0*ZsU`JSn}G37!?gf-jkv$BhtwQ;WyFhr4{%6yWUQW0>YoF7 z-L?uCgf(&o0S{~fCU%l zZT(*Y48t^Q!=9L2zJ6Ny517)fz9)|>U%&YK0RLd`>{^@#qA(18?wz2hH~tE5{Y}F= zpBb72f;JZcMU=&g9~Z0Lsvx_H{y|MT?J>IcjC7`0=zGzoVN=*Ar)SQb%sF#y7l4l= zYasZ?ASVaFY+EVP>u3*5Ix7!=S@%opP@{bcX(11Q8TY`XAi3hVg**UeRz9+XpKPo^ zT9gOCjQukE9&<~l-W>q{L-X$ANo+F`Qke^IS?w9%kbhv>kxb(7l4hALxI()pQ{_oy z(Z%t{&y&gI^ONJa%HuDY0c+dr31CV&CY9VHADjbl?n1#uhCxmT_gna4C+W&-slv1z zCOpdkxI)vvO#!s~1em5|>9oi=(eMD8y#kz}ly;U8umg-v3YdFr|Nj+(FZL@Jk$+{+ z_tXZQ8n7-@#)T&t0aKw-O3k-TSN=g$Lbku3Gp|ws&an88cM|h=ClAlr0>zgvUL5~< zbL5tQEu%@ z9S)KKzOxI!({lo}IH633s+oqP0xlf+uXItK1=vRk0Y8?f z!FcE6r?e#av}#1tV^4V;2Uz>-U;CI4PB*p!0Liud>ap#WLAMh zTd1UfuQN@NvIBm%q5m}txTiT*0hrBzUFY>Mpm{aA40Rahr0ze@XLv&%3Nc*?0{!nltzHH2rA8rizO>0 z#Q+`{YOUAFGq|2_h}arr225c@cEF#a+seLzO%X*DQYz8QSqszwu^Qg%5Ccz>0X|}y zgXRY;qg$bT?aU^s$`nz6$9@5|gfz>KvcMqo^SG-M407DAeYZ0LCVgOBFdL>(IBWh5 zaEYbDg$_YBVH9zVYtWn@@Ck3gJmA(F09{|k83&k5m{L7O?Xk|RHE9y=m$??>`2m-w zf21lO{VU)Kz|w-7G7@k=DltftQHS3_mj*DqCwP9qLe57^Enkv-~EvsgCUd4uK z9i$%HK4c9@=jgNrSimWEroEaRu#>|ysv7;1($n!~z-B!pdGr?rSkALYx|FtX0DKa_OrQK~sR8RSggE><$JII(Fbzp|n0ZO^p0R+#7mTGOEYJko1-wxr z$yAx!c0Dyz$6n~Qi zS_ZIRyNE(Ig9{xm&}n$UcH|;-VG4Q_hl-{ev4C&hyMO=gQV;Imzjf>84Sr1o>2@N( zl^dDr5BAQcMQR`j!y=-nv&hUY=%T3jg^C9iJcxo9#e<3)a8q%Zrx*?@G!t_D8keRVTR6x z0>(v@N;26zJ;Hz%NkJ5J$>bupaxckBBqmi3%SYx!akuu>E0Z^UG&#jM;q`@S)anJ( z0`n9L7*eD$pd}l3vfw%v(RL8z%J3SCPO0+YH$62u!#Lr!0Zz?S2iGfm0ETiL&TB#@ z)!+f=C^$%6P$l^C%s3hz@T)hyb%Ke6*9JJM-yasypl>W-NMgN*!j56uyK0L|SW!*w z<*^HaaVk0h-s%r{n<+=E4Y0ynf_ei^h=gp?mq2#!>T%lYH8+DlE6lO}&5fuexHqou&gvBRMcV(ia7J{4>^=D(g zVeaD#DCDbYn~#4%a$_>RuwoKC!>k((1?;#Q&Wi+|GpVu3NOq5d3uAY>Nf|^lQbhF0 z+jv5d_2+RRaDTb79!qqpMQmO@d|^7>o|M|2KEAMZ`0DXvv+55=SLD!4MQsq^#99{= zoB2oquq_&j_kF@NqD5|vHVCEZ>(z_bfgi9U2sf40_n~C-^$3Sl(++L1VKB6NEt8zo z#>p+`O93p~&U7EWfK`-X3^}h#bE>495+*t!{D379r1Llp9bjQP)FNB*7*ejBZS!F; zwC_(W8L6O1r8Qb2*%0#s{xV+>nP?e8ZlGNdEBr2kj0#Z^&6}5xjSsd%X`LlR+3y2B z-gXa7xN(uGx~~&3BqLaM>Ia-qt+ZVQuD|LH=|Cm^=D!-S)}fj=p>tt4Yl2b+aA)^$ z;zV=6Ro#aJR^dF9%ZRa{MjT+L(lsOt8HO(5&@M^Pk}3Ac)O{p2O0=nuh;$Yaq<<6e zvB`3F(Ez^5wMPsGj15yzBHZK``vKd!X15Yqr-h{am z^Qw4V`$&C%cH|HJ0AqH8womQq1b9z3!2gd9bPIlO+tlq=eR|5XxI6-02F%ZH8_lG4 zkq5kQ1k3_Hy1WASsG-+@_cfr5fPH{5yFn*iW#A8~1?joUdF7?H&QQ0DDS1b#w*~;q=JY>^=fs2^hH>wDki z>m&ylCOiUe1K!->9yZZ*4ZvI!0TUhpw*YUga1YLap=~_j6t|yX1Ps8lRqg=>3{BWX z113BIc7SKAq6Zl8YQVcV?H&QwfKhvZdw>D|0`LY4c+Uvf>gAgy9d`S+V88&3#*-l? zd~pBz_2M)1wv_u_trt}?k9;cCJjMR3WsbkD|F)igUydF;TW2Rs;|XKJe^l2}aw@9! z8!WP;kaoZt^RA?g#V`Q!~kr!Y1M1eF}5JYb&Erm zwDwy-;nP3F7w!St>jQj?fs4BE-_k=R4BITrrE9Cm>{`FZZUl-I8ZHTq7b+ET`Rn1I z;tTfx1NH$%5uRDv_-lGn_4lQ@u|u;t2;GoLc^1TV(_Y%{qFTg}+o(`J`~Et8#BzFZ z{Sdde9)KV0`o~Q8(rd^%-y}s_nl$a~5&i6SQ-fO&EgHa;ZD0C9-LhsZEo7)Hn#kQQw)bHYWMY(QrCIXnrLFB&&jgRl{m zNjzjswf&e;q2`(BNli;Oz$)RZ#yfzL5$_KtEJNfAT-YaL6^O|s>LR#GTk;5zb~e^o zz2H^d(Rrm(Q$}R88KHkCM84P+@()l1;xY-V2+qwQ4M3TeA`YoL+lUDTWyK2Za)5kc z4|a>;fjHWYd(47X69T5LR47-4YApmA8~7U;y?hoZU)X~UUjvR{Ch?T*!dmLadmETf z=`gZ(^LSSJWMBEBde~_Y2V}z!*$$YIS>6*&xGtwA+t7_1iBH~x^@X)*yt6_(7#rRx zVCv@V3ehknjuon;qZ?U1e#_jYi}tRNLxpxIHoRmzPAZ~Y7(RIW9RN0QWjq)`GObgPTJGl_y6hn9G&51Yn5R}~$E4UcOybi_cZ z#juQ%BvqewpCQkrnP1kC9q)bR3wxMhf%~7s_j_ACcN!?o_?L2XGrt*G%KDS6pYQm} z7xpk~1suLZ7cO9=f^CCH2S0+UCYN+US<>UVi+pcbublZVaM3Sx5b*fc!U^IF!Z@PM z1=QwImPXmY2mB{)$K@~V8-XA7*k>$Yqy@r|WxuMWgTzrLGL1#iXde>xk}vGRe}Rj+ zqq7BUSS`w)N(6zWV&KBW5XjCoHG4@sQ5+I>mM>-x{tH~xr33_Q0|XNusYv@6wRCFW zgQDWSgM48RaqtU<=Mu1uQs#qwI+J_`g7c<|D7qa|_{1IOD6UIEm*_-XtS#BTP^PED zeK8~nWptzI`;PLxb}IOWj7X;vPnib<8zArKZ28SsW8rHp?rg7pfd%X#pg@bW9Dc|= zu(`z{Ody+H~NEFzQ;a6-9XuVNNRQ<&yI^jR<;y0T4?@oqKL}S1z z5!eI8Mt=5(<{wt^8^!+6Oy%0^(=+3Khd1A9)W3ekCL=xefnzV+SS5ENbt6x%0 z2bbExkMG89y0uZJgDr~L@Fgu$+#PyVn-=rqtLM4cdx&C2iwR%<v&i!XCyX! zNvpips-l*BI1&E}780oc~X+M&@bgsNrRB7T_LnSNIy#{$8ko$2rW zt}5d5SHD$7jQ;K)tD?*4`FweJs){bDeK#HM3cg>XWdIwDR&G=W@ - - -

- -

- - dispatchLens(applyChanges())} - data-test-subj="lnsSuggestionApplyChanges" - > - - -
- + const renderApplyChangesPrompt = () => ( + + +

+ +

+
+ + dispatchLens(applyChanges())} + data-test-subj="lnsApplyChanges__suggestions" + > + +
); - const suggestionsUI = ( + const renderSuggestionsUI = () => ( <> {currentVisualization.activeId && !hideSuggestions && (
- {changesApplied ? suggestionsUI : applyChangesPrompt} + {changesApplied ? renderSuggestionsUI() : renderApplyChangesPrompt()}
diff --git a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/geo_field_workspace_panel.tsx b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/geo_field_workspace_panel.tsx index 2ed4f223994c6..44d6a7118aca9 100644 --- a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/geo_field_workspace_panel.tsx +++ b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/geo_field_workspace_panel.tsx @@ -52,7 +52,7 @@ export function GeoFieldWorkspacePanel(props: Props) {

{getVisualizeGeoFieldMessage(props.fieldType)}

- + { let mockVisualization: jest.Mocked; let mockVisualization2: jest.Mocked; @@ -115,7 +121,7 @@ describe('workspace_panel', () => { instance = mounted.instance; instance.update(); - expect(instance.find('[data-test-subj="empty-workspace"]')).toHaveLength(2); + expect(instance.find('[data-test-subj="workspace-drag-drop-prompt"]')).toHaveLength(2); expect(instance.find(expressionRendererMock)).toHaveLength(0); }); @@ -133,7 +139,7 @@ describe('workspace_panel', () => { instance = mounted.instance; instance.update(); - expect(instance.find('[data-test-subj="empty-workspace"]')).toHaveLength(2); + expect(instance.find('[data-test-subj="workspace-drag-drop-prompt"]')).toHaveLength(2); expect(instance.find(expressionRendererMock)).toHaveLength(0); }); @@ -151,7 +157,7 @@ describe('workspace_panel', () => { instance = mounted.instance; instance.update(); - expect(instance.find('[data-test-subj="empty-workspace"]')).toHaveLength(2); + expect(instance.find('[data-test-subj="workspace-drag-drop-prompt"]')).toHaveLength(2); expect(instance.find(expressionRendererMock)).toHaveLength(0); }); @@ -218,8 +224,10 @@ describe('workspace_panel', () => { instance = mounted.instance; instance.update(); + const getExpression = () => instance.find(expressionRendererMock).prop('expression'); + // allows initial render - expect(instance.find(expressionRendererMock).prop('expression')).toMatchInlineSnapshot(` + expect(getExpression()).toMatchInlineSnapshot(` "kibana | lens_merge_tables layerIds=\\"first\\" tables={datasource} | testVis" @@ -233,9 +241,9 @@ describe('workspace_panel', () => { }, }); }); + instance.update(); - // nothing should change - expect(instance.find(expressionRendererMock).prop('expression')).toMatchInlineSnapshot(` + expect(getExpression()).toMatchInlineSnapshot(` "kibana | lens_merge_tables layerIds=\\"first\\" tables={datasource} | testVis" @@ -247,7 +255,7 @@ describe('workspace_panel', () => { instance.update(); // should update - expect(instance.find(expressionRendererMock).prop('expression')).toMatchInlineSnapshot(` + expect(getExpression()).toMatchInlineSnapshot(` "kibana | lens_merge_tables layerIds=\\"first\\" tables={new-datasource} | new-vis" @@ -260,22 +268,12 @@ describe('workspace_panel', () => { testVis: { ...mockVisualization, toExpression: () => 'other-new-vis' }, }, }); - }); - - // should not update - expect(instance.find(expressionRendererMock).prop('expression')).toMatchInlineSnapshot(` - "kibana - | lens_merge_tables layerIds=\\"first\\" tables={new-datasource} - | new-vis" - `); - - act(() => { mounted.lensStore.dispatch(enableAutoApply()); }); instance.update(); // reenabling auto-apply triggers an update as well - expect(instance.find(expressionRendererMock).prop('expression')).toMatchInlineSnapshot(` + expect(getExpression()).toMatchInlineSnapshot(` "kibana | lens_merge_tables layerIds=\\"first\\" tables={other-new-datasource} | other-new-vis" @@ -339,13 +337,41 @@ describe('workspace_panel', () => { expect(isSaveable()).toBe(false); }); - it('should allow empty workspace as initial render when auto-apply disabled', async () => { - mockVisualization.toExpression.mockReturnValue('testVis'); + it('should show proper workspace prompts when auto-apply disabled', async () => { const framePublicAPI = createMockFramePublicAPI(); framePublicAPI.datasourceLayers = { first: mockDatasource.publicAPIMock, }; + const configureValidVisualization = () => { + mockVisualization.toExpression.mockReturnValue('testVis'); + mockDatasource.toExpression.mockReturnValue('datasource'); + mockDatasource.getLayers.mockReturnValue(['first']); + act(() => { + instance.setProps({ + visualizationMap: { + testVis: { ...mockVisualization, toExpression: () => 'new-vis' }, + }, + }); + }); + }; + + const deleteVisualization = () => { + act(() => { + instance.setProps({ + visualizationMap: { + testVis: { ...mockVisualization, toExpression: () => null }, + }, + }); + }); + }; + + const dragDropPromptShowing = () => instance.exists(SELECTORS.dragDropPrompt); + + const applyChangesPromptShowing = () => instance.exists(SELECTORS.applyChangesPrompt); + + const visualizationShowing = () => instance.exists(expressionRendererMock); + const mounted = await mountWithProvider( { visualizationMap={{ testVis: mockVisualization, }} + ExpressionRenderer={expressionRendererMock} />, { preloadedState: { @@ -367,7 +394,37 @@ describe('workspace_panel', () => { instance = mounted.instance; instance.update(); - expect(instance.exists('[data-test-subj="empty-workspace"]')).toBeTruthy(); + expect(dragDropPromptShowing()).toBeTruthy(); + + configureValidVisualization(); + instance.update(); + + expect(dragDropPromptShowing()).toBeFalsy(); + expect(applyChangesPromptShowing()).toBeTruthy(); + + instance.find(SELECTORS.applyChangesButton).simulate('click'); + instance.update(); + + expect(visualizationShowing()).toBeTruthy(); + + deleteVisualization(); + instance.update(); + + expect(visualizationShowing()).toBeTruthy(); + + act(() => { + mounted.lensStore.dispatch(applyChanges()); + }); + instance.update(); + + expect(visualizationShowing()).toBeFalsy(); + expect(dragDropPromptShowing()).toBeTruthy(); + + configureValidVisualization(); + instance.update(); + + expect(dragDropPromptShowing()).toBeFalsy(); + expect(applyChangesPromptShowing()).toBeTruthy(); }); it('should execute a trigger on expression event', async () => { @@ -921,9 +978,7 @@ describe('workspace_panel', () => { expect(showingErrors()).toBeFalsy(); // errors should appear when problem changes are applied - act(() => { - lensStore.dispatch(applyChanges()); - }); + instance.find(SELECTORS.applyChangesButton).simulate('click'); instance.update(); expect(showingErrors()).toBeTruthy(); diff --git a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx index 0ad237109d08b..d349428902c82 100644 --- a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx +++ b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel.tsx @@ -20,6 +20,7 @@ import { EuiPageContentBody, EuiButton, EuiSpacer, + EuiTextColor, } from '@elastic/eui'; import type { CoreStart, ApplicationStart } from 'kibana/public'; import type { DataPublicPluginStart, ExecutionContextSearch } from 'src/plugins/data/public'; @@ -47,6 +48,8 @@ import { UiActionsStart } from '../../../../../../../src/plugins/ui_actions/publ import { VIS_EVENT_TO_TRIGGER } from '../../../../../../../src/plugins/visualizations/public'; import { WorkspacePanelWrapper } from './workspace_panel_wrapper'; import { DropIllustration } from '../../../assets/drop_illustration'; +import applyChangesIllustrationDark from '../../../assets/render_dark@2x.png'; +import applyChangesIllustrationLight from '../../../assets/render_light@2x.png'; import { getOriginalRequestErrorMessages, getUnknownVisualizationTypeError, @@ -69,11 +72,14 @@ import { selectAutoApplyEnabled, selectTriggerApplyChanges, selectDatasourceLayers, + applyChanges, + selectChangesApplied, } from '../../../state_management'; import type { LensInspector } from '../../../lens_inspector_service'; import { inferTimeField } from '../../../utils'; import { setChangesApplied } from '../../../state_management/lens_slice'; import type { Datatable } from '../../../../../../../src/plugins/expressions/public'; +import { DONT_CLOSE_DIMENSION_CONTAINER_ON_CLICK_CLASS } from '../config_panel/dimension_container'; export interface WorkspacePanelProps { visualizationMap: VisualizationMap; @@ -143,6 +149,7 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ const activeDatasourceId = useLensSelector(selectActiveDatasourceId); const datasourceStates = useLensSelector(selectDatasourceStates); const autoApplyEnabled = useLensSelector(selectAutoApplyEnabled); + const changesApplied = useLensSelector(selectChangesApplied); const triggerApply = useLensSelector(selectTriggerApplyChanges); const [localState, setLocalState] = useState({ @@ -201,7 +208,8 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ [activeVisualization, visualization.state, activeDatasourceId, datasourceMap, datasourceStates] ); - const _expression = useMemo(() => { + // if the expression is undefined, it means we hit an error that should be displayed to the user + const unappliedExpression = useMemo(() => { if (!configurationValidationError?.length && !missingRefsErrors.length && !unknownVisError) { try { const ast = buildExpression({ @@ -254,20 +262,23 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ ]); useEffect(() => { - dispatchLens(setSaveable(Boolean(_expression))); - }, [_expression, dispatchLens]); + dispatchLens(setSaveable(Boolean(unappliedExpression))); + }, [unappliedExpression, dispatchLens]); useEffect(() => { if (!autoApplyEnabled) { - dispatchLens(setChangesApplied(_expression === localState.expressionToRender)); + dispatchLens(setChangesApplied(unappliedExpression === localState.expressionToRender)); } }); useEffect(() => { if (shouldApplyExpression) { - setLocalState((s) => ({ ...s, expressionToRender: _expression })); + setLocalState((s) => ({ + ...s, + expressionToRender: unappliedExpression, + })); } - }, [_expression, shouldApplyExpression]); + }, [unappliedExpression, shouldApplyExpression]); const expressionExists = Boolean(localState.expressionToRender); useEffect(() => { @@ -332,15 +343,23 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ } }, [suggestionForDraggedField, expressionExists, dispatchLens]); - const renderEmptyWorkspace = () => { + const IS_DARK_THEME = core.uiSettings.get('theme:darkMode'); + + const renderDragDropPrompt = () => { return ( +

{!expressionExists @@ -352,26 +371,25 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ })}

- {!expressionExists && ( <> -

- {i18n.translate('xpack.lens.editorFrame.emptyWorkspaceHeading', { - defaultMessage: 'Lens is the recommended editor for creating visualizations', - })} -

-

- - - {i18n.translate('xpack.lens.editorFrame.goToForums', { - defaultMessage: 'Make requests and give feedback', - })} - - + +

+ {i18n.translate('xpack.lens.editorFrame.emptyWorkspaceHeading', { + defaultMessage: 'Lens is the recommended editor for creating visualizations', + })} +

+ +

+ + {i18n.translate('xpack.lens.editorFrame.goToForums', { + defaultMessage: 'Make requests and give feedback', + })} +

)} @@ -379,11 +397,47 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ ); }; - const renderVisualization = () => { - if (localState.expressionToRender === null) { - return renderEmptyWorkspace(); - } + const renderApplyChangesPrompt = () => { + const applyChangesString = i18n.translate('xpack.lens.editorFrame.applyChanges', { + defaultMessage: 'Apply changes', + }); + return ( + + {applyChangesString} +

+ + {i18n.translate('xpack.lens.editorFrame.applyChangesWorkspacePrompt', { + defaultMessage: 'Apply changes to render visualization', + })} + +

+

+ dispatchLens(applyChanges())} + data-test-subj="lnsApplyChanges__workspace" + > + {applyChangesString} + +

+
+ ); + }; + + const renderVisualization = () => { return ( { + const renderWorkspace = () => { const customWorkspaceRenderer = activeDatasourceId && datasourceMap[activeDatasourceId]?.getCustomWorkspaceRenderer && @@ -413,9 +467,19 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ ) : undefined; - return customWorkspaceRenderer ? ( - customWorkspaceRenderer() - ) : ( + if (customWorkspaceRenderer) { + return customWorkspaceRenderer(); + } + + const hasSomethingToRender = localState.expressionToRender !== null; + + const renderWorkspaceContents = hasSomethingToRender + ? renderVisualization + : !changesApplied + ? renderApplyChangesPrompt + : renderDragDropPrompt; + + return ( - {renderVisualization()} + {renderWorkspaceContents()} ); @@ -444,7 +508,7 @@ export const InnerWorkspacePanel = React.memo(function InnerWorkspacePanel({ visualizationMap={visualizationMap} isFullscreen={isFullscreen} > - {renderDragDrop()} + {renderWorkspace()} ); }); diff --git a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.scss b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.scss index 9b4502ea81944..a3287179f13cd 100644 --- a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.scss +++ b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.scss @@ -31,6 +31,9 @@ &.lnsWorkspacePanelWrapper--fullscreen { margin-bottom: 0; + .lnsWorkspacePanelWrapper__pageContentBody { + box-shadow: none; + } } } @@ -77,6 +80,10 @@ justify-content: center; align-items: center; transition: background-color $euiAnimSpeedFast ease-in-out; + + .lnsWorkspacePanel__actions { + margin-top: $euiSizeL; + } } .lnsWorkspacePanelWrapper__toolbar { @@ -84,6 +91,7 @@ &.lnsWorkspacePanelWrapper__toolbar--fullscreen { padding: $euiSizeS $euiSizeS 0 $euiSizeS; + background-color: #FFF; } & > .euiFlexItem { @@ -91,14 +99,18 @@ } } -.lnsDropIllustration__adjustFill { - fill: $euiColorFullShade; +.lnsWorkspacePanel__promptIllustration { + overflow: visible; // Shows arrow animation when it gets out of bounds + margin-top: 0; + margin-bottom: -$euiSize; + + margin-right: auto; + margin-left: auto; + max-width: 176px; + max-height: 176px; } .lnsWorkspacePanel__dropIllustration { - overflow: visible; // Shows arrow animation when it gets out of bounds - margin-top: $euiSizeL; - margin-bottom: $euiSizeXXL; // Drop shadow values is a dupe of @euiBottomShadowMedium but used as a filter // Hard-coded px values OK (@cchaos) // sass-lint:disable-block indentation @@ -108,6 +120,10 @@ drop-shadow(0 2px 2px transparentize($euiShadowColor, .8)); } +.lnsDropIllustration__adjustFill { + fill: $euiColorFullShade; +} + .lnsDropIllustration__hand { animation: lnsWorkspacePanel__illustrationPulseArrow 5s ease-in-out 0s infinite normal forwards; } diff --git a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.test.tsx b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.test.tsx index 3aab4d6e7d85c..fcdbedff74a8d 100644 --- a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.test.tsx +++ b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.test.tsx @@ -17,7 +17,7 @@ import { disableAutoApply, selectTriggerApplyChanges, } from '../../../state_management'; -import { setChangesApplied } from '../../../state_management/lens_slice'; +import { enableAutoApply, setChangesApplied } from '../../../state_management/lens_slice'; describe('workspace_panel_wrapper', () => { let mockVisualization: jest.Mocked; @@ -83,19 +83,7 @@ describe('workspace_panel_wrapper', () => { } private get applyChangesButton() { - return this._instance.find('button[data-test-subj="lensApplyChanges"]'); - } - - private get autoApplyToggleSwitch() { - return this._instance.find('button[data-test-subj="lensToggleAutoApply"]'); - } - - toggleAutoApply() { - this.autoApplyToggleSwitch.simulate('click'); - } - - public get autoApplySwitchOn() { - return this.autoApplyToggleSwitch.prop('aria-checked'); + return this._instance.find('button[data-test-subj="lnsApplyChanges__toolbar"]'); } applyChanges() { @@ -135,28 +123,24 @@ describe('workspace_panel_wrapper', () => { harness = new Harness(instance); }); - it('toggles auto-apply', async () => { + it('shows and hides apply-changes button depending on whether auto-apply is enabled', async () => { store.dispatch(disableAutoApply()); harness.update(); - expect(selectAutoApplyEnabled(store.getState())).toBeFalsy(); - expect(harness.autoApplySwitchOn).toBeFalsy(); expect(harness.applyChangesExists).toBeTruthy(); - harness.toggleAutoApply(); + store.dispatch(enableAutoApply()); + harness.update(); - expect(selectAutoApplyEnabled(store.getState())).toBeTruthy(); - expect(harness.autoApplySwitchOn).toBeTruthy(); expect(harness.applyChangesExists).toBeFalsy(); - harness.toggleAutoApply(); + store.dispatch(disableAutoApply()); + harness.update(); - expect(selectAutoApplyEnabled(store.getState())).toBeFalsy(); - expect(harness.autoApplySwitchOn).toBeFalsy(); expect(harness.applyChangesExists).toBeTruthy(); }); - it('apply-changes button works', () => { + it('apply-changes button applies changes', () => { store.dispatch(disableAutoApply()); harness.update(); @@ -199,13 +183,11 @@ describe('workspace_panel_wrapper', () => { harness.update(); expect(harness.applyChangesDisabled).toBeFalsy(); - expect(harness.autoApplySwitchOn).toBeFalsy(); expect(harness.applyChangesExists).toBeTruthy(); - // enable auto apply - harness.toggleAutoApply(); + store.dispatch(enableAutoApply()); + harness.update(); - expect(harness.autoApplySwitchOn).toBeTruthy(); expect(harness.applyChangesExists).toBeFalsy(); }); }); diff --git a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.tsx b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.tsx index ab7dad2cb5fea..bb85ed4019412 100644 --- a/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.tsx +++ b/x-pack/plugins/lens/public/editor_frame_service/editor_frame/workspace_panel/workspace_panel_wrapper.tsx @@ -8,12 +8,9 @@ import './workspace_panel_wrapper.scss'; import React, { useCallback } from 'react'; -import { EuiPageContent, EuiFlexGroup, EuiFlexItem, EuiSwitch, EuiButton } from '@elastic/eui'; +import { EuiPageContent, EuiFlexGroup, EuiFlexItem, EuiButton } from '@elastic/eui'; import classNames from 'classnames'; import { FormattedMessage } from '@kbn/i18n-react'; -import { i18n } from '@kbn/i18n'; -import { trackUiEvent } from '../../../lens_ui_telemetry'; -import { Storage } from '../../../../../../../src/plugins/kibana_utils/public'; import { DatasourceMap, FramePublicAPI, VisualizationMap } from '../../../types'; import { NativeRenderer } from '../../../native_renderer'; import { ChartSwitch } from './chart_switch'; @@ -27,13 +24,10 @@ import { useLensSelector, selectChangesApplied, applyChanges, - enableAutoApply, - disableAutoApply, selectAutoApplyEnabled, } from '../../../state_management'; import { WorkspaceTitle } from './title'; import { DONT_CLOSE_DIMENSION_CONTAINER_ON_CLICK_CLASS } from '../config_panel/dimension_container'; -import { writeToStorage } from '../../../settings_storage'; export const AUTO_APPLY_DISABLED_STORAGE_KEY = 'autoApplyDisabled'; @@ -90,17 +84,6 @@ export function WorkspacePanelWrapper({ [dispatchLens] ); - const toggleAutoApply = useCallback(() => { - trackUiEvent('toggle_autoapply'); - - writeToStorage( - new Storage(localStorage), - AUTO_APPLY_DISABLED_STORAGE_KEY, - String(autoApplyEnabled) - ); - dispatchLens(autoApplyEnabled ? disableAutoApply() : enableAutoApply()); - }, [dispatchLens, autoApplyEnabled]); - const warningMessages: React.ReactNode[] = []; if (activeVisualization?.getWarningMessages) { warningMessages.push( @@ -119,102 +102,82 @@ export function WorkspacePanelWrapper({ }); return ( <> -
- - - - {!isFullscreen && ( - - - - - - {activeVisualization && activeVisualization.renderToolbar && ( - - - - )} - - - )} - - + {!(isFullscreen && (autoApplyEnabled || warningMessages?.length)) && ( +
+ + {!isFullscreen && ( + + - - {!autoApplyEnabled && ( + {activeVisualization && activeVisualization.renderToolbar && ( -
- dispatchLens(applyChanges())} - size="s" - data-test-subj="lensApplyChanges" - > - - -
+
)}
-
- - - {warningMessages && warningMessages.length ? ( - {warningMessages} - ) : null} - - -
+ )} + + + + {warningMessages?.length ? ( + {warningMessages} + ) : null} + + {!autoApplyEnabled && ( + +
+ dispatchLens(applyChanges())} + size="m" + data-test-subj="lnsApplyChanges__toolbar" + > + + +
+
+ )} +
+
+
+
+ )} { + it('should preserve apply-changes button with full-screen datasource', async () => { await PageObjects.lens.goToTimeRange(); + await PageObjects.lens.disableAutoApply(); + await PageObjects.lens.configureDimension({ dimension: 'lnsXY_yDimensionPanel > lns-empty-dimension', operation: 'formula', @@ -56,7 +60,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { PageObjects.lens.toggleFullscreen(); - expect(await PageObjects.lens.getAutoApplyToggleExists()).to.be.ok(); + expect(await PageObjects.lens.applyChangesExists('toolbar')).to.be.ok(); PageObjects.lens.toggleFullscreen(); @@ -79,9 +83,9 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { }); // assert that changes haven't been applied - await PageObjects.lens.waitForEmptyWorkspace(); + await PageObjects.lens.waitForWorkspaceWithApplyChangesPrompt(); - await PageObjects.lens.applyChanges(); + await PageObjects.lens.applyChanges('workspace'); await PageObjects.lens.waitForVisualization('xyVisChart'); }); @@ -89,11 +93,11 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { it('should hide suggestions when a change is made', async () => { await PageObjects.lens.switchToVisualization('lnsDatatable'); - expect(await PageObjects.lens.getAreSuggestionsPromptingToApply()).to.be.ok(); + expect(await PageObjects.lens.applyChangesExists('suggestions')).to.be.ok(); - await PageObjects.lens.applyChanges(true); + await PageObjects.lens.applyChanges('suggestions'); - expect(await PageObjects.lens.getAreSuggestionsPromptingToApply()).not.to.be.ok(); + expect(await PageObjects.lens.applyChangesExists('suggestions')).not.to.be.ok(); }); }); } diff --git a/x-pack/test/functional/apps/lens/smokescreen.ts b/x-pack/test/functional/apps/lens/smokescreen.ts index c2a98d2d5dedc..13525ed0ec9c2 100644 --- a/x-pack/test/functional/apps/lens/smokescreen.ts +++ b/x-pack/test/functional/apps/lens/smokescreen.ts @@ -145,7 +145,7 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { expect(await PageObjects.lens.getLayerCount()).to.eql(2); await PageObjects.lens.removeLayer(); await PageObjects.lens.removeLayer(); - await testSubjects.existOrFail('empty-workspace'); + await testSubjects.existOrFail('workspace-drag-drop-prompt'); }); it('should edit settings of xy line chart', async () => { diff --git a/x-pack/test/functional/page_objects/lens_page.ts b/x-pack/test/functional/page_objects/lens_page.ts index fa46052705c91..5a95b195fb0c0 100644 --- a/x-pack/test/functional/page_objects/lens_page.ts +++ b/x-pack/test/functional/page_objects/lens_page.ts @@ -276,7 +276,13 @@ export function LensPageProvider({ getService, getPageObjects }: FtrProviderCont async waitForEmptyWorkspace() { await retry.try(async () => { - await testSubjects.existOrFail(`empty-workspace`); + await testSubjects.existOrFail(`workspace-drag-drop-prompt`); + }); + }, + + async waitForWorkspaceWithApplyChangesPrompt() { + await retry.try(async () => { + await testSubjects.existOrFail(`workspace-apply-changes-prompt`); }); }, @@ -1336,32 +1342,48 @@ export function LensPageProvider({ getService, getPageObjects }: FtrProviderCont return testSubjects.exists('lnsEmptySizeRatioButtonGroup'); }, - getAutoApplyToggleExists() { - return testSubjects.exists('lensToggleAutoApply'); + settingsMenuOpen() { + return testSubjects.exists('lnsApp__settingsMenu'); }, - enableAutoApply() { - return testSubjects.setEuiSwitch('lensToggleAutoApply', 'check'); + async openSettingsMenu() { + if (await this.settingsMenuOpen()) return; + + await testSubjects.click('lnsApp_settingsButton'); }, - disableAutoApply() { - return testSubjects.setEuiSwitch('lensToggleAutoApply', 'uncheck'); + async closeSettingsMenu() { + if (!(await this.settingsMenuOpen())) return; + + await testSubjects.click('lnsApp_settingsButton'); }, - getAutoApplyEnabled() { - return testSubjects.isEuiSwitchChecked('lensToggleAutoApply'); + async enableAutoApply() { + await this.openSettingsMenu(); + + return testSubjects.setEuiSwitch('lnsToggleAutoApply', 'check'); }, - async applyChanges(throughSuggestions = false) { - const applyButtonSelector = throughSuggestions - ? 'lnsSuggestionApplyChanges' - : 'lensApplyChanges'; - await testSubjects.waitForEnabled(applyButtonSelector); - await testSubjects.click(applyButtonSelector); + async disableAutoApply() { + await this.openSettingsMenu(); + + return testSubjects.setEuiSwitch('lnsToggleAutoApply', 'uncheck'); + }, + + async getAutoApplyEnabled() { + await this.openSettingsMenu(); + + return testSubjects.isEuiSwitchChecked('lnsToggleAutoApply'); }, - async getAreSuggestionsPromptingToApply() { - return testSubjects.exists('lnsSuggestionApplyChanges'); + applyChangesExists(whichButton: 'toolbar' | 'suggestions' | 'workspace') { + return testSubjects.exists(`lnsApplyChanges__${whichButton}`); + }, + + async applyChanges(whichButton: 'toolbar' | 'suggestions' | 'workspace') { + const applyButtonSelector = `lnsApplyChanges__${whichButton}`; + await testSubjects.waitForEnabled(applyButtonSelector); + await testSubjects.click(applyButtonSelector); }, }); } From d579ea73b9a58f1c3d61c31d26a8a9e571bdef7b Mon Sep 17 00:00:00 2001 From: Ashokaditya <1849116+ashokaditya@users.noreply.github.com> Date: Tue, 29 Mar 2022 23:10:14 +0200 Subject: [PATCH 129/160] [Security Solution][Endpoint] Fix event filter creation success toast (#128810) * Show creation success toast on adding first event filter fixes elastic/kibana/issues/128444 * clean up redundant type imports refs elastic/kibana/pull/100310/ --- .../pages/event_filters/store/middleware.ts | 7 +++---- .../pages/event_filters/view/translations.ts | 13 +++---------- 2 files changed, 6 insertions(+), 14 deletions(-) diff --git a/x-pack/plugins/security_solution/public/management/pages/event_filters/store/middleware.ts b/x-pack/plugins/security_solution/public/management/pages/event_filters/store/middleware.ts index 83526c907e73f..a8bf725e61b2a 100644 --- a/x-pack/plugins/security_solution/public/management/pages/event_filters/store/middleware.ts +++ b/x-pack/plugins/security_solution/public/management/pages/event_filters/store/middleware.ts @@ -89,10 +89,6 @@ const eventFiltersCreate: MiddlewareActionHandler = async (store, eventFiltersSe const exception = await eventFiltersService.addEventFilters(updatedCommentsEntry); - store.dispatch({ - type: 'eventFiltersCreateSuccess', - }); - store.dispatch({ type: 'eventFiltersFormStateChanged', payload: { @@ -100,6 +96,9 @@ const eventFiltersCreate: MiddlewareActionHandler = async (store, eventFiltersSe data: exception, }, }); + store.dispatch({ + type: 'eventFiltersCreateSuccess', + }); } catch (error) { store.dispatch({ type: 'eventFiltersFormStateChanged', diff --git a/x-pack/plugins/security_solution/public/management/pages/event_filters/view/translations.ts b/x-pack/plugins/security_solution/public/management/pages/event_filters/view/translations.ts index ae8012711fbf1..6177fb7822c92 100644 --- a/x-pack/plugins/security_solution/public/management/pages/event_filters/view/translations.ts +++ b/x-pack/plugins/security_solution/public/management/pages/event_filters/view/translations.ts @@ -7,24 +7,17 @@ import { i18n } from '@kbn/i18n'; -import type { - CreateExceptionListItemSchema, - UpdateExceptionListItemSchema, -} from '@kbn/securitysolution-io-ts-list-types'; import { ServerApiError } from '../../../../common/types'; +import { EventFiltersForm } from '../types'; -export const getCreationSuccessMessage = ( - entry: CreateExceptionListItemSchema | UpdateExceptionListItemSchema | undefined -) => { +export const getCreationSuccessMessage = (entry: EventFiltersForm['entry']) => { return i18n.translate('xpack.securitySolution.eventFilter.form.creationSuccessToastTitle', { defaultMessage: '"{name}" has been added to the event filters list.', values: { name: entry?.name }, }); }; -export const getUpdateSuccessMessage = ( - entry: CreateExceptionListItemSchema | UpdateExceptionListItemSchema | undefined -) => { +export const getUpdateSuccessMessage = (entry: EventFiltersForm['entry']) => { return i18n.translate('xpack.securitySolution.eventFilter.form.updateSuccessToastTitle', { defaultMessage: '"{name}" has been updated successfully.', values: { name: entry?.name }, From ac5603b267eb5b69734758b5412f6cf10a35d514 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Tue, 29 Mar 2022 22:12:19 +0100 Subject: [PATCH 130/160] fix(NA): do not declare @types packages as prod dependencies when generating the pkg.json (#128805) --- package.json | 10 +++++----- packages/kbn-generate/src/commands/package_command.ts | 8 ++++++-- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index 1906f3af232b7..adc45d9afadd7 100644 --- a/package.json +++ b/package.json @@ -200,11 +200,6 @@ "@turf/helpers": "6.0.1", "@turf/length": "^6.0.2", "@types/jsonwebtoken": "^8.5.6", - "@types/kbn__plugin-discovery": "link:bazel-bin/packages/kbn-plugin-discovery/npm_module_types", - "@types/kbn__shared-ux-components": "link:bazel-bin/packages/kbn-shared-ux-components/npm_module_types", - "@types/kbn__shared-ux-services": "link:bazel-bin/packages/kbn-shared-ux-services/npm_module_types", - "@types/kbn__shared-ux-storybook": "link:bazel-bin/packages/kbn-shared-ux-storybook/npm_module_types", - "@types/kbn__shared-ux-utility": "link:bazel-bin/packages/kbn-shared-ux-utility/npm_module_types", "@types/moment-duration-format": "^2.2.3", "JSONStream": "1.3.5", "abort-controller": "^3.0.0", @@ -608,6 +603,7 @@ "@types/kbn__mapbox-gl": "link:bazel-bin/packages/kbn-mapbox-gl/npm_module_types", "@types/kbn__monaco": "link:bazel-bin/packages/kbn-monaco/npm_module_types", "@types/kbn__optimizer": "link:bazel-bin/packages/kbn-optimizer/npm_module_types", + "@types/kbn__plugin-discovery": "link:bazel-bin/packages/kbn-plugin-discovery/npm_module_types", "@types/kbn__plugin-generator": "link:bazel-bin/packages/kbn-plugin-generator/npm_module_types", "@types/kbn__plugin-helpers": "link:bazel-bin/packages/kbn-plugin-helpers/npm_module_types", "@types/kbn__react-field": "link:bazel-bin/packages/kbn-react-field/npm_module_types", @@ -628,6 +624,10 @@ "@types/kbn__securitysolution-utils": "link:bazel-bin/packages/kbn-securitysolution-utils/npm_module_types", "@types/kbn__server-http-tools": "link:bazel-bin/packages/kbn-server-http-tools/npm_module_types", "@types/kbn__server-route-repository": "link:bazel-bin/packages/kbn-server-route-repository/npm_module_types", + "@types/kbn__shared-ux-components": "link:bazel-bin/packages/kbn-shared-ux-components/npm_module_types", + "@types/kbn__shared-ux-services": "link:bazel-bin/packages/kbn-shared-ux-services/npm_module_types", + "@types/kbn__shared-ux-storybook": "link:bazel-bin/packages/kbn-shared-ux-storybook/npm_module_types", + "@types/kbn__shared-ux-utility": "link:bazel-bin/packages/kbn-shared-ux-utility/npm_module_types", "@types/kbn__std": "link:bazel-bin/packages/kbn-std/npm_module_types", "@types/kbn__storybook": "link:bazel-bin/packages/kbn-storybook/npm_module_types", "@types/kbn__telemetry-tools": "link:bazel-bin/packages/kbn-telemetry-tools/npm_module_types", diff --git a/packages/kbn-generate/src/commands/package_command.ts b/packages/kbn-generate/src/commands/package_command.ts index abf4434b78bcd..074f48d26114b 100644 --- a/packages/kbn-generate/src/commands/package_command.ts +++ b/packages/kbn-generate/src/commands/package_command.ts @@ -133,9 +133,13 @@ ${BAZEL_PACKAGE_DIRS.map((rel) => ` ${rel}\n`).join('')} : [packageJson.dependencies, packageJson.devDependencies]; addDeps[name] = `link:bazel-bin/${normalizedRepoRelativeDir}`; - addDeps[typePkgName] = `link:bazel-bin/${normalizedRepoRelativeDir}/npm_module_types`; delete removeDeps[name]; - delete removeDeps[typePkgName]; + + // for @types packages always remove from deps and add to devDeps + packageJson.devDependencies[ + typePkgName + ] = `link:bazel-bin/${normalizedRepoRelativeDir}/npm_module_types`; + delete packageJson.dependencies[typePkgName]; await Fsp.writeFile(packageJsonPath, sortPackageJson(JSON.stringify(packageJson))); log.info('Updated package.json file'); From 18c7f4d0328c290c92b135d1b452fb4636d8c04b Mon Sep 17 00:00:00 2001 From: Tyler Smalley Date: Tue, 29 Mar 2022 14:20:34 -0700 Subject: [PATCH 131/160] Revert "Add a tour showing new rules search capabilities (#128759)" This reverts commit 02a146f7e4fd069c51d964da37460d63d980e829. --- .../security_solution/common/constants.ts | 2 +- .../detection_engine/rules/api.test.ts | 6 +- .../detection_engine/rules/utils.test.ts | 6 +- .../detection_engine/rules/utils.ts | 2 - .../rules_feature_tour_context.tsx | 74 +++++----- .../rules/all/feature_tour/translations.ts | 15 -- .../detection_engine/rules/all/index.test.tsx | 7 +- .../rules_table_filters.test.tsx | 9 +- .../rules_table_filters.tsx | 32 ++--- .../pages/detection_engine/rules/index.tsx | 135 +++++++++--------- .../detection_engine/rules/translations.ts | 3 +- 11 files changed, 127 insertions(+), 164 deletions(-) diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index f7bdc889f9c33..591c7d68e17cb 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -443,7 +443,7 @@ export const RULES_TABLE_PAGE_SIZE_OPTIONS = [5, 10, 20, 50, RULES_TABLE_MAX_PAG * we will need to update this constant with the corresponding version. */ export const RULES_MANAGEMENT_FEATURE_TOUR_STORAGE_KEY = - 'securitySolution.rulesManagementPage.newFeaturesTour.v8.2'; + 'securitySolution.rulesManagementPage.newFeaturesTour.v8.1'; export const RULE_DETAILS_EXECUTION_LOG_TABLE_SHOW_METRIC_COLUMNS_STORAGE_KEY = 'securitySolution.ruleDetails.ruleExecutionLog.showMetrics.v8.2'; diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts index 3c534ca7294a5..c8d8b5bb6ffd0 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/api.test.ts @@ -143,7 +143,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - '(alert.attributes.name: "hello world" OR alert.attributes.params.index: "hello world" OR alert.attributes.params.threat.tactic.id: "hello world" OR alert.attributes.params.threat.tactic.name: "hello world" OR alert.attributes.params.threat.technique.id: "hello world" OR alert.attributes.params.threat.technique.name: "hello world" OR alert.attributes.params.threat.technique.subtechnique.id: "hello world" OR alert.attributes.params.threat.technique.subtechnique.name: "hello world")', + '(alert.attributes.name: "hello world" OR alert.attributes.params.index: "hello world" OR alert.attributes.params.threat.tactic.id: "hello world" OR alert.attributes.params.threat.tactic.name: "hello world" OR alert.attributes.params.threat.technique.id: "hello world" OR alert.attributes.params.threat.technique.name: "hello world")', page: 1, per_page: 20, sort_field: 'enabled', @@ -172,7 +172,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - '(alert.attributes.name: "\\" OR (foo:bar)" OR alert.attributes.params.index: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.subtechnique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.subtechnique.name: "\\" OR (foo:bar)")', + '(alert.attributes.name: "\\" OR (foo:bar)" OR alert.attributes.params.index: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo:bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo:bar)")', page: 1, per_page: 20, sort_field: 'enabled', @@ -383,7 +383,7 @@ describe('Detections Rules API', () => { method: 'GET', query: { filter: - 'alert.attributes.tags: "__internal_immutable:false" AND alert.attributes.tags: "__internal_immutable:true" AND alert.attributes.tags:("hello" AND "world") AND (alert.attributes.name: "ruleName" OR alert.attributes.params.index: "ruleName" OR alert.attributes.params.threat.tactic.id: "ruleName" OR alert.attributes.params.threat.tactic.name: "ruleName" OR alert.attributes.params.threat.technique.id: "ruleName" OR alert.attributes.params.threat.technique.name: "ruleName" OR alert.attributes.params.threat.technique.subtechnique.id: "ruleName" OR alert.attributes.params.threat.technique.subtechnique.name: "ruleName")', + 'alert.attributes.tags: "__internal_immutable:false" AND alert.attributes.tags: "__internal_immutable:true" AND alert.attributes.tags:("hello" AND "world") AND (alert.attributes.name: "ruleName" OR alert.attributes.params.index: "ruleName" OR alert.attributes.params.threat.tactic.id: "ruleName" OR alert.attributes.params.threat.tactic.name: "ruleName" OR alert.attributes.params.threat.technique.id: "ruleName" OR alert.attributes.params.threat.technique.name: "ruleName")', page: 1, per_page: 20, sort_field: 'enabled', diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts index a26a4aec3ec02..e3d2300972a51 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.test.ts @@ -27,7 +27,7 @@ describe('convertRulesFilterToKQL', () => { const kql = convertRulesFilterToKQL({ ...filterOptions, filter: 'foo' }); expect(kql).toBe( - '(alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo" OR alert.attributes.params.threat.technique.subtechnique.id: "foo" OR alert.attributes.params.threat.technique.subtechnique.name: "foo")' + '(alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo")' ); }); @@ -35,7 +35,7 @@ describe('convertRulesFilterToKQL', () => { const kql = convertRulesFilterToKQL({ ...filterOptions, filter: '" OR (foo: bar)' }); expect(kql).toBe( - '(alert.attributes.name: "\\" OR (foo: bar)" OR alert.attributes.params.index: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.subtechnique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.subtechnique.name: "\\" OR (foo: bar)")' + '(alert.attributes.name: "\\" OR (foo: bar)" OR alert.attributes.params.index: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.tactic.name: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.id: "\\" OR (foo: bar)" OR alert.attributes.params.threat.technique.name: "\\" OR (foo: bar)")' ); }); @@ -66,7 +66,7 @@ describe('convertRulesFilterToKQL', () => { }); expect(kql).toBe( - `alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true" AND alert.attributes.tags:("tag1" AND "tag2") AND (alert.attributes.name: "foo" OR alert.attributes.params.index: "foo" OR alert.attributes.params.threat.tactic.id: "foo" OR alert.attributes.params.threat.tactic.name: "foo" OR alert.attributes.params.threat.technique.id: "foo" OR alert.attributes.params.threat.technique.name: "foo" OR alert.attributes.params.threat.technique.subtechnique.id: "foo" OR alert.attributes.params.threat.technique.subtechnique.name: "foo")` + `alert.attributes.tags: "${INTERNAL_IMMUTABLE_KEY}:true" AND alert.attributes.tags:(\"tag1\" AND \"tag2\") AND (alert.attributes.name: \"foo\" OR alert.attributes.params.index: \"foo\" OR alert.attributes.params.threat.tactic.id: \"foo\" OR alert.attributes.params.threat.tactic.name: \"foo\" OR alert.attributes.params.threat.technique.id: \"foo\" OR alert.attributes.params.threat.technique.name: \"foo\")` ); }); }); diff --git a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts index 069746223731c..f5e52fd6362c1 100644 --- a/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts +++ b/x-pack/plugins/security_solution/public/detections/containers/detection_engine/rules/utils.ts @@ -16,8 +16,6 @@ const SEARCHABLE_RULE_PARAMS = [ 'alert.attributes.params.threat.tactic.name', 'alert.attributes.params.threat.technique.id', 'alert.attributes.params.threat.technique.name', - 'alert.attributes.params.threat.technique.subtechnique.id', - 'alert.attributes.params.threat.technique.subtechnique.name', ]; /** diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx index b0f0b0f17923c..aaa483e49fca7 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/rules_feature_tour_context.tsx @@ -43,13 +43,23 @@ const tourConfig: EuiTourState = { const stepsConfig: EuiStatelessTourStep[] = [ { step: 1, - title: i18n.SEARCH_CAPABILITIES_TITLE, - content:

{i18n.SEARCH_CAPABILITIES_DESCRIPTION}

, - stepsTotal: 1, + title: 'A new feature', + content:

{'This feature allows for...'}

, + stepsTotal: 2, children: <>, onFinish: noop, maxWidth: TOUR_POPOVER_WIDTH, }, + { + step: 2, + title: 'Another feature', + content:

{'This another feature allows for...'}

, + stepsTotal: 2, + children: <>, + onFinish: noop, + anchorPosition: 'rightUp', + maxWidth: TOUR_POPOVER_WIDTH, + }, ]; const RulesFeatureTourContext = createContext(null); @@ -72,43 +82,39 @@ export const RulesFeatureTourContextProvider: FC = ({ children }) => { const [tourSteps, tourActions, tourState] = useEuiTour(stepsConfig, restoredState); - const enhancedSteps = useMemo( - () => - tourSteps.map((item, index) => ({ + const enhancedSteps = useMemo(() => { + return tourSteps.map((item, index, array) => { + return { ...item, content: ( <> {item.content} - {tourSteps.length > 1 && ( - <> - - - - - - - - - - - )} + + + + + + + + + ), - })), - [tourSteps, tourActions] - ); + }; + }); + }, [tourSteps, tourActions]); const providerValue = useMemo( () => ({ steps: enhancedSteps, actions: tourActions }), diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts index 88b5489b01eaa..bfcda64bb13dd 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/feature_tour/translations.ts @@ -13,18 +13,3 @@ export const TOUR_TITLE = i18n.translate( defaultMessage: "What's new", } ); - -export const SEARCH_CAPABILITIES_TITLE = i18n.translate( - 'xpack.securitySolution.detectionEngine.rules.allRules.featureTour.searchCapabilitiesTitle', - { - defaultMessage: 'Enhanced search capabilities', - } -); - -export const SEARCH_CAPABILITIES_DESCRIPTION = i18n.translate( - 'xpack.securitySolution.detectionEngine.rules.allRules.featureTour.searchCapabilitiesDescription', - { - defaultMessage: - 'It is now possible to search rules by index patterns, like "filebeat-*", or by MITRE ATT&CK™ tactics or techniques, like "Defense Evasion" or "TA0005".', - } -); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx index 8e44475a7992e..3b24dda539174 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/index.test.tsx @@ -12,7 +12,6 @@ import { useKibana } from '../../../../../common/lib/kibana'; import { TestProviders } from '../../../../../common/mock'; import '../../../../../common/mock/formatted_relative'; import '../../../../../common/mock/match_media'; -import { RulesFeatureTourContextProvider } from './feature_tour/rules_feature_tour_context'; import { AllRules } from './index'; jest.mock('../../../../../common/components/link_to'); @@ -68,8 +67,7 @@ describe('AllRules', () => { rulesNotInstalled={0} rulesNotUpdated={0} /> - , - { wrappingComponent: RulesFeatureTourContextProvider } + ); await waitFor(() => { @@ -92,8 +90,7 @@ describe('AllRules', () => { rulesNotInstalled={0} rulesNotUpdated={0} /> - , - { wrappingComponent: RulesFeatureTourContextProvider } + ); await waitFor(() => { diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx index 88b8e952d215a..816ffdfa9dad6 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.test.tsx @@ -10,16 +10,13 @@ import { mount } from 'enzyme'; import { RulesTableFilters } from './rules_table_filters'; import { TestProviders } from '../../../../../../common/mock'; -import { RulesFeatureTourContextProvider } from '../feature_tour/rules_feature_tour_context'; jest.mock('../rules_table/rules_table_context'); describe('RulesTableFilters', () => { it('renders no numbers next to rule type button filter if none exist', async () => { const wrapper = mount( - - - , + , { wrappingComponent: TestProviders } ); @@ -33,9 +30,7 @@ describe('RulesTableFilters', () => { it('renders number of custom and prepackaged rules', async () => { const wrapper = mount( - - - , + , { wrappingComponent: TestProviders } ); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx index 7e3263f6bb26a..b4c81ae5a177d 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/rules_table_filters/rules_table_filters.tsx @@ -11,13 +11,11 @@ import { EuiFilterGroup, EuiFlexGroup, EuiFlexItem, - EuiTourStep, } from '@elastic/eui'; import { isEqual } from 'lodash/fp'; import React, { useCallback } from 'react'; import styled from 'styled-components'; import * as i18n from '../../translations'; -import { useRulesFeatureTourContext } from '../feature_tour/rules_feature_tour_context'; import { useRulesTableContext } from '../rules_table/rules_table_context'; import { TagsFilterPopover } from './tags_filter_popover'; @@ -25,14 +23,6 @@ const FilterWrapper = styled(EuiFlexGroup)` margin-bottom: ${({ theme }) => theme.eui.euiSizeXS}; `; -const SearchBarWrapper = styled(EuiFlexItem)` - & .euiPopover__anchor { - // This is needed to "cancel" styles passed down from EuiTourStep that - // interfere with EuiFieldSearch and don't allow it to take the full width - display: block; - } -`; - interface RulesTableFiltersProps { rulesCustomInstalled: number | null; rulesInstalled: number | null; @@ -55,8 +45,6 @@ const RulesTableFiltersComponent = ({ const { showCustomRules, showElasticRules, tags: selectedTags } = filterOptions; - const { steps } = useRulesFeatureTourContext(); - const handleOnSearch = useCallback( (filterString) => setFilterOptions({ filter: filterString.trim() }), [setFilterOptions] @@ -81,17 +69,15 @@ const RulesTableFiltersComponent = ({ return ( - - - - - + + + { const [isImportModalVisible, showImportModal, hideImportModal] = useBoolState(); @@ -178,79 +177,77 @@ const RulesPageComponent: React.FC = () => { showCheckBox /> - - - - - - {loadPrebuiltRulesAndTemplatesButton && ( - {loadPrebuiltRulesAndTemplatesButton} - )} - {reloadPrebuiltRulesAndTemplatesButton && ( - {reloadPrebuiltRulesAndTemplatesButton} - )} - - - - {i18n.UPLOAD_VALUE_LISTS} - - - - + + + + + {loadPrebuiltRulesAndTemplatesButton && ( + {loadPrebuiltRulesAndTemplatesButton} + )} + {reloadPrebuiltRulesAndTemplatesButton && ( + {reloadPrebuiltRulesAndTemplatesButton} + )} + + - {i18n.IMPORT_RULE} + {i18n.UPLOAD_VALUE_LISTS} - - - - {i18n.ADD_NEW_RULE} - - - - - {(prePackagedRuleStatus === 'ruleNeedUpdate' || - prePackagedTimelineStatus === 'timelineNeedUpdate') && ( - - )} - + + + + {i18n.IMPORT_RULE} + + + + + {i18n.ADD_NEW_RULE} + + + + + {(prePackagedRuleStatus === 'ruleNeedUpdate' || + prePackagedTimelineStatus === 'timelineNeedUpdate') && ( + - - - + )} + + + diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts index 09949cc5c1a09..f99ebc2c72c26 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/translations.ts @@ -408,8 +408,7 @@ export const SEARCH_RULES = i18n.translate( export const SEARCH_PLACEHOLDER = i18n.translate( 'xpack.securitySolution.detectionEngine.rules.allRules.searchPlaceholder', { - defaultMessage: - 'Rule name, index pattern (e.g., "filebeat-*"), or MITRE ATT&CK™ tactic or technique (e.g., "Defense Evasion" or "TA0005")', + defaultMessage: 'Search by rule name, index pattern, or MITRE ATT&CK tactic or technique', } ); From 0b26abb5a84f9bdd29a4192e29197bfbcf0aeeb2 Mon Sep 17 00:00:00 2001 From: Robert Austin Date: Tue, 29 Mar 2022 17:39:39 -0400 Subject: [PATCH 132/160] Security Solution: Improve client side perf: `getAllBrowserFields` (#128818) The `getAllBrowserFields` function is called a lot when loading the overview and alerts pages. This commit optimizes the function. --- .../source/__snapshots__/index.test.tsx.snap | 544 ++++++++++++++++++ .../common/containers/source/index.test.tsx | 7 +- .../public/common/containers/source/index.tsx | 17 +- 3 files changed, 559 insertions(+), 9 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/common/containers/source/__snapshots__/index.test.tsx.snap diff --git a/x-pack/plugins/security_solution/public/common/containers/source/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/common/containers/source/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000000..3924f81c001ba --- /dev/null +++ b/x-pack/plugins/security_solution/public/common/containers/source/__snapshots__/index.test.tsx.snap @@ -0,0 +1,544 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`source/index.tsx getAllBrowserFields it returns an array of all fields in the BrowserFields argument 1`] = ` +Array [ + Object { + "aggregatable": true, + "category": "agent", + "description": "Ephemeral identifier of this agent (if one exists). This id normally changes across restarts, but \`agent.id\` does not.", + "example": "8a4f500f", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "agent.ephemeral_id", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "agent", + "description": null, + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "agent.hostname", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "agent", + "description": "Unique identifier of this agent (if one exists). Example: For Beats this would be beat.id.", + "example": "8a4f500d", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "agent.id", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "agent", + "description": "Name of the agent. This is a name that can be given to an agent. This can be helpful if for example two Filebeat instances are running on the same host but a human readable separation is needed on which Filebeat instance data is coming from. If no name is given, the name is often left empty.", + "example": "foo", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "agent.name", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "auditd", + "description": null, + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + ], + "name": "auditd.data.a0", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "auditd", + "description": null, + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + ], + "name": "auditd.data.a1", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "auditd", + "description": null, + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + ], + "name": "auditd.data.a2", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "base", + "description": "Date/time when the event originated. For log events this is the date/time when the event was generated, and not when it was read. Required field for all events.", + "example": "2016-05-23T08:05:34.853Z", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "@timestamp", + "readFromDocValues": true, + "searchable": true, + "type": "date", + }, + Object { + "aggregatable": false, + "category": "base", + "description": "Each document has an _id that uniquely identifies it", + "example": "Y-6TfmcB0WOhS6qyMv3s", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "_id", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": false, + "category": "base", + "description": "For log events the message field contains the log message, optimized for viewing in a log viewer. For structured logs without an original message field, other fields can be concatenated to form a human-readable summary of the event. If multiple messages exist, they can be combined into one message.", + "example": "Hello World", + "format": "string", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "message", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "client", + "description": "Some event client addresses are defined ambiguously. The event will sometimes list an IP, a domain or a unix socket. You should always store the raw address in the \`.address\` field. Then it should be duplicated to \`.ip\` or \`.domain\`, depending on which one it is.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "client.address", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "client", + "description": "Bytes sent from the client to the server.", + "example": "184", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "client.bytes", + "searchable": true, + "type": "number", + }, + Object { + "aggregatable": true, + "category": "client", + "description": "Client domain.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "client.domain", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "client", + "description": "Country ISO code.", + "example": "CA", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "client.geo.country_iso_code", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "cloud", + "description": "The cloud account or organization id used to identify different entities in a multi-tenant environment. Examples: AWS account id, Google Cloud ORG Id, or other unique identifier.", + "example": "666777888999", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "cloud.account.id", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "cloud", + "description": "Availability zone in which this host is running.", + "example": "us-east-1c", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "cloud.availability_zone", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "container", + "description": "Unique container id.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "container.id", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "container", + "description": "Name of the image the container was built on.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "container.image.name", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "container", + "description": "Container image tag.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "container.image.tag", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "destination", + "description": "Some event destination addresses are defined ambiguously. The event will sometimes list an IP, a domain or a unix socket. You should always store the raw address in the \`.address\` field. Then it should be duplicated to \`.ip\` or \`.domain\`, depending on which one it is.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "destination.address", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "destination", + "description": "Bytes sent from the destination to the source.", + "example": "184", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "destination.bytes", + "searchable": true, + "type": "number", + }, + Object { + "aggregatable": true, + "category": "destination", + "description": "Destination domain.", + "example": null, + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "destination.domain", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "destination", + "description": "IP address of the destination. Can be one or multiple IPv4 or IPv6 addresses.", + "example": "", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "destination.ip", + "searchable": true, + "type": "ip", + }, + Object { + "aggregatable": true, + "category": "destination", + "description": "Port of the destination.", + "example": "", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "destination.port", + "searchable": true, + "type": "long", + }, + Object { + "aggregatable": true, + "category": "event", + "description": "event.end contains the date when the event ended or when the activity was last observed.", + "example": null, + "format": "", + "indexes": Array [ + "apm-*-transaction*", + "traces-apm*", + "auditbeat-*", + "endgame-*", + "filebeat-*", + "logs-*", + "packetbeat-*", + "winlogbeat-*", + ], + "name": "event.end", + "searchable": true, + "type": "date", + }, + Object { + "aggregatable": true, + "category": "event", + "description": "The action captured by the event. This describes the information in the event. It is more specific than \`event.category\`. Examples are \`group-add\`, \`process-started\`, \`file-created\`. The value is normally defined by the implementer.", + "example": "user-password-change", + "format": "string", + "indexes": Array [ + "apm-*-transaction*", + "traces-apm*", + "auditbeat-*", + "endgame-*", + "filebeat-*", + "logs-*", + "packetbeat-*", + "winlogbeat-*", + ], + "name": "event.action", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "event", + "description": "This is one of four ECS Categorization Fields, and indicates the second level in the ECS category hierarchy. \`event.category\` represents the \\"big buckets\\" of ECS categories. For example, filtering on \`event.category:process\` yields all events relating to process activity. This field is closely related to \`event.type\`, which is used as a subcategory. This field is an array. This will allow proper categorization of some events that fall in multiple categories.", + "example": "authentication", + "format": "string", + "indexes": Array [ + "apm-*-transaction*", + "traces-apm*", + "auditbeat-*", + "endgame-*", + "filebeat-*", + "logs-*", + "packetbeat-*", + "winlogbeat-*", + ], + "name": "event.category", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "event", + "description": "The numeric severity of the event according to your event source. What the different severity values mean can be different between sources and use cases. It's up to the implementer to make sure severities are consistent across events from the same source. The Syslog severity belongs in \`log.syslog.severity.code\`. \`event.severity\` is meant to represent the severity according to the event source (e.g. firewall, IDS). If the event source does not publish its own severity, you may optionally copy the \`log.syslog.severity.code\` to \`event.severity\`.", + "example": 7, + "format": "number", + "indexes": Array [ + "apm-*-transaction*", + "traces-apm*", + "auditbeat-*", + "endgame-*", + "filebeat-*", + "logs-*", + "packetbeat-*", + "winlogbeat-*", + ], + "name": "event.severity", + "searchable": true, + "type": "number", + }, + Object { + "aggregatable": true, + "category": "host", + "description": "Name of the host. It can contain what \`hostname\` returns on Unix systems, the fully qualified domain name, or a name specified by the user. The sender decides which value to use.", + "format": "string", + "indexes": Array [ + "apm-*-transaction*", + "traces-apm*", + "auditbeat-*", + "endgame-*", + "filebeat-*", + "logs-*", + "packetbeat-*", + "winlogbeat-*", + ], + "name": "host.name", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": true, + "category": "source", + "description": "IP address of the source. Can be one or multiple IPv4 or IPv6 addresses.", + "example": "", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "source.ip", + "searchable": true, + "type": "ip", + }, + Object { + "aggregatable": true, + "category": "source", + "description": "Port of the source.", + "example": "", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "source.port", + "searchable": true, + "type": "long", + }, + Object { + "aggregatable": true, + "category": "user", + "description": "Short name or login of the user.", + "example": "albert", + "format": "string", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "user.name", + "searchable": true, + "type": "string", + }, + Object { + "aggregatable": false, + "category": "nestedField", + "description": "", + "example": "", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "nestedField.firstAttributes", + "searchable": true, + "subType": Object { + "nested": Object { + "path": "nestedField", + }, + }, + "type": "string", + }, + Object { + "aggregatable": false, + "category": "nestedField", + "description": "", + "example": "", + "format": "", + "indexes": Array [ + "auditbeat", + "filebeat", + "packetbeat", + ], + "name": "nestedField.secondAttributes", + "searchable": true, + "subType": Object { + "nested": Object { + "path": "nestedField", + }, + }, + "type": "string", + }, +] +`; diff --git a/x-pack/plugins/security_solution/public/common/containers/source/index.test.tsx b/x-pack/plugins/security_solution/public/common/containers/source/index.test.tsx index fd3f35059c6fb..8b1902cbc5e6b 100644 --- a/x-pack/plugins/security_solution/public/common/containers/source/index.test.tsx +++ b/x-pack/plugins/security_solution/public/common/containers/source/index.test.tsx @@ -6,7 +6,7 @@ */ import { IndexField } from '../../../../common/search_strategy/index_fields'; -import { getBrowserFields } from '.'; +import { getBrowserFields, getAllBrowserFields } from '.'; import { IndexFieldSearch, useDataView } from './use_data_view'; import { mockBrowserFields, mocksSource } from './mock'; import { mockGlobalState, TestProviders } from '../../mock'; @@ -25,6 +25,11 @@ jest.mock('react-redux', () => { jest.mock('../../lib/kibana'); describe('source/index.tsx', () => { + describe('getAllBrowserFields', () => { + test('it returns an array of all fields in the BrowserFields argument', () => { + expect(getAllBrowserFields(mockBrowserFields)).toMatchSnapshot(); + }); + }); describe('getBrowserFields', () => { test('it returns an empty object given an empty array', () => { const fields = getBrowserFields('title 1', []); diff --git a/x-pack/plugins/security_solution/public/common/containers/source/index.tsx b/x-pack/plugins/security_solution/public/common/containers/source/index.tsx index f833c2f8c4fc0..7cc37b5f7e6e3 100644 --- a/x-pack/plugins/security_solution/public/common/containers/source/index.tsx +++ b/x-pack/plugins/security_solution/public/common/containers/source/index.tsx @@ -26,14 +26,15 @@ import { useAppToasts } from '../../hooks/use_app_toasts'; export type { BrowserField, BrowserFields, DocValueFields }; -export const getAllBrowserFields = (browserFields: BrowserFields): Array> => - Object.values(browserFields).reduce>>( - (acc, namespace) => [ - ...acc, - ...Object.values(namespace.fields != null ? namespace.fields : {}), - ], - [] - ); +export function getAllBrowserFields(browserFields: BrowserFields): Array> { + const result: Array> = []; + for (const namespace of Object.values(browserFields)) { + if (namespace.fields) { + result.push(...Object.values(namespace.fields)); + } + } + return result; +} export const getAllFieldsByName = ( browserFields: BrowserFields From 71cd640fe2941ffd41521f9e6ac43629aa15b0bb Mon Sep 17 00:00:00 2001 From: Oliver Gupte Date: Tue, 29 Mar 2022 17:41:50 -0400 Subject: [PATCH 133/160] [APM] Fixes editing JSON in Service map storybook example (#128792) (#128822) --- .../cytoscape_example_data.stories.tsx | 28 +++++++++++++------ 1 file changed, 19 insertions(+), 9 deletions(-) diff --git a/x-pack/plugins/apm/public/components/app/service_map/__stories__/cytoscape_example_data.stories.tsx b/x-pack/plugins/apm/public/components/app/service_map/__stories__/cytoscape_example_data.stories.tsx index 24e2dceeafdc8..b3615c7fcc42f 100644 --- a/x-pack/plugins/apm/public/components/app/service_map/__stories__/cytoscape_example_data.stories.tsx +++ b/x-pack/plugins/apm/public/components/app/service_map/__stories__/cytoscape_example_data.stories.tsx @@ -129,18 +129,30 @@ export const MapFromJSON: Story<{}> = () => { const [error, setError] = useState(); const [elements, setElements] = useState([]); - useEffect(() => { + + const [uniqueKeyCounter, setUniqueKeyCounter] = useState(0); + const updateRenderedElements = () => { try { setElements(JSON.parse(json).elements); + setUniqueKeyCounter((key) => key + 1); + setError(undefined); } catch (e) { setError(e.message); } + }; + + useEffect(() => { + updateRenderedElements(); // eslint-disable-next-line react-hooks/exhaustive-deps }, []); return (
- + @@ -150,6 +162,10 @@ export const MapFromJSON: Story<{}> = () => { languageId="json" value={json} options={{ fontFamily: 'monospace' }} + onChange={(value) => { + setJson(value); + setSessionJson(value); + }} /> @@ -177,13 +193,7 @@ export const MapFromJSON: Story<{}> = () => { { - try { - setElements(JSON.parse(json).elements); - setSessionJson(json); - setError(undefined); - } catch (e) { - setError(e.message); - } + updateRenderedElements(); }} > Render JSON From f782f8bf338e7f50974bfc2ed5b0b23b7a1bc4bf Mon Sep 17 00:00:00 2001 From: Tyler Smalley Date: Tue, 29 Mar 2022 14:52:15 -0700 Subject: [PATCH 134/160] Revert "Upgrade EUI to v52.2.0 (#128313)" This reverts commit dccd8290bbfabc245d759e0873bb2cd9ea69c70e. --- package.json | 2 +- .../header/__snapshots__/header.test.tsx.snap | 5 +- src/dev/license_checker/config.ts | 2 +- .../url/__snapshots__/url.test.tsx.snap | 10 ++- .../table/__snapshots__/table.test.tsx.snap | 5 +- .../__snapshots__/table_header.test.tsx.snap | 5 +- .../__snapshots__/field_name.test.tsx.snap | 20 +++--- .../not_found_errors.test.tsx.snap | 20 +++--- .../components/not_found_errors.test.tsx | 8 +-- .../link_preview.test.tsx | 6 +- .../custom_link_toolbar.test.tsx | 4 +- .../dropdown_filter.stories.storyshot | 20 ++---- .../time_filter.stories.storyshot | 60 +++++------------ .../extended_template.stories.storyshot | 8 +-- .../date_format.stories.storyshot | 12 +--- .../number_format.stories.storyshot | 12 +--- .../__snapshots__/asset.stories.storyshot | 32 +++------- .../asset_manager.stories.storyshot | 52 ++++----------- .../__snapshots__/color_dot.stories.storyshot | 16 ++--- .../color_manager.stories.storyshot | 32 +++------- .../color_palette.stories.storyshot | 12 +--- .../color_picker.stories.storyshot | 40 +++--------- .../custom_element_modal.stories.storyshot | 44 ++++--------- .../datasource_component.stories.storyshot | 16 ++--- .../element_card.stories.storyshot | 12 +--- .../file_upload.stories.storyshot | 4 +- .../home/__snapshots__/home.stories.storyshot | 4 +- .../empty_prompt.stories.storyshot | 4 +- .../workpad_table.stories.storyshot | 52 ++++----------- .../__snapshots__/item_grid.stories.storyshot | 24 ++----- .../element_controls.stories.storyshot | 8 +-- .../element_grid.stories.storyshot | 24 ++----- .../saved_elements_modal.stories.storyshot | 64 +++++-------------- .../sidebar_header.stories.storyshot | 16 ++--- .../__snapshots__/tag.stories.storyshot | 8 +-- .../__snapshots__/tag_list.stories.storyshot | 12 +--- .../text_style_picker.stories.storyshot | 56 ++++------------ .../delete_var.stories.storyshot | 8 +-- .../__snapshots__/edit_var.stories.storyshot | 44 ++++--------- .../var_config.stories.storyshot | 8 +-- .../filters_group.component.stories.storyshot | 8 +-- ...orkpad_filters.component.stories.storyshot | 40 +++--------- .../editor_menu.stories.storyshot | 8 +-- .../element_menu.stories.storyshot | 4 +- .../extended_template.stories.storyshot | 24 ++----- .../extended_template.stories.storyshot | 16 ++--- .../simple_template.stories.storyshot | 5 +- .../__snapshots__/canvas.stories.storyshot | 48 ++++---------- .../__snapshots__/footer.stories.storyshot | 32 +++------- .../page_controls.stories.storyshot | 24 ++----- .../__snapshots__/title.stories.storyshot | 12 +--- .../autoplay_settings.stories.storyshot | 24 ++----- .../__snapshots__/settings.stories.storyshot | 8 +-- .../toolbar_settings.stories.storyshot | 24 ++----- .../connectors_dropdown.test.tsx | 2 +- .../markdown_editor/renderer.test.tsx | 2 +- .../components/table/table.test.tsx | 2 +- .../index_setup_dataset_filter.tsx | 1 + .../__jest__/test_pipeline.test.tsx | 14 ++-- .../components/table_basic.test.tsx | 4 +- .../field_item.test.tsx | 5 +- .../request_trial_extension.test.js.snap | 8 +-- .../revert_to_basic.test.js.snap | 6 +- .../__snapshots__/start_trial.test.js.snap | 8 +-- .../__snapshots__/exporters.test.js.snap | 15 ++--- .../__snapshots__/reason_found.test.js.snap | 15 ++--- .../list/remote_clusters_list.test.js | 6 +- .../feature_table_cell.test.tsx | 2 +- .../privilege_summary/__fixtures__/index.ts | 2 +- .../exception_item/exception_entries.test.tsx | 2 +- .../common/components/inspect/modal.test.tsx | 6 +- .../common/components/links/index.test.tsx | 10 +-- .../markdown_editor/renderer.test.tsx | 2 +- .../rules/all/optional_eui_tour_step.tsx | 28 -------- .../network/components/port/index.test.tsx | 6 +- .../source_destination/index.test.tsx | 4 +- .../source_destination_ip.test.tsx | 8 +-- .../certificate_fingerprint/index.test.tsx | 2 +- .../components/ja3_fingerprint/index.test.tsx | 2 +- .../components/netflow/index.test.tsx | 10 +-- .../__snapshots__/index.test.tsx.snap | 5 +- .../body/renderers/get_row_renderer.test.tsx | 12 +--- .../suricata/suricata_details.test.tsx | 6 +- .../suricata/suricata_row_renderer.test.tsx | 7 +- .../system/generic_row_renderer.test.tsx | 26 +++----- .../body/renderers/zeek/zeek_details.test.tsx | 16 ++--- .../renderers/zeek/zeek_row_renderer.test.tsx | 7 +- .../renderers/zeek/zeek_signature.test.tsx | 6 +- .../__jest__/client_integration/home.test.ts | 2 +- .../public/components/inspect/modal.test.tsx | 6 +- .../components/health_check.test.tsx | 14 ++-- .../rule_details/components/rule.test.tsx | 9 +-- .../drilldown_table/drilldown_table.test.tsx | 2 +- .../__snapshots__/expanded_row.test.tsx.snap | 5 +- .../monitor_status.bar.test.tsx.snap | 5 +- .../network_requests_total.test.tsx | 4 +- .../components/waterfall_marker_icon.test.tsx | 4 +- .../ux_metrics/key_ux_metrics.test.tsx | 12 ++-- yarn.lock | 8 +-- 99 files changed, 406 insertions(+), 990 deletions(-) delete mode 100644 x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx diff --git a/package.json b/package.json index adc45d9afadd7..f70bde1a2108f 100644 --- a/package.json +++ b/package.json @@ -108,7 +108,7 @@ "@elastic/datemath": "link:bazel-bin/packages/elastic-datemath", "@elastic/elasticsearch": "npm:@elastic/elasticsearch-canary@8.2.0-canary.1", "@elastic/ems-client": "8.2.0", - "@elastic/eui": "52.2.0", + "@elastic/eui": "51.1.0", "@elastic/filesaver": "1.1.2", "@elastic/node-crypto": "1.2.1", "@elastic/numeral": "^2.5.1", diff --git a/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap b/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap index ad0f27bbf08ce..d2b1078641437 100644 --- a/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap +++ b/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap @@ -3108,13 +3108,12 @@ exports[`Header renders 1`] = ` type="logoElastic" > - Elastic Logo - + /> - External link - + /> @@ -244,11 +243,10 @@ exports[`UrlFormatEditor should render normally 1`] = ` Label template help - External link - + /> diff --git a/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap b/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap index c054b42f51ac7..2b6cf62baf221 100644 --- a/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap +++ b/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap @@ -320,11 +320,10 @@ exports[`Table should render the boolean template (false) 1`] = ``; exports[`Table should render the boolean template (true) 1`] = ` - Is searchable - +/> `; exports[`Table should render timestamp field name 1`] = ` diff --git a/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap b/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap index 612973fe37a48..3f72349f3e2a0 100644 --- a/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap +++ b/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap @@ -20,11 +20,10 @@ exports[`TableHeader with time column renders correctly 1`] = ` class="euiToolTipAnchor" > - Primary time field. - + /> - Geo point field - + />
,
- Number field - + />
,
- String field - + />
,
- Unknown field - + />
,
- External link - + /> - External link - + /> - External link - + /> - External link - + /> { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectThe saved search associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectThe saved search associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); @@ -34,7 +34,7 @@ describe('NotFoundErrors component', () => { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectThe data view associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectThe data view associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); @@ -43,7 +43,7 @@ describe('NotFoundErrors component', () => { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectA field associated with this object no longer exists in the data view.If you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectA field associated with this object no longer exists in the data view.If you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); @@ -52,7 +52,7 @@ describe('NotFoundErrors component', () => { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectIf you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectIf you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); }); diff --git a/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx b/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx index 4c8a5bc00285e..f44b4d1c1205d 100644 --- a/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx +++ b/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx @@ -56,7 +56,7 @@ describe('LinkPreview', () => { removeExternalLinkText( (getByTestId(container, 'preview-link') as HTMLAnchorElement).text ) - ).toContain('https://baz.co'); + ).toEqual('https://baz.co'); }); }); @@ -74,7 +74,7 @@ describe('LinkPreview', () => { removeExternalLinkText( (getByTestId(container, 'preview-link') as HTMLAnchorElement).text ) - ).toContain('https://baz.co?service.name={{invalid}'); + ).toEqual('https://baz.co?service.name={{invalid}'); expect(getByTestId(container, 'preview-warning')).toBeInTheDocument(); }); }); @@ -94,7 +94,7 @@ describe('LinkPreview', () => { removeExternalLinkText( (getByTestId(container, 'preview-link') as HTMLAnchorElement).text ) - ).toContain('https://baz.co?transaction=0'); + ).toEqual('https://baz.co?transaction=0'); }); }); }); diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx index 42ca08cc3d225..4d92f5a1ae34a 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx @@ -45,7 +45,7 @@ describe('CustomLinkToolbar', () => { wrapper: Wrapper, }); expect( - component.getByText('Custom links settings page') + component.getByLabelText('Custom links settings page') ).toBeInTheDocument(); expectTextsInDocument(component, ['Create']); }); @@ -56,7 +56,7 @@ describe('CustomLinkToolbar', () => { { wrapper: Wrapper } ); expect( - component.getByText('Custom links settings page') + component.getByLabelText('Custom links settings page') ).toBeInTheDocument(); expectTextsNotInDocument(component, ['Create']); }); diff --git a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot index 0ded42439fb95..52694d3b04089 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot @@ -35,9 +35,7 @@ exports[`Storyshots renderers/DropdownFilter default 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + />
@@ -98,9 +96,7 @@ exports[`Storyshots renderers/DropdownFilter with choices 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - -
+ />
@@ -161,9 +157,7 @@ exports[`Storyshots renderers/DropdownFilter with choices and new value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - -
+ />
@@ -224,9 +218,7 @@ exports[`Storyshots renderers/DropdownFilter with choices and value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - -
+ />
@@ -269,9 +261,7 @@ exports[`Storyshots renderers/DropdownFilter with new value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - -
+ />
diff --git a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot index e82b6bf082b05..5abd1e9fd05b6 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot @@ -42,17 +42,13 @@ exports[`Storyshots renderers/TimeFilter default 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - -
+ /> - - + /> @@ -95,9 +91,7 @@ exports[`Storyshots renderers/TimeFilter default 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - > - - + /> @@ -156,17 +150,13 @@ exports[`Storyshots renderers/TimeFilter with absolute time bounds 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - - + /> - - + /> @@ -245,9 +235,7 @@ exports[`Storyshots renderers/TimeFilter with absolute time bounds 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - > - - + /> @@ -306,17 +294,13 @@ exports[`Storyshots renderers/TimeFilter with commonlyUsedRanges 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - - + /> - - + /> @@ -359,9 +343,7 @@ exports[`Storyshots renderers/TimeFilter with commonlyUsedRanges 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - > - - + /> @@ -420,17 +402,13 @@ exports[`Storyshots renderers/TimeFilter with dateFormat 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - - + /> - - + /> @@ -473,9 +451,7 @@ exports[`Storyshots renderers/TimeFilter with dateFormat 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - > - - + /> @@ -534,17 +510,13 @@ exports[`Storyshots renderers/TimeFilter with relative time bounds 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - - + /> - - + /> @@ -623,9 +595,7 @@ exports[`Storyshots renderers/TimeFilter with relative time bounds 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot index 7c0a2ad18c3dc..e3badfa833090 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot @@ -65,9 +65,7 @@ exports[`Storyshots arguments/AxisConfig extended 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -145,9 +143,7 @@ exports[`Storyshots arguments/AxisConfig/components extended 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot index 9755e1b53b868..238fe7c259c6e 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot @@ -47,9 +47,7 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -122,9 +120,7 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -196,9 +192,7 @@ exports[`Storyshots arguments/DateFormat with preset format 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot index ecd8e53ce1d25..2159e49e2bcf1 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot @@ -57,9 +57,7 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -142,9 +140,7 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -226,9 +222,7 @@ exports[`Storyshots arguments/NumberFormat with preset format 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot index 587b07ca4f932..6db24bd0b984c 100644 --- a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot @@ -81,9 +81,7 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - > - - + /> @@ -113,9 +111,7 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - > - - + /> @@ -146,9 +142,7 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - > - - + /> @@ -175,9 +169,7 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> @@ -268,9 +260,7 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - > - - + /> @@ -300,9 +290,7 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - > - - + /> @@ -333,9 +321,7 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - > - - + /> @@ -362,9 +348,7 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot index 5409f9c444df0..dd650e9f4c697 100644 --- a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot @@ -26,9 +26,7 @@ exports[`Storyshots components/Assets/AssetManager no assets 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - > - - + />
- - + />
@@ -126,9 +122,7 @@ exports[`Storyshots components/Assets/AssetManager no assets 1`] = ` color="subdued" data-euiicon-type="importAction" size="xxl" - > - - + />
- - + />
- - + />
@@ -390,9 +380,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - > - - + />
@@ -422,9 +410,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - > - - + />
@@ -455,9 +441,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - > - - + />
@@ -484,9 +468,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + />
@@ -566,9 +548,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - > - - + /> @@ -598,9 +578,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - > - - + /> @@ -631,9 +609,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - > - - + /> @@ -660,9 +636,7 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot b/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot index 5d83b2718f916..056b87294f245 100644 --- a/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot @@ -129,9 +129,7 @@ Array [ - - + /> ,
- - + />
,
- - + />
,
- - + />
, ] diff --git a/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot b/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot index 057bd37b71c20..cb3598430c7ef 100644 --- a/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot @@ -394,9 +394,7 @@ exports[`Storyshots components/Color/ColorManager interactive 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> @@ -809,9 +805,7 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> , @@ -894,9 +886,7 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> , @@ -977,9 +965,7 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> , diff --git a/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot b/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot index 53651c8fe33f2..a0d27eafb23dc 100644 --- a/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot @@ -393,9 +393,7 @@ Array [ className="selected-color" color="#333" data-euiicon-type="check" - > - - + /> @@ -760,9 +758,7 @@ exports[`Storyshots components/Color/ColorPalette six colors, wrap at 4 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - > - - + /> @@ -1044,9 +1040,7 @@ Array [ className="selected-color" color="#333" data-euiicon-type="check" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot b/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot index 557f94c26fac9..6ef3eec47e701 100644 --- a/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot @@ -237,9 +237,7 @@ exports[`Storyshots components/Color/ColorPicker interactive 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> @@ -322,9 +318,7 @@ exports[`Storyshots components/Color/ColorPicker six colors 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - > - - + /> @@ -532,9 +526,7 @@ exports[`Storyshots components/Color/ColorPicker six colors 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> @@ -796,9 +786,7 @@ exports[`Storyshots components/Color/ColorPicker six colors, value missing 1`] = color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> @@ -860,9 +846,7 @@ exports[`Storyshots components/Color/ColorPicker three colors 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - > - - + /> @@ -986,9 +970,7 @@ exports[`Storyshots components/Color/ColorPicker three colors 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot b/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot index feb04e68ca1d3..d8c660923e3d7 100644 --- a/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot @@ -27,9 +27,7 @@ exports[`Storyshots components/Elements/CustomElementModal with description 1`] color="inherit" data-euiicon-type="cross" size="m" - > - - + />
- - + />
@@ -228,9 +224,7 @@ exports[`Storyshots components/Elements/CustomElementModal with description 1`] className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - > - - + />
- - + />
- - + />
@@ -656,9 +646,7 @@ exports[`Storyshots components/Elements/CustomElementModal with name 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - > - - + />
- - + />
@@ -857,9 +843,7 @@ exports[`Storyshots components/Elements/CustomElementModal with name 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - > - - + />
- - + />
- - + />
@@ -1166,9 +1146,7 @@ exports[`Storyshots components/Elements/CustomElementModal with title 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - > - - + />
- - + /> - - + /> Test Datasource @@ -74,18 +70,14 @@ exports[`Storyshots components/datasource/DatasourceComponent simple datasource color="inherit" data-euiicon-type="arrowRight" size="m" - > - - + /> - - + /> Test Datasource diff --git a/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot b/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot index 05cec59522ae7..14640fe266839 100644 --- a/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot @@ -19,9 +19,7 @@ exports[`Storyshots components/Elements/ElementCard with click handler 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - > - - + />
- - + />
- - + />
- - + />
diff --git a/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot b/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot index 0863fd13af607..d3ab369dcc32c 100644 --- a/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot @@ -59,9 +59,7 @@ exports[`Storyshots Home Home Page 1`] = ` color="inherit" data-euiicon-type="plusInCircleFilled" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot b/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot index fa3789124ce81..8f00060a1dd1c 100644 --- a/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot @@ -28,9 +28,7 @@ exports[`Storyshots Home/Components/Empty Prompt Empty Prompt 1`] = ` color="subdued" data-euiicon-type="importAction" size="xxl" - > - - + />
- - + />
@@ -75,9 +73,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` className="euiFilePicker__icon" data-euiicon-type="importAction" size="m" - > - - + />
@@ -154,9 +150,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -302,9 +296,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` className="euiTableSortIcon" data-euiicon-type="sortDown" size="m" - > - - + /> @@ -468,9 +460,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - > - - + />
@@ -496,9 +486,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - > - - + />
@@ -644,9 +632,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - > - - + />
@@ -672,9 +658,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - > - - + />
@@ -820,9 +804,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - > - - + />
@@ -848,9 +830,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - > - - + />
@@ -893,9 +873,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -937,9 +915,7 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - > - - + />
    - - + />
diff --git a/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot b/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot index e96302525aea4..dbb591582e909 100644 --- a/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot @@ -73,9 +73,7 @@ exports[`Storyshots components/ItemGrid complex grid 1`] = ` - - + />
- - + />
- - + />
@@ -131,19 +125,13 @@ exports[`Storyshots components/ItemGrid icon grid 1`] = ` > - - + /> - - + /> - - + /> `; diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot index 9f462d9a4d6cd..6f139df7c8773 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot @@ -34,9 +34,7 @@ exports[`Storyshots components/SavedElementsModal/ElementControls has two button color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -63,9 +61,7 @@ exports[`Storyshots components/SavedElementsModal/ElementControls has two button color="inherit" data-euiicon-type="trash" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot index fbab31e5c8c5b..70ee9f543d768 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot @@ -85,9 +85,7 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -114,9 +112,7 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> @@ -196,9 +192,7 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -225,9 +219,7 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> @@ -307,9 +299,7 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -336,9 +326,7 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot index e0b7f40657cf8..fd6f29178aa91 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot @@ -26,9 +26,7 @@ exports[`Storyshots components/SavedElementsModal no custom elements 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - > - - + />
- - + />
@@ -103,9 +99,7 @@ exports[`Storyshots components/SavedElementsModal no custom elements 1`] = ` color="subdued" data-euiicon-type="vector" size="xxl" - > - - + />
- - + />
- - + />
@@ -337,9 +327,7 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -366,9 +354,7 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> @@ -448,9 +434,7 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -477,9 +461,7 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> @@ -559,9 +541,7 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -588,9 +568,7 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> @@ -656,9 +634,7 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - > - - + />
- - + />
- - + />
@@ -815,9 +787,7 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - > - - + /> @@ -844,9 +814,7 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot b/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot index d5e5af856909b..6bf2535131afc 100644 --- a/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot @@ -72,9 +72,7 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="sortUp" size="m" - > - - + /> @@ -100,9 +98,7 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="arrowUp" size="m" - > - - + /> @@ -128,9 +124,7 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="m" - > - - + /> @@ -156,9 +150,7 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot b/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot index 2a1e12c1e0b74..f21ffcf1a70ea 100644 --- a/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot @@ -57,9 +57,7 @@ exports[`Storyshots components/Tags/Tag as health 1`] = ` - - + />
- - + />
- - + />
- - + />
- - + />
- - + />
@@ -246,9 +244,7 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorBold" size="m" - > - - + /> @@ -278,9 +274,7 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorItalic" size="m" - > - - + /> @@ -310,9 +304,7 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorUnderline" size="m" - > - - + /> @@ -356,9 +348,7 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignLeft" size="m" - > - - + /> @@ -394,9 +384,7 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignCenter" size="m" - > - - + /> @@ -432,9 +420,7 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignRight" size="m" - > - - + /> @@ -612,9 +598,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - > - - + /> @@ -706,9 +690,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorBold" size="m" - > - - + /> @@ -738,9 +720,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorItalic" size="m" - > - - + /> @@ -770,9 +750,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorUnderline" size="m" - > - - + /> @@ -816,9 +794,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignLeft" size="m" - > - - + /> @@ -854,9 +830,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignCenter" size="m" - > - - + /> @@ -892,9 +866,7 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignRight" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot index 0d8a5c0cf4e5d..f5351b0d8ea5f 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot @@ -20,9 +20,7 @@ Array [ "verticalAlign": "top", } } - > - - + /> - - + /> diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot index 72e1b4d6ef909..6c70364f9679c 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot @@ -20,9 +20,7 @@ Array [ "verticalAlign": "top", } } - > - - + /> - - + /> @@ -259,9 +255,7 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - > - - + /> @@ -316,9 +310,7 @@ Array [ "verticalAlign": "top", } } - > - - + /> - - + /> @@ -496,9 +486,7 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - > - - + /> @@ -553,9 +541,7 @@ Array [ "verticalAlign": "top", } } - > - - + /> - - + /> @@ -733,9 +717,7 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - > - - + /> @@ -790,9 +772,7 @@ Array [ "verticalAlign": "top", } } - > - - + /> - - + /> diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot index ac27b0443585a..7d43840e431ab 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot @@ -28,9 +28,7 @@ exports[`Storyshots components/Variables/VarConfig default 1`] = ` color="inherit" data-euiicon-type="arrowRight" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot b/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot index 57fbd4c2109cd..b6d842ac44e21 100644 --- a/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot @@ -33,9 +33,7 @@ exports[`Storyshots components/WorkpadFilters/FiltersGroupComponent default 1`] color="inherit" data-euiicon-type="arrowRight" size="m" - > - - + />
- - + />
@@ -1473,9 +1467,7 @@ exports[`Storyshots shareables/Canvas component 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + /> @@ -2817,9 +2809,7 @@ exports[`Storyshots shareables/Canvas contextual: austin 1`] = ` - - + />
- - + />
- - + />
@@ -2963,9 +2949,7 @@ exports[`Storyshots shareables/Canvas contextual: austin 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + /> @@ -3123,9 +3107,7 @@ exports[`Storyshots shareables/Canvas contextual: hello 1`] = ` - - + />
- - + />
- - + />
@@ -3269,9 +3247,7 @@ exports[`Storyshots shareables/Canvas contextual: hello 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot index 6a8d67a70ad1a..90ebc1900d731 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot @@ -1280,9 +1280,7 @@ exports[`Storyshots shareables/Footer contextual: austin 1`] = ` - - + />
- - + />
- - + />
@@ -1426,9 +1420,7 @@ exports[`Storyshots shareables/Footer contextual: austin 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + /> @@ -1540,9 +1532,7 @@ exports[`Storyshots shareables/Footer contextual: hello 1`] = ` - - + />
- - + />
- - + />
@@ -1686,9 +1672,7 @@ exports[`Storyshots shareables/Footer contextual: hello 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot index f2b92754b6d6f..9edb6f1fda62f 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot @@ -34,9 +34,7 @@ exports[`Storyshots shareables/Footer/PageControls component 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - > - - + />
- - + />
@@ -135,9 +131,7 @@ exports[`Storyshots shareables/Footer/PageControls contextual: austin 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - > - - + />
- - + />
@@ -236,9 +228,7 @@ exports[`Storyshots shareables/Footer/PageControls contextual: hello 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - > - - + />
- - + />
diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot index ea19100f6da87..2b326fd0ec51a 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot @@ -34,9 +34,7 @@ exports[`Storyshots shareables/Footer/Title component 1`] = ` - - + />
- - + />
- - + />
- - + /> - - + /> @@ -216,16 +212,12 @@ exports[`Storyshots shareables/Footer/Settings/AutoplaySettings component: on, 5 className="euiSwitch__icon" data-euiicon-type="cross" size="m" - > - - + /> - - + /> @@ -384,16 +376,12 @@ exports[`Storyshots shareables/Footer/Settings/AutoplaySettings contextual 1`] = className="euiSwitch__icon" data-euiicon-type="cross" size="m" - > - - + /> - - + /> diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot index 3c3f26bce7e9e..265cbe460607d 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot @@ -39,9 +39,7 @@ exports[`Storyshots shareables/Footer/Settings component 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + />
@@ -89,9 +87,7 @@ exports[`Storyshots shareables/Footer/Settings contextual 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - > - - + /> diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot index d07e5a9edc8ad..1aafb9cc6b664 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot @@ -59,16 +59,12 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings component: off 1` className="euiSwitch__icon" data-euiicon-type="cross" size="m" - > - - + /> - - + /> @@ -151,16 +147,12 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings component: on 1`] className="euiSwitch__icon" data-euiicon-type="cross" size="m" - > - - + /> - - + /> @@ -243,16 +235,12 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings contextual 1`] = className="euiSwitch__icon" data-euiicon-type="cross" size="m" - > - - + /> - - + /> diff --git a/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx b/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx index 63fc2e2695a3a..4fd56525541a6 100644 --- a/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx +++ b/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx @@ -264,7 +264,7 @@ describe('ConnectorsDropdown', () => { wrapper: ({ children }) => {children}, }); - const tooltips = screen.getAllByText( + const tooltips = screen.getAllByLabelText( 'This connector is deprecated. Update it, or create a new one.' ); expect(tooltips[0]).toBeInTheDocument(); diff --git a/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx b/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx index 8cb8b7f23b439..af803cfc14e05 100644 --- a/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx +++ b/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx @@ -25,7 +25,7 @@ describe('Markdown', () => { test('it renders the expected link text', () => { const result = appMockRender.render({markdownWithLink}); - expect(removeExternalLinkText(result.getByTestId('markdown-link').textContent)).toContain( + expect(removeExternalLinkText(result.getByTestId('markdown-link').textContent)).toEqual( 'External Site' ); }); diff --git a/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx b/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx index eb1f82cc01e37..863e5e85d9ef3 100644 --- a/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx +++ b/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx @@ -138,7 +138,7 @@ describe('Background Search Session Management Table', () => { expect(table.find('tbody td').map((node) => node.text())).toMatchInlineSnapshot(` Array [ "App", - "Namevery background search Info", + "Namevery background search ", "# Searches0", "StatusExpired", "Created2 Dec, 2020, 00:19:32", diff --git a/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx b/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx index d44625b1641ac..0626a946f8848 100644 --- a/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx +++ b/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx @@ -65,6 +65,7 @@ export const IndexSetupDatasetFilter: React.FC<{ isSelected={isVisible} onClick={show} iconType="arrowDown" + size="s" > { // Dropdown should be visible and processor status should equal "success" expect(exists('documentsDropdown')).toBe(true); - const initialProcessorStatusLabel = find('processors>0.processorStatusIcon').props() - .children; + const initialProcessorStatusLabel = find('processors>0.processorStatusIcon').props()[ + 'aria-label' + ]; expect(initialProcessorStatusLabel).toEqual('Success'); // Open flyout and click clear all button @@ -319,8 +320,9 @@ describe('Test pipeline', () => { // Verify documents and processors were reset expect(exists('documentsDropdown')).toBe(false); expect(exists('addDocumentsButton')).toBe(true); - const resetProcessorStatusIconLabel = find('processors>0.processorStatusIcon').props() - .children; + const resetProcessorStatusIconLabel = find('processors>0.processorStatusIcon').props()[ + 'aria-label' + ]; expect(resetProcessorStatusIconLabel).toEqual('Not run'); }); }); @@ -330,7 +332,7 @@ describe('Test pipeline', () => { it('should show "inactive" processor status by default', async () => { const { find } = testBed; - const statusIconLabel = find('processors>0.processorStatusIcon').props().children; + const statusIconLabel = find('processors>0.processorStatusIcon').props()['aria-label']; expect(statusIconLabel).toEqual('Not run'); }); @@ -350,7 +352,7 @@ describe('Test pipeline', () => { actions.closeTestPipelineFlyout(); // Verify status - const statusIconLabel = find('processors>0.processorStatusIcon').props().children; + const statusIconLabel = find('processors>0.processorStatusIcon').props()['aria-label']; expect(statusIconLabel).toEqual('Success'); }); diff --git a/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx b/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx index 2ad20bf0a43e2..36fd1581cb9b6 100644 --- a/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx +++ b/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx @@ -617,9 +617,7 @@ describe('DatatableComponent', () => { wrapper.setProps({ data: newData }); wrapper.update(); - // Using .toContain over .toEqual because this element includes text from - // which can't be seen, but shows in the text content - expect(wrapper.find('[data-test-subj="dataGridHeader"]').children().first().text()).toContain( + expect(wrapper.find('[data-test-subj="dataGridHeader"]').children().first().text()).toEqual( 'new a' ); }); diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx index c20f1c37c6c67..c86fdcc33b15f 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx @@ -120,10 +120,7 @@ describe('IndexPattern Field Item', () => { it('should display displayName of a field', () => { const wrapper = mountWithIntl(); - - // Using .toContain over .toEqual because this element includes text from - // which can't be seen, but shows in the text content - expect(wrapper.find('[data-test-subj="lnsFieldListPanelField"]').first().text()).toContain( + expect(wrapper.find('[data-test-subj="lnsFieldListPanelField"]').first().text()).toEqual( 'bytesLabel' ); }); diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap index 0fd589e4886e3..fda479f2888ce 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap @@ -1,9 +1,9 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`RequestTrialExtension component should display when enterprise license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when enterprise license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when license is active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when license is active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when platinum license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when platinum license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap index cf977731ee452..4fa45c4bec5ce 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap @@ -1,7 +1,7 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`RevertToBasic component should display when license is about to expire 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when license is about to expire 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; -exports[`RevertToBasic component should display when license is expired 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when license is expired 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; -exports[`RevertToBasic component should display when trial is active 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when trial is active 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap index 0880eddcc1683..622bff86ead16 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap @@ -1,9 +1,9 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`StartTrial component when trial is allowed display for basic license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed display for basic license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for expired enterprise license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for expired enterprise license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for expired platinum license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for expired platinum license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for gold license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for gold license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; diff --git a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap index 41501a7eedb62..c5b5e5e65ab38 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap @@ -87,11 +87,10 @@ Array [ > Elasticsearch Service Console - External link - + /> @@ -107,11 +106,10 @@ Array [ > Logs and metrics - External link - + /> @@ -127,11 +125,10 @@ Array [ > the documentation page. - External link - + /> diff --git a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap index faab608e7af14..dda853a28239f 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap @@ -158,11 +158,10 @@ Array [ > Elasticsearch Service Console - External link - + /> @@ -178,11 +177,10 @@ Array [ > Logs and metrics - External link - + /> @@ -198,11 +196,10 @@ Array [ > the documentation page. - External link - + /> diff --git a/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js b/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js index 26af30ba17c04..a6987fa19d1ee 100644 --- a/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js +++ b/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js @@ -252,7 +252,7 @@ describe('', () => { ], [ '', - remoteCluster2.name.concat('Info'), //Tests include the word "info" to account for the rendered text coming from EuiIcon + remoteCluster2.name, 'Not connected', PROXY_MODE, remoteCluster2.proxyAddress, @@ -261,7 +261,7 @@ describe('', () => { ], [ '', - remoteCluster3.name.concat('Info'), //Tests include the word "info" to account for the rendered text coming from EuiIcon + remoteCluster3.name, 'Not connected', PROXY_MODE, remoteCluster2.proxyAddress, @@ -360,7 +360,7 @@ describe('', () => { ({ rows } = table.getMetaData('remoteClusterListTable')); expect(rows.length).toBe(2); - expect(rows[0].columns[1].value).toContain(remoteCluster2.name); + expect(rows[0].columns[1].value).toEqual(remoteCluster2.name); }); }); diff --git a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx index 006ae053940d8..7052f724cd1cc 100644 --- a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx +++ b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx @@ -40,7 +40,7 @@ describe('FeatureTableCell', () => { ); - expect(wrapper.text()).toMatchInlineSnapshot(`"Test Feature Info"`); + expect(wrapper.text()).toMatchInlineSnapshot(`"Test Feature "`); expect(wrapper.find(EuiIconTip).props().content).toMatchInlineSnapshot(` diff --git a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts index f375263c960c3..3a70ff5713bd9 100644 --- a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts +++ b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts @@ -60,7 +60,7 @@ export function getDisplayedFeaturePrivileges( acc[feature.id][key] = { ...acc[feature.id][key], - primaryFeaturePrivilege: primary.text().replaceAll('Info', '').trim(), // Removing the word "info" to account for the rendered text coming from EuiIcon + primaryFeaturePrivilege: primary.text().trim(), hasCustomizedSubFeaturePrivileges: findTestSubject(primary, 'additionalPrivilegesGranted').length > 0, }; diff --git a/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx b/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx index a53be08380698..6070924523f63 100644 --- a/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx @@ -158,7 +158,7 @@ describe('ExceptionEntries', () => { expect(parentValue.text()).toEqual(getEmptyValue()); expect(nestedField.exists('.euiToolTipAnchor')).toBeTruthy(); - expect(nestedField.text()).toContain('host.name'); + expect(nestedField.text()).toEqual('host.name'); expect(nestedOperator.text()).toEqual('is'); expect(nestedValue.text()).toEqual('some name'); }); diff --git a/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx b/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx index 9796ae2624a73..7a9c36a986afd 100644 --- a/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx @@ -58,7 +58,7 @@ describe('Modal Inspect', () => { expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="index-pattern-title"]').text() - ).toContain('Index pattern '); + ).toBe('Index pattern '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="index-pattern-description"]') @@ -66,7 +66,7 @@ describe('Modal Inspect', () => { ).toBe('auditbeat-*, filebeat-*, packetbeat-*, winlogbeat-*'); expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="query-time-title"]').text() - ).toContain('Query time '); + ).toBe('Query time '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="query-time-description"]') @@ -76,7 +76,7 @@ describe('Modal Inspect', () => { wrapper .find('.euiDescriptionList__title span[data-test-subj="request-timestamp-title"]') .text() - ).toContain('Request timestamp '); + ).toBe('Request timestamp '); }); test('Click on request Tab', () => { diff --git a/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx b/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx index adab4db904d6a..97f93b9732c02 100644 --- a/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx @@ -105,7 +105,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); }); test('it renders props passed in as link', () => { @@ -463,7 +463,7 @@ describe('Custom Links', () => { describe('WhoisLink', () => { test('it renders ip passed in as domain', () => { const wrapper = mountWithIntl({'Example Link'}); - expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); }); test('it renders correct href', () => { @@ -488,7 +488,7 @@ describe('Custom Links', () => { {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); }); test('it renders correct href', () => { @@ -519,7 +519,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); }); test('it renders correct href', () => { @@ -548,7 +548,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); }); test('it renders correct href when port is a number', () => { diff --git a/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx b/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx index 68588c9338b4c..da3785648de62 100644 --- a/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx @@ -20,7 +20,7 @@ describe('Markdown', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="markdown-link"]').first().text()) - ).toContain('External Site'); + ).toEqual('External Site'); }); test('it renders the expected href', () => { diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx deleted file mode 100644 index e08389ba250a3..0000000000000 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/all/optional_eui_tour_step.tsx +++ /dev/null @@ -1,28 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import React, { FC } from 'react'; - -import { EuiTourStepProps, EuiTourStep, DistributiveOmit } from '@elastic/eui'; - -/** - * This component can be used for tour steps, when tour step is optional - * If stepProps are not supplied, step will not be rendered, only children component will be - */ -export const OptionalEuiTourStep: FC<{ - stepProps: DistributiveOmit | undefined; -}> = ({ children, stepProps }) => { - if (!stepProps) { - return <>{children}; - } - - return ( - - <>{children} - - ); -}; diff --git a/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx b/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx index ec56dd6934463..480d200c6756f 100644 --- a/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx @@ -54,9 +54,9 @@ describe('Port', () => { ); - expect( - removeExternalLinkText(wrapper.find('[data-test-subj="port"]').first().text()) - ).toContain('443'); + expect(removeExternalLinkText(wrapper.find('[data-test-subj="port"]').first().text())).toEqual( + '443' + ); }); test('it hyperlinks links destination.port to an external service that describes the purpose of the port', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx b/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx index bb8b4683c9d30..3332111d14f8b 100644 --- a/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx @@ -205,7 +205,7 @@ describe('SourceDestination', () => { removeExternalLinkText( wrapper.find('[data-test-subj="destination-ip-and-port"]').first().text() ) - ).toContain('10.1.2.3:80'); + ).toEqual('10.1.2.3:80'); }); test('it renders destination.packets', () => { @@ -329,7 +329,7 @@ describe('SourceDestination', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="source-ip-and-port"]').first().text()) - ).toContain('192.168.1.2:9987'); + ).toEqual('192.168.1.2:9987'); }); test('it renders source.packets', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx b/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx index 6168d98765253..f16cd7dbb109f 100644 --- a/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx @@ -984,7 +984,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-source.port"]').first().text() ) - ).toContain('9987'); + ).toEqual('9987'); }); test('it renders the expected destination port when type is `destination`, and both destinationIp and destinationPort are populated', () => { @@ -1038,7 +1038,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-destination.port"]').first().text() ) - ).toContain('80'); + ).toEqual('80'); }); test('it renders the expected source port when type is `source`, but only sourcePort is populated', () => { @@ -1092,7 +1092,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-source.port"]').first().text() ) - ).toContain('9987'); + ).toEqual('9987'); }); test('it renders the expected destination port when type is `destination`, and only destinationPort is populated', () => { @@ -1147,7 +1147,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-destination.port"]').first().text() ) - ).toContain('80'); + ).toEqual('80'); }); test('it does NOT render the badge when type is `source`, but both sourceIp and sourcePort are undefined', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx index 8b3f0bfdb107a..4ebb804eab8a4 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx @@ -51,7 +51,7 @@ describe('CertificateFingerprint', () => { removeExternalLinkText( wrapper.find('[data-test-subj="certificate-fingerprint-link"]').first().text() ) - ).toContain('3f4c57934e089f02ae7511200aee2d7e7aabd272'); + ).toEqual('3f4c57934e089f02ae7511200aee2d7e7aabd272'); }); test('it renders a hyperlink to an external site to compare the fingerprint against a known set of signatures', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx index ddbba7f2bc9f3..31f2fec942490 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx @@ -48,7 +48,7 @@ describe('Ja3Fingerprint', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="ja3-fingerprint-link"]').first().text()) - ).toContain('fff799d91b7c01ae3fe6787cfc895552'); + ).toEqual('fff799d91b7c01ae3fe6787cfc895552'); }); test('it renders a hyperlink to an external site to compare the fingerprint against a known set of signatures', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx index 9ccabf2f47d44..8a88a7182af03 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx @@ -204,7 +204,7 @@ describe('Netflow', () => { removeExternalLinkText( wrapper.find('[data-test-subj="destination-ip-and-port"]').first().text() ) - ).toContain('10.1.2.3:80'); + ).toEqual('10.1.2.3:80'); }); test('it renders destination.packets', () => { @@ -340,7 +340,7 @@ describe('Netflow', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="source-ip-and-port"]').first().text()) - ).toContain('192.168.1.2:9987'); + ).toEqual('192.168.1.2:9987'); }); test('it renders source.packets', () => { @@ -374,7 +374,7 @@ describe('Netflow', () => { .first() .text() ) - ).toContain('tls.client_certificate.fingerprint.sha1-value'); + ).toEqual('tls.client_certificate.fingerprint.sha1-value'); }); test('it hyperlinks tls.fingerprints.ja3.hash site to compare the fingerprint against a known set of signatures', () => { @@ -390,7 +390,7 @@ describe('Netflow', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="ja3-fingerprint-link"]').first().text()) - ).toContain('tls.fingerprints.ja3.hash-value'); + ).toEqual('tls.fingerprints.ja3.hash-value'); }); test('it hyperlinks tls.server_certificate.fingerprint.sha1 site to compare the fingerprint against a known set of signatures', () => { @@ -418,7 +418,7 @@ describe('Netflow', () => { .first() .text() ) - ).toContain('tls.server_certificate.fingerprint.sha1-value'); + ).toEqual('tls.server_certificate.fingerprint.sha1-value'); }); test('it renders network.transport', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap index ebb807a590124..6ea24e5ca57f6 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap @@ -2686,12 +2686,11 @@ exports[`Details Panel Component DetailsPanel:NetworkDetails: rendering it shoul type="popout" > - External link - + /> { - return str.replaceAll('External link', ''); -}; - jest.mock('../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -96,7 +90,7 @@ describe('get_column_renderer', () => { {row} ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toContain( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); @@ -115,7 +109,7 @@ describe('get_column_renderer', () => { {row} ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toContain( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); @@ -134,7 +128,7 @@ describe('get_column_renderer', () => { {row} ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toContain( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx index f8693d4a4f8ea..2d06c040c5b00 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx @@ -53,11 +53,7 @@ describe('SuricataDetails', () => { /> ); - const removeEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( - 'External link', - '' - ); - expect(removeEuiIconText).toEqual( + expect(removeExternalLinkText(wrapper.text())).toEqual( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx index 2022904e548aa..61ea659964e4d 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx @@ -72,12 +72,7 @@ describe('suricata_row_renderer', () => { {children} ); - - const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( - 'External link', - '' - ); - expect(extractEuiIconText).toContain( + expect(removeExternalLinkText(wrapper.text())).toContain( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx index 4b93c5accb590..ae2caa8ce8401 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx @@ -83,12 +83,6 @@ import { import * as i18n from './translations'; import { RowRenderer } from '../../../../../../../common/types'; -// EuiIcons coming from .testenv render the icon's aria-label as a span -// extractEuiIcon removes the aria-label before checking for equality -const extractEuiIconText = (str: string) => { - return str.replaceAll('External link', ''); -}; - jest.mock('../../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -1136,7 +1130,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'NETWORK SERVICE\\NT AUTHORITY@windows-endpoint-1accepted a connection viasvchost.exe(328)with resultsuccessEndpoint network eventincomingtcpSource10.1.2.3:64557North AmericaUnited States🇺🇸USNorth CarolinaConcordDestination10.50.60.70:3389' ); }); @@ -1220,7 +1214,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'NETWORK SERVICE\\NT AUTHORITY@win2019-endpoint-1made a http request viasvchost.exe(2232)Endpoint network eventoutgoinghttptcpSource10.1.2.3:51570Destination10.11.12.13:80North AmericaUnited States🇺🇸USArizonaPhoenix' ); }); @@ -1249,7 +1243,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'SYSTEM\\NT AUTHORITY@HD-gqf-0af7b4feaccepted a connection viaAmSvc.exe(1084)tcp1:network-community_idSource127.0.0.1:49306Destination127.0.0.1:49305' ); }); @@ -1278,7 +1272,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'SYSTEM\\NT AUTHORITY@HD-55b-3ec87f66accepted a connection via(4)tcp1:network-community_idSource::1:51324Destination::1:5357' ); }); @@ -1304,7 +1298,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'NETWORK SERVICE\\NT AUTHORITY@windows-endpoint-1disconnected viasvchost.exe(328)Endpoint network eventincomingtcpSource10.20.30.40:64557North AmericaUnited States🇺🇸USNorth CarolinaConcord(42.47%)1.2KB(57.53%)1.6KBDestination10.11.12.13:3389' ); }); @@ -1333,7 +1327,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'Arun\\Anvi-Acer@HD-obe-8bf77f54disconnected viachrome.exe(11620)8.1KBtcp1:LxYHJJv98b2O0fNccXu6HheXmwk=Source192.168.0.6:59356(25.78%)2.1KB(74.22%)6KBDestination10.156.162.53:443' ); }); @@ -1362,7 +1356,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'SYSTEM\\NT AUTHORITY@HD-55b-3ec87f66disconnected via(4)7.9KBtcp1:ZylzQhsB1dcptA2t4DY8S6l9o8E=Source::1:51338(96.92%)7.7KB(3.08%)249BDestination::1:2869' ); }); @@ -1391,7 +1385,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'root@foohostopened a socket withgoogle_accounts(2166)Outbound socket (10.4.20.1:59554 -> 10.1.2.3:80) Ooutboundtcp1:network-community_idSource10.4.20.1:59554Destination10.1.2.3:80' ); }); @@ -1420,7 +1414,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'root@foohostclosed a socket withgoogle_accounts(2166)Outbound socket (10.4.20.1:59508 -> 10.1.2.3:80) Coutboundtcp1:network-community_idSource10.4.20.1:59508Destination10.1.2.3:80' ); }); @@ -1728,7 +1722,7 @@ describe('GenericRowRenderer', () => { ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'iot.example.comasked forlookup.example.comwith question typeA, which resolved to10.1.2.3(response code:NOERROR)viaan unknown process6.937500msOct 8, 2019 @ 10:05:23.241Oct 8, 2019 @ 10:05:23.248outbounddns177Budp1:network-community_idSource10.9.9.9:58732(22.60%)40B(77.40%)137BDestination10.1.1.1:53OceaniaAustralia🇦🇺AU' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx index 9af22fca0c707..62836cbffb2b5 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx @@ -14,12 +14,6 @@ import { mockTimelineData, TestProviders } from '../../../../../../common/mock'; import { useMountAppended } from '../../../../../../common/utils/use_mount_appended'; import { ZeekDetails } from './zeek_details'; -// EuiIcons coming from .testenv render the icon's aria-label as a span -// extractEuiIcon removes the aria-label before checking for equality -const extractEuiIconText = (str: string) => { - return str.replaceAll('External link', ''); -}; - jest.mock('../../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -59,7 +53,7 @@ describe('ZeekDetails', () => { /> ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); @@ -74,7 +68,7 @@ describe('ZeekDetails', () => { /> ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'CyIrMA1L1JtLqdIuoldnsudpSource206.189.35.240:57475Destination67.207.67.3:53' ); }); @@ -89,7 +83,7 @@ describe('ZeekDetails', () => { /> ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'CZLkpC22NquQJOpkwehttp302Source206.189.35.240:36220Destination192.241.164.26:80' ); }); @@ -104,7 +98,7 @@ describe('ZeekDetails', () => { /> ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'noticeDropped:falseScan::Port_Scan8.42.77.171 scanned at least 15 unique ports of host 207.154.238.205 in 0m0sSource8.42.77.171' ); }); @@ -119,7 +113,7 @@ describe('ZeekDetails', () => { /> ); - expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( + expect(removeExternalLinkText(wrapper.text())).toEqual( 'CmTxzt2OVXZLkGDaResslTLSv12TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256Source188.166.66.184:34514Destination91.189.95.15:443' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx index fda83c0ade12b..b60a2965bfd70 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx @@ -71,12 +71,7 @@ describe('zeek_row_renderer', () => { {children} ); - - const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( - 'External link', - '' - ); - expect(extractEuiIconText).toContain( + expect(removeExternalLinkText(wrapper.text())).toContain( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx index 726716c7f53ab..3f27b80359131 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx @@ -101,11 +101,7 @@ describe('ZeekSignature', () => { test('should render value', () => { const wrapper = mount(); - const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( - 'External link', - '' - ); - expect(extractEuiIconText).toEqual('abc'); + expect(removeExternalLinkText(wrapper.text())).toEqual('abc'); }); test('should render value and link', () => { diff --git a/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts b/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts index a99a6fdb81167..60fe9d2bd7128 100644 --- a/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts +++ b/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts @@ -769,7 +769,7 @@ describe('', () => { const stateMessage = find('snapshotDetail.state.value').text(); try { - expect(stateMessage).toContain(expectedMessage); // Messages may include the word "Info" to account for the rendered text coming from EuiIcon + expect(stateMessage).toBe(expectedMessage); } catch { throw new Error( `Expected snapshot state message "${expectedMessage}" for state "${state}, but got "${stateMessage}".` diff --git a/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx b/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx index f3846cd784ccc..5ac75f92ea45f 100644 --- a/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx +++ b/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx @@ -110,7 +110,7 @@ describe('Modal Inspect', () => { expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="index-pattern-title"]').text() - ).toContain('Index pattern '); + ).toBe('Index pattern '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="index-pattern-description"]') @@ -118,7 +118,7 @@ describe('Modal Inspect', () => { ).toBe('auditbeat-*, filebeat-*, packetbeat-*, winlogbeat-*'); expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="query-time-title"]').text() - ).toContain('Query time '); + ).toBe('Query time '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="query-time-description"]') @@ -128,7 +128,7 @@ describe('Modal Inspect', () => { wrapper .find('.euiDescriptionList__title span[data-test-subj="request-timestamp-title"]') .text() - ).toContain('Request timestamp '); + ).toBe('Request timestamp '); }); test('Click on request Tab', () => { diff --git a/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx index 6942a7708db78..d23f1cfacf94b 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx @@ -107,12 +107,10 @@ describe('health check', () => { const [action] = queryAllByText(/Learn more/i); expect(description.textContent).toMatchInlineSnapshot( - `"You must enable API keys to use Alerting. Learn more.External link(opens in a new tab or window)"` + `"You must enable API keys to use Alerting. Learn more.(opens in a new tab or window)"` ); - expect(action.textContent).toMatchInlineSnapshot( - `"Learn more.External link(opens in a new tab or window)"` - ); + expect(action.textContent).toMatchInlineSnapshot(`"Learn more.(opens in a new tab or window)"`); expect(action.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/elasticsearch/reference/mocked-test-branch/security-settings.html#api-key-service-settings"` @@ -143,12 +141,12 @@ describe('health check', () => { const description = queryByRole(/banner/i); expect(description!.textContent).toMatchInlineSnapshot( - `"You must configure an encryption key to use Alerting. Learn more.External link(opens in a new tab or window)"` + `"You must configure an encryption key to use Alerting. Learn more.(opens in a new tab or window)"` ); const action = queryByText(/Learn/i); expect(action!.textContent).toMatchInlineSnapshot( - `"Learn more.External link(opens in a new tab or window)"` + `"Learn more.(opens in a new tab or window)"` ); expect(action!.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/kibana/mocked-test-branch/alert-action-settings-kb.html#general-alert-action-settings"` @@ -181,12 +179,12 @@ describe('health check', () => { const description = queryByText(/You must enable/i); expect(description!.textContent).toMatchInlineSnapshot( - `"You must enable API keys and configure an encryption key to use Alerting. Learn more.External link(opens in a new tab or window)"` + `"You must enable API keys and configure an encryption key to use Alerting. Learn more.(opens in a new tab or window)"` ); const action = queryByText(/Learn/i); expect(action!.textContent).toMatchInlineSnapshot( - `"Learn more.External link(opens in a new tab or window)"` + `"Learn more.(opens in a new tab or window)"` ); expect(action!.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/kibana/mocked-test-branch/alerting-setup.html#alerting-prerequisites"` diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx index e7cafb23ee0fa..737501f444300 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx @@ -373,12 +373,9 @@ describe('execution duration overview', () => { const avgExecutionDurationPanel = wrapper.find('[data-test-subj="avgExecutionDurationPanel"]'); expect(avgExecutionDurationPanel.exists()).toBeTruthy(); expect(avgExecutionDurationPanel.first().prop('color')).toEqual('warning'); - - const avgExecutionDurationStat = wrapper - .find('EuiStat[data-test-subj="avgExecutionDurationStat"]') - .text() - .replaceAll('Info', ''); - expect(avgExecutionDurationStat).toEqual('Average duration16:44:44.345'); + expect(wrapper.find('EuiStat[data-test-subj="avgExecutionDurationStat"]').text()).toEqual( + 'Average duration16:44:44.345' + ); expect(wrapper.find('[data-test-subj="ruleDurationWarning"]').exists()).toBeTruthy(); }); diff --git a/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx b/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx index 3576d7e34fd0b..ee485f8aee0c0 100644 --- a/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx +++ b/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx @@ -63,5 +63,5 @@ test('Can delete drilldowns', () => { test('Error is displayed', () => { const screen = render(); - expect(screen.getByText('an error')).toBeInTheDocument(); + expect(screen.getByLabelText('an error')).toBeInTheDocument(); }); diff --git a/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap b/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap index bf25513a6bc2c..51753d2ce8bb3 100644 --- a/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap +++ b/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap @@ -179,11 +179,10 @@ exports[`PingListExpandedRow renders link to docs if body is not recorded but it > docs - External link - + /> diff --git a/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap b/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap index 29d1ba922de8f..80b751d8e243b 100644 --- a/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap +++ b/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap @@ -72,11 +72,10 @@ Array [ > Set tags - External link - + /> diff --git a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx index 671371093c819..63b4d2945a51c 100644 --- a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx @@ -11,7 +11,7 @@ import { render } from '../../../../../lib/helper/rtl_helpers'; describe('NetworkRequestsTotal', () => { it('message in case total is greater than fetched', () => { - const { getByText } = render( + const { getByText, getByLabelText } = render( { ); expect(getByText('First 1000/1100 network requests')).toBeInTheDocument(); - expect(getByText('Info')).toBeInTheDocument(); + expect(getByLabelText('Info')).toBeInTheDocument(); }); it('message in case total is equal to fetched requests', () => { diff --git a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx index 4241a7238ecd6..7558a82e45df4 100644 --- a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx @@ -13,8 +13,8 @@ import { TestWrapper } from './waterfall_marker_test_helper'; describe('', () => { it('renders a dot icon when `field` is an empty string', () => { - const { getByText } = render(); - expect(getByText('An icon indicating that this marker has no field associated with it')); + const { getByLabelText } = render(); + expect(getByLabelText('An icon indicating that this marker has no field associated with it')); }); it('renders an embeddable when opened', async () => { diff --git a/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx b/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx index d232b12f3a47b..2b899aad783d7 100644 --- a/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx +++ b/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx @@ -45,22 +45,20 @@ describe('KeyUXMetrics', () => { }; }; - // Tests include the word "info" between the task and time to account for the rendered text coming from - // the EuiIcon (tooltip) embedded within each stat description expect( - getAllByText(checkText('Longest long task durationInfo271 ms'))[0] + getAllByText(checkText('Longest long task duration271 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('Total long tasks durationInfo520 ms'))[0] + getAllByText(checkText('Total long tasks duration520 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('No. of long tasksInfo3'))[0] + getAllByText(checkText('No. of long tasks3'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('Total blocking timeInfo271 ms'))[0] + getAllByText(checkText('Total blocking time271 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('First contentful paintInfo1.27 s'))[0] + getAllByText(checkText('First contentful paint1.27 s'))[0] ).toBeInTheDocument(); }); }); diff --git a/yarn.lock b/yarn.lock index d78a3567a18c0..0b6f13bc96b94 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1516,10 +1516,10 @@ resolved "https://registry.yarnpkg.com/@elastic/eslint-plugin-eui/-/eslint-plugin-eui-0.0.2.tgz#56b9ef03984a05cc213772ae3713ea8ef47b0314" integrity sha512-IoxURM5zraoQ7C8f+mJb9HYSENiZGgRVcG4tLQxE61yHNNRDXtGDWTZh8N1KIHcsqN1CEPETjuzBXkJYF/fDiQ== -"@elastic/eui@52.2.0": - version "52.2.0" - resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-52.2.0.tgz#761101a29b96a4b5270ef93541dab7bb27f5ca50" - integrity sha512-XboYerntCOTHWHYMWJGzJtu5JYO6pk5IWh0ZHJEQ4SEjmLbTV2bFrVBTO/8uaU7GhV9/RNIo7BU5wHRyYP7z1g== +"@elastic/eui@51.1.0": + version "51.1.0" + resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-51.1.0.tgz#338b710ae7a819bb7c3b8e1916080610e0b8e691" + integrity sha512-pjbBSkfDPAjXBRCMk4zsyZ3sPpf70XVcbOzr4BzT0MW38uKjEgEh6nu1aCdnOi+jVSHRtziJkX9rD8BRDWfsnw== dependencies: "@types/chroma-js" "^2.0.0" "@types/lodash" "^4.14.160" From 40ba9bf53bfa69e9aa8902bbef154360efdb5fe8 Mon Sep 17 00:00:00 2001 From: Spencer Date: Tue, 29 Mar 2022 16:12:14 -0600 Subject: [PATCH 135/160] [axe-config] extract module to it's own package (#128815) --- package.json | 2 + packages/BUILD.bazel | 2 + packages/kbn-axe-config/BUILD.bazel | 123 ++++++++++++++++++ packages/kbn-axe-config/README.md | 3 + packages/kbn-axe-config/package.json | 11 ++ .../config.ts => kbn-axe-config/src/index.ts} | 2 +- packages/kbn-axe-config/tsconfig.json | 17 +++ packages/kbn-test-jest-helpers/BUILD.bazel | 4 +- .../kbn-test-jest-helpers/src/axe_helpers.ts | 2 +- packages/kbn-test/src/index.ts | 2 - test/accessibility/services/a11y/a11y.ts | 2 +- .../apm/ftr_e2e/cypress/support/commands.ts | 11 +- .../applications/shared/cypress/commands.ts | 2 +- yarn.lock | 8 ++ 14 files changed, 176 insertions(+), 15 deletions(-) create mode 100644 packages/kbn-axe-config/BUILD.bazel create mode 100644 packages/kbn-axe-config/README.md create mode 100644 packages/kbn-axe-config/package.json rename packages/{kbn-test/src/a11y/config.ts => kbn-axe-config/src/index.ts} (97%) create mode 100644 packages/kbn-axe-config/tsconfig.json diff --git a/package.json b/package.json index f70bde1a2108f..9f2e28774d0de 100644 --- a/package.json +++ b/package.json @@ -464,6 +464,7 @@ "@istanbuljs/schema": "^0.1.2", "@jest/console": "^26.6.2", "@jest/reporters": "^26.6.2", + "@kbn/axe-config": "link:bazel-bin/packages/kbn-axe-config", "@kbn/babel-code-parser": "link:bazel-bin/packages/kbn-babel-code-parser", "@kbn/babel-preset": "link:bazel-bin/packages/kbn-babel-preset", "@kbn/bazel-packages": "link:bazel-bin/packages/kbn-bazel-packages", @@ -582,6 +583,7 @@ "@types/kbn__analytics": "link:bazel-bin/packages/kbn-analytics/npm_module_types", "@types/kbn__apm-config-loader": "link:bazel-bin/packages/kbn-apm-config-loader/npm_module_types", "@types/kbn__apm-utils": "link:bazel-bin/packages/kbn-apm-utils/npm_module_types", + "@types/kbn__axe-config": "link:bazel-bin/packages/kbn-axe-config/npm_module_types", "@types/kbn__bazel-packages": "link:bazel-bin/packages/kbn-bazel-packages/npm_module_types", "@types/kbn__cli-dev-mode": "link:bazel-bin/packages/kbn-cli-dev-mode/npm_module_types", "@types/kbn__config": "link:bazel-bin/packages/kbn-config/npm_module_types", diff --git a/packages/BUILD.bazel b/packages/BUILD.bazel index f2ca181877883..5a4ee479c5c41 100644 --- a/packages/BUILD.bazel +++ b/packages/BUILD.bazel @@ -18,6 +18,7 @@ filegroup( "//packages/kbn-analytics:build", "//packages/kbn-apm-config-loader:build", "//packages/kbn-apm-utils:build", + "//packages/kbn-axe-config:build", "//packages/kbn-babel-code-parser:build", "//packages/kbn-babel-preset:build", "//packages/kbn-bazel-packages:build", @@ -103,6 +104,7 @@ filegroup( "//packages/kbn-analytics:build_types", "//packages/kbn-apm-config-loader:build_types", "//packages/kbn-apm-utils:build_types", + "//packages/kbn-axe-config:build_types", "//packages/kbn-bazel-packages:build_types", "//packages/kbn-cli-dev-mode:build_types", "//packages/kbn-config-schema:build_types", diff --git a/packages/kbn-axe-config/BUILD.bazel b/packages/kbn-axe-config/BUILD.bazel new file mode 100644 index 0000000000000..d6498ed1546e3 --- /dev/null +++ b/packages/kbn-axe-config/BUILD.bazel @@ -0,0 +1,123 @@ +load("@npm//@bazel/typescript:index.bzl", "ts_config") +load("@build_bazel_rules_nodejs//:index.bzl", "js_library") +load("//src/dev/bazel:index.bzl", "jsts_transpiler", "pkg_npm", "pkg_npm_types", "ts_project") + +PKG_DIRNAME = "kbn-axe-config" +PKG_REQUIRE_NAME = "@kbn/axe-config" + +SOURCE_FILES = glob( + [ + "src/**/*.ts", + "src/**/*.tsx", + ], + exclude = [ + "**/*.test.*", + ], +) + +SRCS = SOURCE_FILES + +filegroup( + name = "srcs", + srcs = SRCS, +) + +NPM_MODULE_EXTRA_FILES = [ + "package.json", +] + +# In this array place runtime dependencies, including other packages and NPM packages +# which must be available for this code to run. +# +# To reference other packages use: +# "//repo/relative/path/to/package" +# eg. "//packages/kbn-utils" +# +# To reference a NPM package use: +# "@npm//name-of-package" +# eg. "@npm//lodash" +RUNTIME_DEPS = [ +] + +# In this array place dependencies necessary to build the types, which will include the +# :npm_module_types target of other packages and packages from NPM, including @types/* +# packages. +# +# To reference the types for another package use: +# "//repo/relative/path/to/package:npm_module_types" +# eg. "//packages/kbn-utils:npm_module_types" +# +# References to NPM packages work the same as RUNTIME_DEPS +TYPES_DEPS = [ + "@npm//@types/node", + "@npm//@types/jest", + "@npm//axe-core", +] + +jsts_transpiler( + name = "target_node", + srcs = SRCS, + build_pkg_name = package_name(), +) + +jsts_transpiler( + name = "target_web", + srcs = SRCS, + build_pkg_name = package_name(), + web = True, +) + +ts_config( + name = "tsconfig", + src = "tsconfig.json", + deps = [ + "//:tsconfig.base.json", + "//:tsconfig.bazel.json", + ], +) + +ts_project( + name = "tsc_types", + args = ['--pretty'], + srcs = SRCS, + deps = TYPES_DEPS, + declaration = True, + emit_declaration_only = True, + out_dir = "target_types", + root_dir = "src", + tsconfig = ":tsconfig", +) + +js_library( + name = PKG_DIRNAME, + srcs = NPM_MODULE_EXTRA_FILES, + deps = RUNTIME_DEPS + [":target_node", ":target_web"], + package_name = PKG_REQUIRE_NAME, + visibility = ["//visibility:public"], +) + +pkg_npm( + name = "npm_module", + deps = [":" + PKG_DIRNAME], +) + +filegroup( + name = "build", + srcs = [":npm_module"], + visibility = ["//visibility:public"], +) + +pkg_npm_types( + name = "npm_module_types", + srcs = SRCS, + deps = [":tsc_types"], + package_name = PKG_REQUIRE_NAME, + tsconfig = ":tsconfig", + visibility = ["//visibility:public"], +) + +filegroup( + name = "build_types", + srcs = [":npm_module_types"], + visibility = ["//visibility:public"], +) diff --git a/packages/kbn-axe-config/README.md b/packages/kbn-axe-config/README.md new file mode 100644 index 0000000000000..8f3556fefeb62 --- /dev/null +++ b/packages/kbn-axe-config/README.md @@ -0,0 +1,3 @@ +# @kbn/axe-config + +This is package shares [axe](https://www.deque.com/axe/) rule configuration and options between various axe tests and test runners (e.g., Kibana FTR, Cypress, jest). The API remains the same between each axe runner, and should ideally be shared between each to maintain consistency across Kibana. diff --git a/packages/kbn-axe-config/package.json b/packages/kbn-axe-config/package.json new file mode 100644 index 0000000000000..c5b929478c3de --- /dev/null +++ b/packages/kbn-axe-config/package.json @@ -0,0 +1,11 @@ +{ + "name": "@kbn/axe-config", + "private": true, + "version": "1.0.0", + "main": "./target_node/index.js", + "browser": "./target_web/index.js", + "license": "SSPL-1.0 OR Elastic License 2.0", + "kibana": { + "devOnly": true + } +} diff --git a/packages/kbn-test/src/a11y/config.ts b/packages/kbn-axe-config/src/index.ts similarity index 97% rename from packages/kbn-test/src/a11y/config.ts rename to packages/kbn-axe-config/src/index.ts index e5f6773f03502..df175dbf08173 100644 --- a/packages/kbn-test/src/a11y/config.ts +++ b/packages/kbn-axe-config/src/index.ts @@ -6,7 +6,7 @@ * Side Public License, v 1. */ -import { ReporterVersion } from 'axe-core'; +import type { ReporterVersion } from 'axe-core'; export const AXE_CONFIG = { rules: [ diff --git a/packages/kbn-axe-config/tsconfig.json b/packages/kbn-axe-config/tsconfig.json new file mode 100644 index 0000000000000..a8cfc2cceb08b --- /dev/null +++ b/packages/kbn-axe-config/tsconfig.json @@ -0,0 +1,17 @@ +{ + "extends": "../../tsconfig.bazel.json", + "compilerOptions": { + "declaration": true, + "emitDeclarationOnly": true, + "outDir": "target_types", + "rootDir": "src", + "stripInternal": false, + "types": [ + "jest", + "node" + ] + }, + "include": [ + "src/**/*" + ] +} diff --git a/packages/kbn-test-jest-helpers/BUILD.bazel b/packages/kbn-test-jest-helpers/BUILD.bazel index c97859e8baab1..dc8b83495494c 100644 --- a/packages/kbn-test-jest-helpers/BUILD.bazel +++ b/packages/kbn-test-jest-helpers/BUILD.bazel @@ -34,7 +34,7 @@ NPM_MODULE_EXTRA_FILES = [ RUNTIME_DEPS = [ "//packages/kbn-dev-utils", "//packages/kbn-i18n-react", - "//packages/kbn-test", + "//packages/kbn-axe-config", "//packages/kbn-std", "//packages/kbn-utils", "@npm//@elastic/elasticsearch", @@ -78,7 +78,7 @@ TYPES_DEPS = [ "//packages/kbn-dev-utils:npm_module_types", "//packages/kbn-i18n-react:npm_module_types", "//packages/kbn-std:npm_module_types", - "//packages/kbn-test:npm_module_types", + "//packages/kbn-axe-config:npm_module_types", "//packages/kbn-utils:npm_module_types", "@npm//@elastic/elasticsearch", "@npm//axios", diff --git a/packages/kbn-test-jest-helpers/src/axe_helpers.ts b/packages/kbn-test-jest-helpers/src/axe_helpers.ts index 215209546f956..6b04bed95c95a 100644 --- a/packages/kbn-test-jest-helpers/src/axe_helpers.ts +++ b/packages/kbn-test-jest-helpers/src/axe_helpers.ts @@ -8,7 +8,7 @@ import { configureAxe } from 'jest-axe'; import { Result } from 'axe-core'; -import { AXE_OPTIONS, AXE_CONFIG } from '@kbn/test'; +import { AXE_OPTIONS, AXE_CONFIG } from '@kbn/axe-config'; import { ReactWrapper } from './testbed/types'; const axeRunner = configureAxe({ globalOptions: { ...AXE_CONFIG } }); diff --git a/packages/kbn-test/src/index.ts b/packages/kbn-test/src/index.ts index a0e45f9d7b752..c9f0e67c558f1 100644 --- a/packages/kbn-test/src/index.ts +++ b/packages/kbn-test/src/index.ts @@ -69,5 +69,3 @@ export { runJest } from './jest/run'; export * from './kbn_archiver_cli'; export * from './kbn_client'; - -export { AXE_CONFIG, AXE_OPTIONS } from './a11y/config'; diff --git a/test/accessibility/services/a11y/a11y.ts b/test/accessibility/services/a11y/a11y.ts index fd4362c1c82b4..e04e38cb9f72f 100644 --- a/test/accessibility/services/a11y/a11y.ts +++ b/test/accessibility/services/a11y/a11y.ts @@ -8,7 +8,7 @@ import chalk from 'chalk'; import testSubjectToCss from '@kbn/test-subj-selector'; -import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; +import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/axe-config'; import { FtrService } from '../../ftr_provider_context'; import { AxeReport, printResult } from './axe_report'; diff --git a/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts b/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts index 3d8d86145cdac..98bad66b1cc76 100644 --- a/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts +++ b/x-pack/plugins/apm/ftr_e2e/cypress/support/commands.ts @@ -8,8 +8,7 @@ import 'cypress-real-events/support'; import { Interception } from 'cypress/types/net-stubbing'; import 'cypress-axe'; import moment from 'moment'; -// Commenting this out since it's breaking the tests. It was caused by https://github.com/elastic/kibana/commit/bef90a58663b6c4b668a7fe0ce45a002fb68c474#diff-8a4659c6955a712376fe5ca0d81636164d1b783a63fe9d1a23da4850bd0dfce3R10 -// import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; +import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/axe-config'; Cypress.Commands.add('loginAsReadOnlyUser', () => { cy.loginAs({ username: 'apm_read_user', password: 'changeme' }); @@ -88,13 +87,11 @@ Cypress.Commands.add( // A11y configuration const axeConfig = { - // See comment on line 11 - // ...AXE_CONFIG, + ...AXE_CONFIG, }; const axeOptions = { - // See comment on line 11 - // ...AXE_OPTIONS, - // runOnly: [...AXE_OPTIONS.runOnly, 'best-practice'], + ...AXE_OPTIONS, + runOnly: [...AXE_OPTIONS.runOnly, 'best-practice'], }; export const checkA11y = ({ skipFailures }: { skipFailures: boolean }) => { diff --git a/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts b/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts index 083d55e6f7029..c5773ec5f44b9 100644 --- a/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts +++ b/x-pack/plugins/enterprise_search/public/applications/shared/cypress/commands.ts @@ -42,7 +42,7 @@ export const login = ({ // eslint-disable-next-line import/no-extraneous-dependencies import 'cypress-axe'; // eslint-disable-next-line import/no-extraneous-dependencies -import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/test'; +import { AXE_CONFIG, AXE_OPTIONS } from '@kbn/axe-config'; const axeConfig = { ...AXE_CONFIG, diff --git a/yarn.lock b/yarn.lock index 0b6f13bc96b94..c13acd20ed888 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2932,6 +2932,10 @@ version "0.0.0" uid "" +"@kbn/axe-config@link:bazel-bin/packages/kbn-axe-config": + version "0.0.0" + uid "" + "@kbn/babel-code-parser@link:bazel-bin/packages/kbn-babel-code-parser": version "0.0.0" uid "" @@ -5954,6 +5958,10 @@ version "0.0.0" uid "" +"@types/kbn__axe-config@link:bazel-bin/packages/kbn-axe-config/npm_module_types": + version "0.0.0" + uid "" + "@types/kbn__bazel-packages@link:bazel-bin/packages/kbn-bazel-packages/npm_module_types": version "0.0.0" uid "" From de894d1ba6fe75d6c954abf68c9bd16c81271dbd Mon Sep 17 00:00:00 2001 From: Frank Hassanabad Date: Tue, 29 Mar 2022 16:32:18 -0600 Subject: [PATCH 136/160] [Security Solution] Adds event log telemetry specific for security solution rules (#128216) ## Summary Adds event log telemetry specific for security solution rules. This adds a new section to the telemetry underneath `detectionMetrics` called `detection_rule_status`.
<-- click this text to see a full JSON sample document

```json { "detection_rule_status": { "all_rules": { "eql": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "indicator": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "mlRule": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "query": { "failed": 4, "top_failed": { "1": { "message": "an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default", "count": 4 }, "2": { "message": "an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default", "count": 2 }, "3": { "message": "an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default", "count": 2 }, "4": { "message": "hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default", "count": 2 }, "5": { "message": "hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default", "count": 1 }, "6": { "message": "hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default", "count": 1 } }, "partial_failure": 2, "top_partial_failure": { "1": { "message": "This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled", "count": 189 }, "2": { "message": "This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent", "count": 187 } }, "succeeded": 2, "index_duration": { "max": 228568, "avg": 2292.8852459016393, "min": 0 }, "search_duration": { "max": 324, "avg": 21.661202185792348, "min": 1 }, "gap_duration": { "max": 5651, "avg": 3929.4166666666665, "min": 2811 }, "gap_count": 10 }, "savedQuery": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "threshold": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "total": { "failed": 4, "partial_failure": 2, "succeeded": 2 } }, "elastic_rules": { "eql": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "indicator": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "mlRule": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "query": { "failed": 2, "top_failed": { "1": { "message": "an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default", "count": 2 }, "2": { "message": "an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default", "count": 2 }, "3": { "message": "hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default", "count": 1 }, "4": { "message": "hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default", "count": 1 } }, "partial_failure": 1, "top_partial_failure": { "1": { "message": "This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent", "count": 187 } }, "succeeded": 1, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 278, "avg": 8.165745856353592, "min": 1 }, "gap_duration": { "max": 5474, "avg": 3831, "min": 2811 }, "gap_count": 6 }, "savedQuery": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "threshold": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "total": { "failed": 2, "partial_failure": 1, "succeeded": 1 } }, "custom_rules": { "eql": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "indicator": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "mlRule": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "query": { "failed": 2, "top_failed": { "1": { "message": "an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default", "count": 4 }, "2": { "message": "hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default", "count": 2 } }, "partial_failure": 1, "top_partial_failure": { "1": { "message": "This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled", "count": 189 } }, "succeeded": 1, "index_duration": { "max": 228568, "avg": 4536.1945945945945, "min": 0 }, "search_duration": { "max": 324, "avg": 34.86486486486486, "min": 8 }, "gap_duration": { "max": 5651, "avg": 4027.8333333333335, "min": 3051 }, "gap_count": 4 }, "savedQuery": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "threshold": { "failed": 0, "top_failed": {}, "partial_failure": 0, "top_partial_failure": {}, "succeeded": 0, "index_duration": { "max": 0, "avg": 0, "min": 0 }, "search_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_duration": { "max": 0, "avg": 0, "min": 0 }, "gap_count": 0 }, "total": { "failed": 2, "partial_failure": 1, "succeeded": 1 } } } } ```

**manual testing** Add some alerts and malfunction them into partial errors by having them not have their indexes and malfunction them by shutting down Kibana for a while and then starting it back up to have Kibana miss some alerts. Then go to Advanced Settings -> scroll to the bottom and click cluster data. Should see data like this after scrolling down for a while: Screen Shot 2022-03-21 at 4 18 58 PM ### Checklist Delete any items that are not applicable to this PR. - [x] [Unit or functional tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html) were updated or added to match the most common scenarios --- .../security_solution/server/plugin.ts | 1 + .../server/usage/collector.ts | 1600 +++++++++ .../usage/detections/get_initial_usage.ts | 3 +- .../usage/detections/get_metrics.test.ts | 23 + .../server/usage/detections/get_metrics.ts | 12 +- .../detections/rules/get_initial_usage.ts | 69 +- .../detections/rules/get_metrics.mocks.ts | 2908 ++++++++++++++++- .../usage/detections/rules/get_metrics.ts | 28 +- .../server/usage/detections/rules/types.ts | 70 + .../get_event_log_by_type_and_status.ts | 148 + .../usage/queries/utils/count_totals.test.ts | 81 + .../usage/queries/utils/count_totals.ts | 35 + .../get_event_log_agg_by_rule_type.test.ts | 80 + .../utils/get_event_log_agg_by_rule_type.ts | 68 + ...event_log_agg_by_rule_type_metrics.test.ts | 74 + .../get_event_log_agg_by_rule_type_metrics.ts | 79 + .../get_event_log_agg_by_rule_types.test.ts | 471 +++ .../utils/get_event_log_agg_by_rule_types.ts | 34 + ...vent_log_agg_by_rule_types_metrics.test.ts | 270 ++ ...get_event_log_agg_by_rule_types_metrics.ts | 19 + .../utils/get_event_log_agg_by_status.test.ts | 380 +++ .../utils/get_event_log_agg_by_status.ts | 39 + .../get_event_log_agg_by_statuses.test.ts | 486 +++ .../utils/get_event_log_agg_by_statuses.ts | 57 + .../get_event_log_by_type_and_status.test.ts | 74 + .../utils/get_search_for_all_rules.test.ts | 63 + .../queries/utils/get_search_for_all_rules.ts | 51 + .../utils/get_search_for_custom_rules.test.ts | 71 + .../utils/get_search_for_custom_rules.ts | 64 + .../get_search_for_elastic_rules.test.ts | 69 + .../utils/get_search_for_elastic_rules.ts | 62 + .../utils/transform_categories.test.ts | 149 + .../queries/utils/transform_categories.ts | 21 + .../utils/transform_category_bucket.test.ts | 22 + .../utils/transform_category_bucket.ts | 20 + .../transform_event_log_type_status.test.ts | 47 + .../utils/transform_event_log_type_status.ts | 138 + .../transform_single_rule_metric.test.ts | 137 + .../utils/transform_single_rule_metric.ts | 62 + .../security_solution/server/usage/types.ts | 89 + .../schema/xpack_plugins.json | 2458 ++++++++++++++ .../usage_collector/detection_rules.ts | 142 + 42 files changed, 10762 insertions(+), 12 deletions(-) create mode 100644 x-pack/plugins/security_solution/server/usage/queries/get_event_log_by_type_and_status.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_by_type_and_status.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.test.ts create mode 100644 x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.ts diff --git a/x-pack/plugins/security_solution/server/plugin.ts b/x-pack/plugins/security_solution/server/plugin.ts index 3f14af0d8affc..e22886ccd53ff 100644 --- a/x-pack/plugins/security_solution/server/plugin.ts +++ b/x-pack/plugins/security_solution/server/plugin.ts @@ -168,6 +168,7 @@ export class Plugin implements ISecuritySolutionPlugin { initUsageCollectors({ core, + eventLogIndex: eventLogService.getIndexPattern(), signalsIndex: DEFAULT_ALERTS_INDEX, ml: plugins.ml, usageCollection: plugins.usageCollection, diff --git a/x-pack/plugins/security_solution/server/usage/collector.ts b/x-pack/plugins/security_solution/server/usage/collector.ts index dc98b68f9f186..1169b04a868e6 100644 --- a/x-pack/plugins/security_solution/server/usage/collector.ts +++ b/x-pack/plugins/security_solution/server/usage/collector.ts @@ -18,6 +18,7 @@ export interface UsageData { export const registerCollector: RegisterCollector = ({ core, + eventLogIndex, signalsIndex, ml, usageCollection, @@ -308,6 +309,1604 @@ export const registerCollector: RegisterCollector = ({ }, }, }, + detection_rule_status: { + all_rules: { + eql: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + threat_match: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + machine_learning: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + query: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + saved_query: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + threshold: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + total: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of succeeded rules' }, + }, + }, + }, + elastic_rules: { + eql: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + threat_match: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + machine_learning: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + query: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + saved_query: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + threshold: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + total: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of succeeded rules' }, + }, + }, + }, + custom_rules: { + eql: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + threat_match: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + machine_learning: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + query: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + saved_query: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + threshold: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + top_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + top_partial_failures: { + type: 'array', + items: { + message: { + type: 'keyword', + _meta: { description: 'Failed rule message' }, + }, + count: { + type: 'long', + _meta: { description: 'Number of times the message occurred' }, + }, + }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of successful rules' }, + }, + index_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + search_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_duration: { + max: { + type: 'float', + _meta: { description: 'The max duration' }, + }, + avg: { + type: 'float', + _meta: { description: 'The avg duration' }, + }, + min: { + type: 'float', + _meta: { description: 'The min duration' }, + }, + }, + gap_count: { + type: 'long', + _meta: { description: 'The count of gaps' }, + }, + }, + total: { + failures: { + type: 'long', + _meta: { description: 'The number of failed rules' }, + }, + partial_failures: { + type: 'long', + _meta: { description: 'The number of partial failure rules' }, + }, + succeeded: { + type: 'long', + _meta: { description: 'The number of succeeded rules' }, + }, + }, + }, + }, }, ml_jobs: { ml_job_usage: { @@ -515,6 +2114,7 @@ export const registerCollector: RegisterCollector = ({ fetch: async ({ esClient }: CollectorFetchContext): Promise => { const savedObjectsClient = await getInternalSavedObjectsClient(core); const detectionMetrics = await getDetectionsMetrics({ + eventLogIndex, signalsIndex, esClient, savedObjectsClient, diff --git a/x-pack/plugins/security_solution/server/usage/detections/get_initial_usage.ts b/x-pack/plugins/security_solution/server/usage/detections/get_initial_usage.ts index 0d885aa3b142c..6252b865c0ec9 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/get_initial_usage.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/get_initial_usage.ts @@ -8,7 +8,7 @@ import type { DetectionMetrics } from './types'; import { getInitialMlJobUsage } from './ml_jobs/get_initial_usage'; -import { getInitialRulesUsage } from './rules/get_initial_usage'; +import { getInitialEventLogUsage, getInitialRulesUsage } from './rules/get_initial_usage'; /** * Initial detection metrics initialized. @@ -21,5 +21,6 @@ export const getInitialDetectionMetrics = (): DetectionMetrics => ({ detection_rules: { detection_rule_detail: [], detection_rule_usage: getInitialRulesUsage(), + detection_rule_status: getInitialEventLogUsage(), }, }); diff --git a/x-pack/plugins/security_solution/server/usage/detections/get_metrics.test.ts b/x-pack/plugins/security_solution/server/usage/detections/get_metrics.test.ts index 65929039bc104..a044c1a22e91e 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/get_metrics.test.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/get_metrics.test.ts @@ -25,6 +25,10 @@ import { getMockRuleAlertsResponse, getMockAlertCaseCommentsResponse, getEmptySavedObjectResponse, + getEventLogAllRules, + getEventLogElasticRules, + getElasticLogCustomRules, + getAllEventLogTransform, } from './rules/get_metrics.mocks'; import { getInitialDetectionMetrics } from './get_initial_usage'; import { getDetectionsMetrics } from './get_metrics'; @@ -45,6 +49,7 @@ describe('Detections Usage and Metrics', () => { it('returns zeroed counts if calls are empty', async () => { const logger = loggingSystemMock.createLogger(); const result = await getDetectionsMetrics({ + eventLogIndex: '', signalsIndex: '', esClient, savedObjectsClient, @@ -55,13 +60,18 @@ describe('Detections Usage and Metrics', () => { }); it('returns information with rule, alerts and cases', async () => { + esClient.search.mockResponseOnce(getEventLogAllRules()); + esClient.search.mockResponseOnce(getEventLogElasticRules()); + esClient.search.mockResponseOnce(getElasticLogCustomRules()); esClient.search.mockResponseOnce(getMockRuleAlertsResponse(3400)); savedObjectsClient.find.mockResolvedValueOnce(getMockRuleSearchResponse()); savedObjectsClient.find.mockResolvedValueOnce(getMockAlertCaseCommentsResponse()); // Get empty saved object for legacy notification system. savedObjectsClient.find.mockResolvedValueOnce(getEmptySavedObjectResponse()); + const logger = loggingSystemMock.createLogger(); const result = await getDetectionsMetrics({ + eventLogIndex: '', signalsIndex: '', esClient, savedObjectsClient, @@ -72,6 +82,7 @@ describe('Detections Usage and Metrics', () => { expect(result).toEqual({ ...getInitialDetectionMetrics(), detection_rules: { + detection_rule_status: getAllEventLogTransform(), detection_rule_detail: [ { alert_count_daily: 3400, @@ -116,6 +127,9 @@ describe('Detections Usage and Metrics', () => { }); it('returns information with on non elastic prebuilt rule', async () => { + esClient.search.mockResponseOnce(getEventLogAllRules()); + esClient.search.mockResponseOnce(getEventLogElasticRules()); + esClient.search.mockResponseOnce(getElasticLogCustomRules()); esClient.search.mockResponseOnce(getMockRuleAlertsResponse(800)); savedObjectsClient.find.mockResolvedValueOnce(getMockRuleSearchResponse('not_immutable')); savedObjectsClient.find.mockResolvedValueOnce(getMockAlertCaseCommentsResponse()); @@ -123,6 +137,7 @@ describe('Detections Usage and Metrics', () => { savedObjectsClient.find.mockResolvedValueOnce(getEmptySavedObjectResponse()); const logger = loggingSystemMock.createLogger(); const result = await getDetectionsMetrics({ + eventLogIndex: '', signalsIndex: '', esClient, savedObjectsClient, @@ -133,6 +148,7 @@ describe('Detections Usage and Metrics', () => { expect(result).toEqual({ ...getInitialDetectionMetrics(), detection_rules: { + detection_rule_status: getAllEventLogTransform(), detection_rule_detail: [], // *should not* contain custom detection rule details detection_rule_usage: { ...getInitialRulesUsage(), @@ -162,6 +178,9 @@ describe('Detections Usage and Metrics', () => { }); it('returns information with rule, no alerts and no cases', async () => { + esClient.search.mockResponseOnce(getEventLogAllRules()); + esClient.search.mockResponseOnce(getEventLogElasticRules()); + esClient.search.mockResponseOnce(getElasticLogCustomRules()); esClient.search.mockResponseOnce(getMockRuleAlertsResponse(0)); savedObjectsClient.find.mockResolvedValueOnce(getMockRuleSearchResponse()); savedObjectsClient.find.mockResolvedValueOnce(getMockAlertCaseCommentsResponse()); @@ -170,6 +189,7 @@ describe('Detections Usage and Metrics', () => { const logger = loggingSystemMock.createLogger(); const result = await getDetectionsMetrics({ + eventLogIndex: '', signalsIndex: '', esClient, savedObjectsClient, @@ -180,6 +200,7 @@ describe('Detections Usage and Metrics', () => { expect(result).toEqual({ ...getInitialDetectionMetrics(), detection_rules: { + detection_rule_status: getAllEventLogTransform(), detection_rule_detail: [ { alert_count_daily: 0, @@ -239,6 +260,7 @@ describe('Detections Usage and Metrics', () => { } as unknown as ReturnType); const logger = loggingSystemMock.createLogger(); const result = await getDetectionsMetrics({ + eventLogIndex: '', signalsIndex: '', esClient, savedObjectsClient, @@ -271,6 +293,7 @@ describe('Detections Usage and Metrics', () => { } as unknown as ReturnType); const result = await getDetectionsMetrics({ + eventLogIndex: '', signalsIndex: '', esClient, savedObjectsClient, diff --git a/x-pack/plugins/security_solution/server/usage/detections/get_metrics.ts b/x-pack/plugins/security_solution/server/usage/detections/get_metrics.ts index 258945fba662a..2d44928026859 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/get_metrics.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/get_metrics.ts @@ -11,7 +11,7 @@ import type { DetectionMetrics } from './types'; import { getMlJobMetrics } from './ml_jobs/get_metrics'; import { getRuleMetrics } from './rules/get_metrics'; -import { getInitialRulesUsage } from './rules/get_initial_usage'; +import { getInitialEventLogUsage, getInitialRulesUsage } from './rules/get_initial_usage'; import { getInitialMlJobUsage } from './ml_jobs/get_initial_usage'; export interface GetDetectionsMetricsOptions { @@ -20,9 +20,11 @@ export interface GetDetectionsMetricsOptions { savedObjectsClient: SavedObjectsClientContract; logger: Logger; mlClient: MlPluginSetup | undefined; + eventLogIndex: string; } export const getDetectionsMetrics = async ({ + eventLogIndex, signalsIndex, esClient, savedObjectsClient, @@ -31,7 +33,7 @@ export const getDetectionsMetrics = async ({ }: GetDetectionsMetricsOptions): Promise => { const [mlJobMetrics, detectionRuleMetrics] = await Promise.allSettled([ getMlJobMetrics({ mlClient, savedObjectsClient, logger }), - getRuleMetrics({ signalsIndex, esClient, savedObjectsClient, logger }), + getRuleMetrics({ signalsIndex, eventLogIndex, esClient, savedObjectsClient, logger }), ]); return { @@ -42,6 +44,10 @@ export const getDetectionsMetrics = async ({ detection_rules: detectionRuleMetrics.status === 'fulfilled' ? detectionRuleMetrics.value - : { detection_rule_detail: [], detection_rule_usage: getInitialRulesUsage() }, + : { + detection_rule_detail: [], + detection_rule_usage: getInitialRulesUsage(), + detection_rule_status: getInitialEventLogUsage(), + }, }; }; diff --git a/x-pack/plugins/security_solution/server/usage/detections/rules/get_initial_usage.ts b/x-pack/plugins/security_solution/server/usage/detections/rules/get_initial_usage.ts index 81ea7aec800e3..b4902e40db822 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/rules/get_initial_usage.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/rules/get_initial_usage.ts @@ -5,7 +5,13 @@ * 2.0. */ -import type { RulesTypeUsage } from './types'; +import type { + EventLogStatusMetric, + MaxAvgMin, + RulesTypeUsage, + SingleEventLogStatusMetric, + SingleEventMetric, +} from './types'; /** * Default detection rule usage count, split by type + elastic/custom @@ -82,3 +88,64 @@ export const getInitialRulesUsage = (): RulesTypeUsage => ({ notifications_disabled: 0, }, }); + +/** + * Returns the initial usage of event logs specific to rules. + * This returns them for all rules, custom rules, and "elastic_rules"/"immutable rules"/pre-packaged rules + * @returns The initial event log usage + */ +export const getInitialEventLogUsage = (): EventLogStatusMetric => ({ + all_rules: getInitialSingleEventLogUsage(), + custom_rules: getInitialSingleEventLogUsage(), + elastic_rules: getInitialSingleEventLogUsage(), +}); + +/** + * Returns the initial single event metric for a particular event log. + * This returns the initial single event metric for either rules, custom rules, or "elastic_rules"/"immutable rules"/pre-packaged rules + * @see getInitialEventLogUsage + * @returns The initial event log usage for a single event metric. + */ +export const getInitialSingleEventLogUsage = (): SingleEventLogStatusMetric => ({ + eql: getInitialSingleEventMetric(), + threat_match: getInitialSingleEventMetric(), + machine_learning: getInitialSingleEventMetric(), + query: getInitialSingleEventMetric(), + saved_query: getInitialSingleEventMetric(), + threshold: getInitialSingleEventMetric(), + total: { + failures: 0, + partial_failures: 0, + succeeded: 0, + }, +}); + +/** + * Returns the initial single event metric. + * This returns the initial single event metric for either rules, custom rules, or "elastic_rules"/"immutable rules"/pre-packaged rules + * @see getInitialEventLogUsage + * @returns The initial event log usage for a single event metric. + */ +export const getInitialSingleEventMetric = (): SingleEventMetric => ({ + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: getInitialMaxAvgMin(), + search_duration: getInitialMaxAvgMin(), + gap_duration: getInitialMaxAvgMin(), + gap_count: 0, +}); + +/** + * Returns the max, avg, or min for an event. + * This returns the max, avg, or min for a single event metric. + * @see getInitialEventLogUsage + * @returns The max, avg, or min. + */ +export const getInitialMaxAvgMin = (): MaxAvgMin => ({ + max: 0.0, + avg: 0.0, + min: 0.0, +}); diff --git a/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.mocks.ts b/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.mocks.ts index 1801d5bd67782..8cedbeaec03d7 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.mocks.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.mocks.ts @@ -7,8 +7,9 @@ import type { SearchResponse } from '@elastic/elasticsearch/lib/api/types'; import type { SavedObjectsFindResponse } from 'kibana/server'; -import type { AlertAggs } from '../../types'; +import type { AlertAggs, EventLogTypeStatusAggs } from '../../types'; import { CommentAttributes, CommentType } from '../../../../../cases/common/api/cases/comment'; +import type { EventLogStatusMetric, SingleEventLogStatusMetric } from './types'; export const getMockRuleAlertsResponse = (docCount: number): SearchResponse => ({ took: 7, @@ -97,3 +98,2908 @@ export const getEmptySavedObjectResponse = (): SavedObjectsFindResponse => ({ + took: 495, + timed_out: false, + _shards: { + total: 1, + successful: 1, + skipped: 0, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + eventActionExecutionMetrics: { + doc_count: 325, + 'siem.queryRule': { + doc_count: 325, + maxTotalIndexDuration: { + value: 228568, + }, + avgGapDuration: { + value: 4246.375, + }, + maxTotalSearchDuration: { + value: 324, + }, + gapCount: { + value: 6, + }, + avgTotalIndexDuration: { + value: 2610.1356466876973, + }, + minTotalIndexDuration: { + value: 0, + }, + minGapDuration: { + value: 2811, + }, + avgTotalSearchDuration: { + value: 23.42902208201893, + }, + minTotalSearchDuration: { + value: 1, + }, + maxGapDuration: { + value: 5651, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.mlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + }, + eventActionStatusChange: { + doc_count: 1297, + 'partial failure': { + doc_count: 325, + 'siem.queryRule': { + doc_count: 325, + categories: { + buckets: [ + { + doc_count: 163, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + }, + { + doc_count: 162, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + }, + ], + }, + cardinality: { + value: 2, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + failed: { + doc_count: 8, + 'siem.queryRule': { + doc_count: 8, + categories: { + buckets: [ + { + doc_count: 2, + key: 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + }, + { + doc_count: 2, + key: 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + }, + ], + }, + cardinality: { + value: 4, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + succeeded: { + doc_count: 317, + 'siem.queryRule': { + doc_count: 317, + cardinality: { + value: 2, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + }, + }, + }, +}); + +/** + * Returns empty event log all rules for testing when you get all the rules. + * See "getEventLogAllRulesResult" for the transform results for use in tests + * @see get_event_log_by_type_and_status + * @see getEventLogAllRulesResult + * @returns The Elasticsearch aggregation for all the rules + */ +export const getEmptyEventLogAllRules = (): SearchResponse => ({ + took: 495, + timed_out: false, + _shards: { + total: 1, + successful: 1, + skipped: 0, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + eventActionExecutionMetrics: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.mlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + }, + eventActionStatusChange: { + doc_count: 0, + 'partial failure': { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + failed: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + succeeded: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + }, + }, + }, +}); + +/** + * Returns the event log total rules for testing when you get elastic rules specifically. + * See "getEventLogElasticRulesResult" for the transform results for use in tests + * @see get_event_log_by_type_and_status + * @see getEventLogElasticRulesResult + * @returns The Elasticsearch aggregation for "elastic rules"/"immutable"/"pre-built rules" + */ +export const getEventLogElasticRules = (): SearchResponse => ({ + took: 488, + timed_out: false, + _shards: { + total: 1, + successful: 1, + skipped: 0, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + eventActionExecutionMetrics: { + doc_count: 160, + 'siem.queryRule': { + doc_count: 160, + maxTotalIndexDuration: { + value: 0, + }, + avgGapDuration: { + value: 4141.75, + }, + maxTotalSearchDuration: { + value: 278, + }, + gapCount: { + value: 4, + }, + avgTotalIndexDuration: { + value: 0, + }, + minTotalIndexDuration: { + value: 0, + }, + minGapDuration: { + value: 2811, + }, + avgTotalSearchDuration: { + value: 9.185897435897436, + }, + minTotalSearchDuration: { + value: 1, + }, + maxGapDuration: { + value: 5474, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.mlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + }, + eventActionStatusChange: { + doc_count: 642, + 'partial failure': { + doc_count: 162, + 'siem.queryRule': { + doc_count: 162, + categories: { + buckets: [ + { + doc_count: 162, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + }, + ], + }, + cardinality: { + value: 1, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + failed: { + doc_count: 4, + 'siem.queryRule': { + doc_count: 4, + categories: { + buckets: [ + { + doc_count: 1, + key: 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + }, + { + doc_count: 1, + key: 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + }, + ], + }, + cardinality: { + value: 2, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + succeeded: { + doc_count: 156, + 'siem.queryRule': { + doc_count: 156, + cardinality: { + value: 1, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + }, + }, + }, +}); + +/** + * Returns empty event log total rules for testing when you get elastic rules specifically. + * See "getEventLogElasticRulesResult" for the transform results for use in tests + * @see get_event_log_by_type_and_status + * @see getEventLogElasticRulesResult + * @returns The Elasticsearch aggregation for "elastic rules"/"immutable"/"pre-built rules" + */ +export const getEmptyEventLogElasticRules = (): SearchResponse => ({ + took: 488, + timed_out: false, + _shards: { + total: 1, + successful: 1, + skipped: 0, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + eventActionExecutionMetrics: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.mlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + }, + eventActionStatusChange: { + doc_count: 0, + 'partial failure': { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + failed: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + succeeded: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + }, + }, + }, +}); + +/** + * Returns the event log custom rules for testing when you get custom rules specifically. + * See "getEventLogCustomRulesResult" for the transform results for use in tests + * @see get_event_log_by_type_and_status + * @see getEventLogCustomRulesResult + * @returns The Elasticsearch aggregation for "custom rules" + */ +export const getElasticLogCustomRules = (): SearchResponse => ({ + took: 487, + timed_out: false, + _shards: { + total: 1, + successful: 1, + skipped: 0, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + eventActionExecutionMetrics: { + doc_count: 165, + 'siem.queryRule': { + doc_count: 165, + maxTotalIndexDuration: { + value: 228568, + }, + avgGapDuration: { + value: 4351, + }, + maxTotalSearchDuration: { + value: 324, + }, + gapCount: { + value: 2, + }, + avgTotalIndexDuration: { + value: 5139.211180124224, + }, + minTotalIndexDuration: { + value: 0, + }, + minGapDuration: { + value: 3051, + }, + avgTotalSearchDuration: { + value: 37.22981366459627, + }, + minTotalSearchDuration: { + value: 8, + }, + maxGapDuration: { + value: 5651, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.mlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + }, + eventActionStatusChange: { + doc_count: 655, + 'partial failure': { + doc_count: 163, + 'siem.queryRule': { + doc_count: 163, + categories: { + buckets: [ + { + doc_count: 163, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + }, + ], + }, + cardinality: { + value: 1, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + failed: { + doc_count: 4, + 'siem.queryRule': { + doc_count: 4, + categories: { + buckets: [ + { + doc_count: 2, + key: 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + }, + { + doc_count: 2, + key: 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + }, + ], + }, + cardinality: { + value: 2, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + succeeded: { + doc_count: 161, + 'siem.queryRule': { + doc_count: 161, + cardinality: { + value: 1, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + }, + }, + }, +}); + +/** + * Returns the empty event log total rules for testing when you get custom rules specifically. + * See "getEventLogCustomRulesResult" for the transform results for use in tests + * @see get_event_log_by_type_and_status + * @see getEventLogCustomRulesResult + * @returns The Elasticsearch aggregation for "custom rules" + */ +export const getEmptyElasticLogCustomRules = (): SearchResponse => ({ + took: 487, + timed_out: false, + _shards: { + total: 1, + successful: 1, + skipped: 0, + failed: 0, + }, + hits: { + max_score: null, + hits: [], + }, + aggregations: { + eventActionExecutionMetrics: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.mlRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + maxTotalIndexDuration: { + value: null, + }, + avgGapDuration: { + value: null, + }, + maxTotalSearchDuration: { + value: null, + }, + gapCount: { + value: 0, + }, + avgTotalIndexDuration: { + value: null, + }, + minTotalIndexDuration: { + value: null, + }, + minGapDuration: { + value: null, + }, + avgTotalSearchDuration: { + value: null, + }, + minTotalSearchDuration: { + value: null, + }, + maxGapDuration: { + value: null, + }, + }, + }, + eventActionStatusChange: { + doc_count: 0, + 'partial failure': { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + failed: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + categories: { + buckets: [], + }, + cardinality: { + value: 0, + }, + }, + }, + succeeded: { + doc_count: 0, + 'siem.queryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.savedQueryRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.eqlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.thresholdRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.mlRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + 'siem.indicatorRule': { + doc_count: 0, + cardinality: { + value: 0, + }, + }, + }, + }, + }, +}); + +/** + * Gets the all rule results for tests. + * @see getEventLogAllRules + * @returns The transform of "getEventLogAllRules" + */ +export const getEventLogAllRulesResult = (): SingleEventLogStatusMetric => ({ + eql: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + threat_match: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + machine_learning: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + query: { + failures: 4, + top_failures: [ + { + message: + 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + count: 2, + }, + { + message: + 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + count: 2, + }, + { + message: + 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + count: 1, + }, + { + message: + 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + count: 1, + }, + { + message: + 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + count: 1, + }, + { + message: + 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + count: 1, + }, + ], + partial_failures: 2, + top_partial_failures: [ + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + count: 163, + }, + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + count: 162, + }, + ], + succeeded: 2, + index_duration: { + max: 228568, + avg: 2610.1356466876973, + min: 0, + }, + search_duration: { + max: 324, + avg: 23.42902208201893, + min: 1, + }, + gap_duration: { + max: 5651, + avg: 4246.375, + min: 2811, + }, + gap_count: 6, + }, + saved_query: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + threshold: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + total: { + failures: 4, + partial_failures: 2, + succeeded: 2, + }, +}); + +/** + * Gets the elastic rule results for tests. + * @see getEventLogElasticRules + * @returns The transform of "getEventLogElasticRules" + */ +export const getEventLogElasticRulesResult = (): SingleEventLogStatusMetric => ({ + eql: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + threat_match: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + machine_learning: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + query: { + failures: 2, + top_failures: [ + { + message: + 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + count: 1, + }, + { + message: + 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + count: 1, + }, + { + message: + 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Endpoint Security id rule id execution id space ID default', + count: 1, + }, + { + message: + 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name Telnet Port Activity id rule id execution id space ID default', + count: 1, + }, + ], + partial_failures: 1, + top_partial_failures: [ + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + count: 162, + }, + ], + succeeded: 1, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 278, + avg: 9.185897435897436, + min: 1, + }, + gap_duration: { + max: 5474, + avg: 4141.75, + min: 2811, + }, + gap_count: 4, + }, + saved_query: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + threshold: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + total: { + failures: 2, + partial_failures: 1, + succeeded: 1, + }, +}); + +/** + * Gets the custom rule results for tests. + * @see getEventLogCustomRulesResult + * @returns The transform of "getEventLogCustomRulesResult" + */ +export const getEventLogCustomRulesResult = (): SingleEventLogStatusMetric => ({ + eql: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + threat_match: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + machine_learning: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + query: { + failures: 2, + top_failures: [ + { + message: + 'an hour were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + count: 2, + }, + { + message: + 'hours were not queried between this rule execution and the last execution so signals may have been missed Consider increasing your look behind time or adding more Kibana instances name * id rule id execution id space ID default', + count: 2, + }, + ], + partial_failures: 1, + top_partial_failures: [ + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + count: 163, + }, + ], + succeeded: 1, + index_duration: { + max: 228568, + avg: 5139.211180124224, + min: 0, + }, + search_duration: { + max: 324, + avg: 37.22981366459627, + min: 8, + }, + gap_duration: { + max: 5651, + avg: 4351, + min: 3051, + }, + gap_count: 2, + }, + saved_query: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + threshold: { + failures: 0, + top_failures: [], + partial_failures: 0, + top_partial_failures: [], + succeeded: 0, + index_duration: { + max: 0, + avg: 0, + min: 0, + }, + search_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_duration: { + max: 0, + avg: 0, + min: 0, + }, + gap_count: 0, + }, + total: { + failures: 2, + partial_failures: 1, + succeeded: 1, + }, +}); + +/** + * Gets all rule results for tests. + * @returns The transform of all the rule results + */ +export const getAllEventLogTransform = (): EventLogStatusMetric => ({ + all_rules: getEventLogAllRulesResult(), + elastic_rules: getEventLogElasticRulesResult(), + custom_rules: getEventLogCustomRulesResult(), +}); diff --git a/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.ts b/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.ts index b202ea964301c..a6d653632a564 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/rules/get_metrics.ts @@ -12,12 +12,13 @@ import { updateRuleUsage } from './update_usage'; import { getDetectionRules } from '../../queries/get_detection_rules'; import { getAlerts } from '../../queries/get_alerts'; import { MAX_PER_PAGE, MAX_RESULTS_WINDOW } from '../../constants'; -import { getInitialRulesUsage } from './get_initial_usage'; +import { getInitialEventLogUsage, getInitialRulesUsage } from './get_initial_usage'; import { getCaseComments } from '../../queries/get_case_comments'; import { getRuleIdToCasesMap } from './transform_utils/get_rule_id_to_cases_map'; import { getAlertIdToCountMap } from './transform_utils/get_alert_id_to_count_map'; import { getRuleIdToEnabledMap } from './transform_utils/get_rule_id_to_enabled_map'; import { getRuleObjectCorrelations } from './transform_utils/get_rule_object_correlations'; +import { getEventLogByTypeAndStatus } from '../../queries/get_event_log_by_type_and_status'; // eslint-disable-next-line no-restricted-imports import { legacyGetRuleActions } from '../../queries/legacy_get_rule_actions'; @@ -27,6 +28,7 @@ export interface GetRuleMetricsOptions { esClient: ElasticsearchClient; savedObjectsClient: SavedObjectsClientContract; logger: Logger; + eventLogIndex: string; } export const getRuleMetrics = async ({ @@ -34,6 +36,7 @@ export const getRuleMetrics = async ({ esClient, savedObjectsClient, logger, + eventLogIndex, }: GetRuleMetricsOptions): Promise => { try { // gets rule saved objects @@ -49,6 +52,7 @@ export const getRuleMetrics = async ({ return { detection_rule_detail: [], detection_rule_usage: getInitialRulesUsage(), + detection_rule_status: getInitialEventLogUsage(), }; } @@ -77,11 +81,21 @@ export const getRuleMetrics = async ({ logger, }); - const [detectionAlertsResp, caseComments, legacyRuleActions] = await Promise.all([ - detectionAlertsRespPromise, - caseCommentsPromise, - legacyRuleActionsPromise, - ]); + // gets the event log information by type and status + const eventLogMetricsTypeStatusPromise = getEventLogByTypeAndStatus({ + esClient, + logger, + eventLogIndex, + ruleResults, + }); + + const [detectionAlertsResp, caseComments, legacyRuleActions, eventLogMetricsTypeStatus] = + await Promise.all([ + detectionAlertsRespPromise, + caseCommentsPromise, + legacyRuleActionsPromise, + eventLogMetricsTypeStatusPromise, + ]); // create in-memory maps for correlation const legacyNotificationRuleIds = getRuleIdToEnabledMap(legacyRuleActions); @@ -108,6 +122,7 @@ export const getRuleMetrics = async ({ return { detection_rule_detail: elasticRuleObjects, detection_rule_usage: rulesUsage, + detection_rule_status: eventLogMetricsTypeStatus, }; } catch (e) { // ignore failure, usage will be zeroed. We use debug mode to not unnecessarily worry users as this will not effect them. @@ -117,6 +132,7 @@ export const getRuleMetrics = async ({ return { detection_rule_detail: [], detection_rule_usage: getInitialRulesUsage(), + detection_rule_status: getInitialEventLogUsage(), }; } }; diff --git a/x-pack/plugins/security_solution/server/usage/detections/rules/types.ts b/x-pack/plugins/security_solution/server/usage/detections/rules/types.ts index 54b3e6d6a0084..4b8f62ad01ed3 100644 --- a/x-pack/plugins/security_solution/server/usage/detections/rules/types.ts +++ b/x-pack/plugins/security_solution/server/usage/detections/rules/types.ts @@ -29,6 +29,7 @@ export interface RulesTypeUsage { export interface RuleAdoption { detection_rule_detail: RuleMetric[]; detection_rule_usage: RulesTypeUsage; + detection_rule_status: EventLogStatusMetric; } export interface RuleMetric { @@ -45,3 +46,72 @@ export interface RuleMetric { has_legacy_notification: boolean; has_notification: boolean; } + +/** + * All the metrics for + * - all_rules, All the rules which includes "custom" and "elastic rules"/"immutable"/"pre-packaged" + * - custom_rules, All the rules which are _not_ "elastic rules"/"immutable"/"pre-packaged", thus custom rules + * - elastic_rules, All the "elastic rules"/"immutable"/"pre-packaged" + * @see get_event_log_by_type_and_status + */ +export interface EventLogStatusMetric { + all_rules: SingleEventLogStatusMetric; + custom_rules: SingleEventLogStatusMetric; + elastic_rules: SingleEventLogStatusMetric; +} + +/** + * Simple max, avg, min interface. + * @see SingleEventMetric + * @see EventLogStatusMetric + */ +export interface MaxAvgMin { + max: number; + avg: number; + min: number; +} + +/** + * Single event metric and how many failures, succeeded, index, durations. + * @see SingleEventLogStatusMetric + * @see EventLogStatusMetric + */ +export interface SingleEventMetric { + failures: number; + top_failures: FailureMessage[]; + partial_failures: number; + top_partial_failures: FailureMessage[]; + succeeded: number; + index_duration: MaxAvgMin; + search_duration: MaxAvgMin; + gap_duration: MaxAvgMin; + gap_count: number; +} + +/** + * This contains the single event log status metric + * @see EventLogStatusMetric + */ +export interface SingleEventLogStatusMetric { + eql: SingleEventMetric; + threat_match: SingleEventMetric; + machine_learning: SingleEventMetric; + query: SingleEventMetric; + saved_query: SingleEventMetric; + threshold: SingleEventMetric; + total: { + failures: number; + partial_failures: number; + succeeded: number; + }; +} + +/** + * This is the format for a failure message which is the message + * and a count of how many rules had that failure message. + * @see EventLogStatusMetric + */ +export interface FailureMessage { + message: string; + count: number; +} diff --git a/x-pack/plugins/security_solution/server/usage/queries/get_event_log_by_type_and_status.ts b/x-pack/plugins/security_solution/server/usage/queries/get_event_log_by_type_and_status.ts new file mode 100644 index 0000000000000..4e6d982bf1d7d --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/get_event_log_by_type_and_status.ts @@ -0,0 +1,148 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { ElasticsearchClient, Logger, SavedObjectsFindResult } from 'kibana/server'; +import { + EQL_RULE_TYPE_ID, + INDICATOR_RULE_TYPE_ID, + ML_RULE_TYPE_ID, + QUERY_RULE_TYPE_ID, + THRESHOLD_RULE_TYPE_ID, + SAVED_QUERY_RULE_TYPE_ID, +} from '@kbn/securitysolution-rules'; +import type { EventLogTypeStatusAggs, RuleSearchResult } from '../types'; +import type { EventLogStatusMetric } from '../detections/rules/types'; +import { getEventLogAggByStatuses } from './utils/get_event_log_agg_by_statuses'; +import { transformEventLogTypeStatus } from './utils/transform_event_log_type_status'; +import { getInitialEventLogUsage } from '../detections/rules/get_initial_usage'; +import { getSearchForAllRules } from './utils/get_search_for_all_rules'; +import { getSearchForElasticRules } from './utils/get_search_for_elastic_rules'; +import { getSearchForCustomRules } from './utils/get_search_for_custom_rules'; + +export interface GetEventLogByTypeAndStatusOptions { + esClient: ElasticsearchClient; + eventLogIndex: string; + logger: Logger; + ruleResults: Array>; +} + +/** + * Gets the event logs by their rule type and rule status. Returns the structure + * transformed. If it malfunctions or times out then it will not malfunction other + * parts of telemetry. + * NOTE: This takes in "ruleResults" to filter against elastic rules and custom rules. + * If the event log recorded information about which rules were elastic vs. custom this + * would not need to be passed down. + * @param esClient the elastic client which should be a system based client + * @param eventLogIndex the index of the event log such as ".kibana-event-log-8.2.0" + * @param logger The kibana logger + * @param ruleResults The elastic and custom rules to filter against each. + * @returns The event log transformed + */ +export const getEventLogByTypeAndStatus = async ({ + esClient, + eventLogIndex, + logger, + ruleResults, +}: GetEventLogByTypeAndStatusOptions): Promise => { + try { + const typeAndStatus = await _getEventLogByTypeAndStatus({ + esClient, + eventLogIndex, + logger, + ruleResults, + }); + return typeAndStatus; + } catch (error) { + logger.debug( + `Error trying to get event log by type and status. Error message is: "${error.message}". Error is: "${error}". Returning empty initialized object.` + ); + return getInitialEventLogUsage(); + } +}; + +/** + * Non-try-catch version. Gets the event logs by their rule type and rule status. Returns the structure + * transformed. + * NOTE: This takes in "ruleResults" to filter against elastic rules and custom rules. + * If the event log recorded information about which rules were elastic vs. custom this + * would not need to be passed down. + * @param esClient the elastic client which should be a system based client + * @param eventLogIndex the index of the event log such as ".kibana-event-log-8.2.0" + * @param logger The kibana logger + * @param ruleResults The elastic and custom rules to filter against each. + * @returns The event log transformed + */ +const _getEventLogByTypeAndStatus = async ({ + esClient, + eventLogIndex, + logger, + ruleResults, +}: GetEventLogByTypeAndStatusOptions): Promise => { + const aggs = getEventLogAggByStatuses({ + ruleStatuses: ['succeeded', 'failed', 'partial failure'], + ruleTypes: [ + EQL_RULE_TYPE_ID, + INDICATOR_RULE_TYPE_ID, + ML_RULE_TYPE_ID, + QUERY_RULE_TYPE_ID, + THRESHOLD_RULE_TYPE_ID, + SAVED_QUERY_RULE_TYPE_ID, + ], + }); + + const elasticRuleIds = ruleResults + .filter((ruleResult) => ruleResult.attributes.params.immutable) + .map((ruleResult) => ruleResult.id); + + const queryForTotal = getSearchForAllRules({ eventLogIndex, aggs }); + const queryForElasticRules = getSearchForElasticRules({ eventLogIndex, aggs, elasticRuleIds }); + const queryForCustomRules = getSearchForCustomRules({ eventLogIndex, aggs, elasticRuleIds }); + logger.debug( + `Getting event logs by type and status with query for total: ${JSON.stringify( + queryForTotal + )}, elastic_rules: ${JSON.stringify(queryForElasticRules)} custom_rules: ${JSON.stringify( + queryForCustomRules + )}` + ); + + const [totalRules, elasticRules, customRules] = await Promise.all([ + esClient.search(queryForTotal), + esClient.search(queryForElasticRules), + esClient.search(queryForCustomRules), + ]); + + logger.debug( + `Raw search results of event logs by type and status for total: ${JSON.stringify( + totalRules + )} elastic_rules: ${JSON.stringify(elasticRules)}, custom_rules: ${JSON.stringify(customRules)}` + ); + + const totalRulesTransformed = transformEventLogTypeStatus({ + aggs: totalRules.aggregations, + logger, + }); + const elasticRulesTransformed = transformEventLogTypeStatus({ + aggs: elasticRules.aggregations, + logger, + }); + const customRulesTransformed = transformEventLogTypeStatus({ + aggs: customRules.aggregations, + logger, + }); + + const logStatusMetric: EventLogStatusMetric = { + all_rules: totalRulesTransformed, + elastic_rules: elasticRulesTransformed, + custom_rules: customRulesTransformed, + }; + logger.debug( + `Metrics transformed for event logs of type and status are: ${JSON.stringify(logStatusMetric)}` + ); + + return logStatusMetric; +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.test.ts new file mode 100644 index 0000000000000..85cb4389cdbd7 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.test.ts @@ -0,0 +1,81 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { countTotals } from './count_totals'; + +describe('count_totals', () => { + test('returns 0 if given an empty array', () => { + const result = countTotals([]); + expect(result).toEqual(0); + }); + + test('returns 0 if given a single cardinality with a null value', () => { + const result = countTotals([ + { + doc_count: 0, + cardinality: { value: null }, + }, + ]); + expect(result).toEqual(0); + }); + + test('it counts a single cardinality by returning that single number', () => { + const result = countTotals([ + { + doc_count: 8, + cardinality: { value: 5 }, + }, + ]); + expect(result).toEqual(5); + }); + + test('it can count 2 cardinalities by adding their sum up correctly', () => { + const result = countTotals([ + { + doc_count: 8, + cardinality: { value: 5 }, + }, + { + doc_count: 8, + cardinality: { value: 3 }, + }, + ]); + expect(result).toEqual(8); + }); + + test('it can will skip a single cardinality value if that value is null', () => { + const result = countTotals([ + { + doc_count: 8, + cardinality: { value: 5 }, + }, + { + doc_count: 0, + cardinality: { value: null }, + }, + ]); + expect(result).toEqual(5); + }); + + test('it can will skip a single cardinality value if that value is null but add the 3rd one', () => { + const result = countTotals([ + { + doc_count: 8, + cardinality: { value: 5 }, + }, + { + doc_count: 0, + cardinality: { value: null }, + }, + { + doc_count: 0, + cardinality: { value: 3 }, + }, + ]); + expect(result).toEqual(8); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.ts new file mode 100644 index 0000000000000..698d654e1e38d --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/count_totals.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { CountCardinality } from '../../types'; + +/** + * Given an array of cardinalities this will count them and return the total. + * You can use this to count failures, partial failures, successes, etc... + * @example + * ```ts + * const failed = countTotals([ + * eqlFailure, + * indicatorFailure, + * mlFailure, + * queryFailure, + * savedQueryFailure, + * thresholdFailure, + * ]), + * ``` + * @param countCardinalities Array of cardinalities to count. + * @returns The count or zero if the cardinalities do not exist or it is an empty array. + */ +export const countTotals = (countCardinalities: CountCardinality[]) => { + return countCardinalities.reduce((accum, countCardinality) => { + if (countCardinality.cardinality.value != null) { + return countCardinality.cardinality.value + accum; + } else { + return accum; + } + }, 0); +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.test.ts new file mode 100644 index 0000000000000..3ecbdd0d03554 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.test.ts @@ -0,0 +1,80 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { getEventLogAggByRuleType } from './get_event_log_agg_by_rule_type'; + +describe('get_event_log_agg_by_rule_type', () => { + test('returns aggregation that does NOT have "categorize_text" when status is "succeeded"', () => { + const result = getEventLogAggByRuleType({ ruleType: 'siem.eqlRule', ruleStatus: 'succeeded' }); + expect(result).toEqual({ + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }); + }); + + test('returns aggregation that has "categorize_text" when status is "failed"', () => { + const result = getEventLogAggByRuleType({ ruleType: 'siem.queryRule', ruleStatus: 'failed' }); + expect(result).toEqual({ + filter: { + term: { + 'rule.category': 'siem.queryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }); + }); + + test('returns aggregation that has "categorize_text" when status is "partial failure"', () => { + const result = getEventLogAggByRuleType({ + ruleType: 'siem.indicatorRule', + ruleStatus: 'partial failure', + }); + expect(result).toEqual({ + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.ts new file mode 100644 index 0000000000000..49dd76aef2bce --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { RuleTypeId } from '@kbn/securitysolution-rules'; +import type { RuleStatus } from '../../types'; + +export interface GetEventLogAggByRuleTypeOptions { + ruleType: RuleTypeId; + ruleStatus: RuleStatus; +} + +/** + * Given a rule type and rule status this will return an aggregation filter and a + * sub aggregation of categories and count how many rule id's are associated. If the + * rule status is "failed" or "partial failure" you get the added aggregation of a + * categorize text added. This categorize text will give you the top 10 failures based + * on the message field. + * @param ruleType The rule type such as "siem.eqlRule" | "siem.mlRule" etc... + * @param ruleStatus The rule status such as "succeeded" | "partial failure" | "failed" + * @returns The aggregation to put into a search + */ +export const getEventLogAggByRuleType = ({ + ruleType, + ruleStatus, +}: GetEventLogAggByRuleTypeOptions): AggregationsAggregationContainer => { + if (ruleStatus === 'failed' || ruleStatus === 'partial failure') { + return { + filter: { + term: { + 'rule.category': ruleType, + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }; + } else { + return { + filter: { + term: { + 'rule.category': ruleType, + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }; + } +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.test.ts new file mode 100644 index 0000000000000..09a988fbf02ef --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.test.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { getEventLogAggByRuleTypeMetrics } from './get_event_log_agg_by_rule_type_metrics'; + +describe('get_event_log_agg_by_rule_type_metrics', () => { + test('returns expected aggregation when given a rule type', () => { + const result = getEventLogAggByRuleTypeMetrics('siem.eqlRule'); + expect(result).toEqual({ + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.ts new file mode 100644 index 0000000000000..6fe8103e29a0d --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_type_metrics.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { RuleTypeId } from '@kbn/securitysolution-rules'; + +/** + * Given a rule type this will return aggregations based on metrics such as "gapCount" and it + * will filter on the rule.category given the rule type to get the metrics based on the rule type + * @param ruleType The rule type such as "siem.eqlRule" | "siem.mlRule" etc... + * @returns The aggregation to put into a search + */ +export const getEventLogAggByRuleTypeMetrics = ( + ruleType: RuleTypeId +): AggregationsAggregationContainer => { + return { + filter: { + term: { + 'rule.category': ruleType, + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }; +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.test.ts new file mode 100644 index 0000000000000..a1dbde6d79841 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.test.ts @@ -0,0 +1,471 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { getEventLogAggByRuleTypes } from './get_event_log_agg_by_rule_types'; + +describe('get_event_log_agg_by_rule_types', () => { + test('it returns empty object if the array is empty', () => { + const result = getEventLogAggByRuleTypes({ ruleTypes: [], ruleStatus: 'succeeded' }); + expect(result).toEqual>({}); + }); + + test('it returns 1 aggregation if the array has a single element', () => { + const result = getEventLogAggByRuleTypes({ + ruleTypes: ['siem.eqlRule'], + ruleStatus: 'succeeded', + }); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }); + }); + + test('it returns 2 aggregations if the array has 2 elements', () => { + const result = getEventLogAggByRuleTypes({ + ruleTypes: ['siem.eqlRule', 'siem.mlRule'], + ruleStatus: 'succeeded', + }); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.mlRule': { + filter: { + term: { + 'rule.category': 'siem.mlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }); + }); + + test('it returns the same aggregation if the array has the same 2 elements of the same type for some reason.', () => { + const result = getEventLogAggByRuleTypes({ + ruleTypes: ['siem.eqlRule', 'siem.eqlRule'], + ruleStatus: 'succeeded', + }); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }); + }); + + test('it returns 6 aggregations if the array has 6 elements', () => { + const result = getEventLogAggByRuleTypes({ + ruleTypes: [ + 'siem.eqlRule', + 'siem.mlRule', + 'siem.indicatorRule', + 'siem.queryRule', + 'siem.savedQueryRule', + 'siem.thresholdRule', + ], + ruleStatus: 'succeeded', + }); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.mlRule': { + filter: { + term: { + 'rule.category': 'siem.mlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.queryRule': { + filter: { + term: { + 'rule.category': 'siem.queryRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.savedQueryRule': { + filter: { + term: { + 'rule.category': 'siem.savedQueryRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }); + }); + + test('it returns 6 aggregations if the array has 6 elements and will have "categorization" if the ruleStatus is "failed"', () => { + const result = getEventLogAggByRuleTypes({ + ruleTypes: [ + 'siem.eqlRule', + 'siem.mlRule', + 'siem.indicatorRule', + 'siem.queryRule', + 'siem.savedQueryRule', + 'siem.thresholdRule', + ], + ruleStatus: 'failed', + }); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.mlRule': { + filter: { + term: { + 'rule.category': 'siem.mlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.queryRule': { + filter: { + term: { + 'rule.category': 'siem.queryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.savedQueryRule': { + filter: { + term: { + 'rule.category': 'siem.savedQueryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }); + }); + + test('it returns 6 aggregations if the array has 6 elements and will have "categorization" if the ruleStatus is "partial failure"', () => { + const result = getEventLogAggByRuleTypes({ + ruleTypes: [ + 'siem.eqlRule', + 'siem.mlRule', + 'siem.indicatorRule', + 'siem.queryRule', + 'siem.savedQueryRule', + 'siem.thresholdRule', + ], + ruleStatus: 'partial failure', + }); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.mlRule': { + filter: { + term: { + 'rule.category': 'siem.mlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.queryRule': { + filter: { + term: { + 'rule.category': 'siem.queryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.savedQueryRule': { + filter: { + term: { + 'rule.category': 'siem.savedQueryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.ts new file mode 100644 index 0000000000000..e046fcbe75c76 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types.ts @@ -0,0 +1,34 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { RuleTypeId } from '@kbn/securitysolution-rules'; +import type { RuleStatus } from '../../types'; +import { getEventLogAggByRuleType } from './get_event_log_agg_by_rule_type'; + +export interface GetEventLogAggByRuleTypesOptions { + ruleTypes: RuleTypeId[]; + ruleStatus: RuleStatus; +} + +/** + * Given an array of rule types such as "siem.eqlRule" | "siem.mlRule", etc.. and + * a rule status such as "succeeded" | "partial failure" | "failed", this will return + * aggregations for querying and categorizing them. + * @param ruleType The rule type such as "siem.eqlRule" | "siem.mlRule" etc... + * @param ruleStatus The rule status such as "succeeded" | "partial failure" | "failed" + * @returns The aggregation by rule types + */ +export const getEventLogAggByRuleTypes = ({ + ruleTypes, + ruleStatus, +}: GetEventLogAggByRuleTypesOptions): Record => { + return ruleTypes.reduce>((accum, ruleType) => { + accum[ruleType] = getEventLogAggByRuleType({ ruleType, ruleStatus }); + return accum; + }, {}); +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.test.ts new file mode 100644 index 0000000000000..22261ac48812c --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.test.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { getEventLogAggByRuleTypesMetrics } from './get_event_log_agg_by_rule_types_metrics'; + +describe('get_event_log_agg_by_rule_types_metrics', () => { + test('returns empty object when given an empty array', () => { + const result = getEventLogAggByRuleTypesMetrics([]); + expect(result).toEqual>({}); + }); + + test('returns expected aggregation when given a single ruleType ', () => { + const result = getEventLogAggByRuleTypesMetrics(['siem.eqlRule']); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + }); + }); + + test('returns same aggregation if the same string is repeated in the array', () => { + const result = getEventLogAggByRuleTypesMetrics(['siem.eqlRule', 'siem.eqlRule']); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + }); + }); + + test('returns 2 expected aggregations when given 2 ruleTypes ', () => { + const result = getEventLogAggByRuleTypesMetrics(['siem.eqlRule', 'siem.indicatorRule']); + expect(result).toEqual>({ + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.ts new file mode 100644 index 0000000000000..425a16bffacd0 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_rule_types_metrics.ts @@ -0,0 +1,19 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/types'; +import type { RuleTypeId } from '@kbn/securitysolution-rules'; +import { getEventLogAggByRuleTypeMetrics } from './get_event_log_agg_by_rule_type_metrics'; + +export const getEventLogAggByRuleTypesMetrics = ( + ruleTypes: RuleTypeId[] +): Record => { + return ruleTypes.reduce>((accum, ruleType) => { + accum[ruleType] = getEventLogAggByRuleTypeMetrics(ruleType); + return accum; + }, {}); +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.test.ts new file mode 100644 index 0000000000000..fad4d5aa35c34 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.test.ts @@ -0,0 +1,380 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { getEventLogAggByStatus } from './get_event_log_agg_by_status'; + +describe('get_event_log_agg_by_status', () => { + test('returns empty aggregation if ruleTypes is an empty array', () => { + const result = getEventLogAggByStatus({ ruleStatus: 'succeeded', ruleTypes: [] }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'succeeded', + }, + }, + aggs: {}, + }); + }); + + test('returns 1 aggregation if ruleTypes has 1 element', () => { + const result = getEventLogAggByStatus({ ruleStatus: 'succeeded', ruleTypes: ['siem.eqlRule'] }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'succeeded', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }); + }); + + test('returns 1 aggregation merged if ruleTypes has same element twice', () => { + const result = getEventLogAggByStatus({ + ruleStatus: 'succeeded', + ruleTypes: ['siem.eqlRule', 'siem.eqlRule'], + }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'succeeded', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }); + }); + + test('returns 2 aggregations if ruleTypes has 2 different elements', () => { + const result = getEventLogAggByStatus({ + ruleStatus: 'succeeded', + ruleTypes: ['siem.eqlRule', 'siem.indicatorRule'], + }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'succeeded', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }); + }); + + test('returns 2 aggregations if ruleTypes has 2 different elements with "categorization" if ruleStatus is "failed', () => { + const result = getEventLogAggByStatus({ + ruleStatus: 'failed', + ruleTypes: ['siem.eqlRule', 'siem.indicatorRule'], + }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'failed', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }); + }); + + test('returns 2 aggregations if ruleTypes has 2 different elements with "categorization" if ruleStatus is "partial failure', () => { + const result = getEventLogAggByStatus({ + ruleStatus: 'partial failure', + ruleTypes: ['siem.eqlRule', 'siem.indicatorRule'], + }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'partial failure', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }); + }); + + test('returns 7 aggregations if ruleTypes has 7 different elements with "categorization" if ruleStatus is "failed', () => { + const result = getEventLogAggByStatus({ + ruleStatus: 'partial failure', + ruleTypes: [ + 'siem.eqlRule', + 'siem.indicatorRule', + 'siem.thresholdRule', + 'siem.indicatorRule', + 'siem.mlRule', + 'siem.queryRule', + 'siem.savedQueryRule', + ], + }); + expect(result).toEqual({ + filter: { + term: { + 'kibana.alert.rule.execution.status': 'partial failure', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.indicatorRule': { + filter: { + term: { + 'rule.category': 'siem.indicatorRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.mlRule': { + filter: { + term: { + 'rule.category': 'siem.mlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.queryRule': { + filter: { + term: { + 'rule.category': 'siem.queryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.savedQueryRule': { + filter: { + term: { + 'rule.category': 'siem.savedQueryRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.ts new file mode 100644 index 0000000000000..7d878260ef5be --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_status.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { RuleTypeId } from '@kbn/securitysolution-rules'; +import type { RuleStatus } from '../../types'; +import { getEventLogAggByRuleTypes } from './get_event_log_agg_by_rule_types'; + +interface GetEventLogAggByStatusOptions { + ruleStatus: RuleStatus; + ruleTypes: RuleTypeId[]; +} + +/** + * Given an array of rule types such as "siem.eqlRule" | "siem.mlRule", etc.. and + * a rule status such as "succeeded" | "partial failure" | "failed", this will return + * aggregations for querying and categorizing them. + * @param ruleType The rule type such as "siem.eqlRule" | "siem.mlRule" etc... + * @param ruleStatus The rule status such as "succeeded" | "partial failure" | "failed" + * @returns The aggregation by rule status + */ +export const getEventLogAggByStatus = ({ + ruleStatus, + ruleTypes, +}: GetEventLogAggByStatusOptions): AggregationsAggregationContainer => { + const aggs = getEventLogAggByRuleTypes({ ruleTypes, ruleStatus }); + return { + filter: { + term: { + 'kibana.alert.rule.execution.status': ruleStatus, + }, + }, + aggs, + }; +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.test.ts new file mode 100644 index 0000000000000..7d474769bd79f --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.test.ts @@ -0,0 +1,486 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { getEventLogAggByStatuses } from './get_event_log_agg_by_statuses'; + +describe('get_event_log_agg_by_statuses', () => { + test('returns empty aggregations with empty array', () => { + const result = getEventLogAggByStatuses({ ruleStatuses: [], ruleTypes: [] }); + expect(result).toEqual>({ + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + aggs: {}, + }, + eventActionExecutionMetrics: { + filter: { + term: { + 'event.action': 'execution-metrics', + }, + }, + aggs: {}, + }, + }); + }); + + test('returns partial empty aggregations when ruleStatuses has a value', () => { + const result = getEventLogAggByStatuses({ ruleStatuses: ['failed'], ruleTypes: [] }); + expect(result).toEqual>({ + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + aggs: { + failed: { + filter: { + term: { + 'kibana.alert.rule.execution.status': 'failed', + }, + }, + aggs: {}, + }, + }, + }, + eventActionExecutionMetrics: { + filter: { + term: { + 'event.action': 'execution-metrics', + }, + }, + aggs: {}, + }, + }); + }); + + test('returns partial empty aggregations when ruleTypes has a value', () => { + const result = getEventLogAggByStatuses({ ruleStatuses: [], ruleTypes: ['siem.eqlRule'] }); + expect(result).toEqual>({ + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + aggs: {}, + }, + eventActionExecutionMetrics: { + filter: { + term: { + 'event.action': 'execution-metrics', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + }, + }, + }); + }); + + test('returns single aggregation when both ruleStatuses and ruleTypes has a single value', () => { + const result = getEventLogAggByStatuses({ + ruleStatuses: ['succeeded'], + ruleTypes: ['siem.eqlRule'], + }); + expect(result).toEqual>({ + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + aggs: { + succeeded: { + filter: { + term: { + 'kibana.alert.rule.execution.status': 'succeeded', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }, + }, + }, + eventActionExecutionMetrics: { + filter: { + term: { + 'event.action': 'execution-metrics', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + }, + }, + }); + }); + + test('returns aggregations when both ruleStatuses and ruleTypes both have multiple values', () => { + const result = getEventLogAggByStatuses({ + ruleStatuses: ['succeeded', 'failed'], + ruleTypes: ['siem.eqlRule', 'siem.thresholdRule'], + }); + expect(result).toEqual>({ + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + aggs: { + succeeded: { + filter: { + term: { + 'kibana.alert.rule.execution.status': 'succeeded', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }, + failed: { + filter: { + term: { + 'kibana.alert.rule.execution.status': 'failed', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + categories: { + categorize_text: { + size: 10, + field: 'message', + }, + }, + cardinality: { + cardinality: { + field: 'rule.id', + }, + }, + }, + }, + }, + }, + }, + }, + eventActionExecutionMetrics: { + filter: { + term: { + 'event.action': 'execution-metrics', + }, + }, + aggs: { + 'siem.eqlRule': { + filter: { + term: { + 'rule.category': 'siem.eqlRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + 'siem.thresholdRule': { + filter: { + term: { + 'rule.category': 'siem.thresholdRule', + }, + }, + aggs: { + gapCount: { + cardinality: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxGapDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + minGapDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + avgGapDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.execution_gap_duration_s', + }, + }, + maxTotalIndexDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + minTotalIndexDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + avgTotalIndexDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_indexing_duration_ms', + }, + }, + maxTotalSearchDuration: { + max: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + minTotalSearchDuration: { + min: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + avgTotalSearchDuration: { + avg: { + field: 'kibana.alert.rule.execution.metrics.total_search_duration_ms', + }, + }, + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.ts new file mode 100644 index 0000000000000..c7431eaf77142 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_agg_by_statuses.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import type { RuleTypeId } from '@kbn/securitysolution-rules'; +import type { RuleStatus } from '../../types'; +import { getEventLogAggByRuleTypesMetrics } from './get_event_log_agg_by_rule_types_metrics'; +import { getEventLogAggByStatus } from './get_event_log_agg_by_status'; + +interface GetEventLogAggByStatusesOptions { + ruleStatuses: RuleStatus[]; + ruleTypes: RuleTypeId[]; +} + +/** + * Given an array of rule types such as "siem.eqlRule" | "siem.mlRule", etc.. and + * a rule status such as "succeeded" | "partial failure" | "failed", this will return + * aggregations for querying and categorizing them. + * @param ruleType The rule type such as "siem.eqlRule" | "siem.mlRule" etc... + * @param ruleStatus The rule status such as "succeeded" | "partial failure" | "failed" + * @returns The aggregation by rule status + */ +export const getEventLogAggByStatuses = ({ + ruleStatuses, + ruleTypes, +}: GetEventLogAggByStatusesOptions): Record => { + const eventActionStatusChangeAggs = ruleStatuses.reduce< + Record + >((accum, ruleStatus) => { + accum[ruleStatus] = getEventLogAggByStatus({ ruleStatus, ruleTypes }); + return accum; + }, {}); + + const actionExecutionAggs = getEventLogAggByRuleTypesMetrics(ruleTypes); + return { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + aggs: eventActionStatusChangeAggs, + }, + eventActionExecutionMetrics: { + filter: { + term: { + 'event.action': 'execution-metrics', + }, + }, + aggs: actionExecutionAggs, + }, + }; +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_by_type_and_status.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_by_type_and_status.test.ts new file mode 100644 index 0000000000000..a1d57387bfb60 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_event_log_by_type_and_status.test.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { EventLogStatusMetric } from '../../detections/rules/types'; +import { elasticsearchServiceMock, loggingSystemMock } from 'src/core/server/mocks'; +import { getInitialEventLogUsage } from '../../detections/rules/get_initial_usage'; +import { + getAllEventLogTransform, + getElasticLogCustomRules, + getEmptyElasticLogCustomRules, + getEmptyEventLogAllRules, + getEmptyEventLogElasticRules, + getEventLogAllRules, + getEventLogElasticRules, +} from '../../detections/rules/get_metrics.mocks'; +import { getEventLogByTypeAndStatus } from '../get_event_log_by_type_and_status'; + +describe('get_event_log_by_type_and_status', () => { + let esClient: ReturnType; + + beforeEach(() => { + esClient = elasticsearchServiceMock.createClusterClient().asInternalUser; + }); + + test('returns initial event log usage results if there are no rule results', async () => { + const logger = loggingSystemMock.createLogger(); + esClient.search.mockResponseOnce(getEmptyEventLogAllRules()); + esClient.search.mockResponseOnce(getEmptyEventLogElasticRules()); + esClient.search.mockResponseOnce(getEmptyElasticLogCustomRules()); + + const result = await getEventLogByTypeAndStatus({ + logger, + eventLogIndex: 'test', + esClient, + ruleResults: [], + }); + expect(result).toEqual(getInitialEventLogUsage()); + }); + + test('returns initial event log usage results if an exception is thrown by Elasticsearch', async () => { + const logger = loggingSystemMock.createLogger(); + esClient.search.mockRejectedValue(new Error('Some error')); + + const result = await getEventLogByTypeAndStatus({ + logger, + eventLogIndex: 'test', + esClient, + ruleResults: [], + }); + expect(logger.debug).toHaveBeenCalledWith( + 'Error trying to get event log by type and status. Error message is: "Some error". Error is: "Error: Some error". Returning empty initialized object.' + ); + expect(result).toEqual(getInitialEventLogUsage()); + }); + + test('returns results transformed if given valid input from Elasticsearch', async () => { + const logger = loggingSystemMock.createLogger(); + esClient.search.mockResponseOnce(getEventLogAllRules()); + esClient.search.mockResponseOnce(getEventLogElasticRules()); + esClient.search.mockResponseOnce(getElasticLogCustomRules()); + + const result = await getEventLogByTypeAndStatus({ + logger, + eventLogIndex: 'test', + esClient, + ruleResults: [], + }); + expect(result).toEqual(getAllEventLogTransform()); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.test.ts new file mode 100644 index 0000000000000..a431e7a07990a --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SearchRequest } from '@elastic/elasticsearch/lib/api/types'; +import { getSearchForAllRules } from './get_search_for_all_rules'; + +describe('get_search_for_all_rules', () => { + test('it returns query merged with an aggregation sent in', () => { + const result = getSearchForAllRules({ + eventLogIndex: 'test-123', + aggs: { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + }, + }, + }); + expect(result).toEqual({ + index: 'test-123', + size: 0, + track_total_hits: false, + aggs: { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + }, + }, + query: { + bool: { + filter: { + bool: { + must: [ + { + range: { + '@timestamp': { + gte: 'now-24h', + lte: 'now', + }, + }, + }, + { + term: { + 'event.provider': 'securitySolution.ruleExecution', + }, + }, + ], + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.ts new file mode 100644 index 0000000000000..c74ce1a2262c3 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_all_rules.ts @@ -0,0 +1,51 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SearchRequest } from '@elastic/elasticsearch/lib/api/types'; +import type { AggregationsAggregationContainer } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; +import { RULE_EXECUTION_LOG_PROVIDER } from '../../../lib/detection_engine/rule_execution_log/event_log/constants'; + +/** + * Given an aggregation of "aggs" this will return a search for all rules within 24 hours. + * @param eventLogIndex The event log index such as ".kibana-event-log-8.2.0*" + * @param aggs The aggregation to break things down by + */ +export const getSearchForAllRules = ({ + eventLogIndex, + aggs, +}: { + eventLogIndex: string; + aggs: Record; +}): SearchRequest => ({ + index: eventLogIndex, + size: 0, + track_total_hits: false, + aggs, + query: { + bool: { + filter: { + bool: { + must: [ + { + range: { + '@timestamp': { + gte: 'now-24h', + lte: 'now', + }, + }, + }, + { + term: { + 'event.provider': RULE_EXECUTION_LOG_PROVIDER, + }, + }, + ], + }, + }, + }, + }, +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.test.ts new file mode 100644 index 0000000000000..8d2aa362ed606 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.test.ts @@ -0,0 +1,71 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SearchRequest } from '@elastic/elasticsearch/lib/api/types'; +import { getSearchForCustomRules } from './get_search_for_custom_rules'; + +describe('get_search_for_custom_rules', () => { + test('it returns query merged with an aggregation sent in and list of elastic ids', () => { + const result = getSearchForCustomRules({ + elasticRuleIds: ['test-123', 'test-456'], + eventLogIndex: 'test-123', + aggs: { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + }, + }, + }); + expect(result).toEqual({ + index: 'test-123', + size: 0, + track_total_hits: false, + aggs: { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + }, + }, + query: { + bool: { + filter: { + bool: { + must: [ + { + range: { + '@timestamp': { + gte: 'now-24h', + lte: 'now', + }, + }, + }, + { + term: { + 'event.provider': 'securitySolution.ruleExecution', + }, + }, + ], + must_not: [ + { + terms: { + 'rule.id': ['test-123', 'test-456'], + }, + }, + ], + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.ts new file mode 100644 index 0000000000000..88f70469e57ee --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_custom_rules.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { + AggregationsAggregationContainer, + SearchRequest, +} from '@elastic/elasticsearch/lib/api/types'; +import { RULE_EXECUTION_LOG_PROVIDER } from '../../../lib/detection_engine/rule_execution_log/event_log/constants'; + +/** + * Given an aggregation of "aggs" this will return a search for rules that are NOT elastic + * rules within 24 hours. + * @param eventLogIndex The event log index such as ".kibana-event-log-8.2.0*" + * @param aggs The aggregation to break things down by + * @param elasticRuleIds Array of elastic rule ids to exclude + */ +export const getSearchForCustomRules = ({ + eventLogIndex, + aggs, + elasticRuleIds, +}: { + eventLogIndex: string; + aggs: Record; + elasticRuleIds: string[]; +}): SearchRequest => ({ + index: eventLogIndex, + size: 0, + track_total_hits: false, + aggs, + query: { + bool: { + filter: { + bool: { + must: [ + { + range: { + '@timestamp': { + gte: 'now-24h', + lte: 'now', + }, + }, + }, + { + term: { + 'event.provider': RULE_EXECUTION_LOG_PROVIDER, + }, + }, + ], + must_not: [ + { + terms: { + 'rule.id': elasticRuleIds, + }, + }, + ], + }, + }, + }, + }, +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.test.ts new file mode 100644 index 0000000000000..0c6e3e1bd5ee4 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.test.ts @@ -0,0 +1,69 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SearchRequest } from '@elastic/elasticsearch/lib/api/types'; +import { getSearchForElasticRules } from './get_search_for_elastic_rules'; + +describe('get_search_for_elastic_rules', () => { + test('it returns query merged with an aggregation sent in and list of elastic ids', () => { + const result = getSearchForElasticRules({ + elasticRuleIds: ['test-123', 'test-456'], + eventLogIndex: 'test-123', + aggs: { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + }, + }, + }); + expect(result).toEqual({ + index: 'test-123', + size: 0, + track_total_hits: false, + aggs: { + eventActionStatusChange: { + filter: { + term: { + 'event.action': 'status-change', + }, + }, + }, + }, + query: { + bool: { + filter: { + bool: { + must: [ + { + range: { + '@timestamp': { + gte: 'now-24h', + lte: 'now', + }, + }, + }, + { + term: { + 'event.provider': 'securitySolution.ruleExecution', + }, + }, + { + terms: { + 'rule.id': ['test-123', 'test-456'], + }, + }, + ], + }, + }, + }, + }, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.ts new file mode 100644 index 0000000000000..30dc61499b17f --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/get_search_for_elastic_rules.ts @@ -0,0 +1,62 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { + AggregationsAggregationContainer, + SearchRequest, +} from '@elastic/elasticsearch/lib/api/types'; +import { RULE_EXECUTION_LOG_PROVIDER } from '../../../lib/detection_engine/rule_execution_log/event_log/constants'; + +/** + * Given an aggregation of "aggs" this will return a search for rules that are elastic + * rules within 24 hours. + * @param eventLogIndex The event log index such as ".kibana-event-log-8.2.0*" + * @param aggs The aggregation to break things down by + * @param elasticRuleIds Array of elastic rule ids to include + */ +export const getSearchForElasticRules = ({ + eventLogIndex, + aggs, + elasticRuleIds, +}: { + eventLogIndex: string; + aggs: Record; + elasticRuleIds: string[]; +}): SearchRequest => ({ + index: eventLogIndex, + size: 0, + track_total_hits: false, + aggs, + query: { + bool: { + filter: { + bool: { + must: [ + { + range: { + '@timestamp': { + gte: 'now-24h', + lte: 'now', + }, + }, + }, + { + term: { + 'event.provider': RULE_EXECUTION_LOG_PROVIDER, + }, + }, + { + terms: { + 'rule.id': elasticRuleIds, + }, + }, + ], + }, + }, + }, + }, +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.test.ts new file mode 100644 index 0000000000000..234bd2a2aa6ec --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.test.ts @@ -0,0 +1,149 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { FailureMessage } from '../../detections/rules/types'; +import { transformCategories } from './transform_categories'; + +describe('transform_categories', () => { + test('it transforms an empty array into an empty object', () => { + const result = transformCategories({ + buckets: [], + }); + expect(result).toEqual([]); + }); + + test('it transforms a single element into a single output', () => { + const result = transformCategories({ + buckets: [ + { + doc_count: 6, + key: 'category-1', + }, + ], + }); + expect(result).toEqual([ + { + count: 6, + message: 'category-1', + }, + ]); + }); + + test('it transforms 2 elements into 2 outputs', () => { + const result = transformCategories({ + buckets: [ + { + doc_count: 6, + key: 'category-1', + }, + { + doc_count: 5, + key: 'category-2', + }, + ], + }); + expect(result).toEqual([ + { + count: 6, + message: 'category-1', + }, + { + count: 5, + message: 'category-2', + }, + ]); + }); + + test('it transforms 10 elements into 10 outputs', () => { + const result = transformCategories({ + buckets: [ + { + doc_count: 10, + key: 'category-10', + }, + { + doc_count: 9, + key: 'category-9', + }, + { + doc_count: 8, + key: 'category-8', + }, + { + doc_count: 7, + key: 'category-7', + }, + { + doc_count: 6, + key: 'category-6', + }, + { + doc_count: 5, + key: 'category-5', + }, + { + doc_count: 4, + key: 'category-4', + }, + { + doc_count: 3, + key: 'category-3', + }, + { + doc_count: 2, + key: 'category-2', + }, + { + doc_count: 1, + key: 'category-1', + }, + ], + }); + expect(result).toEqual([ + { + message: 'category-10', + count: 10, + }, + { + message: 'category-9', + count: 9, + }, + { + message: 'category-8', + count: 8, + }, + { + message: 'category-7', + count: 7, + }, + { + message: 'category-6', + count: 6, + }, + { + message: 'category-5', + count: 5, + }, + { + message: 'category-4', + count: 4, + }, + { + message: 'category-3', + count: 3, + }, + { + message: 'category-2', + count: 2, + }, + { + message: 'category-1', + count: 1, + }, + ]); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.ts new file mode 100644 index 0000000000000..9dbbf7ba4bdb7 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_categories.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { FailureMessage } from '../../detections/rules/types'; +import type { Categories } from '../../types'; +import { transformCategoryBucket } from './transform_category_bucket'; + +/** + * Given a set of categories from a categorization aggregation this will + * return those transformed. + * @param categories The categories to transform + * @see https://www.elastic.co/guide/en/elasticsearch/reference/8.1/search-aggregations-bucket-categorize-text-aggregation.html + * @returns the categories transformed + */ +export const transformCategories = (categories: Categories): FailureMessage[] => { + return categories.buckets.map((bucket) => transformCategoryBucket(bucket)); +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.test.ts new file mode 100644 index 0000000000000..dc5edb779bef3 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.test.ts @@ -0,0 +1,22 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { FailureMessage } from '../../detections/rules/types'; +import { transformCategoryBucket } from './transform_category_bucket'; + +describe('transform_category_bucket', () => { + test('it will transform a bucket sent in', () => { + const result = transformCategoryBucket({ + key: 'test-123', + doc_count: 10, + }); + expect(result).toEqual({ + message: 'test-123', + count: 10, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.ts new file mode 100644 index 0000000000000..8b1c5e318db38 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_category_bucket.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { FailureMessage } from '../../detections/rules/types'; +import type { Categories } from '../../types'; + +/** + * Given a category from a categorization aggregation this will + * return it transformed. + * @param bucket The category bucket to transform + * @see https://www.elastic.co/guide/en/elasticsearch/reference/8.1/search-aggregations-bucket-categorize-text-aggregation.html + * @returns the bucket transformed + */ +export const transformCategoryBucket = (bucket: Categories['buckets'][0]): FailureMessage => { + return { message: bucket.key, count: bucket.doc_count }; +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.test.ts new file mode 100644 index 0000000000000..d7299fdb375b2 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.test.ts @@ -0,0 +1,47 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SingleEventLogStatusMetric } from '../../detections/rules/types'; +import { loggingSystemMock } from 'src/core/server/mocks'; +import { + getElasticLogCustomRules, + getEventLogAllRules, + getEventLogAllRulesResult, + getEventLogCustomRulesResult, + getEventLogElasticRules, + getEventLogElasticRulesResult, +} from '../../detections/rules/get_metrics.mocks'; +import { transformEventLogTypeStatus } from './transform_event_log_type_status'; + +describe('transform_event_log_type_status', () => { + test('returns expected transform for all rules results', () => { + const logger = loggingSystemMock.createLogger(); + const result = transformEventLogTypeStatus({ + logger, + aggs: getEventLogAllRules().aggregations, + }); + expect(result).toEqual(getEventLogAllRulesResult()); + }); + + test('returns expected transform for elastic rules results', () => { + const logger = loggingSystemMock.createLogger(); + const result = transformEventLogTypeStatus({ + logger, + aggs: getEventLogElasticRules().aggregations, + }); + expect(result).toEqual(getEventLogElasticRulesResult()); + }); + + test('returns expected transform for custom rules results', () => { + const logger = loggingSystemMock.createLogger(); + const result = transformEventLogTypeStatus({ + logger, + aggs: getElasticLogCustomRules().aggregations, + }); + expect(result).toEqual(getEventLogCustomRulesResult()); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.ts new file mode 100644 index 0000000000000..b9b2cba496dfd --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_event_log_type_status.ts @@ -0,0 +1,138 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { Logger } from 'kibana/server'; +import type { EventLogTypeStatusAggs } from '../../types'; +import type { SingleEventLogStatusMetric } from '../../detections/rules/types'; +import { getInitialSingleEventLogUsage } from '../../detections/rules/get_initial_usage'; +import { countTotals } from './count_totals'; +import { transformSingleRuleMetric } from './transform_single_rule_metric'; + +export interface TransformEventLogTypeStatusOptions { + logger: Logger; + aggs: EventLogTypeStatusAggs | undefined; +} + +/** + * Given a raw Elasticsearch aggregation against the event log this will transform that + * for telemetry. This expects the aggregation to be broken down by "ruleType" and "ruleStatus". + * @param aggs The Elasticsearch aggregations broken down by "ruleType" and "ruleStatus" + * @params logger The kibana logger + * @returns The single metric from the aggregation broken down + */ +export const transformEventLogTypeStatus = ({ + aggs, + logger, +}: TransformEventLogTypeStatusOptions): SingleEventLogStatusMetric => { + // early return if the aggs are empty/null + if (aggs == null) { + logger.debug( + 'Was expecting aggregations to exist for "transformEventLogTypeStatus", returning empty metrics instead' + ); + return getInitialSingleEventLogUsage(); + } + + // metrics + const eqlMetrics = aggs.eventActionExecutionMetrics['siem.eqlRule']; + const indicatorMetrics = aggs.eventActionExecutionMetrics['siem.indicatorRule']; + const mlMetrics = aggs.eventActionExecutionMetrics['siem.mlRule']; + const queryMetrics = aggs.eventActionExecutionMetrics['siem.queryRule']; + const savedQueryMetrics = aggs.eventActionExecutionMetrics['siem.savedQueryRule']; + const thresholdMetrics = aggs.eventActionExecutionMetrics['siem.thresholdRule']; + + // failure status + const eqlFailure = aggs.eventActionStatusChange.failed['siem.eqlRule']; + const indicatorFailure = aggs.eventActionStatusChange.failed['siem.indicatorRule']; + const mlFailure = aggs.eventActionStatusChange.failed['siem.mlRule']; + const queryFailure = aggs.eventActionStatusChange.failed['siem.queryRule']; + const savedQueryFailure = aggs.eventActionStatusChange.failed['siem.savedQueryRule']; + const thresholdFailure = aggs.eventActionStatusChange.failed['siem.thresholdRule']; + + // partial failure + const eqlPartialFailure = aggs.eventActionStatusChange['partial failure']['siem.eqlRule']; + const indicatorPartialFailure = + aggs.eventActionStatusChange['partial failure']['siem.indicatorRule']; + const mlPartialFailure = aggs.eventActionStatusChange['partial failure']['siem.mlRule']; + const queryPartialFailure = aggs.eventActionStatusChange['partial failure']['siem.queryRule']; + const savedQueryPartialFailure = + aggs.eventActionStatusChange['partial failure']['siem.savedQueryRule']; + const thresholdPartialFailure = + aggs.eventActionStatusChange['partial failure']['siem.thresholdRule']; + + // success + const eqlSuccess = aggs.eventActionStatusChange.succeeded['siem.eqlRule']; + const indicatorSuccess = aggs.eventActionStatusChange.succeeded['siem.indicatorRule']; + const mlSuccess = aggs.eventActionStatusChange.succeeded['siem.mlRule']; + const querySuccess = aggs.eventActionStatusChange.succeeded['siem.queryRule']; + const savedQuerySuccess = aggs.eventActionStatusChange.succeeded['siem.savedQueryRule']; + const thresholdSuccess = aggs.eventActionStatusChange.succeeded['siem.thresholdRule']; + + return { + eql: transformSingleRuleMetric({ + failed: eqlFailure, + partialFailed: eqlPartialFailure, + succeeded: eqlSuccess, + singleMetric: eqlMetrics, + }), + threat_match: transformSingleRuleMetric({ + failed: indicatorFailure, + partialFailed: indicatorPartialFailure, + succeeded: indicatorSuccess, + singleMetric: indicatorMetrics, + }), + machine_learning: transformSingleRuleMetric({ + failed: mlFailure, + partialFailed: mlPartialFailure, + succeeded: mlSuccess, + singleMetric: mlMetrics, + }), + query: transformSingleRuleMetric({ + failed: queryFailure, + partialFailed: queryPartialFailure, + succeeded: querySuccess, + singleMetric: queryMetrics, + }), + saved_query: transformSingleRuleMetric({ + failed: savedQueryFailure, + partialFailed: savedQueryPartialFailure, + succeeded: savedQuerySuccess, + singleMetric: savedQueryMetrics, + }), + threshold: transformSingleRuleMetric({ + failed: thresholdFailure, + partialFailed: thresholdPartialFailure, + succeeded: thresholdSuccess, + singleMetric: thresholdMetrics, + }), + total: { + failures: countTotals([ + eqlFailure, + indicatorFailure, + mlFailure, + queryFailure, + savedQueryFailure, + thresholdFailure, + ]), + partial_failures: countTotals([ + eqlPartialFailure, + indicatorPartialFailure, + mlPartialFailure, + queryPartialFailure, + savedQueryPartialFailure, + thresholdPartialFailure, + ]), + succeeded: countTotals([ + eqlSuccess, + indicatorSuccess, + mlSuccess, + querySuccess, + savedQuerySuccess, + thresholdSuccess, + ]), + }, + }; +}; diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.test.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.test.ts new file mode 100644 index 0000000000000..c64f0833fe851 --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.test.ts @@ -0,0 +1,137 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SingleEventMetric } from '../../detections/rules/types'; +import { transformSingleRuleMetric } from './transform_single_rule_metric'; + +describe('transform_single_rule_metric', () => { + test('it transforms a single metric correctly', () => { + const result = transformSingleRuleMetric({ + failed: { + doc_count: 325, + categories: { + buckets: [ + { + doc_count: 163, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + }, + { + doc_count: 162, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + }, + ], + }, + cardinality: { + value: 2, + }, + }, + partialFailed: { + doc_count: 325, + categories: { + buckets: [ + { + doc_count: 163, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + }, + { + doc_count: 162, + key: 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + }, + ], + }, + cardinality: { + value: 2, + }, + }, + succeeded: { + doc_count: 317, + cardinality: { + value: 5, + }, + }, + singleMetric: { + doc_count: 5, + maxTotalIndexDuration: { + value: 5, + }, + avgTotalIndexDuration: { + value: 3, + }, + minTotalIndexDuration: { + value: 2, + }, + gapCount: { + value: 4, + }, + maxGapDuration: { + value: 8, + }, + avgGapDuration: { + value: 2, + }, + minGapDuration: { + value: 9, + }, + maxTotalSearchDuration: { + value: 4, + }, + avgTotalSearchDuration: { + value: 2, + }, + minTotalSearchDuration: { + value: 12, + }, + }, + }); + + expect(result).toEqual({ + failures: 2, + top_failures: [ + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + count: 163, + }, + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + count: 162, + }, + ], + partial_failures: 2, + top_partial_failures: [ + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching blah frank was found This warning will continue to appear until matching index is created or this rule is disabled', + count: 163, + }, + { + message: + 'This rule is attempting to query data from Elasticsearch indices listed in the Index pattern section of the rule definition however no index matching logs-endpoint.alerts was found This warning will continue to appear until matching index is created or this rule is disabled If you have recently enrolled agents enabled with Endpoint Security through Fleet this warning should stop once an alert is sent from an agent', + count: 162, + }, + ], + succeeded: 5, + index_duration: { + max: 5, + avg: 3, + min: 2, + }, + search_duration: { + max: 4, + avg: 2, + min: 12, + }, + gap_duration: { + max: 8, + avg: 2, + min: 9, + }, + gap_count: 4, + }); + }); +}); diff --git a/x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.ts b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.ts new file mode 100644 index 0000000000000..bebd867fb195f --- /dev/null +++ b/x-pack/plugins/security_solution/server/usage/queries/utils/transform_single_rule_metric.ts @@ -0,0 +1,62 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { SingleEventMetric } from '../../detections/rules/types'; +import type { + CountCardinality, + CountCardinalityWithCategories, + SingleExecutionMetricAgg, +} from '../../types'; +import { transformCategories } from './transform_categories'; + +export interface TransformSingleRuleMetricOptions { + failed: CountCardinalityWithCategories; + partialFailed: CountCardinalityWithCategories; + succeeded: CountCardinality; + singleMetric: SingleExecutionMetricAgg; +} + +/** + * Given a different count cardinalities this will return them broken down by various + * metrics such as "failed", "partial failed", "succeeded, and will list a top 10 of each + * of the error message types. + * @param failed The failed counts and top 10 "messages" + * @param partialFailed The partial failed counts and top 10 "messages" + * @param succeeded The succeeded counts + * @param singleMetric The max/min/avg metric + * @returns The single metric from the aggregation broken down + */ +export const transformSingleRuleMetric = ({ + failed, + partialFailed, + succeeded, + singleMetric, +}: TransformSingleRuleMetricOptions): SingleEventMetric => { + return { + failures: failed.cardinality.value ?? 0, + top_failures: transformCategories(failed.categories), + partial_failures: partialFailed.cardinality.value ?? 0, + top_partial_failures: transformCategories(partialFailed.categories), + succeeded: succeeded.cardinality.value ?? 0, + index_duration: { + max: singleMetric.maxTotalIndexDuration.value ?? 0.0, + avg: singleMetric.avgTotalIndexDuration.value ?? 0.0, + min: singleMetric.minTotalIndexDuration.value ?? 0.0, + }, + search_duration: { + max: singleMetric.maxTotalSearchDuration.value ?? 0.0, + avg: singleMetric.avgTotalSearchDuration.value ?? 0.0, + min: singleMetric.minTotalSearchDuration.value ?? 0.0, + }, + gap_duration: { + max: singleMetric.maxGapDuration.value ?? 0.0, + avg: singleMetric.avgGapDuration.value ?? 0.0, + min: singleMetric.minGapDuration.value ?? 0.0, + }, + gap_count: singleMetric.gapCount.value ?? 0.0, + }; +}; diff --git a/x-pack/plugins/security_solution/server/usage/types.ts b/x-pack/plugins/security_solution/server/usage/types.ts index f591ffd8f422e..3bc2235f9c624 100644 --- a/x-pack/plugins/security_solution/server/usage/types.ts +++ b/x-pack/plugins/security_solution/server/usage/types.ts @@ -14,6 +14,7 @@ export type CollectorDependencies = { signalsIndex: string; core: CoreSetup; logger: Logger; + eventLogIndex: string; } & Pick; export interface AlertBucket { @@ -51,3 +52,91 @@ export type RuleSearchResult = Omit< createdAt: string; updatedAt: string; }; + +export type RuleStatus = 'running' | 'succeeded' | 'partial failure' | 'failed'; + +export interface CountCardinality { + doc_count: number; + cardinality: { + value: number | null; + }; +} + +export interface Categories { + buckets: Array<{ doc_count: number; key: string }>; +} +export interface CountCardinalityWithCategories extends CountCardinality { + categories: Categories; +} + +export interface SingleEVentLogTypeStatusAgg { + doc_count: number; + 'siem.queryRule': CountCardinality; + 'siem.savedQueryRule': CountCardinality; + 'siem.eqlRule': CountCardinality; + 'siem.thresholdRule': CountCardinality; + 'siem.mlRule': CountCardinality; + 'siem.indicatorRule': CountCardinality; +} + +export interface SingleEVentLogTypeStatusAggWithCategories { + doc_count: number; + 'siem.queryRule': CountCardinalityWithCategories; + 'siem.savedQueryRule': CountCardinalityWithCategories; + 'siem.eqlRule': CountCardinalityWithCategories; + 'siem.thresholdRule': CountCardinalityWithCategories; + 'siem.mlRule': CountCardinalityWithCategories; + 'siem.indicatorRule': CountCardinalityWithCategories; +} + +export interface SingleExecutionMetricAgg { + doc_count: number; + maxTotalIndexDuration: { + value: number | null; + }; + avgTotalIndexDuration: { + value: number | null; + }; + minTotalIndexDuration: { + value: number | null; + }; + gapCount: { + value: number | null; + }; + maxGapDuration: { + value: number | null; + }; + avgGapDuration: { + value: number | null; + }; + minGapDuration: { + value: number | null; + }; + maxTotalSearchDuration: { + value: number | null; + }; + avgTotalSearchDuration: { + value: number | null; + }; + minTotalSearchDuration: { + value: number | null; + }; +} + +export interface EventLogTypeStatusAggs { + eventActionStatusChange: { + doc_count: number; + 'partial failure': SingleEVentLogTypeStatusAggWithCategories; + failed: SingleEVentLogTypeStatusAggWithCategories; + succeeded: SingleEVentLogTypeStatusAgg; + }; + eventActionExecutionMetrics: { + doc_count: number; + 'siem.queryRule': SingleExecutionMetricAgg; + 'siem.savedQueryRule': SingleExecutionMetricAgg; + 'siem.eqlRule': SingleExecutionMetricAgg; + 'siem.thresholdRule': SingleExecutionMetricAgg; + 'siem.mlRule': SingleExecutionMetricAgg; + 'siem.indicatorRule': SingleExecutionMetricAgg; + }; +} diff --git a/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json b/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json index 99b11d1d14cf6..1a3e32a3ccd6f 100644 --- a/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json +++ b/x-pack/plugins/telemetry_collection_xpack/schema/xpack_plugins.json @@ -8855,6 +8855,2464 @@ } } } + }, + "detection_rule_status": { + "properties": { + "all_rules": { + "properties": { + "eql": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "threat_match": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "machine_learning": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "query": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "saved_query": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "threshold": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "total": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of succeeded rules" + } + } + } + } + } + }, + "elastic_rules": { + "properties": { + "eql": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "threat_match": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "machine_learning": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "query": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "saved_query": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "threshold": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "total": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of succeeded rules" + } + } + } + } + } + }, + "custom_rules": { + "properties": { + "eql": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "threat_match": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "machine_learning": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "query": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "saved_query": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "threshold": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "top_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "top_partial_failures": { + "type": "array", + "items": { + "properties": { + "message": { + "type": "keyword", + "_meta": { + "description": "Failed rule message" + } + }, + "count": { + "type": "long", + "_meta": { + "description": "Number of times the message occurred" + } + } + } + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of successful rules" + } + }, + "index_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "search_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_duration": { + "properties": { + "max": { + "type": "float", + "_meta": { + "description": "The max duration" + } + }, + "avg": { + "type": "float", + "_meta": { + "description": "The avg duration" + } + }, + "min": { + "type": "float", + "_meta": { + "description": "The min duration" + } + } + } + }, + "gap_count": { + "type": "long", + "_meta": { + "description": "The count of gaps" + } + } + } + }, + "total": { + "properties": { + "failures": { + "type": "long", + "_meta": { + "description": "The number of failed rules" + } + }, + "partial_failures": { + "type": "long", + "_meta": { + "description": "The number of partial failure rules" + } + }, + "succeeded": { + "type": "long", + "_meta": { + "description": "The number of succeeded rules" + } + } + } + } + } + } + } } } }, diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/telemetry/usage_collector/detection_rules.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/telemetry/usage_collector/detection_rules.ts index b93141a1ffe73..41415e8bafc1e 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/telemetry/usage_collector/detection_rules.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/telemetry/usage_collector/detection_rules.ts @@ -34,6 +34,7 @@ import { updateRule, } from '../../../../utils'; import { getInitialDetectionMetrics } from '../../../../../../plugins/security_solution/server/usage/detections/get_initial_usage'; +import { getInitialEventLogUsage } from '../../../../../../plugins/security_solution/server/usage/detections/rules/get_initial_usage'; // eslint-disable-next-line import/no-default-export export default ({ getService }: FtrProviderContext) => { @@ -66,6 +67,10 @@ export default ({ getService }: FtrProviderContext) => { await createRule(supertest, log, rule); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -102,6 +107,10 @@ export default ({ getService }: FtrProviderContext) => { await waitForSignalsToBePresent(supertest, log, 4, [id]); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -141,6 +150,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -174,6 +187,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -207,6 +224,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -240,6 +261,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -272,6 +297,10 @@ export default ({ getService }: FtrProviderContext) => { await createRule(supertest, log, rule); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -308,6 +337,10 @@ export default ({ getService }: FtrProviderContext) => { await waitForSignalsToBePresent(supertest, log, 4, [id]); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -347,6 +380,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -380,6 +417,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -413,6 +454,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -446,6 +491,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -484,6 +533,10 @@ export default ({ getService }: FtrProviderContext) => { await createRule(supertest, log, rule); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -526,6 +579,10 @@ export default ({ getService }: FtrProviderContext) => { await waitForSignalsToBePresent(supertest, log, 4, [id]); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -571,6 +628,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -610,6 +671,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -649,6 +714,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -688,6 +757,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -721,6 +794,10 @@ export default ({ getService }: FtrProviderContext) => { await createRule(supertest, log, rule); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -756,6 +833,10 @@ export default ({ getService }: FtrProviderContext) => { await createRule(supertest, log, rule); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -794,6 +875,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -826,6 +911,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -858,6 +947,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -890,6 +983,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -921,6 +1018,10 @@ export default ({ getService }: FtrProviderContext) => { await createRule(supertest, log, rule); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -972,6 +1073,10 @@ export default ({ getService }: FtrProviderContext) => { await waitForSignalsToBePresent(supertest, log, 4, [id]); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -1011,6 +1116,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -1059,6 +1168,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -1092,6 +1205,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -1140,6 +1257,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + const expected: DetectionMetrics = { ...getInitialDetectionMetrics(), detection_rules: { @@ -1171,6 +1292,10 @@ export default ({ getService }: FtrProviderContext) => { await installPrePackagedRules(supertest, log); await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + expect(stats.detection_rules.detection_rule_usage.elastic_total.enabled).above(0); expect(stats.detection_rules.detection_rule_usage.elastic_total.disabled).above(0); expect(stats.detection_rules.detection_rule_usage.elastic_total.enabled).above(0); @@ -1205,6 +1330,9 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + // Rule id of "9a1a2dae-0b5f-4c3d-8305-a268d404c306" is from the file: // x-pack/plugins/security_solution/server/lib/detection_engine/rules/prepackaged_rules/elastic_endpoint_security.json // We have to search by "rule_name" since the "rule_id" it is storing is the Saved Object ID and not the rule_id @@ -1247,6 +1375,9 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + // We have to search by "rule_name" since the "rule_id" it is storing is the Saved Object ID and not the rule_id const foundRule = stats.detection_rules.detection_rule_detail.find( (rule) => rule.rule_id === '9a1a2dae-0b5f-4c3d-8305-a268d404c306' @@ -1302,6 +1433,9 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + // We have to search by "rule_name" since the "rule_id" it is storing is the Saved Object ID and not the rule_id const foundRule = stats.detection_rules.detection_rule_detail.find( (rule) => rule.rule_id === '9a1a2dae-0b5f-4c3d-8305-a268d404c306' @@ -1356,6 +1490,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + // We have to search by "rule_name" since the "rule_id" it is storing is the Saved Object ID and not the rule_id const foundRule = stats.detection_rules.detection_rule_detail.find( (rule) => rule.rule_id === '9a1a2dae-0b5f-4c3d-8305-a268d404c306' @@ -1410,6 +1548,10 @@ export default ({ getService }: FtrProviderContext) => { await retry.try(async () => { const stats = await getStats(supertest, log); + + // remove "detection_rule_status" from the test by resetting it to initial + stats.detection_rules.detection_rule_status = getInitialEventLogUsage(); + // We have to search by "rule_name" since the "rule_id" it is storing is the Saved Object ID and not the rule_id const foundRule = stats.detection_rules.detection_rule_detail.find( (rule) => rule.rule_id === '9a1a2dae-0b5f-4c3d-8305-a268d404c306' From 8bf8bfda8346e84d8631104efdb1cdb7a561730f Mon Sep 17 00:00:00 2001 From: Davis Plumlee <56367316+dplumlee@users.noreply.github.com> Date: Tue, 29 Mar 2022 18:34:28 -0400 Subject: [PATCH 137/160] [Security Solution][Rule Preview] Display alert table in rule preview result (#127986) --- .../event_details/alert_summary_view.tsx | 7 +- .../components/event_details/columns.tsx | 72 ++++---- .../event_details/event_details.tsx | 21 ++- .../event_details/event_fields_browser.tsx | 5 +- .../event_details/get_alert_summary_rows.tsx | 3 + .../components/event_details/helpers.tsx | 1 + .../event_details/overview/index.tsx | 130 ++++++++------ .../table/summary_value_cell.tsx | 3 +- .../rule_preview/preview_histogram.test.tsx | 1 + .../rules/rule_preview/preview_histogram.tsx | 159 ++++++++++++++---- .../preview_table_cell_renderer.tsx | 113 +++++++++++++ .../preview_table_control_columns.tsx | 76 +++++++++ .../rules/rule_preview/translations.ts | 27 +++ .../detection_engine/rules/create/index.tsx | 3 + .../event_details/expandable_event.tsx | 3 + .../side_panel/event_details/index.tsx | 51 +++--- .../timelines/components/side_panel/index.tsx | 3 + 17 files changed, 530 insertions(+), 148 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_cell_renderer.tsx create mode 100644 x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_control_columns.tsx diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/alert_summary_view.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/alert_summary_view.tsx index 3750753114c36..8df5bd3ce0194 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/alert_summary_view.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/alert_summary_view.tsx @@ -22,10 +22,11 @@ const AlertSummaryViewComponent: React.FC<{ timelineId: string; title: string; goToTable: () => void; -}> = ({ browserFields, data, eventId, isDraggable, timelineId, title, goToTable }) => { + isReadOnly?: boolean; +}> = ({ browserFields, data, eventId, isDraggable, timelineId, title, goToTable, isReadOnly }) => { const summaryRows = useMemo( - () => getSummaryRows({ browserFields, data, eventId, isDraggable, timelineId }), - [browserFields, data, eventId, isDraggable, timelineId] + () => getSummaryRows({ browserFields, data, eventId, isDraggable, timelineId, isReadOnly }), + [browserFields, data, eventId, isDraggable, timelineId, isReadOnly] ); return ; diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/columns.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/columns.tsx index 811c43fdfc5b9..baea88334bb05 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/columns.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/columns.tsx @@ -48,6 +48,7 @@ export const getColumns = ({ toggleColumn, getLinkValue, isDraggable, + isReadOnly, }: { browserFields: BrowserFields; columnHeaders: ColumnHeaderOptions[]; @@ -58,40 +59,45 @@ export const getColumns = ({ toggleColumn: (column: ColumnHeaderOptions) => void; getLinkValue: (field: string) => string | null; isDraggable?: boolean; + isReadOnly?: boolean; }) => [ - { - field: 'values', - name: ( - - {i18n.ACTIONS} - - ), - sortable: false, - truncateText: false, - width: '132px', - render: (values: string[] | null | undefined, data: EventFieldsData) => { - const label = data.isObjectArray - ? i18n.NESTED_COLUMN(data.field) - : i18n.VIEW_COLUMN(data.field); - const fieldFromBrowserField = getFieldFromBrowserField( - [data.category, 'fields', data.field], - browserFields - ); - return ( - - ); - }, - }, + ...(!isReadOnly + ? [ + { + field: 'values', + name: ( + + {i18n.ACTIONS} + + ), + sortable: false, + truncateText: false, + width: '132px', + render: (values: string[] | null | undefined, data: EventFieldsData) => { + const label = data.isObjectArray + ? i18n.NESTED_COLUMN(data.field) + : i18n.VIEW_COLUMN(data.field); + const fieldFromBrowserField = getFieldFromBrowserField( + [data.category, 'fields', data.field], + browserFields + ); + return ( + + ); + }, + }, + ] + : []), { field: 'field', className: 'eventFieldsTable__fieldNameCell', diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/event_details.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/event_details.tsx index f10beb1c9c6ca..c2c88ec3e08c6 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/event_details.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/event_details.tsx @@ -69,6 +69,7 @@ interface Props { timelineId: string; hostRisk: HostRisk | null; handleOnEventClosed: () => void; + isReadOnly?: boolean; } export const Indent = styled.div` @@ -117,6 +118,7 @@ const EventDetailsComponent: React.FC = ({ timelineTabType, hostRisk, handleOnEventClosed, + isReadOnly, }) => { const [selectedTabId, setSelectedTabId] = useState(EventsViewType.summaryView); const handleTabClick = useCallback( @@ -168,6 +170,7 @@ const EventDetailsComponent: React.FC = ({ indexName={indexName} timelineId={timelineId} handleOnEventClosed={handleOnEventClosed} + isReadOnly={isReadOnly} /> @@ -181,6 +184,7 @@ const EventDetailsComponent: React.FC = ({ isDraggable, timelineId, title: i18n.HIGHLIGHTED_FIELDS, + isReadOnly, }} goToTable={goToTableTab} /> @@ -222,12 +226,13 @@ const EventDetailsComponent: React.FC = ({ hostRisk, goToTableTab, handleOnEventClosed, + isReadOnly, ] ); const threatIntelTab = useMemo( () => - isAlert + isAlert && !isReadOnly ? { id: EventsViewType.threatIntelView, 'data-test-subj': 'threatIntelTab', @@ -270,7 +275,16 @@ const EventDetailsComponent: React.FC = ({ ), } : undefined, - [allEnrichments, setRange, range, enrichmentCount, isAlert, eventFields, isEnrichmentsLoading] + [ + allEnrichments, + setRange, + range, + enrichmentCount, + isAlert, + eventFields, + isEnrichmentsLoading, + isReadOnly, + ] ); const tableTab = useMemo( @@ -288,11 +302,12 @@ const EventDetailsComponent: React.FC = ({ isDraggable={isDraggable} timelineId={timelineId} timelineTabType={timelineTabType} + isReadOnly={isReadOnly} /> ), }), - [browserFields, data, id, isDraggable, timelineId, timelineTabType] + [browserFields, data, id, isDraggable, timelineId, timelineTabType, isReadOnly] ); const jsonTab = useMemo( diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/event_fields_browser.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/event_fields_browser.tsx index 384e9d72b0787..29700d3706b7b 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/event_fields_browser.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/event_fields_browser.tsx @@ -37,6 +37,7 @@ interface Props { isDraggable?: boolean; timelineId: string; timelineTabType: TimelineTabs | 'flyout'; + isReadOnly?: boolean; } const TableWrapper = styled.div` @@ -137,7 +138,7 @@ const StyledEuiInMemoryTable = styled(EuiInMemoryTable as any)` /** Renders a table view or JSON view of the `ECS` `data` */ export const EventFieldsBrowser = React.memo( - ({ browserFields, data, eventId, isDraggable, timelineTabType, timelineId }) => { + ({ browserFields, data, eventId, isDraggable, timelineTabType, timelineId, isReadOnly }) => { const containerElement = useRef(null); const dispatch = useDispatch(); const getTimeline = useMemo(() => timelineSelectors.getTimelineByIdSelector(), []); @@ -219,6 +220,7 @@ export const EventFieldsBrowser = React.memo( toggleColumn, getLinkValue, isDraggable, + isReadOnly, }), [ browserFields, @@ -230,6 +232,7 @@ export const EventFieldsBrowser = React.memo( toggleColumn, getLinkValue, isDraggable, + isReadOnly, ] ); diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/get_alert_summary_rows.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/get_alert_summary_rows.tsx index 8d2de0439967c..f2180ea2565e3 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/get_alert_summary_rows.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/get_alert_summary_rows.tsx @@ -227,12 +227,14 @@ export const getSummaryRows = ({ timelineId, eventId, isDraggable = false, + isReadOnly = false, }: { data: TimelineEventsDetailsItem[]; browserFields: BrowserFields; timelineId: string; eventId: string; isDraggable?: boolean; + isReadOnly?: boolean; }) => { const eventCategories = getEventCategoriesFromData(data); @@ -280,6 +282,7 @@ export const getSummaryRows = ({ field, }), isDraggable, + isReadOnly, }; if (field.id === 'agent.id' && !isAlertFromEndpointEvent({ data })) { diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/helpers.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/helpers.tsx index a6c9d71e3371c..a58ac79ee25ae 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/helpers.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/helpers.tsx @@ -56,6 +56,7 @@ export interface AlertSummaryRow { title: string; description: EnrichedFieldInfo & { isDraggable?: boolean; + isReadOnly?: boolean; }; } diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/overview/index.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/overview/index.tsx index 3c9c202a982a8..39fbf36ef5cd8 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/overview/index.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/overview/index.tsx @@ -26,7 +26,7 @@ import { SIGNAL_STATUS_FIELD_NAME, } from '../../../../timelines/components/timeline/body/renderers/constants'; import { FormattedFieldValue } from '../../../../timelines/components/timeline/body/renderers/formatted_field'; -import { OverviewCardWithActions } from '../overview/overview_card'; +import { OverviewCardWithActions, OverviewCard } from '../overview/overview_card'; import { StatusPopoverButton } from '../overview/status_popover_button'; import { SeverityBadge } from '../../../../../public/detections/components/rules/severity_badge'; import { useThrottledResizeObserver } from '../../utils'; @@ -44,10 +44,20 @@ interface Props { handleOnEventClosed: () => void; indexName: string; timelineId: string; + isReadOnly?: boolean; } export const Overview = React.memo( - ({ browserFields, contextId, data, eventId, handleOnEventClosed, indexName, timelineId }) => { + ({ + browserFields, + contextId, + data, + eventId, + handleOnEventClosed, + indexName, + timelineId, + isReadOnly, + }) => { const statusData = useMemo(() => { const item = find({ field: SIGNAL_STATUS_FIELD_NAME, category: 'kibana' }, data); return ( @@ -106,71 +116,83 @@ export const Overview = React.memo( ); }, [browserFields, contextId, data, eventId, timelineId]); - const signalCard = hasData(statusData) ? ( - - - + - - - ) : null; + contextId={contextId} + > + + + + ) : null; const severityCard = hasData(severityData) ? ( - - - + {!isReadOnly ? ( + + + + ) : ( + + + + )} ) : null; const riskScoreCard = hasData(riskScoreData) ? ( - - {riskScoreData.values[0]} - + {!isReadOnly ? ( + + {riskScoreData.values[0]} + + ) : ( + {riskScoreData.values[0]} + )} ) : null; - const ruleNameCard = hasData(ruleNameData) ? ( - - - + - - - ) : null; + > + + + + ) : null; const { width, ref } = useThrottledResizeObserver(); diff --git a/x-pack/plugins/security_solution/public/common/components/event_details/table/summary_value_cell.tsx b/x-pack/plugins/security_solution/public/common/components/event_details/table/summary_value_cell.tsx index 4289e0e73327d..ad9ca84429f00 100644 --- a/x-pack/plugins/security_solution/public/common/components/event_details/table/summary_value_cell.tsx +++ b/x-pack/plugins/security_solution/public/common/components/event_details/table/summary_value_cell.tsx @@ -20,6 +20,7 @@ export const SummaryValueCell: React.FC = ({ linkValue, timelineId, values, + isReadOnly, }) => ( <> = ({ style={{ flexGrow: 0 }} values={values} /> - {timelineId !== TimelineId.active && ( + {timelineId !== TimelineId.active && !isReadOnly && ( { const mockSetQuery = jest.fn(); diff --git a/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_histogram.tsx b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_histogram.tsx index c027c7fc17bc7..3b640592535b6 100644 --- a/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_histogram.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_histogram.tsx @@ -11,6 +11,8 @@ import { Unit } from '@elastic/datemath'; import { EuiFlexGroup, EuiFlexItem, EuiText, EuiSpacer, EuiLoadingChart } from '@elastic/eui'; import styled from 'styled-components'; import { Type } from '@kbn/securitysolution-io-ts-alerting-types'; +import { useIsExperimentalFeatureEnabled } from '../../../../common/hooks/use_experimental_features'; +import { useKibana } from '../../../../common/lib/kibana'; import * as i18n from './translations'; import { useGlobalTime } from '../../../../common/containers/use_global_time'; import { getHistogramConfig, getThresholdHistogramConfig, isNoisy } from './helpers'; @@ -21,12 +23,31 @@ import { BarChart } from '../../../../common/components/charts/barchart'; import { usePreviewHistogram } from './use_preview_histogram'; import { formatDate } from '../../../../common/components/super_date_picker'; import { FieldValueThreshold } from '../threshold_input'; +import { alertsDefaultModel } from '../../alerts_table/default_config'; +import { SourcererScopeName } from '../../../../common/store/sourcerer/model'; +import { defaultRowRenderers } from '../../../../timelines/components/timeline/body/renderers'; +import { TimelineId } from '../../../../../common/types'; +import { APP_ID, APP_UI_ID, DEFAULT_PREVIEW_INDEX } from '../../../../../common/constants'; +import { FIELDS_WITHOUT_CELL_ACTIONS } from '../../../../common/lib/cell_actions/constants'; +import { useSourcererDataView } from '../../../../common/containers/sourcerer'; +import { DetailsPanel } from '../../../../timelines/components/side_panel'; +import { PreviewRenderCellValue } from './preview_table_cell_renderer'; +import { getPreviewTableControlColumn } from './preview_table_control_columns'; +import { useGlobalFullScreen } from '../../../../common/containers/use_full_screen'; +import { InspectButtonContainer } from '../../../../common/components/inspect'; const LoadingChart = styled(EuiLoadingChart)` display: block; margin: 0 auto; `; +const FullScreenContainer = styled.div<{ $isFullScreen: boolean }>` + height: ${({ $isFullScreen }) => ($isFullScreen ? '100%' : undefined)}; + flex: 1 1 auto; + display: flex; + width: 100%; +`; + export const ID = 'previewHistogram'; interface PreviewHistogramProps { @@ -51,7 +72,7 @@ export const PreviewHistogram = ({ index, }: PreviewHistogramProps) => { const { setQuery, isInitializing } = useGlobalTime(); - + const { timelines: timelinesUi, cases } = useKibana().services; const from = useMemo(() => `now-1${timeFrame}`, [timeFrame]); const to = useMemo(() => 'now', []); const startDate = useMemo(() => formatDate(from), [from]); @@ -69,7 +90,30 @@ export const PreviewHistogram = ({ ruleType, }); + const { + columns, + dataProviders, + deletedEventIds, + kqlMode, + itemsPerPage, + itemsPerPageOptions, + graphEventId, + sort, + } = alertsDefaultModel; + + const { + browserFields, + docValueFields, + indexPattern, + runtimeMappings, + loading: isLoadingIndexPattern, + } = useSourcererDataView(SourcererScopeName.detections); + + const { globalFullScreen } = useGlobalFullScreen(); const previousPreviewId = usePrevious(previewId); + const tGridEventRenderedViewEnabled = useIsExperimentalFeatureEnabled( + 'tGridEventRenderedViewEnabled' + ); useEffect(() => { if (previousPreviewId !== previewId && totalCount > 0) { @@ -121,38 +165,91 @@ export const PreviewHistogram = ({ : i18n.QUERY_PREVIEW_TITLE(totalCount), [isLoading, totalCount, thresholdTotalCount, isThresholdRule] ); + const CasesContext = cases.ui.getCasesContext(); return ( - - - - - - - {isLoading ? ( - - ) : ( - + + + + - )} - - - <> - - -

{i18n.QUERY_PREVIEW_DISCLAIMER_MAX_SIGNALS}

-
- -
-
-
+
+ + {isLoading ? ( + + ) : ( + + )} + + + <> + + +

{i18n.QUERY_PREVIEW_DISCLAIMER_MAX_SIGNALS}

+
+ +
+
+
+ + + + + {timelinesUi.getTGrid<'embedded'>({ + additionalFilters: <>, + appId: APP_UI_ID, + browserFields, + columns, + dataProviders, + deletedEventIds, + disabledCellActions: FIELDS_WITHOUT_CELL_ACTIONS, + docValueFields, + end: to, + entityType: 'alerts', + filters: [], + globalFullScreen, + graphEventId, + hasAlertsCrud: false, + id: TimelineId.detectionsPage, + indexNames: [`${DEFAULT_PREVIEW_INDEX}-${spaceId}`], + indexPattern, + isLive: false, + isLoadingIndexPattern, + itemsPerPage, + itemsPerPageOptions, + kqlMode, + query: { query: `kibana.alert.rule.uuid:${previewId}`, language: 'kuery' }, + renderCellValue: PreviewRenderCellValue, + rowRenderers: defaultRowRenderers, + runtimeMappings, + setQuery: () => {}, + sort, + start: from, + tGridEventRenderedViewEnabled, + type: 'embedded', + leadingControlColumns: getPreviewTableControlColumn(1.5), + })} + + + + + ); }; diff --git a/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_cell_renderer.tsx b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_cell_renderer.tsx new file mode 100644 index 0000000000000..ab56bd3fbfe0d --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_cell_renderer.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { useMemo } from 'react'; +import { EuiDataGridCellValueElementProps } from '@elastic/eui'; +import { useIsExperimentalFeatureEnabled } from '../../../../common/hooks/use_experimental_features'; +import { StyledContent } from '../../../../common/lib/cell_actions/expanded_cell_value_actions'; +import { getLinkColumnDefinition } from '../../../../common/lib/cell_actions/helpers'; +import { useGetMappedNonEcsValue } from '../../../../timelines/components/timeline/body/data_driven_columns'; +import { columnRenderers } from '../../../../timelines/components/timeline/body/renderers'; +import { getColumnRenderer } from '../../../../timelines/components/timeline/body/renderers/get_column_renderer'; +import { CellValueElementProps } from '../../../../../../timelines/common'; + +export const PreviewRenderCellValue: React.FC< + EuiDataGridCellValueElementProps & CellValueElementProps +> = ({ + browserFields, + columnId, + data, + ecsData, + eventId, + globalFilters, + header, + isDetails, + isDraggable, + isExpandable, + isExpanded, + linkValues, + rowIndex, + colIndex, + rowRenderers, + setCellProps, + timelineId, + truncate, +}) => ( + +); + +export const PreviewTableCellRenderer: React.FC = ({ + browserFields, + data, + ecsData, + eventId, + header, + isDetails, + isDraggable, + isTimeline, + linkValues, + rowRenderers, + timelineId, + truncate, +}) => { + const usersEnabled = useIsExperimentalFeatureEnabled('usersEnabled'); + + const asPlainText = useMemo(() => { + return ( + getLinkColumnDefinition(header.id, header.type, undefined, usersEnabled) !== undefined && + !isTimeline + ); + }, [header.id, header.type, isTimeline, usersEnabled]); + + const values = useGetMappedNonEcsValue({ + data, + fieldName: header.id, + }); + const styledContentClassName = isDetails + ? 'eui-textBreakWord' + : 'eui-displayInlineBlock eui-textTruncate'; + return ( + <> + + {getColumnRenderer(header.id, columnRenderers, data).renderColumn({ + asPlainText, + browserFields, + columnName: header.id, + ecsData, + eventId, + field: header, + isDetails, + isDraggable, + linkValues, + rowRenderers, + timelineId, + truncate, + values, + })} + + + ); +}; diff --git a/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_control_columns.tsx b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_control_columns.tsx new file mode 100644 index 0000000000000..c8f59149ea1a2 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/preview_table_control_columns.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { EuiToolTip, EuiButtonIcon } from '@elastic/eui'; +import React from 'react'; +import styled from 'styled-components'; +import { ControlColumnProps, ActionProps } from '../../../../../../timelines/common'; +import { + getActionsColumnWidth, + DEFAULT_ACTION_BUTTON_WIDTH, +} from '../../../../../../timelines/public'; +import * as i18n from './translations'; + +const EventsTdContent = styled.div.attrs(({ className }) => ({ + className: `siemEventsTable__tdContent ${className != null ? className : ''}`, +}))<{ textAlign?: string; width?: number }>` + font-size: ${({ theme }) => theme.eui.euiFontSizeXS}; + line-height: ${({ theme }) => theme.eui.euiLineHeight}; + min-width: 0; + padding: ${({ theme }) => theme.eui.paddingSizes.xs}; + text-align: ${({ textAlign }) => textAlign}; + width: ${({ width }) => + width != null + ? `${width}px` + : '100%'}; /* Using width: 100% instead of flex: 1 and max-width: 100% for IE11 */ + + button.euiButtonIcon { + margin-left: ${({ theme }) => `-${theme.eui.paddingSizes.xs}`}; + } +`; + +export const getPreviewTableControlColumn = (actionButtonCount: number): ControlColumnProps[] => [ + { + headerCellRender: () => <>{i18n.ACTIONS}, + id: 'default-timeline-control-column', + rowCellRender: PreviewActions, + width: getActionsColumnWidth(actionButtonCount), + }, +]; + +const ActionsContainer = styled.div` + align-items: center; + display: flex; +`; + +const PreviewActionsComponent: React.FC = ({ + ariaRowindex, + columnValues, + onEventDetailsPanelOpened, +}) => { + return ( + +
+ + + + + +
+
+ ); +}; + +PreviewActionsComponent.displayName = 'PreviewActionsComponent'; + +export const PreviewActions = React.memo(PreviewActionsComponent); diff --git a/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/translations.ts b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/translations.ts index 58a90fba13dc9..3acb533913cfd 100644 --- a/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/translations.ts +++ b/x-pack/plugins/security_solution/public/detections/components/rules/rule_preview/translations.ts @@ -174,3 +174,30 @@ export const QUERY_PREVIEW_SEE_ALL_WARNINGS = i18n.translate( defaultMessage: 'See all warnings', } ); + +export const ACTIONS = i18n.translate( + 'xpack.securitySolution.detectionEngine.queryPreview.actions', + { + defaultMessage: 'Actions', + } +); + +export const VIEW_DETAILS = i18n.translate( + 'xpack.securitySolution.detectionEngine.queryPreview.viewDetailsAriaLabel', + { + defaultMessage: 'View details', + } +); + +export const VIEW_DETAILS_FOR_ROW = ({ + ariaRowindex, + columnValues, +}: { + ariaRowindex: number; + columnValues: string; +}) => + i18n.translate('xpack.securitySolution.detectionEngine.queryPreview.viewDetailsForRowAriaLabel', { + values: { ariaRowindex, columnValues }, + defaultMessage: + 'View details for the alert or event in row {ariaRowindex}, with columns {columnValues}', + }); diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/create/index.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/create/index.tsx index e9d8749ee5601..c7043f3725fcf 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/create/index.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/create/index.tsx @@ -70,6 +70,9 @@ const MyEuiPanel = styled(EuiPanel)<{ display: none; } } + .euiAccordion__childWrapper { + transform: none; /* To circumvent an issue in Eui causing the fullscreen datagrid to break */ + } `; MyEuiPanel.displayName = 'MyEuiPanel'; diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/expandable_event.tsx b/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/expandable_event.tsx index 37c88cc77d110..9955c2c318065 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/expandable_event.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/expandable_event.tsx @@ -40,6 +40,7 @@ interface Props { timelineId: string; hostRisk: HostRisk | null; handleOnEventClosed: HandleOnEventClosed; + isReadOnly?: boolean; } interface ExpandableEventTitleProps { @@ -109,6 +110,7 @@ export const ExpandableEvent = React.memo( hostRisk, rawEventData, handleOnEventClosed, + isReadOnly, }) => { if (!event.eventId) { return {i18n.EVENT_DETAILS_PLACEHOLDER}; @@ -133,6 +135,7 @@ export const ExpandableEvent = React.memo( timelineTabType={timelineTabType} hostRisk={hostRisk} handleOnEventClosed={handleOnEventClosed} + isReadOnly={isReadOnly} /> diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/index.tsx b/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/index.tsx index 0ca853b84f86e..22d8b9bd2f4aa 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/index.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/event_details/index.tsx @@ -67,6 +67,7 @@ interface EventDetailsPanelProps { runtimeMappings: MappingRuntimeFields; tabType: TimelineTabs; timelineId: string; + isReadOnly?: boolean; } const EventDetailsPanelComponent: React.FC = ({ @@ -80,6 +81,7 @@ const EventDetailsPanelComponent: React.FC = ({ runtimeMappings, tabType, timelineId, + isReadOnly, }) => { const [loading, detailsData, rawEventData, ecsData, refetchFlyoutData] = useTimelineEventsDetails( { @@ -234,21 +236,24 @@ const EventDetailsPanelComponent: React.FC = ({ timelineTabType="flyout" hostRisk={hostRisk} handleOnEventClosed={handleOnEventClosed} + isReadOnly={isReadOnly} /> )} - + {!isReadOnly && ( + + )} ) : ( @@ -272,17 +277,19 @@ const EventDetailsPanelComponent: React.FC = ({ hostRisk={hostRisk} handleOnEventClosed={handleOnEventClosed} /> - + {!isReadOnly && ( + + )} ); }; diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/index.tsx b/x-pack/plugins/security_solution/public/timelines/components/side_panel/index.tsx index 736fa39889340..b943d3251c476 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/index.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/index.tsx @@ -30,6 +30,7 @@ interface DetailsPanelProps { runtimeMappings: MappingRuntimeFields; tabType?: TimelineTabs; timelineId: string; + isReadOnly?: boolean; } /** @@ -47,6 +48,7 @@ export const DetailsPanel = React.memo( runtimeMappings, tabType, timelineId, + isReadOnly, }: DetailsPanelProps) => { const dispatch = useDispatch(); const getTimeline = useMemo(() => timelineSelectors.getTimelineByIdSelector(), []); @@ -90,6 +92,7 @@ export const DetailsPanel = React.memo( runtimeMappings={runtimeMappings} tabType={activeTab} timelineId={timelineId} + isReadOnly={isReadOnly} /> ); } From abd3e9e84d620651f4e90c5d6c6a3e76e98c182a Mon Sep 17 00:00:00 2001 From: "Joey F. Poon" Date: Tue, 29 Mar 2022 18:15:42 -0500 Subject: [PATCH 138/160] [Security Solution] silently filter duplicate blocklist values (#128702) --- .../validators/blocklist_validator.ts | 37 +++++++++++++------ .../apis/endpoint_artifacts/blocklists.ts | 29 --------------- 2 files changed, 25 insertions(+), 41 deletions(-) diff --git a/x-pack/plugins/security_solution/server/lists_integration/endpoint/validators/blocklist_validator.ts b/x-pack/plugins/security_solution/server/lists_integration/endpoint/validators/blocklist_validator.ts index e51190467aee4..f6f08d792b115 100644 --- a/x-pack/plugins/security_solution/server/lists_integration/endpoint/validators/blocklist_validator.ts +++ b/x-pack/plugins/security_solution/server/lists_integration/endpoint/validators/blocklist_validator.ts @@ -5,6 +5,7 @@ * 2.0. */ +import { cloneDeep, uniq } from 'lodash'; import { ENDPOINT_BLOCKLISTS_LIST_ID } from '@kbn/securitysolution-list-constants'; import { schema, Type, TypeOf } from '@kbn/config-schema'; import { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; @@ -127,24 +128,14 @@ const hashEntriesValidation = (entries: BlocklistConditionEntry[]) => { } const hashesCount: { [key: string]: boolean } = {}; - const duplicatedHashes: string[] = []; const invalidHash: string[] = []; // Check hash entries individually currentHashes.forEach((hash) => { if (!allowedHashes.includes(hash)) invalidHash.push(hash); - if (hashesCount[hash]) { - duplicatedHashes.push(hash); - } else { - hashesCount[hash] = true; - } + hashesCount[hash] = true; }); - // There is more than one entry with the same hash type - if (duplicatedHashes.length) { - return `There are some duplicated hashes: ${duplicatedHashes.join(',')}`; - } - // There is an entry with an invalid hash type if (invalidHash.length) { return `There are some invalid fields for hash type: ${invalidHash.join(',')}`; @@ -159,7 +150,7 @@ const entriesSchemaOptions = { return hashEntriesValidation(entries); } else { if (entries.length > 1) { - return 'Only one entry is allowed when no using hash field type'; + return 'Only one entry is allowed when not using hash field type'; } } }, @@ -202,6 +193,20 @@ const BlocklistDataSchema = schema.object( { unknowns: 'ignore' } ); +function removeDuplicateEntryValues(entries: BlocklistConditionEntry[]): BlocklistConditionEntry[] { + return entries.map((entry) => { + const nextEntry = cloneDeep(entry); + + if (nextEntry.type === 'match_any') { + nextEntry.value = uniq(nextEntry.value); + } else if (nextEntry.type === 'nested') { + removeDuplicateEntryValues(nextEntry.entries); + } + + return nextEntry; + }); +} + export class BlocklistValidator extends BaseValidator { static isBlocklist(item: { listId: string }): boolean { return item.listId === ENDPOINT_BLOCKLISTS_LIST_ID; @@ -211,6 +216,9 @@ export class BlocklistValidator extends BaseValidator { item: CreateExceptionListItemOptions ): Promise { await this.validateCanManageEndpointArtifacts(); + + item.entries = removeDuplicateEntryValues(item.entries as BlocklistConditionEntry[]); + await this.validateBlocklistData(item); await this.validateCanCreateByPolicyArtifacts(item); await this.validateByPolicyItem(item); @@ -249,6 +257,11 @@ export class BlocklistValidator extends BaseValidator { const updatedItem = _updatedItem as ExceptionItemLikeOptions; await this.validateCanManageEndpointArtifacts(); + + _updatedItem.entries = removeDuplicateEntryValues( + _updatedItem.entries as BlocklistConditionEntry[] + ); + await this.validateBlocklistData(updatedItem); try { diff --git a/x-pack/test/security_solution_endpoint_api_int/apis/endpoint_artifacts/blocklists.ts b/x-pack/test/security_solution_endpoint_api_int/apis/endpoint_artifacts/blocklists.ts index 7e67c38347603..5f58eb40c0956 100644 --- a/x-pack/test/security_solution_endpoint_api_int/apis/endpoint_artifacts/blocklists.ts +++ b/x-pack/test/security_solution_endpoint_api_int/apis/endpoint_artifacts/blocklists.ts @@ -124,35 +124,6 @@ export default function ({ getService }: FtrProviderContext) { .expect(anErrorMessageWith(/types that failed validation:/)); }); - it(`should error on [${blocklistApiCall.method}] if the same hash type is present twice`, async () => { - const body = blocklistApiCall.getBody(); - - body.entries = [ - { - field: 'file.hash.sha256', - value: ['a665a45920422f9d417e4867efdc4fb8a04a1f3fff1fa07e998e86f7f7a27ae3'], - type: 'match_any', - operator: 'included', - }, - { - field: 'file.hash.sha256', - value: [ - '2C26B46B68FFC68FF99B453C1D30413413422D706483BFA0F98A5E886266E7AE', - 'FCDE2B2EDBA56BF408601FB721FE9B5C338D10EE429EA04FAE5511B68FBF8FB9', - ], - type: 'match_any', - operator: 'included', - }, - ]; - - await supertest[blocklistApiCall.method](blocklistApiCall.path) - .set('kbn-xsrf', 'true') - .send(body) - .expect(400) - .expect(anEndpointArtifactError) - .expect(anErrorMessageWith(/duplicated/)); - }); - it(`should error on [${blocklistApiCall.method}] if an invalid hash is used`, async () => { const body = blocklistApiCall.getBody(); From db7db0e4ca7c91bf5dc4ce175d77e8f5a1b54544 Mon Sep 17 00:00:00 2001 From: Spencer Date: Tue, 29 Mar 2022 17:53:38 -0600 Subject: [PATCH 139/160] [ci-stats-reporter] prevent `Request body larger than maxBodyLength limit` error (#128840) Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com> --- .../kbn-dev-utils/src/ci_stats_reporter/ci_stats_reporter.ts | 4 ++++ packages/kbn-pm/dist/index.js | 5 ++++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/packages/kbn-dev-utils/src/ci_stats_reporter/ci_stats_reporter.ts b/packages/kbn-dev-utils/src/ci_stats_reporter/ci_stats_reporter.ts index f710f7ec70843..367a1be175266 100644 --- a/packages/kbn-dev-utils/src/ci_stats_reporter/ci_stats_reporter.ts +++ b/packages/kbn-dev-utils/src/ci_stats_reporter/ci_stats_reporter.ts @@ -312,6 +312,10 @@ export class CiStatsReporter { data: body, params: query, adapter: httpAdapter, + + // if it can be serialized into a string, send it + maxBodyLength: Infinity, + maxContentLength: Infinity, }); return resp.data; diff --git a/packages/kbn-pm/dist/index.js b/packages/kbn-pm/dist/index.js index 5c1403494e944..0b6ebc9deccb4 100644 --- a/packages/kbn-pm/dist/index.js +++ b/packages/kbn-pm/dist/index.js @@ -9304,7 +9304,10 @@ class CiStatsReporter { headers, data: body, params: query, - adapter: _http.default + adapter: _http.default, + // if it can be serialized into a string, send it + maxBodyLength: Infinity, + maxContentLength: Infinity }); return resp.data; } catch (error) { From 2884e56fee10f882c0eb35f38070e19f1027c488 Mon Sep 17 00:00:00 2001 From: "Lucas F. da Costa" Date: Wed, 30 Mar 2022 01:04:37 +0100 Subject: [PATCH 140/160] [Uptime] Use URL from the /allowed route in the action button to signup for Synthetics beta (#128798) * [Uptime] Use URL from the /allowed route in the action button to signup for Synthetics beta * rename betaFormUrl to SignupUrl * Rename service_allowed_wrapper test title to use "allowed" variable instead of enabled Co-authored-by: Dominique Clarke * Rename service_allowed_wrapper test title to use "allowed" variable instead of enabled Co-authored-by: Dominique Clarke * assert on button's HREF on empty state signup form tests Co-authored-by: Dominique Clarke --- .../uptime/common/types/synthetics_monitor.ts | 1 + .../hooks/use_inline_errors.test.tsx | 1 + .../hooks/use_inline_errors_count.test.tsx | 1 + .../hooks/use_locations.test.tsx | 1 + .../monitor_list/monitor_list.test.tsx | 1 + .../public/lib/__mocks__/uptime_store.mock.ts | 1 + .../uptime/public/lib/helper/rtl_helpers.tsx | 15 ++-- .../service_allowed_wrapper.test.tsx | 73 ++++++++++++++----- .../service_allowed_wrapper.tsx | 8 +- .../state/reducers/monitor_management.ts | 6 +- .../synthetics_service/service_api_client.ts | 11 ++- .../synthetics_service.test.ts | 1 + .../synthetics_service/synthetics_service.ts | 10 ++- .../synthetics_service/get_service_allowed.ts | 5 +- 14 files changed, 101 insertions(+), 34 deletions(-) diff --git a/x-pack/plugins/uptime/common/types/synthetics_monitor.ts b/x-pack/plugins/uptime/common/types/synthetics_monitor.ts index 2fba9e0c299aa..d59e45e86b819 100644 --- a/x-pack/plugins/uptime/common/types/synthetics_monitor.ts +++ b/x-pack/plugins/uptime/common/types/synthetics_monitor.ts @@ -22,4 +22,5 @@ export type DecryptedSyntheticsMonitorSavedObject = SimpleSavedObject', () => { }, syntheticsService: { loading: false, + signupUrl: null, }, } as MonitorManagementListState, }; diff --git a/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts b/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts index 298f3d17575f1..1bb86877f9861 100644 --- a/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts +++ b/x-pack/plugins/uptime/public/lib/__mocks__/uptime_store.mock.ts @@ -84,6 +84,7 @@ export const mockState: AppState = { enablement: null, syntheticsService: { loading: false, + signupUrl: null, }, }, ml: { diff --git a/x-pack/plugins/uptime/public/lib/helper/rtl_helpers.tsx b/x-pack/plugins/uptime/public/lib/helper/rtl_helpers.tsx index 15a279e1e95f0..ed23cdd52ca0e 100644 --- a/x-pack/plugins/uptime/public/lib/helper/rtl_helpers.tsx +++ b/x-pack/plugins/uptime/public/lib/helper/rtl_helpers.tsx @@ -285,21 +285,26 @@ const getHistoryFromUrl = (url: Url) => { }); }; -// This function allows us to query for the nearest button with test -// no matter whether it has nested tags or not (as EuiButton elements do). -export const forNearestButton = +const forNearestTag = + (tag: string) => (getByText: (f: MatcherFunction) => HTMLElement | null) => (text: string): HTMLElement | null => getByText((_content: string, node: Nullish) => { if (!node) return false; const noOtherButtonHasText = Array.from(node.children).every( - (child) => child && (child.textContent !== text || child.tagName.toLowerCase() !== 'button') + (child) => child && (child.textContent !== text || child.tagName.toLowerCase() !== tag) ); return ( - noOtherButtonHasText && node.textContent === text && node.tagName.toLowerCase() === 'button' + noOtherButtonHasText && node.textContent === text && node.tagName.toLowerCase() === tag ); }); +// This function allows us to query for the nearest button with test +// no matter whether it has nested tags or not (as EuiButton elements do). +export const forNearestButton = forNearestTag('button'); + +export const forNearestAnchor = forNearestTag('a'); + export const makeUptimePermissionsCore = ( permissions: Partial<{ 'alerting:save': boolean; diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx index 77e64f70d48e3..6f05314bc9fc0 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.test.tsx @@ -6,7 +6,7 @@ */ import React from 'react'; -import { render } from '../../lib/helper/rtl_helpers'; +import { render, forNearestButton, forNearestAnchor } from '../../lib/helper/rtl_helpers'; import * as allowedHook from '../../components/monitor_management/hooks/use_service_allowed'; import { ServiceAllowedWrapper } from './service_allowed_wrapper'; @@ -22,8 +22,10 @@ describe('ServiceAllowedWrapper', () => { expect(await findByText('Test text')).toBeInTheDocument(); }); - it('renders when enabled state is loading', async () => { - jest.spyOn(allowedHook, 'useSyntheticsServiceAllowed').mockReturnValue({ loading: true }); + it('renders loading state when allowed state is loading', async () => { + jest + .spyOn(allowedHook, 'useSyntheticsServiceAllowed') + .mockReturnValue({ loading: true, signupUrl: null }); const { findByText } = render( @@ -34,31 +36,68 @@ describe('ServiceAllowedWrapper', () => { expect(await findByText('Loading Monitor Management')).toBeInTheDocument(); }); - it('renders when enabled state is false', async () => { + it('renders children when allowed state is true', async () => { jest .spyOn(allowedHook, 'useSyntheticsServiceAllowed') - .mockReturnValue({ loading: false, isAllowed: false }); + .mockReturnValue({ loading: false, isAllowed: true, signupUrl: 'https://example.com' }); - const { findByText } = render( + const { findByText, queryByText } = render(
Test text
); - expect(await findByText('Monitor Management')).toBeInTheDocument(); + expect(await findByText('Test text')).toBeInTheDocument(); + expect(await queryByText('Monitor management')).not.toBeInTheDocument(); }); - it('renders when enabled state is true', async () => { - jest - .spyOn(allowedHook, 'useSyntheticsServiceAllowed') - .mockReturnValue({ loading: false, isAllowed: true }); + describe('when enabled state is false', () => { + it('renders an enabled button if there is a form URL', async () => { + jest + .spyOn(allowedHook, 'useSyntheticsServiceAllowed') + .mockReturnValue({ loading: false, isAllowed: false, signupUrl: 'https://example.com' }); - const { findByText } = render( - -
Test text
-
- ); + const { findByText, getByText } = render( + +
Test text
+
+ ); - expect(await findByText('Test text')).toBeInTheDocument(); + expect(await findByText('Monitor management')).toBeInTheDocument(); + expect(forNearestAnchor(getByText)('Request access')).toBeEnabled(); + expect(forNearestAnchor(getByText)('Request access')).toHaveAttribute( + 'href', + 'https://example.com' + ); + }); + + it('renders a disabled button if there is no form URL', async () => { + jest + .spyOn(allowedHook, 'useSyntheticsServiceAllowed') + .mockReturnValue({ loading: false, isAllowed: false, signupUrl: null }); + + const { findByText, getByText } = render( + +
Test text
+
+ ); + + expect(await findByText('Monitor management')).toBeInTheDocument(); + expect(forNearestButton(getByText)('Request access')).toBeDisabled(); + }); + + it('renders when enabled state is false', async () => { + jest + .spyOn(allowedHook, 'useSyntheticsServiceAllowed') + .mockReturnValue({ loading: false, isAllowed: false, signupUrl: 'https://example.com' }); + + const { findByText } = render( + +
Test text
+
+ ); + + expect(await findByText('Monitor management')).toBeInTheDocument(); + }); }); }); diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx index 8f6cd7d3f0eb5..152bc1cca12ad 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/service_allowed_wrapper.tsx @@ -11,7 +11,7 @@ import { EuiButton, EuiEmptyPrompt, EuiLoadingLogo } from '@elastic/eui'; import { useSyntheticsServiceAllowed } from '../../components/monitor_management/hooks/use_service_allowed'; export const ServiceAllowedWrapper: React.FC = ({ children }) => { - const { isAllowed, loading } = useSyntheticsServiceAllowed(); + const { isAllowed, signupUrl, loading } = useSyntheticsServiceAllowed(); if (loading) { return ( @@ -29,7 +29,7 @@ export const ServiceAllowedWrapper: React.FC = ({ children }) => { title={

{MONITOR_MANAGEMENT_LABEL}

} body={

{PUBLIC_BETA_DESCRIPTION}

} actions={[ - + {REQUEST_ACCESS_LABEL} , ]} @@ -45,7 +45,7 @@ const REQUEST_ACCESS_LABEL = i18n.translate('xpack.uptime.monitorManagement.requ }); const MONITOR_MANAGEMENT_LABEL = i18n.translate('xpack.uptime.monitorManagement.label', { - defaultMessage: 'Monitor Management', + defaultMessage: 'Monitor management', }); const LOADING_MONITOR_MANAGEMENT_LABEL = i18n.translate( @@ -59,7 +59,7 @@ const PUBLIC_BETA_DESCRIPTION = i18n.translate( 'xpack.uptime.monitorManagement.publicBetaDescription', { defaultMessage: - 'Monitor Management is available only for selected public beta users. With public\n' + + 'Monitor management is available only for selected public beta users. With public\n' + 'beta access, you will be able to add HTTP, TCP, ICMP and Browser checks which will\n' + "run on Elastic's managed synthetics service nodes.", } diff --git a/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts b/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts index 419c43db20ccf..2f60b9bf1499e 100644 --- a/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts +++ b/x-pack/plugins/uptime/public/state/reducers/monitor_management.ts @@ -40,7 +40,7 @@ export interface MonitorManagementList { list: MonitorManagementListResult; locations: ServiceLocations; enablement: MonitorManagementEnablementResult | null; - syntheticsService: { isAllowed?: boolean; loading: boolean }; + syntheticsService: { isAllowed?: boolean; signupUrl: string | null; loading: boolean }; throttling: ThrottlingOptions; } @@ -64,6 +64,7 @@ export const initialState: MonitorManagementList = { enablement: null, }, syntheticsService: { + signupUrl: null, loading: false, }, throttling: DEFAULT_THROTTLING, @@ -269,6 +270,7 @@ export const monitorManagementListReducer = createReducer(initialState, (builder ...state, syntheticsService: { isAllowed: state.syntheticsService?.isAllowed, + signupUrl: state.syntheticsService?.signupUrl, loading: true, }, }) @@ -282,6 +284,7 @@ export const monitorManagementListReducer = createReducer(initialState, (builder ...state, syntheticsService: { isAllowed: action.payload.serviceAllowed, + signupUrl: action.payload.signupUrl, loading: false, }, }) @@ -292,6 +295,7 @@ export const monitorManagementListReducer = createReducer(initialState, (builder ...state, syntheticsService: { isAllowed: false, + signupUrl: null, loading: false, }, }) diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/service_api_client.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/service_api_client.ts index cf27574c09d6f..68d4ebd385f07 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/service_api_client.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/service_api_client.ts @@ -85,10 +85,10 @@ export class ServiceAPIClient { return this.callAPI('POST', { ...data, runOnce: true }); } - async checkIfAccountAllowed() { + async checkAccountAccessStatus() { if (this.authorization) { // in case username/password is provided, we assume it's always allowed - return true; + return { allowed: true, signupUrl: null }; } const httpsAgent = this.getHttpsAgent(); @@ -109,12 +109,15 @@ export class ServiceAPIClient { : undefined, httpsAgent, }); - return data.allowed; + + const { allowed, signupUrl } = data; + return { allowed, signupUrl }; } catch (e) { this.logger.error(e); } } - return false; + + return { allowed: false, signupUrl: null }; } async callAPI( diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.test.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.test.ts index 74c4aa0fca7da..f76126d40d5e9 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.test.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.test.ts @@ -30,6 +30,7 @@ describe('SyntheticsService', () => { expect(service.isAllowed).toEqual(false); expect(service.locations).toEqual([]); + expect(service.signupUrl).toEqual(null); }); it('inits properly with basic auth', async () => { diff --git a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts index 21d5fa6760983..b48a785f8354f 100644 --- a/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts +++ b/x-pack/plugins/uptime/server/lib/synthetics_service/synthetics_service.ts @@ -61,12 +61,14 @@ export class SyntheticsService { private indexTemplateInstalling?: boolean; public isAllowed: boolean; + public signupUrl: string | null; constructor(logger: Logger, server: UptimeServerSetup, config: ServiceConfig) { this.logger = logger; this.server = server; this.config = config; this.isAllowed = false; + this.signupUrl = null; this.apiClient = new ServiceAPIClient(logger, this.config, this.server.kibanaVersion); @@ -78,7 +80,9 @@ export class SyntheticsService { public async init() { await this.registerServiceLocations(); - this.isAllowed = await this.apiClient.checkIfAccountAllowed(); + const { allowed, signupUrl } = await this.apiClient.checkAccountAccessStatus(); + this.isAllowed = allowed; + this.signupUrl = signupUrl; } private setupIndexTemplates() { @@ -140,7 +144,9 @@ export class SyntheticsService { await service.registerServiceLocations(); - service.isAllowed = await service.apiClient.checkIfAccountAllowed(); + const { allowed, signupUrl } = await service.apiClient.checkAccountAccessStatus(); + service.isAllowed = allowed; + service.signupUrl = signupUrl; if (service.isAllowed) { service.setupIndexTemplates(); diff --git a/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_service_allowed.ts b/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_service_allowed.ts index a7d6a1e0c9882..8e302e5fefde8 100644 --- a/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_service_allowed.ts +++ b/x-pack/plugins/uptime/server/rest_api/synthetics_service/get_service_allowed.ts @@ -13,6 +13,9 @@ export const getServiceAllowedRoute: UMRestApiRouteFactory = () => ({ path: API_URLS.SERVICE_ALLOWED, validate: {}, handler: async ({ server }): Promise => { - return { serviceAllowed: server.syntheticsService.isAllowed }; + return { + serviceAllowed: server.syntheticsService.isAllowed, + signupUrl: server.syntheticsService.signupUrl, + }; }, }); From a5b7bbba21e5e651b9bc7a4486de659cfa4e823f Mon Sep 17 00:00:00 2001 From: Nathan Reese Date: Tue, 29 Mar 2022 18:32:20 -0600 Subject: [PATCH 141/160] [Maps] Allow implementers of ITooltipProperty to return React-DOM for the tooltip-value (#127069) * [Maps] Allow implementers of ITooltipProperty to return React-DOM for the tooltip-value * update snapshots * update ml tooltip to create reactnode instead of generating html string * revert unneeded change * remove actualDisplay and typicalDisplay * tslint * fix jest test Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- x-pack/plugins/maps/common/index.ts | 1 + .../tooltips/es_agg_tooltip_property.ts | 3 +- ...ip_property.ts => es_tooltip_property.tsx} | 19 ++++- .../join_tooltip_property.tsx | 2 +- .../classes/tooltips/tooltip_property.ts | 2 +- .../feature_properties.test.tsx.snap | 54 +++++--------- .../features_tooltip/feature_properties.tsx | 22 +----- .../plugins/ml/public/maps/anomaly_source.tsx | 8 +- ...urce_field.ts => anomaly_source_field.tsx} | 55 +++++++++++--- .../plugins/ml/public/maps/maps_util.test.js | 43 +---------- .../ml/public/maps/results.test.mock.ts | 63 +++++++--------- x-pack/plugins/ml/public/maps/util.ts | 74 +++++-------------- 12 files changed, 132 insertions(+), 214 deletions(-) rename x-pack/plugins/maps/public/classes/tooltips/{es_tooltip_property.ts => es_tooltip_property.tsx} (83%) rename x-pack/plugins/ml/public/maps/{anomaly_source_field.ts => anomaly_source_field.tsx} (77%) diff --git a/x-pack/plugins/maps/common/index.ts b/x-pack/plugins/maps/common/index.ts index e140a855c3c30..fc86af0e2b1f5 100644 --- a/x-pack/plugins/maps/common/index.ts +++ b/x-pack/plugins/maps/common/index.ts @@ -8,6 +8,7 @@ export { AGG_TYPE, COLOR_MAP_TYPE, + DECIMAL_DEGREES_PRECISION, ES_GEO_FIELD_TYPE, FIELD_ORIGIN, INITIAL_LOCATION, diff --git a/x-pack/plugins/maps/public/classes/tooltips/es_agg_tooltip_property.ts b/x-pack/plugins/maps/public/classes/tooltips/es_agg_tooltip_property.ts index 54d5495db2389..24c250c55d708 100644 --- a/x-pack/plugins/maps/public/classes/tooltips/es_agg_tooltip_property.ts +++ b/x-pack/plugins/maps/public/classes/tooltips/es_agg_tooltip_property.ts @@ -5,6 +5,7 @@ * 2.0. */ +import { ReactNode } from 'react'; import { ESTooltipProperty } from './es_tooltip_property'; import { AGG_TYPE } from '../../../common/constants'; import { ITooltipProperty } from './tooltip_property'; @@ -27,7 +28,7 @@ export class ESAggTooltipProperty extends ESTooltipProperty { this._aggField = field; } - getHtmlDisplayValue(): string { + getHtmlDisplayValue(): ReactNode { const rawValue = this.getRawValue(); return typeof rawValue !== 'undefined' && this._aggField.isCount() ? parseInt(rawValue as string, 10).toLocaleString() diff --git a/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.ts b/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.tsx similarity index 83% rename from x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.ts rename to x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.tsx index 04e8086ea6480..de6421895c654 100644 --- a/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.ts +++ b/x-pack/plugins/maps/public/classes/tooltips/es_tooltip_property.tsx @@ -5,6 +5,7 @@ * 2.0. */ +import React, { ReactNode } from 'react'; import _ from 'lodash'; import { type Filter, buildExistsFilter, buildPhraseFilter } from '@kbn/es-query'; import { ITooltipProperty } from './tooltip_property'; @@ -45,7 +46,7 @@ export class ESTooltipProperty implements ITooltipProperty { return this._indexPattern.fields.getByName(this._field.getRootName()); } - getHtmlDisplayValue(): string { + getHtmlDisplayValue(): ReactNode { if (typeof this.getRawValue() === 'undefined') { return '-'; } @@ -62,9 +63,19 @@ export class ESTooltipProperty implements ITooltipProperty { const formatter = this._indexPattern.getFormatterForField(indexPatternField); const htmlConverter = formatter.getConverterFor('html'); - return htmlConverter - ? htmlConverter(this.getRawValue()) - : formatter.convert(this.getRawValue()); + return htmlConverter ? ( + + ) : ( + formatter.convert(this.getRawValue()) + ); } isFilterable(): boolean { diff --git a/x-pack/plugins/maps/public/classes/tooltips/join_tooltip_property/join_tooltip_property.tsx b/x-pack/plugins/maps/public/classes/tooltips/join_tooltip_property/join_tooltip_property.tsx index 30793572b4f6a..c6ca5e9b3d5f9 100644 --- a/x-pack/plugins/maps/public/classes/tooltips/join_tooltip_property/join_tooltip_property.tsx +++ b/x-pack/plugins/maps/public/classes/tooltips/join_tooltip_property/join_tooltip_property.tsx @@ -41,7 +41,7 @@ export class JoinTooltipProperty implements ITooltipProperty { return this._tooltipProperty.getRawValue(); } - getHtmlDisplayValue(): string { + getHtmlDisplayValue(): ReactNode { return this._tooltipProperty.getHtmlDisplayValue(); } diff --git a/x-pack/plugins/maps/public/classes/tooltips/tooltip_property.ts b/x-pack/plugins/maps/public/classes/tooltips/tooltip_property.ts index 5fa23a3266190..0a4ca8af5dd79 100644 --- a/x-pack/plugins/maps/public/classes/tooltips/tooltip_property.ts +++ b/x-pack/plugins/maps/public/classes/tooltips/tooltip_property.ts @@ -16,7 +16,7 @@ import type { TooltipFeature } from '../../../../../plugins/maps/common/descript export interface ITooltipProperty { getPropertyKey(): string; getPropertyName(): string | ReactNode; - getHtmlDisplayValue(): string; + getHtmlDisplayValue(): ReactNode; getRawValue(): string | string[] | undefined; isFilterable(): boolean; getESFilters(): Promise; diff --git a/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/__snapshots__/feature_properties.test.tsx.snap b/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/__snapshots__/feature_properties.test.tsx.snap index 29df06a64a3f2..06440a83fb9c6 100644 --- a/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/__snapshots__/feature_properties.test.tsx.snap +++ b/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/__snapshots__/feature_properties.test.tsx.snap @@ -16,12 +16,9 @@ exports[`FeatureProperties should render 1`] = ` + > + foobar1 + + > + foobar2 + @@ -76,12 +70,9 @@ exports[`FeatureProperties should show filter button for filterable properties 1 + > + foobar1 + + > + foobar2 + @@ -135,12 +123,9 @@ exports[`FeatureProperties should show view actions button when there are availa + > + foobar1 + @@ -181,12 +166,9 @@ exports[`FeatureProperties should show view actions button when there are availa + > + foobar2 + diff --git a/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/feature_properties.tsx b/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/feature_properties.tsx index a994731f0adec..25e1a69805d96 100644 --- a/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/feature_properties.tsx +++ b/x-pack/plugins/maps/public/connected_components/mb_map/tooltip_control/features_tooltip/feature_properties.tsx @@ -217,16 +217,7 @@ export class FeatureProperties extends Component { {tooltipProperty.getPropertyName()} - + {tooltipProperty.getHtmlDisplayValue()} @@ -338,16 +329,7 @@ export class FeatureProperties extends Component { {tooltipProperty.getPropertyName()} - + {tooltipProperty.getHtmlDisplayValue()} {this._renderFilterCell(tooltipProperty)} ); diff --git a/x-pack/plugins/ml/public/maps/anomaly_source.tsx b/x-pack/plugins/ml/public/maps/anomaly_source.tsx index e2d92a730d95a..07f6df52f44e5 100644 --- a/x-pack/plugins/ml/public/maps/anomaly_source.tsx +++ b/x-pack/plugins/ml/public/maps/anomaly_source.tsx @@ -251,13 +251,7 @@ export class AnomalySource implements IVectorSource { continue; } if (properties.hasOwnProperty(key)) { - const label = ANOMALY_SOURCE_FIELDS[key]?.label; - if (label) { - tooltipProperties.push(new AnomalySourceTooltipProperty(label, properties[key])); - } else if (!ANOMALY_SOURCE_FIELDS[key]) { - // partition field keys will be different each time so won't be in ANOMALY_SOURCE_FIELDS - tooltipProperties.push(new AnomalySourceTooltipProperty(key, properties[key])); - } + tooltipProperties.push(new AnomalySourceTooltipProperty(key, properties[key])); } } return tooltipProperties; diff --git a/x-pack/plugins/ml/public/maps/anomaly_source_field.ts b/x-pack/plugins/ml/public/maps/anomaly_source_field.tsx similarity index 77% rename from x-pack/plugins/ml/public/maps/anomaly_source_field.ts rename to x-pack/plugins/ml/public/maps/anomaly_source_field.tsx index ac60cb3b54fb5..70eb0a8d9c408 100644 --- a/x-pack/plugins/ml/public/maps/anomaly_source_field.ts +++ b/x-pack/plugins/ml/public/maps/anomaly_source_field.tsx @@ -6,11 +6,12 @@ */ // eslint-disable-next-line max-classes-per-file +import React, { ReactNode } from 'react'; import { escape } from 'lodash'; import { i18n } from '@kbn/i18n'; import { Filter } from '@kbn/es-query'; import { IField, IVectorSource } from '../../../maps/public'; -import { FIELD_ORIGIN } from '../../../maps/common'; +import { FIELD_ORIGIN, DECIMAL_DEGREES_PRECISION } from '../../../maps/common'; import { TileMetaFeature } from '../../../maps/common/descriptor_types'; import { AnomalySource } from './anomaly_source'; import { ITooltipProperty } from '../../../maps/public'; @@ -25,6 +26,8 @@ export const TYPICAL_TO_ACTUAL = i18n.translate('xpack.ml.maps.anomalyLayerTypic defaultMessage: 'Typical to actual', }); +const INFLUENCER_LIMIT = 3; + export const ANOMALY_SOURCE_FIELDS: Record> = { record_score: { label: i18n.translate('xpack.ml.maps.anomalyLayerRecordScoreLabel', { @@ -50,15 +53,11 @@ export const ANOMALY_SOURCE_FIELDS: Record> = { }), type: 'string', }, - // this value is only used to place the point on the map - actual: {}, - actualDisplay: { + actual: { label: ACTUAL_LABEL, type: 'string', }, - // this value is only used to place the point on the map - typical: {}, - typicalDisplay: { + typical: { label: TYPICAL_LABEL, type: 'string', }, @@ -106,23 +105,55 @@ export const ANOMALY_SOURCE_FIELDS: Record> = { }, }; +const ROUND_POWER = Math.pow(10, DECIMAL_DEGREES_PRECISION); +function roundCoordinate(coordinate: number) { + return Math.round(Number(coordinate) * ROUND_POWER) / ROUND_POWER; +} + export class AnomalySourceTooltipProperty implements ITooltipProperty { - constructor(private readonly _label: string, private readonly _value: string) {} + constructor(private readonly _field: string, private readonly _value: string) {} async getESFilters(): Promise { return []; } - getHtmlDisplayValue(): string { + getHtmlDisplayValue(): string | ReactNode { + if (this._field === 'influencers') { + try { + const influencers = JSON.parse(this._value) as Array<{ + influencer_field_name: string; + influencer_field_values: string[]; + }>; + return ( +
    + {influencers.map(({ influencer_field_name: name, influencer_field_values: values }) => { + return
  • {`${name}: ${values.slice(0, INFLUENCER_LIMIT).join(', ')}`}
  • ; + })} +
+ ); + } catch (error) { + // ignore error and display unformated value + } + } else if (this._field === 'actual' || this._field === 'typical') { + try { + const point = JSON.parse(this._value) as number[]; + return `[${roundCoordinate(point[0])}, ${roundCoordinate(point[1])}]`; + } catch (error) { + // ignore error and display unformated value + } + } + return this._value.toString(); } getPropertyKey(): string { - return this._label; + return this._field; } getPropertyName(): string { - return this._label; + return ANOMALY_SOURCE_FIELDS[this._field] && ANOMALY_SOURCE_FIELDS[this._field].label + ? ANOMALY_SOURCE_FIELDS[this._field].label + : this._field; } getRawValue(): string | string[] | undefined { @@ -146,7 +177,7 @@ export class AnomalySourceField implements IField { async createTooltipProperty(value: string | string[] | undefined): Promise { return new AnomalySourceTooltipProperty( - await this.getLabel(), + this._field, escape(Array.isArray(value) ? value.join() : value ? value : '') ); } diff --git a/x-pack/plugins/ml/public/maps/maps_util.test.js b/x-pack/plugins/ml/public/maps/maps_util.test.js index dd6fde9e8b28c..be21a292eb163 100644 --- a/x-pack/plugins/ml/public/maps/maps_util.test.js +++ b/x-pack/plugins/ml/public/maps/maps_util.test.js @@ -5,7 +5,7 @@ * 2.0. */ -import { getInfluencersHtmlString, getResultsForJobId } from './util'; +import { getResultsForJobId } from './util'; import { mlResultsServiceMock, typicalExpected, @@ -14,47 +14,6 @@ import { } from './results.test.mock'; describe('Maps util', () => { - describe('getInfluencersHtmlString', () => { - const splitField = 'split_field_influencer'; - const valueFour = 'value_four'; - const influencerFour = 'influencer_four'; - const influencers = [ - { - influencer_field_name: 'influencer_one', - influencer_field_values: ['value_one', 'value_two', 'value_three', valueFour], - }, - { - influencer_field_name: 'influencer_two', - influencer_field_values: ['value_one', 'value_two', 'value_three', valueFour], - }, - { - influencer_field_name: splitField, - influencer_field_values: ['value_one', 'value_two'], - }, - { - influencer_field_name: 'influencer_three', - influencer_field_values: ['value_one', 'value_two', 'value_three', valueFour], - }, - { - influencer_field_name: influencerFour, - influencer_field_values: ['value_one', 'value_two', 'value_three', valueFour], - }, - ]; - - test('should create the html string when given an array of influencers', () => { - const expected = - '
  • influencer_one: value_one, value_two, value_three
  • influencer_two: value_one, value_two, value_three
  • influencer_three: value_one, value_two, value_three
'; - const actual = getInfluencersHtmlString(influencers, splitField); - expect(actual).toBe(expected); - // Should not include split field - expect(actual.includes(splitField)).toBe(false); - // should limit to the first three influencer values - expect(actual.includes(valueFour)).toBe(false); - // should limit to the first three influencer names - expect(actual.includes(influencerFour)).toBe(false); - }); - }); - describe('getResultsForJobId', () => { const jobId = 'jobId'; const searchFilters = { diff --git a/x-pack/plugins/ml/public/maps/results.test.mock.ts b/x-pack/plugins/ml/public/maps/results.test.mock.ts index f718e818ba73c..8db3aaeda62ad 100644 --- a/x-pack/plugins/ml/public/maps/results.test.mock.ts +++ b/x-pack/plugins/ml/public/maps/results.test.mock.ts @@ -5,6 +5,30 @@ * 2.0. */ +const influencers = [ + { + influencer_field_name: 'geo.dest', + influencer_field_values: ['CN', 'DO', 'RU', 'US'], + }, + { + influencer_field_name: 'clientip', + influencer_field_values: [ + '108.131.25.207', + '192.41.143.247', + '194.12.201.131', + '41.91.106.242', + ], + }, + { + influencer_field_name: 'agent.keyword', + influencer_field_values: [ + 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)', + 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24', + 'Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1', + ], + }, +]; + const results = { took: 9, timed_out: false, @@ -41,29 +65,7 @@ const results = { typical: [39.9864616394043, -97.862548828125], actual: [29.261693651787937, -121.93940273718908], field_name: 'geo.coordinates', - influencers: [ - { - influencer_field_name: 'geo.dest', - influencer_field_values: ['CN', 'DO', 'RU', 'US'], - }, - { - influencer_field_name: 'clientip', - influencer_field_values: [ - '108.131.25.207', - '192.41.143.247', - '194.12.201.131', - '41.91.106.242', - ], - }, - { - influencer_field_name: 'agent.keyword', - influencer_field_values: [ - 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)', - 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24', - 'Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1', - ], - }, - ], + influencers, geo_results: { typical_point: '39.986461639404,-97.862548828125', actual_point: '29.261693651788,-121.939402737189', @@ -87,15 +89,12 @@ export const typicalExpected = { geometry: { coordinates: [-97.862548828125, 39.986461639404], type: 'Point' }, properties: { actual: [-121.939402737189, 29.261693651788], - actualDisplay: [-121.94, 29.26], fieldName: 'geo.coordinates', functionDescription: 'lat_long', - influencers: - '
  • geo.dest: CN, DO, RU
  • clientip: 108.131.25.207, 192.41.143.247, 194.12.201.131
  • agent.keyword: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322), Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24, Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1
', + influencers, record_score: 77, timestamp: 'February 27th 2022, 10:00:00', typical: [-97.862548828125, 39.986461639404], - typicalDisplay: [-97.86, 39.99], }, type: 'Feature', }, @@ -114,15 +113,12 @@ export const actualExpected = { }, properties: { actual: [-121.939402737189, 29.261693651788], - actualDisplay: [-121.94, 29.26], typical: [-97.862548828125, 39.986461639404], - typicalDisplay: [-97.86, 39.99], fieldName: 'geo.coordinates', functionDescription: 'lat_long', timestamp: 'February 27th 2022, 10:00:00', record_score: 77, - influencers: - '
  • geo.dest: CN, DO, RU
  • clientip: 108.131.25.207, 192.41.143.247, 194.12.201.131
  • agent.keyword: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322), Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24, Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1
', + influencers, }, }, ], @@ -141,15 +137,12 @@ export const typicalToActualExpected = { }, properties: { actual: [-121.939402737189, 29.261693651788], - actualDisplay: [-121.94, 29.26], typical: [-97.862548828125, 39.986461639404], - typicalDisplay: [-97.86, 39.99], fieldName: 'geo.coordinates', functionDescription: 'lat_long', timestamp: 'February 27th 2022, 10:00:00', record_score: 77, - influencers: - '
  • geo.dest: CN, DO, RU
  • clientip: 108.131.25.207, 192.41.143.247, 194.12.201.131
  • agent.keyword: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322), Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24, Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1
', + influencers, }, }, ], diff --git a/x-pack/plugins/ml/public/maps/util.ts b/x-pack/plugins/ml/public/maps/util.ts index 11e6b6f5a3920..f2a4719bc4ef8 100644 --- a/x-pack/plugins/ml/public/maps/util.ts +++ b/x-pack/plugins/ml/public/maps/util.ts @@ -23,42 +23,12 @@ export const ML_ANOMALY_LAYERS = { } as const; export type MlAnomalyLayersType = typeof ML_ANOMALY_LAYERS[keyof typeof ML_ANOMALY_LAYERS]; -const INFLUENCER_LIMIT = 3; -const INFLUENCER_MAX_VALUES = 3; - -export function getInfluencersHtmlString( - influencers: Array<{ influencer_field_name: string; influencer_field_values: string[] }>, - splitFields: string[] -) { - let htmlString = '
    '; - let influencerCount = 0; - for (let i = 0; i < influencers.length; i++) { - // eslint-disable-next-line @typescript-eslint/naming-convention - const { influencer_field_name, influencer_field_values } = influencers[i]; - // Skip if there are no values or it's a partition field - if (!influencer_field_values.length || splitFields.includes(influencer_field_name)) continue; - - const fieldValuesString = influencer_field_values.slice(0, INFLUENCER_MAX_VALUES).join(', '); - - htmlString += `
  • ${influencer_field_name}: ${fieldValuesString}
  • `; - influencerCount += 1; - - if (influencerCount === INFLUENCER_LIMIT) { - break; - } - } - htmlString += '
'; - - return htmlString; -} // Must reverse coordinates here. Map expects [lon, lat] - anomalies are stored as [lat, lon] for lat_lon jobs -function getCoordinates(actualCoordinateStr: string, round: boolean = false): number[] { - const convertWithRounding = (point: string) => Math.round(Number(point) * 100) / 100; - const convert = (point: string) => Number(point); - return actualCoordinateStr +function getCoordinates(latLonString: string): number[] { + return latLonString .split(',') - .map(round ? convertWithRounding : convert) + .map((coordinate: string) => Number(coordinate)) .reverse(); } @@ -136,21 +106,10 @@ export async function getResultsForJobId( const features: Feature[] = resp?.hits.hits.map(({ _source }) => { const geoResults = _source.geo_results; - const actualCoordStr = geoResults && geoResults.actual_point; - const typicalCoordStr = geoResults && geoResults.typical_point; - let typical: number[] = []; - let typicalDisplay: number[] = []; - let actual: number[] = []; - let actualDisplay: number[] = []; - - if (actualCoordStr !== undefined) { - actual = getCoordinates(actualCoordStr); - actualDisplay = getCoordinates(actualCoordStr, true); - } - if (typicalCoordStr !== undefined) { - typical = getCoordinates(typicalCoordStr); - typicalDisplay = getCoordinates(typicalCoordStr, true); - } + const actual = + geoResults && geoResults.actual_point ? getCoordinates(geoResults.actual_point) : [0, 0]; + const typical = + geoResults && geoResults.typical_point ? getCoordinates(geoResults.typical_point) : [0, 0]; let geometry: Geometry; if (locationType === ML_ANOMALY_LAYERS.TYPICAL || locationType === ML_ANOMALY_LAYERS.ACTUAL) { @@ -173,25 +132,30 @@ export async function getResultsForJobId( ...(_source.over_field_name ? { [_source.over_field_name]: _source.over_field_value } : {}), }; + const splitFieldKeys = Object.keys(splitFields); + const influencers = _source.influencers + ? _source.influencers.filter( + ({ influencer_field_name: name, influencer_field_values: values }) => { + // remove influencers without values and influencers on partition fields + return values.length && !splitFieldKeys.includes(name); + } + ) + : []; + return { type: 'Feature', geometry, properties: { actual, - actualDisplay, typical, - typicalDisplay, fieldName: _source.field_name, functionDescription: _source.function_description, timestamp: formatHumanReadableDateTimeSeconds(_source.timestamp), record_score: Math.floor(_source.record_score), ...(Object.keys(splitFields).length > 0 ? splitFields : {}), - ...(_source.influencers?.length + ...(influencers.length ? { - influencers: getInfluencersHtmlString( - _source.influencers, - Object.keys(splitFields) - ), + influencers, } : {}), }, From 1f00343bab2d57b3e2d5dad1d99e9caa8a4e0b52 Mon Sep 17 00:00:00 2001 From: Robert Austin Date: Tue, 29 Mar 2022 20:49:29 -0400 Subject: [PATCH 142/160] Security Solution: enhance getAggregatableFields perf (#128824) The `getAggregatableFields` function is used to determine which fields can be passed to a stacked visualization. When there are many fields, this function can run long. This commit reimplements the function so that it run faster and uses less memory. --- .../common/__snapshots__/hooks.test.tsx.snap | 3 +++ .../alerts_kpis/common/hooks.test.tsx | 11 +++++++++- .../components/alerts_kpis/common/hooks.ts | 21 +++++++++---------- 3 files changed, 23 insertions(+), 12 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/__snapshots__/hooks.test.tsx.snap diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/__snapshots__/hooks.test.tsx.snap b/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/__snapshots__/hooks.test.tsx.snap new file mode 100644 index 0000000000000..6637bcf724c0f --- /dev/null +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/__snapshots__/hooks.test.tsx.snap @@ -0,0 +1,3 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`getAggregatableFields 1`] = `Array []`; diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.test.tsx b/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.test.tsx index d68c5c303cfd7..064798040fb8b 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.test.tsx +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.test.tsx @@ -7,7 +7,12 @@ import React from 'react'; import { renderHook } from '@testing-library/react-hooks'; -import { useInspectButton, UseInspectButtonParams, useStackByFields } from './hooks'; +import { + getAggregatableFields, + useInspectButton, + UseInspectButtonParams, + useStackByFields, +} from './hooks'; import { mockBrowserFields } from '../../../../common/containers/source/mock'; import { TestProviders } from '../../../../common/mock'; @@ -16,6 +21,10 @@ jest.mock('react-router-dom', () => { return { ...actual, useLocation: jest.fn().mockReturnValue({ pathname: '' }) }; }); +test('getAggregatableFields', () => { + expect(getAggregatableFields(mockBrowserFields)).toMatchSnapshot(); +}); + describe('hooks', () => { describe('useInspectButton', () => { const defaultParams: UseInspectButtonParams = { diff --git a/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.ts b/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.ts index 65b87670810b0..85d8be5a2e846 100644 --- a/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.ts +++ b/x-pack/plugins/security_solution/public/detections/components/alerts_kpis/common/hooks.ts @@ -55,17 +55,16 @@ export const useInspectButton = ({ }, [setQuery, loading, response, request, refetch, uniqueQueryId, deleteQuery]); }; -function getAggregatableFields(fields: { [fieldName: string]: Partial }) { - return Object.entries(fields).reduce( - (filteredOptions: EuiComboBoxOptionOption[], [key, field]) => { - if (field.aggregatable === true) { - return [...filteredOptions, { label: key, value: key }]; - } else { - return filteredOptions; - } - }, - [] - ); +export function getAggregatableFields(fields: { + [fieldName: string]: Partial; +}): EuiComboBoxOptionOption[] { + const result = []; + for (const [key, field] of Object.entries(fields)) { + if (field.aggregatable === true) { + result.push({ label: key, value: key }); + } + } + return result; } export const useStackByFields = () => { From 05a8b3218270fd2ca7b3f458bea3d3751cfb2621 Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Tue, 29 Mar 2022 20:51:16 -0400 Subject: [PATCH 143/160] [CI] Build TS refs before API docs (#128816) --- .buildkite/scripts/steps/build_api_docs.sh | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/.buildkite/scripts/steps/build_api_docs.sh b/.buildkite/scripts/steps/build_api_docs.sh index 2f63d6efa0941..00387fa657a59 100755 --- a/.buildkite/scripts/steps/build_api_docs.sh +++ b/.buildkite/scripts/steps/build_api_docs.sh @@ -4,5 +4,11 @@ set -euo pipefail .buildkite/scripts/bootstrap.sh +echo "--- Build TS Refs" +node scripts/build_ts_refs \ + --clean \ + --no-cache \ + --force + echo "--- Build API Docs" node --max-old-space-size=12000 scripts/build_api_docs From 66f4b12b05d5ae2000cebb3f7c26a8e4c876f5e2 Mon Sep 17 00:00:00 2001 From: Paulo Henrique Date: Tue, 29 Mar 2022 22:48:10 -0300 Subject: [PATCH 144/160] [Security solution][Session view] - Adding Session Viewer Icons (#128828) --- .../public/timelines/components/timeline/body/actions/index.tsx | 2 +- .../session_view/public/components/process_tree_node/index.tsx | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/actions/index.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/actions/index.tsx index 300f000bb4a63..cd96cfaf42db1 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/actions/index.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/actions/index.tsx @@ -257,7 +257,7 @@ const ActionsComponent: React.FC = ({ diff --git a/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx b/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx index 4a75948d3d3aa..213b8724fbf8d 100644 --- a/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx +++ b/x-pack/plugins/session_view/public/components/process_tree_node/index.tsx @@ -207,7 +207,7 @@ export function ProcessTreeNode({ const showUserEscalation = user.id && user.id !== parent.user?.id; const interactiveSession = !!tty; - const sessionIcon = interactiveSession ? 'consoleApp' : 'compute'; + const sessionIcon = interactiveSession ? 'desktop' : 'gear'; const iconTestSubj = hasExec ? 'sessionView:processTreeNodeExecIcon' : 'sessionView:processTreeNodeForkIcon'; From 436dfbed8cb43fd39e32b684871a65360db22c8a Mon Sep 17 00:00:00 2001 From: Shahzad Date: Wed, 30 Mar 2022 03:52:01 +0200 Subject: [PATCH 145/160] [Monitor management] Show public beta fair usage (#128770) * show public beta fair usage * add callout for async service errors Co-authored-by: Dominique Clarke --- .../monitor_management/locations.ts | 15 ++- .../monitor_management/monitor_types.ts | 27 ++-- .../action_bar/action_bar.tsx | 40 +----- .../monitor_list/monitor_async_error.test.tsx | 116 ++++++++++++++++++ .../monitor_list/monitor_async_error.tsx | 75 +++++++++++ .../monitor_list/monitor_list_container.tsx | 2 + .../monitor_management/show_sync_errors.tsx | 52 ++++++++ .../monitor_management/monitor_management.tsx | 4 +- .../state/reducers/monitor_management.ts | 1 + .../synthetics_service/synthetics_service.ts | 7 +- .../synthetics_service/get_monitor.ts | 3 +- 11 files changed, 285 insertions(+), 57 deletions(-) create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/show_sync_errors.tsx diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts index d11ae7c655405..82d2bc8afa412 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts @@ -64,12 +64,15 @@ export const ServiceLocationErrors = t.array( status: t.number, }), t.partial({ - failed_monitors: t.array( - t.interface({ - id: t.string, - message: t.string, - }) - ), + failed_monitors: t.union([ + t.array( + t.interface({ + id: t.string, + message: t.string, + }) + ), + t.null, + ]), }), ]), }) diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts index 44c643d2160d1..872ccdbb71ec8 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts @@ -8,7 +8,7 @@ import * as t from 'io-ts'; import { secretKeys } from '../../constants/monitor_management'; import { ConfigKey } from './config_key'; -import { LocationsCodec } from './locations'; +import { LocationsCodec, ServiceLocationErrors } from './locations'; import { DataStreamCodec, ModeCodec, @@ -306,14 +306,23 @@ export type EncryptedSyntheticsMonitorWithId = t.TypeOf< typeof EncryptedSyntheticsMonitorWithIdCodec >; -export const MonitorManagementListResultCodec = t.type({ - monitors: t.array( - t.interface({ id: t.string, attributes: EncryptedSyntheticsMonitorCodec, updated_at: t.string }) - ), - page: t.number, - perPage: t.number, - total: t.union([t.number, t.null]), -}); +export const MonitorManagementListResultCodec = t.intersection([ + t.type({ + monitors: t.array( + t.interface({ + id: t.string, + attributes: EncryptedSyntheticsMonitorCodec, + updated_at: t.string, + }) + ), + page: t.number, + perPage: t.number, + total: t.union([t.number, t.null]), + }), + t.partial({ + syncErrors: ServiceLocationErrors, + }), +]); export type MonitorManagementListResult = t.TypeOf; diff --git a/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx b/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx index 3b30458974ed7..5f6e67e363171 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx @@ -19,7 +19,6 @@ import { i18n } from '@kbn/i18n'; import { useSelector } from 'react-redux'; import { FETCH_STATUS, useFetcher } from '../../../../../observability/public'; -import { toMountPoint } from '../../../../../../../src/plugins/kibana_react/public'; import { MONITOR_MANAGEMENT_ROUTE } from '../../../../common/constants'; import { UptimeSettingsContext } from '../../../contexts'; @@ -32,6 +31,7 @@ import { TestRun } from '../test_now_mode/test_now_mode'; import { monitorManagementListSelector } from '../../../state/selectors'; import { kibanaService } from '../../../state/kibana_service'; +import { showSyncErrors } from '../show_sync_errors'; export interface ActionBarProps { monitor: SyntheticsMonitor; @@ -103,43 +103,7 @@ export const ActionBar = ({ }); setIsSuccessful(true); } else if (hasErrors && !loading) { - Object.values(data.attributes.errors!).forEach((location) => { - const { status: responseStatus, reason } = location.error || {}; - kibanaService.toasts.addWarning({ - title: i18n.translate('xpack.uptime.monitorManagement.service.error.title', { - defaultMessage: `Unable to sync monitor config`, - }), - text: toMountPoint( - <> -

- {i18n.translate('xpack.uptime.monitorManagement.service.error.message', { - defaultMessage: `Your monitor was saved, but there was a problem syncing the configuration for {location}. We will automatically try again later. If this problem continues, your monitors will stop running in {location}. Please contact Support for assistance.`, - values: { - location: locations?.find((loc) => loc?.id === location.locationId)?.label, - }, - })} -

- {responseStatus || reason ? ( -

- {responseStatus - ? i18n.translate('xpack.uptime.monitorManagement.service.error.status', { - defaultMessage: 'Status: {status}. ', - values: { status: responseStatus }, - }) - : null} - {reason - ? i18n.translate('xpack.uptime.monitorManagement.service.error.reason', { - defaultMessage: 'Reason: {reason}.', - values: { reason }, - }) - : null} -

- ) : null} - - ), - toastLifeTimeMs: 30000, - }); - }); + showSyncErrors(data.attributes.errors, locations); setIsSuccessful(true); } }, [data, status, isSaving, isValid, monitorId, hasErrors, locations, loading]); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx new file mode 100644 index 0000000000000..1122d136c926c --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { screen } from '@testing-library/react'; +import React from 'react'; +import { DEFAULT_THROTTLING } from '../../../../common/runtime_types'; +import { render } from '../../../lib/helper/rtl_helpers'; +import { MonitorManagementList as MonitorManagementListState } from '../../../state/reducers/monitor_management'; +import { MonitorAsyncError } from './monitor_async_error'; + +describe('', () => { + const location1 = 'US Central'; + const location2 = 'US North'; + const reason1 = 'Unauthorized'; + const reason2 = 'Forbidden'; + const status1 = 401; + const status2 = 403; + const state = { + monitorManagementList: { + throttling: DEFAULT_THROTTLING, + enablement: null, + list: { + perPage: 5, + page: 1, + total: 6, + monitors: [], + syncErrors: [ + { + locationId: 'us_central', + error: { + reason: reason1, + status: status1, + }, + }, + { + locationId: 'us_north', + error: { + reason: reason2, + status: status2, + }, + }, + ], + }, + locations: [ + { + id: 'us_central', + label: location1, + geo: { + lat: 0, + lon: 0, + }, + url: '', + }, + { + id: 'us_north', + label: location2, + geo: { + lat: 0, + lon: 0, + }, + url: '', + }, + ], + error: { + serviceLocations: null, + monitorList: null, + enablement: null, + }, + loading: { + monitorList: true, + serviceLocations: false, + enablement: false, + }, + syntheticsService: { + loading: false, + }, + } as MonitorManagementListState, + }; + + it('renders when errors are defined', () => { + render(, { state }); + + expect(screen.getByText(new RegExp(reason1))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(`${status1}`))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(reason2))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(`${status2}`))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(location1))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(location2))).toBeInTheDocument(); + }); + + it('renders null when errors are empty', () => { + render(, { + state: { + ...state, + monitorManagementList: { + ...state.monitorManagementList, + list: { + ...state.monitorManagementList.list, + syncErrors: [], + }, + }, + }, + }); + + expect(screen.queryByText(new RegExp(reason1))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(`${status1}`))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(reason2))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(`${status2}`))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(location1))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(location2))).not.toBeInTheDocument(); + }); +}); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx new file mode 100644 index 0000000000000..c9e9dba2027a4 --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React, { useState } from 'react'; +import { useSelector } from 'react-redux'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { EuiButton, EuiCallOut, EuiSpacer } from '@elastic/eui'; +import { monitorManagementListSelector } from '../../../state/selectors'; + +export const MonitorAsyncError = () => { + const [isDismissed, setIsDismissed] = useState(false); + const { list, locations } = useSelector(monitorManagementListSelector); + const syncErrors = list.syncErrors; + const hasSyncErrors = syncErrors && syncErrors.length > 0; + + return hasSyncErrors && !isDismissed ? ( + <> + + } + color="warning" + iconType="alert" + > +

+ +

+
    + {Object.values(syncErrors).map((e) => { + return ( +
  • {`${ + locations.find((location) => location.id === e.locationId)?.label + } - ${STATUS_LABEL}: ${e.error.status}; ${REASON_LABEL}: ${e.error.reason}.`}
  • + ); + })} +
+ setIsDismissed(true)} color="warning"> + {DISMISS_LABEL} + +
+ + + ) : null; +}; + +const REASON_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.monitorSync.failure.reasonLabel', + { + defaultMessage: 'Reason', + } +); + +const STATUS_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.monitorSync.failure.statusLabel', + { + defaultMessage: 'Status', + } +); + +const DISMISS_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.monitorSync.failure.dismissLabel', + { + defaultMessage: 'Dismiss', + } +); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx index a3f041a33a9f8..53afdf49c1592 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx @@ -13,6 +13,7 @@ import { ConfigKey } from '../../../../common/runtime_types'; import { getMonitors } from '../../../state/actions'; import { monitorManagementListSelector } from '../../../state/selectors'; import { MonitorManagementListPageState } from './monitor_list'; +import { MonitorAsyncError } from './monitor_async_error'; import { useInlineErrors } from '../hooks/use_inline_errors'; import { MonitorListTabs } from './list_tabs'; import { AllMonitors } from './all_monitors'; @@ -66,6 +67,7 @@ export const MonitorListContainer: React.FC = () => { return ( <> + { + Object.values(errors).forEach((location) => { + const { status: responseStatus, reason } = location.error || {}; + kibanaService.toasts.addWarning({ + title: i18n.translate('xpack.uptime.monitorManagement.service.error.title', { + defaultMessage: `Unable to sync monitor config`, + }), + text: toMountPoint( + <> +

+ {i18n.translate('xpack.uptime.monitorManagement.service.error.message', { + defaultMessage: `Your monitor was saved, but there was a problem syncing the configuration for {location}. We will automatically try again later. If this problem continues, your monitors will stop running in {location}. Please contact Support for assistance.`, + values: { + location: locations?.find((loc) => loc?.id === location.locationId)?.label, + }, + })} +

+ {responseStatus || reason ? ( +

+ {responseStatus + ? i18n.translate('xpack.uptime.monitorManagement.service.error.status', { + defaultMessage: 'Status: {status}. ', + values: { status: responseStatus }, + }) + : null} + {reason + ? i18n.translate('xpack.uptime.monitorManagement.service.error.reason', { + defaultMessage: 'Reason: {reason}.', + values: { reason }, + }) + : null} +

+ ) : null} + + ), + toastLifeTimeMs: 30000, + }); + }); +}; diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx index 3e0e9b955f31f..71785dbaf78ee 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx @@ -17,6 +17,7 @@ import { useMonitorManagementBreadcrumbs } from './use_monitor_management_breadc import { MonitorListContainer } from '../../components/monitor_management/monitor_list/monitor_list_container'; import { EnablementEmptyState } from '../../components/monitor_management/monitor_list/enablement_empty_state'; import { useEnablement } from '../../components/monitor_management/hooks/use_enablement'; +import { useLocations } from '../../components/monitor_management/hooks/use_locations'; import { Loader } from '../../components/monitor_management/loader/loader'; export const MonitorManagementPage: React.FC = () => { @@ -32,6 +33,7 @@ export const MonitorManagementPage: React.FC = () => { loading: enablementLoading, enableSynthetics, } = useEnablement(); + const { loading: locationsLoading } = useLocations(); const { list: monitorList } = useSelector(monitorManagementListSelector); const { isEnabled } = enablement; @@ -62,7 +64,7 @@ export const MonitorManagementPage: React.FC = () => { return ( <> ({ search: schema.maybe(schema.string()), }), }, - handler: async ({ request, savedObjectsClient }): Promise => { + handler: async ({ request, savedObjectsClient, server }): Promise => { const { perPage = 50, page, sortField, sortOrder, search } = request.query; // TODO: add query/filtering params const { @@ -78,6 +78,7 @@ export const getAllSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ ...rest, perPage: perPageT, monitors, + syncErrors: server.syntheticsService.syncErrors, }; }, }); From ace270fba0abb2c8b35522e3179d5a79e818b7a4 Mon Sep 17 00:00:00 2001 From: Garrett Spong Date: Tue, 29 Mar 2022 19:58:49 -0600 Subject: [PATCH 146/160] [Security Solution][Detections] Fixes show alerts for execution action on Rule Execution Log (#128843) ## Summary One-liner fix for the `Show alerts for execution` action on the Rule Execution Log table. Had the wrong key after changing the response interface. Working on the follow-up feedback PR from https://github.com/elastic/kibana/pull/126215, and will be including additional test coverage there, but wanted to get this in before the first BC for testing purposes.

--- .../rules/details/execution_log_table/execution_log_table.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx index 212ac9ec5b94f..03ccd9ea5ee70 100644 --- a/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx +++ b/x-pack/plugins/security_solution/public/detections/pages/detection_engine/rules/details/execution_log_table/execution_log_table.tsx @@ -223,7 +223,7 @@ const ExecutionLogTableComponent: React.FC = ({ icon: 'filter', type: 'icon', onClick: (value: object) => { - const executionId = get(value, EXECUTION_UUID_FIELD_NAME); + const executionId = get(value, 'execution_uuid'); if (executionId) { onFilterByExecutionIdCallback(executionId); } From 253b9a3c8501e125e6a6472902ebe073f4e471ca Mon Sep 17 00:00:00 2001 From: Corey Robertson Date: Tue, 29 Mar 2022 22:12:08 -0400 Subject: [PATCH 147/160] Time slider control (#128305) Adds the Time Slider Control to the controls plugin. --- .../steps/storybooks/build_and_upload.js | 1 + .../time_slider_persistable_state.ts | 47 +++ .../common/control_types/time_slider/types.ts | 17 + src/plugins/controls/common/index.ts | 2 + src/plugins/controls/jest.config.js | 18 + src/plugins/controls/jest_setup.ts | 14 + .../public/__stories__/controls.stories.tsx | 4 +- .../storybook_control_factories.ts | 6 + .../time_slider.component.stories.tsx | 190 ++++++++++ .../public/control_types/time_slider/index.ts | 11 + .../time_slider/time_slider.component.scss | 47 +++ .../time_slider/time_slider.component.tsx | 336 ++++++++++++++++++ .../control_types/time_slider/time_slider.tsx | 94 +++++ .../time_slider/time_slider_editor.tsx | 103 ++++++ .../time_slider_embeddable.test.ts | 287 +++++++++++++++ .../time_slider/time_slider_embeddable.tsx | 321 +++++++++++++++++ .../time_slider_embeddable_factory.tsx | 60 ++++ .../time_slider/time_slider_reducers.ts | 21 ++ .../time_slider/time_slider_strings.ts | 46 +++ src/plugins/controls/public/index.ts | 7 +- src/plugins/controls/public/plugin.ts | 18 + src/plugins/controls/public/services/data.ts | 15 + src/plugins/controls/public/services/index.ts | 2 + .../controls/public/services/kibana/data.ts | 81 ++++- .../controls/public/services/kibana/index.ts | 2 + .../public/services/kibana/settings.ts | 27 ++ .../controls/public/services/settings.ts | 12 + .../public/services/storybook/data.ts | 8 +- .../public/services/storybook/index.ts | 2 + .../public/services/storybook/settings.ts | 16 + .../controls/public/services/stub/index.ts | 2 + .../time_slider_embeddable_factory.ts | 22 ++ src/plugins/controls/server/plugin.ts | 2 + src/plugins/controls/tsconfig.json | 3 +- 34 files changed, 1835 insertions(+), 9 deletions(-) create mode 100644 src/plugins/controls/common/control_types/time_slider/time_slider_persistable_state.ts create mode 100644 src/plugins/controls/common/control_types/time_slider/types.ts create mode 100644 src/plugins/controls/jest.config.js create mode 100644 src/plugins/controls/jest_setup.ts create mode 100644 src/plugins/controls/public/control_types/time_slider/__stories__/time_slider.component.stories.tsx create mode 100644 src/plugins/controls/public/control_types/time_slider/index.ts create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider.component.scss create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider.component.tsx create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider.tsx create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider_editor.tsx create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.test.ts create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.tsx create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider_embeddable_factory.tsx create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider_reducers.ts create mode 100644 src/plugins/controls/public/control_types/time_slider/time_slider_strings.ts create mode 100644 src/plugins/controls/public/services/kibana/settings.ts create mode 100644 src/plugins/controls/public/services/settings.ts create mode 100644 src/plugins/controls/public/services/storybook/settings.ts create mode 100644 src/plugins/controls/server/control_types/time_slider/time_slider_embeddable_factory.ts diff --git a/.buildkite/scripts/steps/storybooks/build_and_upload.js b/.buildkite/scripts/steps/storybooks/build_and_upload.js index 9d40edc905763..482640b8d9cc0 100644 --- a/.buildkite/scripts/steps/storybooks/build_and_upload.js +++ b/.buildkite/scripts/steps/storybooks/build_and_upload.js @@ -16,6 +16,7 @@ const STORYBOOKS = [ 'canvas', 'ci_composite', 'cloud', + 'controls', 'custom_integrations', 'dashboard_enhanced', 'dashboard', diff --git a/src/plugins/controls/common/control_types/time_slider/time_slider_persistable_state.ts b/src/plugins/controls/common/control_types/time_slider/time_slider_persistable_state.ts new file mode 100644 index 0000000000000..660f33a15a33d --- /dev/null +++ b/src/plugins/controls/common/control_types/time_slider/time_slider_persistable_state.ts @@ -0,0 +1,47 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { + EmbeddableStateWithType, + EmbeddablePersistableStateService, +} from '../../../../embeddable/common'; +import { TimeSliderControlEmbeddableInput } from './types'; +import { SavedObjectReference } from '../../../../../core/types'; +import { DATA_VIEW_SAVED_OBJECT_TYPE } from '../../../../data_views/common'; + +type TimeSliderInputWithType = Partial & { type: string }; +const dataViewReferenceName = 'timeSliderDataView'; + +export const createTimeSliderInject = (): EmbeddablePersistableStateService['inject'] => { + return (state: EmbeddableStateWithType, references: SavedObjectReference[]) => { + const workingState = { ...state } as EmbeddableStateWithType | TimeSliderInputWithType; + references.forEach((reference) => { + if (reference.name === dataViewReferenceName) { + (workingState as TimeSliderInputWithType).dataViewId = reference.id; + } + }); + return workingState as EmbeddableStateWithType; + }; +}; + +export const createTimeSliderExtract = (): EmbeddablePersistableStateService['extract'] => { + return (state: EmbeddableStateWithType) => { + const workingState = { ...state } as EmbeddableStateWithType | TimeSliderInputWithType; + const references: SavedObjectReference[] = []; + + if ('dataViewId' in workingState) { + references.push({ + name: dataViewReferenceName, + type: DATA_VIEW_SAVED_OBJECT_TYPE, + id: workingState.dataViewId!, + }); + delete workingState.dataViewId; + } + return { state: workingState as EmbeddableStateWithType, references }; + }; +}; diff --git a/src/plugins/controls/common/control_types/time_slider/types.ts b/src/plugins/controls/common/control_types/time_slider/types.ts new file mode 100644 index 0000000000000..73d364da80caa --- /dev/null +++ b/src/plugins/controls/common/control_types/time_slider/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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { ControlInput } from '../../types'; + +export const TIME_SLIDER_CONTROL = 'timeSlider'; + +export interface TimeSliderControlEmbeddableInput extends ControlInput { + fieldName: string; + dataViewId: string; + value?: [number | null, number | null]; +} diff --git a/src/plugins/controls/common/index.ts b/src/plugins/controls/common/index.ts index 23779e225ce47..ff2c39346f075 100644 --- a/src/plugins/controls/common/index.ts +++ b/src/plugins/controls/common/index.ts @@ -16,3 +16,5 @@ export { OPTIONS_LIST_CONTROL } from './control_types/options_list/types'; export { RANGE_SLIDER_CONTROL } from './control_types/range_slider/types'; export { getDefaultControlGroupInput } from './control_group/control_group_constants'; + +export { TIME_SLIDER_CONTROL } from './control_types/time_slider/types'; diff --git a/src/plugins/controls/jest.config.js b/src/plugins/controls/jest.config.js new file mode 100644 index 0000000000000..bf024134ef60c --- /dev/null +++ b/src/plugins/controls/jest.config.js @@ -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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +module.exports = { + preset: '@kbn/test', + rootDir: '../../..', + roots: ['/src/plugins/controls'], + testRunner: 'jasmine2', + coverageDirectory: '/target/kibana-coverage/jest/src/plugins/controls', + coverageReporters: ['text', 'html'], + collectCoverageFrom: ['/src/plugins/controls/{common,public,server}/**/*.{ts,tsx}'], + setupFiles: ['/src/plugins/controls/jest_setup.ts'], +}; diff --git a/src/plugins/controls/jest_setup.ts b/src/plugins/controls/jest_setup.ts new file mode 100644 index 0000000000000..bef43fb98d3f0 --- /dev/null +++ b/src/plugins/controls/jest_setup.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +// Start the services with stubs +import { pluginServices } from './public/services'; +import { registry } from './public/services/stub'; + +registry.start({}); +pluginServices.setRegistry(registry); diff --git a/src/plugins/controls/public/__stories__/controls.stories.tsx b/src/plugins/controls/public/__stories__/controls.stories.tsx index 12bf0cacbe136..12e595f483e04 100644 --- a/src/plugins/controls/public/__stories__/controls.stories.tsx +++ b/src/plugins/controls/public/__stories__/controls.stories.tsx @@ -63,7 +63,7 @@ const storybookStubOptionsListRequest = async ( ); replaceOptionsListMethod(storybookStubOptionsListRequest); -const ControlGroupStoryComponent: FC<{ +export const ControlGroupStoryComponent: FC<{ panels?: ControlsPanels; edit?: boolean; }> = ({ panels, edit }) => { @@ -161,7 +161,7 @@ export const ConfiguredControlGroupStory = () => ( } as OptionsListEmbeddableInput, }, optionsList3: { - type: OPTIONS_LIST_CONTROL, + type: 'TIME_SLIDER', order: 3, width: 'auto', explicitInput: { diff --git a/src/plugins/controls/public/__stories__/storybook_control_factories.ts b/src/plugins/controls/public/__stories__/storybook_control_factories.ts index 12674a97d856d..f0c0611ad45fe 100644 --- a/src/plugins/controls/public/__stories__/storybook_control_factories.ts +++ b/src/plugins/controls/public/__stories__/storybook_control_factories.ts @@ -8,6 +8,7 @@ import { OptionsListEmbeddableFactory } from '../control_types/options_list'; import { RangeSliderEmbeddableFactory } from '../control_types/range_slider'; +import { TimesliderEmbeddableFactory } from '../control_types/time_slider'; import { ControlsService } from '../services/controls'; import { ControlFactory } from '..'; @@ -25,4 +26,9 @@ export const populateStorybookControlFactories = (controlsServiceStub: ControlsS const rangeSliderControlFactory = rangeSliderFactoryStub as unknown as ControlFactory; rangeSliderControlFactory.getDefaultInput = () => ({}); controlsServiceStub.registerControlType(rangeSliderControlFactory); + + const timesliderFactoryStub = new TimesliderEmbeddableFactory(); + const timeSliderControlFactory = timesliderFactoryStub as unknown as ControlFactory; + timeSliderControlFactory.getDefaultInput = () => ({}); + controlsServiceStub.registerControlType(timeSliderControlFactory); }; diff --git a/src/plugins/controls/public/control_types/time_slider/__stories__/time_slider.component.stories.tsx b/src/plugins/controls/public/control_types/time_slider/__stories__/time_slider.component.stories.tsx new file mode 100644 index 0000000000000..7ae7871497045 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/__stories__/time_slider.component.stories.tsx @@ -0,0 +1,190 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ +import React, { FC, useCallback, useState } from 'react'; +import moment from 'moment'; +import { EuiFormControlLayout } from '@elastic/eui'; + +import { TimeSliderProps, TimeSlider } from '../time_slider.component'; + +export default { + title: 'Time Slider', + description: '', +}; + +const TimeSliderWrapper: FC> = (props) => { + const [value, setValue] = useState(props.value); + const onChange = useCallback( + (newValue: [number | null, number | null]) => { + const lowValue = newValue[0]; + const highValue = newValue[1]; + + setValue([lowValue, highValue]); + }, + [setValue] + ); + + return ( +
+ + + +
+ ); +}; + +const undefinedValue: [null, null] = [null, null]; +const undefinedRange: [undefined, undefined] = [undefined, undefined]; + +export const TimeSliderNoValuesOrRange = () => { + // If range is undefined, that should be inndicate that we are loading the range + return ; +}; + +export const TimeSliderUndefinedRangeNoValue = () => { + // If a range is [undefined, undefined] then it was loaded, but no values were found. + return ; +}; + +export const TimeSliderUndefinedRangeWithValue = () => { + const lastWeek = moment().subtract(7, 'days'); + const now = moment(); + + return ( + + ); +}; + +export const TimeSliderWithRangeAndNoValue = () => { + const lastWeek = moment().subtract(7, 'days'); + const now = moment(); + + return ( + + ); +}; + +export const TimeSliderWithRangeAndLowerValue = () => { + const lastWeek = moment().subtract(7, 'days'); + const now = moment(); + + const threeDays = moment().subtract(3, 'days'); + + return ( + + ); +}; + +export const TimeSliderWithRangeAndUpperValue = () => { + const lastWeek = moment().subtract(7, 'days'); + const now = moment(); + + const threeDays = moment().subtract(3, 'days'); + + return ( + + ); +}; + +export const TimeSliderWithLowRangeOverlap = () => { + const lastWeek = moment().subtract(7, 'days'); + const now = moment(); + + const threeDays = moment().subtract(3, 'days'); + const twoDays = moment().subtract(2, 'days'); + + return ( + + ); +}; + +export const TimeSliderWithLowRangeOverlapAndIgnoredValidation = () => { + const lastWeek = moment().subtract(7, 'days'); + const now = moment(); + + const threeDays = moment().subtract(3, 'days'); + const twoDays = moment().subtract(2, 'days'); + + return ( + + ); +}; + +export const TimeSliderWithRangeLowerThanValue = () => { + const twoWeeksAgo = moment().subtract(14, 'days'); + const lastWeek = moment().subtract(7, 'days'); + + const now = moment(); + const threeDays = moment().subtract(3, 'days'); + + return ( + + ); +}; + +export const TimeSliderWithRangeHigherThanValue = () => { + const twoWeeksAgo = moment().subtract(14, 'days'); + const lastWeek = moment().subtract(7, 'days'); + + const now = moment(); + const threeDays = moment().subtract(3, 'days'); + + return ( + + ); +}; + +export const PartialValueLowerThanRange = () => { + // Selected value is March 8 -> March 9 + // Range is March 11 -> 25 + const eightDaysAgo = moment().subtract(8, 'days'); + + const lastWeek = moment().subtract(7, 'days'); + const today = moment(); + + return ( + + ); +}; + +export const PartialValueHigherThanRange = () => { + // Selected value is March 8 -> March 9 + // Range is March 11 -> 25 + const eightDaysAgo = moment().subtract(8, 'days'); + + const lastWeek = moment().subtract(7, 'days'); + const today = moment(); + + return ( + + ); +}; diff --git a/src/plugins/controls/public/control_types/time_slider/index.ts b/src/plugins/controls/public/control_types/time_slider/index.ts new file mode 100644 index 0000000000000..1cd5900164676 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export { TimesliderEmbeddableFactory } from './time_slider_embeddable_factory'; +export { type TimeSliderControlEmbeddableInput } from '../../../common/control_types/time_slider/types'; +export {} from '../../../common'; diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider.component.scss b/src/plugins/controls/public/control_types/time_slider/time_slider.component.scss new file mode 100644 index 0000000000000..3f8a37ec44d37 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider.component.scss @@ -0,0 +1,47 @@ +.timeSlider__anchorOverride { + display:block; + >div { + height: 100%; + } +} + +.timeSlider__popoverOverride { + width: 100%; + max-width: 100%; + height: 100%; +} + +.timeSlider__panelOverride { + min-width: $euiSizeXXL * 15; +} + +.timeSlider__anchor { + text-decoration: none; + width: 100%; + background-color: $euiFormBackgroundColor; + box-shadow: none; + @include euiFormControlSideBorderRadius($euiFormControlBorderRadius, $side: 'right', $internal: true); + overflow: hidden; + height: 100%; + + &:enabled:focus { + background-color: $euiFormBackgroundColor; + } + + .euiText { + background-color: $euiFormBackgroundColor; + } + + .timeSlider__anchorText { + font-weight: $euiFontWeightBold; + } + + .timeSlider__anchorText--default { + color: $euiColorMediumShade; + } + + .timeSlider__anchorText--invalid { + text-decoration: line-through; + color: $euiColorMediumShade; + } +} \ No newline at end of file diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider.component.tsx b/src/plugins/controls/public/control_types/time_slider/time_slider.component.tsx new file mode 100644 index 0000000000000..9ce7cf825e863 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider.component.tsx @@ -0,0 +1,336 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React, { FC, useState, useMemo, useCallback } from 'react'; +import { isNil } from 'lodash'; +import { + EuiText, + EuiLoadingSpinner, + EuiInputPopover, + EuiPopoverTitle, + EuiSpacer, + EuiFlexItem, + EuiFlexGroup, + EuiToolTip, + EuiButtonIcon, +} from '@elastic/eui'; +import { EuiRangeTick } from '@elastic/eui/src/components/form/range/range_ticks'; +import moment from 'moment-timezone'; +import { calcAutoIntervalNear } from '../../../../data/common'; +import { ValidatedDualRange } from '../../../../kibana_react/public'; +import { TimeSliderStrings } from './time_slider_strings'; +import './time_slider.component.scss'; + +function getScaledDateFormat(interval: number): string { + if (interval >= moment.duration(1, 'y').asMilliseconds()) { + return 'YYYY'; + } + + if (interval >= moment.duration(1, 'd').asMilliseconds()) { + return 'MMM D'; + } + + if (interval >= moment.duration(6, 'h').asMilliseconds()) { + return 'Do HH'; + } + + if (interval >= moment.duration(1, 'h').asMilliseconds()) { + return 'HH:mm'; + } + + if (interval >= moment.duration(1, 'm').asMilliseconds()) { + return 'HH:mm'; + } + + if (interval >= moment.duration(1, 's').asMilliseconds()) { + return 'mm:ss'; + } + + return 'ss.SSS'; +} + +export function getInterval(min: number, max: number, steps = 6): number { + const duration = max - min; + let interval = calcAutoIntervalNear(steps, duration).asMilliseconds(); + // Sometimes auto interval is not quite right and returns 2X or 3X requested ticks + // Adjust the interval to get closer to the requested number of ticks + const actualSteps = duration / interval; + if (actualSteps > steps * 1.5) { + const factor = Math.round(actualSteps / steps); + interval *= factor; + } else if (actualSteps < 5) { + interval *= 0.5; + } + return interval; +} + +export interface TimeSliderProps { + range?: [number | undefined, number | undefined]; + value: [number | null, number | null]; + onChange: (range: [number | null, number | null]) => void; + dateFormat?: string; + timezone?: string; + fieldName: string; + ignoreValidation?: boolean; +} + +const isValidRange = (maybeRange: TimeSliderProps['range']): maybeRange is [number, number] => { + return maybeRange !== undefined && !isNil(maybeRange[0]) && !isNil(maybeRange[1]); +}; + +const unselectedClass = 'timeSlider__anchorText--default'; +const validClass = 'timeSlider__anchorText'; +const invalidClass = 'timeSlider__anchorText--invalid'; + +export const TimeSlider: FC = (props) => { + const defaultProps = { + dateFormat: 'MMM D, YYYY @ HH:mm:ss.SSS', + ignoreValidation: false, + timezone: 'Browser', + ...props, + }; + const { range, value, timezone, dateFormat, fieldName, ignoreValidation } = defaultProps; + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + const togglePopover = useCallback(() => { + setIsPopoverOpen(!isPopoverOpen); + }, [isPopoverOpen, setIsPopoverOpen]); + + const getTimezone = useCallback(() => { + const detectedTimezone = moment.tz.guess(); + + return timezone === 'Browser' ? detectedTimezone : timezone; + }, [timezone]); + + const epochToKbnDateFormat = useCallback( + (epoch: number) => { + const tz = getTimezone(); + return moment.tz(epoch, tz).format(dateFormat); + }, + [dateFormat, getTimezone] + ); + + // If we don't have a range or we have is loading, show the loading state + const hasRange = range !== undefined; + + // We have values if we have a range or value entry for both position + const hasValues = + (value[0] !== null || (hasRange && range[0] !== undefined)) && + (value[1] !== null || (hasRange && range[1] !== undefined)); + + let valueText: JSX.Element | null = null; + if (hasValues) { + let lower = value[0] !== null ? value[0] : range![0]!; + let upper = value[1] !== null ? value[1] : range![1]!; + + if (value[0] !== null && lower > upper) { + upper = lower; + } else if (value[1] !== null && lower > upper) { + lower = upper; + } + + const hasLowerValueInRange = + value[0] !== null && isValidRange(range) && value[0] >= range[0] && value[0] <= range[1]; + // It's out of range if the upper value is above the upper range or below the lower range + const hasUpperValueInRange = + value[1] !== null && isValidRange(range) && value[1] <= range[1] && value[1] >= range[0]; + + let lowClass = unselectedClass; + let highClass = unselectedClass; + if (value[0] !== null && (hasLowerValueInRange || ignoreValidation)) { + lowClass = validClass; + } else if (value[0] !== null) { + lowClass = invalidClass; + } + + if (value[1] !== null && (hasUpperValueInRange || ignoreValidation)) { + highClass = validClass; + } else if (value[1] !== null) { + highClass = invalidClass; + } + + // if no value then anchorText default + // if hasLowerValueInRange || skipValidation then anchor text + // else strikethrough + + valueText = ( + + {epochToKbnDateFormat(lower)} +   →   + {epochToKbnDateFormat(upper)} + + ); + } + + const button = ( + + ); + + return ( + setIsPopoverOpen(false)} + panelPaddingSize="s" + anchorPosition="downCenter" + disableFocusTrap + repositionOnScroll + > + {isValidRange(range) ? ( + + ) : ( + + )} + + ); +}; + +const TimeSliderComponentPopoverNoDocuments: FC = () => { + return {TimeSliderStrings.noDocumentsPopover.getLabel()}; +}; + +export const TimeSliderComponentPopover: FC< + TimeSliderProps & { + range: [number, number]; + getTimezone: () => string; + epochToKbnDateFormat: (epoch: number) => string; + } +> = ({ range, value, onChange, getTimezone, epochToKbnDateFormat, fieldName }) => { + const [lowerBound, upperBound] = range; + let [lowerValue, upperValue] = value; + + if (lowerValue === null) { + lowerValue = lowerBound; + } + + if (upperValue === null) { + upperValue = upperBound; + } + + const fullRange = useMemo( + () => [Math.min(lowerValue!, lowerBound), Math.max(upperValue!, upperBound)], + [lowerValue, lowerBound, upperValue, upperBound] + ); + + const getTicks = useCallback( + (min: number, max: number, interval: number): EuiRangeTick[] => { + const format = getScaledDateFormat(interval); + const tz = getTimezone(); + + let tick = Math.ceil(min / interval) * interval; + const ticks: EuiRangeTick[] = []; + while (tick < max) { + ticks.push({ + value: tick, + label: moment.tz(tick, tz).format(format), + }); + tick += interval; + } + + return ticks; + }, + [getTimezone] + ); + + const ticks = useMemo(() => { + const interval = getInterval(fullRange[0], fullRange[1]); + return getTicks(fullRange[0], fullRange[1], interval); + }, [fullRange, getTicks]); + + const onChangeHandler = useCallback( + ([_min, _max]: [number | string, number | string]) => { + // If a value is undefined and the number that is given here matches the range bounds + // then we will ignore it, becuase they probably didn't actually select that value + const report: [number | null, number | null] = [null, null]; + + let min: number; + let max: number; + if (typeof _min === 'string') { + min = parseFloat(_min); + min = isNaN(min) ? range[0] : min; + } else { + min = _min; + } + + if (typeof _max === 'string') { + max = parseFloat(_max); + max = isNaN(max) ? range[0] : max; + } else { + max = _max; + } + + if (value[0] !== null || min !== range[0]) { + report[0] = min; + } + if (value[1] !== null || max !== range[1]) { + report[1] = max; + } + + onChange(report); + }, + [onChange, value, range] + ); + + const levels = [{ min: range[0], max: range[1], color: 'success' }]; + + return ( + <> + {fieldName} + + {epochToKbnDateFormat(lowerValue)} - {epochToKbnDateFormat(upperValue)} + + + + + + + + + onChange([null, null])} + aria-label={TimeSliderStrings.resetButton.getLabel()} + data-test-subj="timeSlider__clearRangeButton" + /> + + + + + + ); +}; diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider.tsx b/src/plugins/controls/public/control_types/time_slider/time_slider.tsx new file mode 100644 index 0000000000000..d2198416fdc42 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider.tsx @@ -0,0 +1,94 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React, { FC, useCallback, useState, useMemo } from 'react'; +import { BehaviorSubject } from 'rxjs'; +import { debounce } from 'lodash'; +import { useStateObservable } from '../../hooks/use_state_observable'; +import { useReduxEmbeddableContext } from '../../../../presentation_util/public'; +import { TimeSliderControlEmbeddableInput } from '../../../common/control_types/time_slider/types'; +import { timeSliderReducers } from './time_slider_reducers'; +import { TimeSlider as Component } from './time_slider.component'; + +export interface TimeSliderSubjectState { + range?: { + min?: number; + max?: number; + }; + loading: boolean; +} + +interface TimeSliderProps { + componentStateSubject: BehaviorSubject; + dateFormat: string; + timezone: string; + fieldName: string; + ignoreValidation: boolean; +} + +export const TimeSlider: FC = ({ + componentStateSubject, + dateFormat, + timezone, + fieldName, + ignoreValidation, +}) => { + const { + useEmbeddableDispatch, + useEmbeddableSelector, + actions: { selectRange }, + } = useReduxEmbeddableContext(); + const dispatch = useEmbeddableDispatch(); + + const { range: availableRange } = useStateObservable( + componentStateSubject, + componentStateSubject.getValue() + ); + + const { min, max } = availableRange + ? availableRange + : ({} as { + min?: number; + max?: number; + }); + + const { value } = useEmbeddableSelector((state) => state); + + const [selectedValue, setSelectedValue] = useState<[number | null, number | null]>( + value || [null, null] + ); + + const dispatchChange = useCallback( + (range: [number | null, number | null]) => { + dispatch(selectRange(range)); + }, + [dispatch, selectRange] + ); + + const debouncedDispatchChange = useMemo(() => debounce(dispatchChange, 500), [dispatchChange]); + + const onChangeComplete = useCallback( + (range: [number | null, number | null]) => { + debouncedDispatchChange(range); + setSelectedValue(range); + }, + [setSelectedValue, debouncedDispatchChange] + ); + + return ( + + ); +}; diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider_editor.tsx b/src/plugins/controls/public/control_types/time_slider/time_slider_editor.tsx new file mode 100644 index 0000000000000..8e5f107df8201 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider_editor.tsx @@ -0,0 +1,103 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import useMount from 'react-use/lib/useMount'; +import React, { useEffect, useState } from 'react'; +import { EuiFormRow } from '@elastic/eui'; + +import { pluginServices } from '../../services'; +import { ControlEditorProps } from '../../types'; +import { DataViewListItem, DataView } from '../../../../data_views/common'; +import { + LazyDataViewPicker, + LazyFieldPicker, + withSuspense, +} from '../../../../presentation_util/public'; +import { TimeSliderStrings } from './time_slider_strings'; + +interface TimeSliderEditorState { + dataViewListItems: DataViewListItem[]; + dataView?: DataView; + fieldName?: string; +} + +const FieldPicker = withSuspense(LazyFieldPicker, null); +const DataViewPicker = withSuspense(LazyDataViewPicker, null); + +export const TimeSliderEditor = ({ + onChange, + initialInput, + setValidState, + setDefaultTitle, +}: ControlEditorProps) => { + // Controls Services Context + const { dataViews } = pluginServices.getHooks(); + const { getIdsWithTitle, getDefaultId, get } = dataViews.useService(); + + const [state, setState] = useState({ + fieldName: initialInput?.fieldName, + dataViewListItems: [], + }); + + useMount(() => { + let mounted = true; + if (state.fieldName) setDefaultTitle(state.fieldName); + (async () => { + const dataViewListItems = await getIdsWithTitle(); + const initialId = initialInput?.dataViewId ?? (await getDefaultId()); + let dataView: DataView | undefined; + if (initialId) { + onChange({ dataViewId: initialId }); + dataView = await get(initialId); + } + if (!mounted) return; + setState((s) => ({ ...s, dataView, dataViewListItems })); + })(); + return () => { + mounted = false; + }; + }); + + useEffect( + () => setValidState(Boolean(state.fieldName) && Boolean(state.dataView)), + [state.fieldName, setValidState, state.dataView] + ); + + const { dataView, fieldName } = state; + return ( + <> + + { + onChange({ dataViewId }); + get(dataViewId).then((newDataView) => + setState((s) => ({ ...s, dataView: newDataView })) + ); + }} + trigger={{ + label: state.dataView?.title ?? TimeSliderStrings.editor.getNoDataViewTitle(), + }} + /> + + + field.type === 'date'} + selectedFieldName={fieldName} + dataView={dataView} + onSelectField={(field) => { + setDefaultTitle(field.displayName ?? field.name); + onChange({ fieldName: field.name }); + setState((s) => ({ ...s, fieldName: field.name })); + }} + /> + + + ); +}; diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.test.ts b/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.test.ts new file mode 100644 index 0000000000000..c4a42e6b03e2c --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.test.ts @@ -0,0 +1,287 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { of } from 'rxjs'; +import { delay, map } from 'rxjs/operators'; +import { TimeSliderControlEmbeddableInput } from '.'; +import { TimeSliderControlEmbeddable } from './time_slider_embeddable'; +import { stubLogstashDataView } from '../../../../data_views/common/data_view.stub'; +import { pluginServices } from '../../services'; +import { TestScheduler } from 'rxjs/testing'; +import { buildRangeFilter } from '@kbn/es-query'; + +const buildFilter = (range: [number | null, number | null]) => { + const filterPieces: Record = {}; + if (range[0] !== null) { + filterPieces.gte = range[0]; + } + if (range[1] !== null) { + filterPieces.lte = range[1]; + } + + const filter = buildRangeFilter( + stubLogstashDataView.getFieldByName('bytes')!, + filterPieces, + stubLogstashDataView + ); + filter.meta.key = 'bytes'; + + return filter; +}; + +const rangeMin = 20; +const rangeMax = 30; +const range = { min: rangeMin, max: rangeMax }; + +const lowerValue: [number, number] = [15, 25]; +const upperValue: [number, number] = [25, 35]; +const partialLowValue: [number, null] = [25, null]; +const partialHighValue: [null, number] = [null, 25]; +const withinRangeValue: [number, number] = [21, 29]; +const outOfRangeValue: [number, number] = [31, 40]; + +const rangeFilter = buildFilter([rangeMin, rangeMax]); +const lowerValueFilter = buildFilter(lowerValue); +const lowerValuePartialFilter = buildFilter([20, 25]); +const upperValueFilter = buildFilter(upperValue); +const upperValuePartialFilter = buildFilter([25, 30]); + +const partialLowValueFilter = buildFilter(partialLowValue); +const partialHighValueFilter = buildFilter(partialHighValue); +const withinRangeValueFilter = buildFilter(withinRangeValue); +const outOfRangeValueFilter = buildFilter(outOfRangeValue); + +const baseInput: TimeSliderControlEmbeddableInput = { + id: 'id', + fieldName: 'bytes', + dataViewId: stubLogstashDataView.id!, +}; + +describe('Time Slider Control Embeddable', () => { + const services = pluginServices.getServices(); + const fetchRange = jest.spyOn(services.data, 'fetchFieldRange'); + const getDataView = jest.spyOn(services.data, 'getDataView'); + const fetchRange$ = jest.spyOn(services.data, 'fetchFieldRange$'); + const getDataView$ = jest.spyOn(services.data, 'getDataView$'); + + beforeEach(() => { + jest.resetAllMocks(); + + fetchRange.mockResolvedValue(range); + fetchRange$.mockReturnValue(of(range).pipe(delay(100))); + getDataView.mockResolvedValue(stubLogstashDataView); + getDataView$.mockReturnValue(of(stubLogstashDataView)); + }); + + describe('outputting filters', () => { + let testScheduler: TestScheduler; + beforeEach(() => { + testScheduler = new TestScheduler((actual, expected) => { + expect(actual).toEqual(expected); + }); + }); + + const testFilterOutput = ( + input: any, + expectedFilterAfterRangeFetch: any, + mockRange: { min?: number; max?: number } = range + ) => { + testScheduler.run(({ expectObservable, cold }) => { + fetchRange$.mockReturnValue(cold('--b', { b: mockRange })); + const expectedMarbles = 'a-b'; + const expectedValues = { + a: undefined, + b: expectedFilterAfterRangeFetch ? [expectedFilterAfterRangeFetch] : undefined, + }; + + const embeddable = new TimeSliderControlEmbeddable(input, {}); + const source$ = embeddable.getOutput$().pipe(map((o) => o.filters)); + + expectObservable(source$).toBe(expectedMarbles, expectedValues); + }); + }; + + it('outputs no filter when no value is given', () => { + testFilterOutput(baseInput, undefined); + }); + + it('outputs the value filter after the range is fetched', () => { + testFilterOutput({ ...baseInput, value: withinRangeValue }, withinRangeValueFilter); + }); + + it('outputs a partial filter for a low partial value', () => { + testFilterOutput({ ...baseInput, value: partialLowValue }, partialLowValueFilter); + }); + + it('outputs a partial filter for a high partial value', () => { + testFilterOutput({ ...baseInput, value: partialHighValue }, partialHighValueFilter); + }); + + describe('with validation', () => { + it('outputs a partial value filter if value is below range', () => { + testFilterOutput({ ...baseInput, value: lowerValue }, lowerValuePartialFilter); + }); + + it('outputs a partial value filter if value is above range', () => { + testFilterOutput({ ...baseInput, value: upperValue }, upperValuePartialFilter); + }); + + it('outputs range filter value if value is completely out of range', () => { + testFilterOutput({ ...baseInput, value: outOfRangeValue }, rangeFilter); + }); + + it('outputs no filter when no range available', () => { + testFilterOutput({ ...baseInput, value: withinRangeValue }, undefined, {}); + }); + }); + + describe('with validation off', () => { + it('outputs the lower value filter', () => { + testFilterOutput( + { ...baseInput, ignoreParentSettings: { ignoreValidations: true }, value: lowerValue }, + lowerValueFilter + ); + }); + + it('outputs the uppwer value filter', () => { + testFilterOutput( + { ...baseInput, ignoreParentSettings: { ignoreValidations: true }, value: upperValue }, + upperValueFilter + ); + }); + + it('outputs the out of range filter', () => { + testFilterOutput( + { + ...baseInput, + ignoreParentSettings: { ignoreValidations: true }, + value: outOfRangeValue, + }, + outOfRangeValueFilter + ); + }); + + it('outputs the value filter when no range found', () => { + testFilterOutput( + { + ...baseInput, + ignoreParentSettings: { ignoreValidations: true }, + value: withinRangeValue, + }, + withinRangeValueFilter, + { min: undefined, max: undefined } + ); + }); + }); + }); + + describe('fetching range', () => { + it('fetches range on init', () => { + const testScheduler = new TestScheduler((actual, expected) => { + expect(actual).toEqual(expected); + }); + + testScheduler.run(({ cold, expectObservable }) => { + const mockRange = { min: 1, max: 2 }; + fetchRange$.mockReturnValue(cold('--b', { b: mockRange })); + + const expectedMarbles = 'a-b'; + const expectedValues = { + a: undefined, + b: mockRange, + }; + + const embeddable = new TimeSliderControlEmbeddable(baseInput, {}); + const source$ = embeddable.getComponentState$().pipe(map((state) => state.range)); + + const { fieldName, ...inputForFetch } = baseInput; + + expectObservable(source$).toBe(expectedMarbles, expectedValues); + expect(fetchRange$).toBeCalledWith(stubLogstashDataView, fieldName, { + ...inputForFetch, + filters: undefined, + query: undefined, + timeRange: undefined, + viewMode: 'edit', + }); + }); + }); + + it('fetches range on input change', () => { + const testScheduler = new TestScheduler((actual, expected) => { + expect(actual).toEqual(expected); + }); + + testScheduler.run(({ cold, expectObservable, flush }) => { + const mockRange = { min: 1, max: 2 }; + fetchRange$.mockReturnValue(cold('a', { a: mockRange })); + + const embeddable = new TimeSliderControlEmbeddable(baseInput, {}); + const updatedInput = { ...baseInput, fieldName: '@timestamp' }; + + embeddable.updateInput(updatedInput); + + expect(fetchRange$).toBeCalledTimes(2); + expect(fetchRange$.mock.calls[1][1]).toBe(updatedInput.fieldName); + }); + }); + + it('passes input to fetch range to build the query', () => { + const testScheduler = new TestScheduler((actual, expected) => { + expect(actual).toEqual(expected); + }); + + testScheduler.run(({ cold, expectObservable, flush }) => { + const mockRange = { min: 1, max: 2 }; + fetchRange$.mockReturnValue(cold('a', { a: mockRange })); + + const input = { + ...baseInput, + query: {} as any, + filters: {} as any, + timeRange: {} as any, + }; + + new TimeSliderControlEmbeddable(input, {}); + + expect(fetchRange$).toBeCalledTimes(1); + const args = fetchRange$.mock.calls[0][2]; + expect(args.query).toBe(input.query); + expect(args.filters).toBe(input.filters); + expect(args.timeRange).toBe(input.timeRange); + }); + }); + + it('does not pass ignored parent settings', () => { + const testScheduler = new TestScheduler((actual, expected) => { + expect(actual).toEqual(expected); + }); + + testScheduler.run(({ cold, expectObservable, flush }) => { + const mockRange = { min: 1, max: 2 }; + fetchRange$.mockReturnValue(cold('a', { a: mockRange })); + + const input = { + ...baseInput, + query: '' as any, + filters: {} as any, + timeRange: {} as any, + ignoreParentSettings: { ignoreFilters: true, ignoreQuery: true, ignoreTimerange: true }, + }; + + new TimeSliderControlEmbeddable(input, {}); + + expect(fetchRange$).toBeCalledTimes(1); + const args = fetchRange$.mock.calls[0][2]; + expect(args.query).not.toBe(input.query); + expect(args.filters).not.toBe(input.filters); + expect(args.timeRange).not.toBe(input.timeRange); + }); + }); + }); +}); diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.tsx b/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.tsx new file mode 100644 index 0000000000000..d6507c10b2d6f --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable.tsx @@ -0,0 +1,321 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { compareFilters, buildRangeFilter, RangeFilterParams } from '@kbn/es-query'; +import React from 'react'; +import ReactDOM from 'react-dom'; +import { isEqual } from 'lodash'; +import deepEqual from 'fast-deep-equal'; +import { merge, Subscription, BehaviorSubject, Observable } from 'rxjs'; +import { map, distinctUntilChanged, skip, take, mergeMap } from 'rxjs/operators'; + +import { TimeSliderControlEmbeddableInput } from '../../../common/control_types/time_slider/types'; + +import { + withSuspense, + LazyReduxEmbeddableWrapper, + ReduxEmbeddableWrapperPropsWithChildren, +} from '../../../../presentation_util/public'; + +import { TIME_SLIDER_CONTROL } from '../../'; +import { ControlsSettingsService } from '../../services/settings'; +import { Embeddable, IContainer } from '../../../../embeddable/public'; +import { ControlsDataService } from '../../services/data'; +import { DataView } from '../../../../data_views/public'; +import { ControlOutput } from '../..'; +import { pluginServices } from '../../services'; + +import { TimeSlider as TimeSliderComponent, TimeSliderSubjectState } from './time_slider'; +import { timeSliderReducers } from './time_slider_reducers'; + +const TimeSliderControlReduxWrapper = withSuspense< + ReduxEmbeddableWrapperPropsWithChildren +>(LazyReduxEmbeddableWrapper); + +const diffDataFetchProps = (current?: any, last?: any) => { + if (!current || !last) return false; + const { filters: currentFilters, ...currentWithoutFilters } = current; + const { filters: lastFilters, ...lastWithoutFilters } = last; + if (!deepEqual(currentWithoutFilters, lastWithoutFilters)) return false; + if (!compareFilters(lastFilters ?? [], currentFilters ?? [])) return false; + return true; +}; + +export class TimeSliderControlEmbeddable extends Embeddable< + TimeSliderControlEmbeddableInput, + ControlOutput +> { + public readonly type = TIME_SLIDER_CONTROL; + public deferEmbeddableLoad = true; + + private subscriptions: Subscription = new Subscription(); + private node?: HTMLElement; + + // Internal data fetching state for this input control. + private dataView?: DataView; + + private componentState: TimeSliderSubjectState; + private componentStateSubject$ = new BehaviorSubject({ + range: undefined, + loading: false, + }); + + // Internal state subject will let us batch updates to the externally accessible state subject + private internalComponentStateSubject$ = new BehaviorSubject({ + range: undefined, + loading: false, + }); + + private internalOutput: ControlOutput; + + private fetchRange$: ControlsDataService['fetchFieldRange$']; + private getDataView$: ControlsDataService['getDataView$']; + private getDateFormat: ControlsSettingsService['getDateFormat']; + private getTimezone: ControlsSettingsService['getTimezone']; + + constructor(input: TimeSliderControlEmbeddableInput, output: ControlOutput, parent?: IContainer) { + super(input, output, parent); // get filters for initial output... + + const { + data: { fetchFieldRange$, getDataView$ }, + settings: { getDateFormat, getTimezone }, + } = pluginServices.getServices(); + this.fetchRange$ = fetchFieldRange$; + this.getDataView$ = getDataView$; + this.getDateFormat = getDateFormat; + this.getTimezone = getTimezone; + + this.componentState = { loading: true }; + this.updateComponentState(this.componentState, true); + + this.internalOutput = {}; + + this.initialize(); + } + + private initialize() { + // If value is undefined, then we can be finished with initialization because we're not going to output a filter + if (this.getInput().value === undefined) { + this.setInitializationFinished(); + } + + this.setupSubscriptions(); + } + + private setupSubscriptions() { + // We need to fetch data when any of these values change + const dataFetchPipe = this.getInput$().pipe( + map((newInput) => ({ + lastReloadRequestTime: newInput.lastReloadRequestTime, + dataViewId: newInput.dataViewId, + fieldName: newInput.fieldName, + timeRange: newInput.timeRange, + filters: newInput.filters, + query: newInput.query, + })), + distinctUntilChanged(diffDataFetchProps) + ); + + // When data fetch pipe emits, we start the fetch + this.subscriptions.add(dataFetchPipe.subscribe(this.fetchAvailableTimerange)); + + const availableRangePipe = this.internalComponentStateSubject$.pipe( + map((state) => (state.range ? { min: state.range.min, max: state.range.max } : {})), + distinctUntilChanged((a, b) => isEqual(a, b)) + ); + + this.subscriptions.add( + merge( + this.getInput$().pipe( + skip(1), // Skip the first input value + distinctUntilChanged((a, b) => isEqual(a.value, b.value)) + ), + availableRangePipe.pipe(skip(1)) + ).subscribe(() => { + this.setInitializationFinished(); + this.buildFilter(); + + this.componentStateSubject$.next(this.componentState); + }) + ); + } + + private buildFilter = () => { + const { fieldName, value, ignoreParentSettings } = this.getInput(); + + const min = value ? value[0] : null; + const max = value ? value[1] : null; + const hasRange = + this.componentState.range!.max !== undefined && this.componentState.range!.min !== undefined; + + this.getCurrentDataView$().subscribe((dataView) => { + const range: RangeFilterParams = {}; + let filterMin: number | undefined; + let filterMax: number | undefined; + const field = dataView.getFieldByName(fieldName); + + if (ignoreParentSettings?.ignoreValidations) { + if (min !== null) { + range.gte = min; + } + + if (max !== null) { + range.lte = max; + } + } else { + // If we have a value or a range use the min/max of those, otherwise undefined + if (min !== null && this.componentState.range!.min !== undefined) { + filterMin = Math.max(min || 0, this.componentState.range!.min || 0); + } + + if (max !== null && this.componentState.range!.max) { + filterMax = Math.min( + max || Number.MAX_SAFE_INTEGER, + this.componentState.range!.max || Number.MAX_SAFE_INTEGER + ); + } + + // Last check, if the value is completely outside the range then we will just default to the range + if ( + hasRange && + ((min !== null && min > this.componentState.range!.max!) || + (max !== null && max < this.componentState.range!.min!)) + ) { + filterMin = this.componentState.range!.min; + filterMax = this.componentState.range!.max; + } + + if (hasRange && filterMin !== undefined) { + range.gte = filterMin; + } + if (hasRange && filterMax !== undefined) { + range.lte = filterMax; + } + } + + if (range.lte !== undefined || range.gte !== undefined) { + const rangeFilter = buildRangeFilter(field!, range, dataView); + rangeFilter.meta.key = field?.name; + + this.updateInternalOutput({ filters: [rangeFilter] }, true); + this.updateComponentState({ loading: false }); + } else { + this.updateInternalOutput({ filters: undefined, dataViews: [dataView] }, true); + this.updateComponentState({ loading: false }); + } + }); + }; + + private updateComponentState(changes: Partial, publish = false) { + this.componentState = { + ...this.componentState, + ...changes, + }; + + this.internalComponentStateSubject$.next(this.componentState); + + if (publish) { + this.componentStateSubject$.next(this.componentState); + } + } + + private updateInternalOutput(changes: Partial, publish = false) { + this.internalOutput = { + ...this.internalOutput, + ...changes, + }; + + if (publish) { + this.updateOutput(this.internalOutput); + } + } + + private getCurrentDataView$ = () => { + const { dataViewId } = this.getInput(); + if (this.dataView && this.dataView.id === dataViewId) + return new Observable((subscriber) => { + subscriber.next(this.dataView); + subscriber.complete(); + }); + + return this.getDataView$(dataViewId); + }; + + private fetchAvailableTimerange = () => { + this.updateComponentState({ loading: true }, true); + this.updateInternalOutput({ loading: true }, true); + + const { fieldName, ignoreParentSettings, query, filters, timeRange, ...input } = + this.getInput(); + + const inputForFetch = { + ...input, + ...(ignoreParentSettings?.ignoreQuery ? {} : { query }), + ...(ignoreParentSettings?.ignoreFilters ? {} : { filters }), + ...(ignoreParentSettings?.ignoreTimerange ? {} : { timeRange }), + }; + + try { + this.getCurrentDataView$() + .pipe( + mergeMap((dataView) => this.fetchRange$(dataView, fieldName, inputForFetch)), + take(1) + ) + .subscribe(({ min, max }) => { + this.updateInternalOutput({ loading: false }); + this.updateComponentState({ + range: { + min: min === null ? undefined : min, + max: max === null ? undefined : max, + }, + loading: false, + }); + }); + } catch (e) { + this.updateComponentState({ loading: false }, true); + this.updateInternalOutput({ loading: false }, true); + } + }; + + public getComponentState$ = () => { + return this.componentStateSubject$; + }; + + public destroy = () => { + super.destroy(); + this.subscriptions.unsubscribe(); + }; + + public reload = () => { + this.fetchAvailableTimerange(); + }; + + public render = (node: HTMLElement) => { + if (this.node) { + ReactDOM.unmountComponentAtNode(this.node); + } + this.node = node; + + ReactDOM.render( + + + , + node + ); + }; +} diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable_factory.tsx b/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable_factory.tsx new file mode 100644 index 0000000000000..d1bd1508a45cb --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider_embeddable_factory.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import deepEqual from 'fast-deep-equal'; + +import { TIME_SLIDER_CONTROL } from '../../'; +import { ControlEmbeddable, IEditableControlFactory } from '../../types'; +import { EmbeddableFactoryDefinition, IContainer } from '../../../../embeddable/public'; +import { + createOptionsListExtract, + createOptionsListInject, +} from '../../../common/control_types/options_list/options_list_persistable_state'; +import { TimeSliderEditor } from './time_slider_editor'; +import { TimeSliderControlEmbeddableInput } from '../../../common/control_types/time_slider/types'; +import { TimeSliderStrings } from './time_slider_strings'; + +export class TimesliderEmbeddableFactory + implements EmbeddableFactoryDefinition, IEditableControlFactory +{ + public type = TIME_SLIDER_CONTROL; + public canCreateNew = () => false; + + constructor() {} + + public async create(initialInput: TimeSliderControlEmbeddableInput, parent?: IContainer) { + const { TimeSliderControlEmbeddable } = await import('./time_slider_embeddable'); + + return Promise.resolve(new TimeSliderControlEmbeddable(initialInput, {}, parent)); + } + + public presaveTransformFunction = ( + newInput: Partial, + embeddable?: ControlEmbeddable + ) => { + if ( + embeddable && + (!deepEqual(newInput.fieldName, embeddable.getInput().fieldName) || + !deepEqual(newInput.dataViewId, embeddable.getInput().dataViewId)) + ) { + // if the field name or data view id has changed in this editing session, selected options are invalid, so reset them. + newInput.value = undefined; + } + return newInput; + }; + + public controlEditorComponent = TimeSliderEditor; + + public isEditable = () => Promise.resolve(false); + + public getDisplayName = () => TimeSliderStrings.getDisplayName(); + public getDescription = () => TimeSliderStrings.getDescription(); + + public inject = createOptionsListInject(); + public extract = createOptionsListExtract(); +} diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider_reducers.ts b/src/plugins/controls/public/control_types/time_slider/time_slider_reducers.ts new file mode 100644 index 0000000000000..d4cb8aba8f510 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider_reducers.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { PayloadAction } from '@reduxjs/toolkit'; +import { WritableDraft } from 'immer/dist/types/types-external'; + +import { TimeSliderControlEmbeddableInput } from '../../../common/control_types/time_slider/types'; + +export const timeSliderReducers = { + selectRange: ( + state: WritableDraft, + action: PayloadAction<[number | null, number | null]> + ) => { + state.value = action.payload; + }, +}; diff --git a/src/plugins/controls/public/control_types/time_slider/time_slider_strings.ts b/src/plugins/controls/public/control_types/time_slider/time_slider_strings.ts new file mode 100644 index 0000000000000..2c61d7d43a797 --- /dev/null +++ b/src/plugins/controls/public/control_types/time_slider/time_slider_strings.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { i18n } from '@kbn/i18n'; + +export const TimeSliderStrings = { + getDisplayName: () => + i18n.translate('controls.timeSlider.displayName', { + defaultMessage: 'Time slider', + }), + getDescription: () => + i18n.translate('controls.timeSlider.description', { + defaultMessage: 'Add a slider for selecting a time range', + }), + editor: { + getDataViewTitle: () => + i18n.translate('controls.timeSlider.editor.dataViewTitle', { + defaultMessage: 'Data view', + }), + getNoDataViewTitle: () => + i18n.translate('controls.timeSlider.editor.noDataViewTitle', { + defaultMessage: 'Select data view', + }), + getFieldTitle: () => + i18n.translate('controls.timeSlider.editor.fieldTitle', { + defaultMessage: 'Field', + }), + }, + resetButton: { + getLabel: () => + i18n.translate('controls.timeSlider.resetButton.label', { + defaultMessage: 'Reset selections', + }), + }, + noDocumentsPopover: { + getLabel: () => + i18n.translate('controls.timeSlider.noDocuments.label', { + defaultMessage: 'There were no documents found. Range selection unavailable.', + }), + }, +}; diff --git a/src/plugins/controls/public/index.ts b/src/plugins/controls/public/index.ts index db4586b315075..5cc7ffce2c328 100644 --- a/src/plugins/controls/public/index.ts +++ b/src/plugins/controls/public/index.ts @@ -24,7 +24,12 @@ export type { ControlInput, } from '../common/types'; -export { CONTROL_GROUP_TYPE, OPTIONS_LIST_CONTROL, RANGE_SLIDER_CONTROL } from '../common'; +export { + CONTROL_GROUP_TYPE, + OPTIONS_LIST_CONTROL, + RANGE_SLIDER_CONTROL, + TIME_SLIDER_CONTROL, +} from '../common'; export { ControlGroupContainer, diff --git a/src/plugins/controls/public/plugin.ts b/src/plugins/controls/public/plugin.ts index 96cb7eeef3a27..b583f14d94ddd 100644 --- a/src/plugins/controls/public/plugin.ts +++ b/src/plugins/controls/public/plugin.ts @@ -29,7 +29,12 @@ import { CONTROL_GROUP_TYPE, OPTIONS_LIST_CONTROL, RANGE_SLIDER_CONTROL, + TIME_SLIDER_CONTROL, } from '.'; +import { + TimesliderEmbeddableFactory, + TimeSliderControlEmbeddableInput, +} from './control_types/time_slider'; import { controlsService } from './services/kibana/controls'; import { EmbeddableFactory } from '../../embeddable/public'; @@ -97,6 +102,19 @@ export class ControlsPlugin rangeSliderFactory ); registerControlType(rangeSliderFactory); + + // Time Slider Control Factory Setup + const timeSliderFactoryDef = new TimesliderEmbeddableFactory(); + const timeSliderFactory = embeddable.registerEmbeddableFactory( + TIME_SLIDER_CONTROL, + timeSliderFactoryDef + )(); + this.transferEditorFunctions( + timeSliderFactoryDef, + timeSliderFactory + ); + + registerControlType(timeSliderFactory); }); return { diff --git a/src/plugins/controls/public/services/data.ts b/src/plugins/controls/public/services/data.ts index f11e451995535..57c2342beb425 100644 --- a/src/plugins/controls/public/services/data.ts +++ b/src/plugins/controls/public/services/data.ts @@ -6,9 +6,24 @@ * Side Public License, v 1. */ +import { Observable } from 'rxjs'; import { DataPublicPluginStart } from '../../../data/public'; +import { DataView } from '../../../data_views/public'; +import { ControlInput } from '../types'; export interface ControlsDataService { + fetchFieldRange: ( + dataView: DataView, + fieldName: string, + input: ControlInput + ) => Promise<{ min: number; max: number }>; + fetchFieldRange$: ( + dataView: DataView, + fieldName: string, + input: ControlInput + ) => Observable<{ min?: number; max?: number }>; + getDataView: DataPublicPluginStart['dataViews']['get']; + getDataView$: (id: string) => Observable; autocomplete: DataPublicPluginStart['autocomplete']; query: DataPublicPluginStart['query']; searchSource: DataPublicPluginStart['search']['searchSource']; diff --git a/src/plugins/controls/public/services/index.ts b/src/plugins/controls/public/services/index.ts index d1dcd9b158a0a..1a8c8b0c4bdfe 100644 --- a/src/plugins/controls/public/services/index.ts +++ b/src/plugins/controls/public/services/index.ts @@ -15,6 +15,7 @@ import { ControlsDataService } from './data'; import { ControlsService } from './controls'; import { ControlsHTTPService } from './http'; import { ControlsOptionsListService } from './options_list'; +import { ControlsSettingsService } from './settings'; export interface ControlsServices { // dependency services @@ -22,6 +23,7 @@ export interface ControlsServices { overlays: ControlsOverlaysService; data: ControlsDataService; http: ControlsHTTPService; + settings: ControlsSettingsService; // controls plugin's own services controls: ControlsService; diff --git a/src/plugins/controls/public/services/kibana/data.ts b/src/plugins/controls/public/services/kibana/data.ts index 0830233109e2a..9eb981d90c237 100644 --- a/src/plugins/controls/public/services/kibana/data.ts +++ b/src/plugins/controls/public/services/kibana/data.ts @@ -6,6 +6,9 @@ * Side Public License, v 1. */ +import { DataViewField } from 'src/plugins/data_views/common'; +import { get } from 'lodash'; +import { from } from 'rxjs'; import { ControlsDataService } from '../data'; import { ControlsPluginStartDeps } from '../../types'; import { KibanaPluginServiceFactory } from '../../../../presentation_util/public'; @@ -15,14 +18,86 @@ export type DataServiceFactory = KibanaPluginServiceFactory< ControlsPluginStartDeps >; +const minMaxAgg = (field?: DataViewField) => { + const aggBody: Record = {}; + if (field) { + if (field.scripted) { + aggBody.script = { + source: field.script, + lang: field.lang, + }; + } else { + aggBody.field = field.name; + } + } + + return { + maxAgg: { + max: aggBody, + }, + minAgg: { + min: aggBody, + }, + }; +}; + export const dataServiceFactory: DataServiceFactory = ({ startPlugins }) => { const { - data: { autocomplete, query, search }, + data: { query: queryPlugin, search, autocomplete }, } = startPlugins; + const { data } = startPlugins; + + const fetchFieldRange: ControlsDataService['fetchFieldRange'] = async ( + dataView, + fieldName, + input + ) => { + const { ignoreParentSettings, query, timeRange } = input; + let { filters = [] } = input; + + const field = dataView.getFieldByName(fieldName); + + if (!field) { + throw new Error('Field Missing Error'); + } + + if (timeRange) { + const timeFilter = data.query.timefilter.timefilter.createFilter(dataView, timeRange); + if (timeFilter) { + filters = filters.concat(timeFilter); + } + } + + const searchSource = await data.search.searchSource.create(); + searchSource.setField('size', 0); + searchSource.setField('index', dataView); + + const aggs = minMaxAgg(field); + searchSource.setField('aggs', aggs); + + searchSource.setField('filter', ignoreParentSettings?.ignoreFilters ? [] : filters); + searchSource.setField('query', ignoreParentSettings?.ignoreQuery ? undefined : query); + + const resp = await searchSource.fetch$().toPromise(); + + const min = get(resp, 'rawResponse.aggregations.minAgg.value', undefined); + const max = get(resp, 'rawResponse.aggregations.maxAgg.value', undefined); + + return { + min: min === null ? undefined : min, + max: max === null ? undefined : max, + }; + }; + return { + fetchFieldRange, + fetchFieldRange$: (dataView, fieldName, input) => + from(fetchFieldRange(dataView, fieldName, input)), + getDataView: data.dataViews.get, + getDataView$: (id: string) => from(data.dataViews.get(id)), autocomplete, - query, + query: queryPlugin, searchSource: search.searchSource, - timefilter: query.timefilter.timefilter, + timefilter: queryPlugin.timefilter.timefilter, }; }; diff --git a/src/plugins/controls/public/services/kibana/index.ts b/src/plugins/controls/public/services/kibana/index.ts index f87bd744b3541..19a2c0891ac8f 100644 --- a/src/plugins/controls/public/services/kibana/index.ts +++ b/src/plugins/controls/public/services/kibana/index.ts @@ -21,6 +21,7 @@ import { overlaysServiceFactory } from './overlays'; import { dataServiceFactory } from './data'; import { httpServiceFactory } from './http'; import { optionsListServiceFactory } from './options_list'; +import { settingsServiceFactory } from './settings'; export const providers: PluginServiceProviders< ControlsServices, @@ -30,6 +31,7 @@ export const providers: PluginServiceProviders< data: new PluginServiceProvider(dataServiceFactory), overlays: new PluginServiceProvider(overlaysServiceFactory), dataViews: new PluginServiceProvider(dataViewsServiceFactory), + settings: new PluginServiceProvider(settingsServiceFactory), optionsList: new PluginServiceProvider(optionsListServiceFactory, ['data', 'http']), controls: new PluginServiceProvider(controlsServiceFactory), diff --git a/src/plugins/controls/public/services/kibana/settings.ts b/src/plugins/controls/public/services/kibana/settings.ts new file mode 100644 index 0000000000000..27e308f19693b --- /dev/null +++ b/src/plugins/controls/public/services/kibana/settings.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { ControlsSettingsService } from '../settings'; +import { ControlsPluginStartDeps } from '../../types'; +import { KibanaPluginServiceFactory } from '../../../../presentation_util/public'; + +export type SettingsServiceFactory = KibanaPluginServiceFactory< + ControlsSettingsService, + ControlsPluginStartDeps +>; + +export const settingsServiceFactory: SettingsServiceFactory = ({ coreStart }) => { + return { + getDateFormat: () => { + return coreStart.uiSettings.get('dateFormat', 'MMM D, YYYY @ HH:mm:ss.SSS'); + }, + getTimezone: () => { + return coreStart.uiSettings.get('dateFormat:tz', 'Browser'); + }, + }; +}; diff --git a/src/plugins/controls/public/services/settings.ts b/src/plugins/controls/public/services/settings.ts new file mode 100644 index 0000000000000..476a99c5bd733 --- /dev/null +++ b/src/plugins/controls/public/services/settings.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +export interface ControlsSettingsService { + getTimezone: () => string; + getDateFormat: () => string; +} diff --git a/src/plugins/controls/public/services/storybook/data.ts b/src/plugins/controls/public/services/storybook/data.ts index bfdcf05767b01..3e63066d0d5ff 100644 --- a/src/plugins/controls/public/services/storybook/data.ts +++ b/src/plugins/controls/public/services/storybook/data.ts @@ -6,10 +6,10 @@ * Side Public License, v 1. */ -import { of } from 'rxjs'; +import { of, Observable } from 'rxjs'; import { PluginServiceFactory } from '../../../../presentation_util/public'; import { DataPublicPluginStart } from '../../../../data/public'; -import { DataViewField } from '../../../../data_views/common'; +import { DataViewField, DataView } from '../../../../data_views/common'; import { ControlsDataService } from '../data'; let valueSuggestionMethod = ({ field, query }: { field: DataViewField; query: string }) => @@ -38,4 +38,8 @@ export const dataServiceFactory: DataServiceFactory = () => ({ timefilter: { createFilter: () => {}, } as unknown as DataPublicPluginStart['query']['timefilter']['timefilter'], + fetchFieldRange: () => Promise.resolve({ min: 0, max: 100 }), + fetchFieldRange$: () => new Observable<{ min: number; max: number }>(), + getDataView: () => Promise.resolve({} as DataView), + getDataView$: () => new Observable({} as any), }); diff --git a/src/plugins/controls/public/services/storybook/index.ts b/src/plugins/controls/public/services/storybook/index.ts index 4eabd6a1bb006..535befd925f49 100644 --- a/src/plugins/controls/public/services/storybook/index.ts +++ b/src/plugins/controls/public/services/storybook/index.ts @@ -17,6 +17,7 @@ import { dataServiceFactory } from './data'; import { overlaysServiceFactory } from './overlays'; import { dataViewsServiceFactory } from './data_views'; import { httpServiceFactory } from '../stub/http'; +import { settingsServiceFactory } from './settings'; import { optionsListServiceFactory } from './options_list'; import { controlsServiceFactory } from '../stub/controls'; @@ -28,6 +29,7 @@ export const providers: PluginServiceProviders = { http: new PluginServiceProvider(httpServiceFactory), data: new PluginServiceProvider(dataServiceFactory), overlays: new PluginServiceProvider(overlaysServiceFactory), + settings: new PluginServiceProvider(settingsServiceFactory), controls: new PluginServiceProvider(controlsServiceFactory), optionsList: new PluginServiceProvider(optionsListServiceFactory), diff --git a/src/plugins/controls/public/services/storybook/settings.ts b/src/plugins/controls/public/services/storybook/settings.ts new file mode 100644 index 0000000000000..40b175bcec7bb --- /dev/null +++ b/src/plugins/controls/public/services/storybook/settings.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { PluginServiceFactory } from '../../../../presentation_util/public'; +import { ControlsSettingsService } from '../settings'; + +export type SettingsServiceFactory = PluginServiceFactory; +export const settingsServiceFactory: SettingsServiceFactory = () => ({ + getTimezone: () => 'Browser', + getDateFormat: () => 'MMM D, YYYY @ HH:mm:ss.SSS', +}); diff --git a/src/plugins/controls/public/services/stub/index.ts b/src/plugins/controls/public/services/stub/index.ts index ddb0a76057648..486c42a999f9a 100644 --- a/src/plugins/controls/public/services/stub/index.ts +++ b/src/plugins/controls/public/services/stub/index.ts @@ -19,12 +19,14 @@ import { controlsServiceFactory } from './controls'; import { dataServiceFactory } from '../storybook/data'; import { dataViewsServiceFactory } from '../storybook/data_views'; import { optionsListServiceFactory } from '../storybook/options_list'; +import { settingsServiceFactory } from '../storybook/settings'; export const providers: PluginServiceProviders = { http: new PluginServiceProvider(httpServiceFactory), data: new PluginServiceProvider(dataServiceFactory), overlays: new PluginServiceProvider(overlaysServiceFactory), dataViews: new PluginServiceProvider(dataViewsServiceFactory), + settings: new PluginServiceProvider(settingsServiceFactory), controls: new PluginServiceProvider(controlsServiceFactory), optionsList: new PluginServiceProvider(optionsListServiceFactory), diff --git a/src/plugins/controls/server/control_types/time_slider/time_slider_embeddable_factory.ts b/src/plugins/controls/server/control_types/time_slider/time_slider_embeddable_factory.ts new file mode 100644 index 0000000000000..0b48dc94707c4 --- /dev/null +++ b/src/plugins/controls/server/control_types/time_slider/time_slider_embeddable_factory.ts @@ -0,0 +1,22 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import { EmbeddableRegistryDefinition } from '../../../../embeddable/server'; +import { TIME_SLIDER_CONTROL } from '../../../common'; +import { + createTimeSliderExtract, + createTimeSliderInject, +} from '../../../common/control_types/time_slider/time_slider_persistable_state'; + +export const timeSliderPersistableStateServiceFactory = (): EmbeddableRegistryDefinition => { + return { + id: TIME_SLIDER_CONTROL, + extract: createTimeSliderExtract(), + inject: createTimeSliderInject(), + }; +}; diff --git a/src/plugins/controls/server/plugin.ts b/src/plugins/controls/server/plugin.ts index 261737f2775c4..6ff67f702be54 100644 --- a/src/plugins/controls/server/plugin.ts +++ b/src/plugins/controls/server/plugin.ts @@ -13,6 +13,7 @@ import { PluginSetup as DataSetup } from '../../data/server'; import { setupOptionsListSuggestionsRoute } from './control_types/options_list/options_list_suggestions_route'; import { controlGroupContainerPersistableStateServiceFactory } from './control_group/control_group_container_factory'; import { optionsListPersistableStateServiceFactory } from './control_types/options_list/options_list_embeddable_factory'; +import { timeSliderPersistableStateServiceFactory } from './control_types/time_slider/time_slider_embeddable_factory'; interface SetupDeps { embeddable: EmbeddableSetup; @@ -22,6 +23,7 @@ interface SetupDeps { export class ControlsPlugin implements Plugin { public setup(core: CoreSetup, { embeddable, data }: SetupDeps) { embeddable.registerEmbeddableFactory(optionsListPersistableStateServiceFactory()); + embeddable.registerEmbeddableFactory(timeSliderPersistableStateServiceFactory()); embeddable.registerEmbeddableFactory( controlGroupContainerPersistableStateServiceFactory(embeddable) diff --git a/src/plugins/controls/tsconfig.json b/src/plugins/controls/tsconfig.json index ed0c2e63011d0..10ec84fbd32f6 100644 --- a/src/plugins/controls/tsconfig.json +++ b/src/plugins/controls/tsconfig.json @@ -13,7 +13,8 @@ "public/**/*.json", "server/**/*", "storybook/**/*", - "../../../typings/**/*" + "../../../typings/**/*", + "./jest_setup.ts" ], "references": [ { "path": "../../core/tsconfig.json" }, From ad026f89cd1ecf1dc692dbedcd022e4b5f482163 Mon Sep 17 00:00:00 2001 From: Jonathan Budzenski Date: Tue, 29 Mar 2022 21:22:30 -0500 Subject: [PATCH 148/160] Revert "[Monitor management] Show public beta fair usage (#128770)" This reverts commit 436dfbed8cb43fd39e32b684871a65360db22c8a. --- .../monitor_management/locations.ts | 15 +-- .../monitor_management/monitor_types.ts | 27 ++-- .../action_bar/action_bar.tsx | 40 +++++- .../monitor_list/monitor_async_error.test.tsx | 116 ------------------ .../monitor_list/monitor_async_error.tsx | 75 ----------- .../monitor_list/monitor_list_container.tsx | 2 - .../monitor_management/show_sync_errors.tsx | 52 -------- .../monitor_management/monitor_management.tsx | 4 +- .../state/reducers/monitor_management.ts | 1 - .../synthetics_service/synthetics_service.ts | 7 +- .../synthetics_service/get_monitor.ts | 3 +- 11 files changed, 57 insertions(+), 285 deletions(-) delete mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx delete mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx delete mode 100644 x-pack/plugins/uptime/public/components/monitor_management/show_sync_errors.tsx diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts index 82d2bc8afa412..d11ae7c655405 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts @@ -64,15 +64,12 @@ export const ServiceLocationErrors = t.array( status: t.number, }), t.partial({ - failed_monitors: t.union([ - t.array( - t.interface({ - id: t.string, - message: t.string, - }) - ), - t.null, - ]), + failed_monitors: t.array( + t.interface({ + id: t.string, + message: t.string, + }) + ), }), ]), }) diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts index 872ccdbb71ec8..44c643d2160d1 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts @@ -8,7 +8,7 @@ import * as t from 'io-ts'; import { secretKeys } from '../../constants/monitor_management'; import { ConfigKey } from './config_key'; -import { LocationsCodec, ServiceLocationErrors } from './locations'; +import { LocationsCodec } from './locations'; import { DataStreamCodec, ModeCodec, @@ -306,23 +306,14 @@ export type EncryptedSyntheticsMonitorWithId = t.TypeOf< typeof EncryptedSyntheticsMonitorWithIdCodec >; -export const MonitorManagementListResultCodec = t.intersection([ - t.type({ - monitors: t.array( - t.interface({ - id: t.string, - attributes: EncryptedSyntheticsMonitorCodec, - updated_at: t.string, - }) - ), - page: t.number, - perPage: t.number, - total: t.union([t.number, t.null]), - }), - t.partial({ - syncErrors: ServiceLocationErrors, - }), -]); +export const MonitorManagementListResultCodec = t.type({ + monitors: t.array( + t.interface({ id: t.string, attributes: EncryptedSyntheticsMonitorCodec, updated_at: t.string }) + ), + page: t.number, + perPage: t.number, + total: t.union([t.number, t.null]), +}); export type MonitorManagementListResult = t.TypeOf; diff --git a/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx b/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx index 5f6e67e363171..3b30458974ed7 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx @@ -19,6 +19,7 @@ import { i18n } from '@kbn/i18n'; import { useSelector } from 'react-redux'; import { FETCH_STATUS, useFetcher } from '../../../../../observability/public'; +import { toMountPoint } from '../../../../../../../src/plugins/kibana_react/public'; import { MONITOR_MANAGEMENT_ROUTE } from '../../../../common/constants'; import { UptimeSettingsContext } from '../../../contexts'; @@ -31,7 +32,6 @@ import { TestRun } from '../test_now_mode/test_now_mode'; import { monitorManagementListSelector } from '../../../state/selectors'; import { kibanaService } from '../../../state/kibana_service'; -import { showSyncErrors } from '../show_sync_errors'; export interface ActionBarProps { monitor: SyntheticsMonitor; @@ -103,7 +103,43 @@ export const ActionBar = ({ }); setIsSuccessful(true); } else if (hasErrors && !loading) { - showSyncErrors(data.attributes.errors, locations); + Object.values(data.attributes.errors!).forEach((location) => { + const { status: responseStatus, reason } = location.error || {}; + kibanaService.toasts.addWarning({ + title: i18n.translate('xpack.uptime.monitorManagement.service.error.title', { + defaultMessage: `Unable to sync monitor config`, + }), + text: toMountPoint( + <> +

+ {i18n.translate('xpack.uptime.monitorManagement.service.error.message', { + defaultMessage: `Your monitor was saved, but there was a problem syncing the configuration for {location}. We will automatically try again later. If this problem continues, your monitors will stop running in {location}. Please contact Support for assistance.`, + values: { + location: locations?.find((loc) => loc?.id === location.locationId)?.label, + }, + })} +

+ {responseStatus || reason ? ( +

+ {responseStatus + ? i18n.translate('xpack.uptime.monitorManagement.service.error.status', { + defaultMessage: 'Status: {status}. ', + values: { status: responseStatus }, + }) + : null} + {reason + ? i18n.translate('xpack.uptime.monitorManagement.service.error.reason', { + defaultMessage: 'Reason: {reason}.', + values: { reason }, + }) + : null} +

+ ) : null} + + ), + toastLifeTimeMs: 30000, + }); + }); setIsSuccessful(true); } }, [data, status, isSaving, isValid, monitorId, hasErrors, locations, loading]); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx deleted file mode 100644 index 1122d136c926c..0000000000000 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx +++ /dev/null @@ -1,116 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { screen } from '@testing-library/react'; -import React from 'react'; -import { DEFAULT_THROTTLING } from '../../../../common/runtime_types'; -import { render } from '../../../lib/helper/rtl_helpers'; -import { MonitorManagementList as MonitorManagementListState } from '../../../state/reducers/monitor_management'; -import { MonitorAsyncError } from './monitor_async_error'; - -describe('', () => { - const location1 = 'US Central'; - const location2 = 'US North'; - const reason1 = 'Unauthorized'; - const reason2 = 'Forbidden'; - const status1 = 401; - const status2 = 403; - const state = { - monitorManagementList: { - throttling: DEFAULT_THROTTLING, - enablement: null, - list: { - perPage: 5, - page: 1, - total: 6, - monitors: [], - syncErrors: [ - { - locationId: 'us_central', - error: { - reason: reason1, - status: status1, - }, - }, - { - locationId: 'us_north', - error: { - reason: reason2, - status: status2, - }, - }, - ], - }, - locations: [ - { - id: 'us_central', - label: location1, - geo: { - lat: 0, - lon: 0, - }, - url: '', - }, - { - id: 'us_north', - label: location2, - geo: { - lat: 0, - lon: 0, - }, - url: '', - }, - ], - error: { - serviceLocations: null, - monitorList: null, - enablement: null, - }, - loading: { - monitorList: true, - serviceLocations: false, - enablement: false, - }, - syntheticsService: { - loading: false, - }, - } as MonitorManagementListState, - }; - - it('renders when errors are defined', () => { - render(, { state }); - - expect(screen.getByText(new RegExp(reason1))).toBeInTheDocument(); - expect(screen.getByText(new RegExp(`${status1}`))).toBeInTheDocument(); - expect(screen.getByText(new RegExp(reason2))).toBeInTheDocument(); - expect(screen.getByText(new RegExp(`${status2}`))).toBeInTheDocument(); - expect(screen.getByText(new RegExp(location1))).toBeInTheDocument(); - expect(screen.getByText(new RegExp(location2))).toBeInTheDocument(); - }); - - it('renders null when errors are empty', () => { - render(, { - state: { - ...state, - monitorManagementList: { - ...state.monitorManagementList, - list: { - ...state.monitorManagementList.list, - syncErrors: [], - }, - }, - }, - }); - - expect(screen.queryByText(new RegExp(reason1))).not.toBeInTheDocument(); - expect(screen.queryByText(new RegExp(`${status1}`))).not.toBeInTheDocument(); - expect(screen.queryByText(new RegExp(reason2))).not.toBeInTheDocument(); - expect(screen.queryByText(new RegExp(`${status2}`))).not.toBeInTheDocument(); - expect(screen.queryByText(new RegExp(location1))).not.toBeInTheDocument(); - expect(screen.queryByText(new RegExp(location2))).not.toBeInTheDocument(); - }); -}); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx deleted file mode 100644 index c9e9dba2027a4..0000000000000 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.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 - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ -import React, { useState } from 'react'; -import { useSelector } from 'react-redux'; -import { i18n } from '@kbn/i18n'; -import { FormattedMessage } from '@kbn/i18n-react'; -import { EuiButton, EuiCallOut, EuiSpacer } from '@elastic/eui'; -import { monitorManagementListSelector } from '../../../state/selectors'; - -export const MonitorAsyncError = () => { - const [isDismissed, setIsDismissed] = useState(false); - const { list, locations } = useSelector(monitorManagementListSelector); - const syncErrors = list.syncErrors; - const hasSyncErrors = syncErrors && syncErrors.length > 0; - - return hasSyncErrors && !isDismissed ? ( - <> - - } - color="warning" - iconType="alert" - > -

- -

-
    - {Object.values(syncErrors).map((e) => { - return ( -
  • {`${ - locations.find((location) => location.id === e.locationId)?.label - } - ${STATUS_LABEL}: ${e.error.status}; ${REASON_LABEL}: ${e.error.reason}.`}
  • - ); - })} -
- setIsDismissed(true)} color="warning"> - {DISMISS_LABEL} - -
- - - ) : null; -}; - -const REASON_LABEL = i18n.translate( - 'xpack.uptime.monitorManagement.monitorSync.failure.reasonLabel', - { - defaultMessage: 'Reason', - } -); - -const STATUS_LABEL = i18n.translate( - 'xpack.uptime.monitorManagement.monitorSync.failure.statusLabel', - { - defaultMessage: 'Status', - } -); - -const DISMISS_LABEL = i18n.translate( - 'xpack.uptime.monitorManagement.monitorSync.failure.dismissLabel', - { - defaultMessage: 'Dismiss', - } -); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx index 53afdf49c1592..a3f041a33a9f8 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx @@ -13,7 +13,6 @@ import { ConfigKey } from '../../../../common/runtime_types'; import { getMonitors } from '../../../state/actions'; import { monitorManagementListSelector } from '../../../state/selectors'; import { MonitorManagementListPageState } from './monitor_list'; -import { MonitorAsyncError } from './monitor_async_error'; import { useInlineErrors } from '../hooks/use_inline_errors'; import { MonitorListTabs } from './list_tabs'; import { AllMonitors } from './all_monitors'; @@ -67,7 +66,6 @@ export const MonitorListContainer: React.FC = () => { return ( <> - { - Object.values(errors).forEach((location) => { - const { status: responseStatus, reason } = location.error || {}; - kibanaService.toasts.addWarning({ - title: i18n.translate('xpack.uptime.monitorManagement.service.error.title', { - defaultMessage: `Unable to sync monitor config`, - }), - text: toMountPoint( - <> -

- {i18n.translate('xpack.uptime.monitorManagement.service.error.message', { - defaultMessage: `Your monitor was saved, but there was a problem syncing the configuration for {location}. We will automatically try again later. If this problem continues, your monitors will stop running in {location}. Please contact Support for assistance.`, - values: { - location: locations?.find((loc) => loc?.id === location.locationId)?.label, - }, - })} -

- {responseStatus || reason ? ( -

- {responseStatus - ? i18n.translate('xpack.uptime.monitorManagement.service.error.status', { - defaultMessage: 'Status: {status}. ', - values: { status: responseStatus }, - }) - : null} - {reason - ? i18n.translate('xpack.uptime.monitorManagement.service.error.reason', { - defaultMessage: 'Reason: {reason}.', - values: { reason }, - }) - : null} -

- ) : null} - - ), - toastLifeTimeMs: 30000, - }); - }); -}; diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx index 71785dbaf78ee..3e0e9b955f31f 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx @@ -17,7 +17,6 @@ import { useMonitorManagementBreadcrumbs } from './use_monitor_management_breadc import { MonitorListContainer } from '../../components/monitor_management/monitor_list/monitor_list_container'; import { EnablementEmptyState } from '../../components/monitor_management/monitor_list/enablement_empty_state'; import { useEnablement } from '../../components/monitor_management/hooks/use_enablement'; -import { useLocations } from '../../components/monitor_management/hooks/use_locations'; import { Loader } from '../../components/monitor_management/loader/loader'; export const MonitorManagementPage: React.FC = () => { @@ -33,7 +32,6 @@ export const MonitorManagementPage: React.FC = () => { loading: enablementLoading, enableSynthetics, } = useEnablement(); - const { loading: locationsLoading } = useLocations(); const { list: monitorList } = useSelector(monitorManagementListSelector); const { isEnabled } = enablement; @@ -64,7 +62,7 @@ export const MonitorManagementPage: React.FC = () => { return ( <> ({ search: schema.maybe(schema.string()), }), }, - handler: async ({ request, savedObjectsClient, server }): Promise => { + handler: async ({ request, savedObjectsClient }): Promise => { const { perPage = 50, page, sortField, sortOrder, search } = request.query; // TODO: add query/filtering params const { @@ -78,7 +78,6 @@ export const getAllSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ ...rest, perPage: perPageT, monitors, - syncErrors: server.syntheticsService.syncErrors, }; }, }); From 9122810c17a7fce4942f8ce1c2fffb42d193e2e0 Mon Sep 17 00:00:00 2001 From: Joe Portner <5295965+jportner@users.noreply.github.com> Date: Tue, 29 Mar 2022 22:44:58 -0400 Subject: [PATCH 149/160] Update spaces list and saved object management page (#128669) --- .../objects_table/components/table.tsx | 6 + .../share_saved_objects_to_space_action.tsx | 4 +- .../public/services/column_service.test.ts | 8 +- .../public/services/column_service.ts | 7 +- .../public/services/columns/constants.ts | 29 +++ .../share_saved_objects_to_space_column.tsx | 171 +++++++++++++++--- .../public/services/index.ts | 4 +- .../public/services/types/action.ts | 2 +- .../public/services/types/column.ts | 31 +++- .../public/services/types/index.ts | 2 +- 10 files changed, 223 insertions(+), 41 deletions(-) create mode 100644 src/plugins/saved_objects_management/public/services/columns/constants.ts diff --git a/src/plugins/saved_objects_management/public/management_section/objects_table/components/table.tsx b/src/plugins/saved_objects_management/public/management_section/objects_table/components/table.tsx index a7f43438e5525..fb0e55fb272a1 100644 --- a/src/plugins/saved_objects_management/public/management_section/objects_table/components/table.tsx +++ b/src/plugins/saved_objects_management/public/management_section/objects_table/components/table.tsx @@ -227,6 +227,12 @@ export class Table extends PureComponent { } as EuiTableFieldDataColumnType>, ...(taggingApi ? [taggingApi.ui.getTableColumnDefinition()] : []), ...columnRegistry.getAll().map((column) => { + column.setColumnContext({ capabilities }); + column.registerOnFinishCallback(() => { + const { refreshOnFinish = () => [] } = column; + const objectsToRefresh = refreshOnFinish(); + onActionRefresh(objectsToRefresh); + }); return { ...column.euiColumn, sortable: false, diff --git a/src/plugins/saved_objects_management/public/services/actions/share_saved_objects_to_space_action.tsx b/src/plugins/saved_objects_management/public/services/actions/share_saved_objects_to_space_action.tsx index e36c13bd8fd8b..b1a80c71e4ea2 100644 --- a/src/plugins/saved_objects_management/public/services/actions/share_saved_objects_to_space_action.tsx +++ b/src/plugins/saved_objects_management/public/services/actions/share_saved_objects_to_space_action.tsx @@ -33,10 +33,10 @@ export class ShareToSpaceSavedObjectsManagementAction extends SavedObjectsManage public euiAction = { name: i18n.translate('savedObjectsManagement.shareToSpace.actionTitle', { - defaultMessage: 'Share to space', + defaultMessage: 'Assign spaces', }), description: i18n.translate('savedObjectsManagement.shareToSpace.actionDescription', { - defaultMessage: 'Share this saved object to one or more spaces', + defaultMessage: 'Change the spaces this object is assigned to', }), icon: 'share', type: 'icon', diff --git a/src/plugins/saved_objects_management/public/services/column_service.test.ts b/src/plugins/saved_objects_management/public/services/column_service.test.ts index 5676cfaa81285..1124e71b36c52 100644 --- a/src/plugins/saved_objects_management/public/services/column_service.test.ts +++ b/src/plugins/saved_objects_management/public/services/column_service.test.ts @@ -14,8 +14,10 @@ import { } from './column_service'; import { SavedObjectsManagementColumn } from './types'; -class DummyColumn implements SavedObjectsManagementColumn { - constructor(public id: string) {} +class DummyColumn extends SavedObjectsManagementColumn { + constructor(public id: string) { + super(); + } public euiColumn = { field: 'id', @@ -29,7 +31,7 @@ describe('SavedObjectsManagementColumnRegistry', () => { let service: SavedObjectsManagementColumnService; let setup: SavedObjectsManagementColumnServiceSetup; - const createColumn = (id: string): SavedObjectsManagementColumn => { + const createColumn = (id: string): SavedObjectsManagementColumn => { return new DummyColumn(id); }; diff --git a/src/plugins/saved_objects_management/public/services/column_service.ts b/src/plugins/saved_objects_management/public/services/column_service.ts index 8189fc7d07f83..d9c88ec8834e5 100644 --- a/src/plugins/saved_objects_management/public/services/column_service.ts +++ b/src/plugins/saved_objects_management/public/services/column_service.ts @@ -14,18 +14,18 @@ export interface SavedObjectsManagementColumnServiceSetup { /** * register given column in the registry. */ - register: (column: SavedObjectsManagementColumn) => void; + register: (column: SavedObjectsManagementColumn) => void; } export interface SavedObjectsManagementColumnServiceStart { /** * return all {@link SavedObjectsManagementColumn | columns} currently registered. */ - getAll: () => Array>; + getAll: () => SavedObjectsManagementColumn[]; } export class SavedObjectsManagementColumnService { - private readonly columns = new Map>(); + private readonly columns = new Map(); setup(): SavedObjectsManagementColumnServiceSetup { return { @@ -52,6 +52,5 @@ function registerSpacesApiColumns( service: SavedObjectsManagementColumnService, spacesApi: SpacesApi ) { - // Note: this column is hidden for now because no saved objects are shareable. It should be uncommented when at least one saved object type is multi-namespace. service.setup().register(new ShareToSpaceSavedObjectsManagementColumn(spacesApi.ui)); } diff --git a/src/plugins/saved_objects_management/public/services/columns/constants.ts b/src/plugins/saved_objects_management/public/services/columns/constants.ts new file mode 100644 index 0000000000000..9f459fbbf2fbe --- /dev/null +++ b/src/plugins/saved_objects_management/public/services/columns/constants.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +/** + * This is a hard-coded list that can be removed when each of these "share-capable" object types are changed to be shareable. + * Note, this list does not preclude other object types from being made shareable in the future, it just consists of the object types that + * we are working towards making shareable in the near term. + * + * This is purely for changing the tooltip in the Saved Object Management UI, it's not used anywhere else. + */ +export const SHAREABLE_SOON_OBJECT_TYPES = [ + 'tag', + 'dashboard', + 'canvas-workpad', + 'canvas-element', + 'lens', + 'visualization', + 'map', + 'graph-workspace', + 'search', + 'query', + 'rule', + 'connector', +]; diff --git a/src/plugins/saved_objects_management/public/services/columns/share_saved_objects_to_space_column.tsx b/src/plugins/saved_objects_management/public/services/columns/share_saved_objects_to_space_column.tsx index 6971021a81e84..3ce8b82f98acf 100644 --- a/src/plugins/saved_objects_management/public/services/columns/share_saved_objects_to_space_column.tsx +++ b/src/plugins/saved_objects_management/public/services/columns/share_saved_objects_to_space_column.tsx @@ -6,49 +6,170 @@ * Side Public License, v 1. */ -import React, { useMemo } from 'react'; +import React, { useMemo, useState } from 'react'; import { i18n } from '@kbn/i18n'; -import type { SpaceListProps, SpacesApiUi } from '../../../../../../x-pack/plugins/spaces/public'; -import type { SavedObjectsManagementColumn } from '../types'; +import type { SavedObjectsNamespaceType } from 'src/core/public'; +import { EuiIconTip, EuiToolTip } from '@elastic/eui'; + +import type { + ShareToSpaceFlyoutProps, + SpaceListProps, + SpacesApiUi, +} from '../../../../../../x-pack/plugins/spaces/public'; +import type { SavedObjectsManagementRecord } from '../types'; +import { SavedObjectsManagementColumn } from '../types'; +import { SHAREABLE_SOON_OBJECT_TYPES } from './constants'; interface WrapperProps { + objectType: string; + objectNamespaceType: SavedObjectsNamespaceType; spacesApiUi: SpacesApiUi; - props: SpaceListProps; + spaceListProps: SpaceListProps; + flyoutProps: ShareToSpaceFlyoutProps; } -const Wrapper = ({ spacesApiUi, props }: WrapperProps) => { - const LazyComponent = useMemo(() => spacesApiUi.components.getSpaceList, [spacesApiUi]); +const columnName = i18n.translate('savedObjectsManagement.shareToSpace.columnTitle', { + defaultMessage: 'Spaces', +}); +const columnDescription = i18n.translate('savedObjectsManagement.shareToSpace.columnDescription', { + defaultMessage: 'The spaces that this object is currently assigned to', +}); +const isolatedObjectTypeTitle = i18n.translate( + 'savedObjectsManagement.shareToSpace.isolatedObjectTypeTitle', + { defaultMessage: 'Isolated saved object' } +); +const isolatedObjectTypeContent = i18n.translate( + 'savedObjectsManagement.shareToSpace.isolatedObjectTypeContent', + { + defaultMessage: + 'This saved object is available in only one space, it cannot be assigned to multiple spaces.', + } +); +const shareableSoonObjectTypeTitle = i18n.translate( + 'savedObjectsManagement.shareToSpace.shareableSoonObjectTypeTitle', + { defaultMessage: 'Coming soon: Assign saved object to multiple spaces' } +); +const shareableSoonObjectTypeContent = i18n.translate( + 'savedObjectsManagement.shareToSpace.shareableSoonObjectTypeContent', + { + defaultMessage: + 'This saved object is available in only one space. In a future release, you can assign it to multiple spaces.', + } +); +const globalObjectTypeTitle = i18n.translate( + 'savedObjectsManagement.shareToSpace.globalObjectTypeTitle', + { defaultMessage: 'Global saved object' } +); +const globalObjectTypeContent = i18n.translate( + 'savedObjectsManagement.shareToSpace.globalObjectTypeContent', + { defaultMessage: 'This saved object is available in all spaces and cannot be changed.' } +); + +const Wrapper = ({ + objectType, + objectNamespaceType, + spacesApiUi, + spaceListProps, + flyoutProps, +}: WrapperProps) => { + const [showFlyout, setShowFlyout] = useState(false); + + function listOnClick() { + setShowFlyout(true); + } + + function onClose() { + setShowFlyout(false); + flyoutProps.onClose?.(); + } + + const LazySpaceList = useMemo(() => spacesApiUi.components.getSpaceList, [spacesApiUi]); + const LazyShareToSpaceFlyout = useMemo( + () => spacesApiUi.components.getShareToSpaceFlyout, + [spacesApiUi] + ); + const LazySpaceAvatar = useMemo(() => spacesApiUi.components.getSpaceAvatar, [spacesApiUi]); - return ; + if (objectNamespaceType === 'single' || objectNamespaceType === 'multiple-isolated') { + const tooltipProps = SHAREABLE_SOON_OBJECT_TYPES.includes(objectType) + ? { title: shareableSoonObjectTypeTitle, content: shareableSoonObjectTypeContent } + : { title: isolatedObjectTypeTitle, content: isolatedObjectTypeContent }; + return ; + } else if (objectNamespaceType === 'agnostic') { + return ( + + + + ); + } + + return ( + <> + + {showFlyout && } + + ); }; -export class ShareToSpaceSavedObjectsManagementColumn - implements SavedObjectsManagementColumn -{ +export class ShareToSpaceSavedObjectsManagementColumn extends SavedObjectsManagementColumn { public id: string = 'share_saved_objects_to_space'; public euiColumn = { field: 'namespaces', - name: i18n.translate('savedObjectsManagement.shareToSpace.columnTitle', { - defaultMessage: 'Shared spaces', - }), - description: i18n.translate('savedObjectsManagement.shareToSpace.columnDescription', { - defaultMessage: 'The other spaces that this object is currently shared to', - }), - render: (namespaces: string[] | undefined) => { - if (!namespaces) { - return null; - } - - const props: SpaceListProps = { - namespaces, + name: columnName, + description: columnDescription, + render: (namespaces: string[] | undefined, record: SavedObjectsManagementRecord) => { + const spaceListProps: SpaceListProps = { + namespaces: namespaces ?? [], + behaviorContext: 'outside-space', + }; + const flyoutProps: ShareToSpaceFlyoutProps = { + savedObjectTarget: { + type: record.type, + id: record.id, + namespaces: namespaces ?? [], + title: record.meta.title, + icon: record.meta.icon, + }, + flyoutIcon: 'share', + onUpdate: (updatedObjects: Array<{ type: string; id: string }>) => + (this.objectsToRefresh = [...updatedObjects]), + onClose: this.onClose, + enableCreateCopyCallout: true, + enableCreateNewSpaceLink: true, }; - return ; + return ( + + ); }, }; + public refreshOnFinish = () => this.objectsToRefresh; + + private objectsToRefresh: Array<{ type: string; id: string }> = []; - constructor(private readonly spacesApiUi: SpacesApiUi) {} + constructor(private readonly spacesApiUi: SpacesApiUi) { + super(); + } + + private onClose = () => { + this.finish(); + }; } diff --git a/src/plugins/saved_objects_management/public/services/index.ts b/src/plugins/saved_objects_management/public/services/index.ts index c45c81d3122ad..997a1b96b418f 100644 --- a/src/plugins/saved_objects_management/public/services/index.ts +++ b/src/plugins/saved_objects_management/public/services/index.ts @@ -16,5 +16,5 @@ export type { SavedObjectsManagementColumnServiceSetup, } from './column_service'; export { SavedObjectsManagementColumnService } from './column_service'; -export type { SavedObjectsManagementColumn, SavedObjectsManagementRecord } from './types'; -export { SavedObjectsManagementAction } from './types'; +export type { SavedObjectsManagementRecord } from './types'; +export { SavedObjectsManagementColumn, SavedObjectsManagementAction } from './types'; diff --git a/src/plugins/saved_objects_management/public/services/types/action.ts b/src/plugins/saved_objects_management/public/services/types/action.ts index 625405e9955fd..b0ab229065555 100644 --- a/src/plugins/saved_objects_management/public/services/types/action.ts +++ b/src/plugins/saved_objects_management/public/services/types/action.ts @@ -7,7 +7,7 @@ */ import { ReactNode } from 'react'; -import { Capabilities } from 'src/core/public'; +import type { Capabilities } from 'src/core/public'; import { SavedObjectsManagementRecord } from '.'; interface ActionContext { diff --git a/src/plugins/saved_objects_management/public/services/types/column.ts b/src/plugins/saved_objects_management/public/services/types/column.ts index 1be279db91205..fcdb33015df59 100644 --- a/src/plugins/saved_objects_management/public/services/types/column.ts +++ b/src/plugins/saved_objects_management/public/services/types/column.ts @@ -7,9 +7,34 @@ */ import { EuiTableFieldDataColumnType } from '@elastic/eui'; +import type { Capabilities } from 'src/core/public'; import { SavedObjectsManagementRecord } from '.'; -export interface SavedObjectsManagementColumn { - id: string; - euiColumn: Omit, 'sortable'>; +interface ColumnContext { + capabilities: Capabilities; +} + +export abstract class SavedObjectsManagementColumn { + public abstract id: string; + public abstract euiColumn: Omit< + EuiTableFieldDataColumnType, + 'sortable' + >; + public refreshOnFinish?: () => Array<{ type: string; id: string }>; + + private callbacks: Function[] = []; + + protected columnContext: ColumnContext | null = null; + + public setColumnContext(columnContext: ColumnContext) { + this.columnContext = columnContext; + } + + public registerOnFinishCallback(callback: Function) { + this.callbacks.push(callback); + } + + protected finish() { + this.callbacks.forEach((callback) => callback()); + } } diff --git a/src/plugins/saved_objects_management/public/services/types/index.ts b/src/plugins/saved_objects_management/public/services/types/index.ts index 82b45f9df33f0..ba95f78c7afc9 100644 --- a/src/plugins/saved_objects_management/public/services/types/index.ts +++ b/src/plugins/saved_objects_management/public/services/types/index.ts @@ -7,5 +7,5 @@ */ export { SavedObjectsManagementAction } from './action'; -export type { SavedObjectsManagementColumn } from './column'; +export { SavedObjectsManagementColumn } from './column'; export type { SavedObjectsManagementRecord } from './record'; From 482f819a0580d58e766e1db7e8e012a351e41247 Mon Sep 17 00:00:00 2001 From: Marshall Main <55718608+marshallmain@users.noreply.github.com> Date: Tue, 29 Mar 2022 20:11:55 -0700 Subject: [PATCH 150/160] [Security Solution][Alerts] Replace schemas derived from FieldMaps with versioned alert schema (#127218) * Replace schemas derived from FieldMaps with versioned alert schema * Import fixes and comment * Another import fix * Separate read and write schemas * Separate read and write schemas for common alert fields * fix import * Update ALERT_RULE_PARAMETERS type * Fix getField type * Fix more types * Remove unneeded index signature from PersistenceAlertServiceResult * Fix types and tests * Update comment describing new schema process * Update Ancestor800 type * Add modified PR description as initial README * Remove duplication in CommonAlertFields definition * Add explicit undefined value for rule in mock Co-authored-by: Kibana Machine <42973632+kibanamachine@users.noreply.github.com> --- .../src/technical_field_names.ts | 3 + .../field_maps/experimental_rule_field_map.ts | 2 +- .../field_maps/technical_rule_field_map.ts | 5 +- .../common/schemas/8.0.0/index.ts | 52 ++++ .../rule_registry/common/schemas/README.md | 1 + .../rule_registry/common/schemas/index.ts | 20 ++ .../server/utils/create_lifecycle_executor.ts | 9 +- .../server/utils/get_common_alert_fields.ts | 26 +- .../server/utils/persistence_types.ts | 3 +- .../schemas/alerts/8.0.0/index.ts | 178 +++++++++++++ .../detection_engine/schemas/alerts/README.md | 54 ++++ .../detection_engine/schemas/alerts/index.ts | 28 +++ .../schemas/request/rule_schemas.ts | 2 +- .../common/field_maps/{ => 8.0.0}/alerts.ts | 4 +- .../common/field_maps/8.0.0/index.ts | 11 + .../common/field_maps/{ => 8.0.0}/rules.ts | 0 .../common/field_maps/field_names.ts | 12 + .../common/field_maps/index.ts | 4 +- .../schedule_notification_actions.ts | 8 +- .../factories/bulk_create_factory.ts | 14 +- .../factories/utils/build_alert.test.ts | 2 + .../rule_types/factories/utils/build_alert.ts | 156 ++++++++---- .../utils/build_alert_group_from_sequence.ts | 89 +++---- .../factories/utils/build_bulk_body.ts | 7 +- .../factories/utils/filter_source.ts | 3 +- .../utils/generate_building_block_ids.ts | 9 +- .../rule_types/factories/wrap_hits_factory.ts | 26 +- .../factories/wrap_sequences_factory.ts | 7 +- .../lib/detection_engine/rule_types/types.ts | 19 -- .../signals/__mocks__/es_results.ts | 137 +++++++++- .../signals/bulk_create_ml_signals.ts | 3 +- .../detection_engine/signals/executors/eql.ts | 7 +- .../signals/filter_duplicate_signals.test.ts | 48 ---- .../signals/filter_duplicate_signals.ts | 29 --- .../signals/search_after_bulk_create.test.ts | 234 +++++++++++++++--- .../signals/threshold/build_signal_history.ts | 6 +- .../bulk_create_threshold_signals.ts | 3 +- .../lib/detection_engine/signals/types.ts | 17 +- .../detection_engine/signals/utils.test.ts | 22 +- .../lib/detection_engine/signals/utils.ts | 22 +- .../basic/tests/open_close_signals.ts | 24 +- .../basic/tests/update_rac_alerts.ts | 26 +- .../tests/open_close_signals.ts | 10 +- .../detection_engine_api_integration/utils.ts | 14 +- 44 files changed, 994 insertions(+), 362 deletions(-) create mode 100644 x-pack/plugins/rule_registry/common/schemas/8.0.0/index.ts create mode 100644 x-pack/plugins/rule_registry/common/schemas/README.md create mode 100644 x-pack/plugins/rule_registry/common/schemas/index.ts create mode 100644 x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/8.0.0/index.ts create mode 100644 x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/README.md create mode 100644 x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/index.ts rename x-pack/plugins/security_solution/common/field_maps/{ => 8.0.0}/alerts.ts (97%) create mode 100644 x-pack/plugins/security_solution/common/field_maps/8.0.0/index.ts rename x-pack/plugins/security_solution/common/field_maps/{ => 8.0.0}/rules.ts (100%) delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.test.ts delete mode 100644 x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.ts diff --git a/packages/kbn-rule-data-utils/src/technical_field_names.ts b/packages/kbn-rule-data-utils/src/technical_field_names.ts index f76043c2a6afc..e6b6494e68a56 100644 --- a/packages/kbn-rule-data-utils/src/technical_field_names.ts +++ b/packages/kbn-rule-data-utils/src/technical_field_names.ts @@ -54,6 +54,7 @@ const ALERT_RULE_INTERVAL = `${ALERT_RULE_NAMESPACE}.interval` as const; const ALERT_RULE_LICENSE = `${ALERT_RULE_NAMESPACE}.license` as const; const ALERT_RULE_CATEGORY = `${ALERT_RULE_NAMESPACE}.category` as const; const ALERT_RULE_NAME = `${ALERT_RULE_NAMESPACE}.name` as const; +const ALERT_RULE_NAMESPACE_FIELD = `${ALERT_RULE_NAMESPACE}.namespace` as const; const ALERT_RULE_NOTE = `${ALERT_RULE_NAMESPACE}.note` as const; const ALERT_RULE_PARAMETERS = `${ALERT_RULE_NAMESPACE}.parameters` as const; const ALERT_RULE_REFERENCES = `${ALERT_RULE_NAMESPACE}.references` as const; @@ -111,6 +112,7 @@ const fields = { ALERT_RULE_INTERVAL, ALERT_RULE_LICENSE, ALERT_RULE_NAME, + ALERT_RULE_NAMESPACE_FIELD, ALERT_RULE_NOTE, ALERT_RULE_PARAMETERS, ALERT_RULE_REFERENCES, @@ -166,6 +168,7 @@ export { ALERT_RULE_INTERVAL, ALERT_RULE_LICENSE, ALERT_RULE_NAME, + ALERT_RULE_NAMESPACE_FIELD, ALERT_RULE_NOTE, ALERT_RULE_PARAMETERS, ALERT_RULE_REFERENCES, diff --git a/x-pack/plugins/rule_registry/common/assets/field_maps/experimental_rule_field_map.ts b/x-pack/plugins/rule_registry/common/assets/field_maps/experimental_rule_field_map.ts index f7b4de188ec11..473850a20d0b9 100644 --- a/x-pack/plugins/rule_registry/common/assets/field_maps/experimental_rule_field_map.ts +++ b/x-pack/plugins/rule_registry/common/assets/field_maps/experimental_rule_field_map.ts @@ -5,7 +5,7 @@ * 2.0. */ -import * as Fields from '../../../common/technical_rule_data_field_names'; +import * as Fields from '../../technical_rule_data_field_names'; export const experimentalRuleFieldMap = { [Fields.ALERT_INSTANCE_ID]: { type: 'keyword', required: true }, diff --git a/x-pack/plugins/rule_registry/common/assets/field_maps/technical_rule_field_map.ts b/x-pack/plugins/rule_registry/common/assets/field_maps/technical_rule_field_map.ts index c81329baad572..72db005578e30 100644 --- a/x-pack/plugins/rule_registry/common/assets/field_maps/technical_rule_field_map.ts +++ b/x-pack/plugins/rule_registry/common/assets/field_maps/technical_rule_field_map.ts @@ -4,8 +4,9 @@ * 2.0; you may not use this file except in compliance with the Elastic License * 2.0. */ -import { pickWithPatterns } from '../../../common/pick_with_patterns'; -import * as Fields from '../../../common/technical_rule_data_field_names'; + +import { pickWithPatterns } from '../../pick_with_patterns'; +import * as Fields from '../../technical_rule_data_field_names'; import { ecsFieldMap } from './ecs_field_map'; export const technicalRuleFieldMap = { diff --git a/x-pack/plugins/rule_registry/common/schemas/8.0.0/index.ts b/x-pack/plugins/rule_registry/common/schemas/8.0.0/index.ts new file mode 100644 index 0000000000000..269caa5c21fb6 --- /dev/null +++ b/x-pack/plugins/rule_registry/common/schemas/8.0.0/index.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { Values } from '@kbn/utility-types'; +import { + ALERT_INSTANCE_ID, + ALERT_UUID, + ALERT_RULE_CATEGORY, + ALERT_RULE_CONSUMER, + ALERT_RULE_EXECUTION_UUID, + ALERT_RULE_NAME, + ALERT_RULE_PRODUCER, + ALERT_RULE_TYPE_ID, + ALERT_RULE_UUID, + SPACE_IDS, + ALERT_RULE_TAGS, + TIMESTAMP, +} from '@kbn/rule-data-utils'; + +/* DO NOT MODIFY THIS SCHEMA TO ADD NEW FIELDS. These types represent the alerts that shipped in 8.0.0. +Any changes to these types should be bug fixes so the types more accurately represent the alerts from 8.0.0. + +If you are adding new fields for a new release of Kibana, create a new sibling folder to this one +for the version to be released and add the field(s) to the schema in that folder. + +Then, update `../index.ts` to import from the new folder that has the latest schemas, add the +new schemas to the union of all alert schemas, and re-export the new schemas as the `*Latest` schemas. +*/ + +const commonAlertIdFieldNames = [ALERT_INSTANCE_ID, ALERT_UUID]; +export type CommonAlertIdFieldName800 = Values; + +export interface CommonAlertFields800 { + [ALERT_RULE_CATEGORY]: string; + [ALERT_RULE_CONSUMER]: string; + [ALERT_RULE_EXECUTION_UUID]: string; + [ALERT_RULE_NAME]: string; + [ALERT_RULE_PRODUCER]: string; + [ALERT_RULE_TYPE_ID]: string; + [ALERT_RULE_UUID]: string; + [SPACE_IDS]: string[]; + [ALERT_RULE_TAGS]: string[]; + [TIMESTAMP]: string; +} + +export type CommonAlertFieldName800 = keyof CommonAlertFields800; + +export type AlertWithCommonFields800 = T & CommonAlertFields800; diff --git a/x-pack/plugins/rule_registry/common/schemas/README.md b/x-pack/plugins/rule_registry/common/schemas/README.md new file mode 100644 index 0000000000000..7995cd8aab0e7 --- /dev/null +++ b/x-pack/plugins/rule_registry/common/schemas/README.md @@ -0,0 +1 @@ +See x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/README.md for full description of versioned alert schema strategy and how it's used in the Security Solution's Detection Engine. diff --git a/x-pack/plugins/rule_registry/common/schemas/index.ts b/x-pack/plugins/rule_registry/common/schemas/index.ts new file mode 100644 index 0000000000000..e12c59617fd00 --- /dev/null +++ b/x-pack/plugins/rule_registry/common/schemas/index.ts @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { + CommonAlertFieldName800, + CommonAlertIdFieldName800, + CommonAlertFields800, + AlertWithCommonFields800, +} from './8.0.0'; + +export type { + CommonAlertFieldName800 as CommonAlertFieldNameLatest, + CommonAlertIdFieldName800 as CommonAlertIdFieldNameLatest, + CommonAlertFields800 as CommonAlertFieldsLatest, + AlertWithCommonFields800 as AlertWithCommonFieldsLatest, +}; diff --git a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts index c9912b0e29438..9f79768416e27 100644 --- a/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts +++ b/x-pack/plugins/rule_registry/server/utils/create_lifecycle_executor.ts @@ -37,16 +37,13 @@ import { TIMESTAMP, VERSION, } from '../../common/technical_rule_data_field_names'; +import { CommonAlertFieldNameLatest, CommonAlertIdFieldNameLatest } from '../../common/schemas'; import { IRuleDataClient } from '../rule_data_client'; import { AlertExecutorOptionsWithExtraServices } from '../types'; import { fetchExistingAlerts } from './fetch_existing_alerts'; -import { - CommonAlertFieldName, - CommonAlertIdFieldName, - getCommonAlertFields, -} from './get_common_alert_fields'; +import { getCommonAlertFields } from './get_common_alert_fields'; -type ImplicitTechnicalFieldName = CommonAlertFieldName | CommonAlertIdFieldName; +type ImplicitTechnicalFieldName = CommonAlertFieldNameLatest | CommonAlertIdFieldNameLatest; type ExplicitTechnicalAlertFields = Partial< Omit diff --git a/x-pack/plugins/rule_registry/server/utils/get_common_alert_fields.ts b/x-pack/plugins/rule_registry/server/utils/get_common_alert_fields.ts index db8c56f84b2c4..a4f429c634dc9 100644 --- a/x-pack/plugins/rule_registry/server/utils/get_common_alert_fields.ts +++ b/x-pack/plugins/rule_registry/server/utils/get_common_alert_fields.ts @@ -5,10 +5,7 @@ * 2.0. */ -import { Values } from '@kbn/utility-types'; import { - ALERT_INSTANCE_ID, - ALERT_UUID, ALERT_RULE_CATEGORY, ALERT_RULE_CONSUMER, ALERT_RULE_EXECUTION_UUID, @@ -22,30 +19,11 @@ import { } from '@kbn/rule-data-utils'; import { AlertExecutorOptions } from '../../../alerting/server'; -import { ParsedTechnicalFields } from '../../common/parse_technical_fields'; - -const commonAlertFieldNames = [ - ALERT_RULE_CATEGORY, - ALERT_RULE_CONSUMER, - ALERT_RULE_EXECUTION_UUID, - ALERT_RULE_NAME, - ALERT_RULE_PRODUCER, - ALERT_RULE_TYPE_ID, - ALERT_RULE_UUID, - SPACE_IDS, - ALERT_RULE_TAGS, - TIMESTAMP, -]; -export type CommonAlertFieldName = Values; - -const commonAlertIdFieldNames = [ALERT_INSTANCE_ID, ALERT_UUID]; -export type CommonAlertIdFieldName = Values; - -export type CommonAlertFields = Pick; +import { CommonAlertFieldsLatest } from '../../common/schemas'; export const getCommonAlertFields = ( options: AlertExecutorOptions -): CommonAlertFields => { +): CommonAlertFieldsLatest => { return { [ALERT_RULE_CATEGORY]: options.rule.ruleTypeName, [ALERT_RULE_CONSUMER]: options.rule.consumer, diff --git a/x-pack/plugins/rule_registry/server/utils/persistence_types.ts b/x-pack/plugins/rule_registry/server/utils/persistence_types.ts index 70e37dd20e34d..5c80d60ee5118 100644 --- a/x-pack/plugins/rule_registry/server/utils/persistence_types.ts +++ b/x-pack/plugins/rule_registry/server/utils/persistence_types.ts @@ -17,6 +17,7 @@ import { import { WithoutReservedActionGroups } from '../../../alerting/common'; import { IRuleDataClient } from '../rule_data_client'; import { BulkResponseErrorAggregation } from './utils'; +import { AlertWithCommonFieldsLatest } from '../../common/schemas'; export type PersistenceAlertService = ( alerts: Array<{ @@ -27,7 +28,7 @@ export type PersistenceAlertService = ( ) => Promise>; export interface PersistenceAlertServiceResult { - createdAlerts: Array; + createdAlerts: Array & { _id: string; _index: string }>; errors: BulkResponseErrorAggregation; } diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/8.0.0/index.ts b/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/8.0.0/index.ts new file mode 100644 index 0000000000000..f695aad1eb125 --- /dev/null +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/8.0.0/index.ts @@ -0,0 +1,178 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { + ALERT_BUILDING_BLOCK_TYPE, + ALERT_REASON, + ALERT_RISK_SCORE, + ALERT_RULE_AUTHOR, + ALERT_RULE_CONSUMER, + ALERT_RULE_CREATED_AT, + ALERT_RULE_CREATED_BY, + ALERT_RULE_DESCRIPTION, + ALERT_RULE_ENABLED, + ALERT_RULE_FROM, + ALERT_RULE_INTERVAL, + ALERT_RULE_LICENSE, + ALERT_RULE_NAME, + ALERT_RULE_NAMESPACE_FIELD, + ALERT_RULE_NOTE, + ALERT_RULE_PARAMETERS, + ALERT_RULE_REFERENCES, + ALERT_RULE_RULE_ID, + ALERT_RULE_RULE_NAME_OVERRIDE, + ALERT_RULE_TAGS, + ALERT_RULE_TO, + ALERT_RULE_TYPE, + ALERT_RULE_UPDATED_AT, + ALERT_RULE_UPDATED_BY, + ALERT_RULE_UUID, + ALERT_RULE_VERSION, + ALERT_SEVERITY, + ALERT_STATUS, + ALERT_UUID, + ALERT_WORKFLOW_STATUS, + EVENT_KIND, + SPACE_IDS, + TIMESTAMP, +} from '@kbn/rule-data-utils'; +// TODO: Create and import 8.0.0 versioned ListArray schema +import { ListArray } from '@kbn/securitysolution-io-ts-list-types'; +// TODO: Create and import 8.0.0 versioned alerting-types schemas +import { + RiskScoreMapping, + SeverityMapping, + Threats, + Type, +} from '@kbn/securitysolution-io-ts-alerting-types'; +import { + ALERT_ANCESTORS, + ALERT_DEPTH, + ALERT_ORIGINAL_TIME, + ALERT_RULE_ACTIONS, + ALERT_RULE_EXCEPTIONS_LIST, + ALERT_RULE_FALSE_POSITIVES, + ALERT_GROUP_ID, + ALERT_GROUP_INDEX, + ALERT_RULE_IMMUTABLE, + ALERT_RULE_MAX_SIGNALS, + ALERT_RULE_RISK_SCORE_MAPPING, + ALERT_RULE_SEVERITY_MAPPING, + ALERT_RULE_THREAT, + ALERT_RULE_THROTTLE, + ALERT_RULE_TIMELINE_ID, + ALERT_RULE_TIMELINE_TITLE, + ALERT_RULE_TIMESTAMP_OVERRIDE, +} from '../../../../field_maps/field_names'; +// TODO: Create and import 8.0.0 versioned RuleAlertAction type +import { RuleAlertAction, SearchTypes } from '../../../types'; +import { AlertWithCommonFields800 } from '../../../../../../rule_registry/common/schemas/8.0.0'; + +/* DO NOT MODIFY THIS SCHEMA TO ADD NEW FIELDS. These types represent the alerts that shipped in 8.0.0. +Any changes to these types should be bug fixes so the types more accurately represent the alerts from 8.0.0. + +If you are adding new fields for a new release of Kibana, create a new sibling folder to this one +for the version to be released and add the field(s) to the schema in that folder. + +Then, update `../index.ts` to import from the new folder that has the latest schemas, add the +new schemas to the union of all alert schemas, and re-export the new schemas as the `*Latest` schemas. +*/ + +export interface Ancestor800 { + rule: string | undefined; + id: string; + type: string; + index: string; + depth: number; +} + +export interface BaseFields800 { + [TIMESTAMP]: string; + [SPACE_IDS]: string[]; + [EVENT_KIND]: 'signal'; + [ALERT_ORIGINAL_TIME]: string | undefined; + // When we address https://github.com/elastic/kibana/issues/102395 and change ID generation logic, consider moving + // ALERT_UUID creation into buildAlert and keep ALERT_UUID with the rest of BaseFields fields. As of 8.2 though, + // ID generation logic is fragmented and it would be more confusing to put any of it in buildAlert + // [ALERT_UUID]: string; + [ALERT_RULE_CONSUMER]: string; + [ALERT_ANCESTORS]: Ancestor800[]; + [ALERT_STATUS]: string; + [ALERT_WORKFLOW_STATUS]: string; + [ALERT_DEPTH]: number; + [ALERT_REASON]: string; + [ALERT_BUILDING_BLOCK_TYPE]: string | undefined; + [ALERT_SEVERITY]: string; + [ALERT_RISK_SCORE]: number; + // TODO: version rule schemas and pull in 8.0.0 versioned rule schema to define alert rule parameters type + [ALERT_RULE_PARAMETERS]: { [key: string]: SearchTypes }; + [ALERT_RULE_ACTIONS]: RuleAlertAction[]; + [ALERT_RULE_AUTHOR]: string[]; + [ALERT_RULE_CREATED_AT]: string; + [ALERT_RULE_CREATED_BY]: string; + [ALERT_RULE_DESCRIPTION]: string; + [ALERT_RULE_ENABLED]: boolean; + [ALERT_RULE_EXCEPTIONS_LIST]: ListArray; + [ALERT_RULE_FALSE_POSITIVES]: string[]; + [ALERT_RULE_FROM]: string; + [ALERT_RULE_IMMUTABLE]: boolean; + [ALERT_RULE_INTERVAL]: string; + [ALERT_RULE_LICENSE]: string | undefined; + [ALERT_RULE_MAX_SIGNALS]: number; + [ALERT_RULE_NAME]: string; + [ALERT_RULE_NAMESPACE_FIELD]: string | undefined; + [ALERT_RULE_NOTE]: string | undefined; + [ALERT_RULE_REFERENCES]: string[]; + [ALERT_RULE_RISK_SCORE_MAPPING]: RiskScoreMapping; + [ALERT_RULE_RULE_ID]: string; + [ALERT_RULE_RULE_NAME_OVERRIDE]: string | undefined; + [ALERT_RULE_SEVERITY_MAPPING]: SeverityMapping; + [ALERT_RULE_TAGS]: string[]; + [ALERT_RULE_THREAT]: Threats; + [ALERT_RULE_THROTTLE]: string | undefined; + [ALERT_RULE_TIMELINE_ID]: string | undefined; + [ALERT_RULE_TIMELINE_TITLE]: string | undefined; + [ALERT_RULE_TIMESTAMP_OVERRIDE]: string | undefined; + [ALERT_RULE_TO]: string; + [ALERT_RULE_TYPE]: Type; + [ALERT_RULE_UPDATED_AT]: string; + [ALERT_RULE_UPDATED_BY]: string; + [ALERT_RULE_UUID]: string; + [ALERT_RULE_VERSION]: number; + 'kibana.alert.rule.risk_score': number; + 'kibana.alert.rule.severity': string; + 'kibana.alert.rule.building_block_type': string | undefined; + [key: string]: SearchTypes; +} + +// This type is used after the alert UUID is generated and stored in the _id and ALERT_UUID fields +export interface WrappedFields800 { + _id: string; + _index: string; + _source: T & { [ALERT_UUID]: string }; +} + +export interface EqlBuildingBlockFields800 extends BaseFields800 { + [ALERT_GROUP_ID]: string; + [ALERT_GROUP_INDEX]: number; + [ALERT_BUILDING_BLOCK_TYPE]: 'default'; +} + +export interface EqlShellFields800 extends BaseFields800 { + [ALERT_GROUP_ID]: string; + [ALERT_UUID]: string; +} + +export type EqlBuildingBlockAlert800 = AlertWithCommonFields800; + +export type EqlShellAlert800 = AlertWithCommonFields800; + +export type GenericAlert800 = AlertWithCommonFields800; + +// This is the type of the final generated alert including base fields, common fields +// added by the alertWithPersistence function, and arbitrary fields copied from source documents +export type DetectionAlert800 = GenericAlert800 | EqlShellAlert800 | EqlBuildingBlockAlert800; diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/README.md b/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/README.md new file mode 100644 index 0000000000000..c7acf84813f08 --- /dev/null +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/README.md @@ -0,0 +1,54 @@ +# Summary + +Original PR: https://github.com/elastic/kibana/pull/127218 +The goal here is to create a system of schemas that are: + +- Easy to read +- Usable historical records of alert schemas from previous Kibana versions +- Accurate for every field +- Usable on both server and client side + +# Motivation - Development speed and quality + +We have already run into one bug (https://github.com/elastic/kibana/issues/125885) where a required field was not populated in some alert documents. Once a bug ships that creates documents incorrectly, any fix requires user action to initiate a re-index of the alerts in addition to the developer time to create and validate the fix. The changes proposed here would catch this bug at compile time. These sorts of bugs become harder to catch as the schema evolves over time and fields get added, removed, and changed. Keeping the schemas separated by version will help reduce the risk of repeated schema changes over time causing fields to be incorrectly included in or omitted from alert documents. + +We are also spending more time than necessary communicating details of the alerts schema over Slack and Zoom. It will be far more efficient for the code to clearly communicate more details about the alert schema. With a more comprehensive static schema, the knowledge will transfer to new developers more efficiently. + +Static types are a powerful tool for ensuring code correctness. However, each deviation of the static type from the actual runtime structure adds places where developers may need to cast, assert, or use conditional logic to satisfy the compiler. The current static types require frequent workarounds when the static types don't match what developers know or believe is true about the runtime type of the alert documents. These runtime workarounds establish patterns that evade the type system - costing developer time to create and maintain in addition to increasing the risk of bugs due to the additional complexity. Accurate static types are excellent documentation of the data structures we use but it's crucial that the static types are comprehensive to minimize cases where runtime checks are needed. + +# Structure - Common Alert Schema Directory + +The schemas in this directory have 2 primary purposes: (1) separate the alert document schemas from the FieldMaps, and (2) set up a code structure that enables easy versioning of alert schemas. During the Detection Engine migration to the rule registry we used the FieldMaps to define the alert schema, but ended up with numerous type casts and some bugs in the process. This common directory stores the various alert schemas by Kibana version. + +x-pack/plugins/security_solution/common/detection_engine/schemas/alerts initially contains index.ts and one folder, 8.0.0. index.ts imports the schemas from 8.0.0 and re-exports them as ...Latest, denoting that those are the "write" schemas. The reason for this is that as we add new schemas, there are many places server side where we want to ensure that we're writing the latest alert schema. By having index.ts re-export 8.0.0 schemas, when we add make a new alert schema in the future (e.g. adding an additional field in 8.x) we can simply update index.ts to re-export the new schema instead of the previous schema. index.ts also exports a DetectionAlert which is the "read" schema - this type will be maintained as a union of all versioned alert schemas, which is needed to accurately type alerts that are read from the alerts index. + +## Reading vs writing alerts + +When writing code that deals with creating a new alert document, always use the schema from alerts/index.ts, not from a specific version folder. This way when the schema is updated in the future, your code will automatically use the latest alert schema and the static type system will tell us if code is writing alerts that don't conform to the new schema. + +When writing code that deals with reading alerts, it must be able to handle alerts from any schema version. The "read schema" in index.ts DetectionAlert is a union of all of the versioned alert schemas since a valid alert from the .alerts index could be from any version. Initially there is only one versioned schema, so DetectionAlert is identical to DetectionAlert800. + +Generally, Solution code should not be directly importing alert schemas from a specific version. Alert writing code should use the latest schema, and alert reading code should use the union of all schemas. + +## Adding new schemas + +In the future, when we want to add new fields, we should create a new folder named with the version the field is being added in, create the updated schema in the new folder, and update index.ts to re-export the schemas for the new version instead of the previous version. Also, update the "read schema" DetectionAlert type in index.ts to include the new schema in addition to the previous schemas. The schema in the new version folder can either build on the previous version, e.g. 8.4.0 could import the schema from 8.0.0 and simply add a few new fields, or for larger changes the new version could build the schema from scratch. Old schemas should not change when new fields are added! + +## Changing existing schemas + +The schema in the 8.0.0 folder, and any future versioned folders after the version is released, should not be updated with new fields. Old schemas should only be updated if a bug is discovered and it is determined that the schema does not accurately represent the alert documents that were actually written by that version, e.g. if a field is typed as string in the schema but was actually written as string[]. The goal of these schemas is to represent documents accurately as they were written and since we aren't changing the documents that already exist, the schema should generally not change. + +## No changes + +If a version of Kibana makes no changes to the schema, a new folder for that version is not needed. + +# Design decisions + +- Why not combine the FieldMaps and alert schema, creating a single structure that can define both? + FieldMaps are integrated tightly with Elasticsearch mappings already, with minimal support for accurate TypeScript types of the fields. We want to avoid adding tons of extra information in to the FieldMaps that would not be used for the Elasticsearch mappings. Instead later we can write a bit of code to ensure that the alert schemas are compatible with the FieldMap schemas, essentially ensuring that the alert schemas extend the FieldMap schemas. + +- Why is | undefined used in field definitions instead of making fields optional? + Making all fields required, but some | undefined in the type, helps ensure that we don't forget to copy over fields that may be undefined. If the field is optional, e.g. [ALERT_RULE_NOTE]?: string, then the compiler won't complain if the field is completely left out when we build the alert document. However, when it's defined as [ALERT_RULE_NOTE]: string | undefined instead, the field must be explicitly provided when creating an object literal of the alert type - even if the value is undefined. This makes it harder to forget to populate all of the fields. This can be seen in build_alert.ts where removing one of the optional fields from the return value results in a compiler error. + +- Why do we need to version the schemas instead of adding all new fields as | undefined? + Adding new fields as | undefined when they're actually required reduces the accuracy of the schema, which makes it less useful and harder to work with. If we decide to add a new field and always populate it going forward then accurately representing that in the static type makes it easier to work with alerts during the alert creation process. When a field is typed as | undefined but a developer knows that it should always exist, it encourages patterns that fight the type system through type-casting, assertions, using ?? , etc. This makes the code harder to read, harder to reason about, and thus harder to maintain because the knowledge of "this field is typed as | undefined but actually always exists here" is not represented in the code and only lives in developers minds. Versioned alert schemas aim to turn the static types into an asset that precisely documents what the alert document structure is. diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/index.ts b/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/index.ts new file mode 100644 index 0000000000000..51b5c505b817a --- /dev/null +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/alerts/index.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import type { + Ancestor800, + BaseFields800, + DetectionAlert800, + WrappedFields800, + EqlBuildingBlockFields800, + EqlShellFields800, +} from './8.0.0'; + +// When new Alert schemas are created for new Kibana versions, add the DetectionAlert type from the new version +// here, e.g. `export type DetectionAlert = DetectionAlert800 | DetectionAlert820` if a new schema is created in 8.2.0 +export type DetectionAlert = DetectionAlert800; + +export type { + Ancestor800 as AncestorLatest, + BaseFields800 as BaseFieldsLatest, + DetectionAlert800 as DetectionAlertLatest, + WrappedFields800 as WrappedFieldsLatest, + EqlBuildingBlockFields800 as EqlBuildingBlockFieldsLatest, + EqlShellFields800 as EqlShellFieldsLatest, +}; diff --git a/x-pack/plugins/security_solution/common/detection_engine/schemas/request/rule_schemas.ts b/x-pack/plugins/security_solution/common/detection_engine/schemas/request/rule_schemas.ts index 950460580925e..69a748c3bd95c 100644 --- a/x-pack/plugins/security_solution/common/detection_engine/schemas/request/rule_schemas.ts +++ b/x-pack/plugins/security_solution/common/detection_engine/schemas/request/rule_schemas.ts @@ -219,7 +219,7 @@ const { patch: eqlPatchParams, response: eqlResponseParams, } = buildAPISchemas(eqlRuleParams); -export { eqlCreateParams }; +export { eqlCreateParams, eqlResponseParams }; const threatMatchRuleParams = { required: { diff --git a/x-pack/plugins/security_solution/common/field_maps/alerts.ts b/x-pack/plugins/security_solution/common/field_maps/8.0.0/alerts.ts similarity index 97% rename from x-pack/plugins/security_solution/common/field_maps/alerts.ts rename to x-pack/plugins/security_solution/common/field_maps/8.0.0/alerts.ts index 330f85a8a8343..0694c15551efc 100644 --- a/x-pack/plugins/security_solution/common/field_maps/alerts.ts +++ b/x-pack/plugins/security_solution/common/field_maps/8.0.0/alerts.ts @@ -5,9 +5,7 @@ * 2.0. */ -import { FieldMap } from '../../../rule_registry/common/field_map'; - -export const alertsFieldMap: FieldMap = { +export const alertsFieldMap = { 'kibana.alert.ancestors': { type: 'object', array: true, diff --git a/x-pack/plugins/security_solution/common/field_maps/8.0.0/index.ts b/x-pack/plugins/security_solution/common/field_maps/8.0.0/index.ts new file mode 100644 index 0000000000000..e293dac663816 --- /dev/null +++ b/x-pack/plugins/security_solution/common/field_maps/8.0.0/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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { AlertsFieldMap, alertsFieldMap } from './alerts'; +import { RulesFieldMap, rulesFieldMap } from './rules'; +export type { AlertsFieldMap, RulesFieldMap }; +export { alertsFieldMap, rulesFieldMap }; diff --git a/x-pack/plugins/security_solution/common/field_maps/rules.ts b/x-pack/plugins/security_solution/common/field_maps/8.0.0/rules.ts similarity index 100% rename from x-pack/plugins/security_solution/common/field_maps/rules.ts rename to x-pack/plugins/security_solution/common/field_maps/8.0.0/rules.ts diff --git a/x-pack/plugins/security_solution/common/field_maps/field_names.ts b/x-pack/plugins/security_solution/common/field_maps/field_names.ts index 1cb40063202d0..164f87b4e7b5c 100644 --- a/x-pack/plugins/security_solution/common/field_maps/field_names.ts +++ b/x-pack/plugins/security_solution/common/field_maps/field_names.ts @@ -23,6 +23,18 @@ export const ALERT_ORIGINAL_EVENT_KIND = `${ALERT_ORIGINAL_EVENT}.kind` as const export const ALERT_ORIGINAL_EVENT_MODULE = `${ALERT_ORIGINAL_EVENT}.module` as const; export const ALERT_ORIGINAL_EVENT_TYPE = `${ALERT_ORIGINAL_EVENT}.type` as const; +export const ALERT_RULE_ACTIONS = `${ALERT_RULE_NAMESPACE}.actions` as const; +export const ALERT_RULE_EXCEPTIONS_LIST = `${ALERT_RULE_NAMESPACE}.exceptions_list` as const; +export const ALERT_RULE_FALSE_POSITIVES = `${ALERT_RULE_NAMESPACE}.false_positives` as const; +export const ALERT_RULE_IMMUTABLE = `${ALERT_RULE_NAMESPACE}.immutable` as const; +export const ALERT_RULE_MAX_SIGNALS = `${ALERT_RULE_NAMESPACE}.max_signals` as const; +export const ALERT_RULE_META = `${ALERT_RULE_NAMESPACE}.meta` as const; +export const ALERT_RULE_RISK_SCORE_MAPPING = `${ALERT_RULE_NAMESPACE}.risk_score_mapping` as const; +export const ALERT_RULE_SEVERITY_MAPPING = `${ALERT_RULE_NAMESPACE}.severity_mapping` as const; +export const ALERT_RULE_THREAT = `${ALERT_RULE_NAMESPACE}.threat` as const; export const ALERT_RULE_THRESHOLD = `${ALERT_RULE_NAMESPACE}.threshold` as const; export const ALERT_RULE_THRESHOLD_FIELD = `${ALERT_RULE_THRESHOLD}.field` as const; +export const ALERT_RULE_THROTTLE = `${ALERT_RULE_NAMESPACE}.throttle` as const; export const ALERT_RULE_TIMELINE_ID = `${ALERT_RULE_NAMESPACE}.timeline_id` as const; +export const ALERT_RULE_TIMELINE_TITLE = `${ALERT_RULE_NAMESPACE}.timeline_title` as const; +export const ALERT_RULE_TIMESTAMP_OVERRIDE = `${ALERT_RULE_NAMESPACE}.timestamp_override` as const; diff --git a/x-pack/plugins/security_solution/common/field_maps/index.ts b/x-pack/plugins/security_solution/common/field_maps/index.ts index e293dac663816..260b56ffe9141 100644 --- a/x-pack/plugins/security_solution/common/field_maps/index.ts +++ b/x-pack/plugins/security_solution/common/field_maps/index.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { AlertsFieldMap, alertsFieldMap } from './alerts'; -import { RulesFieldMap, rulesFieldMap } from './rules'; +import { AlertsFieldMap, alertsFieldMap } from './8.0.0/alerts'; +import { RulesFieldMap, rulesFieldMap } from './8.0.0/rules'; export type { AlertsFieldMap, RulesFieldMap }; export { alertsFieldMap, rulesFieldMap }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/schedule_notification_actions.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/schedule_notification_actions.ts index 394e431203a24..d4cc8385429da 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/schedule_notification_actions.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/schedule_notification_actions.ts @@ -10,15 +10,15 @@ import { Alert } from '../../../../../alerting/server'; import { expandDottedObject } from '../../../../common/utils/expand_dotted'; import { RuleParams } from '../schemas/rule_schemas'; import aadFieldConversion from '../routes/index/signal_aad_mapping.json'; -import { isRACAlert } from '../signals/utils'; -import { RACAlert } from '../rule_types/types'; +import { isDetectionAlert } from '../signals/utils'; +import { DetectionAlert } from '../../../../common/detection_engine/schemas/alerts'; export type NotificationRuleTypeParams = RuleParams & { id: string; name: string; }; -const convertToLegacyAlert = (alert: RACAlert) => +const convertToLegacyAlert = (alert: DetectionAlert) => Object.entries(aadFieldConversion).reduce((acc, [legacyField, aadField]) => { const val = alert[aadField]; if (val != null) { @@ -36,7 +36,7 @@ const convertToLegacyAlert = (alert: RACAlert) => */ const formatAlertsForNotificationActions = (alerts: unknown[]): unknown[] => { return alerts.map((alert) => - isRACAlert(alert) + isDetectionAlert(alert) ? { ...expandDottedObject(convertToLegacyAlert(alert)), ...expandDottedObject(alert), diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/bulk_create_factory.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/bulk_create_factory.ts index efe02f2ec6b7a..60a3be4b5345f 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/bulk_create_factory.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/bulk_create_factory.ts @@ -9,17 +9,21 @@ import { performance } from 'perf_hooks'; import { isEmpty } from 'lodash'; import { Logger } from 'kibana/server'; -import { BaseHit } from '../../../../../common/detection_engine/types'; import { BuildRuleMessage } from '../../signals/rule_messages'; import { makeFloatString } from '../../signals/utils'; import { RefreshTypes } from '../../types'; import { PersistenceAlertService } from '../../../../../../rule_registry/server'; +import { + BaseFieldsLatest, + WrappedFieldsLatest, +} from '../../../../../common/detection_engine/schemas/alerts'; +import { AlertWithCommonFieldsLatest } from '../../../../../../rule_registry/common/schemas'; -export interface GenericBulkCreateResponse { +export interface GenericBulkCreateResponse { success: boolean; bulkCreateDuration: string; createdItemsCount: number; - createdItems: Array; + createdItems: Array & { _id: string; _index: string }>; errors: string[]; } @@ -30,8 +34,8 @@ export const bulkCreateFactory = buildRuleMessage: BuildRuleMessage, refreshForBulkCreate: RefreshTypes ) => - async >( - wrappedDocs: Array> + async ( + wrappedDocs: Array> ): Promise> => { if (wrappedDocs.length === 0) { return { diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.test.ts index a39c5f77bc289..5768306999f79 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.test.ts @@ -65,6 +65,7 @@ describe('buildAlert', () => { const timestamp = alert[TIMESTAMP]; const expected = { [TIMESTAMP]: timestamp, + [EVENT_KIND]: 'signal', [SPACE_IDS]: [SPACE_ID], [ALERT_RULE_CONSUMER]: SERVER_APP_ID, [ALERT_ANCESTORS]: [ @@ -235,6 +236,7 @@ describe('buildAlert', () => { const expected = { [TIMESTAMP]: timestamp, + [EVENT_KIND]: 'signal', [SPACE_IDS]: [SPACE_ID], [ALERT_RULE_CONSUMER]: SERVER_APP_ID, [ALERT_ANCESTORS]: [ diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.ts index 07f2dfa31015c..e1259be5062a0 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert.ts @@ -8,14 +8,34 @@ import { ALERT_REASON, ALERT_RISK_SCORE, + ALERT_RULE_AUTHOR, ALERT_RULE_CONSUMER, - ALERT_RULE_NAMESPACE, + ALERT_RULE_CREATED_AT, + ALERT_RULE_CREATED_BY, + ALERT_RULE_DESCRIPTION, + ALERT_RULE_ENABLED, + ALERT_RULE_FROM, + ALERT_RULE_INTERVAL, + ALERT_RULE_LICENSE, + ALERT_RULE_NAME, + ALERT_RULE_NAMESPACE_FIELD, + ALERT_RULE_NOTE, ALERT_RULE_PARAMETERS, + ALERT_RULE_REFERENCES, + ALERT_RULE_RULE_ID, + ALERT_RULE_RULE_NAME_OVERRIDE, + ALERT_RULE_TAGS, + ALERT_RULE_TO, + ALERT_RULE_TYPE, + ALERT_RULE_UPDATED_AT, + ALERT_RULE_UPDATED_BY, ALERT_RULE_UUID, + ALERT_RULE_VERSION, ALERT_SEVERITY, ALERT_STATUS, ALERT_STATUS_ACTIVE, ALERT_WORKFLOW_STATUS, + EVENT_KIND, SPACE_IDS, TIMESTAMP, } from '@kbn/rule-data-utils'; @@ -23,14 +43,13 @@ import { flattenWithPrefix } from '@kbn/securitysolution-rules'; import { createHash } from 'crypto'; -import { Ancestor, BaseSignalHit, SimpleHit, ThresholdResult } from '../../../signals/types'; +import { BaseSignalHit, SimpleHit, ThresholdResult } from '../../../signals/types'; import { getField, getValidDateFromDoc, - isWrappedRACAlert, + isWrappedDetectionAlert, isWrappedSignalHit, } from '../../../signals/utils'; -import { RACAlert } from '../../types'; import { SERVER_APP_ID } from '../../../../../../common/constants'; import { SearchTypes } from '../../../../telemetry/types'; import { @@ -40,6 +59,19 @@ import { ALERT_THRESHOLD_RESULT, ALERT_ORIGINAL_EVENT, ALERT_BUILDING_BLOCK_TYPE, + ALERT_RULE_ACTIONS, + ALERT_RULE_THROTTLE, + ALERT_RULE_TIMELINE_ID, + ALERT_RULE_TIMELINE_TITLE, + ALERT_RULE_META, + ALERT_RULE_TIMESTAMP_OVERRIDE, + ALERT_RULE_FALSE_POSITIVES, + ALERT_RULE_MAX_SIGNALS, + ALERT_RULE_RISK_SCORE_MAPPING, + ALERT_RULE_SEVERITY_MAPPING, + ALERT_RULE_THREAT, + ALERT_RULE_EXCEPTIONS_LIST, + ALERT_RULE_IMMUTABLE, } from '../../../../../../common/field_maps/field_names'; import { CompleteRule, RuleParams } from '../../../schemas/rule_schemas'; import { @@ -48,13 +80,18 @@ import { } from '../../../schemas/rule_converters'; import { transformTags } from '../../../routes/rules/utils'; import { transformAlertToRuleAction } from '../../../../../../common/detection_engine/transform_actions'; +import { + AncestorLatest, + BaseFieldsLatest, +} from '../../../../../../common/detection_engine/schemas/alerts'; -export const generateAlertId = (alert: RACAlert) => { +export const generateAlertId = (alert: BaseFieldsLatest) => { return createHash('sha256') .update( - (alert[ALERT_ANCESTORS] as Ancestor[]) - .reduce((acc, ancestor) => acc.concat(ancestor.id, ancestor.index), '') - .concat(alert[ALERT_RULE_UUID] as string) + alert[ALERT_ANCESTORS].reduce( + (acc, ancestor) => acc.concat(ancestor.id, ancestor.index), + '' + ).concat(alert[ALERT_RULE_UUID]) ) .digest('hex'); }; @@ -64,17 +101,15 @@ export const generateAlertId = (alert: RACAlert) => { * alert's ancestors array. * @param doc The parent event */ -export const buildParent = (doc: SimpleHit): Ancestor => { - const isSignal: boolean = isWrappedSignalHit(doc) || isWrappedRACAlert(doc); - const parent: Ancestor = { +export const buildParent = (doc: SimpleHit): AncestorLatest => { + const isSignal: boolean = isWrappedSignalHit(doc) || isWrappedDetectionAlert(doc); + const parent: AncestorLatest = { id: doc._id, type: isSignal ? 'signal' : 'event', index: doc._index, - depth: isSignal ? getField(doc, ALERT_DEPTH) ?? 1 : 0, + depth: isSignal ? (getField(doc, ALERT_DEPTH) as number | undefined) ?? 1 : 0, + rule: isSignal ? (getField(doc, ALERT_RULE_UUID) as string) : undefined, }; - if (isSignal) { - parent.rule = getField(doc, ALERT_RULE_UUID); - } return parent; }; @@ -83,9 +118,10 @@ export const buildParent = (doc: SimpleHit): Ancestor => { * creating an array of N+1 ancestors. * @param doc The parent event for which to extend the ancestry. */ -export const buildAncestors = (doc: SimpleHit): Ancestor[] => { +export const buildAncestors = (doc: SimpleHit): AncestorLatest[] => { const newAncestor = buildParent(doc); - const existingAncestors: Ancestor[] = getField(doc, ALERT_ANCESTORS) ?? []; + const existingAncestors: AncestorLatest[] = + (getField(doc, ALERT_ANCESTORS) as AncestorLatest[] | undefined) ?? []; return [...existingAncestors, newAncestor]; }; @@ -106,10 +142,13 @@ export const buildAlert = ( severityOverride: string; riskScoreOverride: number; } -): RACAlert => { +): BaseFieldsLatest => { const parents = docs.map(buildParent); const depth = parents.reduce((acc, parent) => Math.max(parent.depth, acc), 0) + 1; - const ancestors = docs.reduce((acc: Ancestor[], doc) => acc.concat(buildAncestors(doc)), []); + const ancestors = docs.reduce( + (acc: AncestorLatest[], doc) => acc.concat(buildAncestors(doc)), + [] + ); const { output_index: outputIndex, ...commonRuleParams } = commonParamsCamelToSnake( completeRule.ruleParams @@ -133,35 +172,67 @@ export const buildAlert = ( updatedAt, } = completeRule.ruleConfig; + const params = completeRule.ruleParams; + + const originalTime = getValidDateFromDoc({ + doc: docs[0], + timestampOverride: undefined, + }); + return { [TIMESTAMP]: new Date().toISOString(), - [ALERT_RULE_CONSUMER]: SERVER_APP_ID, [SPACE_IDS]: spaceId != null ? [spaceId] : [], + [EVENT_KIND]: 'signal', + [ALERT_ORIGINAL_TIME]: originalTime?.toISOString(), + [ALERT_RULE_CONSUMER]: SERVER_APP_ID, [ALERT_ANCESTORS]: ancestors, [ALERT_STATUS]: ALERT_STATUS_ACTIVE, [ALERT_WORKFLOW_STATUS]: 'open', [ALERT_DEPTH]: depth, [ALERT_REASON]: reason, - [ALERT_BUILDING_BLOCK_TYPE]: completeRule.ruleParams.buildingBlockType, - [ALERT_SEVERITY]: overrides?.severityOverride ?? completeRule.ruleParams.severity, - [ALERT_RISK_SCORE]: overrides?.riskScoreOverride ?? completeRule.ruleParams.riskScore, + [ALERT_BUILDING_BLOCK_TYPE]: params.buildingBlockType, + [ALERT_SEVERITY]: overrides?.severityOverride ?? params.severity, + [ALERT_RISK_SCORE]: overrides?.riskScoreOverride ?? params.riskScore, [ALERT_RULE_PARAMETERS]: ruleParamsSnakeCase, - ...flattenWithPrefix(ALERT_RULE_NAMESPACE, { - uuid: completeRule.alertId, - actions: actions.map(transformAlertToRuleAction), - created_at: createdAt.toISOString(), - created_by: createdBy ?? '', - enabled, - interval: schedule.interval, - name: overrides?.nameOverride ?? name, - tags: transformTags(tags), - throttle: throttle ?? undefined, - updated_at: updatedAt.toISOString(), - updated_by: updatedBy ?? '', - type: completeRule.ruleParams.type, - ...commonRuleParams, - }), - } as unknown as RACAlert; + [ALERT_RULE_ACTIONS]: actions.map(transformAlertToRuleAction), + [ALERT_RULE_AUTHOR]: params.author, + [ALERT_RULE_CREATED_AT]: createdAt.toISOString(), + [ALERT_RULE_CREATED_BY]: createdBy ?? '', + [ALERT_RULE_DESCRIPTION]: params.description, + [ALERT_RULE_ENABLED]: enabled, + [ALERT_RULE_EXCEPTIONS_LIST]: params.exceptionsList, + [ALERT_RULE_FALSE_POSITIVES]: params.falsePositives, + [ALERT_RULE_FROM]: params.from, + [ALERT_RULE_IMMUTABLE]: params.immutable, + [ALERT_RULE_INTERVAL]: schedule.interval, + [ALERT_RULE_LICENSE]: params.license, + [ALERT_RULE_MAX_SIGNALS]: params.maxSignals, + [ALERT_RULE_NAME]: overrides?.nameOverride ?? name, + [ALERT_RULE_NAMESPACE_FIELD]: params.namespace, + [ALERT_RULE_NOTE]: params.note, + [ALERT_RULE_REFERENCES]: params.references, + [ALERT_RULE_RISK_SCORE_MAPPING]: params.riskScoreMapping, + [ALERT_RULE_RULE_ID]: params.ruleId, + [ALERT_RULE_RULE_NAME_OVERRIDE]: params.ruleNameOverride, + [ALERT_RULE_SEVERITY_MAPPING]: params.severityMapping, + [ALERT_RULE_TAGS]: transformTags(tags), + [ALERT_RULE_THREAT]: params.threat, + [ALERT_RULE_THROTTLE]: throttle ?? undefined, + [ALERT_RULE_TIMELINE_ID]: params.timelineId, + [ALERT_RULE_TIMELINE_TITLE]: params.timelineTitle, + [ALERT_RULE_TIMESTAMP_OVERRIDE]: params.timestampOverride, + [ALERT_RULE_TO]: params.to, + [ALERT_RULE_TYPE]: params.type, + [ALERT_RULE_UPDATED_AT]: updatedAt.toISOString(), + [ALERT_RULE_UPDATED_BY]: updatedBy ?? '', + [ALERT_RULE_UUID]: completeRule.alertId, + [ALERT_RULE_VERSION]: params.version, + ...flattenWithPrefix(ALERT_RULE_META, params.meta), + // These fields don't exist in the mappings, but leaving here for now to limit changes to the alert building logic + 'kibana.alert.rule.risk_score': params.riskScore, + 'kibana.alert.rule.severity': params.severity, + 'kibana.alert.rule.building_block_type': params.buildingBlockType, + }; }; const isThresholdResult = (thresholdResult: SearchTypes): thresholdResult is ThresholdResult => { @@ -178,12 +249,7 @@ export const additionalAlertFields = (doc: BaseSignalHit) => { if (thresholdResult != null && !isThresholdResult(thresholdResult)) { throw new Error(`threshold_result failed to validate: ${thresholdResult}`); } - const originalTime = getValidDateFromDoc({ - doc, - timestampOverride: undefined, - }); - const additionalFields: Record = { - [ALERT_ORIGINAL_TIME]: originalTime != null ? originalTime.toISOString() : undefined, + const additionalFields: Record = { ...(thresholdResult != null ? { [ALERT_THRESHOLD_RESULT]: thresholdResult } : {}), }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts index 26e0289732bfb..a991da87485a5 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_alert_group_from_sequence.ts @@ -11,7 +11,6 @@ import { Logger } from 'kibana/server'; import type { ConfigType } from '../../../../../config'; import { Ancestor, SignalSource, SignalSourceHit } from '../../../signals/types'; -import { RACAlert, WrappedRACAlert } from '../../types'; import { buildAlert, buildAncestors, generateAlertId } from './build_alert'; import { buildBulkBody } from './build_bulk_body'; import { EqlSequence } from '../../../../../../common/detection_engine/types'; @@ -22,8 +21,13 @@ import { ALERT_BUILDING_BLOCK_TYPE, ALERT_GROUP_ID, ALERT_GROUP_INDEX, - ALERT_ORIGINAL_TIME, } from '../../../../../../common/field_maps/field_names'; +import { + BaseFieldsLatest, + EqlBuildingBlockFieldsLatest, + EqlShellFieldsLatest, + WrappedFieldsLatest, +} from '../../../../../../common/detection_engine/schemas/alerts'; /** * Takes N raw documents from ES that form a sequence and builds them into N+1 signals ready to be indexed - @@ -39,67 +43,70 @@ export const buildAlertGroupFromSequence = ( mergeStrategy: ConfigType['alertMergeStrategy'], spaceId: string | null | undefined, buildReasonMessage: BuildReasonMessage -): WrappedRACAlert[] => { +): Array> => { const ancestors: Ancestor[] = sequence.events.flatMap((event) => buildAncestors(event)); if (ancestors.some((ancestor) => ancestor?.rule === completeRule.alertId)) { return []; } - let buildingBlocks: RACAlert[] = []; + // The "building block" alerts start out as regular BaseFields. We'll add the group ID and index fields + // after creating the shell alert later on, since that's when the group ID is determined. + let baseAlerts: BaseFieldsLatest[] = []; try { - buildingBlocks = sequence.events.map((event) => ({ - ...buildBulkBody(spaceId, completeRule, event, mergeStrategy, [], false, buildReasonMessage), - [ALERT_BUILDING_BLOCK_TYPE]: 'default', - })); + baseAlerts = sequence.events.map((event) => + buildBulkBody(spaceId, completeRule, event, mergeStrategy, [], false, buildReasonMessage) + ); } catch (error) { logger.error(error); return []; } - const buildingBlockIds = generateBuildingBlockIds(buildingBlocks); - const wrappedBuildingBlocks: WrappedRACAlert[] = buildingBlocks.map((block, i) => ({ - _id: buildingBlockIds[i], - _index: '', - _source: { - ...block, - [ALERT_UUID]: buildingBlockIds[i], - }, - })); + // The ID of each building block alert depends on all of the other building blocks as well, + // so we generate the IDs after making all the BaseFields + const buildingBlockIds = generateBuildingBlockIds(baseAlerts); + const wrappedBaseFields: Array> = baseAlerts.map( + (block, i): WrappedFieldsLatest => ({ + _id: buildingBlockIds[i], + _index: '', + _source: { + ...block, + [ALERT_UUID]: buildingBlockIds[i], + }, + }) + ); // Now that we have an array of building blocks for the events in the sequence, // we can build the signal that links the building blocks together // and also insert the group id (which is also the "shell" signal _id) in each building block - const doc = buildAlertRoot(wrappedBuildingBlocks, completeRule, spaceId, buildReasonMessage); - const sequenceAlertId = generateAlertId(doc); - const sequenceAlert = { - _id: sequenceAlertId, + const shellAlert = buildAlertRoot(wrappedBaseFields, completeRule, spaceId, buildReasonMessage); + const sequenceAlert: WrappedFieldsLatest = { + _id: shellAlert[ALERT_UUID], _index: '', - _source: doc, + _source: shellAlert, }; - wrappedBuildingBlocks.forEach((block, i) => { - block._source[ALERT_GROUP_ID] = sequenceAlert._source[ALERT_GROUP_ID]; - block._source[ALERT_GROUP_INDEX] = i; - }); - - sequenceAlert._source[ALERT_UUID] = sequenceAlertId; + // Finally, we have the group id from the shell alert so we can convert the BaseFields into EqlBuildingBlocks + const wrappedBuildingBlocks = wrappedBaseFields.map( + (block, i): WrappedFieldsLatest => ({ + ...block, + _source: { + ...block._source, + [ALERT_BUILDING_BLOCK_TYPE]: 'default', + [ALERT_GROUP_ID]: shellAlert[ALERT_GROUP_ID], + [ALERT_GROUP_INDEX]: i, + }, + }) + ); return [...wrappedBuildingBlocks, sequenceAlert]; }; export const buildAlertRoot = ( - wrappedBuildingBlocks: WrappedRACAlert[], + wrappedBuildingBlocks: Array>, completeRule: CompleteRule, spaceId: string | null | undefined, buildReasonMessage: BuildReasonMessage -): RACAlert => { - const timestamps = wrappedBuildingBlocks - .sort( - (block1, block2) => - (block1._source[ALERT_ORIGINAL_TIME] as number) - - (block2._source[ALERT_ORIGINAL_TIME] as number) - ) - .map((alert) => alert._source[ALERT_ORIGINAL_TIME]); +): EqlShellFieldsLatest => { const mergedAlerts = objectArrayIntersection(wrappedBuildingBlocks.map((alert) => alert._source)); const reason = buildReasonMessage({ name: completeRule.ruleConfig.name, @@ -107,14 +114,12 @@ export const buildAlertRoot = ( mergedDoc: mergedAlerts as SignalSourceHit, }); const doc = buildAlert(wrappedBuildingBlocks, completeRule, spaceId, reason); + const alertId = generateAlertId(doc); return { ...mergedAlerts, - event: { - kind: 'signal', - }, ...doc, - [ALERT_ORIGINAL_TIME]: timestamps[0], - [ALERT_GROUP_ID]: generateAlertId(doc), + [ALERT_UUID]: alertId, + [ALERT_GROUP_ID]: alertId, }; }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_bulk_body.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_bulk_body.ts index ef3d76be1df4b..a73471ec83ada 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_bulk_body.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/build_bulk_body.ts @@ -5,7 +5,6 @@ * 2.0. */ -import { EVENT_KIND, TIMESTAMP } from '@kbn/rule-data-utils'; import { flattenWithPrefix } from '@kbn/securitysolution-rules'; import { BaseHit } from '../../../../../../common/detection_engine/types'; @@ -13,13 +12,13 @@ import type { ConfigType } from '../../../../../config'; import { BuildReasonMessage } from '../../../signals/reason_formatters'; import { getMergeStrategy } from '../../../signals/source_fields_merging/strategies'; import { BaseSignalHit, SignalSource, SignalSourceHit, SimpleHit } from '../../../signals/types'; -import { RACAlert } from '../../types'; import { additionalAlertFields, buildAlert } from './build_alert'; import { filterSource } from './filter_source'; import { CompleteRule, RuleParams } from '../../../schemas/rule_schemas'; import { buildRuleNameFromMapping } from '../../../signals/mappings/build_rule_name_from_mapping'; import { buildSeverityFromMapping } from '../../../signals/mappings/build_severity_from_mapping'; import { buildRiskScoreFromMapping } from '../../../signals/mappings/build_risk_score_from_mapping'; +import { BaseFieldsLatest } from '../../../../../../common/detection_engine/schemas/alerts'; const isSourceDoc = ( hit: SignalSourceHit @@ -51,7 +50,7 @@ export const buildBulkBody = ( ignoreFields: ConfigType['alertIgnoreFields'], applyOverrides: boolean, buildReasonMessage: BuildReasonMessage -): RACAlert => { +): BaseFieldsLatest => { const mergedDoc = getMergeStrategy(mergeStrategy)({ doc, ignoreFields }); const eventFields = buildEventTypeAlert(mergedDoc); const filteredSource = filterSource(mergedDoc); @@ -88,8 +87,6 @@ export const buildBulkBody = ( ...eventFields, ...buildAlert([mergedDoc], completeRule, spaceId, reason, overrides), ...additionalAlertFields({ ...mergedDoc, _source: { ...mergedDoc._source, ...eventFields } }), - [EVENT_KIND]: 'signal', - [TIMESTAMP]: new Date().toISOString(), }; } diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/filter_source.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/filter_source.ts index 473b0da1d58e9..f1fd9d3b83929 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/filter_source.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/filter_source.ts @@ -7,9 +7,8 @@ import { ALERT_THRESHOLD_RESULT } from '../../../../../../common/field_maps/field_names'; import { SignalSourceHit } from '../../../signals/types'; -import { RACAlert } from '../../types'; -export const filterSource = (doc: SignalSourceHit): Partial => { +export const filterSource = (doc: SignalSourceHit) => { const docSource = doc._source ?? {}; const { event, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/generate_building_block_ids.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/generate_building_block_ids.ts index a603946b03d3b..f0ae5d7cdc6ab 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/generate_building_block_ids.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/utils/generate_building_block_ids.ts @@ -7,9 +7,8 @@ import { ALERT_RULE_UUID } from '@kbn/rule-data-utils'; import { createHash } from 'crypto'; +import { BaseFieldsLatest } from '../../../../../../common/detection_engine/schemas/alerts'; import { ALERT_ANCESTORS } from '../../../../../../common/field_maps/field_names'; -import { Ancestor } from '../../../signals/types'; -import { RACAlert } from '../../types'; /** * Generates unique doc ids for each building block signal within a sequence. The id of each building block @@ -17,17 +16,17 @@ import { RACAlert } from '../../types'; * (e.g. if multiple rules build sequences that share a common event/signal) will get a unique id per sequence. * @param buildingBlocks The full list of building blocks in the sequence. */ -export const generateBuildingBlockIds = (buildingBlocks: RACAlert[]): string[] => { +export const generateBuildingBlockIds = (buildingBlocks: BaseFieldsLatest[]): string[] => { const baseHashString = buildingBlocks.reduce( (baseString, block) => baseString .concat( - (block[ALERT_ANCESTORS] as Ancestor[]).reduce( + block[ALERT_ANCESTORS].reduce( (acc, ancestor) => acc.concat(ancestor.id, ancestor.index), '' ) ) - .concat(block[ALERT_RULE_UUID] as string), + .concat(block[ALERT_RULE_UUID]), '' ); return buildingBlocks.map((block, idx) => diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_hits_factory.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_hits_factory.ts index 81a4af31881fb..2c5c9cca02080 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_hits_factory.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_hits_factory.ts @@ -5,14 +5,19 @@ * 2.0. */ +import type * as estypes from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import { ALERT_UUID } from '@kbn/rule-data-utils'; import type { ConfigType } from '../../../../config'; -import { filterDuplicateSignals } from '../../signals/filter_duplicate_signals'; -import { SimpleHit, WrapHits } from '../../signals/types'; +import { SignalSource, SimpleHit } from '../../signals/types'; import { CompleteRule, RuleParams } from '../../schemas/rule_schemas'; import { generateId } from '../../signals/utils'; import { buildBulkBody } from './utils/build_bulk_body'; +import { BuildReasonMessage } from '../../signals/reason_formatters'; +import { + BaseFieldsLatest, + WrappedFieldsLatest, +} from '../../../../../common/detection_engine/schemas/alerts'; export const wrapHitsFactory = ({ @@ -25,9 +30,12 @@ export const wrapHitsFactory = ignoreFields: ConfigType['alertIgnoreFields']; mergeStrategy: ConfigType['alertMergeStrategy']; spaceId: string | null | undefined; - }): WrapHits => - (events, buildReasonMessage) => { - const wrappedDocs = events.map((event) => { + }) => + ( + events: Array>, + buildReasonMessage: BuildReasonMessage + ): Array> => { + const wrappedDocs = events.map((event): WrappedFieldsLatest => { const id = generateId( event._index, event._id, @@ -51,6 +59,10 @@ export const wrapHitsFactory = }, }; }); - - return filterDuplicateSignals(completeRule.alertId, wrappedDocs, true); + return wrappedDocs.filter( + (doc) => + !doc._source['kibana.alert.ancestors'].some( + (ancestor) => ancestor.rule === completeRule.alertId + ) + ); }; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_sequences_factory.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_sequences_factory.ts index 916b7f4801e8e..0aeb8935c6cc0 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_sequences_factory.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/factories/wrap_sequences_factory.ts @@ -10,8 +10,11 @@ import { Logger } from 'kibana/server'; import { WrapSequences } from '../../signals/types'; import { buildAlertGroupFromSequence } from './utils/build_alert_group_from_sequence'; import { ConfigType } from '../../../../config'; -import { WrappedRACAlert } from '../types'; import { CompleteRule, RuleParams } from '../../schemas/rule_schemas'; +import { + BaseFieldsLatest, + WrappedFieldsLatest, +} from '../../../../../common/detection_engine/schemas/alerts'; export const wrapSequencesFactory = ({ @@ -29,7 +32,7 @@ export const wrapSequencesFactory = }): WrapSequences => (sequences, buildReasonMessage) => sequences.reduce( - (acc: WrappedRACAlert[], sequence) => [ + (acc: Array>, sequence) => [ ...acc, ...buildAlertGroupFromSequence( logger, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/types.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/types.ts index 2503c799ebc84..2537f7eeeaf72 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/types.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/rule_types/types.ts @@ -7,9 +7,7 @@ import { Moment } from 'moment'; -import { SearchHit } from '@elastic/elasticsearch/lib/api/typesWithBodyKey'; import { Logger } from '@kbn/logging'; -import { ALERT_RULE_PARAMETERS } from '@kbn/rule-data-utils'; import { ExceptionListItemSchema } from '@kbn/securitysolution-io-ts-list-types'; import { AlertExecutorOptions, RuleType } from '../../../../../alerting/server'; @@ -20,10 +18,7 @@ import { WithoutReservedActionGroups, } from '../../../../../alerting/common'; import { ListClient } from '../../../../../lists/server'; -import { TechnicalRuleFieldMap } from '../../../../../rule_registry/common/assets/field_maps/technical_rule_field_map'; -import { TypeOfFieldMap } from '../../../../../rule_registry/common/field_map'; import { PersistenceServices, IRuleDataClient } from '../../../../../rule_registry/server'; -import { BaseHit } from '../../../../common/detection_engine/types'; import { ConfigType } from '../../../config'; import { SetupPlugins } from '../../../plugin'; import { CompleteRule, RuleParams } from '../schemas/rule_schemas'; @@ -36,10 +31,8 @@ import { } from '../signals/types'; import { ExperimentalFeatures } from '../../../../common/experimental_features'; import { IEventLogService } from '../../../../../event_log/server'; -import { AlertsFieldMap, RulesFieldMap } from '../../../../common/field_maps'; import { ITelemetryEventsSender } from '../../telemetry/sender'; import { RuleExecutionLogForExecutorsFactory } from '../rule_execution_log'; -import { commonParamsCamelToSnake } from '../schemas/rule_converters'; export interface SecurityAlertTypeReturnValue { bulkCreateTimes: string[]; @@ -112,18 +105,6 @@ export type CreateSecurityRuleTypeWrapper = ( type: SecurityAlertType ) => RuleType; -export type RACAlertSignal = TypeOfFieldMap & TypeOfFieldMap; -export type RACAlert = Omit< - TypeOfFieldMap & RACAlertSignal, - '@timestamp' | typeof ALERT_RULE_PARAMETERS -> & { - '@timestamp': string; - [ALERT_RULE_PARAMETERS]: ReturnType; -}; - -export type RACSourceHit = SearchHit; -export type WrappedRACAlert = BaseHit; - export interface CreateRuleOptions { experimentalFeatures: ExperimentalFeatures; logger: Logger; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/__mocks__/es_results.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/__mocks__/es_results.ts index 5f6ce6966fc02..3ed5dccaccdf2 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/__mocks__/es_results.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/__mocks__/es_results.ts @@ -23,14 +23,63 @@ import { RulesSchema } from '../../../../../common/detection_engine/schemas/resp import { RuleParams } from '../../schemas/rule_schemas'; import { getThreatMock } from '../../../../../common/detection_engine/schemas/types/threat.mock'; import { + ALERT_BUILDING_BLOCK_TYPE, ALERT_REASON, + ALERT_RISK_SCORE, + ALERT_RULE_AUTHOR, + ALERT_RULE_CATEGORY, + ALERT_RULE_CONSUMER, + ALERT_RULE_CREATED_AT, + ALERT_RULE_CREATED_BY, + ALERT_RULE_DESCRIPTION, + ALERT_RULE_ENABLED, + ALERT_RULE_EXECUTION_UUID, + ALERT_RULE_FROM, + ALERT_RULE_INTERVAL, + ALERT_RULE_LICENSE, + ALERT_RULE_NAME, + ALERT_RULE_NAMESPACE_FIELD, + ALERT_RULE_NOTE, ALERT_RULE_PARAMETERS, + ALERT_RULE_PRODUCER, + ALERT_RULE_REFERENCES, + ALERT_RULE_RULE_ID, + ALERT_RULE_RULE_NAME_OVERRIDE, + ALERT_RULE_TAGS, + ALERT_RULE_TO, + ALERT_RULE_TYPE, + ALERT_RULE_TYPE_ID, + ALERT_RULE_UPDATED_AT, + ALERT_RULE_UPDATED_BY, ALERT_RULE_UUID, + ALERT_RULE_VERSION, + ALERT_SEVERITY, + ALERT_STATUS, + ALERT_STATUS_ACTIVE, ALERT_UUID, ALERT_WORKFLOW_STATUS, EVENT_KIND, + SPACE_IDS, + TIMESTAMP, } from '@kbn/rule-data-utils'; -import { ALERT_ANCESTORS } from '../../../../../common/field_maps/field_names'; +import { + ALERT_ANCESTORS, + ALERT_DEPTH, + ALERT_ORIGINAL_TIME, + ALERT_RULE_ACTIONS, + ALERT_RULE_EXCEPTIONS_LIST, + ALERT_RULE_FALSE_POSITIVES, + ALERT_RULE_IMMUTABLE, + ALERT_RULE_MAX_SIGNALS, + ALERT_RULE_RISK_SCORE_MAPPING, + ALERT_RULE_SEVERITY_MAPPING, + ALERT_RULE_THREAT, + ALERT_RULE_THROTTLE, + ALERT_RULE_TIMELINE_ID, + ALERT_RULE_TIMELINE_TITLE, + ALERT_RULE_TIMESTAMP_OVERRIDE, +} from '../../../../../common/field_maps/field_names'; +import { SERVER_APP_ID } from '../../../../../common/constants'; export const sampleRuleSO = (params: T): SavedObject> => { return { @@ -212,23 +261,95 @@ export const sampleAlertDocAADNoSortId = ( _id: someUuid, _source: { someKey: 'someValue', - '@timestamp': '2020-04-20T21:27:45+0000', - source: { - ip: ip ?? '127.0.0.1', - }, + + [TIMESTAMP]: '2020-04-20T21:27:45+0000', + [SPACE_IDS]: ['default'], [EVENT_KIND]: 'signal', - [ALERT_UUID]: someUuid, - [ALERT_REASON]: 'reasonable reason', - [ALERT_WORKFLOW_STATUS]: 'open', + [ALERT_RULE_CONSUMER]: SERVER_APP_ID, [ALERT_ANCESTORS]: [ { id: 'd5e8eb51-a6a0-456d-8a15-4b79bfec3d71', type: 'event', index: 'myFakeSignalIndex', depth: 0, + rule: undefined, + }, + ], + [ALERT_BUILDING_BLOCK_TYPE]: undefined, + [ALERT_ORIGINAL_TIME]: undefined, + [ALERT_STATUS]: ALERT_STATUS_ACTIVE, + [ALERT_WORKFLOW_STATUS]: 'open', + [ALERT_DEPTH]: 1, + [ALERT_REASON]: 'reasonable reason', + [ALERT_SEVERITY]: 'high', + [ALERT_RISK_SCORE]: 50, + [ALERT_RULE_ACTIONS]: [], + [ALERT_RULE_AUTHOR]: ['Elastic'], + [ALERT_RULE_CATEGORY]: 'Custom Query Rule', + [ALERT_RULE_CREATED_AT]: '2020-03-27T22:55:59.577Z', + [ALERT_RULE_CREATED_BY]: 'sample user', + [ALERT_RULE_DESCRIPTION]: 'Descriptive description', + [ALERT_RULE_ENABLED]: true, + [ALERT_RULE_EXCEPTIONS_LIST]: [], + [ALERT_RULE_EXECUTION_UUID]: '97e8f53a-4971-4935-bb54-9b8f86930cc7', + [ALERT_RULE_FALSE_POSITIVES]: [], + [ALERT_RULE_FROM]: 'now-6m', + [ALERT_RULE_IMMUTABLE]: false, + [ALERT_RULE_INTERVAL]: '5m', + [ALERT_RULE_LICENSE]: 'Elastic License', + [ALERT_RULE_MAX_SIGNALS]: 10000, + [ALERT_RULE_NAME]: 'rule-name', + [ALERT_RULE_NAMESPACE_FIELD]: undefined, + [ALERT_RULE_NOTE]: undefined, + [ALERT_RULE_PRODUCER]: 'siem', + [ALERT_RULE_REFERENCES]: ['http://example.com', 'https://example.com'], + [ALERT_RULE_RISK_SCORE_MAPPING]: [], + [ALERT_RULE_RULE_ID]: 'rule-1', + [ALERT_RULE_RULE_NAME_OVERRIDE]: undefined, + [ALERT_RULE_TYPE_ID]: 'siem.queryRule', + [ALERT_RULE_SEVERITY_MAPPING]: [], + [ALERT_RULE_TAGS]: ['some fake tag 1', 'some fake tag 2'], + [ALERT_RULE_THREAT]: [ + { + framework: 'MITRE ATT&CK', + tactic: { + id: 'TA0000', + name: 'test tactic', + reference: 'https://attack.mitre.org/tactics/TA0000/', + }, + technique: [ + { + id: 'T0000', + name: 'test technique', + reference: 'https://attack.mitre.org/techniques/T0000/', + subtechnique: [ + { + id: 'T0000.000', + name: 'test subtechnique', + reference: 'https://attack.mitre.org/techniques/T0000/000/', + }, + ], + }, + ], }, ], + [ALERT_RULE_THROTTLE]: 'no_actions', + [ALERT_RULE_TIMELINE_ID]: 'some-timeline-id', + [ALERT_RULE_TIMELINE_TITLE]: 'some-timeline-title', + [ALERT_RULE_TIMESTAMP_OVERRIDE]: undefined, + [ALERT_RULE_TO]: 'now', + [ALERT_RULE_TYPE]: 'query', + [ALERT_RULE_UPDATED_AT]: '2020-03-27T22:55:59.577Z', + [ALERT_RULE_UPDATED_BY]: 'sample user', [ALERT_RULE_UUID]: '2e051244-b3c6-4779-a241-e1b4f0beceb9', + [ALERT_RULE_VERSION]: 1, + source: { + ip: ip ?? '127.0.0.1', + }, + [ALERT_UUID]: someUuid, + 'kibana.alert.rule.risk_score': 50, + 'kibana.alert.rule.severity': 'high', + 'kibana.alert.rule.building_block_type': undefined, [ALERT_RULE_PARAMETERS]: { description: 'Descriptive description', meta: { someMeta: 'someField' }, diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts index a757e178ea48a..1a35d9f0771fe 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/bulk_create_ml_signals.ts @@ -20,6 +20,7 @@ import { BuildRuleMessage } from './rule_messages'; import { BulkCreate, WrapHits } from './types'; import { CompleteRule, MachineLearningRuleParams } from '../schemas/rule_schemas'; import { buildReasonMessageForMlAlert } from './reason_formatters'; +import { BaseFieldsLatest } from '../../../../common/detection_engine/schemas/alerts'; interface BulkCreateMlSignalsParams { someResult: AnomalyResults; @@ -86,7 +87,7 @@ const transformAnomalyResultsToEcs = ( export const bulkCreateMlSignals = async ( params: BulkCreateMlSignalsParams -): Promise> => { +): Promise> => { const anomalyResults = params.someResult; const ecsResults = transformAnomalyResultsToEcs(anomalyResults); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/eql.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/eql.ts index 5195f40da8010..dd9d5e2938e67 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/eql.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/executors/eql.ts @@ -26,7 +26,6 @@ import { WrapSequences, RuleRangeTuple, SearchAfterAndBulkCreateReturnType, - SimpleHit, SignalSource, } from '../types'; import { createSearchAfterReturnType, makeFloatString } from '../utils'; @@ -34,6 +33,10 @@ import { ExperimentalFeatures } from '../../../../../common/experimental_feature import { buildReasonMessageForEqlAlert } from '../reason_formatters'; import { CompleteRule, EqlRuleParams } from '../../schemas/rule_schemas'; import { withSecuritySpan } from '../../../../utils/with_security_span'; +import { + BaseFieldsLatest, + WrappedFieldsLatest, +} from '../../../../../common/detection_engine/schemas/alerts'; export const eqlExecutor = async ({ completeRule, @@ -118,7 +121,7 @@ export const eqlExecutor = async ({ const eqlSearchDuration = makeFloatString(eqlSignalSearchEnd - eqlSignalSearchStart); result.searchAfterTimes = [eqlSearchDuration]; - let newSignals: SimpleHit[] | undefined; + let newSignals: Array> | undefined; if (response.hits.sequences !== undefined) { newSignals = wrapSequences(response.hits.sequences, buildReasonMessageForEqlAlert); } else if (response.hits.events !== undefined) { diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.test.ts deleted file mode 100644 index 0098d50fc01ef..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.test.ts +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { filterDuplicateSignals } from './filter_duplicate_signals'; -import { sampleWrappedSignalHit } from './__mocks__/es_results'; - -const mockRuleId1 = 'aaaaaaaa'; -const mockRuleId2 = 'bbbbbbbb'; -const mockRuleId3 = 'cccccccc'; - -const createWrappedSignalHitWithRuleId = (ruleId: string) => { - const mockSignal = sampleWrappedSignalHit(); - return { - ...mockSignal, - _source: { - ...mockSignal._source, - signal: { - ...mockSignal._source.signal, - ancestors: [ - { - ...mockSignal._source.signal.ancestors[0], - rule: ruleId, - }, - ], - }, - }, - }; -}; -const mockSignals = [ - createWrappedSignalHitWithRuleId(mockRuleId1), - createWrappedSignalHitWithRuleId(mockRuleId2), -]; - -describe('filterDuplicateSignals', () => { - describe('detection engine implementation', () => { - it('filters duplicate signals', () => { - expect(filterDuplicateSignals(mockRuleId1, mockSignals, false).length).toEqual(1); - }); - - it('does not filter non-duplicate signals', () => { - expect(filterDuplicateSignals(mockRuleId3, mockSignals, false).length).toEqual(2); - }); - }); -}); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.ts deleted file mode 100644 index 77671167c1cfd..0000000000000 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/filter_duplicate_signals.ts +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License - * 2.0; you may not use this file except in compliance with the Elastic License - * 2.0. - */ - -import { WrappedRACAlert } from '../rule_types/types'; -import { Ancestor, SimpleHit, WrappedSignalHit } from './types'; - -export const filterDuplicateSignals = ( - ruleId: string, - signals: SimpleHit[], - isRuleRegistryEnabled: boolean -) => { - // TODO: handle alerts-on-legacy-alerts - if (!isRuleRegistryEnabled) { - return (signals as WrappedSignalHit[]).filter( - (doc) => !doc._source.signal?.ancestors.some((ancestor) => ancestor.rule === ruleId) - ); - } else { - return (signals as WrappedRACAlert[]).filter( - (doc) => - !(doc._source['kibana.alert.ancestors'] as Ancestor[]).some( - (ancestor) => ancestor.rule === ruleId - ) - ); - } -}; diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts index 52d0a04eee1ec..d6332af195fcf 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/search_after_bulk_create.test.ts @@ -33,6 +33,20 @@ import { BuildReasonMessage } from './reason_formatters'; import { QueryRuleParams } from '../schemas/rule_schemas'; import { createPersistenceServicesMock } from '../../../../../rule_registry/server/utils/create_persistence_rule_type_wrapper.mock'; import { PersistenceServices } from '../../../../../rule_registry/server'; +import { + ALERT_RULE_CATEGORY, + ALERT_RULE_CONSUMER, + ALERT_RULE_EXECUTION_UUID, + ALERT_RULE_NAME, + ALERT_RULE_PRODUCER, + ALERT_RULE_TAGS, + ALERT_RULE_TYPE_ID, + ALERT_RULE_UUID, + SPACE_IDS, + TIMESTAMP, +} from '@kbn/rule-data-utils'; +import { SERVER_APP_ID } from '../../../../common/constants'; +import { CommonAlertFieldsLatest } from '../../../../../rule_registry/common/schemas'; const buildRuleMessage = mockBuildRuleMessage; @@ -50,6 +64,18 @@ describe('searchAfterAndBulkCreate', () => { const defaultFilter = { match_all: {}, }; + const mockCommonFields: CommonAlertFieldsLatest = { + [ALERT_RULE_CATEGORY]: 'Custom Query Rule', + [ALERT_RULE_CONSUMER]: SERVER_APP_ID, + [ALERT_RULE_EXECUTION_UUID]: '97e8f53a-4971-4935-bb54-9b8f86930cc7', + [ALERT_RULE_NAME]: 'rule-name', + [ALERT_RULE_PRODUCER]: 'siem', + [ALERT_RULE_TYPE_ID]: 'siem.queryRule', + [ALERT_RULE_UUID]: '2e051244-b3c6-4779-a241-e1b4f0beceb9', + [SPACE_IDS]: ['default'], + [ALERT_RULE_TAGS]: [], + [TIMESTAMP]: '2020-04-20T21:27:45+0000', + }; sampleParams.maxSignals = 30; let tuple: RuleRangeTuple; beforeEach(() => { @@ -92,7 +118,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -103,7 +135,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -114,7 +152,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -125,7 +169,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '4', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -178,7 +228,13 @@ describe('searchAfterAndBulkCreate', () => { ) ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -189,7 +245,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -200,7 +262,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -254,10 +322,26 @@ describe('searchAfterAndBulkCreate', () => { mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ createdAlerts: [ - { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '4', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, ], errors: {}, }); @@ -365,10 +449,26 @@ describe('searchAfterAndBulkCreate', () => { test('should return success when empty string sortId present', async () => { mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ createdAlerts: [ - { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '4', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, ], errors: {}, }); @@ -478,10 +578,26 @@ describe('searchAfterAndBulkCreate', () => { mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ createdAlerts: [ - { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '4', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, ], errors: {}, }); @@ -530,10 +646,26 @@ describe('searchAfterAndBulkCreate', () => { mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ createdAlerts: [ - { _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }, - { _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }, + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + { + _id: '4', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, ], errors: {}, }); @@ -695,7 +827,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: { 'error on creation': { count: 1, @@ -713,7 +851,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -724,7 +868,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -735,7 +885,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '4', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '4', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -777,7 +933,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '1', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '1', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -788,7 +950,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '2', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '2', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); @@ -799,7 +967,13 @@ describe('searchAfterAndBulkCreate', () => { ); mockPersistenceServices.alertWithPersistence.mockResolvedValueOnce({ - createdAlerts: [{ _id: '3', _index: '.internal.alerts-security.alerts-default-000001' }], + createdAlerts: [ + { + _id: '3', + _index: '.internal.alerts-security.alerts-default-000001', + ...mockCommonFields, + }, + ], errors: {}, }); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/build_signal_history.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/build_signal_history.ts index d251d6fcfcbf2..9fda5205e9dab 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/build_signal_history.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/build_signal_history.ts @@ -10,14 +10,14 @@ import { ALERT_RULE_PARAMETERS } from '@kbn/rule-data-utils'; import { ALERT_ORIGINAL_TIME } from '../../../../../common/field_maps/field_names'; import { SimpleHit, ThresholdSignalHistory } from '../types'; -import { getThresholdTermsHash, isWrappedRACAlert, isWrappedSignalHit } from '../utils'; +import { getThresholdTermsHash, isWrappedDetectionAlert, isWrappedSignalHit } from '../utils'; interface GetThresholdSignalHistoryParams { alerts: Array>; } const getTerms = (alert: SimpleHit) => { - if (isWrappedRACAlert(alert)) { + if (isWrappedDetectionAlert(alert)) { const parameters = alert._source[ALERT_RULE_PARAMETERS] as unknown as Record< string, Record @@ -35,7 +35,7 @@ const getTerms = (alert: SimpleHit) => { }; const getOriginalTime = (alert: SimpleHit) => { - if (isWrappedRACAlert(alert)) { + if (isWrappedDetectionAlert(alert)) { const originalTime = alert._source[ALERT_ORIGINAL_TIME]; return originalTime != null ? new Date(originalTime as string).getTime() : undefined; } else if (isWrappedSignalHit(alert)) { diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts index 2148d4feacdae..49a81a47502d2 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/threshold/bulk_create_threshold_signals.ts @@ -30,6 +30,7 @@ import type { WrapHits, } from '../types'; import { CompleteRule, ThresholdRuleParams } from '../../schemas/rule_schemas'; +import { BaseFieldsLatest } from '../../../../../common/detection_engine/schemas/alerts'; interface BulkCreateThresholdSignalsParams { someResult: SignalSearchResponse; @@ -205,7 +206,7 @@ export const transformThresholdResultsToEcs = ( export const bulkCreateThresholdSignals = async ( params: BulkCreateThresholdSignalsParams -): Promise> => { +): Promise> => { const ruleParams = params.completeRule.ruleParams; const thresholdResults = params.someResult; const ecsResults = transformThresholdResultsToEcs( diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts index 44154a8727f38..bbe6adc5c729f 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/types.ts @@ -34,7 +34,11 @@ import { GenericBulkCreateResponse } from '../rule_types/factories'; import { EcsFieldMap } from '../../../../../rule_registry/common/assets/field_maps/ecs_field_map'; import { TypeOfFieldMap } from '../../../../../rule_registry/common/field_map'; import { BuildReasonMessage } from './reason_formatters'; -import { RACAlert } from '../rule_types/types'; +import { + BaseFieldsLatest, + DetectionAlert, + WrappedFieldsLatest, +} from '../../../../common/detection_engine/schemas/alerts'; // used for gap detection code // eslint-disable-next-line @typescript-eslint/naming-convention @@ -179,10 +183,9 @@ export type EventHit = Exclude, '@timestamp'> & { }; export type WrappedEventHit = BaseHit; -export type AlertSearchResponse = estypes.SearchResponse; export type SignalSearchResponse = estypes.SearchResponse; export type SignalSourceHit = estypes.SearchHit; -export type AlertSourceHit = estypes.SearchHit; +export type AlertSourceHit = estypes.SearchHit; export type WrappedSignalHit = BaseHit; export type BaseSignalHit = estypes.SearchHit; @@ -276,8 +279,8 @@ export type BulkResponseErrorAggregation = Record Promise; -export type BulkCreate = >( - docs: Array> +export type BulkCreate = ( + docs: Array> ) => Promise>; export type SimpleHit = BaseHit<{ '@timestamp'?: string }>; @@ -285,12 +288,12 @@ export type SimpleHit = BaseHit<{ '@timestamp'?: string }>; export type WrapHits = ( hits: Array>, buildReasonMessage: BuildReasonMessage -) => SimpleHit[]; +) => Array>; export type WrapSequences = ( sequences: Array>, buildReasonMessage: BuildReasonMessage -) => SimpleHit[]; +) => Array>; export interface SearchAfterAndBulkCreateParams { tuple: { diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.test.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.test.ts index 9cf57ff0018be..7c020a476c41b 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.test.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.test.ts @@ -43,7 +43,7 @@ import { getValidDateFromDoc, calculateTotal, getTotalHitsValue, - isRACAlert, + isDetectionAlert, getField, } from './utils'; import type { BulkResponseErrorAggregation, SearchAfterAndBulkCreateReturnType } from './types'; @@ -1538,10 +1538,10 @@ describe('utils', () => { }); }); - describe('isRACAlert', () => { + describe('isDetectionAlert', () => { test('alert with dotted fields returns true', () => { expect( - isRACAlert({ + isDetectionAlert({ [ALERT_UUID]: '123', }) ).toEqual(true); @@ -1549,7 +1549,7 @@ describe('utils', () => { test('alert with nested fields returns true', () => { expect( - isRACAlert({ + isDetectionAlert({ kibana: { alert: { uuid: '123' }, }, @@ -1558,31 +1558,31 @@ describe('utils', () => { }); test('undefined returns false', () => { - expect(isRACAlert(undefined)).toEqual(false); + expect(isDetectionAlert(undefined)).toEqual(false); }); test('null returns false', () => { - expect(isRACAlert(null)).toEqual(false); + expect(isDetectionAlert(null)).toEqual(false); }); test('number returns false', () => { - expect(isRACAlert(5)).toEqual(false); + expect(isDetectionAlert(5)).toEqual(false); }); test('string returns false', () => { - expect(isRACAlert('a')).toEqual(false); + expect(isDetectionAlert('a')).toEqual(false); }); test('array returns false', () => { - expect(isRACAlert([])).toEqual(false); + expect(isDetectionAlert([])).toEqual(false); }); test('empty object returns false', () => { - expect(isRACAlert({})).toEqual(false); + expect(isDetectionAlert({})).toEqual(false); }); test('alert with null value returns false', () => { - expect(isRACAlert({ 'kibana.alert.uuid': null })).toEqual(false); + expect(isDetectionAlert({ 'kibana.alert.uuid': null })).toEqual(false); }); }); diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.ts index f49eee858d135..0a4618d81081b 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/utils.ts @@ -62,10 +62,10 @@ import type { ThreatRuleParams, ThresholdRuleParams, } from '../schemas/rule_schemas'; -import type { RACAlert, WrappedRACAlert } from '../rule_types/types'; -import type { SearchTypes } from '../../../../common/detection_engine/types'; +import type { BaseHit, SearchTypes } from '../../../../common/detection_engine/types'; import type { IRuleExecutionLogForExecutors } from '../rule_execution_log'; import { withSecuritySpan } from '../../../utils/with_security_span'; +import { DetectionAlert } from '../../../../common/detection_engine/schemas/alerts'; import { ENABLE_CCS_READ_WARNING_SETTING } from '../../../../common/constants'; interface SortExceptionsReturn { @@ -971,18 +971,18 @@ export const buildChunkedOrFilter = (field: string, values: string[], chunkSize: }; export const isWrappedEventHit = (event: SimpleHit): event is WrappedEventHit => { - return !isWrappedSignalHit(event) && !isWrappedRACAlert(event); + return !isWrappedSignalHit(event) && !isWrappedDetectionAlert(event); }; export const isWrappedSignalHit = (event: SimpleHit): event is WrappedSignalHit => { return (event as WrappedSignalHit)?._source?.signal != null; }; -export const isWrappedRACAlert = (event: SimpleHit): event is WrappedRACAlert => { - return (event as WrappedRACAlert)?._source?.[ALERT_UUID] != null; +export const isWrappedDetectionAlert = (event: SimpleHit): event is BaseHit => { + return (event as BaseHit)?._source?.[ALERT_UUID] != null; }; -export const isRACAlert = (event: unknown): event is RACAlert => { +export const isDetectionAlert = (event: unknown): event is DetectionAlert => { return get(event, ALERT_UUID) != null; }; @@ -1019,19 +1019,19 @@ export const racFieldMappings: Record = { 'signal.rule.immutable': `${ALERT_RULE_PARAMETERS}.immutable`, }; -export const getField = (event: SimpleHit, field: string): T | undefined => { - if (isWrappedRACAlert(event)) { +export const getField = (event: SimpleHit, field: string): SearchTypes | undefined => { + if (isWrappedDetectionAlert(event)) { const mappedField = racFieldMappings[field] ?? field.replace('signal', 'kibana.alert'); const parts = mappedField.split('.'); if (mappedField.includes(ALERT_RULE_PARAMETERS) && parts[parts.length - 1] !== 'parameters') { const params = get(event._source, ALERT_RULE_PARAMETERS); return get(params, parts[parts.length - 1]); } - return get(event._source, mappedField) as T; + return get(event._source, mappedField) as SearchTypes | undefined; } else if (isWrappedSignalHit(event)) { const mappedField = invert(racFieldMappings)[field] ?? field.replace('kibana.alert', 'signal'); - return get(event._source, mappedField) as T; + return get(event._source, mappedField) as SearchTypes | undefined; } else if (isWrappedEventHit(event)) { - return get(event._source, field) as T; + return get(event._source, field) as SearchTypes | undefined; } }; diff --git a/x-pack/test/detection_engine_api_integration/basic/tests/open_close_signals.ts b/x-pack/test/detection_engine_api_integration/basic/tests/open_close_signals.ts index f58dee11c48da..005352a643af1 100644 --- a/x-pack/test/detection_engine_api_integration/basic/tests/open_close_signals.ts +++ b/x-pack/test/detection_engine_api_integration/basic/tests/open_close_signals.ts @@ -26,7 +26,7 @@ import { waitForRuleSuccessOrStatus, getRuleForSignalTesting, } from '../../utils'; -import { RACAlert } from '../../../../plugins/security_solution/server/lib/detection_engine/rule_types/types'; +import { DetectionAlert } from '../../../../plugins/security_solution/common/detection_engine/schemas/alerts'; // eslint-disable-next-line import/no-default-export export default ({ getService }: FtrProviderContext) => { @@ -92,11 +92,12 @@ export default ({ getService }: FtrProviderContext) => { .send(setSignalStatus({ signalIds, status: 'closed' })) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest - .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) - .set('kbn-xsrf', 'true') - .send(getQuerySignalIds(signalIds)) - .expect(200); + const { body: signalsClosed }: { body: estypes.SearchResponse } = + await supertest + .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) + .set('kbn-xsrf', 'true') + .send(getQuerySignalIds(signalIds)) + .expect(200); expect(signalsClosed.hits.hits.length).to.equal(10); }); @@ -117,11 +118,12 @@ export default ({ getService }: FtrProviderContext) => { .send(setSignalStatus({ signalIds, status: 'closed' })) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest - .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) - .set('kbn-xsrf', 'true') - .send(getQuerySignalIds(signalIds)) - .expect(200); + const { body: signalsClosed }: { body: estypes.SearchResponse } = + await supertest + .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) + .set('kbn-xsrf', 'true') + .send(getQuerySignalIds(signalIds)) + .expect(200); const everySignalClosed = signalsClosed.hits.hits.every( (hit) => hit._source?.[ALERT_WORKFLOW_STATUS] === 'closed' diff --git a/x-pack/test/detection_engine_api_integration/basic/tests/update_rac_alerts.ts b/x-pack/test/detection_engine_api_integration/basic/tests/update_rac_alerts.ts index 18207f9258059..d0c839fcb1b62 100644 --- a/x-pack/test/detection_engine_api_integration/basic/tests/update_rac_alerts.ts +++ b/x-pack/test/detection_engine_api_integration/basic/tests/update_rac_alerts.ts @@ -23,7 +23,7 @@ import { waitForRuleSuccessOrStatus, getRuleForSignalTesting, } from '../../utils'; -import { RACAlert } from '../../../../plugins/security_solution/server/lib/detection_engine/rule_types/types'; +import { DetectionAlert } from '../../../../plugins/security_solution/common/detection_engine/schemas/alerts'; // eslint-disable-next-line import/no-default-export export default ({ getService }: FtrProviderContext) => { @@ -86,11 +86,12 @@ export default ({ getService }: FtrProviderContext) => { .send({ ids: signalIds, status: 'closed', index: '.siem-signals-default' }) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest - .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) - .set('kbn-xsrf', 'true') - .send(getQuerySignalIds(signalIds)) - .expect(200); + const { body: signalsClosed }: { body: estypes.SearchResponse } = + await supertest + .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) + .set('kbn-xsrf', 'true') + .send(getQuerySignalIds(signalIds)) + .expect(200); expect(signalsClosed.hits.hits.length).to.equal(10); }); @@ -111,11 +112,12 @@ export default ({ getService }: FtrProviderContext) => { .send({ ids: signalIds, status: 'closed', index: '.siem-signals-default' }) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest - .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) - .set('kbn-xsrf', 'true') - .send(getQuerySignalIds(signalIds)) - .expect(200); + const { body: signalsClosed }: { body: estypes.SearchResponse } = + await supertest + .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) + .set('kbn-xsrf', 'true') + .send(getQuerySignalIds(signalIds)) + .expect(200); const everySignalClosed = signalsClosed.hits.hits.every( (hit) => hit._source?.['kibana.alert.workflow_status'] === 'closed' @@ -140,7 +142,7 @@ export default ({ getService }: FtrProviderContext) => { .send({ ids: signalIds, status: 'acknowledged', index: '.siem-signals-default' }) .expect(200); - const { body: acknowledgedSignals }: { body: estypes.SearchResponse } = + const { body: acknowledgedSignals }: { body: estypes.SearchResponse } = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/open_close_signals.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/open_close_signals.ts index 6138995bdc02f..18edf09727d3a 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/open_close_signals.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/open_close_signals.ts @@ -29,7 +29,7 @@ import { } from '../../utils'; import { createUserAndRole, deleteUserAndRole } from '../../../common/services/security_solution'; import { ROLES } from '../../../../plugins/security_solution/common/test'; -import { RACAlert } from '../../../../plugins/security_solution/server/lib/detection_engine/rule_types/types'; +import { DetectionAlert } from '../../../../plugins/security_solution/common/detection_engine/schemas/alerts'; // eslint-disable-next-line import/no-default-export export default ({ getService }: FtrProviderContext) => { @@ -126,7 +126,7 @@ export default ({ getService }: FtrProviderContext) => { .send(setSignalStatus({ signalIds, status: 'closed' })) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = + const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') @@ -152,7 +152,7 @@ export default ({ getService }: FtrProviderContext) => { .send(setSignalStatus({ signalIds, status: 'closed' })) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = + const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') @@ -186,7 +186,7 @@ export default ({ getService }: FtrProviderContext) => { // query for the signals with the superuser // to allow a check that the signals were NOT closed with t1 analyst - const { body: signalsClosed }: { body: estypes.SearchResponse } = + const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') @@ -221,7 +221,7 @@ export default ({ getService }: FtrProviderContext) => { .send(setSignalStatus({ signalIds, status: 'closed' })) .expect(200); - const { body: signalsClosed }: { body: estypes.SearchResponse } = + const { body: signalsClosed }: { body: estypes.SearchResponse } = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') diff --git a/x-pack/test/detection_engine_api_integration/utils.ts b/x-pack/test/detection_engine_api_integration/utils.ts index 594f380199dd6..2fc5cdadecb2a 100644 --- a/x-pack/test/detection_engine_api_integration/utils.ts +++ b/x-pack/test/detection_engine_api_integration/utils.ts @@ -58,8 +58,8 @@ import { SECURITY_TELEMETRY_URL, UPDATE_OR_CREATE_LEGACY_ACTIONS, } from '../../plugins/security_solution/common/constants'; -import { RACAlert } from '../../plugins/security_solution/server/lib/detection_engine/rule_types/types'; import { DetectionMetrics } from '../../plugins/security_solution/server/usage/detections/types'; +import { DetectionAlert } from '../../plugins/security_solution/common/detection_engine/schemas/alerts'; /** * This will remove server generated properties such as date times, etc... @@ -1593,7 +1593,7 @@ export const getSignalsByRuleIds = async ( supertest: SuperTest.SuperTest, log: ToolingLog, ruleIds: string[] -): Promise> => { +): Promise> => { const response = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') @@ -1607,7 +1607,7 @@ export const getSignalsByRuleIds = async ( ); } - const { body: signalsOpen }: { body: estypes.SearchResponse } = response; + const { body: signalsOpen }: { body: estypes.SearchResponse } = response; return signalsOpen; }; @@ -1622,7 +1622,7 @@ export const getSignalsByIds = async ( log: ToolingLog, ids: string[], size?: number -): Promise> => { +): Promise> => { const response = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') @@ -1635,7 +1635,7 @@ export const getSignalsByIds = async ( )}, status: ${JSON.stringify(response.status)}` ); } - const { body: signalsOpen }: { body: estypes.SearchResponse } = response; + const { body: signalsOpen }: { body: estypes.SearchResponse } = response; return signalsOpen; }; @@ -1648,7 +1648,7 @@ export const getSignalsById = async ( supertest: SuperTest.SuperTest, log: ToolingLog, id: string -): Promise> => { +): Promise> => { const response = await supertest .post(DETECTION_ENGINE_QUERY_SIGNALS_URL) .set('kbn-xsrf', 'true') @@ -1661,7 +1661,7 @@ export const getSignalsById = async ( )}, status: ${JSON.stringify(response.status)}` ); } - const { body: signalsOpen }: { body: estypes.SearchResponse } = response; + const { body: signalsOpen }: { body: estypes.SearchResponse } = response; return signalsOpen; }; From 2688cb21f9f29f57beea6b1e91a7e9d45a0ee517 Mon Sep 17 00:00:00 2001 From: Constance Date: Tue, 29 Mar 2022 20:44:44 -0700 Subject: [PATCH 151/160] Upgrade EUI to v52.2.0 (#128841) * Updgraded EUI packages in package.json and src/dev/license_checker/config.js * Resolved Jest test failures for Jest test suites 1 and 2. Updated snapshots, and updated equality conditions for specific test cases * Resolve Jest test cases for Jest test suite 3. Updated snapshots for required tests * Resolved failing Jest test cases in Jest suite 3. Updated tests checking for strict text equality to account for text coming from the EuiScreenReaderOnly component. Also updated tests to account for EuiIcon text that is now rendered when the icon is imported from .testenv (PR 5709 - https://github.com/elastic/eui/pull/5709/). * type fixes * eui to 52.2.0 * Resolved test cases for Jest test suites 1 and 2. Updated required snapshots. Updated tests using getAllByLabelText and getByLabelText to getAllByText and getByText respectively as the former have been deprecated * Updated Jest tests for Jest test suites 5 and 6. Updated required snapshots. Updated instances of getByLabelText and getAllByLabelText to getByText and getAllByText as the former are now deprecated. * Updated Jest tests for Jest test suite 7. Updated required snapshots. * Completed test case revisions for Jest test suites 1, 3, 6, 7, and 8. Updated required snapshots. Updated various tests to account for text rendering of the EuiIcon text. * removed unused test utils * use .contains for euiicon content * storyshots updates * linting * Fix failing a11y violations tests * Fix Jest failures caused by #eui/5709 - these changes should be reverted if we opt to revert the above PR Co-authored-by: Bree Hall Co-authored-by: Greg Thompson --- package.json | 2 +- .../header/__snapshots__/header.test.tsx.snap | 5 +- src/dev/license_checker/config.ts | 2 +- .../url/__snapshots__/url.test.tsx.snap | 10 +-- .../table/__snapshots__/table.test.tsx.snap | 5 +- .../__snapshots__/table_header.test.tsx.snap | 5 +- .../__snapshots__/field_name.test.tsx.snap | 20 +++--- .../not_found_errors.test.tsx.snap | 20 +++--- .../components/not_found_errors.test.tsx | 8 +-- .../link_preview.test.tsx | 6 +- .../custom_link_toolbar.test.tsx | 4 +- .../dropdown_filter.stories.storyshot | 20 ++++-- .../time_filter.stories.storyshot | 60 ++++++++++++----- .../extended_template.stories.storyshot | 8 ++- .../date_format.stories.storyshot | 12 +++- .../number_format.stories.storyshot | 12 +++- .../__snapshots__/asset.stories.storyshot | 32 +++++++--- .../asset_manager.stories.storyshot | 52 +++++++++++---- .../__snapshots__/color_dot.stories.storyshot | 16 +++-- .../color_manager.stories.storyshot | 32 +++++++--- .../color_palette.stories.storyshot | 12 +++- .../color_picker.stories.storyshot | 40 +++++++++--- .../custom_element_modal.stories.storyshot | 44 +++++++++---- .../datasource_component.stories.storyshot | 16 +++-- .../element_card.stories.storyshot | 12 +++- .../file_upload.stories.storyshot | 4 +- .../home/__snapshots__/home.stories.storyshot | 4 +- .../empty_prompt.stories.storyshot | 4 +- .../workpad_table.stories.storyshot | 52 +++++++++++---- .../__snapshots__/item_grid.stories.storyshot | 24 +++++-- .../element_controls.stories.storyshot | 8 ++- .../element_grid.stories.storyshot | 24 +++++-- .../saved_elements_modal.stories.storyshot | 64 ++++++++++++++----- .../sidebar_header.stories.storyshot | 16 +++-- .../__snapshots__/tag.stories.storyshot | 8 ++- .../__snapshots__/tag_list.stories.storyshot | 12 +++- .../text_style_picker.stories.storyshot | 56 ++++++++++++---- .../delete_var.stories.storyshot | 8 ++- .../__snapshots__/edit_var.stories.storyshot | 44 +++++++++---- .../var_config.stories.storyshot | 8 ++- .../filters_group.component.stories.storyshot | 8 ++- ...orkpad_filters.component.stories.storyshot | 40 +++++++++--- .../editor_menu.stories.storyshot | 8 ++- .../element_menu.stories.storyshot | 4 +- .../extended_template.stories.storyshot | 24 +++++-- .../extended_template.stories.storyshot | 16 +++-- .../simple_template.stories.storyshot | 5 +- .../__snapshots__/canvas.stories.storyshot | 48 ++++++++++---- .../__snapshots__/footer.stories.storyshot | 32 +++++++--- .../page_controls.stories.storyshot | 24 +++++-- .../__snapshots__/title.stories.storyshot | 12 +++- .../autoplay_settings.stories.storyshot | 24 +++++-- .../__snapshots__/settings.stories.storyshot | 8 ++- .../toolbar_settings.stories.storyshot | 24 +++++-- .../connectors_dropdown.test.tsx | 2 +- .../markdown_editor/renderer.test.tsx | 2 +- .../components/csp_page_template.test.tsx | 4 +- .../components/table/table.test.tsx | 2 +- .../__jest__/a11y/indices_tab.a11y.test.ts | 43 ++----------- .../index_setup_dataset_filter.tsx | 1 - .../__jest__/test_pipeline.test.tsx | 14 ++-- .../components/table_basic.test.tsx | 4 +- .../field_item.test.tsx | 5 +- .../request_trial_extension.test.js.snap | 8 +-- .../revert_to_basic.test.js.snap | 6 +- .../__snapshots__/start_trial.test.js.snap | 8 +-- .../__snapshots__/exporters.test.js.snap | 15 +++-- .../__snapshots__/reason_found.test.js.snap | 15 +++-- .../list/remote_clusters_list.test.js | 6 +- .../feature_table_cell.test.tsx | 2 +- .../privilege_summary/__fixtures__/index.ts | 2 +- .../exception_item/exception_entries.test.tsx | 2 +- .../common/components/inspect/modal.test.tsx | 6 +- .../common/components/links/index.test.tsx | 10 +-- .../markdown_editor/renderer.test.tsx | 2 +- .../network/components/port/index.test.tsx | 6 +- .../source_destination/index.test.tsx | 4 +- .../source_destination_ip.test.tsx | 8 +-- .../certificate_fingerprint/index.test.tsx | 2 +- .../components/ja3_fingerprint/index.test.tsx | 2 +- .../components/netflow/index.test.tsx | 10 +-- .../__snapshots__/index.test.tsx.snap | 5 +- .../body/renderers/get_row_renderer.test.tsx | 12 +++- .../suricata/suricata_details.test.tsx | 6 +- .../suricata/suricata_row_renderer.test.tsx | 7 +- .../system/generic_row_renderer.test.tsx | 26 +++++--- .../body/renderers/zeek/zeek_details.test.tsx | 16 +++-- .../renderers/zeek/zeek_row_renderer.test.tsx | 7 +- .../renderers/zeek/zeek_signature.test.tsx | 6 +- .../__jest__/client_integration/home.test.ts | 2 +- .../public/components/inspect/modal.test.tsx | 6 +- .../components/health_check.test.tsx | 14 ++-- .../rule_details/components/rule.test.tsx | 9 ++- .../drilldown_table/drilldown_table.test.tsx | 2 +- .../__snapshots__/expanded_row.test.tsx.snap | 5 +- .../monitor_status.bar.test.tsx.snap | 5 +- .../network_requests_total.test.tsx | 4 +- .../components/waterfall_marker_icon.test.tsx | 4 +- .../ux_metrics/key_ux_metrics.test.tsx | 12 ++-- yarn.lock | 8 +-- 100 files changed, 970 insertions(+), 445 deletions(-) diff --git a/package.json b/package.json index 9f2e28774d0de..735f388881999 100644 --- a/package.json +++ b/package.json @@ -108,7 +108,7 @@ "@elastic/datemath": "link:bazel-bin/packages/elastic-datemath", "@elastic/elasticsearch": "npm:@elastic/elasticsearch-canary@8.2.0-canary.1", "@elastic/ems-client": "8.2.0", - "@elastic/eui": "51.1.0", + "@elastic/eui": "52.2.0", "@elastic/filesaver": "1.1.2", "@elastic/node-crypto": "1.2.1", "@elastic/numeral": "^2.5.1", diff --git a/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap b/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap index d2b1078641437..ad0f27bbf08ce 100644 --- a/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap +++ b/src/core/public/chrome/ui/header/__snapshots__/header.test.tsx.snap @@ -3108,12 +3108,13 @@ exports[`Header renders 1`] = ` type="logoElastic" > + > + Elastic Logo + + > + External link + @@ -243,10 +244,11 @@ exports[`UrlFormatEditor should render normally 1`] = ` Label template help + > + External link + diff --git a/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap b/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap index 2b6cf62baf221..c054b42f51ac7 100644 --- a/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap +++ b/src/plugins/data_view_management/public/components/edit_index_pattern/indexed_fields_table/components/table/__snapshots__/table.test.tsx.snap @@ -320,10 +320,11 @@ exports[`Table should render the boolean template (false) 1`] = ``; exports[`Table should render the boolean template (true) 1`] = ` +> + Is searchable + `; exports[`Table should render timestamp field name 1`] = ` diff --git a/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap b/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap index 3f72349f3e2a0..612973fe37a48 100644 --- a/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap +++ b/src/plugins/discover/public/components/doc_table/components/table_header/__snapshots__/table_header.test.tsx.snap @@ -20,10 +20,11 @@ exports[`TableHeader with time column renders correctly 1`] = ` class="euiToolTipAnchor" > + > + Primary time field. + + > + Geo point field + ,
+ > + Number field +
,
+ > + String field +
,
+ > + Unknown field +
,
+ > + External link + + > + External link + + > + External link + + > + External link + { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectThe saved search associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectThe saved search associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); @@ -34,7 +34,7 @@ describe('NotFoundErrors component', () => { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectThe data view associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectThe data view associated with this object no longer exists.If you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); @@ -43,7 +43,7 @@ describe('NotFoundErrors component', () => { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectA field associated with this object no longer exists in the data view.If you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectA field associated with this object no longer exists in the data view.If you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); @@ -52,7 +52,7 @@ describe('NotFoundErrors component', () => { const callOut = mounted.find('EuiCallOut'); expect(callOut).toMatchSnapshot(); expect(mounted.text()).toMatchInlineSnapshot( - `"There is a problem with this saved objectIf you know what this error means, you can use the Saved objects APIs(opens in a new tab or window) to fix it — otherwise click the delete button above."` + `"There is a problem with this saved objectIf you know what this error means, you can use the Saved objects APIsExternal link(opens in a new tab or window) to fix it — otherwise click the delete button above."` ); }); }); diff --git a/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx b/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx index f44b4d1c1205d..4c8a5bc00285e 100644 --- a/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx +++ b/x-pack/plugins/apm/public/components/app/settings/custom_link/create_edit_custom_link_flyout/link_preview.test.tsx @@ -56,7 +56,7 @@ describe('LinkPreview', () => { removeExternalLinkText( (getByTestId(container, 'preview-link') as HTMLAnchorElement).text ) - ).toEqual('https://baz.co'); + ).toContain('https://baz.co'); }); }); @@ -74,7 +74,7 @@ describe('LinkPreview', () => { removeExternalLinkText( (getByTestId(container, 'preview-link') as HTMLAnchorElement).text ) - ).toEqual('https://baz.co?service.name={{invalid}'); + ).toContain('https://baz.co?service.name={{invalid}'); expect(getByTestId(container, 'preview-warning')).toBeInTheDocument(); }); }); @@ -94,7 +94,7 @@ describe('LinkPreview', () => { removeExternalLinkText( (getByTestId(container, 'preview-link') as HTMLAnchorElement).text ) - ).toEqual('https://baz.co?transaction=0'); + ).toContain('https://baz.co?transaction=0'); }); }); }); diff --git a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx index 4d92f5a1ae34a..42ca08cc3d225 100644 --- a/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx +++ b/x-pack/plugins/apm/public/components/shared/transaction_action_menu/custom_link_menu_section/custom_link_toolbar.test.tsx @@ -45,7 +45,7 @@ describe('CustomLinkToolbar', () => { wrapper: Wrapper, }); expect( - component.getByLabelText('Custom links settings page') + component.getByText('Custom links settings page') ).toBeInTheDocument(); expectTextsInDocument(component, ['Create']); }); @@ -56,7 +56,7 @@ describe('CustomLinkToolbar', () => { { wrapper: Wrapper } ); expect( - component.getByLabelText('Custom links settings page') + component.getByText('Custom links settings page') ).toBeInTheDocument(); expectTextsNotInDocument(component, ['Create']); }); diff --git a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot index 52694d3b04089..0ded42439fb95 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/dropdown_filter/component/__stories__/__snapshots__/dropdown_filter.stories.storyshot @@ -35,7 +35,9 @@ exports[`Storyshots renderers/DropdownFilter default 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -96,7 +98,9 @@ exports[`Storyshots renderers/DropdownFilter with choices 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -157,7 +161,9 @@ exports[`Storyshots renderers/DropdownFilter with choices and new value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -218,7 +224,9 @@ exports[`Storyshots renderers/DropdownFilter with choices and value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
@@ -261,7 +269,9 @@ exports[`Storyshots renderers/DropdownFilter with new value 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + +
diff --git a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot index 5abd1e9fd05b6..e82b6bf082b05 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/renderers/filters/time_filter/components/__stories__/__snapshots__/time_filter.stories.storyshot @@ -42,13 +42,17 @@ exports[`Storyshots renderers/TimeFilter default 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + +
+ > + +
@@ -91,7 +95,9 @@ exports[`Storyshots renderers/TimeFilter default 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + +
@@ -150,13 +156,17 @@ exports[`Storyshots renderers/TimeFilter with absolute time bounds 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -235,7 +245,9 @@ exports[`Storyshots renderers/TimeFilter with absolute time bounds 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -294,13 +306,17 @@ exports[`Storyshots renderers/TimeFilter with commonlyUsedRanges 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -343,7 +359,9 @@ exports[`Storyshots renderers/TimeFilter with commonlyUsedRanges 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -402,13 +420,17 @@ exports[`Storyshots renderers/TimeFilter with dateFormat 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -451,7 +473,9 @@ exports[`Storyshots renderers/TimeFilter with dateFormat 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + @@ -510,13 +534,17 @@ exports[`Storyshots renderers/TimeFilter with relative time bounds 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + + > + + @@ -595,7 +623,9 @@ exports[`Storyshots renderers/TimeFilter with relative time bounds 1`] = ` color="inherit" data-euiicon-type="timeRefresh" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot index e3badfa833090..7c0a2ad18c3dc 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/axis_config/__stories__/__snapshots__/extended_template.stories.storyshot @@ -65,7 +65,9 @@ exports[`Storyshots arguments/AxisConfig extended 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -143,7 +145,9 @@ exports[`Storyshots arguments/AxisConfig/components extended 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot index 238fe7c259c6e..9755e1b53b868 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/date_format/__stories__/__snapshots__/date_format.stories.storyshot @@ -47,7 +47,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -120,7 +122,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -192,7 +196,9 @@ exports[`Storyshots arguments/DateFormat with preset format 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + diff --git a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot index 2159e49e2bcf1..ecd8e53ce1d25 100644 --- a/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot +++ b/x-pack/plugins/canvas/canvas_plugin_src/uis/arguments/number_format/__stories__/__snapshots__/number_format.stories.storyshot @@ -57,7 +57,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -140,7 +142,9 @@ Array [ className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -222,7 +226,9 @@ exports[`Storyshots arguments/NumberFormat with preset format 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot index 6db24bd0b984c..587b07ca4f932 100644 --- a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset.stories.storyshot @@ -81,7 +81,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + + @@ -111,7 +113,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -142,7 +146,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + + @@ -169,7 +175,9 @@ exports[`Storyshots components/Assets/Asset airplane 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -260,7 +268,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + + @@ -290,7 +300,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -321,7 +333,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + + @@ -348,7 +362,9 @@ exports[`Storyshots components/Assets/Asset marker 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot index dd650e9f4c697..5409f9c444df0 100644 --- a/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/asset_manager/__stories__/__snapshots__/asset_manager.stories.storyshot @@ -26,7 +26,9 @@ exports[`Storyshots components/Assets/AssetManager no assets 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -122,7 +126,9 @@ exports[`Storyshots components/Assets/AssetManager no assets 1`] = ` color="subdued" data-euiicon-type="importAction" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -380,7 +390,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + +
@@ -410,7 +422,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + +
@@ -441,7 +455,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + +
@@ -468,7 +484,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + +
@@ -548,7 +566,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="vector" size="m" - /> + > + + @@ -578,7 +598,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -609,7 +631,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="copyClipboard" size="m" - /> + > + + @@ -636,7 +660,9 @@ exports[`Storyshots components/Assets/AssetManager two assets 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot b/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot index 056b87294f245..5d83b2718f916 100644 --- a/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_dot/__stories__/__snapshots__/color_dot.stories.storyshot @@ -129,7 +129,9 @@ Array [ + > + + ,
+ > + +
,
+ > + +
,
+ > + +
, ] diff --git a/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot b/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot index cb3598430c7ef..057bd37b71c20 100644 --- a/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_manager/__stories__/__snapshots__/color_manager.stories.storyshot @@ -394,7 +394,9 @@ exports[`Storyshots components/Color/ColorManager interactive 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -805,7 +809,9 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + , @@ -886,7 +894,9 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + , @@ -965,7 +977,9 @@ Array [ color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + , diff --git a/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot b/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot index a0d27eafb23dc..53651c8fe33f2 100644 --- a/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_palette/__stories__/__snapshots__/color_palette.stories.storyshot @@ -393,7 +393,9 @@ Array [ className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -758,7 +760,9 @@ exports[`Storyshots components/Color/ColorPalette six colors, wrap at 4 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -1040,7 +1044,9 @@ Array [ className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot b/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot index 6ef3eec47e701..557f94c26fac9 100644 --- a/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/color_picker/__stories__/__snapshots__/color_picker.stories.storyshot @@ -237,7 +237,9 @@ exports[`Storyshots components/Color/ColorPicker interactive 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -318,7 +322,9 @@ exports[`Storyshots components/Color/ColorPicker six colors 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -526,7 +532,9 @@ exports[`Storyshots components/Color/ColorPicker six colors 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -786,7 +796,9 @@ exports[`Storyshots components/Color/ColorPicker six colors, value missing 1`] = color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + @@ -846,7 +860,9 @@ exports[`Storyshots components/Color/ColorPicker three colors 1`] = ` className="selected-color" color="#333" data-euiicon-type="check" - /> + > + + @@ -970,7 +986,9 @@ exports[`Storyshots components/Color/ColorPicker three colors 1`] = ` color="inherit" data-euiicon-type="plusInCircle" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot b/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot index d8c660923e3d7..feb04e68ca1d3 100644 --- a/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/custom_element_modal/__stories__/__snapshots__/custom_element_modal.stories.storyshot @@ -27,7 +27,9 @@ exports[`Storyshots components/Elements/CustomElementModal with description 1`] color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -224,7 +228,9 @@ exports[`Storyshots components/Elements/CustomElementModal with description 1`] className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -646,7 +656,9 @@ exports[`Storyshots components/Elements/CustomElementModal with name 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -843,7 +857,9 @@ exports[`Storyshots components/Elements/CustomElementModal with name 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -1146,7 +1166,9 @@ exports[`Storyshots components/Elements/CustomElementModal with title 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + + + > + + Test Datasource @@ -70,14 +74,18 @@ exports[`Storyshots components/datasource/DatasourceComponent simple datasource color="inherit" data-euiicon-type="arrowRight" size="m" - /> + > + + + > + + Test Datasource diff --git a/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot b/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot index 14640fe266839..05cec59522ae7 100644 --- a/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/element_card/__stories__/__snapshots__/element_card.stories.storyshot @@ -19,7 +19,9 @@ exports[`Storyshots components/Elements/ElementCard with click handler 1`] = ` className="euiCard__icon" data-euiicon-type="canvasApp" size="xxl" - /> + > + +
+ > + +
+ > + +
+ > + +
diff --git a/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot b/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot index d3ab369dcc32c..0863fd13af607 100644 --- a/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/home/__snapshots__/home.stories.storyshot @@ -59,7 +59,9 @@ exports[`Storyshots Home Home Page 1`] = ` color="inherit" data-euiicon-type="plusInCircleFilled" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot b/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot index 8f00060a1dd1c..fa3789124ce81 100644 --- a/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/home/my_workpads/__snapshots__/empty_prompt.stories.storyshot @@ -28,7 +28,9 @@ exports[`Storyshots Home/Components/Empty Prompt Empty Prompt 1`] = ` color="subdued" data-euiicon-type="importAction" size="xxl" - /> + > + +
+ > + +
@@ -73,7 +75,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` className="euiFilePicker__icon" data-euiicon-type="importAction" size="m" - /> + > + +
@@ -150,7 +154,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -296,7 +302,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` className="euiTableSortIcon" data-euiicon-type="sortDown" size="m" - /> + > + + @@ -460,7 +468,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - /> + > + +
@@ -486,7 +496,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - /> + > + +
@@ -632,7 +644,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - /> + > + +
@@ -658,7 +672,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - /> + > + +
@@ -804,7 +820,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="exportAction" size="m" - /> + > + +
@@ -830,7 +848,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="copy" size="m" - /> + > + +
@@ -873,7 +893,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -915,7 +937,9 @@ exports[`Storyshots Home/Components/Workpad Table Workpad Table 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
    + > + +
diff --git a/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot b/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot index dbb591582e909..e96302525aea4 100644 --- a/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/item_grid/__stories__/__snapshots__/item_grid.stories.storyshot @@ -73,7 +73,9 @@ exports[`Storyshots components/ItemGrid complex grid 1`] = ` + > + +
+ > + +
+ > + +
@@ -125,13 +131,19 @@ exports[`Storyshots components/ItemGrid icon grid 1`] = ` > + > + + + > + + + > + + `; diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot index 6f139df7c8773..9f462d9a4d6cd 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_controls.stories.storyshot @@ -34,7 +34,9 @@ exports[`Storyshots components/SavedElementsModal/ElementControls has two button color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -61,7 +63,9 @@ exports[`Storyshots components/SavedElementsModal/ElementControls has two button color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot index 70ee9f543d768..fbab31e5c8c5b 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/element_grid.stories.storyshot @@ -85,7 +85,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -112,7 +114,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -192,7 +196,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -219,7 +225,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -299,7 +307,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -326,7 +336,9 @@ exports[`Storyshots components/SavedElementsModal/ElementGrid default 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot index fd6f29178aa91..e0b7f40657cf8 100644 --- a/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/saved_elements_modal/__stories__/__snapshots__/saved_elements_modal.stories.storyshot @@ -26,7 +26,9 @@ exports[`Storyshots components/SavedElementsModal no custom elements 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
@@ -99,7 +103,9 @@ exports[`Storyshots components/SavedElementsModal no custom elements 1`] = ` color="subdued" data-euiicon-type="vector" size="xxl" - /> + > + +
+ > + +
+ > + +
@@ -327,7 +337,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -354,7 +366,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -434,7 +448,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -461,7 +477,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -541,7 +559,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -568,7 +588,9 @@ exports[`Storyshots components/SavedElementsModal with custom elements 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + @@ -634,7 +656,9 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="cross" size="m" - /> + > + +
+ > + +
+ > + +
@@ -787,7 +815,9 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="pencil" size="m" - /> + > + + @@ -814,7 +844,9 @@ exports[`Storyshots components/SavedElementsModal with text filter 1`] = ` color="inherit" data-euiicon-type="trash" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot b/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot index 6bf2535131afc..d5e5af856909b 100644 --- a/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/sidebar_header/__stories__/__snapshots__/sidebar_header.stories.storyshot @@ -72,7 +72,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="sortUp" size="m" - /> + > + + @@ -98,7 +100,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="arrowUp" size="m" - /> + > + + @@ -124,7 +128,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="arrowDown" size="m" - /> + > + + @@ -150,7 +156,9 @@ exports[`Storyshots components/Sidebar/SidebarHeader with layer controls 1`] = ` color="inherit" data-euiicon-type="sortDown" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot b/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot index f21ffcf1a70ea..2a1e12c1e0b74 100644 --- a/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/tag/__stories__/__snapshots__/tag.stories.storyshot @@ -57,7 +57,9 @@ exports[`Storyshots components/Tags/Tag as health 1`] = ` + > + +
+ > + +
+ > + +
+ > + +
+ > + +
+ > + +
@@ -244,7 +246,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorBold" size="m" - /> + > + + @@ -274,7 +278,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorItalic" size="m" - /> + > + + @@ -304,7 +310,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorUnderline" size="m" - /> + > + + @@ -348,7 +356,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignLeft" size="m" - /> + > + + @@ -384,7 +394,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignCenter" size="m" - /> + > + + @@ -420,7 +432,9 @@ exports[`Storyshots components/TextStylePicker default 1`] = ` color="inherit" data-euiicon-type="editorAlignRight" size="m" - /> + > + + @@ -598,7 +612,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` className="euiFormControlLayoutCustomIcon__icon" data-euiicon-type="arrowDown" size="s" - /> + > + + @@ -690,7 +706,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorBold" size="m" - /> + > + + @@ -720,7 +738,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorItalic" size="m" - /> + > + + @@ -750,7 +770,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorUnderline" size="m" - /> + > + + @@ -794,7 +816,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignLeft" size="m" - /> + > + + @@ -830,7 +854,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignCenter" size="m" - /> + > + + @@ -866,7 +892,9 @@ exports[`Storyshots components/TextStylePicker interactive 1`] = ` color="inherit" data-euiicon-type="editorAlignRight" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot index f5351b0d8ea5f..0d8a5c0cf4e5d 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/delete_var.stories.storyshot @@ -20,7 +20,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot index 6c70364f9679c..72e1b4d6ef909 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/edit_var.stories.storyshot @@ -20,7 +20,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + @@ -255,7 +259,9 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - /> + > + + @@ -310,7 +316,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + @@ -486,7 +496,9 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - /> + > + + @@ -541,7 +553,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + @@ -717,7 +733,9 @@ Array [ color="inherit" data-euiicon-type="save" size="m" - /> + > + + @@ -772,7 +790,9 @@ Array [ "verticalAlign": "top", } } - /> + > + + + > + + diff --git a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot index 7d43840e431ab..ac27b0443585a 100644 --- a/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/var_config/__stories__/__snapshots__/var_config.stories.storyshot @@ -28,7 +28,9 @@ exports[`Storyshots components/Variables/VarConfig default 1`] = ` color="inherit" data-euiicon-type="arrowRight" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot b/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot index b6d842ac44e21..57fbd4c2109cd 100644 --- a/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot +++ b/x-pack/plugins/canvas/public/components/workpad_filters/__stories__/__snapshots__/filters_group.component.stories.storyshot @@ -33,7 +33,9 @@ exports[`Storyshots components/WorkpadFilters/FiltersGroupComponent default 1`] color="inherit" data-euiicon-type="arrowRight" size="m" - /> + > + +
+ > + +
@@ -1467,7 +1473,9 @@ exports[`Storyshots shareables/Canvas component 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + @@ -2809,7 +2817,9 @@ exports[`Storyshots shareables/Canvas contextual: austin 1`] = ` + > + +
+ > + +
+ > + +
@@ -2949,7 +2963,9 @@ exports[`Storyshots shareables/Canvas contextual: austin 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + @@ -3107,7 +3123,9 @@ exports[`Storyshots shareables/Canvas contextual: hello 1`] = ` + > + +
+ > + +
+ > + +
@@ -3247,7 +3269,9 @@ exports[`Storyshots shareables/Canvas contextual: hello 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot index 90ebc1900d731..6a8d67a70ad1a 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/footer.stories.storyshot @@ -1280,7 +1280,9 @@ exports[`Storyshots shareables/Footer contextual: austin 1`] = ` + > + +
+ > + +
+ > + +
@@ -1420,7 +1426,9 @@ exports[`Storyshots shareables/Footer contextual: austin 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + @@ -1532,7 +1540,9 @@ exports[`Storyshots shareables/Footer contextual: hello 1`] = ` + > + +
+ > + +
+ > + +
@@ -1672,7 +1686,9 @@ exports[`Storyshots shareables/Footer contextual: hello 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot index 9edb6f1fda62f..f2b92754b6d6f 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/page_controls.stories.storyshot @@ -34,7 +34,9 @@ exports[`Storyshots shareables/Footer/PageControls component 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
+ > + +
@@ -131,7 +135,9 @@ exports[`Storyshots shareables/Footer/PageControls contextual: austin 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
+ > + +
@@ -228,7 +236,9 @@ exports[`Storyshots shareables/Footer/PageControls contextual: hello 1`] = ` color="inherit" data-euiicon-type="arrowLeft" size="m" - /> + > + +
+ > + +
diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot index 2b326fd0ec51a..ea19100f6da87 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/__stories__/__snapshots__/title.stories.storyshot @@ -34,7 +34,9 @@ exports[`Storyshots shareables/Footer/Title component 1`] = ` + > + +
+ > + +
+ > + +
+ > + + + > + + @@ -212,12 +216,16 @@ exports[`Storyshots shareables/Footer/Settings/AutoplaySettings component: on, 5 className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + @@ -376,12 +384,16 @@ exports[`Storyshots shareables/Footer/Settings/AutoplaySettings contextual 1`] = className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot index 265cbe460607d..3c3f26bce7e9e 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/settings.stories.storyshot @@ -39,7 +39,9 @@ exports[`Storyshots shareables/Footer/Settings component 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + +
@@ -87,7 +89,9 @@ exports[`Storyshots shareables/Footer/Settings contextual 1`] = ` color="inherit" data-euiicon-type="gear" size="m" - /> + > + + diff --git a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot index 1aafb9cc6b664..d07e5a9edc8ad 100644 --- a/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot +++ b/x-pack/plugins/canvas/shareable_runtime/components/footer/settings/__stories__/__snapshots__/toolbar_settings.stories.storyshot @@ -59,12 +59,16 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings component: off 1` className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + @@ -147,12 +151,16 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings component: on 1`] className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + @@ -235,12 +243,16 @@ exports[`Storyshots shareables/Footer/Settings/ToolbarSettings contextual 1`] = className="euiSwitch__icon" data-euiicon-type="cross" size="m" - /> + > + + + > + + diff --git a/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx b/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx index 4fd56525541a6..63fc2e2695a3a 100644 --- a/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx +++ b/x-pack/plugins/cases/public/components/configure_cases/connectors_dropdown.test.tsx @@ -264,7 +264,7 @@ describe('ConnectorsDropdown', () => { wrapper: ({ children }) => {children}, }); - const tooltips = screen.getAllByLabelText( + const tooltips = screen.getAllByText( 'This connector is deprecated. Update it, or create a new one.' ); expect(tooltips[0]).toBeInTheDocument(); diff --git a/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx b/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx index af803cfc14e05..8cb8b7f23b439 100644 --- a/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx +++ b/x-pack/plugins/cases/public/components/markdown_editor/renderer.test.tsx @@ -25,7 +25,7 @@ describe('Markdown', () => { test('it renders the expected link text', () => { const result = appMockRender.render({markdownWithLink}); - expect(removeExternalLinkText(result.getByTestId('markdown-link').textContent)).toEqual( + expect(removeExternalLinkText(result.getByTestId('markdown-link').textContent)).toContain( 'External Site' ); }); diff --git a/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx b/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx index ef097f224ab5f..8cc8c750b8240 100644 --- a/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx +++ b/x-pack/plugins/cloud_security_posture/public/components/csp_page_template.test.tsx @@ -102,7 +102,7 @@ describe('', () => { renderCspPageTemplate({ children }); Object.values(PACKAGE_NOT_INSTALLED_TEXT).forEach((text) => - expect(screen.getByText(text)).toBeInTheDocument() + expect(screen.getAllByText(text)[0]).toBeInTheDocument() ); expect(screen.queryByText(children)).not.toBeInTheDocument(); expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); @@ -247,7 +247,7 @@ describe('', () => { }); expect(screen.getByText(pageTitle)).toBeInTheDocument(); - expect(screen.getByText(solution, { exact: false })).toBeInTheDocument(); + expect(screen.getAllByText(solution, { exact: false })[0]).toBeInTheDocument(); expect(screen.queryByText(LOADING)).not.toBeInTheDocument(); expect(screen.queryByText(children)).not.toBeInTheDocument(); expect(screen.queryByText(ERROR_LOADING_DATA_DEFAULT_MESSAGE)).not.toBeInTheDocument(); diff --git a/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx b/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx index 863e5e85d9ef3..eb1f82cc01e37 100644 --- a/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx +++ b/x-pack/plugins/data_enhanced/public/search/sessions_mgmt/components/table/table.test.tsx @@ -138,7 +138,7 @@ describe('Background Search Session Management Table', () => { expect(table.find('tbody td').map((node) => node.text())).toMatchInlineSnapshot(` Array [ "App", - "Namevery background search ", + "Namevery background search Info", "# Searches0", "StatusExpired", "Created2 Dec, 2020, 00:19:32", diff --git a/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts b/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts index dada1c0fc91c5..e6c071225316f 100644 --- a/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts +++ b/x-pack/plugins/index_management/__jest__/a11y/indices_tab.a11y.test.ts @@ -6,8 +6,7 @@ */ import { act } from 'react-dom/test-utils'; -// import { expectToBeAccessible } from '@kbn/test-jest-helpers'; -import { getA11yViolations } from '@kbn/test-jest-helpers'; +import { expectToBeAccessible } from '@kbn/test-jest-helpers'; import { IndicesTestBed, setup } from '../client_integration/home/indices_tab.helpers'; import { indexMappings, @@ -38,13 +37,7 @@ describe('A11y Indices tab', () => { }); const { component } = testBed; component.update(); - // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana - // await expectToBeAccessible(component); - // until then check that only 1 expected violation is found - const violations = await getA11yViolations(component); - expect(violations).toHaveLength(1); - const { id } = violations[0]; - expect(id).toEqual('aria-allowed-attr'); + await expectToBeAccessible(component); }); it('when there are indices', async () => { @@ -57,13 +50,7 @@ describe('A11y Indices tab', () => { }); const { component } = testBed; component.update(); - // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana - // await expectToBeAccessible(component); - // until then check that only 1 expected violation is found - const violations = await getA11yViolations(component); - expect(violations).toHaveLength(1); - const { id } = violations[0]; - expect(id).toEqual('aria-allowed-attr'); + await expectToBeAccessible(component); }); describe('index details flyout', () => { @@ -86,26 +73,14 @@ describe('A11y Indices tab', () => { it('summary tab', async () => { const { component, find } = testBed; expect(find('detailPanelTabSelected').text()).toEqual('Summary'); - // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana - // await expectToBeAccessible(component); - // until then check that only 1 expected violation is found - const violations = await getA11yViolations(component); - expect(violations).toHaveLength(1); - const { id } = violations[0]; - expect(id).toEqual('aria-allowed-attr'); + await expectToBeAccessible(component); }); ['settings', 'mappings', 'stats'].forEach((tab) => { it(`${tab} tab`, async () => { const { component, find, actions } = testBed; await actions.selectIndexDetailsTab(tab as 'settings'); expect(find('detailPanelTabSelected').text().toLowerCase()).toEqual(tab); - // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana - // await expectToBeAccessible(component); - // until then check that only 1 expected violation is found - const violations = await getA11yViolations(component); - expect(violations).toHaveLength(1); - const { id } = violations[0]; - expect(id).toEqual('aria-allowed-attr'); + await expectToBeAccessible(component); }); }); @@ -113,13 +88,7 @@ describe('A11y Indices tab', () => { const { component, find, actions } = testBed; await actions.selectIndexDetailsTab('edit_settings'); expect(find('detailPanelTabSelected').text()).toEqual('Edit settings'); - // this is expected to fail and needs to be updated when EUI 52.0.0 is available in Kibana - // await expectToBeAccessible(component); - // until then check that only 1 expected violation is found - const violations = await getA11yViolations(component); - expect(violations).toHaveLength(1); - const { id } = violations[0]; - expect(id).toEqual('aria-allowed-attr'); + await expectToBeAccessible(component); }); }); }); diff --git a/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx b/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx index 0626a946f8848..d44625b1641ac 100644 --- a/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx +++ b/x-pack/plugins/infra/public/components/logging/log_analysis_setup/initial_configuration_step/index_setup_dataset_filter.tsx @@ -65,7 +65,6 @@ export const IndexSetupDatasetFilter: React.FC<{ isSelected={isVisible} onClick={show} iconType="arrowDown" - size="s" > { // Dropdown should be visible and processor status should equal "success" expect(exists('documentsDropdown')).toBe(true); - const initialProcessorStatusLabel = find('processors>0.processorStatusIcon').props()[ - 'aria-label' - ]; + const initialProcessorStatusLabel = find('processors>0.processorStatusIcon').props() + .children; expect(initialProcessorStatusLabel).toEqual('Success'); // Open flyout and click clear all button @@ -320,9 +319,8 @@ describe('Test pipeline', () => { // Verify documents and processors were reset expect(exists('documentsDropdown')).toBe(false); expect(exists('addDocumentsButton')).toBe(true); - const resetProcessorStatusIconLabel = find('processors>0.processorStatusIcon').props()[ - 'aria-label' - ]; + const resetProcessorStatusIconLabel = find('processors>0.processorStatusIcon').props() + .children; expect(resetProcessorStatusIconLabel).toEqual('Not run'); }); }); @@ -332,7 +330,7 @@ describe('Test pipeline', () => { it('should show "inactive" processor status by default', async () => { const { find } = testBed; - const statusIconLabel = find('processors>0.processorStatusIcon').props()['aria-label']; + const statusIconLabel = find('processors>0.processorStatusIcon').props().children; expect(statusIconLabel).toEqual('Not run'); }); @@ -352,7 +350,7 @@ describe('Test pipeline', () => { actions.closeTestPipelineFlyout(); // Verify status - const statusIconLabel = find('processors>0.processorStatusIcon').props()['aria-label']; + const statusIconLabel = find('processors>0.processorStatusIcon').props().children; expect(statusIconLabel).toEqual('Success'); }); diff --git a/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx b/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx index 36fd1581cb9b6..2ad20bf0a43e2 100644 --- a/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx +++ b/x-pack/plugins/lens/public/datatable_visualization/components/table_basic.test.tsx @@ -617,7 +617,9 @@ describe('DatatableComponent', () => { wrapper.setProps({ data: newData }); wrapper.update(); - expect(wrapper.find('[data-test-subj="dataGridHeader"]').children().first().text()).toEqual( + // Using .toContain over .toEqual because this element includes text from + // which can't be seen, but shows in the text content + expect(wrapper.find('[data-test-subj="dataGridHeader"]').children().first().text()).toContain( 'new a' ); }); diff --git a/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx b/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx index c86fdcc33b15f..c20f1c37c6c67 100644 --- a/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx +++ b/x-pack/plugins/lens/public/indexpattern_datasource/field_item.test.tsx @@ -120,7 +120,10 @@ describe('IndexPattern Field Item', () => { it('should display displayName of a field', () => { const wrapper = mountWithIntl(); - expect(wrapper.find('[data-test-subj="lnsFieldListPanelField"]').first().text()).toEqual( + + // Using .toContain over .toEqual because this element includes text from + // which can't be seen, but shows in the text content + expect(wrapper.find('[data-test-subj="lnsFieldListPanelField"]').first().text()).toContain( 'bytesLabel' ); }); diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap index fda479f2888ce..0fd589e4886e3 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/request_trial_extension.test.js.snap @@ -1,9 +1,9 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`RequestTrialExtension component should display when enterprise license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when enterprise license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when license is active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when license is active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; -exports[`RequestTrialExtension component should display when platinum license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription features(opens in a new tab or window), request an extension now.

"`; +exports[`RequestTrialExtension component should display when platinum license is not active and trial has been used 1`] = `"
Extend your trial

If you’d like to continue using machine learning, advanced security, and our other awesome subscription featuresExternal link(opens in a new tab or window), request an extension now.

"`; diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap index 4fa45c4bec5ce..cf977731ee452 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/revert_to_basic.test.js.snap @@ -1,7 +1,7 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`RevertToBasic component should display when license is about to expire 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when license is about to expire 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; -exports[`RevertToBasic component should display when license is expired 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when license is expired 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; -exports[`RevertToBasic component should display when trial is active 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription features(opens in a new tab or window).

"`; +exports[`RevertToBasic component should display when trial is active 1`] = `"
Revert to Basic license

You’ll revert to our free features and lose access to machine learning, advanced security, and other subscription featuresExternal link(opens in a new tab or window).

"`; diff --git a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap index 622bff86ead16..0880eddcc1683 100644 --- a/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap +++ b/x-pack/plugins/license_management/__jest__/__snapshots__/start_trial.test.js.snap @@ -1,9 +1,9 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`StartTrial component when trial is allowed display for basic license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed display for basic license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for expired enterprise license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for expired enterprise license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for expired platinum license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for expired platinum license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; -exports[`StartTrial component when trial is allowed should display for gold license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription features(opens in a new tab or window) have to offer.

"`; +exports[`StartTrial component when trial is allowed should display for gold license 1`] = `"
Start a 30-day trial

Experience what machine learning, advanced security, and all our other subscription featuresExternal link(opens in a new tab or window) have to offer.

"`; diff --git a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap index c5b5e5e65ab38..41501a7eedb62 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/explanations/exporters/__snapshots__/exporters.test.js.snap @@ -87,10 +87,11 @@ Array [ > Elasticsearch Service Console + > + External link + @@ -106,10 +107,11 @@ Array [ > Logs and metrics + > + External link + @@ -125,10 +127,11 @@ Array [ > the documentation page. + > + External link + diff --git a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap index dda853a28239f..faab608e7af14 100644 --- a/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap +++ b/x-pack/plugins/monitoring/public/components/no_data/reasons/__snapshots__/reason_found.test.js.snap @@ -158,10 +158,11 @@ Array [ > Elasticsearch Service Console + > + External link + @@ -177,10 +178,11 @@ Array [ > Logs and metrics + > + External link + @@ -196,10 +198,11 @@ Array [ > the documentation page. + > + External link + diff --git a/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js b/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js index a6987fa19d1ee..26af30ba17c04 100644 --- a/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js +++ b/x-pack/plugins/remote_clusters/__jest__/client_integration/list/remote_clusters_list.test.js @@ -252,7 +252,7 @@ describe('', () => { ], [ '', - remoteCluster2.name, + remoteCluster2.name.concat('Info'), //Tests include the word "info" to account for the rendered text coming from EuiIcon 'Not connected', PROXY_MODE, remoteCluster2.proxyAddress, @@ -261,7 +261,7 @@ describe('', () => { ], [ '', - remoteCluster3.name, + remoteCluster3.name.concat('Info'), //Tests include the word "info" to account for the rendered text coming from EuiIcon 'Not connected', PROXY_MODE, remoteCluster2.proxyAddress, @@ -360,7 +360,7 @@ describe('', () => { ({ rows } = table.getMetaData('remoteClusterListTable')); expect(rows.length).toBe(2); - expect(rows[0].columns[1].value).toEqual(remoteCluster2.name); + expect(rows[0].columns[1].value).toContain(remoteCluster2.name); }); }); diff --git a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx index 7052f724cd1cc..006ae053940d8 100644 --- a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx +++ b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/feature_table_cell/feature_table_cell.test.tsx @@ -40,7 +40,7 @@ describe('FeatureTableCell', () => { ); - expect(wrapper.text()).toMatchInlineSnapshot(`"Test Feature "`); + expect(wrapper.text()).toMatchInlineSnapshot(`"Test Feature Info"`); expect(wrapper.find(EuiIconTip).props().content).toMatchInlineSnapshot(` diff --git a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts index 3a70ff5713bd9..f375263c960c3 100644 --- a/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts +++ b/x-pack/plugins/security/public/management/roles/edit_role/privileges/kibana/privilege_summary/__fixtures__/index.ts @@ -60,7 +60,7 @@ export function getDisplayedFeaturePrivileges( acc[feature.id][key] = { ...acc[feature.id][key], - primaryFeaturePrivilege: primary.text().trim(), + primaryFeaturePrivilege: primary.text().replaceAll('Info', '').trim(), // Removing the word "info" to account for the rendered text coming from EuiIcon hasCustomizedSubFeaturePrivileges: findTestSubject(primary, 'additionalPrivilegesGranted').length > 0, }; diff --git a/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx b/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx index 6070924523f63..a53be08380698 100644 --- a/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/exceptions/viewer/exception_item/exception_entries.test.tsx @@ -158,7 +158,7 @@ describe('ExceptionEntries', () => { expect(parentValue.text()).toEqual(getEmptyValue()); expect(nestedField.exists('.euiToolTipAnchor')).toBeTruthy(); - expect(nestedField.text()).toEqual('host.name'); + expect(nestedField.text()).toContain('host.name'); expect(nestedOperator.text()).toEqual('is'); expect(nestedValue.text()).toEqual('some name'); }); diff --git a/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx b/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx index 7a9c36a986afd..9796ae2624a73 100644 --- a/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/inspect/modal.test.tsx @@ -58,7 +58,7 @@ describe('Modal Inspect', () => { expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="index-pattern-title"]').text() - ).toBe('Index pattern '); + ).toContain('Index pattern '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="index-pattern-description"]') @@ -66,7 +66,7 @@ describe('Modal Inspect', () => { ).toBe('auditbeat-*, filebeat-*, packetbeat-*, winlogbeat-*'); expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="query-time-title"]').text() - ).toBe('Query time '); + ).toContain('Query time '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="query-time-description"]') @@ -76,7 +76,7 @@ describe('Modal Inspect', () => { wrapper .find('.euiDescriptionList__title span[data-test-subj="request-timestamp-title"]') .text() - ).toBe('Request timestamp '); + ).toContain('Request timestamp '); }); test('Click on request Tab', () => { diff --git a/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx b/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx index 97f93b9732c02..adab4db904d6a 100644 --- a/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/links/index.test.tsx @@ -105,7 +105,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders props passed in as link', () => { @@ -463,7 +463,7 @@ describe('Custom Links', () => { describe('WhoisLink', () => { test('it renders ip passed in as domain', () => { const wrapper = mountWithIntl({'Example Link'}); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href', () => { @@ -488,7 +488,7 @@ describe('Custom Links', () => { {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href', () => { @@ -519,7 +519,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href', () => { @@ -548,7 +548,7 @@ describe('Custom Links', () => { const wrapper = mountWithIntl( {'Example Link'} ); - expect(removeExternalLinkText(wrapper.text())).toEqual('Example Link'); + expect(removeExternalLinkText(wrapper.text())).toContain('Example Link'); }); test('it renders correct href when port is a number', () => { diff --git a/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx b/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx index da3785648de62..68588c9338b4c 100644 --- a/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/common/components/markdown_editor/renderer.test.tsx @@ -20,7 +20,7 @@ describe('Markdown', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="markdown-link"]').first().text()) - ).toEqual('External Site'); + ).toContain('External Site'); }); test('it renders the expected href', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx b/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx index 480d200c6756f..ec56dd6934463 100644 --- a/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/port/index.test.tsx @@ -54,9 +54,9 @@ describe('Port', () => { ); - expect(removeExternalLinkText(wrapper.find('[data-test-subj="port"]').first().text())).toEqual( - '443' - ); + expect( + removeExternalLinkText(wrapper.find('[data-test-subj="port"]').first().text()) + ).toContain('443'); }); test('it hyperlinks links destination.port to an external service that describes the purpose of the port', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx b/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx index 3332111d14f8b..bb8b4683c9d30 100644 --- a/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/source_destination/index.test.tsx @@ -205,7 +205,7 @@ describe('SourceDestination', () => { removeExternalLinkText( wrapper.find('[data-test-subj="destination-ip-and-port"]').first().text() ) - ).toEqual('10.1.2.3:80'); + ).toContain('10.1.2.3:80'); }); test('it renders destination.packets', () => { @@ -329,7 +329,7 @@ describe('SourceDestination', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="source-ip-and-port"]').first().text()) - ).toEqual('192.168.1.2:9987'); + ).toContain('192.168.1.2:9987'); }); test('it renders source.packets', () => { diff --git a/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx b/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx index f16cd7dbb109f..6168d98765253 100644 --- a/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx +++ b/x-pack/plugins/security_solution/public/network/components/source_destination/source_destination_ip.test.tsx @@ -984,7 +984,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-source.port"]').first().text() ) - ).toEqual('9987'); + ).toContain('9987'); }); test('it renders the expected destination port when type is `destination`, and both destinationIp and destinationPort are populated', () => { @@ -1038,7 +1038,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-destination.port"]').first().text() ) - ).toEqual('80'); + ).toContain('80'); }); test('it renders the expected source port when type is `source`, but only sourcePort is populated', () => { @@ -1092,7 +1092,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-source.port"]').first().text() ) - ).toEqual('9987'); + ).toContain('9987'); }); test('it renders the expected destination port when type is `destination`, and only destinationPort is populated', () => { @@ -1147,7 +1147,7 @@ describe('SourceDestinationIp', () => { removeExternalLinkText( wrapper.find('[data-test-subj="draggable-content-destination.port"]').first().text() ) - ).toEqual('80'); + ).toContain('80'); }); test('it does NOT render the badge when type is `source`, but both sourceIp and sourcePort are undefined', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx index 4ebb804eab8a4..8b3f0bfdb107a 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/certificate_fingerprint/index.test.tsx @@ -51,7 +51,7 @@ describe('CertificateFingerprint', () => { removeExternalLinkText( wrapper.find('[data-test-subj="certificate-fingerprint-link"]').first().text() ) - ).toEqual('3f4c57934e089f02ae7511200aee2d7e7aabd272'); + ).toContain('3f4c57934e089f02ae7511200aee2d7e7aabd272'); }); test('it renders a hyperlink to an external site to compare the fingerprint against a known set of signatures', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx index 31f2fec942490..ddbba7f2bc9f3 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/ja3_fingerprint/index.test.tsx @@ -48,7 +48,7 @@ describe('Ja3Fingerprint', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="ja3-fingerprint-link"]').first().text()) - ).toEqual('fff799d91b7c01ae3fe6787cfc895552'); + ).toContain('fff799d91b7c01ae3fe6787cfc895552'); }); test('it renders a hyperlink to an external site to compare the fingerprint against a known set of signatures', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx index 8a88a7182af03..9ccabf2f47d44 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/netflow/index.test.tsx @@ -204,7 +204,7 @@ describe('Netflow', () => { removeExternalLinkText( wrapper.find('[data-test-subj="destination-ip-and-port"]').first().text() ) - ).toEqual('10.1.2.3:80'); + ).toContain('10.1.2.3:80'); }); test('it renders destination.packets', () => { @@ -340,7 +340,7 @@ describe('Netflow', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="source-ip-and-port"]').first().text()) - ).toEqual('192.168.1.2:9987'); + ).toContain('192.168.1.2:9987'); }); test('it renders source.packets', () => { @@ -374,7 +374,7 @@ describe('Netflow', () => { .first() .text() ) - ).toEqual('tls.client_certificate.fingerprint.sha1-value'); + ).toContain('tls.client_certificate.fingerprint.sha1-value'); }); test('it hyperlinks tls.fingerprints.ja3.hash site to compare the fingerprint against a known set of signatures', () => { @@ -390,7 +390,7 @@ describe('Netflow', () => { expect( removeExternalLinkText(wrapper.find('[data-test-subj="ja3-fingerprint-link"]').first().text()) - ).toEqual('tls.fingerprints.ja3.hash-value'); + ).toContain('tls.fingerprints.ja3.hash-value'); }); test('it hyperlinks tls.server_certificate.fingerprint.sha1 site to compare the fingerprint against a known set of signatures', () => { @@ -418,7 +418,7 @@ describe('Netflow', () => { .first() .text() ) - ).toEqual('tls.server_certificate.fingerprint.sha1-value'); + ).toContain('tls.server_certificate.fingerprint.sha1-value'); }); test('it renders network.transport', () => { diff --git a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap index 6ea24e5ca57f6..ebb807a590124 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap +++ b/x-pack/plugins/security_solution/public/timelines/components/side_panel/__snapshots__/index.test.tsx.snap @@ -2686,11 +2686,12 @@ exports[`Details Panel Component DetailsPanel:NetworkDetails: rendering it shoul type="popout" > + > + External link + { + return str.replaceAll('External link', ''); +}; + jest.mock('../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -90,7 +96,7 @@ describe('get_column_renderer', () => { {row} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); @@ -109,7 +115,7 @@ describe('get_column_renderer', () => { {row} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); @@ -128,7 +134,7 @@ describe('get_column_renderer', () => { {row} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx index 2d06c040c5b00..f8693d4a4f8ea 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_details.test.tsx @@ -53,7 +53,11 @@ describe('SuricataDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + const removeEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(removeEuiIconText).toEqual( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx index 61ea659964e4d..2022904e548aa 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/suricata/suricata_row_renderer.test.tsx @@ -72,7 +72,12 @@ describe('suricata_row_renderer', () => { {children} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + + const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(extractEuiIconText).toContain( '4ETEXPLOITNETGEARWNR2000v5 hidden_lang_avi Stack Overflow (CVE-2016-10174)Source192.168.0.3:53Destination192.168.0.3:6343' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx index ae2caa8ce8401..4b93c5accb590 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/system/generic_row_renderer.test.tsx @@ -83,6 +83,12 @@ import { import * as i18n from './translations'; import { RowRenderer } from '../../../../../../../common/types'; +// EuiIcons coming from .testenv render the icon's aria-label as a span +// extractEuiIcon removes the aria-label before checking for equality +const extractEuiIconText = (str: string) => { + return str.replaceAll('External link', ''); +}; + jest.mock('../../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -1130,7 +1136,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'NETWORK SERVICE\\NT AUTHORITY@windows-endpoint-1accepted a connection viasvchost.exe(328)with resultsuccessEndpoint network eventincomingtcpSource10.1.2.3:64557North AmericaUnited States🇺🇸USNorth CarolinaConcordDestination10.50.60.70:3389' ); }); @@ -1214,7 +1220,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'NETWORK SERVICE\\NT AUTHORITY@win2019-endpoint-1made a http request viasvchost.exe(2232)Endpoint network eventoutgoinghttptcpSource10.1.2.3:51570Destination10.11.12.13:80North AmericaUnited States🇺🇸USArizonaPhoenix' ); }); @@ -1243,7 +1249,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'SYSTEM\\NT AUTHORITY@HD-gqf-0af7b4feaccepted a connection viaAmSvc.exe(1084)tcp1:network-community_idSource127.0.0.1:49306Destination127.0.0.1:49305' ); }); @@ -1272,7 +1278,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'SYSTEM\\NT AUTHORITY@HD-55b-3ec87f66accepted a connection via(4)tcp1:network-community_idSource::1:51324Destination::1:5357' ); }); @@ -1298,7 +1304,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'NETWORK SERVICE\\NT AUTHORITY@windows-endpoint-1disconnected viasvchost.exe(328)Endpoint network eventincomingtcpSource10.20.30.40:64557North AmericaUnited States🇺🇸USNorth CarolinaConcord(42.47%)1.2KB(57.53%)1.6KBDestination10.11.12.13:3389' ); }); @@ -1327,7 +1333,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'Arun\\Anvi-Acer@HD-obe-8bf77f54disconnected viachrome.exe(11620)8.1KBtcp1:LxYHJJv98b2O0fNccXu6HheXmwk=Source192.168.0.6:59356(25.78%)2.1KB(74.22%)6KBDestination10.156.162.53:443' ); }); @@ -1356,7 +1362,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'SYSTEM\\NT AUTHORITY@HD-55b-3ec87f66disconnected via(4)7.9KBtcp1:ZylzQhsB1dcptA2t4DY8S6l9o8E=Source::1:51338(96.92%)7.7KB(3.08%)249BDestination::1:2869' ); }); @@ -1385,7 +1391,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'root@foohostopened a socket withgoogle_accounts(2166)Outbound socket (10.4.20.1:59554 -> 10.1.2.3:80) Ooutboundtcp1:network-community_idSource10.4.20.1:59554Destination10.1.2.3:80' ); }); @@ -1414,7 +1420,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'root@foohostclosed a socket withgoogle_accounts(2166)Outbound socket (10.4.20.1:59508 -> 10.1.2.3:80) Coutboundtcp1:network-community_idSource10.4.20.1:59508Destination10.1.2.3:80' ); }); @@ -1722,7 +1728,7 @@ describe('GenericRowRenderer', () => { ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toBe( 'iot.example.comasked forlookup.example.comwith question typeA, which resolved to10.1.2.3(response code:NOERROR)viaan unknown process6.937500msOct 8, 2019 @ 10:05:23.241Oct 8, 2019 @ 10:05:23.248outbounddns177Budp1:network-community_idSource10.9.9.9:58732(22.60%)40B(77.40%)137BDestination10.1.1.1:53OceaniaAustralia🇦🇺AU' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx index 62836cbffb2b5..9af22fca0c707 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_details.test.tsx @@ -14,6 +14,12 @@ import { mockTimelineData, TestProviders } from '../../../../../../common/mock'; import { useMountAppended } from '../../../../../../common/utils/use_mount_appended'; import { ZeekDetails } from './zeek_details'; +// EuiIcons coming from .testenv render the icon's aria-label as a span +// extractEuiIcon removes the aria-label before checking for equality +const extractEuiIconText = (str: string) => { + return str.replaceAll('External link', ''); +}; + jest.mock('../../../../../../common/lib/kibana'); jest.mock('@elastic/eui', () => { @@ -53,7 +59,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); @@ -68,7 +74,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'CyIrMA1L1JtLqdIuoldnsudpSource206.189.35.240:57475Destination67.207.67.3:53' ); }); @@ -83,7 +89,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'CZLkpC22NquQJOpkwehttp302Source206.189.35.240:36220Destination192.241.164.26:80' ); }); @@ -98,7 +104,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'noticeDropped:falseScan::Port_Scan8.42.77.171 scanned at least 15 unique ports of host 207.154.238.205 in 0m0sSource8.42.77.171' ); }); @@ -113,7 +119,7 @@ describe('ZeekDetails', () => { /> ); - expect(removeExternalLinkText(wrapper.text())).toEqual( + expect(extractEuiIconText(removeExternalLinkText(wrapper.text()))).toEqual( 'CmTxzt2OVXZLkGDaResslTLSv12TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256Source188.166.66.184:34514Destination91.189.95.15:443' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx index b60a2965bfd70..fda83c0ade12b 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_row_renderer.test.tsx @@ -71,7 +71,12 @@ describe('zeek_row_renderer', () => { {children} ); - expect(removeExternalLinkText(wrapper.text())).toContain( + + const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(extractEuiIconText).toContain( 'C8DRTq362Fios6hw16connectionREJSrConnection attempt rejectedtcpSource185.176.26.101:44059Destination207.154.238.205:11568' ); }); diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx index 3f27b80359131..726716c7f53ab 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/body/renderers/zeek/zeek_signature.test.tsx @@ -101,7 +101,11 @@ describe('ZeekSignature', () => { test('should render value', () => { const wrapper = mount(); - expect(removeExternalLinkText(wrapper.text())).toEqual('abc'); + const extractEuiIconText = removeExternalLinkText(wrapper.text()).replaceAll( + 'External link', + '' + ); + expect(extractEuiIconText).toEqual('abc'); }); test('should render value and link', () => { diff --git a/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts b/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts index 60fe9d2bd7128..a99a6fdb81167 100644 --- a/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts +++ b/x-pack/plugins/snapshot_restore/__jest__/client_integration/home.test.ts @@ -769,7 +769,7 @@ describe('', () => { const stateMessage = find('snapshotDetail.state.value').text(); try { - expect(stateMessage).toBe(expectedMessage); + expect(stateMessage).toContain(expectedMessage); // Messages may include the word "Info" to account for the rendered text coming from EuiIcon } catch { throw new Error( `Expected snapshot state message "${expectedMessage}" for state "${state}, but got "${stateMessage}".` diff --git a/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx b/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx index 5ac75f92ea45f..f3846cd784ccc 100644 --- a/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx +++ b/x-pack/plugins/timelines/public/components/inspect/modal.test.tsx @@ -110,7 +110,7 @@ describe('Modal Inspect', () => { expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="index-pattern-title"]').text() - ).toBe('Index pattern '); + ).toContain('Index pattern '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="index-pattern-description"]') @@ -118,7 +118,7 @@ describe('Modal Inspect', () => { ).toBe('auditbeat-*, filebeat-*, packetbeat-*, winlogbeat-*'); expect( wrapper.find('.euiDescriptionList__title span[data-test-subj="query-time-title"]').text() - ).toBe('Query time '); + ).toContain('Query time '); expect( wrapper .find('.euiDescriptionList__description span[data-test-subj="query-time-description"]') @@ -128,7 +128,7 @@ describe('Modal Inspect', () => { wrapper .find('.euiDescriptionList__title span[data-test-subj="request-timestamp-title"]') .text() - ).toBe('Request timestamp '); + ).toContain('Request timestamp '); }); test('Click on request Tab', () => { diff --git a/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx index d23f1cfacf94b..6942a7708db78 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/components/health_check.test.tsx @@ -107,10 +107,12 @@ describe('health check', () => { const [action] = queryAllByText(/Learn more/i); expect(description.textContent).toMatchInlineSnapshot( - `"You must enable API keys to use Alerting. Learn more.(opens in a new tab or window)"` + `"You must enable API keys to use Alerting. Learn more.External link(opens in a new tab or window)"` ); - expect(action.textContent).toMatchInlineSnapshot(`"Learn more.(opens in a new tab or window)"`); + expect(action.textContent).toMatchInlineSnapshot( + `"Learn more.External link(opens in a new tab or window)"` + ); expect(action.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/elasticsearch/reference/mocked-test-branch/security-settings.html#api-key-service-settings"` @@ -141,12 +143,12 @@ describe('health check', () => { const description = queryByRole(/banner/i); expect(description!.textContent).toMatchInlineSnapshot( - `"You must configure an encryption key to use Alerting. Learn more.(opens in a new tab or window)"` + `"You must configure an encryption key to use Alerting. Learn more.External link(opens in a new tab or window)"` ); const action = queryByText(/Learn/i); expect(action!.textContent).toMatchInlineSnapshot( - `"Learn more.(opens in a new tab or window)"` + `"Learn more.External link(opens in a new tab or window)"` ); expect(action!.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/kibana/mocked-test-branch/alert-action-settings-kb.html#general-alert-action-settings"` @@ -179,12 +181,12 @@ describe('health check', () => { const description = queryByText(/You must enable/i); expect(description!.textContent).toMatchInlineSnapshot( - `"You must enable API keys and configure an encryption key to use Alerting. Learn more.(opens in a new tab or window)"` + `"You must enable API keys and configure an encryption key to use Alerting. Learn more.External link(opens in a new tab or window)"` ); const action = queryByText(/Learn/i); expect(action!.textContent).toMatchInlineSnapshot( - `"Learn more.(opens in a new tab or window)"` + `"Learn more.External link(opens in a new tab or window)"` ); expect(action!.getAttribute('href')).toMatchInlineSnapshot( `"https://www.elastic.co/guide/en/kibana/mocked-test-branch/alerting-setup.html#alerting-prerequisites"` diff --git a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx index 737501f444300..e7cafb23ee0fa 100644 --- a/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx +++ b/x-pack/plugins/triggers_actions_ui/public/application/sections/rule_details/components/rule.test.tsx @@ -373,9 +373,12 @@ describe('execution duration overview', () => { const avgExecutionDurationPanel = wrapper.find('[data-test-subj="avgExecutionDurationPanel"]'); expect(avgExecutionDurationPanel.exists()).toBeTruthy(); expect(avgExecutionDurationPanel.first().prop('color')).toEqual('warning'); - expect(wrapper.find('EuiStat[data-test-subj="avgExecutionDurationStat"]').text()).toEqual( - 'Average duration16:44:44.345' - ); + + const avgExecutionDurationStat = wrapper + .find('EuiStat[data-test-subj="avgExecutionDurationStat"]') + .text() + .replaceAll('Info', ''); + expect(avgExecutionDurationStat).toEqual('Average duration16:44:44.345'); expect(wrapper.find('[data-test-subj="ruleDurationWarning"]').exists()).toBeTruthy(); }); diff --git a/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx b/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx index ee485f8aee0c0..3576d7e34fd0b 100644 --- a/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx +++ b/x-pack/plugins/ui_actions_enhanced/public/drilldowns/drilldown_manager/components/drilldown_table/drilldown_table.test.tsx @@ -63,5 +63,5 @@ test('Can delete drilldowns', () => { test('Error is displayed', () => { const screen = render(); - expect(screen.getByLabelText('an error')).toBeInTheDocument(); + expect(screen.getByText('an error')).toBeInTheDocument(); }); diff --git a/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap b/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap index 51753d2ce8bb3..bf25513a6bc2c 100644 --- a/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap +++ b/x-pack/plugins/uptime/public/components/monitor/ping_list/__snapshots__/expanded_row.test.tsx.snap @@ -179,10 +179,11 @@ exports[`PingListExpandedRow renders link to docs if body is not recorded but it > docs + > + External link + diff --git a/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap b/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap index 80b751d8e243b..29d1ba922de8f 100644 --- a/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap +++ b/x-pack/plugins/uptime/public/components/monitor/status_details/__snapshots__/monitor_status.bar.test.tsx.snap @@ -72,10 +72,11 @@ Array [ > Set tags + > + External link + diff --git a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx index 63b4d2945a51c..671371093c819 100644 --- a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/network_requests_total.test.tsx @@ -11,7 +11,7 @@ import { render } from '../../../../../lib/helper/rtl_helpers'; describe('NetworkRequestsTotal', () => { it('message in case total is greater than fetched', () => { - const { getByText, getByLabelText } = render( + const { getByText } = render( { ); expect(getByText('First 1000/1100 network requests')).toBeInTheDocument(); - expect(getByLabelText('Info')).toBeInTheDocument(); + expect(getByText('Info')).toBeInTheDocument(); }); it('message in case total is equal to fetched requests', () => { diff --git a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx index 7558a82e45df4..4241a7238ecd6 100644 --- a/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx +++ b/x-pack/plugins/uptime/public/components/monitor/synthetics/waterfall/components/waterfall_marker_icon.test.tsx @@ -13,8 +13,8 @@ import { TestWrapper } from './waterfall_marker_test_helper'; describe('', () => { it('renders a dot icon when `field` is an empty string', () => { - const { getByLabelText } = render(); - expect(getByLabelText('An icon indicating that this marker has no field associated with it')); + const { getByText } = render(); + expect(getByText('An icon indicating that this marker has no field associated with it')); }); it('renders an embeddable when opened', async () => { diff --git a/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx b/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx index 2b899aad783d7..d232b12f3a47b 100644 --- a/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx +++ b/x-pack/plugins/ux/public/components/app/rum_dashboard/ux_metrics/key_ux_metrics.test.tsx @@ -45,20 +45,22 @@ describe('KeyUXMetrics', () => { }; }; + // Tests include the word "info" between the task and time to account for the rendered text coming from + // the EuiIcon (tooltip) embedded within each stat description expect( - getAllByText(checkText('Longest long task duration271 ms'))[0] + getAllByText(checkText('Longest long task durationInfo271 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('Total long tasks duration520 ms'))[0] + getAllByText(checkText('Total long tasks durationInfo520 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('No. of long tasks3'))[0] + getAllByText(checkText('No. of long tasksInfo3'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('Total blocking time271 ms'))[0] + getAllByText(checkText('Total blocking timeInfo271 ms'))[0] ).toBeInTheDocument(); expect( - getAllByText(checkText('First contentful paint1.27 s'))[0] + getAllByText(checkText('First contentful paintInfo1.27 s'))[0] ).toBeInTheDocument(); }); }); diff --git a/yarn.lock b/yarn.lock index c13acd20ed888..7168c8af39761 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1516,10 +1516,10 @@ resolved "https://registry.yarnpkg.com/@elastic/eslint-plugin-eui/-/eslint-plugin-eui-0.0.2.tgz#56b9ef03984a05cc213772ae3713ea8ef47b0314" integrity sha512-IoxURM5zraoQ7C8f+mJb9HYSENiZGgRVcG4tLQxE61yHNNRDXtGDWTZh8N1KIHcsqN1CEPETjuzBXkJYF/fDiQ== -"@elastic/eui@51.1.0": - version "51.1.0" - resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-51.1.0.tgz#338b710ae7a819bb7c3b8e1916080610e0b8e691" - integrity sha512-pjbBSkfDPAjXBRCMk4zsyZ3sPpf70XVcbOzr4BzT0MW38uKjEgEh6nu1aCdnOi+jVSHRtziJkX9rD8BRDWfsnw== +"@elastic/eui@52.2.0": + version "52.2.0" + resolved "https://registry.yarnpkg.com/@elastic/eui/-/eui-52.2.0.tgz#761101a29b96a4b5270ef93541dab7bb27f5ca50" + integrity sha512-XboYerntCOTHWHYMWJGzJtu5JYO6pk5IWh0ZHJEQ4SEjmLbTV2bFrVBTO/8uaU7GhV9/RNIo7BU5wHRyYP7z1g== dependencies: "@types/chroma-js" "^2.0.0" "@types/lodash" "^4.14.160" From 118321fff993ad0a802237dee9f43e133b9af5bd Mon Sep 17 00:00:00 2001 From: Nick Peihl Date: Wed, 30 Mar 2022 00:17:55 -0400 Subject: [PATCH 152/160] [Maps] Support custom icons in maps (#113144) Adds support for users to upload their own SVG icons for styling geo_points or clusters in Elastic Maps. Because Elastic Maps uses WebGL, dynamic styling requires rendering SVG icons as monochromatic PNGs using a Signed Distance Function algorithm. As a result, highly detailed designs and any color definitions in SVGs uploaded to Maps are not retained. Monochromatic SVG icons work best. Custom icons are appended to the map saved object and are not accessible in other maps. Using the custom icon in another map requires creating a copy of the existing map or uploading the icon to the new map. Custom icons can be added, edited, or deleted in Map Settings. Custom icons can also be added from within the Icon select menu. --- docs/maps/vector-style-properties.asciidoc | 1 - x-pack/plugins/maps/common/constants.ts | 11 + .../style_property_descriptor_types.ts | 13 + .../maps/public/actions/layer_actions.test.ts | 5 + .../maps/public/actions/layer_actions.ts | 4 +- .../maps/public/actions/map_actions.ts | 58 ++- .../maps/public/classes/layers/layer.tsx | 9 +- .../blended_vector_layer.test.tsx | 8 + .../blended_vector_layer.ts | 3 + .../mvt_vector_layer.test.tsx | 2 +- .../mvt_vector_layer/mvt_vector_layer.tsx | 4 +- .../layers/vector_layer/vector_layer.test.tsx | 2 + .../layers/vector_layer/vector_layer.tsx | 4 + .../maps/public/classes/styles/_index.scss | 2 + .../maps/public/classes/styles/style.ts | 5 +- .../__snapshots__/vector_icon.test.tsx.snap | 12 + .../components/legend/breaked_legend.tsx | 10 +- .../vector/components/legend/category.tsx | 12 +- .../vector/components/legend/symbol_icon.tsx | 8 +- .../components/legend/vector_icon.test.tsx | 16 + .../vector/components/legend/vector_icon.tsx | 25 +- .../components/legend/vector_style_legend.tsx | 4 +- .../vector/components/style_prop_editor.tsx | 3 + .../custom_icon_modal.test.tsx.snap | 311 ++++++++++++++ .../icon_map_select.test.tsx.snap | 49 ++- .../__snapshots__/icon_select.test.js.snap | 254 ++++++++--- .../components/symbol/_custom_icon_modal.scss | 8 + .../components/symbol/_icon_preview.scss | 3 + .../components/symbol/_icon_select.scss | 2 +- .../symbol/custom_icon_modal.test.tsx | 42 ++ .../components/symbol/custom_icon_modal.tsx | 393 ++++++++++++++++++ .../components/symbol/dynamic_icon_form.js | 4 + .../symbol/icon_map_select.test.tsx | 55 ++- .../components/symbol/icon_map_select.tsx | 17 +- .../vector/components/symbol/icon_preview.tsx | 223 ++++++++++ .../vector/components/symbol/icon_select.js | 140 ++++++- .../components/symbol/icon_select.test.js | 46 +- .../vector/components/symbol/icon_stops.js | 229 +++++----- .../components/symbol/static_icon_form.js | 21 +- .../components/vector_style_editor.test.tsx | 6 +- .../vector/components/vector_style_editor.tsx | 5 + .../classes/styles/vector/maki_icons.ts | 2 +- .../dynamic_icon_property.test.tsx.snap | 92 ++++ .../properties/dynamic_color_property.tsx | 14 +- .../properties/dynamic_icon_property.test.tsx | 37 +- .../properties/dynamic_icon_property.tsx | 9 +- .../properties/dynamic_size_property.tsx | 7 +- .../vector/properties/static_icon_property.ts | 2 +- .../vector/properties/static_size_property.ts | 6 +- .../vector/properties/style_property.ts | 1 + .../properties/test_helpers/test_util.ts | 8 + .../classes/styles/vector/style_util.test.ts | 60 ++- .../classes/styles/vector/style_util.ts | 8 +- .../classes/styles/vector/symbol_utils.js | 50 ++- .../styles/vector/symbol_utils.test.js | 11 +- .../styles/vector/vector_style.test.js | 24 +- .../classes/styles/vector/vector_style.tsx | 76 +++- .../edit_layer_panel/style_settings/index.ts | 7 +- .../style_settings/style_settings.tsx | 7 +- .../custom_icons_panel.test.tsx.snap | 125 ++++++ .../custom_icons_panel.test.tsx | 52 +++ .../map_settings_panel/custom_icons_panel.tsx | 202 +++++++++ .../map_settings_panel/index.ts | 17 +- .../map_settings_panel/map_settings_panel.tsx | 15 +- .../connected_components/mb_map/index.ts | 2 + .../connected_components/mb_map/mb_map.tsx | 36 +- .../reducers/map/default_map_settings.ts | 1 + .../plugins/maps/public/reducers/map/types.ts | 2 + .../public/selectors/map_selectors.test.ts | 16 +- .../maps/public/selectors/map_selectors.ts | 37 +- yarn.lock | 24 ++ 71 files changed, 2646 insertions(+), 333 deletions(-) create mode 100644 x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/custom_icon_modal.test.tsx.snap create mode 100644 x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_custom_icon_modal.scss create mode 100644 x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_preview.scss create mode 100644 x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.test.tsx create mode 100644 x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.tsx create mode 100644 x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_preview.tsx create mode 100644 x-pack/plugins/maps/public/connected_components/map_settings_panel/__snapshots__/custom_icons_panel.test.tsx.snap create mode 100644 x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.test.tsx create mode 100644 x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.tsx diff --git a/docs/maps/vector-style-properties.asciidoc b/docs/maps/vector-style-properties.asciidoc index be1b2c5e25285..ac06ba32e6e40 100644 --- a/docs/maps/vector-style-properties.asciidoc +++ b/docs/maps/vector-style-properties.asciidoc @@ -61,7 +61,6 @@ Available icons [role="screenshot"] image::maps/images/maki-icons.png[] - [float] [[polygon-style-properties]] ==== Polygon style properties diff --git a/x-pack/plugins/maps/common/constants.ts b/x-pack/plugins/maps/common/constants.ts index e02fead277f60..b51259307f3a1 100644 --- a/x-pack/plugins/maps/common/constants.ts +++ b/x-pack/plugins/maps/common/constants.ts @@ -218,6 +218,17 @@ export enum LABEL_BORDER_SIZES { } export const DEFAULT_ICON = 'marker'; +export const DEFAULT_CUSTOM_ICON_CUTOFF = 0.25; +export const DEFAULT_CUSTOM_ICON_RADIUS = 0.25; +export const CUSTOM_ICON_SIZE = 64; +export const CUSTOM_ICON_PREFIX_SDF = '__kbn__custom_icon_sdf__'; +export const MAKI_ICON_SIZE = 16; +export const HALF_MAKI_ICON_SIZE = MAKI_ICON_SIZE / 2; + +export enum ICON_SOURCE { + CUSTOM = 'CUSTOM', + MAKI = 'MAKI', +} export enum VECTOR_STYLES { SYMBOLIZE_AS = 'symbolizeAs', diff --git a/x-pack/plugins/maps/common/descriptor_types/style_property_descriptor_types.ts b/x-pack/plugins/maps/common/descriptor_types/style_property_descriptor_types.ts index 1a334448e9208..dce4d0f9df50e 100644 --- a/x-pack/plugins/maps/common/descriptor_types/style_property_descriptor_types.ts +++ b/x-pack/plugins/maps/common/descriptor_types/style_property_descriptor_types.ts @@ -10,6 +10,7 @@ import { COLOR_MAP_TYPE, FIELD_ORIGIN, + ICON_SOURCE, LABEL_BORDER_SIZES, SYMBOLIZE_AS_TYPES, VECTOR_STYLES, @@ -60,6 +61,7 @@ export type CategoryColorStop = { export type IconStop = { stop: string | null; icon: string; + iconSource?: ICON_SOURCE; }; export type ColorDynamicOptions = { @@ -108,6 +110,9 @@ export type IconDynamicOptions = { export type IconStaticOptions = { value: string; // icon id + label?: string; + svg?: string; + iconSource?: ICON_SOURCE; }; export type IconStylePropertyDescriptor = @@ -178,6 +183,14 @@ export type SizeStylePropertyDescriptor = options: SizeDynamicOptions; }; +export type CustomIcon = { + symbolId: string; + svg: string; // svg string + label: string; // user given label + cutoff: number; + radius: number; +}; + export type VectorStylePropertiesDescriptor = { [VECTOR_STYLES.SYMBOLIZE_AS]: SymbolizeAsStylePropertyDescriptor; [VECTOR_STYLES.FILL_COLOR]: ColorStylePropertyDescriptor; diff --git a/x-pack/plugins/maps/public/actions/layer_actions.test.ts b/x-pack/plugins/maps/public/actions/layer_actions.test.ts index 06adbed92c0cf..cbec68e5108f8 100644 --- a/x-pack/plugins/maps/public/actions/layer_actions.test.ts +++ b/x-pack/plugins/maps/public/actions/layer_actions.test.ts @@ -39,6 +39,11 @@ describe('layer_actions', () => { return true; }; + // eslint-disable-next-line @typescript-eslint/no-var-requires + require('../selectors/map_selectors').getCustomIcons = () => { + return []; + }; + // eslint-disable-next-line @typescript-eslint/no-var-requires require('../selectors/map_selectors').createLayerInstance = () => { return { diff --git a/x-pack/plugins/maps/public/actions/layer_actions.ts b/x-pack/plugins/maps/public/actions/layer_actions.ts index b081ed6d34979..a89172f8ce340 100644 --- a/x-pack/plugins/maps/public/actions/layer_actions.ts +++ b/x-pack/plugins/maps/public/actions/layer_actions.ts @@ -11,6 +11,7 @@ import { Query } from 'src/plugins/data/public'; import { MapStoreState } from '../reducers/store'; import { createLayerInstance, + getCustomIcons, getEditState, getLayerById, getLayerList, @@ -174,8 +175,7 @@ export function addLayer(layerDescriptor: LayerDescriptor) { layer: layerDescriptor, }); dispatch(syncDataForLayerId(layerDescriptor.id, false)); - - const layer = createLayerInstance(layerDescriptor); + const layer = createLayerInstance(layerDescriptor, getCustomIcons(getState())); const features = await layer.getLicensedFeatures(); features.forEach(notifyLicensedFeatureUsage); }; diff --git a/x-pack/plugins/maps/public/actions/map_actions.ts b/x-pack/plugins/maps/public/actions/map_actions.ts index cccb49f360622..24a378335bc56 100644 --- a/x-pack/plugins/maps/public/actions/map_actions.ts +++ b/x-pack/plugins/maps/public/actions/map_actions.ts @@ -14,10 +14,11 @@ import turfBooleanContains from '@turf/boolean-contains'; import { Filter } from '@kbn/es-query'; import { Query, TimeRange } from 'src/plugins/data/public'; import { Geometry, Position } from 'geojson'; -import { asyncForEach } from '@kbn/std'; -import { DRAW_MODE, DRAW_SHAPE } from '../../common/constants'; +import { asyncForEach, asyncMap } from '@kbn/std'; +import { DRAW_MODE, DRAW_SHAPE, LAYER_STYLE_TYPE } from '../../common/constants'; import type { MapExtentState, MapViewContext } from '../reducers/map/types'; import { MapStoreState } from '../reducers/store'; +import { IVectorStyle } from '../classes/styles/vector/vector_style'; import { getDataFilters, getFilters, @@ -60,7 +61,13 @@ import { } from './data_request_actions'; import { addLayer, addLayerWithoutDataSync } from './layer_actions'; import { MapSettings } from '../reducers/map'; -import { DrawState, MapCenterAndZoom, MapExtent, Timeslice } from '../../common/descriptor_types'; +import { + CustomIcon, + DrawState, + MapCenterAndZoom, + MapExtent, + Timeslice, +} from '../../common/descriptor_types'; import { INITIAL_LOCATION } from '../../common/constants'; import { updateTooltipStateForLayer } from './tooltip_actions'; import { isVectorLayer, IVectorLayer } from '../classes/layers/vector_layer'; @@ -108,6 +115,51 @@ export function updateMapSetting( }; } +export function updateCustomIcons(customIcons: CustomIcon[]) { + return { + type: UPDATE_MAP_SETTING, + settingKey: 'customIcons', + settingValue: customIcons.map((icon) => { + return { ...icon, svg: Buffer.from(icon.svg).toString('base64') }; + }), + }; +} + +export function deleteCustomIcon(value: string) { + return async ( + dispatch: ThunkDispatch, + getState: () => MapStoreState + ) => { + const layersContainingCustomIcon = getLayerList(getState()).filter((layer) => { + const style = layer.getCurrentStyle(); + if (!style || style.getType() !== LAYER_STYLE_TYPE.VECTOR) { + return false; + } + return (style as IVectorStyle).isUsingCustomIcon(value); + }); + + if (layersContainingCustomIcon.length > 0) { + const layerList = await asyncMap(layersContainingCustomIcon, async (layer) => { + return await layer.getDisplayName(); + }); + getToasts().addWarning( + i18n.translate('xpack.maps.mapActions.deleteCustomIconWarning', { + defaultMessage: `Unable to delete icon. The icon is in use by the {count, plural, one {layer} other {layers}}: {layerNames}`, + values: { + count: layerList.length, + layerNames: layerList.join(', '), + }, + }) + ); + } else { + const newIcons = getState().map.settings.customIcons.filter( + ({ symbolId }) => symbolId !== value + ); + dispatch(updateMapSetting('customIcons', newIcons)); + } + }; +} + export function mapReady() { return ( dispatch: ThunkDispatch, diff --git a/x-pack/plugins/maps/public/classes/layers/layer.tsx b/x-pack/plugins/maps/public/classes/layers/layer.tsx index 99afa21a3f003..458a8a159a25d 100644 --- a/x-pack/plugins/maps/public/classes/layers/layer.tsx +++ b/x-pack/plugins/maps/public/classes/layers/layer.tsx @@ -26,6 +26,7 @@ import { import { copyPersistentState } from '../../reducers/copy_persistent_state'; import { Attribution, + CustomIcon, LayerDescriptor, MapExtent, StyleDescriptor, @@ -92,7 +93,8 @@ export interface ILayer { isVisible(): boolean; cloneDescriptor(): Promise; renderStyleEditor( - onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void + onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void, + onCustomIconsChange: (customIcons: CustomIcon[]) => void ): ReactElement | null; getInFlightRequestTokens(): symbol[]; getPrevRequestToken(dataId: string): symbol | undefined; @@ -431,13 +433,14 @@ export class AbstractLayer implements ILayer { } renderStyleEditor( - onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void + onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void, + onCustomIconsChange: (customIcons: CustomIcon[]) => void ): ReactElement | null { const style = this.getStyleForEditing(); if (!style) { return null; } - return style.renderEditor(onStyleDescriptorChange); + return style.renderEditor(onStyleDescriptorChange, onCustomIconsChange); } getIndexPatternIds(): string[] { diff --git a/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.test.tsx b/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.test.tsx index ee97f4c243491..f2ef7ca9588be 100644 --- a/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.test.tsx +++ b/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.test.tsx @@ -10,6 +10,7 @@ import { BlendedVectorLayer } from './blended_vector_layer'; import { ESSearchSource } from '../../../sources/es_search_source'; import { AbstractESSourceDescriptor, + CustomIcon, ESGeoGridSourceDescriptor, } from '../../../../../common/descriptor_types'; @@ -23,6 +24,8 @@ jest.mock('../../../../kibana_services', () => { const mapColors: string[] = []; +const customIcons: CustomIcon[] = []; + const notClusteredDataRequest = { data: { isSyncClustered: false }, dataId: 'ACTIVE_COUNT_DATA_ID', @@ -51,6 +54,7 @@ describe('getSource', () => { }, mapColors ), + customIcons, }); const source = blendedVectorLayer.getSource(); @@ -72,6 +76,7 @@ describe('getSource', () => { }, mapColors ), + customIcons, }); const source = blendedVectorLayer.getSource(); @@ -112,6 +117,7 @@ describe('getSource', () => { }, mapColors ), + customIcons, }); const source = blendedVectorLayer.getSource(); @@ -132,6 +138,7 @@ describe('cloneDescriptor', () => { }, mapColors ), + customIcons, }); const clonedLayerDescriptor = await blendedVectorLayer.cloneDescriptor(); @@ -151,6 +158,7 @@ describe('cloneDescriptor', () => { }, mapColors ), + customIcons, }); const clonedLayerDescriptor = await blendedVectorLayer.cloneDescriptor(); diff --git a/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.ts b/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.ts index 91421a31219cb..e46c670b677ba 100644 --- a/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.ts +++ b/x-pack/plugins/maps/public/classes/layers/vector_layer/blended_vector_layer/blended_vector_layer.ts @@ -31,6 +31,7 @@ import { ISource } from '../../../sources/source'; import { DataRequestContext } from '../../../../actions'; import { DataRequestAbortError } from '../../../util/data_request'; import { + CustomIcon, VectorStyleDescriptor, SizeDynamicOptions, DynamicStylePropertyOptions, @@ -171,6 +172,7 @@ export interface BlendedVectorLayerArguments { chartsPaletteServiceGetColor?: (value: string) => string | null; source: IVectorSource; layerDescriptor: VectorLayerDescriptor; + customIcons: CustomIcon[]; } export class BlendedVectorLayer extends GeoJsonVectorLayer implements IVectorLayer { @@ -207,6 +209,7 @@ export class BlendedVectorLayer extends GeoJsonVectorLayer implements IVectorLay clusterStyleDescriptor, this._clusterSource, this, + options.customIcons, options.chartsPaletteServiceGetColor ); diff --git a/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.test.tsx b/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.test.tsx index 4e4e76d3634f4..27d377851152e 100644 --- a/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.test.tsx +++ b/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.test.tsx @@ -58,7 +58,7 @@ function createLayer( sourceDescriptor, }; const layerDescriptor = MvtVectorLayer.createDescriptor(defaultLayerOptions); - return new MvtVectorLayer({ layerDescriptor, source: mvtSource }); + return new MvtVectorLayer({ layerDescriptor, source: mvtSource, customIcons: [] }); } describe('visiblity', () => { diff --git a/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.tsx b/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.tsx index 5947013dc39f1..325e302c0941a 100644 --- a/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.tsx +++ b/x-pack/plugins/maps/public/classes/layers/vector_layer/mvt_vector_layer/mvt_vector_layer.tsx @@ -54,8 +54,8 @@ export class MvtVectorLayer extends AbstractVectorLayer { readonly _source: IMvtVectorSource; - constructor({ layerDescriptor, source }: VectorLayerArguments) { - super({ layerDescriptor, source }); + constructor({ layerDescriptor, source, customIcons }: VectorLayerArguments) { + super({ layerDescriptor, source, customIcons }); this._source = source as IMvtVectorSource; } diff --git a/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.test.tsx b/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.test.tsx index bd2c8a036bf59..5b91e5e49c514 100644 --- a/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.test.tsx +++ b/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.test.tsx @@ -86,6 +86,7 @@ describe('cloneDescriptor', () => { const layer = new AbstractVectorLayer({ layerDescriptor, source: new MockSource() as unknown as IVectorSource, + customIcons: [], }); const clonedDescriptor = await layer.cloneDescriptor(); const clonedStyleProps = (clonedDescriptor.style as VectorStyleDescriptor).properties; @@ -123,6 +124,7 @@ describe('cloneDescriptor', () => { const layer = new AbstractVectorLayer({ layerDescriptor, source: new MockSource() as unknown as IVectorSource, + customIcons: [], }); const clonedDescriptor = await layer.cloneDescriptor(); const clonedStyleProps = (clonedDescriptor.style as VectorStyleDescriptor).properties; diff --git a/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.tsx b/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.tsx index b8b90fdf75ff4..17408a2a22df0 100644 --- a/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.tsx +++ b/x-pack/plugins/maps/public/classes/layers/vector_layer/vector_layer.tsx @@ -38,6 +38,7 @@ import { } from '../../util/mb_filter_expressions'; import { AggDescriptor, + CustomIcon, DynamicStylePropertyOptions, DataFilters, ESTermSourceDescriptor, @@ -70,6 +71,7 @@ export interface VectorLayerArguments { source: IVectorSource; joins?: InnerJoin[]; layerDescriptor: VectorLayerDescriptor; + customIcons: CustomIcon[]; chartsPaletteServiceGetColor?: (value: string) => string | null; } @@ -133,6 +135,7 @@ export class AbstractVectorLayer extends AbstractLayer implements IVectorLayer { layerDescriptor, source, joins = [], + customIcons, chartsPaletteServiceGetColor, }: VectorLayerArguments) { super({ @@ -144,6 +147,7 @@ export class AbstractVectorLayer extends AbstractLayer implements IVectorLayer { layerDescriptor.style, source, this, + customIcons, chartsPaletteServiceGetColor ); } diff --git a/x-pack/plugins/maps/public/classes/styles/_index.scss b/x-pack/plugins/maps/public/classes/styles/_index.scss index bd1467bed9d4e..1cc5f4423d02f 100644 --- a/x-pack/plugins/maps/public/classes/styles/_index.scss +++ b/x-pack/plugins/maps/public/classes/styles/_index.scss @@ -2,5 +2,7 @@ @import 'vector/components/style_prop_editor'; @import 'vector/components/color/color_stops'; @import 'vector/components/symbol/icon_select'; +@import 'vector/components/symbol/icon_preview'; +@import 'vector/components/symbol/custom_icon_modal'; @import 'vector/components/legend/category'; @import 'vector/components/legend/vector_legend'; diff --git a/x-pack/plugins/maps/public/classes/styles/style.ts b/x-pack/plugins/maps/public/classes/styles/style.ts index c8326f365f42b..bafb0e9c36d75 100644 --- a/x-pack/plugins/maps/public/classes/styles/style.ts +++ b/x-pack/plugins/maps/public/classes/styles/style.ts @@ -6,11 +6,12 @@ */ import { ReactElement } from 'react'; -import { StyleDescriptor } from '../../../common/descriptor_types'; +import { CustomIcon, StyleDescriptor } from '../../../common/descriptor_types'; export interface IStyle { getType(): string; renderEditor( - onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void + onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void, + onCustomIconsChange: (customIcons: CustomIcon[]) => void ): ReactElement | null; } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/__snapshots__/vector_icon.test.tsx.snap b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/__snapshots__/vector_icon.test.tsx.snap index 656a4eb6ca599..e41b3b09134d4 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/__snapshots__/vector_icon.test.tsx.snap +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/__snapshots__/vector_icon.test.tsx.snap @@ -41,6 +41,18 @@ exports[`Renders SymbolIcon 1`] = ` key="airfield-15#ff0000rgb(106,173,213)" stroke="rgb(106,173,213)" style={Object {}} + svg="\\\\n\\\\n \\\\n" symbolId="airfield-15" /> `; + +exports[`Renders SymbolIcon with custom icon 1`] = ` +" + symbolId="__kbn__custom_icon_sdf__foobar" +/> +`; diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/breaked_legend.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/breaked_legend.tsx index 5cc4cfa67df01..fb851ae629f62 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/breaked_legend.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/breaked_legend.tsx @@ -16,6 +16,7 @@ const EMPTY_VALUE = ''; export interface Break { color: string; label: ReactElement | string | number; + svg?: string; symbolId?: string; } @@ -66,16 +67,17 @@ export class BreakedLegend extends Component { return null; } - const categories = this.props.breaks.map((brk, index) => { + const categories = this.props.breaks.map(({ symbolId, svg, label, color }, index) => { return ( ); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/category.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/category.tsx index cec8b48f505e8..cc544fd4030e7 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/category.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/category.tsx @@ -17,9 +17,18 @@ interface Props { isLinesOnly: boolean; isPointsOnly: boolean; symbolId?: string; + svg?: string; } -export function Category({ styleName, label, color, isLinesOnly, isPointsOnly, symbolId }: Props) { +export function Category({ + styleName, + label, + color, + isLinesOnly, + isPointsOnly, + symbolId, + svg, +}: Props) { function renderIcon() { if (styleName === VECTOR_STYLES.LABEL_COLOR) { return ( @@ -36,6 +45,7 @@ export function Category({ styleName, label, color, isLinesOnly, isPointsOnly, s isLinesOnly={isLinesOnly} strokeColor={color} symbolId={symbolId} + svg={svg} /> ); } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/symbol_icon.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/symbol_icon.tsx index cec1e8ed40aa2..4cc4d4169d7e0 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/symbol_icon.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/symbol_icon.tsx @@ -7,13 +7,14 @@ import React, { Component, CSSProperties } from 'react'; // @ts-expect-error -import { getMakiSymbolSvg, styleSvg, buildSrcUrl } from '../../symbol_utils'; +import { CUSTOM_ICON_PREFIX_SDF, getSymbolSvg, styleSvg, buildSrcUrl } from '../../symbol_utils'; interface Props { symbolId: string; fill?: string; stroke?: string; - style: CSSProperties; + style?: CSSProperties; + svg: string; } interface State { @@ -39,8 +40,7 @@ export class SymbolIcon extends Component { async _loadSymbol() { let imgDataUrl; try { - const svg = getMakiSymbolSvg(this.props.symbolId); - const styledSvg = await styleSvg(svg, this.props.fill, this.props.stroke); + const styledSvg = await styleSvg(this.props.svg, this.props.fill, this.props.stroke); imgDataUrl = buildSrcUrl(styledSvg); } catch (error) { // ignore failures - component will just not display an icon diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.test.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.test.tsx index 7907780d0ab4a..09993f8d0e5f3 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.test.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.test.tsx @@ -52,6 +52,22 @@ test('Renders SymbolIcon', () => { isLinesOnly={false} strokeColor="rgb(106,173,213)" symbolId="airfield-15" + svg='\n\n \n' + /> + ); + + expect(component).toMatchSnapshot(); +}); + +test('Renders SymbolIcon with custom icon', () => { + const component = shallow( + ); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.tsx index 333ba932dc6f3..745d1aae1b8dd 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_icon.tsx @@ -19,6 +19,7 @@ interface Props { isLinesOnly: boolean; strokeColor?: string; symbolId?: string; + svg?: string; } export function VectorIcon({ @@ -28,6 +29,7 @@ export function VectorIcon({ isLinesOnly, strokeColor, symbolId, + svg, }: Props) { if (isLinesOnly) { const style = { @@ -53,13 +55,18 @@ export function VectorIcon({ return ; } - return ( - - ); + if (svg) { + return ( + + ); + } + + return null; } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_style_legend.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_style_legend.tsx index 4de64e328eb13..2d282a4b530cb 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_style_legend.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/legend/vector_style_legend.tsx @@ -13,9 +13,10 @@ interface Props { isPointsOnly: boolean; styles: Array>; symbolId?: string; + svg?: string; } -export function VectorStyleLegend({ isLinesOnly, isPointsOnly, styles, symbolId }: Props) { +export function VectorStyleLegend({ isLinesOnly, isPointsOnly, styles, symbolId, svg }: Props) { const legendRows = []; for (let i = 0; i < styles.length; i++) { @@ -23,6 +24,7 @@ export function VectorStyleLegend({ isLinesOnly, isPointsOnly, styles, symbolId isLinesOnly, isPointsOnly, symbolId, + svg, }); legendRows.push( diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/style_prop_editor.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/style_prop_editor.tsx index 95be7f56a5597..c239e316d472f 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/style_prop_editor.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/style_prop_editor.tsx @@ -17,6 +17,7 @@ import { import { i18n } from '@kbn/i18n'; import { getVectorStyleLabel, getDisabledByMessage } from './get_vector_style_label'; import { STYLE_TYPE, VECTOR_STYLES } from '../../../../../common/constants'; +import { CustomIcon } from '../../../../../common/descriptor_types'; import { IStyleProperty } from '../properties/style_property'; import { StyleField } from '../style_fields_helper'; @@ -27,9 +28,11 @@ export interface Props { defaultDynamicStyleOptions: DynamicOptions; disabled?: boolean; disabledBy?: VECTOR_STYLES; + customIcons?: CustomIcon[]; fields: StyleField[]; onDynamicStyleChange: (propertyName: VECTOR_STYLES, options: DynamicOptions) => void; onStaticStyleChange: (propertyName: VECTOR_STYLES, options: StaticOptions) => void; + onCustomIconsChange?: (customIcons: CustomIcon[]) => void; styleProperty: IStyleProperty; } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/custom_icon_modal.test.tsx.snap b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/custom_icon_modal.test.tsx.snap new file mode 100644 index 0000000000000..06e6f24f9ea89 --- /dev/null +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/custom_icon_modal.test.tsx.snap @@ -0,0 +1,311 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`should render a custom icon modal with an existing icon 1`] = ` + + + +

+ Edit custom icon +

+
+
+ + + + + + + + + + + + + + + + + Reset + + + + + + Alpha threshold + + + + + } + labelType="label" + > + + + + + Radius + + + + + } + labelType="label" + > + + + + + + + " + /> + + + + + + + + Cancel + + + + + Delete + + + + + Save + + + + +
+`; + +exports[`should render an empty custom icon modal 1`] = ` + + + +

+ Custom Icon +

+
+
+ + + + + + + + + + + + + + + Cancel + + + + + Save + + + + +
+`; diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_map_select.test.tsx.snap b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_map_select.test.tsx.snap index b0b85268aa1c8..324e4d9dbd453 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_map_select.test.tsx.snap +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_map_select.test.tsx.snap @@ -3,6 +3,7 @@ exports[`Should not render icon map select when isCustomOnly 1`] = ` + + +", }, ] } onChange={[Function]} + onCustomIconsChange={[Function]} /> `; @@ -62,6 +64,7 @@ exports[`Should render custom stops input when useCustomIconMap 1`] = ` size="s" /> `; @@ -122,3 +126,40 @@ exports[`Should render default props 1`] = ` /> `; + +exports[`Should render icon map select with custom icons 1`] = ` + + + mock filledShapes option + , + "value": "filledShapes", + }, + Object { + "inputDisplay":
+ mock hollowShapes option +
, + "value": "hollowShapes", + }, + ] + } + valueOfSelected="filledShapes" + /> + +
+`; diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_select.test.js.snap b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_select.test.js.snap index c0505426d1f63..d9a62dff00423 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_select.test.js.snap +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/__snapshots__/icon_select.test.js.snap @@ -1,76 +1,204 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`Should render icon select 1`] = ` - - + + icon={ + Object { + "side": "right", + "type": "arrowDown", + } } + onKeyDown={[Function]} readOnly={true} - value="symbol1" - /> - - } - closePopover={[Function]} - display="block" - hasArrow={true} - isOpen={false} - ownFocus={true} - panelPaddingSize="s" -> - - + , - "value": "symbol1", - }, + /> + } + readOnly={true} + value="symbol1" + /> + + } + closePopover={[Function]} + display="block" + hasArrow={true} + isOpen={false} + ownFocus={true} + panelPaddingSize="s" + > + + + + +" + symbolId="symbol1" + />, + }, + Object { + "key": "symbol2", + "label": "symbol2", + "prepend": + + +" + symbolId="symbol2" + />, + }, + ] + } + searchable={true} + singleSelection={false} + > + + + + + +`; + +exports[`Should render icon select with custom icons 1`] = ` + + + , - "value": "symbol2", - }, - ] - } - searchable={true} - singleSelection={false} + svg="" + symbolId="__kbn__custom_icon_sdf__foobar" + /> + } + readOnly={true} + value="My Custom Icon" + /> + + } + closePopover={[Function]} + display="block" + hasArrow={true} + isOpen={false} + ownFocus={true} + panelPaddingSize="s" + > + - - - - + " + symbolId="__kbn__custom_icon_sdf__foobar" + />, + }, + Object { + "key": "__kbn__custom_icon_sdf__bizzbuzz", + "label": "My Other Custom Icon", + "prepend": " + symbolId="__kbn__custom_icon_sdf__bizzbuzz" + />, + }, + Object { + "isGroupLabel": true, + "label": "Kibana icons", + }, + Object { + "key": "symbol1", + "label": "symbol1", + "prepend": + + +" + symbolId="symbol1" + />, + }, + Object { + "key": "symbol2", + "label": "symbol2", + "prepend": + + +" + symbolId="symbol2" + />, + }, + ] + } + searchable={true} + singleSelection={false} + > + + + + + `; diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_custom_icon_modal.scss b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_custom_icon_modal.scss new file mode 100644 index 0000000000000..e3480d0017435 --- /dev/null +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_custom_icon_modal.scss @@ -0,0 +1,8 @@ +.mapsCustomIconForm { + min-width: 400px; +} + +.mapsCustomIconForm__preview { + max-width: 210px; + min-height: 210px; +} diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_preview.scss b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_preview.scss new file mode 100644 index 0000000000000..2204483710eb0 --- /dev/null +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_preview.scss @@ -0,0 +1,3 @@ +.mapsCustomIconPreview__mapContainer { + height: 150px; +} diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_select.scss b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_select.scss index 5e69d97131095..bc244131d9314 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_select.scss +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/_icon_select.scss @@ -1,3 +1,3 @@ .mapIconSelectSymbol__inputButton { - margin-left: $euiSizeS; + margin: 0 $euiSizeXS; } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.test.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.test.tsx new file mode 100644 index 0000000000000..8e21679405c07 --- /dev/null +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.test.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React from 'react'; +import { shallow } from 'enzyme'; + +import { CustomIconModal } from './custom_icon_modal'; + +const defaultProps = { + cutoff: 0.25, + onCancel: () => {}, + onSave: () => {}, + radius: 0.25, + title: 'Custom Icon', +}; + +test('should render an empty custom icon modal', () => { + const component = shallow(); + + expect(component).toMatchSnapshot(); +}); + +test('should render a custom icon modal with an existing icon', () => { + const component = shallow( + {}} + radius={0.15} + svg='' + symbolId="__kbn__custom_icon_sdf__foobar" + title="Edit custom icon" + /> + ); + + expect(component).toMatchSnapshot(); +}); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.tsx new file mode 100644 index 0000000000000..9898ac0cd3e93 --- /dev/null +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/custom_icon_modal.tsx @@ -0,0 +1,393 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { Component } from 'react'; +import { + EuiAccordion, + EuiButton, + EuiButtonEmpty, + EuiFieldText, + EuiFilePicker, + EuiFlexGroup, + EuiFlexItem, + EuiFormRow, + EuiIcon, + EuiModal, + EuiModalBody, + EuiModalFooter, + EuiModalHeader, + EuiModalHeaderTitle, + EuiPanel, + EuiSpacer, + EuiToolTip, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { IconPreview } from './icon_preview'; +// @ts-expect-error +import { getCustomIconId } from '../../symbol_utils'; +// @ts-expect-error +import { ValidatedRange } from '../../../../../components/validated_range'; +import { CustomIcon } from '../../../../../../common/descriptor_types'; + +const strings = { + getAdvancedOptionsLabel: () => + i18n.translate('xpack.maps.customIconModal.advancedOptionsLabel', { + defaultMessage: 'Advanced options', + }), + getCancelButtonLabel: () => + i18n.translate('xpack.maps.customIconModal.cancelButtonLabel', { + defaultMessage: 'Cancel', + }), + getCutoffRangeLabel: () => ( + + <> + {i18n.translate('xpack.maps.customIconModal.cutoffRangeLabel', { + defaultMessage: 'Alpha threshold', + })}{' '} + + + + ), + getDeleteButtonLabel: () => + i18n.translate('xpack.maps.customIconModal.deleteButtonLabel', { + defaultMessage: 'Delete', + }), + getImageFilePickerPlaceholder: () => + i18n.translate('xpack.maps.customIconModal.imageFilePickerPlaceholder', { + defaultMessage: 'Select or drag and drop an SVG icon', + }), + getImageInputDescription: () => + i18n.translate('xpack.maps.customIconModal.imageInputDescription', { + defaultMessage: + 'SVGs without sharp corners and intricate details work best. Modifying the settings under Advanced options may improve rendering.', + }), + getInvalidFileLabel: () => + i18n.translate('xpack.maps.customIconModal.invalidFileError', { + defaultMessage: 'Icon must be in SVG format. Other image types are not supported.', + }), + getNameInputLabel: () => + i18n.translate('xpack.maps.customIconModal.nameInputLabel', { + defaultMessage: 'Name', + }), + getRadiusRangeLabel: () => ( + + <> + {i18n.translate('xpack.maps.customIconModal.radiusRangeLabel', { + defaultMessage: 'Radius', + })}{' '} + + + + ), + getResetButtonLabel: () => + i18n.translate('xpack.maps.customIconModal.resetButtonLabel', { + defaultMessage: 'Reset', + }), + getSaveButtonLabel: () => + i18n.translate('xpack.maps.customIconModal.saveButtonLabel', { + defaultMessage: 'Save', + }), +}; + +function getFileNameWithoutExt(fileName: string) { + const splits = fileName.split('.'); + if (splits.length > 1) { + splits.pop(); + } + return splits.join('.'); +} +interface Props { + /** + * initial value for the id of image added to map + */ + symbolId?: string; + /** + * initial value of the label of the custom element + */ + label?: string; + /** + * initial value of the preview image of the custom element as a base64 dataurl + */ + svg?: string; + /** + * intial value of alpha threshold for signed-distance field + */ + cutoff: number; + /** + * intial value of radius for signed-distance field + */ + radius: number; + /** + * title of the modal + */ + title: string; + /** + * A click handler for the save button + */ + onSave: (icon: CustomIcon) => void; + /** + * A click handler for the cancel button + */ + onCancel: () => void; + /** + * A click handler for the delete button + */ + onDelete?: (symbolId: string) => void; +} + +interface State { + /** + * label of the custom element to be saved + */ + label: string; + /** + * image of the custom element to be saved + */ + svg: string; + + cutoff: number; + radius: number; + isFileInvalid: boolean; +} + +export class CustomIconModal extends Component { + private _isMounted: boolean = false; + + public state = { + label: this.props.label || '', + svg: this.props.svg || '', + cutoff: this.props.cutoff, + radius: this.props.radius, + isFileInvalid: this.props.svg ? false : true, + }; + + componentWillUnmount() { + this._isMounted = false; + } + + componentDidMount() { + this._isMounted = true; + } + + private _handleLabelChange = (value: string) => { + this.setState({ label: value }); + }; + + private _handleCutoffChange = (value: number) => { + this.setState({ cutoff: value }); + }; + + private _handleRadiusChange = (value: number) => { + this.setState({ radius: value }); + }; + + private _resetAdvancedOptions = () => { + this.setState({ radius: this.props.radius, cutoff: this.props.cutoff }); + }; + + private _onFileSelect = async (files: FileList | null) => { + this.setState({ + label: '', + svg: '', + isFileInvalid: false, + }); + + if (files && files.length) { + const file = files[0]; + const { type } = file; + if (type === 'image/svg+xml') { + const label = this.props.label ?? getFileNameWithoutExt(file.name); + try { + const svg = await file.text(); + + if (!this._isMounted) { + return; + } + this.setState({ isFileInvalid: false, label, svg }); + } catch (err) { + if (!this._isMounted) { + return; + } + this.setState({ isFileInvalid: true }); + } + } else { + this.setState({ isFileInvalid: true }); + } + } + }; + + private _renderAdvancedOptions() { + const { cutoff, radius } = this.state; + return ( + + + + + + {strings.getResetButtonLabel()} + + + + + + + + + + + + ); + } + + private _renderIconForm() { + const { label, svg } = this.state; + return svg !== '' ? ( + <> + + this._handleLabelChange(e.target.value)} + required + data-test-subj="mapsCustomIconForm-label" + /> + + + {this._renderAdvancedOptions()} + + ) : null; + } + + private _renderIconPreview() { + const { svg, isFileInvalid, cutoff, radius } = this.state; + return svg !== '' ? ( + + + + ) : null; + } + + public render() { + const { symbolId, onSave, onCancel, onDelete, title } = this.props; + const { label, svg, cutoff, radius, isFileInvalid } = this.state; + const isComplete = label.length !== 0 && svg.length !== 0 && !isFileInvalid; + const fileError = svg && isFileInvalid ? strings.getInvalidFileLabel() : ''; + return ( + + + +

{title}

+
+
+ + + + + + + + {this._renderIconForm()} + + {this._renderIconPreview()} + + + + + + {strings.getCancelButtonLabel()} + + {onDelete && symbolId ? ( + + { + onDelete(symbolId); + }} + data-test-subj="mapsCustomIconForm-submit" + > + {strings.getDeleteButtonLabel()} + + + ) : null} + + { + onSave({ symbolId: symbolId ?? getCustomIconId(), label, svg, cutoff, radius }); + }} + data-test-subj="mapsCustomIconForm-submit" + isDisabled={!isComplete} + > + {strings.getSaveButtonLabel()} + + + + +
+ ); + } +} diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/dynamic_icon_form.js b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/dynamic_icon_form.js index c7d6928884183..3bc8208e2325e 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/dynamic_icon_form.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/dynamic_icon_form.js @@ -14,6 +14,8 @@ import { IconMapSelect } from './icon_map_select'; export function DynamicIconForm({ fields, onDynamicStyleChange, + onCustomIconsChange, + customIcons, staticDynamicSelect, styleProperty, }) { @@ -44,7 +46,9 @@ export function DynamicIconForm({ ); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.test.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.test.tsx index be59b2eae9026..e569b0cabb753 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.test.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.test.tsx @@ -52,6 +52,15 @@ const defaultProps = { styleProperty: new MockDynamicStyleProperty() as unknown as IDynamicStyleProperty, isCustomOnly: false, + customIconStops: [ + { + stop: null, + icon: 'circle', + svg: '\n\n \n', + }, + ], + customIcons: [], + onCustomIconsChange: () => {}, }; test('Should render default props', () => { @@ -66,8 +75,50 @@ test('Should render custom stops input when useCustomIconMap', () => { {...defaultProps} useCustomIconMap={true} customIconStops={[ - { stop: null, icon: 'circle' }, - { stop: 'value1', icon: 'marker' }, + { + stop: null, + icon: 'circle', + }, + { + stop: 'value1', + icon: 'marker', + }, + ]} + /> + ); + + expect(component).toMatchSnapshot(); +}); + +test('Should render icon map select with custom icons', () => { + const component = shallow( + ', + cutoff: 0.25, + radius: 0.25, + }, + { + symbolId: '__kbn__custom_icon_sdf__bizzbuzz', + label: 'My Other Custom Icon', + svg: '', + cutoff: 0.3, + radius: 0.15, + }, + ]} + customIconStops={[ + { + stop: null, + icon: '__kbn__custom_icon_sdf__bizzbuzz', + }, + { + stop: 'value1', + icon: 'marker', + }, ]} /> ); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.tsx index f5a0390c602e9..37b6a9185ad71 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_map_select.tsx @@ -13,14 +13,19 @@ import { i18n } from '@kbn/i18n'; import { IconStops } from './icon_stops'; // @ts-expect-error import { getIconPaletteOptions, PREFERRED_ICONS } from '../../symbol_utils'; -import { IconDynamicOptions, IconStop } from '../../../../../../common/descriptor_types'; +import { + CustomIcon, + IconDynamicOptions, + IconStop, +} from '../../../../../../common/descriptor_types'; +import { ICON_SOURCE } from '../../../../../../common/constants'; import { IDynamicStyleProperty } from '../../properties/dynamic_style_property'; const CUSTOM_MAP_ID = 'CUSTOM_MAP_ID'; -const DEFAULT_ICON_STOPS = [ - { stop: null, icon: PREFERRED_ICONS[0] }, // first stop is the "other" category - { stop: '', icon: PREFERRED_ICONS[1] }, +const DEFAULT_ICON_STOPS: IconStop[] = [ + { stop: null, icon: PREFERRED_ICONS[0], iconSource: ICON_SOURCE.MAKI }, // first stop is the "other" category + { stop: '', icon: PREFERRED_ICONS[1], iconSource: ICON_SOURCE.MAKI }, ]; interface StyleOptionChanges { @@ -32,6 +37,8 @@ interface StyleOptionChanges { interface Props { customIconStops?: IconStop[]; iconPaletteId: string | null; + customIcons: CustomIcon[]; + onCustomIconsChange: (customIcons: CustomIcon[]) => void; onChange: ({ customIconStops, iconPaletteId, useCustomIconMap }: StyleOptionChanges) => void; styleProperty: IDynamicStyleProperty; useCustomIconMap?: boolean; @@ -86,6 +93,8 @@ export class IconMapSelect extends Component { getValueSuggestions={this.props.styleProperty.getValueSuggestions} iconStops={this.state.customIconStops} onChange={this._onCustomMapChange} + onCustomIconsChange={this.props.onCustomIconsChange} + customIcons={this.props.customIcons} /> ); } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_preview.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_preview.tsx new file mode 100644 index 0000000000000..f1a5653da612b --- /dev/null +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_preview.tsx @@ -0,0 +1,223 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { Component } from 'react'; +import { + EuiColorPicker, + EuiFlexItem, + EuiFormRow, + EuiIcon, + EuiPanel, + EuiSpacer, + EuiTitle, + EuiToolTip, +} from '@elastic/eui'; +import { mapboxgl, Map as MapboxMap } from '@kbn/mapbox-gl'; +import { i18n } from '@kbn/i18n'; +import { ResizeChecker } from '.././../../../../../../../../src/plugins/kibana_utils/public'; +import { + CUSTOM_ICON_PIXEL_RATIO, + createSdfIcon, + // @ts-expect-error +} from '../../symbol_utils'; + +export interface Props { + svg: string; + cutoff: number; + radius: number; + isSvgInvalid: boolean; +} + +interface State { + map: MapboxMap | null; + iconColor: string; +} + +export class IconPreview extends Component { + static iconId = `iconPreview`; + private _checker?: ResizeChecker; + private _isMounted = false; + private _containerRef: HTMLDivElement | null = null; + + state: State = { + map: null, + iconColor: '#E7664C', + }; + + componentDidMount() { + this._isMounted = true; + this._initializeMap(); + } + + componentDidUpdate(prevProps: Props) { + if ( + this.props.svg !== prevProps.svg || + this.props.cutoff !== prevProps.cutoff || + this.props.radius !== prevProps.radius + ) { + this._syncImageToMap(); + } + } + + componentWillUnmount() { + this._isMounted = false; + if (this._checker) { + this._checker.destroy(); + } + if (this.state.map) { + this.state.map.remove(); + this.state.map = null; + } + } + + _setIconColor = (iconColor: string) => { + this.setState({ iconColor }, () => { + this._syncPaintPropertiesToMap(); + }); + }; + + _setContainerRef = (element: HTMLDivElement) => { + this._containerRef = element; + }; + + async _syncImageToMap() { + if (this._isMounted && this.state.map) { + const map = this.state.map; + const { svg, cutoff, radius, isSvgInvalid } = this.props; + if (!svg || isSvgInvalid) { + map.setLayoutProperty('icon-layer', 'visibility', 'none'); + return; + } + const imageData = await createSdfIcon({ svg, cutoff, radius }); + if (map.hasImage(IconPreview.iconId)) { + // @ts-expect-error + map.updateImage(IconPreview.iconId, imageData); + } else { + map.addImage(IconPreview.iconId, imageData, { + sdf: true, + pixelRatio: CUSTOM_ICON_PIXEL_RATIO, + }); + } + map.setLayoutProperty('icon-layer', 'icon-image', IconPreview.iconId); + map.setLayoutProperty('icon-layer', 'icon-size', 6); + map.setLayoutProperty('icon-layer', 'visibility', 'visible'); + this._syncPaintPropertiesToMap(); + } + } + + _syncPaintPropertiesToMap() { + const { map, iconColor } = this.state; + if (!map) return; + map.setPaintProperty('icon-layer', 'icon-halo-color', '#000000'); + map.setPaintProperty('icon-layer', 'icon-halo-width', 1); + map.setPaintProperty('icon-layer', 'icon-color', iconColor); + map.setLayoutProperty('icon-layer', 'icon-size', 12); + } + + _initResizerChecker() { + this._checker = new ResizeChecker(this._containerRef!); + this._checker.on('resize', () => { + if (this.state.map) { + this.state.map.resize(); + } + }); + } + + _createMapInstance(): MapboxMap { + const map = new mapboxgl.Map({ + container: this._containerRef!, + interactive: false, + center: [0, 0], + zoom: 2, + style: { + version: 8, + name: 'Empty', + sources: {}, + layers: [ + { + id: 'background', + type: 'background', + paint: { + 'background-color': 'rgba(0,0,0,0)', + }, + }, + ], + }, + }); + + map.on('load', () => { + map.addLayer({ + id: 'icon-layer', + type: 'symbol', + source: { + type: 'geojson', + data: { + type: 'Feature', + geometry: { + type: 'Point', + coordinates: [0, 0], + }, + properties: {}, + }, + }, + }); + this._syncImageToMap(); + }); + + return map; + } + + _initializeMap() { + const map: MapboxMap = this._createMapInstance(); + + this.setState({ map }, () => { + this._initResizerChecker(); + }); + } + + render() { + const iconColor = this.state.iconColor; + return ( +
+ + + +

+ + <> + {i18n.translate('xpack.maps.customIconModal.elementPreviewTitle', { + defaultMessage: 'Render preview', + })}{' '} + + + +

+
+ + +
+ + + + + + + +
+ ); + } +} diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.js b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.js index cc03eb3d5ef1e..432a36478127f 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.js @@ -5,19 +5,28 @@ * 2.0. */ -import React, { Component } from 'react'; +import React, { Component, Fragment } from 'react'; import { + EuiButton, EuiFormControlLayout, EuiFieldText, EuiPopover, EuiPopoverTitle, + EuiPopoverFooter, EuiFocusTrap, keys, EuiSelectable, } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { + DEFAULT_CUSTOM_ICON_CUTOFF, + DEFAULT_CUSTOM_ICON_RADIUS, +} from '../../../../../../common/constants'; import { SymbolIcon } from '../legend/symbol_icon'; import { SYMBOL_OPTIONS } from '../../symbol_utils'; import { getIsDarkMode } from '../../../../../kibana_services'; +import { CustomIconModal } from './custom_icon_modal'; function isKeyboardEvent(event) { return typeof event === 'object' && 'keyCode' in event; @@ -26,16 +35,48 @@ function isKeyboardEvent(event) { export class IconSelect extends Component { state = { isPopoverOpen: false, + isModalVisible: false, + }; + + _handleSave = ({ symbolId, svg, cutoff, radius, label }) => { + const icons = [ + ...this.props.customIcons.filter((i) => { + return i.symbolId !== symbolId; + }), + { + symbolId, + svg, + label, + cutoff, + radius, + }, + ]; + this.props.onCustomIconsChange(icons); + this._hideModal(); }; _closePopover = () => { this.setState({ isPopoverOpen: false }); }; + _hideModal = () => { + this.setState({ isModalVisible: false }); + }; + _openPopover = () => { this.setState({ isPopoverOpen: true }); }; + _showModal = () => { + this.setState({ isModalVisible: true }); + }; + + _toggleModal = () => { + this.setState((prevState) => ({ + isModalVisible: !prevState.isModalVisible, + })); + }; + _togglePopover = () => { this.setState((prevState) => ({ isPopoverOpen: !prevState.isPopoverOpen, @@ -59,12 +100,14 @@ export class IconSelect extends Component { }); if (selectedOption) { - this.props.onChange(selectedOption.value); + const { key } = selectedOption; + this.props.onChange({ selectedIconId: key }); } this._closePopover(); }; _renderPopoverButton() { + const { value, svg, label } = this.props.icon; return ( } @@ -95,26 +139,69 @@ export class IconSelect extends Component { } _renderIconSelectable() { - const options = SYMBOL_OPTIONS.map(({ value, label }) => { + const makiOptions = [ + { + label: i18n.translate('xpack.maps.styles.vector.iconSelect.kibanaIconsGroupLabel', { + defaultMessage: 'Kibana icons', + }), + isGroupLabel: true, + }, + ...SYMBOL_OPTIONS.map(({ value, label, svg }) => { + return { + key: value, + label, + prepend: ( + + ), + }; + }), + ]; + + const customOptions = this.props.customIcons.map(({ symbolId, label, svg }) => { return { - value, + key: symbolId, label, prepend: ( ), }; }); + if (customOptions.length) + customOptions.splice(0, 0, { + label: i18n.translate('xpack.maps.styles.vector.iconSelect.customIconsGroupLabel', { + defaultMessage: 'Custom icons', + }), + isGroupLabel: true, + }); + + const options = [...customOptions, ...makiOptions]; + return ( - + {(list, search) => (
{search} {list} + + {' '} + + + +
)}
@@ -123,17 +210,28 @@ export class IconSelect extends Component { render() { return ( - - {this._renderIconSelectable()} - + + + {this._renderIconSelectable()} + + {this.state.isModalVisible ? ( + + ) : null} + ); } } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.test.js b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.test.js index ac5b3b7dd9847..5bb5f7f1c7808 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.test.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_select.test.js @@ -16,8 +16,16 @@ jest.mock('../../../../../kibana_services', () => { jest.mock('../../symbol_utils', () => { return { SYMBOL_OPTIONS: [ - { value: 'symbol1', label: 'symbol1' }, - { value: 'symbol2', label: 'symbol2' }, + { + value: 'symbol1', + label: 'symbol1', + svg: '\n\n \n', + }, + { + value: 'symbol2', + label: 'symbol2', + svg: '\n\n \n', + }, ], }; }); @@ -28,7 +36,39 @@ import { shallow } from 'enzyme'; import { IconSelect } from './icon_select'; test('Should render icon select', () => { - const component = shallow( {}} />); + const component = shallow( + {}} /> + ); + + expect(component).toMatchSnapshot(); +}); + +test('Should render icon select with custom icons', () => { + const component = shallow( + ', + cutoff: 0.25, + radius: 0.25, + }, + { + symbolId: '__kbn__custom_icon_sdf__bizzbuzz', + label: 'My Other Custom Icon', + svg: '', + cutoff: 0.3, + radius: 0.15, + }, + ]} + icon={{ + value: '__kbn__custom_icon_sdf__foobar', + svg: '', + label: 'My Custom Icon', + }} + /> + ); expect(component).toMatchSnapshot(); }); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_stops.js b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_stops.js index 79491d6ededf3..2700a599c3aee 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_stops.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/icon_stops.js @@ -6,13 +6,13 @@ */ import React from 'react'; -import { DEFAULT_ICON } from '../../../../../../common/constants'; +import { DEFAULT_ICON, ICON_SOURCE } from '../../../../../../common/constants'; import { i18n } from '@kbn/i18n'; import { getOtherCategoryLabel } from '../../style_util'; import { EuiButtonIcon, EuiFlexGroup, EuiFlexItem, EuiFormRow, EuiFieldText } from '@elastic/eui'; import { IconSelect } from './icon_select'; import { StopInput } from '../stop_input'; -import { PREFERRED_ICONS, SYMBOL_OPTIONS } from '../../symbol_utils'; +import { getMakiSymbol, PREFERRED_ICONS, SYMBOL_OPTIONS } from '../../symbol_utils'; function isDuplicateStop(targetStop, iconStops) { const stops = iconStops.filter(({ stop }) => { @@ -43,113 +43,136 @@ export function getFirstUnusedSymbol(iconStops) { return firstUnusedSymbol ? firstUnusedSymbol.value : DEFAULT_ICON; } -export function IconStops({ field, getValueSuggestions, iconStops, onChange }) { - return iconStops.map(({ stop, icon }, index) => { - const onIconSelect = (selectedIconId) => { - const newIconStops = [...iconStops]; - newIconStops[index] = { - ...iconStops[index], - icon: selectedIconId, +export function IconStops({ + field, + getValueSuggestions, + iconStops, + onChange, + onCustomIconsChange, + customIcons, +}) { + return iconStops + .map(({ stop, icon, iconSource }, index) => { + const iconInfo = + iconSource === ICON_SOURCE.CUSTOM + ? customIcons.find(({ symbolId }) => symbolId === icon) + : getMakiSymbol(icon); + if (iconInfo === undefined) return; + const { svg, label } = iconInfo; + const onIconSelect = ({ selectedIconId }) => { + const newIconStops = [...iconStops]; + newIconStops[index] = { + ...iconStops[index], + icon: selectedIconId, + }; + onChange({ customStops: newIconStops }); }; - onChange({ customStops: newIconStops }); - }; - const onStopChange = (newStopValue) => { - const newIconStops = [...iconStops]; - newIconStops[index] = { - ...iconStops[index], - stop: newStopValue, + const onStopChange = (newStopValue) => { + const newIconStops = [...iconStops]; + newIconStops[index] = { + ...iconStops[index], + stop: newStopValue, + }; + onChange({ + customStops: newIconStops, + isInvalid: isDuplicateStop(newStopValue, iconStops), + }); }; - onChange({ - customStops: newIconStops, - isInvalid: isDuplicateStop(newStopValue, iconStops), - }); - }; - const onAdd = () => { - onChange({ - customStops: [ - ...iconStops.slice(0, index + 1), - { - stop: '', - icon: getFirstUnusedSymbol(iconStops), - }, - ...iconStops.slice(index + 1), - ], - }); - }; - const onRemove = () => { - onChange({ - customStops: [...iconStops.slice(0, index), ...iconStops.slice(index + 1)], - }); - }; + const onAdd = () => { + onChange({ + customStops: [ + ...iconStops.slice(0, index + 1), + { + stop: '', + icon: getFirstUnusedSymbol(iconStops), + }, + ...iconStops.slice(index + 1), + ], + }); + }; + const onRemove = () => { + onChange({ + customStops: [...iconStops.slice(0, index), ...iconStops.slice(index + 1)], + }); + }; + + let deleteButton; + if (iconStops.length > 2 && index !== 0) { + deleteButton = ( + + ); + } - let deleteButton; - if (iconStops.length > 2 && index !== 0) { - deleteButton = ( - + const iconStopButtons = ( +
+ {deleteButton} + +
); - } - const iconStopButtons = ( -
- {deleteButton} - -
- ); + const errors = []; + // TODO check for duplicate values and add error messages here - const errors = []; - // TODO check for duplicate values and add error messages here + const stopInput = + index === 0 ? ( + + ) : ( + + ); - const stopInput = - index === 0 ? ( - - ) : ( - + return ( + + + + {stopInput} + + + + + + ); - - return ( - - - - {stopInput} - - - - - - - ); - }); + }) + .filter((stop) => { + return stop !== undefined; + }); } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/static_icon_form.js b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/static_icon_form.js index 262fb5c7e0991..6ec372496e8be 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/static_icon_form.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/symbol/static_icon_form.js @@ -9,9 +9,17 @@ import React from 'react'; import { EuiFlexGroup, EuiFlexItem } from '@elastic/eui'; import { IconSelect } from './icon_select'; -export function StaticIconForm({ onStaticStyleChange, staticDynamicSelect, styleProperty }) { - const onChange = (selectedIconId) => { - onStaticStyleChange(styleProperty.getStyleName(), { value: selectedIconId }); +export function StaticIconForm({ + onStaticStyleChange, + onCustomIconsChange, + customIcons, + staticDynamicSelect, + styleProperty, +}) { + const onChange = ({ selectedIconId }) => { + onStaticStyleChange(styleProperty.getStyleName(), { + value: selectedIconId, + }); }; return ( @@ -20,7 +28,12 @@ export function StaticIconForm({ onStaticStyleChange, staticDynamicSelect, style {staticDynamicSelect}
- + ); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.test.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.test.tsx index b89f4ee0b2aa0..8edb67703a4d1 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.test.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.test.tsx @@ -11,6 +11,7 @@ import { StyleProperties, VectorStyleEditor } from './vector_style_editor'; import { getDefaultStaticProperties } from '../vector_style_defaults'; import { IVectorLayer } from '../../../layers/vector_layer'; import { IVectorSource } from '../../../sources/vector_source'; +import { CustomIcon } from '../../../../../common/descriptor_types'; import { FIELD_ORIGIN, LAYER_STYLE_TYPE, @@ -61,7 +62,8 @@ const vectorStyleDescriptor = { const vectorStyle = new VectorStyle( vectorStyleDescriptor, {} as unknown as IVectorSource, - {} as unknown as IVectorLayer + {} as unknown as IVectorLayer, + [] as CustomIcon[] ); const styleProperties: StyleProperties = {}; vectorStyle.getAllStyleProperties().forEach((styleProperty) => { @@ -73,11 +75,13 @@ const defaultProps = { isPointsOnly: true, isLinesOnly: false, onIsTimeAwareChange: (isTimeAware: boolean) => {}, + onCustomIconsChange: (customIcons: CustomIcon[]) => {}, handlePropertyChange: (propertyName: VECTOR_STYLES, stylePropertyDescriptor: unknown) => {}, hasBorder: true, styleProperties, isTimeAware: true, showIsTimeAware: true, + customIcons: [], }; test('should render', async () => { diff --git a/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.tsx b/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.tsx index a7488ab13da6c..4431cead9b0d1 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/components/vector_style_editor.tsx @@ -33,6 +33,7 @@ import { createStyleFieldsHelper, StyleField, StyleFieldsHelper } from '../style import { ColorDynamicOptions, ColorStaticOptions, + CustomIcon, DynamicStylePropertyOptions, IconDynamicOptions, IconStaticOptions, @@ -62,11 +63,13 @@ interface Props { isPointsOnly: boolean; isLinesOnly: boolean; onIsTimeAwareChange: (isTimeAware: boolean) => void; + onCustomIconsChange: (customIcons: CustomIcon[]) => void; handlePropertyChange: (propertyName: VECTOR_STYLES, stylePropertyDescriptor: unknown) => void; hasBorder: boolean; styleProperties: StyleProperties; isTimeAware: boolean; showIsTimeAware: boolean; + customIcons: CustomIcon[]; } interface State { @@ -392,8 +395,10 @@ export class VectorStyleEditor extends Component { = { aerialway: { label: 'Aerialway', svg: '\n\n \n', diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/__snapshots__/dynamic_icon_property.test.tsx.snap b/x-pack/plugins/maps/public/classes/styles/vector/properties/__snapshots__/dynamic_icon_property.test.tsx.snap index a3f23536326aa..a49dd9a494c7f 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/__snapshots__/dynamic_icon_property.test.tsx.snap +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/__snapshots__/dynamic_icon_property.test.tsx.snap @@ -47,6 +47,10 @@ exports[`renderLegendDetailRow Should render categorical legend with breaks 1`] isPointsOnly={true} label="US_format" styleName="icon" + svg=" + + +" symbolId="circle" /> @@ -59,6 +63,10 @@ exports[`renderLegendDetailRow Should render categorical legend with breaks 1`] isPointsOnly={true} label="CN_format" styleName="icon" + svg=" + + +" symbolId="marker" /> @@ -77,9 +85,93 @@ exports[`renderLegendDetailRow Should render categorical legend with breaks 1`] } styleName="icon" + svg=" + + +" symbolId="square" />
`; + +exports[`renderLegendDetailRow Should render categorical legend with custom icons in breaks 1`] = ` +
+ + + + + + + foobar_label + + + + + + + + + + + +" + symbolId="marker" + /> + + + + Other + + } + styleName="icon" + svg=" + + +" + symbolId="kbn__custom_icon_sdf__foobar" + /> + + +
+`; diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_color_property.tsx b/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_color_property.tsx index c9e7cfb6d7e39..0802c78c26933 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_color_property.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_color_property.tsx @@ -324,7 +324,7 @@ export class DynamicColorProperty extends DynamicStyleProperty | null = null; let getValuePrefix: ((i: number, isNext: boolean) => string) | null = null; if (this._options.useCustomColorRamp) { @@ -361,6 +361,7 @@ export class DynamicColorProperty extends DynamicStyleProperty { if (stop !== null && color != null) { breaks.push({ color, + svg, symbolId, label: this.formatField(stop), }); @@ -427,17 +430,18 @@ export class DynamicColorProperty extends DynamicStyleProperty{getOtherCategoryLabel()}, symbolId, + svg, }); } return breaks; } - renderLegendDetailRow({ isPointsOnly, isLinesOnly, symbolId }: LegendProps) { + renderLegendDetailRow({ isPointsOnly, isLinesOnly, symbolId, svg }: LegendProps) { let breaks: Break[] = []; if (this.isOrdinal()) { - breaks = this._getOrdinalBreaks(symbolId); + breaks = this._getOrdinalBreaks(symbolId, svg); } else if (this.isCategorical()) { - breaks = this._getCategoricalBreaks(symbolId); + breaks = this._getCategoricalBreaks(symbolId, svg); } return ( ({ })); import React from 'react'; -import { RawValue, VECTOR_STYLES } from '../../../../../common/constants'; +import { ICON_SOURCE, RawValue, VECTOR_STYLES } from '../../../../../common/constants'; // @ts-ignore import { DynamicIconProperty } from './dynamic_icon_property'; import { mockField, MockLayer } from './test_helpers/test_util'; @@ -57,7 +57,30 @@ describe('renderLegendDetailRow', () => { const iconStyle = makeProperty({ iconPaletteId: 'filledShapes', }); + const legendRow = iconStyle.renderLegendDetailRow({ isPointsOnly: true, isLinesOnly: false }); + const component = shallow(legendRow); + await new Promise((resolve) => process.nextTick(resolve)); + component.update(); + expect(component).toMatchSnapshot(); + }); + + test('Should render categorical legend with custom icons in breaks', async () => { + const iconStyle = makeProperty({ + useCustomIconMap: true, + customIconStops: [ + { + stop: null, + icon: 'kbn__custom_icon_sdf__foobar', + iconSource: ICON_SOURCE.CUSTOM, + }, + { + stop: 'MX', + icon: 'marker', + iconSource: ICON_SOURCE.MAKI, + }, + ], + }); const legendRow = iconStyle.renderLegendDetailRow({ isPointsOnly: true, isLinesOnly: false }); const component = shallow(legendRow); await new Promise((resolve) => process.nextTick(resolve)); @@ -88,8 +111,16 @@ describe('get mapbox icon-image expression (via internal _getMbIconImageExpressi const iconStyle = makeProperty({ useCustomIconMap: true, customIconStops: [ - { stop: null, icon: 'circle' }, - { stop: 'MX', icon: 'marker' }, + { + stop: null, + icon: 'circle', + iconSource: ICON_SOURCE.MAKI, + }, + { + stop: 'MX', + icon: 'marker', + iconSource: ICON_SOURCE.MAKI, + }, ], }); expect(iconStyle._getMbIconImageExpression()).toEqual([ diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_icon_property.tsx b/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_icon_property.tsx index c95d5eec069a8..db295f200a148 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_icon_property.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_icon_property.tsx @@ -10,6 +10,7 @@ import React from 'react'; import { EuiTextColor } from '@elastic/eui'; import type { Map as MbMap } from '@kbn/mapbox-gl'; import { DynamicStyleProperty } from './dynamic_style_property'; +import { IVectorStyle } from '../vector_style'; import { getIconPalette, getMakiSymbolAnchor, @@ -48,10 +49,11 @@ export class DynamicIconProperty extends DynamicStyleProperty { if (stop) { + const svg = layerStyle.getIconSvg(style); breaks.push({ color: 'grey', label: this.formatField(stop), symbolId: style, + svg, }); } }); if (fallbackSymbolId) { + const svg = layerStyle.getIconSvg(fallbackSymbolId); breaks.push({ color: 'grey', label: {getOtherCategoryLabel()}, symbolId: fallbackSymbolId, + svg, }); } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_size_property.tsx b/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_size_property.tsx index 5ea99e64e8626..89f138ff7744b 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_size_property.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/dynamic_size_property.tsx @@ -11,10 +11,11 @@ import { DynamicStyleProperty } from './dynamic_style_property'; import { OrdinalLegend } from '../components/legend/ordinal_legend'; import { makeMbClampedNumberExpression } from '../style_util'; import { + FieldFormatter, HALF_MAKI_ICON_SIZE, - // @ts-expect-error -} from '../symbol_utils'; -import { FieldFormatter, MB_LOOKUP_FUNCTION, VECTOR_STYLES } from '../../../../../common/constants'; + MB_LOOKUP_FUNCTION, + VECTOR_STYLES, +} from '../../../../../common/constants'; import { SizeDynamicOptions } from '../../../../../common/descriptor_types'; import { IField } from '../../../fields/field'; import { IVectorLayer } from '../../../layers/vector_layer'; diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/static_icon_property.ts b/x-pack/plugins/maps/public/classes/styles/vector/properties/static_icon_property.ts index 1ebe35d65ac95..0a2464d8bed8b 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/static_icon_property.ts +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/static_icon_property.ts @@ -8,7 +8,7 @@ import type { Map as MbMap } from '@kbn/mapbox-gl'; import { StaticStyleProperty } from './static_style_property'; // @ts-expect-error -import { getMakiSymbolAnchor, getMakiIconId } from '../symbol_utils'; +import { getMakiSymbolAnchor } from '../symbol_utils'; import { IconStaticOptions } from '../../../../../common/descriptor_types'; export class StaticIconProperty extends StaticStyleProperty { diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/static_size_property.ts b/x-pack/plugins/maps/public/classes/styles/vector/properties/static_size_property.ts index 771e0f8f33a0c..74a4ffebea96d 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/static_size_property.ts +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/static_size_property.ts @@ -7,11 +7,7 @@ import type { Map as MbMap } from '@kbn/mapbox-gl'; import { StaticStyleProperty } from './static_style_property'; -import { VECTOR_STYLES } from '../../../../../common/constants'; -import { - HALF_MAKI_ICON_SIZE, - // @ts-expect-error -} from '../symbol_utils'; +import { HALF_MAKI_ICON_SIZE, VECTOR_STYLES } from '../../../../../common/constants'; import { SizeStaticOptions } from '../../../../../common/descriptor_types'; export class StaticSizeProperty extends StaticStyleProperty { diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/style_property.ts b/x-pack/plugins/maps/public/classes/styles/vector/properties/style_property.ts index 41877406f7489..ee3da4e3636b3 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/style_property.ts +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/style_property.ts @@ -16,6 +16,7 @@ export type LegendProps = { isPointsOnly: boolean; isLinesOnly: boolean; symbolId?: string; + svg?: string; }; export interface IStyleProperty { diff --git a/x-pack/plugins/maps/public/classes/styles/vector/properties/test_helpers/test_util.ts b/x-pack/plugins/maps/public/classes/styles/vector/properties/test_helpers/test_util.ts index 13455b3e4f840..3d1cad1561a0e 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/properties/test_helpers/test_util.ts +++ b/x-pack/plugins/maps/public/classes/styles/vector/properties/test_helpers/test_util.ts @@ -66,6 +66,10 @@ export class MockStyle implements IStyle { return null; } + getIconSvg(symbolId: string) { + return `\n\n \n`; + } + getType() { return LAYER_STYLE_TYPE.VECTOR; } @@ -109,6 +113,10 @@ export class MockLayer { return this._style; } + getCurrentStyle() { + return this._style; + } + getDataRequest() { return null; } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/style_util.test.ts b/x-pack/plugins/maps/public/classes/styles/vector/style_util.test.ts index 46b2e047d0d63..fc57f1b92f5af 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/style_util.test.ts +++ b/x-pack/plugins/maps/public/classes/styles/vector/style_util.test.ts @@ -73,53 +73,81 @@ describe('isOnlySingleFeatureType', () => { }); describe('assignCategoriesToPalette', () => { - test('Categories and palette values have same length', () => { + test('Categories and icons have same length', () => { const categories = [ { key: 'alpah', count: 1 }, { key: 'bravo', count: 1 }, { key: 'charlie', count: 1 }, { key: 'delta', count: 1 }, ]; - const paletteValues = ['red', 'orange', 'yellow', 'green']; + const paletteValues = ['circle', 'marker', 'triangle', 'square']; expect(assignCategoriesToPalette({ categories, paletteValues })).toEqual({ stops: [ - { stop: 'alpah', style: 'red' }, - { stop: 'bravo', style: 'orange' }, - { stop: 'charlie', style: 'yellow' }, + { + stop: 'alpah', + style: 'circle', + iconSource: 'MAKI', + }, + { + stop: 'bravo', + style: 'marker', + iconSource: 'MAKI', + }, + { + stop: 'charlie', + style: 'triangle', + iconSource: 'MAKI', + }, ], - fallbackSymbolId: 'green', + fallbackSymbolId: 'square', }); }); - test('Should More categories than palette values', () => { + test('Should More categories than icon values', () => { const categories = [ { key: 'alpah', count: 1 }, { key: 'bravo', count: 1 }, { key: 'charlie', count: 1 }, { key: 'delta', count: 1 }, ]; - const paletteValues = ['red', 'orange', 'yellow']; + const paletteValues = ['circle', 'square', 'triangle']; expect(assignCategoriesToPalette({ categories, paletteValues })).toEqual({ stops: [ - { stop: 'alpah', style: 'red' }, - { stop: 'bravo', style: 'orange' }, + { + stop: 'alpah', + style: 'circle', + iconSource: 'MAKI', + }, + { + stop: 'bravo', + style: 'square', + iconSource: 'MAKI', + }, ], - fallbackSymbolId: 'yellow', + fallbackSymbolId: 'triangle', }); }); - test('Less categories than palette values', () => { + test('Less categories than icon values', () => { const categories = [ { key: 'alpah', count: 1 }, { key: 'bravo', count: 1 }, ]; - const paletteValues = ['red', 'orange', 'yellow', 'green', 'blue']; + const paletteValues = ['circle', 'triangle', 'marker', 'square', 'rectangle']; expect(assignCategoriesToPalette({ categories, paletteValues })).toEqual({ stops: [ - { stop: 'alpah', style: 'red' }, - { stop: 'bravo', style: 'orange' }, + { + stop: 'alpah', + style: 'circle', + iconSource: 'MAKI', + }, + { + stop: 'bravo', + style: 'triangle', + iconSource: 'MAKI', + }, ], - fallbackSymbolId: 'yellow', + fallbackSymbolId: 'marker', }); }); }); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/style_util.ts b/x-pack/plugins/maps/public/classes/styles/vector/style_util.ts index 467fd6b3621a2..11f564f436dd5 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/style_util.ts +++ b/x-pack/plugins/maps/public/classes/styles/vector/style_util.ts @@ -6,7 +6,12 @@ */ import { i18n } from '@kbn/i18n'; -import { MB_LOOKUP_FUNCTION, VECTOR_SHAPE_TYPE, VECTOR_STYLES } from '../../../../common/constants'; +import { + ICON_SOURCE, + MB_LOOKUP_FUNCTION, + VECTOR_SHAPE_TYPE, + VECTOR_STYLES, +} from '../../../../common/constants'; import { Category } from '../../../../common/descriptor_types'; import { StaticTextProperty } from './properties/static_text_property'; import { DynamicTextProperty } from './properties/dynamic_text_property'; @@ -74,6 +79,7 @@ export function assignCategoriesToPalette({ stops.push({ stop: categories[i].key, style: paletteValues[i], + iconSource: ICON_SOURCE.MAKI, }); } } diff --git a/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.js b/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.js index 07ac77dc0cb78..af165863ffc9c 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.js @@ -7,39 +7,48 @@ import React from 'react'; import xml2js from 'xml2js'; +import uuid from 'uuid/v4'; import { Canvg } from 'canvg'; import calcSDF from 'bitmap-sdf'; +import { + CUSTOM_ICON_SIZE, + CUSTOM_ICON_PREFIX_SDF, + MAKI_ICON_SIZE, +} from '../../../../common/constants'; import { parseXmlString } from '../../../../common/parse_xml_string'; import { SymbolIcon } from './components/legend/symbol_icon'; import { getIsDarkMode } from '../../../kibana_services'; import { MAKI_ICONS } from './maki_icons'; -const MAKI_ICON_SIZE = 16; -export const HALF_MAKI_ICON_SIZE = MAKI_ICON_SIZE / 2; +export const CUSTOM_ICON_PIXEL_RATIO = Math.floor( + window.devicePixelRatio * (CUSTOM_ICON_SIZE / MAKI_ICON_SIZE) * 0.75 +); -export const SYMBOL_OPTIONS = Object.keys(MAKI_ICONS).map((symbolId) => { +export const SYMBOL_OPTIONS = Object.entries(MAKI_ICONS).map(([value, { svg, label }]) => { return { - value: symbolId, - label: symbolId, + value, + label, + svg, }; }); /** - * Converts a SVG icon to a monochrome image using a signed distance function. + * Converts a SVG icon to a PNG image using a signed distance function (SDF). * * @param {string} svgString - SVG icon as string - * @param {number} [cutoff=0.25] - balance between SDF inside 1 and outside 0 of glyph + * @param {number} [renderSize=64] - size of the output PNG (higher provides better resolution but requires more processing) + * @param {number} [cutoff=0.25] - balance between SDF inside 1 and outside 0 of icon * @param {number} [radius=0.25] - size of SDF around the cutoff as percent of output icon size - * @return {ImageData} Monochrome image that can be added to a MapLibre map + * @return {ImageData} image that can be added to a MapLibre map with option `{ sdf: true }` */ -export async function createSdfIcon(svgString, cutoff = 0.25, radius = 0.25) { +export async function createSdfIcon({ svg, renderSize = 64, cutoff = 0.25, radius = 0.25 }) { const buffer = 3; - const size = MAKI_ICON_SIZE + buffer * 4; + const size = renderSize + buffer * 4; const svgCanvas = document.createElement('canvas'); svgCanvas.width = size; svgCanvas.height = size; const svgCtx = svgCanvas.getContext('2d'); - const v = Canvg.fromString(svgCtx, svgString, { + const v = Canvg.fromString(svgCtx, svg, { ignoreDimensions: true, offsetX: buffer / 2, offsetY: buffer / 2, @@ -70,12 +79,8 @@ export async function createSdfIcon(svgString, cutoff = 0.25, radius = 0.25) { return imageData; } -export function getMakiSymbolSvg(symbolId) { - const svg = MAKI_ICONS?.[symbolId]?.svg; - if (!svg) { - throw new Error(`Unable to find symbol: ${symbolId}`); - } - return svg; +export function getMakiSymbol(symbolId) { + return MAKI_ICONS?.[symbolId]; } export function getMakiSymbolAnchor(symbolId) { @@ -89,6 +94,10 @@ export function getMakiSymbolAnchor(symbolId) { } } +export function getCustomIconId() { + return `${CUSTOM_ICON_PREFIX_SDF}${uuid()}`; +} + export function buildSrcUrl(svgString) { const domUrl = window.URL || window.webkitURL || window; const svg = new Blob([svgString], { type: 'image/svg+xml' }); @@ -130,9 +139,9 @@ const ICON_PALETTES = [ // PREFERRED_ICONS is used to provide less random default icon values for forms that need default icon values export const PREFERRED_ICONS = []; ICON_PALETTES.forEach((iconPalette) => { - iconPalette.icons.forEach((iconId) => { - if (!PREFERRED_ICONS.includes(iconId)) { - PREFERRED_ICONS.push(iconId); + iconPalette.icons.forEach((icon) => { + if (!PREFERRED_ICONS.includes(icon)) { + PREFERRED_ICONS.push(icon); } }); }); @@ -154,6 +163,7 @@ export function getIconPaletteOptions() { className="mapIcon" symbolId={iconId} fill={isDarkMode ? 'rgb(223, 229, 239)' : 'rgb(52, 55, 65)'} + svg={getMakiSymbol(iconId).svg} /> ); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.test.js b/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.test.js index d5fc3d30a447c..8c85702b19579 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.test.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/symbol_utils.test.js @@ -5,12 +5,13 @@ * 2.0. */ -import { getMakiSymbolSvg, styleSvg } from './symbol_utils'; +import { getMakiSymbol, styleSvg } from './symbol_utils'; -describe('getMakiSymbolSvg', () => { - it('Should load symbol svg', () => { - const svgString = getMakiSymbolSvg('aerialway'); - expect(svgString.length).toBe(624); +describe('getMakiSymbol', () => { + it('Should load symbol', () => { + const symbol = getMakiSymbol('aerialway'); + expect(symbol.svg.length).toBe(624); + expect(symbol.label).toBe('Aerialway'); }); }); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/vector_style.test.js b/x-pack/plugins/maps/public/classes/styles/vector/vector_style.test.js index 33125019ecc0b..c1aa8e395d8c0 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/vector_style.test.js +++ b/x-pack/plugins/maps/public/classes/styles/vector/vector_style.test.js @@ -35,6 +35,8 @@ class MockSource { describe('getDescriptorWithUpdatedStyleProps', () => { const previousFieldName = 'doIStillExist'; const mapColors = []; + const layer = {}; + const customIcons = []; const properties = { fillColor: { type: STYLE_TYPE.STATIC, @@ -69,7 +71,7 @@ describe('getDescriptorWithUpdatedStyleProps', () => { describe('When there is no mismatch in configuration', () => { it('Should return no changes when next ordinal fields contain existing style property fields', async () => { - const vectorStyle = new VectorStyle({ properties }, new MockSource()); + const vectorStyle = new VectorStyle({ properties }, new MockSource(), layer, customIcons); const nextFields = [new MockField({ fieldName: previousFieldName, dataType: 'number' })]; const { hasChanges } = await vectorStyle.getDescriptorWithUpdatedStyleProps( @@ -83,7 +85,7 @@ describe('getDescriptorWithUpdatedStyleProps', () => { describe('When styles should revert to static styling', () => { it('Should convert dynamic styles to static styles when there are no next fields', async () => { - const vectorStyle = new VectorStyle({ properties }, new MockSource()); + const vectorStyle = new VectorStyle({ properties }, new MockSource(), layer, customIcons); const nextFields = []; const { hasChanges, nextStyleDescriptor } = @@ -104,7 +106,7 @@ describe('getDescriptorWithUpdatedStyleProps', () => { }); it('Should convert dynamic ICON_SIZE static style when there are no next ordinal fields', async () => { - const vectorStyle = new VectorStyle({ properties }, new MockSource()); + const vectorStyle = new VectorStyle({ properties }, new MockSource(), layer, customIcons); const nextFields = [ { @@ -143,7 +145,7 @@ describe('getDescriptorWithUpdatedStyleProps', () => { describe('When styles should not be cleared', () => { it('Should update field in styles when the fields and style combination remains compatible', async () => { - const vectorStyle = new VectorStyle({ properties }, new MockSource()); + const vectorStyle = new VectorStyle({ properties }, new MockSource(), layer, customIcons); const nextFields = [new MockField({ fieldName: 'someOtherField', dataType: 'number' })]; const { hasChanges, nextStyleDescriptor } = @@ -174,6 +176,8 @@ describe('getDescriptorWithUpdatedStyleProps', () => { }); describe('pluckStyleMetaFromSourceDataRequest', () => { + const layer = {}; + const customIcons = []; describe('has features', () => { it('Should identify when feature collection only contains points', async () => { const sourceDataRequest = new DataRequest({ @@ -195,7 +199,7 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { ], }, }); - const vectorStyle = new VectorStyle({}, new MockSource()); + const vectorStyle = new VectorStyle({}, new MockSource(), layer, customIcons); const featuresMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); expect(featuresMeta.geometryTypes.isPointsOnly).toBe(true); @@ -231,7 +235,7 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { ], }, }); - const vectorStyle = new VectorStyle({}, new MockSource()); + const vectorStyle = new VectorStyle({}, new MockSource(), layer, customIcons); const featuresMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); expect(featuresMeta.geometryTypes.isPointsOnly).toBe(false); @@ -280,7 +284,9 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { }, }, }, - new MockSource() + new MockSource(), + layer, + customIcons ); const featuresMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); @@ -304,7 +310,9 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { }, }, }, - new MockSource() + new MockSource(), + layer, + customIcons ); const styleMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); diff --git a/x-pack/plugins/maps/public/classes/styles/vector/vector_style.tsx b/x-pack/plugins/maps/public/classes/styles/vector/vector_style.tsx index 0e87651e234bc..52209563e9807 100644 --- a/x-pack/plugins/maps/public/classes/styles/vector/vector_style.tsx +++ b/x-pack/plugins/maps/public/classes/styles/vector/vector_style.tsx @@ -20,6 +20,7 @@ import { DEFAULT_ICON, FIELD_ORIGIN, GEO_JSON_TYPE, + ICON_SOURCE, KBN_IS_CENTROID_FEATURE, LAYER_STYLE_TYPE, SOURCE_FORMATTERS_DATA_REQUEST_ID, @@ -28,6 +29,8 @@ import { VECTOR_STYLES, } from '../../../../common/constants'; import { StyleMeta } from './style_meta'; +// @ts-expect-error +import { getMakiSymbol, PREFERRED_ICONS } from './symbol_utils'; import { VectorIcon } from './components/legend/vector_icon'; import { VectorStyleLegend } from './components/legend/vector_style_legend'; import { isOnlySingleFeatureType, getHasLabel } from './style_util'; @@ -50,6 +53,7 @@ import { ColorDynamicOptions, ColorStaticOptions, ColorStylePropertyDescriptor, + CustomIcon, DynamicStyleProperties, DynamicStylePropertyOptions, IconDynamicOptions, @@ -99,6 +103,8 @@ export interface IVectorStyle extends IStyle { isTimeAware(): boolean; getPrimaryColor(): string; getIcon(showIncompleteIndicator: boolean): ReactElement; + getIconSvg(symbolId: string): string | undefined; + isUsingCustomIcon(symbolId: string): boolean; hasLegendDetails: () => Promise; renderLegendDetails: () => ReactElement; clearFeatureState: (featureCollection: FeatureCollection, mbMap: MbMap, sourceId: string) => void; @@ -151,6 +157,7 @@ export interface IVectorStyle extends IStyle { export class VectorStyle implements IVectorStyle { private readonly _descriptor: VectorStyleDescriptor; private readonly _layer: IVectorLayer; + private readonly _customIcons: CustomIcon[]; private readonly _source: IVectorSource; private readonly _styleMeta: StyleMeta; @@ -186,10 +193,12 @@ export class VectorStyle implements IVectorStyle { descriptor: VectorStyleDescriptor | null, source: IVectorSource, layer: IVectorLayer, + customIcons: CustomIcon[], chartsPaletteServiceGetColor?: (value: string) => string | null ) { this._source = source; this._layer = layer; + this._customIcons = customIcons; this._descriptor = descriptor ? { ...descriptor, @@ -458,7 +467,10 @@ export class VectorStyle implements IVectorStyle { : (this._lineWidthStyleProperty as StaticSizeProperty).getOptions().size !== 0; } - renderEditor(onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void) { + renderEditor( + onStyleDescriptorChange: (styleDescriptor: StyleDescriptor) => void, + onCustomIconsChange: (customIcons: CustomIcon[]) => void + ) { const rawProperties = this.getRawProperties(); const handlePropertyChange = (propertyName: VECTOR_STYLES, stylePropertyDescriptor: any) => { rawProperties[propertyName] = stylePropertyDescriptor; // override single property, but preserve the rest @@ -488,8 +500,10 @@ export class VectorStyle implements IVectorStyle { isPointsOnly={this.getIsPointsOnly()} isLinesOnly={this._getIsLinesOnly()} onIsTimeAwareChange={onIsTimeAwareChange} + onCustomIconsChange={onCustomIconsChange} isTimeAware={this.isTimeAware()} showIsTimeAware={propertiesWithFieldMeta.length > 0} + customIcons={this._customIcons} hasBorder={this._hasBorder()} /> ); @@ -697,12 +711,28 @@ export class VectorStyle implements IVectorStyle { return formatters ? formatters[fieldName] : null; }; + getIconSvg(symbolId: string) { + const meta = this._getIconMeta(symbolId); + return meta ? meta.svg : undefined; + } + _getSymbolId() { return this.arePointsSymbolizedAsCircles() || this._iconStyleProperty.isDynamic() ? undefined : (this._iconStyleProperty as StaticIconProperty).getOptions().value; } + _getIconMeta( + symbolId: string + ): { svg: string; label: string; iconSource: ICON_SOURCE } | undefined { + const icon = this._customIcons.find(({ symbolId: value }) => value === symbolId); + if (icon) { + return { ...icon, iconSource: ICON_SOURCE.CUSTOM }; + } + const symbol = getMakiSymbol(symbolId); + return symbol ? { ...symbol, iconSource: ICON_SOURCE.MAKI } : undefined; + } + getPrimaryColor() { const primaryColorKey = this._getIsLinesOnly() ? VECTOR_STYLES.LINE_COLOR @@ -741,18 +771,31 @@ export class VectorStyle implements IVectorStyle { } : {}; + const symbolId = this._getSymbolId(); + const svg = symbolId ? this.getIconSvg(symbolId) : undefined; + return ( ); } + isUsingCustomIcon(symbolId: string) { + if (this._iconStyleProperty.isDynamic()) { + const { customIconStops } = this._iconStyleProperty.getOptions() as IconDynamicOptions; + return customIconStops ? customIconStops.some(({ icon }) => icon === symbolId) : false; + } + const { value } = this._iconStyleProperty.getOptions() as IconStaticOptions; + return value === symbolId; + } + _getLegendDetailStyleProperties = () => { const hasLabel = getHasLabel(this._labelStyleProperty); return this.getDynamicPropertiesArray().filter((styleProperty) => { @@ -783,12 +826,16 @@ export class VectorStyle implements IVectorStyle { } renderLegendDetails() { + const symbolId = this._getSymbolId(); + const svg = symbolId ? this.getIconSvg(symbolId) : undefined; + return ( ); } @@ -1040,9 +1087,28 @@ export class VectorStyle implements IVectorStyle { if (!descriptor || !descriptor.options) { return new StaticIconProperty({ value: DEFAULT_ICON }, VECTOR_STYLES.ICON); } else if (descriptor.type === StaticStyleProperty.type) { - return new StaticIconProperty(descriptor.options as IconStaticOptions, VECTOR_STYLES.ICON); + const { value } = { ...descriptor.options } as IconStaticOptions; + const meta = this._getIconMeta(value); + let svg; + let label; + let iconSource; + if (meta) { + ({ svg, label, iconSource } = meta); + } + return new StaticIconProperty( + { value, svg, label, iconSource } as IconStaticOptions, + VECTOR_STYLES.ICON + ); } else if (descriptor.type === DynamicStyleProperty.type) { - const options = descriptor.options as IconDynamicOptions; + const options = { ...descriptor.options } as IconDynamicOptions; + if (options.customIconStops) { + options.customIconStops.forEach((iconStop) => { + const meta = this._getIconMeta(iconStop.icon); + if (meta) { + iconStop.iconSource = meta.iconSource; + } + }); + } const field = this._makeField(options.field); return new DynamicIconProperty( options, diff --git a/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/index.ts b/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/index.ts index d52689cda141a..f2125f1a30993 100644 --- a/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/index.ts +++ b/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/index.ts @@ -10,9 +10,9 @@ import { ThunkDispatch } from 'redux-thunk'; import { connect } from 'react-redux'; import { StyleSettings } from './style_settings'; import { getSelectedLayer } from '../../../selectors/map_selectors'; -import { updateLayerStyleForSelectedLayer } from '../../../actions'; +import { updateCustomIcons, updateLayerStyleForSelectedLayer } from '../../../actions'; import { MapStoreState } from '../../../reducers/store'; -import { StyleDescriptor } from '../../../../common/descriptor_types'; +import { CustomIcon, StyleDescriptor } from '../../../../common/descriptor_types'; function mapStateToProps(state: MapStoreState) { return { @@ -25,6 +25,9 @@ function mapDispatchToProps(dispatch: ThunkDispatch { dispatch(updateLayerStyleForSelectedLayer(styleDescriptor)); }, + updateCustomIcons: (customIcons: CustomIcon[]) => { + dispatch(updateCustomIcons(customIcons)); + }, }; } diff --git a/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/style_settings.tsx b/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/style_settings.tsx index d4f461e7cb3ec..8d399f19a765c 100644 --- a/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/style_settings.tsx +++ b/x-pack/plugins/maps/public/connected_components/edit_layer_panel/style_settings/style_settings.tsx @@ -10,16 +10,17 @@ import React, { Fragment } from 'react'; import { EuiFlexGroup, EuiFlexItem, EuiTitle, EuiPanel, EuiSpacer } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n-react'; -import { StyleDescriptor } from '../../../../common/descriptor_types'; +import { CustomIcon, StyleDescriptor } from '../../../../common/descriptor_types'; import { ILayer } from '../../../classes/layers/layer'; export interface Props { layer: ILayer; updateStyleDescriptor: (styleDescriptor: StyleDescriptor) => void; + updateCustomIcons: (customIcons: CustomIcon[]) => void; } -export function StyleSettings({ layer, updateStyleDescriptor }: Props) { - const settingsEditor = layer.renderStyleEditor(updateStyleDescriptor); +export function StyleSettings({ layer, updateStyleDescriptor, updateCustomIcons }: Props) { + const settingsEditor = layer.renderStyleEditor(updateStyleDescriptor, updateCustomIcons); if (!settingsEditor) { return null; diff --git a/x-pack/plugins/maps/public/connected_components/map_settings_panel/__snapshots__/custom_icons_panel.test.tsx.snap b/x-pack/plugins/maps/public/connected_components/map_settings_panel/__snapshots__/custom_icons_panel.test.tsx.snap new file mode 100644 index 0000000000000..033adb3262115 --- /dev/null +++ b/x-pack/plugins/maps/public/connected_components/map_settings_panel/__snapshots__/custom_icons_panel.test.tsx.snap @@ -0,0 +1,125 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`should render 1`] = ` + + + +
+ +
+
+ + +

+ + + +

+
+ + + + + +
+
+`; + +exports[`should render with custom icons 1`] = ` + + + +
+ +
+
+ + " + symbolId="My Custom Icon" + />, + "key": "__kbn__custom_icon_sdf__foobar", + "label": "My Custom Icon", + }, + Object { + "extraAction": Object { + "alwaysShow": true, + "iconType": "gear", + "onClick": [Function], + }, + "icon": " + symbolId="My Other Custom Icon" + />, + "key": "__kbn__custom_icon_sdf__bizzbuzz", + "label": "My Other Custom Icon", + }, + ] + } + /> + + + + + +
+
+`; diff --git a/x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.test.tsx b/x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.test.tsx new file mode 100644 index 0000000000000..2665a1e1d1858 --- /dev/null +++ b/x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.test.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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +jest.mock('../../kibana_services', () => { + return { + getIsDarkMode() { + return false; + }, + }; +}); + +import React from 'react'; +import { shallow } from 'enzyme'; +import { CustomIconsPanel } from './custom_icons_panel'; + +const defaultProps = { + customIcons: [], + updateCustomIcons: () => {}, + deleteCustomIcon: () => {}, +}; + +test('should render', async () => { + const component = shallow(); + + expect(component).toMatchSnapshot(); +}); + +test('should render with custom icons', async () => { + const customIcons = [ + { + symbolId: '__kbn__custom_icon_sdf__foobar', + label: 'My Custom Icon', + svg: '', + cutoff: 0.25, + radius: 0.25, + }, + { + symbolId: '__kbn__custom_icon_sdf__bizzbuzz', + label: 'My Other Custom Icon', + svg: '', + cutoff: 0.3, + radius: 0.15, + }, + ]; + const component = shallow(); + + expect(component).toMatchSnapshot(); +}); diff --git a/x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.tsx b/x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.tsx new file mode 100644 index 0000000000000..acc205a084b5d --- /dev/null +++ b/x-pack/plugins/maps/public/connected_components/map_settings_panel/custom_icons_panel.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import React, { Component, Fragment } from 'react'; +import { + EuiButtonEmpty, + EuiListGroup, + EuiPanel, + EuiSpacer, + EuiText, + EuiTextAlign, + EuiTextColor, + EuiTitle, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { DEFAULT_CUSTOM_ICON_CUTOFF, DEFAULT_CUSTOM_ICON_RADIUS } from '../../../common/constants'; +import { getIsDarkMode } from '../../kibana_services'; +// @ts-expect-error +import { getCustomIconId } from '../../classes/styles/vector/symbol_utils'; +import { SymbolIcon } from '../../classes/styles/vector/components/legend/symbol_icon'; +import { CustomIconModal } from '../../classes/styles/vector/components/symbol/custom_icon_modal'; +import { CustomIcon } from '../../../common/descriptor_types'; + +interface Props { + customIcons: CustomIcon[]; + updateCustomIcons: (customIcons: CustomIcon[]) => void; + deleteCustomIcon: (symbolId: string) => void; +} + +interface State { + isModalVisible: boolean; + selectedIcon?: CustomIcon; +} + +export class CustomIconsPanel extends Component { + public state = { + isModalVisible: false, + selectedIcon: undefined, + }; + + private _handleIconEdit = (icon: CustomIcon) => { + this.setState({ selectedIcon: icon, isModalVisible: true }); + }; + + private _handleNewIcon = () => { + this.setState({ isModalVisible: true }); + }; + + private _renderModal = () => { + if (!this.state.isModalVisible) { + return null; + } + if (this.state.selectedIcon) { + const { symbolId, label, svg, cutoff, radius } = this.state.selectedIcon; + return ( + + ); + } + return ( + + ); + }; + + private _hideModal = () => { + this.setState({ isModalVisible: false, selectedIcon: undefined }); + }; + + private _handleSave = (icon: CustomIcon) => { + const { symbolId, label, svg, cutoff, radius } = icon; + + const icons = [ + ...this.props.customIcons.filter((i) => { + return i.symbolId !== symbolId; + }), + { + symbolId, + svg, + label, + cutoff, + radius, + }, + ]; + this.props.updateCustomIcons(icons); + this._hideModal(); + }; + + private _handleDelete = (symbolId: string) => { + this.props.deleteCustomIcon(symbolId); + this._hideModal(); + }; + + private _renderCustomIconsList = () => { + const addIconButton = ( + + + this._handleNewIcon()} + data-test-subj="mapsCustomIconPanel-add" + > + + + + + ); + if (!this.props.customIcons.length) { + return ( + + +

+ + + +

+
+ {addIconButton} +
+ ); + } + + const customIconsList = this.props.customIcons.map((icon) => { + const { symbolId, label, svg } = icon; + return { + label, + key: symbolId, + icon: ( + + ), + extraAction: { + iconType: 'gear', + alwaysShow: true, + onClick: () => { + this._handleIconEdit(icon); + }, + }, + }; + }); + + return ( + + + {addIconButton} + + ); + }; + + public render() { + return ( + + + +
+ +
+
+ + {this._renderCustomIconsList()} +
+ {this._renderModal()} +
+ ); + } +} diff --git a/x-pack/plugins/maps/public/connected_components/map_settings_panel/index.ts b/x-pack/plugins/maps/public/connected_components/map_settings_panel/index.ts index c858c74c819d5..e10e59e83dea6 100644 --- a/x-pack/plugins/maps/public/connected_components/map_settings_panel/index.ts +++ b/x-pack/plugins/maps/public/connected_components/map_settings_panel/index.ts @@ -11,8 +11,16 @@ import { ThunkDispatch } from 'redux-thunk'; import { FLYOUT_STATE } from '../../reducers/ui'; import { MapStoreState } from '../../reducers/store'; import { MapSettingsPanel } from './map_settings_panel'; -import { rollbackMapSettings, updateMapSetting, updateFlyout } from '../../actions'; +import { CustomIcon } from '../../../common/descriptor_types'; import { + deleteCustomIcon, + rollbackMapSettings, + updateCustomIcons, + updateMapSetting, + updateFlyout, +} from '../../actions'; +import { + getCustomIcons, getMapCenter, getMapSettings, getMapZoom, @@ -22,6 +30,7 @@ import { function mapStateToProps(state: MapStoreState) { return { center: getMapCenter(state), + customIcons: getCustomIcons(state), hasMapSettingsChanges: hasMapSettingsChanges(state), settings: getMapSettings(state), zoom: getMapZoom(state), @@ -40,6 +49,12 @@ function mapDispatchToProps(dispatch: ThunkDispatch { dispatch(updateMapSetting(settingKey, settingValue)); }, + updateCustomIcons: (customIcons: CustomIcon[]) => { + dispatch(updateCustomIcons(customIcons)); + }, + deleteCustomIcon: (symbolId: string) => { + dispatch(deleteCustomIcon(symbolId)); + }, }; } diff --git a/x-pack/plugins/maps/public/connected_components/map_settings_panel/map_settings_panel.tsx b/x-pack/plugins/maps/public/connected_components/map_settings_panel/map_settings_panel.tsx index baee9c4ff48a0..1efa07e280039 100644 --- a/x-pack/plugins/maps/public/connected_components/map_settings_panel/map_settings_panel.tsx +++ b/x-pack/plugins/maps/public/connected_components/map_settings_panel/map_settings_panel.tsx @@ -22,7 +22,8 @@ import { MapSettings } from '../../reducers/map'; import { NavigationPanel } from './navigation_panel'; import { SpatialFiltersPanel } from './spatial_filters_panel'; import { DisplayPanel } from './display_panel'; -import { MapCenter } from '../../../common/descriptor_types'; +import { CustomIconsPanel } from './custom_icons_panel'; +import { CustomIcon, MapCenter } from '../../../common/descriptor_types'; export interface Props { cancelChanges: () => void; @@ -30,7 +31,10 @@ export interface Props { hasMapSettingsChanges: boolean; keepChanges: () => void; settings: MapSettings; + customIcons: CustomIcon[]; updateMapSetting: (settingKey: string, settingValue: string | number | boolean | object) => void; + updateCustomIcons: (customIcons: CustomIcon[]) => void; + deleteCustomIcon: (symbolId: string) => void; zoom: number; } @@ -40,7 +44,10 @@ export function MapSettingsPanel({ hasMapSettingsChanges, keepChanges, settings, + customIcons, updateMapSetting, + updateCustomIcons, + deleteCustomIcon, zoom, }: Props) { // TODO move common text like Cancel and Close to common i18n translation @@ -77,6 +84,12 @@ export function MapSettingsPanel({ /> + + diff --git a/x-pack/plugins/maps/public/connected_components/mb_map/index.ts b/x-pack/plugins/maps/public/connected_components/mb_map/index.ts index d46d4f53de47f..df03f755d6d2b 100644 --- a/x-pack/plugins/maps/public/connected_components/mb_map/index.ts +++ b/x-pack/plugins/maps/public/connected_components/mb_map/index.ts @@ -21,6 +21,7 @@ import { updateMetaFromTiles, } from '../../actions'; import { + getCustomIcons, getGoto, getLayerList, getMapReady, @@ -40,6 +41,7 @@ function mapStateToProps(state: MapStoreState) { return { isMapReady: getMapReady(state), settings: getMapSettings(state), + customIcons: getCustomIcons(state), layerList: getLayerList(state), spatialFiltersLayer: getSpatialFiltersLayer(state), goto: getGoto(state), diff --git a/x-pack/plugins/maps/public/connected_components/mb_map/mb_map.tsx b/x-pack/plugins/maps/public/connected_components/mb_map/mb_map.tsx index b4c13294e292d..f778fd06cce9b 100644 --- a/x-pack/plugins/maps/public/connected_components/mb_map/mb_map.tsx +++ b/x-pack/plugins/maps/public/connected_components/mb_map/mb_map.tsx @@ -23,12 +23,19 @@ import { ILayer } from '../../classes/layers/layer'; import { IVectorSource } from '../../classes/sources/vector_source'; import { MapSettings } from '../../reducers/map'; import { + CustomIcon, Goto, MapCenterAndZoom, TileMetaFeature, Timeslice, } from '../../../common/descriptor_types'; -import { DECIMAL_DEGREES_PRECISION, RawValue, ZOOM_PRECISION } from '../../../common/constants'; +import { + CUSTOM_ICON_SIZE, + DECIMAL_DEGREES_PRECISION, + MAKI_ICON_SIZE, + RawValue, + ZOOM_PRECISION, +} from '../../../common/constants'; import { getGlyphUrl } from '../../util'; import { syncLayerOrder } from './sort_layers'; @@ -39,12 +46,13 @@ import { TileStatusTracker } from './tile_status_tracker'; import { DrawFeatureControl } from './draw_control/draw_feature_control'; import type { MapExtentState } from '../../reducers/map/types'; // @ts-expect-error -import { createSdfIcon } from '../../classes/styles/vector/symbol_utils'; +import { CUSTOM_ICON_PIXEL_RATIO, createSdfIcon } from '../../classes/styles/vector/symbol_utils'; import { MAKI_ICONS } from '../../classes/styles/vector/maki_icons'; export interface Props { isMapReady: boolean; settings: MapSettings; + customIcons: CustomIcon[]; layerList: ILayer[]; spatialFiltersLayer: ILayer; goto?: Goto | null; @@ -78,6 +86,7 @@ export class MbMap extends Component { private _checker?: ResizeChecker; private _isMounted: boolean = false; private _containerRef: HTMLDivElement | null = null; + private _prevCustomIcons?: CustomIcon[]; private _prevDisableInteractive?: boolean; private _prevLayerList?: ILayer[]; private _prevTimeslice?: Timeslice; @@ -288,7 +297,7 @@ export class MbMap extends Component { const pixelRatio = Math.floor(window.devicePixelRatio); for (const [symbolId, { svg }] of Object.entries(MAKI_ICONS)) { if (!mbMap.hasImage(symbolId)) { - const imageData = await createSdfIcon(svg, 0.25, 0.25); + const imageData = await createSdfIcon({ renderSize: MAKI_ICON_SIZE, svg }); mbMap.addImage(symbolId, imageData, { pixelRatio, sdf: true, @@ -389,6 +398,27 @@ export class MbMap extends Component { } } + if ( + this._prevCustomIcons === undefined || + !_.isEqual(this._prevCustomIcons, this.props.customIcons) + ) { + this._prevCustomIcons = this.props.customIcons; + const mbMap = this.state.mbMap; + for (const { symbolId, svg, cutoff, radius } of this.props.customIcons) { + createSdfIcon({ svg, renderSize: CUSTOM_ICON_SIZE, cutoff, radius }).then( + (imageData: ImageData) => { + // @ts-expect-error MapboxMap type is missing updateImage method + if (mbMap.hasImage(symbolId)) mbMap.updateImage(symbolId, imageData); + else + mbMap.addImage(symbolId, imageData, { + sdf: true, + pixelRatio: CUSTOM_ICON_PIXEL_RATIO, + }); + } + ); + } + } + let zoomRangeChanged = false; if (this.props.settings.minZoom !== this.state.mbMap.getMinZoom()) { this.state.mbMap.setMinZoom(this.props.settings.minZoom); diff --git a/x-pack/plugins/maps/public/reducers/map/default_map_settings.ts b/x-pack/plugins/maps/public/reducers/map/default_map_settings.ts index f5af113b3b316..242d0684f565a 100644 --- a/x-pack/plugins/maps/public/reducers/map/default_map_settings.ts +++ b/x-pack/plugins/maps/public/reducers/map/default_map_settings.ts @@ -13,6 +13,7 @@ export function getDefaultMapSettings(): MapSettings { return { autoFitToDataBounds: false, backgroundColor: euiThemeVars.euiColorEmptyShade, + customIcons: [], disableInteractive: false, disableTooltipControl: false, hideToolbarOverlay: false, diff --git a/x-pack/plugins/maps/public/reducers/map/types.ts b/x-pack/plugins/maps/public/reducers/map/types.ts index d7fa98c24b46f..9f70c7e67271a 100644 --- a/x-pack/plugins/maps/public/reducers/map/types.ts +++ b/x-pack/plugins/maps/public/reducers/map/types.ts @@ -10,6 +10,7 @@ import type { Query } from 'src/plugins/data/common'; import { Filter } from '@kbn/es-query'; import { + CustomIcon, DrawState, EditState, Goto, @@ -51,6 +52,7 @@ export type MapContext = Partial & { export type MapSettings = { autoFitToDataBounds: boolean; backgroundColor: string; + customIcons: CustomIcon[]; disableInteractive: boolean; disableTooltipControl: boolean; hideToolbarOverlay: boolean; diff --git a/x-pack/plugins/maps/public/selectors/map_selectors.test.ts b/x-pack/plugins/maps/public/selectors/map_selectors.test.ts index baca2d79b833d..3c08a0e6f19ce 100644 --- a/x-pack/plugins/maps/public/selectors/map_selectors.test.ts +++ b/x-pack/plugins/maps/public/selectors/map_selectors.test.ts @@ -35,7 +35,7 @@ import { getQueryableUniqueIndexPatternIds, } from './map_selectors'; -import { LayerDescriptor, VectorLayerDescriptor } from '../../common/descriptor_types'; +import { CustomIcon, LayerDescriptor, VectorLayerDescriptor } from '../../common/descriptor_types'; import { ILayer } from '../classes/layers/layer'; import { Filter } from '@kbn/es-query'; import { ESSearchSource } from '../classes/sources/es_search_source'; @@ -255,8 +255,13 @@ describe('getQueryableUniqueIndexPatternIds', () => { ]; const waitingForMapReadyLayerList: VectorLayerDescriptor[] = [] as unknown as VectorLayerDescriptor[]; + const customIcons: CustomIcon[] = []; expect( - getQueryableUniqueIndexPatternIds.resultFunc(layerList, waitingForMapReadyLayerList) + getQueryableUniqueIndexPatternIds.resultFunc( + layerList, + waitingForMapReadyLayerList, + customIcons + ) ).toEqual(['foo', 'bar']); }); @@ -274,8 +279,13 @@ describe('getQueryableUniqueIndexPatternIds', () => { createWaitLayerDescriptorMock({ indexPatternId: 'fbr' }), createWaitLayerDescriptorMock({ indexPatternId: 'foo' }), ] as unknown as VectorLayerDescriptor[]; + const customIcons: CustomIcon[] = []; expect( - getQueryableUniqueIndexPatternIds.resultFunc(layerList, waitingForMapReadyLayerList) + getQueryableUniqueIndexPatternIds.resultFunc( + layerList, + waitingForMapReadyLayerList, + customIcons + ) ).toEqual(['foo', 'fbr']); }); }); diff --git a/x-pack/plugins/maps/public/selectors/map_selectors.ts b/x-pack/plugins/maps/public/selectors/map_selectors.ts index 9253b27a50f66..f86f3dd927c69 100644 --- a/x-pack/plugins/maps/public/selectors/map_selectors.ts +++ b/x-pack/plugins/maps/public/selectors/map_selectors.ts @@ -43,6 +43,7 @@ import { MapStoreState } from '../reducers/store'; import { AbstractSourceDescriptor, DataRequestDescriptor, + CustomIcon, DrawState, EditState, Goto, @@ -65,6 +66,7 @@ import { getIsReadOnly } from './ui_selectors'; export function createLayerInstance( layerDescriptor: LayerDescriptor, + customIcons: CustomIcon[], inspectorAdapters?: Adapters, chartsPaletteServiceGetColor?: (value: string) => string | null ): ILayer { @@ -86,6 +88,7 @@ export function createLayerInstance( layerDescriptor: vectorLayerDescriptor, source: source as IVectorSource, joins, + customIcons, chartsPaletteServiceGetColor, }); case LAYER_TYPE.EMS_VECTOR_TILE: @@ -99,12 +102,14 @@ export function createLayerInstance( return new BlendedVectorLayer({ layerDescriptor: layerDescriptor as VectorLayerDescriptor, source: source as IVectorSource, + customIcons, chartsPaletteServiceGetColor, }); case LAYER_TYPE.MVT_VECTOR: return new MvtVectorLayer({ layerDescriptor: layerDescriptor as VectorLayerDescriptor, source: source as IVectorSource, + customIcons, }); default: throw new Error(`Unrecognized layerType ${layerDescriptor.type}`); @@ -184,6 +189,14 @@ export const getTimeFilters = ({ map }: MapStoreState): TimeRange => export const getTimeslice = ({ map }: MapStoreState) => map.mapState.timeslice; +export const getCustomIcons = ({ map }: MapStoreState): CustomIcon[] => { + return ( + map.settings.customIcons.map((icon) => { + return { ...icon, svg: Buffer.from(icon.svg, 'base64').toString('utf-8') }; + }) ?? [] + ); +}; + export const getQuery = ({ map }: MapStoreState): Query | undefined => map.mapState.query; export const getFilters = ({ map }: MapStoreState): Filter[] => map.mapState.filters; @@ -261,7 +274,8 @@ export const getDataFilters = createSelector( export const getSpatialFiltersLayer = createSelector( getFilters, getMapSettings, - (filters, settings) => { + getCustomIcons, + (filters, settings, customIcons) => { const featureCollection: FeatureCollection = { type: 'FeatureCollection', features: extractFeaturesFromFilters(filters), @@ -298,6 +312,7 @@ export const getSpatialFiltersLayer = createSelector( }), }), source: new GeoJsonFileSource(geoJsonSourceDescriptor), + customIcons, }); } ); @@ -306,9 +321,15 @@ export const getLayerList = createSelector( getLayerListRaw, getInspectorAdapters, getChartsPaletteServiceGetColor, - (layerDescriptorList, inspectorAdapters, chartsPaletteServiceGetColor) => { + getCustomIcons, + (layerDescriptorList, inspectorAdapters, chartsPaletteServiceGetColor, customIcons) => { return layerDescriptorList.map((layerDescriptor) => - createLayerInstance(layerDescriptor, inspectorAdapters, chartsPaletteServiceGetColor) + createLayerInstance( + layerDescriptor, + customIcons, + inspectorAdapters, + chartsPaletteServiceGetColor + ) ); } ); @@ -375,12 +396,13 @@ export const getSelectedLayerJoinDescriptors = createSelector(getSelectedLayer, export const getQueryableUniqueIndexPatternIds = createSelector( getLayerList, getWaitingForMapReadyLayerListRaw, - (layerList, waitingForMapReadyLayerList) => { + getCustomIcons, + (layerList, waitingForMapReadyLayerList, customIcons) => { const indexPatternIds: string[] = []; if (waitingForMapReadyLayerList.length) { waitingForMapReadyLayerList.forEach((layerDescriptor) => { - const layer = createLayerInstance(layerDescriptor); + const layer = createLayerInstance(layerDescriptor, customIcons); if (layer.isVisible()) { indexPatternIds.push(...layer.getQueryableIndexPatternIds()); } @@ -399,12 +421,13 @@ export const getQueryableUniqueIndexPatternIds = createSelector( export const getGeoFieldNames = createSelector( getLayerList, getWaitingForMapReadyLayerListRaw, - (layerList, waitingForMapReadyLayerList) => { + getCustomIcons, + (layerList, waitingForMapReadyLayerList, customIcons) => { const geoFieldNames: string[] = []; if (waitingForMapReadyLayerList.length) { waitingForMapReadyLayerList.forEach((layerDescriptor) => { - const layer = createLayerInstance(layerDescriptor); + const layer = createLayerInstance(layerDescriptor, customIcons); geoFieldNames.push(...layer.getGeoFieldNames()); }); } else { diff --git a/yarn.lock b/yarn.lock index 7168c8af39761..eabf97f983bc9 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6562,6 +6562,11 @@ resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.4.tgz#cd667bcfdd025213aafb7ca5915a932590acdcdc" integrity sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw== +"@types/raf@^3.4.0": + version "3.4.0" + resolved "https://registry.yarnpkg.com/@types/raf/-/raf-3.4.0.tgz#2b72cbd55405e071f1c4d29992638e022b20acc2" + integrity sha512-taW5/WYqo36N7V39oYyHP9Ipfd5pNFvGTIQsNGj86xV88YQ7GnI30/yMfKDF7Zgin0m3e+ikX88FvImnK4RjGw== + "@types/rbush@^3.0.0": version "3.0.0" resolved "https://registry.yarnpkg.com/@types/rbush/-/rbush-3.0.0.tgz#b6887d99b159e87ae23cd14eceff34f139842aa6" @@ -9737,6 +9742,20 @@ canvg@^3.0.9: stackblur-canvas "^2.0.0" svg-pathdata "^6.0.3" +canvg@^3.0.9: + version "3.0.9" + resolved "https://registry.yarnpkg.com/canvg/-/canvg-3.0.9.tgz#9ba095f158b94b97ca2c9c1c40785b11dc08df6d" + integrity sha512-rDXcnRPuz4QHoCilMeoTxql+fvGqNAxp+qV/KHD8rOiJSAfVjFclbdUNHD2Uqfthr+VMg17bD2bVuk6F07oLGw== + dependencies: + "@babel/runtime" "^7.12.5" + "@types/raf" "^3.4.0" + core-js "^3.8.3" + raf "^3.4.1" + regenerator-runtime "^0.13.7" + rgbcolor "^1.0.1" + stackblur-canvas "^2.0.0" + svg-pathdata "^6.0.3" + capture-exit@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/capture-exit/-/capture-exit-2.0.0.tgz#fb953bfaebeb781f62898239dabb426d08a509a4" @@ -10830,6 +10849,11 @@ core-js@^3.0.4, core-js@^3.21.1, core-js@^3.6.5, core-js@^3.8.2, core-js@^3.8.3: resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.21.1.tgz#f2e0ddc1fc43da6f904706e8e955bc19d06a0d94" integrity sha512-FRq5b/VMrWlrmCzwRrpDYNxyHP9BcAZC+xHJaqTgIE5091ZV1NTmyh0sGOg5XqpnHvR0svdy0sv1gWA1zmhxig== +core-js@^3.8.3: + version "3.19.1" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.19.1.tgz#f6f173cae23e73a7d88fa23b6e9da329276c6641" + integrity sha512-Tnc7E9iKd/b/ff7GFbhwPVzJzPztGrChB8X8GLqoYGdEOG8IpLnK1xPyo3ZoO3HsK6TodJS58VGPOxA+hLHQMg== + core-util-is@1.0.2, core-util-is@^1.0.2, core-util-is@~1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" From d9d5f15fe472a2a7def623bd0f877c5118c5c273 Mon Sep 17 00:00:00 2001 From: Candace Park <56409205+parkiino@users.noreply.github.com> Date: Wed, 30 Mar 2022 00:59:09 -0400 Subject: [PATCH 153/160] [Security Solution][Endpoint][Admin][Policy] Remove page header and update ui for endpoint and policy empty state (#128844) --- .../components/management_empty_state.tsx | 17 +++++++++++------ .../pages/endpoint_hosts/view/index.tsx | 1 + .../pages/policy/view/policy_list.tsx | 1 + 3 files changed, 13 insertions(+), 6 deletions(-) diff --git a/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx b/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx index b4a03fb18b2fe..b659cdd118837 100644 --- a/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx +++ b/x-pack/plugins/security_solution/public/management/components/management_empty_state.tsx @@ -23,6 +23,7 @@ import { } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { FormattedMessage } from '@kbn/i18n-react'; +import styled from 'styled-components'; import onboardingLogo from '../images/security_administration_onboarding.svg'; import { useKibana } from '../../common/lib/kibana'; @@ -40,6 +41,10 @@ interface ManagementStep { children: JSX.Element; } +const StyledDiv = styled.div` + padding-left: 20%; +`; + const PolicyEmptyState = React.memo<{ loading: boolean; onActionClick: (event: MouseEvent) => void; @@ -48,7 +53,7 @@ const PolicyEmptyState = React.memo<{ }>(({ loading, onActionClick, actionDisabled, policyEntryPoint = false }) => { const docLinks = useKibana().services.docLinks; return ( -
+ {loading ? ( @@ -57,14 +62,14 @@ const PolicyEmptyState = React.memo<{ ) : ( - + -

+

-

+
@@ -118,12 +123,12 @@ const PolicyEmptyState = React.memo<{
- + )} -
+ ); }); diff --git a/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx b/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx index c2d01d0181d3b..c43c20a4bcae1 100644 --- a/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx +++ b/x-pack/plugins/security_solution/public/management/pages/endpoint_hosts/view/index.tsx @@ -671,6 +671,7 @@ export const EndpointList = () => { return ( { return ( Date: Tue, 29 Mar 2022 22:05:05 -0700 Subject: [PATCH 154/160] [Security Solution][Actions] - Update newest bulk routes to include action migration logic (#128518) Partially addresses #127918 Thanks to our newly added telemetry noticed that in 8.0+ versions there continued to be enabled rules with legacy actions. This was not expected as we expected that on re-enable of rules post 8.0 update, the rules' actions would be migrated so we would see 0 enabled rules with legacy actions. The new bulk routes were added in 8.1 so this does not answer why we see some 8.0 legacy actions, but could account for some of the 8.1+ ones. This PR adds the migration code to the new rule bulk routes and adds e2e tests. --- .../routes/rules/perform_bulk_action_route.ts | 93 +++++- .../security_and_spaces/tests/patch_rules.ts | 2 +- .../tests/patch_rules_bulk.ts | 2 +- .../tests/perform_bulk_action.ts | 266 ++++++++++++++++++ .../detection_engine_api_integration/utils.ts | 19 +- 5 files changed, 366 insertions(+), 16 deletions(-) diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/perform_bulk_action_route.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/perform_bulk_action_route.ts index d8978cd8b11aa..4c4eee366ab84 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/perform_bulk_action_route.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/routes/rules/perform_bulk_action_route.ts @@ -9,10 +9,12 @@ import { truncate } from 'lodash'; import moment from 'moment'; import { BadRequestError, transformError } from '@kbn/securitysolution-es-utils'; import { KibanaResponseFactory, Logger } from 'src/core/server'; +import { SavedObjectsClientContract } from 'kibana/server'; import { RuleAlertType } from '../../rules/types'; import type { RulesClient } from '../../../../../../alerting/server'; +import { SanitizedAlert } from '../../../../../../alerting/common'; import { DETECTION_ENGINE_RULES_BULK_ACTION, @@ -42,6 +44,8 @@ import { getExportByObjectIds } from '../../rules/get_export_by_object_ids'; import { buildSiemResponse } from '../utils'; import { AbortError } from '../../../../../../../../src/plugins/kibana_utils/common'; import { internalRuleToAPIResponse } from '../../schemas/rule_converters'; +import { legacyMigrate } from '../../rules/utils'; +import { RuleParams } from '../../schemas/rule_schemas'; const MAX_RULES_TO_PROCESS_TOTAL = 10000; const MAX_ERROR_MESSAGE_LENGTH = 1000; @@ -191,6 +195,39 @@ const fetchRulesByQueryOrIds = async ({ }; }; +/** + * Helper method to migrate any legacy actions a rule may have. If no actions or no legacy actions + * no migration is performed. + * @params rulesClient + * @params savedObjectsClient + * @params rule - rule to be migrated + * @returns The migrated rule + */ +export const migrateRuleActions = async ({ + rulesClient, + savedObjectsClient, + rule, +}: { + rulesClient: RulesClient; + savedObjectsClient: SavedObjectsClientContract; + rule: RuleAlertType; +}): Promise> => { + const migratedRule = await legacyMigrate({ + rulesClient, + savedObjectsClient, + rule, + }); + + // This should only be hit if `rule` passed into `legacyMigrate` + // is `null` or `rule.id` is null which right now, as typed, should not occur + // but catching if does, in which case something upstream would be breaking down + if (migratedRule == null) { + throw new Error(`An error occurred processing rule with id:${rule.id}`); + } + + return migratedRule; +}; + export const performBulkActionRoute = ( router: SecuritySolutionPluginRouter, ml: SetupPlugins['ml'], @@ -264,13 +301,19 @@ export const performBulkActionRoute = ( concurrency: MAX_RULES_TO_UPDATE_IN_PARALLEL, items: rules, executor: async (rule) => { - if (!rule.enabled) { - throwAuthzError(await mlAuthz.validateRuleType(rule.params.type)); - await rulesClient.enable({ id: rule.id }); + const migratedRule = await migrateRuleActions({ + rulesClient, + savedObjectsClient, + rule, + }); + + if (!migratedRule.enabled) { + throwAuthzError(await mlAuthz.validateRuleType(migratedRule.params.type)); + await rulesClient.enable({ id: migratedRule.id }); } return { - ...rule, + ...migratedRule, enabled: true, }; }, @@ -282,13 +325,19 @@ export const performBulkActionRoute = ( concurrency: MAX_RULES_TO_UPDATE_IN_PARALLEL, items: rules, executor: async (rule) => { - if (rule.enabled) { - throwAuthzError(await mlAuthz.validateRuleType(rule.params.type)); - await rulesClient.disable({ id: rule.id }); + const migratedRule = await migrateRuleActions({ + rulesClient, + savedObjectsClient, + rule, + }); + + if (migratedRule.enabled) { + throwAuthzError(await mlAuthz.validateRuleType(migratedRule.params.type)); + await rulesClient.disable({ id: migratedRule.id }); } return { - ...rule, + ...migratedRule, enabled: false, }; }, @@ -300,8 +349,14 @@ export const performBulkActionRoute = ( concurrency: MAX_RULES_TO_UPDATE_IN_PARALLEL, items: rules, executor: async (rule) => { + const migratedRule = await migrateRuleActions({ + rulesClient, + savedObjectsClient, + rule, + }); + await deleteRules({ - ruleId: rule.id, + ruleId: migratedRule.id, rulesClient, ruleExecutionLog, }); @@ -316,10 +371,16 @@ export const performBulkActionRoute = ( concurrency: MAX_RULES_TO_UPDATE_IN_PARALLEL, items: rules, executor: async (rule) => { - throwAuthzError(await mlAuthz.validateRuleType(rule.params.type)); + const migratedRule = await migrateRuleActions({ + rulesClient, + savedObjectsClient, + rule, + }); + + throwAuthzError(await mlAuthz.validateRuleType(migratedRule.params.type)); const createdRule = await rulesClient.create({ - data: duplicateRule(rule, isRuleRegistryEnabled), + data: duplicateRule(migratedRule, isRuleRegistryEnabled), }); return createdRule; @@ -357,9 +418,15 @@ export const performBulkActionRoute = ( throwAuthzError(await mlAuthz.validateRuleType(rule.params.type)); + const migratedRule = await migrateRuleActions({ + rulesClient, + savedObjectsClient, + rule, + }); + const editedRule = body[BulkAction.edit].reduce( (acc, action) => applyBulkActionEditToRule(acc, action), - rule + migratedRule ); const { tags, params: { timelineTitle, timelineId } = {} } = editedRule; @@ -367,7 +434,7 @@ export const performBulkActionRoute = ( await patchRules({ rulesClient, - rule, + rule: migratedRule, tags, index, timelineTitle, diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules.ts index 7867fc2fd16e4..ccfd8371c3f2d 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules.ts @@ -224,7 +224,7 @@ export default ({ getService }: FtrProviderContext) => { }, }, ]; - outputRule.throttle = '1m'; + outputRule.throttle = '1h'; const bodyToCompare = removeServerGeneratedProperties(patchResponse.body); expect(bodyToCompare).to.eql(outputRule); }); diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules_bulk.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules_bulk.ts index d3128c6670402..51cf1a334a2c7 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules_bulk.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/patch_rules_bulk.ts @@ -171,7 +171,7 @@ export default ({ getService }: FtrProviderContext) => { }, }, ]; - outputRule.throttle = '1m'; + outputRule.throttle = '1h'; const bodyToCompare = removeServerGeneratedProperties(response); expect(bodyToCompare).to.eql(outputRule); }); diff --git a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/perform_bulk_action.ts b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/perform_bulk_action.ts index 1bbfafd8f0b14..5b36d9a880397 100644 --- a/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/perform_bulk_action.ts +++ b/x-pack/test/detection_engine_api_integration/security_and_spaces/tests/perform_bulk_action.ts @@ -25,11 +25,15 @@ import { getSimpleRule, getSimpleRuleOutput, removeServerGeneratedProperties, + createLegacyRuleAction, + getLegacyActionSO, } from '../../utils'; +import { RulesSchema } from '../../../../plugins/security_solution/common/detection_engine/schemas/response'; // eslint-disable-next-line import/no-default-export export default ({ getService }: FtrProviderContext): void => { const supertest = getService('supertest'); + const es = getService('es'); const log = getService('log'); const postBulkAction = () => @@ -95,6 +99,45 @@ export default ({ getService }: FtrProviderContext): void => { await fetchRule(ruleId).expect(404); }); + it('should delete rules and any associated legacy actions', async () => { + const ruleId = 'ruleId'; + const [connector, rule1] = await Promise.all([ + supertest + .post(`/api/actions/connector`) + .set('kbn-xsrf', 'foo') + .send({ + name: 'My action', + connector_type_id: '.slack', + secrets: { + webhookUrl: 'http://localhost:1234', + }, + }), + createRule(supertest, log, getSimpleRule(ruleId, false)), + ]); + await createLegacyRuleAction(supertest, rule1.id, connector.body.id); + + // check for legacy sidecar action + const sidecarActionsResults = await getLegacyActionSO(es); + expect(sidecarActionsResults.hits.hits.length).to.eql(1); + expect(sidecarActionsResults.hits.hits[0]?._source?.references[0].id).to.eql(rule1.id); + + const { body } = await postBulkAction() + .send({ query: '', action: BulkAction.delete }) + .expect(200); + + expect(body.attributes.summary).to.eql({ failed: 0, succeeded: 1, total: 1 }); + + // Check that the deleted rule is returned with the response + expect(body.attributes.results.deleted[0].name).to.eql(rule1.name); + + // legacy sidecar action should be gone + const sidecarActionsPostResults = await getLegacyActionSO(es); + expect(sidecarActionsPostResults.hits.hits.length).to.eql(0); + + // Check that the updates have been persisted + await fetchRule(ruleId).expect(404); + }); + it('should enable rules', async () => { const ruleId = 'ruleId'; await createRule(supertest, log, getSimpleRule(ruleId)); @@ -113,6 +156,57 @@ export default ({ getService }: FtrProviderContext): void => { expect(ruleBody.enabled).to.eql(true); }); + it('should enable rules and migrate actions', async () => { + const ruleId = 'ruleId'; + const [connector, rule1] = await Promise.all([ + supertest + .post(`/api/actions/connector`) + .set('kbn-xsrf', 'foo') + .send({ + name: 'My action', + connector_type_id: '.slack', + secrets: { + webhookUrl: 'http://localhost:1234', + }, + }), + createRule(supertest, log, getSimpleRule(ruleId, false)), + ]); + await createLegacyRuleAction(supertest, rule1.id, connector.body.id); + + // check for legacy sidecar action + const sidecarActionsResults = await getLegacyActionSO(es); + expect(sidecarActionsResults.hits.hits.length).to.eql(1); + expect(sidecarActionsResults.hits.hits[0]?._source?.references[0].id).to.eql(rule1.id); + + const { body } = await postBulkAction() + .send({ query: '', action: BulkAction.enable }) + .expect(200); + + expect(body.attributes.summary).to.eql({ failed: 0, succeeded: 1, total: 1 }); + + // Check that the updated rule is returned with the response + expect(body.attributes.results.updated[0].enabled).to.eql(true); + + // Check that the updates have been persisted + const { body: ruleBody } = await fetchRule(ruleId).expect(200); + + // legacy sidecar action should be gone + const sidecarActionsPostResults = await getLegacyActionSO(es); + expect(sidecarActionsPostResults.hits.hits.length).to.eql(0); + + expect(ruleBody.enabled).to.eql(true); + expect(ruleBody.actions).to.eql([ + { + action_type_id: '.slack', + group: 'default', + id: connector.body.id, + params: { + message: 'Hourly\nRule {{context.rule.name}} generated {{state.signals_count}} alerts', + }, + }, + ]); + }); + it('should disable rules', async () => { const ruleId = 'ruleId'; await createRule(supertest, log, getSimpleRule(ruleId, true)); @@ -131,6 +225,57 @@ export default ({ getService }: FtrProviderContext): void => { expect(ruleBody.enabled).to.eql(false); }); + it('should disable rules and migrate actions', async () => { + const ruleId = 'ruleId'; + const [connector, rule1] = await Promise.all([ + supertest + .post(`/api/actions/connector`) + .set('kbn-xsrf', 'foo') + .send({ + name: 'My action', + connector_type_id: '.slack', + secrets: { + webhookUrl: 'http://localhost:1234', + }, + }), + createRule(supertest, log, getSimpleRule(ruleId, true)), + ]); + await createLegacyRuleAction(supertest, rule1.id, connector.body.id); + + // check for legacy sidecar action + const sidecarActionsResults = await getLegacyActionSO(es); + expect(sidecarActionsResults.hits.hits.length).to.eql(1); + expect(sidecarActionsResults.hits.hits[0]?._source?.references[0].id).to.eql(rule1.id); + + const { body } = await postBulkAction() + .send({ query: '', action: BulkAction.disable }) + .expect(200); + + expect(body.attributes.summary).to.eql({ failed: 0, succeeded: 1, total: 1 }); + + // Check that the updated rule is returned with the response + expect(body.attributes.results.updated[0].enabled).to.eql(false); + + // Check that the updates have been persisted + const { body: ruleBody } = await fetchRule(ruleId).expect(200); + + // legacy sidecar action should be gone + const sidecarActionsPostResults = await getLegacyActionSO(es); + expect(sidecarActionsPostResults.hits.hits.length).to.eql(0); + + expect(ruleBody.enabled).to.eql(false); + expect(ruleBody.actions).to.eql([ + { + action_type_id: '.slack', + group: 'default', + id: connector.body.id, + params: { + message: 'Hourly\nRule {{context.rule.name}} generated {{state.signals_count}} alerts', + }, + }, + ]); + }); + it('should duplicate rules', async () => { const ruleId = 'ruleId'; const ruleToDuplicate = getSimpleRule(ruleId); @@ -154,6 +299,66 @@ export default ({ getService }: FtrProviderContext): void => { expect(rulesResponse.total).to.eql(2); }); + it('should duplicate rule with a legacy action and migrate new rules action', async () => { + const ruleId = 'ruleId'; + const [connector, ruleToDuplicate] = await Promise.all([ + supertest + .post(`/api/actions/connector`) + .set('kbn-xsrf', 'foo') + .send({ + name: 'My action', + connector_type_id: '.slack', + secrets: { + webhookUrl: 'http://localhost:1234', + }, + }), + createRule(supertest, log, getSimpleRule(ruleId, true)), + ]); + await createLegacyRuleAction(supertest, ruleToDuplicate.id, connector.body.id); + + // check for legacy sidecar action + const sidecarActionsResults = await getLegacyActionSO(es); + expect(sidecarActionsResults.hits.hits.length).to.eql(1); + expect(sidecarActionsResults.hits.hits[0]?._source?.references[0].id).to.eql( + ruleToDuplicate.id + ); + + const { body } = await postBulkAction() + .send({ query: '', action: BulkAction.duplicate }) + .expect(200); + + expect(body.attributes.summary).to.eql({ failed: 0, succeeded: 1, total: 1 }); + + // Check that the duplicated rule is returned with the response + expect(body.attributes.results.created[0].name).to.eql(`${ruleToDuplicate.name} [Duplicate]`); + + // legacy sidecar action should be gone + const sidecarActionsPostResults = await getLegacyActionSO(es); + expect(sidecarActionsPostResults.hits.hits.length).to.eql(0); + + // Check that the updates have been persisted + const { body: rulesResponse } = await supertest + .get(`${DETECTION_ENGINE_RULES_URL}/_find`) + .set('kbn-xsrf', 'true') + .expect(200); + + expect(rulesResponse.total).to.eql(2); + + rulesResponse.data.forEach((rule: RulesSchema) => { + expect(rule.actions).to.eql([ + { + action_type_id: '.slack', + group: 'default', + id: connector.body.id, + params: { + message: + 'Hourly\nRule {{context.rule.name}} generated {{state.signals_count}} alerts', + }, + }, + ]); + }); + }); + describe('edit action', () => { it('should set, add and delete tags in rules', async () => { const ruleId = 'ruleId'; @@ -224,6 +429,67 @@ export default ({ getService }: FtrProviderContext): void => { expect(deletedTagsRule.tags).to.eql(['tag2']); }); + it('should migrate legacy actions on edit', async () => { + const ruleId = 'ruleId'; + const [connector, ruleToDuplicate] = await Promise.all([ + supertest + .post(`/api/actions/connector`) + .set('kbn-xsrf', 'foo') + .send({ + name: 'My action', + connector_type_id: '.slack', + secrets: { + webhookUrl: 'http://localhost:1234', + }, + }), + createRule(supertest, log, getSimpleRule(ruleId, true)), + ]); + await createLegacyRuleAction(supertest, ruleToDuplicate.id, connector.body.id); + + // check for legacy sidecar action + const sidecarActionsResults = await getLegacyActionSO(es); + expect(sidecarActionsResults.hits.hits.length).to.eql(1); + expect(sidecarActionsResults.hits.hits[0]?._source?.references[0].id).to.eql( + ruleToDuplicate.id + ); + + const { body: setTagsBody } = await postBulkAction() + .send({ + query: '', + action: BulkAction.edit, + [BulkAction.edit]: [ + { + type: BulkActionEditType.set_tags, + value: ['reset-tag'], + }, + ], + }) + .expect(200); + + expect(setTagsBody.attributes.summary).to.eql({ failed: 0, succeeded: 1, total: 1 }); + + // Check that the updates have been persisted + const { body: setTagsRule } = await fetchRule(ruleId).expect(200); + + // Sidecar should be removed + const sidecarActionsPostResults = await getLegacyActionSO(es); + expect(sidecarActionsPostResults.hits.hits.length).to.eql(0); + + expect(setTagsRule.tags).to.eql(['reset-tag']); + + expect(setTagsRule.actions).to.eql([ + { + action_type_id: '.slack', + group: 'default', + id: connector.body.id, + params: { + message: + 'Hourly\nRule {{context.rule.name}} generated {{state.signals_count}} alerts', + }, + }, + ]); + }); + it('should set, add and delete index patterns in rules', async () => { const ruleId = 'ruleId'; const indices = ['index1-*', 'index2-*']; diff --git a/x-pack/test/detection_engine_api_integration/utils.ts b/x-pack/test/detection_engine_api_integration/utils.ts index 2fc5cdadecb2a..ebf3a7008cd57 100644 --- a/x-pack/test/detection_engine_api_integration/utils.ts +++ b/x-pack/test/detection_engine_api_integration/utils.ts @@ -26,6 +26,8 @@ import type { } from '@kbn/securitysolution-io-ts-list-types'; import { EXCEPTION_LIST_ITEM_URL, EXCEPTION_LIST_URL } from '@kbn/securitysolution-list-constants'; import { ToolingLog } from '@kbn/dev-utils'; +import { SearchResponse } from '@elastic/elasticsearch/lib/api/types'; +import { SavedObjectReference } from 'kibana/server'; import { PrePackagedRulesAndTimelinesStatusSchema } from '../../plugins/security_solution/common/detection_engine/schemas/response'; import { CreateRulesSchema, @@ -59,6 +61,7 @@ import { UPDATE_OR_CREATE_LEGACY_ACTIONS, } from '../../plugins/security_solution/common/constants'; import { DetectionMetrics } from '../../plugins/security_solution/server/usage/detections/types'; +import { LegacyRuleActions } from '../../plugins/security_solution/server/lib/detection_engine/rule_actions/legacy_types'; import { DetectionAlert } from '../../plugins/security_solution/common/detection_engine/schemas/alerts'; /** @@ -638,7 +641,7 @@ export const createLegacyRuleAction = async ( .query({ alert_id: alertId }) .send({ name: 'Legacy notification with one action', - interval: '1m', + interval: '1h', actions: [ { id: connectorId, @@ -2100,3 +2103,17 @@ export const getSimpleThreatMatch = ( ], threat_filters: [], }); + +interface LegacyActionSO extends LegacyRuleActions { + references: SavedObjectReference[]; +} + +/** + * Fetch all legacy action sidecar SOs from the .kibana index + * @param es The ElasticSearch service + */ +export const getLegacyActionSO = async (es: Client): Promise> => + es.search({ + index: '.kibana', + q: 'type:siem-detection-engine-rule-actions', + }); From 4f070b3435b0b4e6f739ac6949a93ac9a1338944 Mon Sep 17 00:00:00 2001 From: Melissa Alvarez Date: Wed, 30 Mar 2022 01:04:26 -0600 Subject: [PATCH 155/160] [ML][Maps] Anomaly Detection: Add link to maps in charts section of Anomaly Explorer (#128697) * add link to maps in charts section of explorer * linting fix and wrap path generator in useCallback * export necessary constants from maps plugin * add size constant * typical layer to grey. Update maps export. Fix jest test * add query for partition fields * add tests and escape special characters --- x-pack/plugins/maps/common/index.ts | 1 + x-pack/plugins/maps/public/index.ts | 1 + .../explorer_charts_container.js | 138 ++++++++++++++++++ .../explorer_charts_container.test.js | 101 ++++++++++++- .../maps/anomaly_layer_wizard_factory.tsx | 2 +- .../plugins/ml/public/maps/anomaly_source.tsx | 28 +++- 6 files changed, 264 insertions(+), 7 deletions(-) diff --git a/x-pack/plugins/maps/common/index.ts b/x-pack/plugins/maps/common/index.ts index fc86af0e2b1f5..56abccb510ad5 100644 --- a/x-pack/plugins/maps/common/index.ts +++ b/x-pack/plugins/maps/common/index.ts @@ -7,6 +7,7 @@ export { AGG_TYPE, + APP_ID, COLOR_MAP_TYPE, DECIMAL_DEGREES_PRECISION, ES_GEO_FIELD_TYPE, diff --git a/x-pack/plugins/maps/public/index.ts b/x-pack/plugins/maps/public/index.ts index 071300b7784fb..6b8767abe9c11 100644 --- a/x-pack/plugins/maps/public/index.ts +++ b/x-pack/plugins/maps/public/index.ts @@ -18,6 +18,7 @@ export const plugin: PluginInitializer = ( }; export { MAP_SAVED_OBJECT_TYPE } from '../common/constants'; +export { MAPS_APP_LOCATOR } from './locators'; export type { PreIndexedShape } from '../common/elasticsearch_util'; export { GEOJSON_FEATURE_ID_PROPERTY_NAME } from './classes/layers/vector_layer/geojson_vector_layer/assign_feature_ids'; diff --git a/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js b/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js index 2029211c98970..79a1121a98a62 100644 --- a/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js +++ b/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js @@ -7,6 +7,7 @@ import './_index.scss'; import React, { useEffect, useState, useCallback, useRef } from 'react'; +import { escapeKuery } from '@kbn/es-query'; import { EuiButtonEmpty, @@ -15,6 +16,7 @@ import { EuiFlexItem, EuiIconTip, EuiToolTip, + htmlIdGenerator, } from '@elastic/eui'; import { @@ -27,15 +29,22 @@ import { ExplorerChartSingleMetric } from './explorer_chart_single_metric'; import { ExplorerChartLabel } from './components/explorer_chart_label'; import { CHART_TYPE } from '../explorer_constants'; +import { SEARCH_QUERY_LANGUAGE } from '../../../../common/constants/search'; import { i18n } from '@kbn/i18n'; import { FormattedMessage } from '@kbn/i18n-react'; import { MlTooltipComponent } from '../../components/chart_tooltip'; import { withKibana } from '../../../../../../../src/plugins/kibana_react/public'; +import { useMlKibana } from '../../contexts/kibana'; import { ML_JOB_AGGREGATION } from '../../../../common/constants/aggregation_types'; +import { AnomalySource } from '../../../maps/anomaly_source'; +import { CUSTOM_COLOR_RAMP } from '../../../maps/anomaly_layer_wizard_factory'; +import { LAYER_TYPE, APP_ID as MAPS_APP_ID } from '../../../../../maps/common'; +import { MAPS_APP_LOCATOR } from '../../../../../maps/public'; import { ExplorerChartsErrorCallOuts } from './explorer_charts_error_callouts'; import { addItemToRecentlyAccessed } from '../../util/recently_accessed'; import { EmbeddedMapComponentWrapper } from './explorer_chart_embedded_map'; import { useActiveCursor } from '../../../../../../../src/plugins/charts/public'; +import { ML_ANOMALY_LAYERS } from '../../../maps/util'; import { Chart, Settings } from '@elastic/charts'; import useObservable from 'react-use/lib/useObservable'; @@ -53,6 +62,20 @@ const textViewButton = i18n.translate( const mapsPluginMessage = i18n.translate('xpack.ml.explorer.charts.mapsPluginMissingMessage', { defaultMessage: 'maps or embeddable start plugin not found', }); +const openInMapsPluginMessage = i18n.translate('xpack.ml.explorer.charts.openInMapsPluginMessage', { + defaultMessage: 'Open in Maps', +}); + +export function getEntitiesQuery(series) { + const queryString = series.entityFields + ?.map(({ fieldName, fieldValue }) => `${escapeKuery(fieldName)}:${escapeKuery(fieldValue)}`) + .join(' or '); + const query = { + language: SEARCH_QUERY_LANGUAGE.KUERY, + query: queryString, + }; + return { query, queryString }; +} // create a somewhat unique ID // from charts metadata for React's key attribute @@ -79,6 +102,81 @@ function ExplorerChartContainer({ chartsService, }) { const [explorerSeriesLink, setExplorerSeriesLink] = useState(''); + const [mapsLink, setMapsLink] = useState(''); + + const { + services: { + data, + share, + application: { navigateToApp }, + }, + } = useMlKibana(); + + const getMapsLink = useCallback(async () => { + const { queryString, query } = getEntitiesQuery(series); + const initialLayers = []; + const typicalStyle = { + type: 'VECTOR', + properties: { + fillColor: { + type: 'STATIC', + options: { + color: '#98A2B2', + }, + }, + lineColor: { + type: 'STATIC', + options: { + color: '#fff', + }, + }, + lineWidth: { + type: 'STATIC', + options: { + size: 2, + }, + }, + iconSize: { + type: 'STATIC', + options: { + size: 6, + }, + }, + }, + }; + + const style = { + type: 'VECTOR', + properties: { + fillColor: CUSTOM_COLOR_RAMP, + lineColor: CUSTOM_COLOR_RAMP, + }, + isTimeAware: false, + }; + + for (const layer in ML_ANOMALY_LAYERS) { + if (ML_ANOMALY_LAYERS.hasOwnProperty(layer)) { + initialLayers.push({ + id: htmlIdGenerator()(), + type: LAYER_TYPE.GEOJSON_VECTOR, + sourceDescriptor: AnomalySource.createDescriptor({ + jobId: series.jobId, + typicalActual: ML_ANOMALY_LAYERS[layer], + }), + style: ML_ANOMALY_LAYERS[layer] === ML_ANOMALY_LAYERS.TYPICAL ? typicalStyle : style, + }); + } + } + + const locator = share.url.locators.get(MAPS_APP_LOCATOR); + const location = await locator.getLocation({ + initialLayers: initialLayers, + timeRange: data.query.timefilter.timefilter.getTime(), + ...(queryString !== undefined ? { query } : {}), + }); + + return location; + }, [series?.jobId]); useEffect(() => { let isCancelled = false; @@ -98,6 +196,29 @@ function ExplorerChartContainer({ }; }, [mlLocator, series]); + useEffect( + function getMapsPluginLink() { + if (!series) return; + let isCancelled = false; + const generateLink = async () => { + if (!isCancelled) { + try { + const mapsLink = await getMapsLink(); + setMapsLink(mapsLink?.path); + } catch (error) { + console.error(error); + setMapsLink(''); + } + } + }; + generateLink().catch(console.error); + return () => { + isCancelled = true; + }; + }, + [series] + ); + const chartRef = useRef(null); const chartTheme = chartsService.theme.useChartsTheme(); @@ -191,6 +312,23 @@ function ExplorerChartContainer({ )} + {chartType === CHART_TYPE.GEO_MAP && mapsLink ? ( + + { + await navigateToApp(MAPS_APP_ID, { path: mapsLink }); + }} + > + + + + ) : null} diff --git a/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js b/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js index 903a0d75e6f60..0d324a83e27ad 100644 --- a/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js +++ b/x-pack/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js @@ -11,7 +11,7 @@ import { mount, shallow } from 'enzyme'; import { I18nProvider } from '@kbn/i18n-react'; import { getDefaultChartsData } from './explorer_charts_container_service'; -import { ExplorerChartsContainer } from './explorer_charts_container'; +import { ExplorerChartsContainer, getEntitiesQuery } from './explorer_charts_container'; import { chartData } from './__mocks__/mock_chart_data'; import seriesConfig from './__mocks__/mock_series_config_filebeat.json'; @@ -37,6 +37,40 @@ jest.mock('../../../../../../../src/plugins/kibana_react/public', () => ({ }, })); +jest.mock('../../contexts/kibana', () => ({ + useMlKibana: () => { + return { + services: { + share: { + url: { + locators: { + get: jest.fn(() => { + return { + getLocation: jest.fn(() => ({ path: '/#maps' })), + }; + }), + }, + }, + }, + data: { + query: { + timefilter: { + timefilter: { + getTime: jest.fn(() => { + return { from: '', to: '' }; + }), + }, + }, + }, + }, + application: { + navigateToApp: jest.fn(), + }, + }, + }; + }, +})); + const getUtilityProps = () => { const mlUrlGenerator = { createUrl: jest.fn(), @@ -124,4 +158,69 @@ describe('ExplorerChartsContainer', () => { // Check if the additional y-axis information for rare charts is part of the chart expect(wrapper.html().search(rareChartUniqueString)).toBeGreaterThan(0); }); + + describe('getEntitiesQuery', () => { + test('no entity fields', () => { + const series = {}; + const expected = { + query: { language: 'kuery', query: undefined }, + queryString: undefined, + }; + const actual = getEntitiesQuery(series); + expect(actual).toMatchObject(expected); + }); + + test('with entity field', () => { + const series = { + entityFields: [{ fieldName: 'testFieldName', fieldValue: 'testFieldValue' }], + }; + const expected = { + query: { language: 'kuery', query: 'testFieldName:testFieldValue' }, + queryString: 'testFieldName:testFieldValue', + }; + const actual = getEntitiesQuery(series); + expect(actual).toMatchObject(expected); + }); + + test('with multiple entity fields', () => { + const series = { + entityFields: [ + { fieldName: 'testFieldName1', fieldValue: 'testFieldValue1' }, + { fieldName: 'testFieldName2', fieldValue: 'testFieldValue2' }, + ], + }; + const expected = { + query: { + language: 'kuery', + query: 'testFieldName1:testFieldValue1 or testFieldName2:testFieldValue2', + }, + queryString: 'testFieldName1:testFieldValue1 or testFieldName2:testFieldValue2', + }; + const actual = getEntitiesQuery(series); + expect(actual).toMatchObject(expected); + }); + + test('with entity field with special characters', () => { + const series = { + entityFields: [ + { + fieldName: 'agent.keyword', + fieldValue: + 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24', + }, + ], + }; + const expected = { + query: { + language: 'kuery', + query: + 'agent.keyword:Mozilla/5.0 \\(X11; Linux i686\\) AppleWebKit/534.24 \\(KHTML, like Gecko\\) Chrome/11.0.696.50 Safari/534.24', + }, + queryString: + 'agent.keyword:Mozilla/5.0 \\(X11; Linux i686\\) AppleWebKit/534.24 \\(KHTML, like Gecko\\) Chrome/11.0.696.50 Safari/534.24', + }; + const actual = getEntitiesQuery(series); + expect(actual).toMatchObject(expected); + }); + }); }); diff --git a/x-pack/plugins/ml/public/maps/anomaly_layer_wizard_factory.tsx b/x-pack/plugins/ml/public/maps/anomaly_layer_wizard_factory.tsx index 260d058b78e78..e4309247a272a 100644 --- a/x-pack/plugins/ml/public/maps/anomaly_layer_wizard_factory.tsx +++ b/x-pack/plugins/ml/public/maps/anomaly_layer_wizard_factory.tsx @@ -26,7 +26,7 @@ import type { MlPluginStart, MlStartDependencies } from '../plugin'; import type { MlApiServices } from '../application/services/ml_api_service'; export const ML_ANOMALY = 'ML_ANOMALIES'; -const CUSTOM_COLOR_RAMP = { +export const CUSTOM_COLOR_RAMP = { type: STYLE_TYPE.DYNAMIC, options: { customColorRamp: SEVERITY_COLOR_RAMP, diff --git a/x-pack/plugins/ml/public/maps/anomaly_source.tsx b/x-pack/plugins/ml/public/maps/anomaly_source.tsx index 07f6df52f44e5..1ae65b49adc69 100644 --- a/x-pack/plugins/ml/public/maps/anomaly_source.tsx +++ b/x-pack/plugins/ml/public/maps/anomaly_source.tsx @@ -33,6 +33,8 @@ import { getResultsForJobId, ML_ANOMALY_LAYERS, MlAnomalyLayersType } from './ut import { UpdateAnomalySourceEditor } from './update_anomaly_source_editor'; import type { MlApiServices } from '../application/services/ml_api_service'; +const RESULT_LIMIT = 1000; + export interface AnomalySourceDescriptor extends AbstractSourceDescriptor { jobId: string; typicalActual: MlAnomalyLayersType; @@ -59,7 +61,7 @@ export class AnomalySource implements IVectorSource { constructor(sourceDescriptor: Partial, adapters?: Adapters) { this._descriptor = AnomalySource.createDescriptor(sourceDescriptor); } - // TODO: implement query awareness + async getGeoJsonWithMeta( layerName: string, searchFilters: VectorSourceRequestMeta, @@ -77,7 +79,7 @@ export class AnomalySource implements IVectorSource { data: results, meta: { // Set this to true if data is incomplete (e.g. capping number of results to first 1k) - areResultsTrimmed: false, + areResultsTrimmed: results.features.length === RESULT_LIMIT, }, }; } @@ -147,8 +149,23 @@ export class AnomalySource implements IVectorSource { return null; } - getSourceStatus() { - return { tooltipContent: null, areResultsTrimmed: true }; + getSourceStatus(sourceDataRequest?: DataRequest): SourceStatus { + const meta = sourceDataRequest ? sourceDataRequest.getMeta() : null; + + if (meta?.areResultsTrimmed) { + return { + tooltipContent: i18n.translate('xpack.ml.maps.resultsTrimmedMsg', { + defaultMessage: `Results limited to first {count} documents.`, + values: { count: RESULT_LIMIT }, + }), + areResultsTrimmed: true, + }; + } + + return { + tooltipContent: null, + areResultsTrimmed: false, + }; } getType(): string { @@ -222,12 +239,13 @@ export class AnomalySource implements IVectorSource { } getSourceTooltipContent(sourceDataRequest?: DataRequest): SourceStatus { + const meta = sourceDataRequest ? sourceDataRequest.getMeta() : null; return { tooltipContent: i18n.translate('xpack.ml.maps.sourceTooltip', { defaultMessage: 'Shows anomalies', }), // set to true if data is incomplete (we limit to first 1000 results) - areResultsTrimmed: true, + areResultsTrimmed: meta?.areResultsTrimmed ?? false, }; } From d0c06b0112c97eb83f67a9375a4d92b57ef03b25 Mon Sep 17 00:00:00 2001 From: Dmitry Tomashevich <39378793+Dmitriynj@users.noreply.github.com> Date: Wed, 30 Mar 2022 12:19:46 +0500 Subject: [PATCH 156/160] [Discover] Update document explorer callout wording (#128556) - Adding a new callout when Document explorer is active, linking to documentation Co-authored-by: Matthias Wilhelm --- .../document_explorer_callout.tsx | 29 +++- .../document_explorer_update_callout.test.tsx | 60 +++++++++ .../document_explorer_update_callout.tsx | 124 ++++++++++++++++++ .../components/layout/discover_documents.tsx | 52 ++++---- src/plugins/discover/server/ui_settings.ts | 2 +- .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - 7 files changed, 239 insertions(+), 30 deletions(-) create mode 100644 src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_update_callout.test.tsx create mode 100644 src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_update_callout.tsx diff --git a/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx b/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx index 73fc7cdf9a105..9b35b52dbc87f 100644 --- a/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx +++ b/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx @@ -6,7 +6,7 @@ * Side Public License, v 1. */ -import React, { useCallback, useState } from 'react'; +import React, { useCallback, useMemo, useState } from 'react'; import './document_explorer_callout.scss'; import { i18n } from '@kbn/i18n'; import { FormattedMessage } from '@kbn/i18n-react'; @@ -17,7 +17,9 @@ import { EuiFlexGroup, EuiFlexItem, EuiLink, + useEuiTheme, } from '@elastic/eui'; +import { css } from '@emotion/react'; import { useDiscoverServices } from '../../../../utils/use_discover_services'; import { DOC_TABLE_LEGACY } from '../../../../../common'; import { Storage } from '../../../../../../kibana_utils/public'; @@ -32,7 +34,11 @@ const updateStoredCalloutState = (newState: boolean, storage: Storage) => { storage.set(CALLOUT_STATE_KEY, newState); }; +/** + * The callout that's displayed when Document explorer is disabled + */ export const DocumentExplorerCallout = () => { + const { euiTheme } = useEuiTheme(); const { storage, capabilities, docLinks, addBasePath } = useDiscoverServices(); const [calloutClosed, setCalloutClosed] = useState(getStoredCalloutState(storage)); @@ -41,6 +47,13 @@ export const DocumentExplorerCallout = () => { setCalloutClosed(true); }, [storage]); + const semiBoldStyle = useMemo( + () => css` + font-weight: ${euiTheme.font.weight.semiBold}; + `, + [euiTheme.font.weight.semiBold] + ); + if (calloutClosed || !capabilities.advancedSettings.save) { return null; } @@ -54,7 +67,17 @@ export const DocumentExplorerCallout = () => {

+ + + ), + }} />

{ /> - + '', + docLinks: { links: { discover: { documentExplorer: '' } } }, + capabilities: { advancedSettings: { save: true } }, + storage: new LocalStorageMock({ [CALLOUT_STATE_KEY]: false }), +} as unknown as DiscoverServices; + +const mount = (services: DiscoverServices) => { + return mountWithIntl( + + + + ); +}; + +describe('Document Explorer Update callout', () => { + it('should render callout', () => { + const result = mount(defaultServices); + + expect(result.find('.dscDocumentExplorerCallout').exists()).toBeTruthy(); + }); + + it('should not render callout for user without permissions', () => { + const services = { + ...defaultServices, + capabilities: { advancedSettings: { save: false } }, + } as unknown as DiscoverServices; + const result = mount(services); + + expect(result.find('.dscDocumentExplorerCallout').exists()).toBeFalsy(); + }); + + it('should not render callout of it was closed', () => { + const services = { + ...defaultServices, + storage: new LocalStorageMock({ [CALLOUT_STATE_KEY]: true }), + } as unknown as DiscoverServices; + const result = mount(services); + + expect(result.find('.dscDocumentExplorerCallout').exists()).toBeFalsy(); + }); +}); diff --git a/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_update_callout.tsx b/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_update_callout.tsx new file mode 100644 index 0000000000000..7e45193cba3ee --- /dev/null +++ b/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_update_callout.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 + * 2.0 and the Server Side Public License, v 1; you may not use this file except + * in compliance with, at your election, the Elastic License 2.0 or the Server + * Side Public License, v 1. + */ + +import React, { useCallback, useMemo, useState } from 'react'; +import './document_explorer_callout.scss'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { + EuiButton, + EuiButtonIcon, + EuiCallOut, + EuiFlexGroup, + EuiFlexItem, + useEuiTheme, +} from '@elastic/eui'; +import { css } from '@emotion/react'; +import { useDiscoverServices } from '../../../../utils/use_discover_services'; +import { Storage } from '../../../../../../kibana_utils/public'; + +export const CALLOUT_STATE_KEY = 'discover:docExplorerUpdateCalloutClosed'; + +const getStoredCalloutState = (storage: Storage): boolean => { + const calloutClosed = storage.get(CALLOUT_STATE_KEY); + return Boolean(calloutClosed); +}; +const updateStoredCalloutState = (newState: boolean, storage: Storage) => { + storage.set(CALLOUT_STATE_KEY, newState); +}; + +/** + * The callout that's displayed when Document explorer is enabled + */ +export const DocumentExplorerUpdateCallout = () => { + const { euiTheme } = useEuiTheme(); + const { storage, capabilities, docLinks } = useDiscoverServices(); + const [calloutClosed, setCalloutClosed] = useState(getStoredCalloutState(storage)); + + const semiBoldStyle = useMemo( + () => css` + font-weight: ${euiTheme.font.weight.semiBold}; + `, + [euiTheme.font.weight.semiBold] + ); + + const onCloseCallout = useCallback(() => { + updateStoredCalloutState(true, storage); + setCalloutClosed(true); + }, [storage]); + + if (calloutClosed || !capabilities.advancedSettings.save) { + return null; + } + + return ( + } + iconType="search" + > +

+ + + + ), + documentExplorer: ( + + + + ), + }} + /> +

+ + + +
+ ); +}; + +function CalloutTitle({ onCloseCallout }: { onCloseCallout: () => void }) { + return ( + + + + + + + + + ); +} diff --git a/src/plugins/discover/public/application/main/components/layout/discover_documents.tsx b/src/plugins/discover/public/application/main/components/layout/discover_documents.tsx index b3b1b31186dbd..1c7971fe9a292 100644 --- a/src/plugins/discover/public/application/main/components/layout/discover_documents.tsx +++ b/src/plugins/discover/public/application/main/components/layout/discover_documents.tsx @@ -34,6 +34,7 @@ import { DocTableInfinite } from '../../../../components/doc_table/doc_table_inf import { SortPairArr } from '../../../../components/doc_table/lib/get_sort'; import { ElasticSearchHit } from '../../../../types'; import { DocumentExplorerCallout } from '../document_explorer_callout'; +import { DocumentExplorerUpdateCallout } from '../document_explorer_callout/document_explorer_update_callout'; const DocTableInfiniteMemoized = React.memo(DocTableInfinite); const DataGridMemoized = React.memo(DiscoverGrid); @@ -156,30 +157,33 @@ function DiscoverDocumentsComponent({ )} {!isLegacy && (
- + <> + + +
)}
diff --git a/src/plugins/discover/server/ui_settings.ts b/src/plugins/discover/server/ui_settings.ts index b3e955c592ad2..94c85e42673ec 100644 --- a/src/plugins/discover/server/ui_settings.ts +++ b/src/plugins/discover/server/ui_settings.ts @@ -171,7 +171,7 @@ export const getUiSettings: (docLinks: DocLinksServiceSetup) => Record` + i18n.translate('discover.advancedSettings.documentExplorerLinkText', { defaultMessage: 'Document Explorer', diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index c22beedbb4e27..04ef060b80ffd 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -2720,7 +2720,6 @@ "discover.doc.loadingDescription": "読み込み中…", "discover.doc.somethingWentWrongDescription": "{indexName}が見つかりません。", "discover.doc.somethingWentWrongDescriptionAddon": "インデックスが存在することを確認してください。", - "discover.docExplorerCallout.bodyMessage": "ドキュメントエクスプローラーでは、データの並べ替え、選択、比較のほか、列のサイズ変更やドキュメントの全画面表示をすばやく実行できます。", "discover.docExplorerCallout.closeButtonAriaLabel": "閉じる", "discover.docExplorerCallout.headerMessage": "より効率的な探索方法", "discover.docExplorerCallout.tryDocumentExplorer": "ドキュメントエクスプローラーを試す", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 3b85ad51fdb3d..da1bda187ee80 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -2725,7 +2725,6 @@ "discover.doc.loadingDescription": "正在加载……", "discover.doc.somethingWentWrongDescription": "{indexName} 缺失。", "discover.doc.somethingWentWrongDescriptionAddon": "请确保索引存在。", - "discover.docExplorerCallout.bodyMessage": "使用 Document Explorer 快速排序、选择和比较数据,调整列大小并以全屏方式查看文档。", "discover.docExplorerCallout.closeButtonAriaLabel": "关闭", "discover.docExplorerCallout.headerMessage": "更好的浏览方式", "discover.docExplorerCallout.tryDocumentExplorer": "试用 Document Explorer", From 4f54124b77198d3ffc40ca3e22217a0ce0996791 Mon Sep 17 00:00:00 2001 From: Matthias Wilhelm Date: Wed, 30 Mar 2022 09:40:17 +0200 Subject: [PATCH 157/160] [Discover] Implement search source migration (#128609) --- src/plugins/discover/server/plugin.ts | 15 +++- .../discover/server/saved_objects/index.ts | 2 +- .../discover/server/saved_objects/search.ts | 81 ++++++++++--------- .../saved_objects/search_migrations.test.ts | 33 +++++++- .../server/saved_objects/search_migrations.ts | 54 ++++++++++++- 5 files changed, 138 insertions(+), 47 deletions(-) diff --git a/src/plugins/discover/server/plugin.ts b/src/plugins/discover/server/plugin.ts index 879b75986365b..00888d31f8d9b 100644 --- a/src/plugins/discover/server/plugin.ts +++ b/src/plugins/discover/server/plugin.ts @@ -9,13 +9,22 @@ import { CoreSetup, CoreStart, Plugin } from 'kibana/server'; import { getUiSettings } from './ui_settings'; import { capabilitiesProvider } from './capabilities_provider'; -import { searchSavedObjectType } from './saved_objects'; +import { getSavedSearchObjectType } from './saved_objects'; +import type { PluginSetup as DataPluginSetup } from '../../data/server'; export class DiscoverServerPlugin implements Plugin { - public setup(core: CoreSetup) { + public setup( + core: CoreSetup, + plugins: { + data: DataPluginSetup; + } + ) { + const getSearchSourceMigrations = plugins.data.search.searchSource.getAllMigrations.bind( + plugins.data.search.searchSource + ); core.capabilities.registerProvider(capabilitiesProvider); core.uiSettings.register(getUiSettings(core.docLinks)); - core.savedObjects.registerType(searchSavedObjectType); + core.savedObjects.registerType(getSavedSearchObjectType(getSearchSourceMigrations)); return {}; } diff --git a/src/plugins/discover/server/saved_objects/index.ts b/src/plugins/discover/server/saved_objects/index.ts index 27bb6eead7f61..fdb078850cf77 100644 --- a/src/plugins/discover/server/saved_objects/index.ts +++ b/src/plugins/discover/server/saved_objects/index.ts @@ -6,4 +6,4 @@ * Side Public License, v 1. */ -export { searchSavedObjectType } from './search'; +export { getSavedSearchObjectType } from './search'; diff --git a/src/plugins/discover/server/saved_objects/search.ts b/src/plugins/discover/server/saved_objects/search.ts index d5b0a3e09bc61..796ab164cf0af 100644 --- a/src/plugins/discover/server/saved_objects/search.ts +++ b/src/plugins/discover/server/saved_objects/search.ts @@ -7,46 +7,51 @@ */ import { SavedObjectsType } from 'kibana/server'; -import { searchMigrations } from './search_migrations'; +import { MigrateFunctionsObject } from 'src/plugins/kibana_utils/common'; +import { getAllMigrations } from './search_migrations'; -export const searchSavedObjectType: SavedObjectsType = { - name: 'search', - hidden: false, - namespaceType: 'multiple-isolated', - convertToMultiNamespaceTypeVersion: '8.0.0', - management: { - icon: 'discoverApp', - defaultSearchField: 'title', - importableAndExportable: true, - getTitle(obj) { - return obj.attributes.title; - }, - getInAppUrl(obj) { - return { - path: `/app/discover#/view/${encodeURIComponent(obj.id)}`, - uiCapabilitiesPath: 'discover.show', - }; +export function getSavedSearchObjectType( + getSearchSourceMigrations: () => MigrateFunctionsObject +): SavedObjectsType { + return { + name: 'search', + hidden: false, + namespaceType: 'multiple-isolated', + convertToMultiNamespaceTypeVersion: '8.0.0', + management: { + icon: 'discoverApp', + defaultSearchField: 'title', + importableAndExportable: true, + getTitle(obj) { + return obj.attributes.title; + }, + getInAppUrl(obj) { + return { + path: `/app/discover#/view/${encodeURIComponent(obj.id)}`, + uiCapabilitiesPath: 'discover.show', + }; + }, }, - }, - mappings: { - properties: { - columns: { type: 'keyword', index: false, doc_values: false }, - description: { type: 'text' }, - viewMode: { type: 'keyword', index: false, doc_values: false }, - hideChart: { type: 'boolean', index: false, doc_values: false }, - hideAggregatedPreview: { type: 'boolean', index: false, doc_values: false }, - hits: { type: 'integer', index: false, doc_values: false }, - kibanaSavedObjectMeta: { - properties: { - searchSourceJSON: { type: 'text', index: false }, + mappings: { + properties: { + columns: { type: 'keyword', index: false, doc_values: false }, + description: { type: 'text' }, + viewMode: { type: 'keyword', index: false, doc_values: false }, + hideChart: { type: 'boolean', index: false, doc_values: false }, + hideAggregatedPreview: { type: 'boolean', index: false, doc_values: false }, + hits: { type: 'integer', index: false, doc_values: false }, + kibanaSavedObjectMeta: { + properties: { + searchSourceJSON: { type: 'text', index: false }, + }, }, + sort: { type: 'keyword', index: false, doc_values: false }, + title: { type: 'text' }, + grid: { type: 'object', enabled: false }, + version: { type: 'integer' }, + rowHeight: { type: 'text' }, }, - sort: { type: 'keyword', index: false, doc_values: false }, - title: { type: 'text' }, - grid: { type: 'object', enabled: false }, - version: { type: 'integer' }, - rowHeight: { type: 'text' }, }, - }, - migrations: searchMigrations, -}; + migrations: () => getAllMigrations(getSearchSourceMigrations()), + }; +} diff --git a/src/plugins/discover/server/saved_objects/search_migrations.test.ts b/src/plugins/discover/server/saved_objects/search_migrations.test.ts index 122371642fabd..9e4c23c91976c 100644 --- a/src/plugins/discover/server/saved_objects/search_migrations.test.ts +++ b/src/plugins/discover/server/saved_objects/search_migrations.test.ts @@ -6,8 +6,8 @@ * Side Public License, v 1. */ -import { SavedObjectMigrationContext } from 'kibana/server'; -import { searchMigrations } from './search_migrations'; +import { SavedObjectMigrationContext, SavedObjectUnsanitizedDoc } from 'kibana/server'; +import { getAllMigrations, searchMigrations } from './search_migrations'; const savedObjectMigrationContext = null as unknown as SavedObjectMigrationContext; @@ -350,4 +350,33 @@ Object { testMigrateMatchAllQuery(migrationFn); }); }); + it('should apply search source migrations within saved search', () => { + const savedSearch = { + attributes: { + kibanaSavedObjectMeta: { + searchSourceJSON: JSON.stringify({ + some: 'prop', + migrated: false, + }), + }, + }, + } as SavedObjectUnsanitizedDoc; + + const versionToTest = '9.1.1'; + const migrations = getAllMigrations({ + // providing a function for search source migration that's just setting `migrated` to true + [versionToTest]: (state) => ({ ...state, migrated: true }), + }); + + expect(migrations[versionToTest](savedSearch, {} as SavedObjectMigrationContext)).toEqual({ + attributes: { + kibanaSavedObjectMeta: { + searchSourceJSON: JSON.stringify({ + some: 'prop', + migrated: true, + }), + }, + }, + }); + }); }); diff --git a/src/plugins/discover/server/saved_objects/search_migrations.ts b/src/plugins/discover/server/saved_objects/search_migrations.ts index 5d630f782fb78..cb8ced07387a1 100644 --- a/src/plugins/discover/server/saved_objects/search_migrations.ts +++ b/src/plugins/discover/server/saved_objects/search_migrations.ts @@ -8,10 +8,22 @@ // TODO: This needs to be removed and properly typed /* eslint-disable @typescript-eslint/no-explicit-any */ - -import { flow, get } from 'lodash'; -import { SavedObjectMigrationFn } from 'kibana/server'; +import { flow, get, mapValues } from 'lodash'; +import type { + SavedObjectAttributes, + SavedObjectMigrationFn, + SavedObjectMigrationMap, +} from 'kibana/server'; +import { mergeSavedObjectMigrationMaps } from '../../../../core/server'; import { DEFAULT_QUERY_LANGUAGE } from '../../../data/server'; +import { MigrateFunctionsObject, MigrateFunction } from '../../../kibana_utils/common'; +import type { SerializedSearchSourceFields } from '../../../data/common'; + +export interface SavedSearchMigrationAttributes extends SavedObjectAttributes { + kibanaSavedObjectMeta: { + searchSourceJSON: string; + }; +} /** * This migration script is related to: @@ -120,9 +132,45 @@ const migrateSearchSortToNestedArray: SavedObjectMigrationFn = (doc) = }; }; +/** + * This creates a migration map that applies search source migrations + */ +const getSearchSourceMigrations = (searchSourceMigrations: MigrateFunctionsObject) => + mapValues( + searchSourceMigrations, + (migrate: MigrateFunction): MigrateFunction => + (state) => { + const _state = state as unknown as { attributes: SavedSearchMigrationAttributes }; + + const parsedSearchSourceJSON = _state.attributes.kibanaSavedObjectMeta.searchSourceJSON; + + if (!parsedSearchSourceJSON) return _state; + + return { + ..._state, + attributes: { + ..._state.attributes, + kibanaSavedObjectMeta: { + ..._state.attributes.kibanaSavedObjectMeta, + searchSourceJSON: JSON.stringify(migrate(JSON.parse(parsedSearchSourceJSON))), + }, + }, + }; + } + ); + export const searchMigrations = { '6.7.2': flow(migrateMatchAllQuery), '7.0.0': flow(setNewReferences), '7.4.0': flow(migrateSearchSortToNestedArray), '7.9.3': flow(migrateMatchAllQuery), }; + +export const getAllMigrations = ( + searchSourceMigrations: MigrateFunctionsObject +): SavedObjectMigrationMap => { + return mergeSavedObjectMigrationMaps( + searchMigrations, + getSearchSourceMigrations(searchSourceMigrations) as unknown as SavedObjectMigrationMap + ); +}; From 349b6cf5d2d664703f46a217d0f298524ae3042a Mon Sep 17 00:00:00 2001 From: Dmitry Tomashevich <39378793+Dmitriynj@users.noreply.github.com> Date: Wed, 30 Mar 2022 14:19:52 +0500 Subject: [PATCH 158/160] [Discover] Fix toggle table column for classic table (#128603) * Fx toggle table column * Add functional test Co-authored-by: Matthias Wilhelm --- .../document_explorer_callout.tsx | 1 + .../doc_table/doc_table_wrapper.tsx | 5 ++-- test/functional/apps/discover/_doc_table.ts | 24 +++++++++++++++++++ 3 files changed, 28 insertions(+), 2 deletions(-) diff --git a/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx b/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx index 9b35b52dbc87f..efae6bcc51db5 100644 --- a/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx +++ b/src/plugins/discover/public/application/main/components/document_explorer_callout/document_explorer_callout.tsx @@ -125,6 +125,7 @@ function CalloutTitle({ onCloseCallout }: { onCloseCallout: () => void }) { aria-label={i18n.translate('discover.docExplorerCallout.closeButtonAriaLabel', { defaultMessage: 'Close', })} + data-test-subj="dscExplorerCalloutClose" onClick={onCloseCallout} type="button" iconType="cross" diff --git a/src/plugins/discover/public/components/doc_table/doc_table_wrapper.tsx b/src/plugins/discover/public/components/doc_table/doc_table_wrapper.tsx index b208331601330..334c825d78de0 100644 --- a/src/plugins/discover/public/components/doc_table/doc_table_wrapper.tsx +++ b/src/plugins/discover/public/components/doc_table/doc_table_wrapper.tsx @@ -164,12 +164,13 @@ export const DocTableWrapper = forwardRef( indexPattern={indexPattern} row={current} useNewFieldsApi={useNewFieldsApi} - onAddColumn={onAddColumn} fieldsToShow={fieldsToShow} + onAddColumn={onAddColumn} + onRemoveColumn={onRemoveColumn} /> )); }, - [columns, onFilter, indexPattern, useNewFieldsApi, onAddColumn, fieldsToShow] + [columns, onFilter, indexPattern, useNewFieldsApi, fieldsToShow, onAddColumn, onRemoveColumn] ); return ( diff --git a/test/functional/apps/discover/_doc_table.ts b/test/functional/apps/discover/_doc_table.ts index 794204b923b72..321c41b92e9be 100644 --- a/test/functional/apps/discover/_doc_table.ts +++ b/test/functional/apps/discover/_doc_table.ts @@ -189,6 +189,30 @@ export default function ({ getService, getPageObjects }: FtrProviderContext) { expect(defaultMessageElResubmit).to.be.ok(); }); }); + it('should show allow toggling columns from the expanded document', async function () { + await PageObjects.discover.clickNewSearchButton(); + await testSubjects.click('dscExplorerCalloutClose'); + await retry.try(async function () { + await docTable.clickRowToggle({ isAnchorRow: false, rowIndex: rowToInspect - 1 }); + + // add columns + const fields = ['_id', '_index', 'agent']; + for (const field of fields) { + await testSubjects.click(`toggleColumnButton-${field}`); + } + + const headerWithFields = await docTable.getHeaderFields(); + expect(headerWithFields.join(' ')).to.contain(fields.join(' ')); + + // remove columns + for (const field of fields) { + await testSubjects.click(`toggleColumnButton-${field}`); + } + + const headerWithoutFields = await docTable.getHeaderFields(); + expect(headerWithoutFields.join(' ')).not.to.contain(fields.join(' ')); + }); + }); }); describe('add and remove columns', function () { From 6304e4a54f4c09e198165c5b581bafa7533124c4 Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Wed, 30 Mar 2022 11:39:19 +0200 Subject: [PATCH 159/160] improve check for 0 opacity (#128630) --- .../public/application/components/vis_types/timeseries/vis.js | 4 ++-- .../vis_types/timeseries/public/trigger_action/get_extents.ts | 4 ++-- .../vis_types/timeseries/public/trigger_action/index.ts | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/plugins/vis_types/timeseries/public/application/components/vis_types/timeseries/vis.js b/src/plugins/vis_types/timeseries/public/application/components/vis_types/timeseries/vis.js index 8ea5a8594bf19..0fb4e99b1e973 100644 --- a/src/plugins/vis_types/timeseries/public/application/components/vis_types/timeseries/vis.js +++ b/src/plugins/vis_types/timeseries/public/application/components/vis_types/timeseries/vis.js @@ -85,8 +85,8 @@ class TimeseriesVisualization extends Component { const axisMin = get(model, 'axis_min', '').toString(); const axisMax = get(model, 'axis_max', '').toString(); const fit = model.series - ? model.series.filter(({ hidden }) => !hidden).every(({ fill }) => fill === '0') - : model.fill === '0'; + ? model.series.filter(({ hidden }) => !hidden).every(({ fill }) => Number(fill) === 0) + : Number(model.fill) === 0; return { min: axisMin.length ? Number(axisMin) : undefined, diff --git a/src/plugins/vis_types/timeseries/public/trigger_action/get_extents.ts b/src/plugins/vis_types/timeseries/public/trigger_action/get_extents.ts index 857de8390a6a3..a0587671c7686 100644 --- a/src/plugins/vis_types/timeseries/public/trigger_action/get_extents.ts +++ b/src/plugins/vis_types/timeseries/public/trigger_action/get_extents.ts @@ -57,7 +57,7 @@ export const getYExtents = (model: Panel) => { model.series.forEach((s) => { if (s.axis_position === 'left') { - if (s.chart_type !== 'line' || (s.chart_type === 'line' && s.fill !== '0')) { + if (s.chart_type !== 'line' || (s.chart_type === 'line' && Number(s.fill) > 0)) { hasBarOrAreaLeft = true; } if (s.separate_axis) { @@ -68,7 +68,7 @@ export const getYExtents = (model: Panel) => { } } if (s.axis_position === 'right' && s.separate_axis) { - if (s.chart_type !== 'line' || (s.chart_type === 'line' && s.fill !== '0')) { + if (s.chart_type !== 'line' || (s.chart_type === 'line' && Number(s.fill) > 0)) { hasBarOrAreaRight = true; } if (s.separate_axis) { diff --git a/src/plugins/vis_types/timeseries/public/trigger_action/index.ts b/src/plugins/vis_types/timeseries/public/trigger_action/index.ts index 0df0ac55e35eb..15fb1aec2974c 100644 --- a/src/plugins/vis_types/timeseries/public/trigger_action/index.ts +++ b/src/plugins/vis_types/timeseries/public/trigger_action/index.ts @@ -58,7 +58,7 @@ export const triggerTSVBtoLensConfiguration = async ( const timeShift = layer.offset_time; // translate to Lens seriesType const layerChartType = - layer.chart_type === 'line' && layer.fill !== '0' ? 'area' : layer.chart_type; + layer.chart_type === 'line' && Number(layer.fill) > 0 ? 'area' : layer.chart_type; let chartType = layerChartType; if (layer.stacked !== 'none' && layer.stacked !== 'percent') { From 84bd77ca443f082758c6d819dd915c2fe53f9e23 Mon Sep 17 00:00:00 2001 From: "Lucas F. da Costa" Date: Wed, 30 Mar 2022 10:45:37 +0100 Subject: [PATCH 160/160] [Monitor management] Show public beta fair usage (#128857) * show public beta fair usage * type * add callout for async service errors * remove unused variables * Re-add "Revert "[Monitor management] Show public beta fair usage (#128770)" with types fixed Co-authored-by: shahzad31 Co-authored-by: Dominique Clarke --- .../monitor_management/locations.ts | 15 ++- .../monitor_management/monitor_types.ts | 27 ++-- .../action_bar/action_bar.tsx | 40 +----- .../monitor_list/monitor_async_error.test.tsx | 117 ++++++++++++++++++ .../monitor_list/monitor_async_error.tsx | 75 +++++++++++ .../monitor_list/monitor_list_container.tsx | 2 + .../monitor_management/show_sync_errors.tsx | 52 ++++++++ .../monitor_management/monitor_management.tsx | 4 +- .../state/reducers/monitor_management.ts | 1 + .../synthetics_service/synthetics_service.ts | 7 +- .../synthetics_service/get_monitor.ts | 3 +- 11 files changed, 286 insertions(+), 57 deletions(-) create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx create mode 100644 x-pack/plugins/uptime/public/components/monitor_management/show_sync_errors.tsx diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts index d11ae7c655405..82d2bc8afa412 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/locations.ts @@ -64,12 +64,15 @@ export const ServiceLocationErrors = t.array( status: t.number, }), t.partial({ - failed_monitors: t.array( - t.interface({ - id: t.string, - message: t.string, - }) - ), + failed_monitors: t.union([ + t.array( + t.interface({ + id: t.string, + message: t.string, + }) + ), + t.null, + ]), }), ]), }) diff --git a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts index 44c643d2160d1..872ccdbb71ec8 100644 --- a/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts +++ b/x-pack/plugins/uptime/common/runtime_types/monitor_management/monitor_types.ts @@ -8,7 +8,7 @@ import * as t from 'io-ts'; import { secretKeys } from '../../constants/monitor_management'; import { ConfigKey } from './config_key'; -import { LocationsCodec } from './locations'; +import { LocationsCodec, ServiceLocationErrors } from './locations'; import { DataStreamCodec, ModeCodec, @@ -306,14 +306,23 @@ export type EncryptedSyntheticsMonitorWithId = t.TypeOf< typeof EncryptedSyntheticsMonitorWithIdCodec >; -export const MonitorManagementListResultCodec = t.type({ - monitors: t.array( - t.interface({ id: t.string, attributes: EncryptedSyntheticsMonitorCodec, updated_at: t.string }) - ), - page: t.number, - perPage: t.number, - total: t.union([t.number, t.null]), -}); +export const MonitorManagementListResultCodec = t.intersection([ + t.type({ + monitors: t.array( + t.interface({ + id: t.string, + attributes: EncryptedSyntheticsMonitorCodec, + updated_at: t.string, + }) + ), + page: t.number, + perPage: t.number, + total: t.union([t.number, t.null]), + }), + t.partial({ + syncErrors: ServiceLocationErrors, + }), +]); export type MonitorManagementListResult = t.TypeOf; diff --git a/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx b/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx index 3b30458974ed7..5f6e67e363171 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/action_bar/action_bar.tsx @@ -19,7 +19,6 @@ import { i18n } from '@kbn/i18n'; import { useSelector } from 'react-redux'; import { FETCH_STATUS, useFetcher } from '../../../../../observability/public'; -import { toMountPoint } from '../../../../../../../src/plugins/kibana_react/public'; import { MONITOR_MANAGEMENT_ROUTE } from '../../../../common/constants'; import { UptimeSettingsContext } from '../../../contexts'; @@ -32,6 +31,7 @@ import { TestRun } from '../test_now_mode/test_now_mode'; import { monitorManagementListSelector } from '../../../state/selectors'; import { kibanaService } from '../../../state/kibana_service'; +import { showSyncErrors } from '../show_sync_errors'; export interface ActionBarProps { monitor: SyntheticsMonitor; @@ -103,43 +103,7 @@ export const ActionBar = ({ }); setIsSuccessful(true); } else if (hasErrors && !loading) { - Object.values(data.attributes.errors!).forEach((location) => { - const { status: responseStatus, reason } = location.error || {}; - kibanaService.toasts.addWarning({ - title: i18n.translate('xpack.uptime.monitorManagement.service.error.title', { - defaultMessage: `Unable to sync monitor config`, - }), - text: toMountPoint( - <> -

- {i18n.translate('xpack.uptime.monitorManagement.service.error.message', { - defaultMessage: `Your monitor was saved, but there was a problem syncing the configuration for {location}. We will automatically try again later. If this problem continues, your monitors will stop running in {location}. Please contact Support for assistance.`, - values: { - location: locations?.find((loc) => loc?.id === location.locationId)?.label, - }, - })} -

- {responseStatus || reason ? ( -

- {responseStatus - ? i18n.translate('xpack.uptime.monitorManagement.service.error.status', { - defaultMessage: 'Status: {status}. ', - values: { status: responseStatus }, - }) - : null} - {reason - ? i18n.translate('xpack.uptime.monitorManagement.service.error.reason', { - defaultMessage: 'Reason: {reason}.', - values: { reason }, - }) - : null} -

- ) : null} - - ), - toastLifeTimeMs: 30000, - }); - }); + showSyncErrors(data.attributes.errors, locations); setIsSuccessful(true); } }, [data, status, isSaving, isValid, monitorId, hasErrors, locations, loading]); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx new file mode 100644 index 0000000000000..6085c7f8b419d --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.test.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ + +import { screen } from '@testing-library/react'; +import React from 'react'; +import { DEFAULT_THROTTLING } from '../../../../common/runtime_types'; +import { render } from '../../../lib/helper/rtl_helpers'; +import { MonitorManagementList as MonitorManagementListState } from '../../../state/reducers/monitor_management'; +import { MonitorAsyncError } from './monitor_async_error'; + +describe('', () => { + const location1 = 'US Central'; + const location2 = 'US North'; + const reason1 = 'Unauthorized'; + const reason2 = 'Forbidden'; + const status1 = 401; + const status2 = 403; + const state = { + monitorManagementList: { + throttling: DEFAULT_THROTTLING, + enablement: null, + list: { + perPage: 5, + page: 1, + total: 6, + monitors: [], + syncErrors: [ + { + locationId: 'us_central', + error: { + reason: reason1, + status: status1, + }, + }, + { + locationId: 'us_north', + error: { + reason: reason2, + status: status2, + }, + }, + ], + }, + locations: [ + { + id: 'us_central', + label: location1, + geo: { + lat: 0, + lon: 0, + }, + url: '', + }, + { + id: 'us_north', + label: location2, + geo: { + lat: 0, + lon: 0, + }, + url: '', + }, + ], + error: { + serviceLocations: null, + monitorList: null, + enablement: null, + }, + loading: { + monitorList: true, + serviceLocations: false, + enablement: false, + }, + syntheticsService: { + loading: false, + signupUrl: null, + }, + } as MonitorManagementListState, + }; + + it('renders when errors are defined', () => { + render(, { state }); + + expect(screen.getByText(new RegExp(reason1))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(`${status1}`))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(reason2))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(`${status2}`))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(location1))).toBeInTheDocument(); + expect(screen.getByText(new RegExp(location2))).toBeInTheDocument(); + }); + + it('renders null when errors are empty', () => { + render(, { + state: { + ...state, + monitorManagementList: { + ...state.monitorManagementList, + list: { + ...state.monitorManagementList.list, + syncErrors: [], + }, + }, + }, + }); + + expect(screen.queryByText(new RegExp(reason1))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(`${status1}`))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(reason2))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(`${status2}`))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(location1))).not.toBeInTheDocument(); + expect(screen.queryByText(new RegExp(location2))).not.toBeInTheDocument(); + }); +}); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx new file mode 100644 index 0000000000000..c9e9dba2027a4 --- /dev/null +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_async_error.tsx @@ -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 + * 2.0; you may not use this file except in compliance with the Elastic License + * 2.0. + */ +import React, { useState } from 'react'; +import { useSelector } from 'react-redux'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n-react'; +import { EuiButton, EuiCallOut, EuiSpacer } from '@elastic/eui'; +import { monitorManagementListSelector } from '../../../state/selectors'; + +export const MonitorAsyncError = () => { + const [isDismissed, setIsDismissed] = useState(false); + const { list, locations } = useSelector(monitorManagementListSelector); + const syncErrors = list.syncErrors; + const hasSyncErrors = syncErrors && syncErrors.length > 0; + + return hasSyncErrors && !isDismissed ? ( + <> + + } + color="warning" + iconType="alert" + > +

+ +

+
    + {Object.values(syncErrors).map((e) => { + return ( +
  • {`${ + locations.find((location) => location.id === e.locationId)?.label + } - ${STATUS_LABEL}: ${e.error.status}; ${REASON_LABEL}: ${e.error.reason}.`}
  • + ); + })} +
+ setIsDismissed(true)} color="warning"> + {DISMISS_LABEL} + +
+ + + ) : null; +}; + +const REASON_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.monitorSync.failure.reasonLabel', + { + defaultMessage: 'Reason', + } +); + +const STATUS_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.monitorSync.failure.statusLabel', + { + defaultMessage: 'Status', + } +); + +const DISMISS_LABEL = i18n.translate( + 'xpack.uptime.monitorManagement.monitorSync.failure.dismissLabel', + { + defaultMessage: 'Dismiss', + } +); diff --git a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx index a3f041a33a9f8..53afdf49c1592 100644 --- a/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx +++ b/x-pack/plugins/uptime/public/components/monitor_management/monitor_list/monitor_list_container.tsx @@ -13,6 +13,7 @@ import { ConfigKey } from '../../../../common/runtime_types'; import { getMonitors } from '../../../state/actions'; import { monitorManagementListSelector } from '../../../state/selectors'; import { MonitorManagementListPageState } from './monitor_list'; +import { MonitorAsyncError } from './monitor_async_error'; import { useInlineErrors } from '../hooks/use_inline_errors'; import { MonitorListTabs } from './list_tabs'; import { AllMonitors } from './all_monitors'; @@ -66,6 +67,7 @@ export const MonitorListContainer: React.FC = () => { return ( <> + { + Object.values(errors).forEach((location) => { + const { status: responseStatus, reason } = location.error || {}; + kibanaService.toasts.addWarning({ + title: i18n.translate('xpack.uptime.monitorManagement.service.error.title', { + defaultMessage: `Unable to sync monitor config`, + }), + text: toMountPoint( + <> +

+ {i18n.translate('xpack.uptime.monitorManagement.service.error.message', { + defaultMessage: `Your monitor was saved, but there was a problem syncing the configuration for {location}. We will automatically try again later. If this problem continues, your monitors will stop running in {location}. Please contact Support for assistance.`, + values: { + location: locations?.find((loc) => loc?.id === location.locationId)?.label, + }, + })} +

+ {responseStatus || reason ? ( +

+ {responseStatus + ? i18n.translate('xpack.uptime.monitorManagement.service.error.status', { + defaultMessage: 'Status: {status}. ', + values: { status: responseStatus }, + }) + : null} + {reason + ? i18n.translate('xpack.uptime.monitorManagement.service.error.reason', { + defaultMessage: 'Reason: {reason}.', + values: { reason }, + }) + : null} +

+ ) : null} + + ), + toastLifeTimeMs: 30000, + }); + }); +}; diff --git a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx index 3e0e9b955f31f..71785dbaf78ee 100644 --- a/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx +++ b/x-pack/plugins/uptime/public/pages/monitor_management/monitor_management.tsx @@ -17,6 +17,7 @@ import { useMonitorManagementBreadcrumbs } from './use_monitor_management_breadc import { MonitorListContainer } from '../../components/monitor_management/monitor_list/monitor_list_container'; import { EnablementEmptyState } from '../../components/monitor_management/monitor_list/enablement_empty_state'; import { useEnablement } from '../../components/monitor_management/hooks/use_enablement'; +import { useLocations } from '../../components/monitor_management/hooks/use_locations'; import { Loader } from '../../components/monitor_management/loader/loader'; export const MonitorManagementPage: React.FC = () => { @@ -32,6 +33,7 @@ export const MonitorManagementPage: React.FC = () => { loading: enablementLoading, enableSynthetics, } = useEnablement(); + const { loading: locationsLoading } = useLocations(); const { list: monitorList } = useSelector(monitorManagementListSelector); const { isEnabled } = enablement; @@ -62,7 +64,7 @@ export const MonitorManagementPage: React.FC = () => { return ( <> ({ search: schema.maybe(schema.string()), }), }, - handler: async ({ request, savedObjectsClient }): Promise => { + handler: async ({ request, savedObjectsClient, server }): Promise => { const { perPage = 50, page, sortField, sortOrder, search } = request.query; // TODO: add query/filtering params const { @@ -78,6 +78,7 @@ export const getAllSyntheticsMonitorRoute: UMRestApiRouteFactory = () => ({ ...rest, perPage: perPageT, monitors, + syncErrors: server.syntheticsService.syncErrors, }; }, });