From 4295dfec0f745761edb3de64e2fe18abff253bb9 Mon Sep 17 00:00:00 2001 From: spalger Date: Sat, 13 Jun 2020 14:37:30 -0700 Subject: [PATCH 01/39] skip flaky suite (#63339) --- x-pack/test/functional/apps/canvas/custom_elements.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/x-pack/test/functional/apps/canvas/custom_elements.ts b/x-pack/test/functional/apps/canvas/custom_elements.ts index 029837ad6ef02..20ad045d0a653 100644 --- a/x-pack/test/functional/apps/canvas/custom_elements.ts +++ b/x-pack/test/functional/apps/canvas/custom_elements.ts @@ -19,7 +19,8 @@ export default function canvasCustomElementTest({ const PageObjects = getPageObjects(['canvas', 'common']); const find = getService('find'); - describe('custom elements', function () { + // FLAKY: https://github.com/elastic/kibana/issues/63339 + describe.skip('custom elements', function () { this.tags('skipFirefox'); before(async () => { From 4ce3702a8477efb1dff5e7e3748fe5b46ecdc36b Mon Sep 17 00:00:00 2001 From: Matthias Wilhelm Date: Mon, 15 Jun 2020 08:44:24 +0200 Subject: [PATCH 02/39] Rename space id for disabled index pattern test (#68990) --- .../apps/discover/feature_controls/discover_spaces.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts b/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts index 96a601a576332..767dad74c23d7 100644 --- a/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts +++ b/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts @@ -140,19 +140,19 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { describe('space with index pattern management disabled', () => { before(async () => { await spacesService.create({ - id: 'custom_space', - name: 'custom_space', + id: 'custom_space_no_index_patterns', + name: 'custom_space_no_index_patterns', disabledFeatures: ['indexPatterns'], }); }); after(async () => { - await spacesService.delete('custom_space'); + await spacesService.delete('custom_space_no_index_patterns'); }); it('Navigates to Kibana home rather than index pattern management when no index patterns exist', async () => { await PageObjects.common.navigateToUrl('discover', '', { - basePath: '/s/custom_space', + basePath: '/s/custom_space_no_index_patterns', ensureCurrentUrl: false, }); await testSubjects.existOrFail('homeApp', { timeout: config.get('timeouts.waitFor') }); From 437f9f6041e067ecdc77f3f6cd622f52ef51a719 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cau=C3=AA=20Marcondes?= <55978943+cauemarcondes@users.noreply.github.com> Date: Mon, 15 Jun 2020 07:46:36 +0100 Subject: [PATCH 03/39] [Observability] Create context container to enable Observability plugin registry function (#68642) * creating observability context registry * adding registryContext * addressing PR comments * addressing PR comments * adding context to registry provider * adding obs own registry * refactoring * refactoring * fixing types * removing apm code Co-authored-by: Elastic Machine --- x-pack/plugins/apm/public/plugin.ts | 7 ++-- .../observability/public/data_handler.ts | 24 +++++++++++ .../public/hooks/use_track_metric.tsx | 3 +- x-pack/plugins/observability/public/index.ts | 6 ++- x-pack/plugins/observability/public/plugin.ts | 16 +++++-- .../public/typings/data_handler/index.d.ts | 42 +++++++++++++++++++ .../plugins/observability/typings/common.ts | 2 + 7 files changed, 89 insertions(+), 11 deletions(-) create mode 100644 x-pack/plugins/observability/public/data_handler.ts create mode 100644 x-pack/plugins/observability/public/typings/data_handler/index.d.ts diff --git a/x-pack/plugins/apm/public/plugin.ts b/x-pack/plugins/apm/public/plugin.ts index 2f46e2090351b..e9de8fcd890d0 100644 --- a/x-pack/plugins/apm/public/plugin.ts +++ b/x-pack/plugins/apm/public/plugin.ts @@ -7,6 +7,7 @@ import { i18n } from '@kbn/i18n'; import { lazy } from 'react'; import { ConfigSchema } from '.'; +import { ObservabilityPluginSetup } from '../../observability/public'; import { AppMountParameters, CoreSetup, @@ -33,10 +34,10 @@ import { import { AlertType } from '../common/alert_types'; import { featureCatalogueEntry } from './featureCatalogueEntry'; import { createCallApmApi } from './services/rest/createCallApmApi'; -import { createStaticIndexPattern } from './services/rest/index_pattern'; import { setHelpExtension } from './setHelpExtension'; import { toggleAppLinkInNav } from './toggleAppLinkInNav'; import { setReadonlyBadge } from './updateBadge'; +import { createStaticIndexPattern } from './services/rest/index_pattern'; export type ApmPluginSetup = void; export type ApmPluginStart = void; @@ -48,6 +49,7 @@ export interface ApmPluginSetupDeps { home: HomePublicPluginSetup; licensing: LicensingPluginSetup; triggers_actions_ui: TriggersAndActionsUIPublicPluginSetup; + observability?: ObservabilityPluginSetup; } export interface ApmPluginStartDeps { @@ -64,6 +66,7 @@ export class ApmPlugin implements Plugin { this.initializerContext = initializerContext; } public setup(core: CoreSetup, plugins: ApmPluginSetupDeps) { + createCallApmApi(core.http); const config = this.initializerContext.config.get(); const pluginSetupDeps = plugins; @@ -100,8 +103,6 @@ export class ApmPlugin implements Plugin { }); } public start(core: CoreStart, plugins: ApmPluginStartDeps) { - createCallApmApi(core.http); - toggleAppLinkInNav(core, this.initializerContext.config.get()); plugins.triggers_actions_ui.alertTypeRegistry.register({ diff --git a/x-pack/plugins/observability/public/data_handler.ts b/x-pack/plugins/observability/public/data_handler.ts new file mode 100644 index 0000000000000..30a7357404d23 --- /dev/null +++ b/x-pack/plugins/observability/public/data_handler.ts @@ -0,0 +1,24 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { FetchData, HasData } from './typings/data_handler'; +import { ObservabilityApp } from '../typings/common'; + +interface DataHandler { + fetchData: FetchData; + hasData: HasData; +} + +const dataHandlers: Partial> = {}; + +export type RegisterDataHandler = (params: { appName: ObservabilityApp } & DataHandler) => void; +export const registerDataHandler: RegisterDataHandler = ({ appName, fetchData, hasData }) => { + dataHandlers[appName] = { fetchData, hasData }; +}; + +export function getDataHandler(appName: ObservabilityApp): DataHandler | undefined { + return dataHandlers[appName]; +} diff --git a/x-pack/plugins/observability/public/hooks/use_track_metric.tsx b/x-pack/plugins/observability/public/hooks/use_track_metric.tsx index b146a80e89ea8..2c7ce8cbabf8e 100644 --- a/x-pack/plugins/observability/public/hooks/use_track_metric.tsx +++ b/x-pack/plugins/observability/public/hooks/use_track_metric.tsx @@ -8,6 +8,7 @@ import { useEffect, useMemo } from 'react'; import { METRIC_TYPE, UiStatsMetricType } from '@kbn/analytics'; import { UsageCollectionSetup } from 'src/plugins/usage_collection/public'; import { useKibana } from '../../../../../src/plugins/kibana_react/public'; +import { ObservabilityApp } from '../../typings/common'; /** * Note: The usage_collection plugin will take care of sending this data to the telemetry server. @@ -17,8 +18,6 @@ import { useKibana } from '../../../../../src/plugins/kibana_react/public'; * a value, which will be a counter */ -type ObservabilityApp = 'infra_metrics' | 'infra_logs' | 'apm' | 'uptime'; - interface TrackOptions { app?: ObservabilityApp; metricType?: UiStatsMetricType; diff --git a/x-pack/plugins/observability/public/index.ts b/x-pack/plugins/observability/public/index.ts index dd8bca90cff4f..ade347c79728d 100644 --- a/x-pack/plugins/observability/public/index.ts +++ b/x-pack/plugins/observability/public/index.ts @@ -5,14 +5,16 @@ */ import { PluginInitializerContext, PluginInitializer } from 'kibana/public'; -import { Plugin, ClientSetup, ClientStart } from './plugin'; +import { Plugin, ObservabilityPluginSetup, ObservabilityPluginStart } from './plugin'; -export const plugin: PluginInitializer = ( +export const plugin: PluginInitializer = ( context: PluginInitializerContext ) => { return new Plugin(context); }; +export { ObservabilityPluginSetup, ObservabilityPluginStart }; + export * from './components/action_menu'; export { diff --git a/x-pack/plugins/observability/public/plugin.ts b/x-pack/plugins/observability/public/plugin.ts index f2c88a7b1c056..16adf88d152c5 100644 --- a/x-pack/plugins/observability/public/plugin.ts +++ b/x-pack/plugins/observability/public/plugin.ts @@ -10,11 +10,15 @@ import { Plugin as PluginClass, PluginInitializerContext, } from '../../../../src/core/public'; +import { RegisterDataHandler, registerDataHandler } from './data_handler'; -export type ClientSetup = void; -export type ClientStart = void; +export interface ObservabilityPluginSetup { + dashboard: { register: RegisterDataHandler }; +} + +export type ObservabilityPluginStart = void; -export class Plugin implements PluginClass { +export class Plugin implements PluginClass { constructor(context: PluginInitializerContext) {} public setup(core: CoreSetup) { @@ -25,7 +29,7 @@ export class Plugin implements PluginClass { appRoute: '/app/observability', category: DEFAULT_APP_CATEGORIES.observability, - async mount(params: AppMountParameters) { + mount: async (params: AppMountParameters) => { // Load application bundle const { renderApp } = await import('./application'); // Get start services @@ -34,6 +38,10 @@ export class Plugin implements PluginClass { return renderApp(coreStart, params); }, }); + + return { + dashboard: { register: registerDataHandler }, + }; } public start() {} } diff --git a/x-pack/plugins/observability/public/typings/data_handler/index.d.ts b/x-pack/plugins/observability/public/typings/data_handler/index.d.ts new file mode 100644 index 0000000000000..a208e4e7c223d --- /dev/null +++ b/x-pack/plugins/observability/public/typings/data_handler/index.d.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; + * you may not use this file except in compliance with the Elastic License. + */ + +interface Stat { + label: string; + value: string; + color?: string; +} + +export interface Coordinates { + x: number; + y?: number; +} + +interface Series { + label: string; + coordinates: Coordinates[]; + color?: string; + key?: string; +} + +interface FetchDataResponse { + title: string; + appLink: string; + stats: Stat[]; + series: Series[]; +} +interface FetchDataParams { + // The start timestamp in milliseconds of the queried time interval + startTime: string; + // The end timestamp in milliseconds of the queried time interval + endTime: string; + // The aggregation bucket size in milliseconds if applicable to the data source + bucketSize: string; +} + +export type FetchData = (fetchDataParams: FetchDataParams) => Promise; + +export type HasData = () => Promise; diff --git a/x-pack/plugins/observability/typings/common.ts b/x-pack/plugins/observability/typings/common.ts index b4a90934a9f49..579c4fe3bbb90 100644 --- a/x-pack/plugins/observability/typings/common.ts +++ b/x-pack/plugins/observability/typings/common.ts @@ -4,6 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ +export type ObservabilityApp = 'infra_metrics' | 'infra_logs' | 'apm' | 'uptime'; + export type PromiseReturnType = Func extends (...args: any[]) => Promise ? Value : Func; From efe6ba49033615e83966ed08d5a7199953d08d42 Mon Sep 17 00:00:00 2001 From: Liza Katz Date: Mon, 15 Jun 2020 11:10:22 +0300 Subject: [PATCH 04/39] [Search][BUG] Call wrong search strategy recursively in async search (#69116) * Call sync search recursively * Fix test * Fix search mock to avoid resetting it * delete empty line * fix tests --- src/plugins/data/public/mocks.ts | 6 +-- .../legacy/default_search_strategy.test.ts | 4 +- src/plugins/data/public/search/mocks.ts | 41 +++++++++++-------- .../public/table_vis_controller.test.ts | 4 +- .../search/async_search_strategy.test.ts | 2 + .../public/search/async_search_strategy.ts | 2 +- 6 files changed, 35 insertions(+), 24 deletions(-) diff --git a/src/plugins/data/public/mocks.ts b/src/plugins/data/public/mocks.ts index d544d3c800bbe..135b6121d1dd5 100644 --- a/src/plugins/data/public/mocks.ts +++ b/src/plugins/data/public/mocks.ts @@ -19,7 +19,7 @@ import { Plugin, IndexPatternsContract } from '.'; import { fieldFormatsServiceMock } from './field_formats/mocks'; -import { searchSetupMock, searchStartMock } from './search/mocks'; +import { searchServiceMock } from './search/mocks'; import { queryServiceMock } from './query/mocks'; import { AutocompleteStart, AutocompleteSetup } from './autocomplete'; @@ -41,7 +41,7 @@ const createSetupContract = (): Setup => { const querySetupMock = queryServiceMock.createSetupContract(); return { autocomplete: automcompleteSetupMock, - search: searchSetupMock, + search: searchServiceMock.createSetupContract(), fieldFormats: fieldFormatsServiceMock.createSetupContract(), query: querySetupMock, }; @@ -55,7 +55,7 @@ const createStartContract = (): Start => { createFiltersFromRangeSelectAction: jest.fn(), }, autocomplete: autocompleteStartMock, - search: searchStartMock, + search: searchServiceMock.createStartContract(), fieldFormats: fieldFormatsServiceMock.createStartContract(), query: queryStartMock, ui: { diff --git a/src/plugins/data/public/search/legacy/default_search_strategy.test.ts b/src/plugins/data/public/search/legacy/default_search_strategy.test.ts index 436b522744622..4148055c1eb58 100644 --- a/src/plugins/data/public/search/legacy/default_search_strategy.test.ts +++ b/src/plugins/data/public/search/legacy/default_search_strategy.test.ts @@ -19,7 +19,7 @@ import { IUiSettingsClient } from 'kibana/public'; import { defaultSearchStrategy } from './default_search_strategy'; -import { searchStartMock } from '../mocks'; +import { searchServiceMock } from '../mocks'; import { SearchStrategySearchParams } from './types'; import { UI_SETTINGS } from '../../../common'; @@ -51,7 +51,7 @@ describe('defaultSearchStrategy', function () { searchMockResponse.abort.mockClear(); searchMock.mockClear(); - const searchService = searchStartMock; + const searchService = searchServiceMock.createStartContract(); searchService.aggs.calculateAutoTimeExpression = jest.fn().mockReturnValue('1d'); searchService.__LEGACY.esClient.search = searchMock; searchService.__LEGACY.esClient.msearch = msearchMock; diff --git a/src/plugins/data/public/search/mocks.ts b/src/plugins/data/public/search/mocks.ts index fcdbeb515423d..45f4416859640 100644 --- a/src/plugins/data/public/search/mocks.ts +++ b/src/plugins/data/public/search/mocks.ts @@ -23,23 +23,32 @@ import { searchSourceMock, createSearchSourceMock } from './search_source/mocks' export * from './search_source/mocks'; -const searchSetupMock: jest.Mocked = { - aggs: searchAggsSetupMock(), - registerSearchStrategy: jest.fn(), -}; +function createSetupContract(): jest.Mocked { + return { + aggs: searchAggsSetupMock(), + registerSearchStrategy: jest.fn(), + }; +} -const searchStartMock: jest.Mocked = { - aggs: searchAggsStartMock(), - setInterceptor: jest.fn(), - getSearchStrategy: jest.fn(), - search: jest.fn(), - searchSource: searchSourceMock, - __LEGACY: { - esClient: { - search: jest.fn(), - msearch: jest.fn(), +function createStartContract(): jest.Mocked { + return { + aggs: searchAggsStartMock(), + setInterceptor: jest.fn(), + getSearchStrategy: jest.fn(), + search: jest.fn(), + searchSource: searchSourceMock, + __LEGACY: { + esClient: { + search: jest.fn(), + msearch: jest.fn(), + }, }, - }, + }; +} + +export const searchServiceMock = { + createSetupContract, + createStartContract, }; -export { searchSetupMock, searchStartMock, createSearchSourceMock }; +export { createSearchSourceMock }; diff --git a/src/plugins/vis_type_table/public/table_vis_controller.test.ts b/src/plugins/vis_type_table/public/table_vis_controller.test.ts index 4607324ca150c..e7d7f6726b0cd 100644 --- a/src/plugins/vis_type_table/public/table_vis_controller.test.ts +++ b/src/plugins/vis_type_table/public/table_vis_controller.test.ts @@ -36,9 +36,9 @@ import { coreMock } from '../../../core/public/mocks'; import { IAggConfig, search } from '../../data/public'; // TODO: remove linting disable // eslint-disable-next-line @kbn/eslint/no-restricted-paths -import { searchStartMock } from '../../data/public/search/mocks'; +import { searchServiceMock } from '../../data/public/search/mocks'; -const { createAggConfigs } = searchStartMock.aggs; +const { createAggConfigs } = searchServiceMock.createStartContract().aggs; const { tabifyAggResponse } = search; diff --git a/x-pack/plugins/data_enhanced/public/search/async_search_strategy.test.ts b/x-pack/plugins/data_enhanced/public/search/async_search_strategy.test.ts index 3013f9966f068..6b8820b92ba84 100644 --- a/x-pack/plugins/data_enhanced/public/search/async_search_strategy.test.ts +++ b/x-pack/plugins/data_enhanced/public/search/async_search_strategy.test.ts @@ -25,6 +25,7 @@ describe('Async search strategy', () => { mockCoreSetup = coreMock.createSetup(); mockDataStart = dataPluginMock.createStartContract(); (mockDataStart.search.getSearchStrategy as jest.Mock).mockReturnValue({ search: mockSearch }); + mockCoreSetup.getStartServices.mockResolvedValue([ undefined as any, { data: mockDataStart }, @@ -92,6 +93,7 @@ describe('Async search strategy', () => { await asyncSearch.search(mockRequest, mockOptions).toPromise(); + expect(mockDataStart.search.getSearchStrategy).toBeCalledTimes(1); expect(mockSearch).toBeCalledTimes(2); expect(mockSearch.mock.calls[0][0]).toEqual(mockRequest); expect(mockSearch.mock.calls[1][0]).toEqual({ id: 1, serverStrategy: 'foo' }); diff --git a/x-pack/plugins/data_enhanced/public/search/async_search_strategy.ts b/x-pack/plugins/data_enhanced/public/search/async_search_strategy.ts index 7de4dd28ad3d7..49b27bba33a60 100644 --- a/x-pack/plugins/data_enhanced/public/search/async_search_strategy.ts +++ b/x-pack/plugins/data_enhanced/public/search/async_search_strategy.ts @@ -70,7 +70,7 @@ export function asyncSearchStrategyProvider( return timer(pollInterval).pipe( // Send future requests using just the ID from the response mergeMap(() => { - return search({ id, serverStrategy }, options); + return syncSearch.search({ id, serverStrategy }, options); }) ); }), From 0c34bd7e67454b4fa577da63f87b456b1188470d Mon Sep 17 00:00:00 2001 From: Aleh Zasypkin Date: Mon, 15 Jun 2020 11:38:04 +0200 Subject: [PATCH 05/39] Re-enable mistakenly skipped tests. (#69123) --- .../kerberos_api_integration/apis/security/kerberos_login.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/x-pack/test/kerberos_api_integration/apis/security/kerberos_login.ts b/x-pack/test/kerberos_api_integration/apis/security/kerberos_login.ts index 35021328cdb4a..8d2e575fad313 100644 --- a/x-pack/test/kerberos_api_integration/apis/security/kerberos_login.ts +++ b/x-pack/test/kerberos_api_integration/apis/security/kerberos_login.ts @@ -37,8 +37,7 @@ export default function ({ getService }: FtrProviderContext) { expect(cookie.maxAge).to.be(0); } - // FLAKY: https://github.com/elastic/kibana/issues/68836 - describe.skip('Kerberos authentication', () => { + describe('Kerberos authentication', () => { before(async () => { await getService('esSupertest') .post('/_security/role_mapping/krb5') From 533046fd9ce73cddd1677a5179d1b325b9e15a09 Mon Sep 17 00:00:00 2001 From: Alison Goryachev Date: Mon, 15 Jun 2020 08:48:10 -0400 Subject: [PATCH 06/39] [ES UI] Error handling (#68809) --- .../errors/index.ts | 20 +++++++++++ .../errors/is_es_error.ts | 33 +++++++++++++++++++ src/plugins/es_ui_shared/kibana.json | 3 +- .../es_ui_shared/server/errors/index.ts | 20 +++++++++++ src/plugins/es_ui_shared/server/index.ts | 28 ++++++++++++++++ .../server/lib/is_es_error.ts | 13 -------- .../server/plugin.ts | 2 +- .../register_create_route.test.ts | 2 +- .../register_delete_route.test.ts | 2 +- .../register_fetch_route.test.ts | 2 +- .../register_get_route.test.ts | 2 +- .../register_pause_route.test.ts | 2 +- .../register_resume_route.test.ts | 2 +- .../register_update_route.test.ts | 2 +- .../register_create_route.test.ts | 2 +- .../register_fetch_route.test.ts | 2 +- .../follower_index/register_get_route.test.ts | 2 +- .../register_pause_route.test.ts | 2 +- .../register_resume_route.test.ts | 2 +- .../register_unfollow_route.test.ts | 2 +- .../server/shared_imports.ts} | 2 +- .../cross_cluster_replication/server/types.ts | 2 +- .../server/lib/is_es_error.ts | 13 -------- .../server/plugin.ts | 2 +- .../server/shared_imports.ts} | 2 +- .../server/types.ts | 2 +- .../server/lib/is_es_error.ts | 13 -------- .../plugins/index_management/server/plugin.ts | 2 +- .../server/shared_imports.ts} | 2 +- .../plugins/index_management/server/types.ts | 2 +- .../server/lib/is_es_error.ts | 13 -------- .../plugins/ingest_pipelines/server/plugin.ts | 2 +- .../{lib/index.ts => shared_imports.ts} | 2 +- .../plugins/ingest_pipelines/server/types.ts | 2 +- .../server/lib/is_es_error.ts | 13 -------- .../license_management/server/plugin.ts | 2 +- .../server/shared_imports.ts | 7 ++++ .../license_management/server/types.ts | 2 +- .../painless_lab/server/lib/is_es_error.ts | 13 -------- .../painless_lab/server/routes/api/execute.ts | 2 +- .../painless_lab/server/shared_imports.ts | 7 ++++ .../server/lib/is_es_error/is_es_error.ts | 13 -------- .../server/routes/api/add_route.ts | 2 +- .../server/routes/api/delete_route.ts | 2 +- .../server/routes/api/get_route.ts | 2 +- .../server/routes/api/update_route.ts | 2 +- .../remote_clusters/server/shared_imports.ts | 7 ++++ .../plugins/rollup/server/lib/is_es_error.ts | 13 -------- x-pack/plugins/rollup/server/plugin.ts | 2 +- .../plugins/rollup/server/shared_imports.ts | 2 ++ x-pack/plugins/rollup/server/types.ts | 2 +- .../snapshot_restore/server/lib/index.ts | 1 - .../server/lib/is_es_error.ts | 13 -------- .../plugins/snapshot_restore/server/plugin.ts | 3 +- .../snapshot_restore/server/shared_imports.ts | 7 ++++ .../server/test/helpers/route_dependencies.ts | 3 +- .../plugins/snapshot_restore/server/types.ts | 3 +- .../server/lib/is_es_error/is_es_error.ts | 13 -------- .../routes/api/indices/register_get_route.ts | 2 +- .../routes/api/register_list_fields_route.ts | 2 +- .../routes/api/register_load_history_route.ts | 2 +- .../api/settings/register_load_route.ts | 2 +- .../action/register_acknowledge_route.ts | 2 +- .../api/watch/register_activate_route.ts | 2 +- .../api/watch/register_deactivate_route.ts | 2 +- .../routes/api/watch/register_delete_route.ts | 2 +- .../api/watch/register_execute_route.ts | 2 +- .../api/watch/register_history_route.ts | 2 +- .../routes/api/watch/register_load_route.ts | 2 +- .../routes/api/watch/register_save_route.ts | 2 +- .../api/watch/register_visualize_route.ts | 2 +- .../routes/api/watches/register_list_route.ts | 2 +- .../plugins/watcher/server/shared_imports.ts | 7 ++++ 73 files changed, 194 insertions(+), 183 deletions(-) create mode 100644 src/plugins/es_ui_shared/__packages_do_not_import__/errors/index.ts create mode 100644 src/plugins/es_ui_shared/__packages_do_not_import__/errors/is_es_error.ts create mode 100644 src/plugins/es_ui_shared/server/errors/index.ts create mode 100644 src/plugins/es_ui_shared/server/index.ts delete mode 100644 x-pack/plugins/cross_cluster_replication/server/lib/is_es_error.ts rename x-pack/plugins/{painless_lab/server/lib/index.ts => cross_cluster_replication/server/shared_imports.ts} (76%) delete mode 100644 x-pack/plugins/index_lifecycle_management/server/lib/is_es_error.ts rename x-pack/plugins/{remote_clusters/server/lib/is_es_error/index.ts => index_lifecycle_management/server/shared_imports.ts} (76%) delete mode 100644 x-pack/plugins/index_management/server/lib/is_es_error.ts rename x-pack/plugins/{watcher/server/lib/is_es_error/index.ts => index_management/server/shared_imports.ts} (76%) delete mode 100644 x-pack/plugins/ingest_pipelines/server/lib/is_es_error.ts rename x-pack/plugins/ingest_pipelines/server/{lib/index.ts => shared_imports.ts} (76%) delete mode 100644 x-pack/plugins/license_management/server/lib/is_es_error.ts create mode 100644 x-pack/plugins/license_management/server/shared_imports.ts delete mode 100644 x-pack/plugins/painless_lab/server/lib/is_es_error.ts create mode 100644 x-pack/plugins/painless_lab/server/shared_imports.ts delete mode 100644 x-pack/plugins/remote_clusters/server/lib/is_es_error/is_es_error.ts create mode 100644 x-pack/plugins/remote_clusters/server/shared_imports.ts delete mode 100644 x-pack/plugins/rollup/server/lib/is_es_error.ts delete mode 100644 x-pack/plugins/snapshot_restore/server/lib/is_es_error.ts create mode 100644 x-pack/plugins/snapshot_restore/server/shared_imports.ts delete mode 100644 x-pack/plugins/watcher/server/lib/is_es_error/is_es_error.ts create mode 100644 x-pack/plugins/watcher/server/shared_imports.ts diff --git a/src/plugins/es_ui_shared/__packages_do_not_import__/errors/index.ts b/src/plugins/es_ui_shared/__packages_do_not_import__/errors/index.ts new file mode 100644 index 0000000000000..0d025442f4a92 --- /dev/null +++ b/src/plugins/es_ui_shared/__packages_do_not_import__/errors/index.ts @@ -0,0 +1,20 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +export { isEsError } from './is_es_error'; diff --git a/src/plugins/es_ui_shared/__packages_do_not_import__/errors/is_es_error.ts b/src/plugins/es_ui_shared/__packages_do_not_import__/errors/is_es_error.ts new file mode 100644 index 0000000000000..1e212307ca1cc --- /dev/null +++ b/src/plugins/es_ui_shared/__packages_do_not_import__/errors/is_es_error.ts @@ -0,0 +1,33 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import * as legacyElasticsearch from 'elasticsearch'; + +const esErrorsParent = legacyElasticsearch.errors._Abstract; + +interface RequestError extends Error { + statusCode?: number; +} + +export function isEsError(err: RequestError) { + const isInstanceOfEsError = err instanceof esErrorsParent; + const hasStatusCode = Boolean(err.statusCode); + + return isInstanceOfEsError && hasStatusCode; +} diff --git a/src/plugins/es_ui_shared/kibana.json b/src/plugins/es_ui_shared/kibana.json index 5a3db3b344090..5f772b3c83da9 100644 --- a/src/plugins/es_ui_shared/kibana.json +++ b/src/plugins/es_ui_shared/kibana.json @@ -1,5 +1,6 @@ { "id": "esUiShared", "version": "kibana", - "ui": true + "ui": true, + "server": true } diff --git a/src/plugins/es_ui_shared/server/errors/index.ts b/src/plugins/es_ui_shared/server/errors/index.ts new file mode 100644 index 0000000000000..c18374cd9ec31 --- /dev/null +++ b/src/plugins/es_ui_shared/server/errors/index.ts @@ -0,0 +1,20 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +export { isEsError } from '../../__packages_do_not_import__/errors'; diff --git a/src/plugins/es_ui_shared/server/index.ts b/src/plugins/es_ui_shared/server/index.ts new file mode 100644 index 0000000000000..0118bbda53262 --- /dev/null +++ b/src/plugins/es_ui_shared/server/index.ts @@ -0,0 +1,28 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +export { isEsError } from './errors'; + +/** dummy plugin*/ +export function plugin() { + return new (class EsUiSharedPlugin { + setup() {} + start() {} + })(); +} diff --git a/x-pack/plugins/cross_cluster_replication/server/lib/is_es_error.ts b/x-pack/plugins/cross_cluster_replication/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/cross_cluster_replication/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/cross_cluster_replication/server/plugin.ts b/x-pack/plugins/cross_cluster_replication/server/plugin.ts index f30378d874a9a..d9fe296553f38 100644 --- a/x-pack/plugins/cross_cluster_replication/server/plugin.ts +++ b/x-pack/plugins/cross_cluster_replication/server/plugin.ts @@ -30,7 +30,7 @@ import { registerApiRoutes } from './routes'; import { License } from './services'; import { elasticsearchJsPlugin } from './client/elasticsearch_ccr'; import { CrossClusterReplicationConfig } from './config'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; import { formatEsError } from './lib/format_es_error'; interface CrossClusterReplicationContext { diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_create_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_create_route.test.ts index b41b52e1764c8..0b5f04556596a 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_create_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_create_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_delete_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_delete_route.test.ts index e610d09b44275..7468c643a3aa6 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_delete_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_delete_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_fetch_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_fetch_route.test.ts index dd102c45665cb..1aa7112c75276 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_fetch_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_fetch_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_get_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_get_route.test.ts index d5889074651f5..980128027c2f9 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_get_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_get_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_pause_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_pause_route.test.ts index 1eaac02918b88..5b27c77ca86de 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_pause_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_pause_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_resume_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_resume_route.test.ts index 9839761e701fc..afea0f631fe48 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_resume_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_resume_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_update_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_update_route.test.ts index 85f2270ec3aee..bdce84f6404b1 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_update_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/auto_follow_pattern/register_update_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_create_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_create_route.test.ts index bba82b04ce9a0..ccf7c469fe780 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_create_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_create_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_fetch_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_fetch_route.test.ts index 151ab84fabf4c..e1ec28a7c90b1 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_fetch_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_fetch_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_get_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_get_route.test.ts index 42d04ca65b1cb..99c871d5d4f2d 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_get_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_get_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_pause_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_pause_route.test.ts index 82cb88cbacea7..3d28d36ac6182 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_pause_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_pause_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_resume_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_resume_route.test.ts index 04167c5db3162..09975b262dca8 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_resume_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_resume_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_unfollow_route.test.ts b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_unfollow_route.test.ts index 6302d5868b0db..5f0d148bfcae9 100644 --- a/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_unfollow_route.test.ts +++ b/x-pack/plugins/cross_cluster_replication/server/routes/api/follower_index/register_unfollow_route.test.ts @@ -7,7 +7,7 @@ import { httpServiceMock, httpServerMock } from 'src/core/server/mocks'; import { IRouter, kibanaResponseFactory, RequestHandler } from 'src/core/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { formatEsError } from '../../../lib/format_es_error'; import { License } from '../../../services'; import { mockRouteContext } from '../test_lib'; diff --git a/x-pack/plugins/painless_lab/server/lib/index.ts b/x-pack/plugins/cross_cluster_replication/server/shared_imports.ts similarity index 76% rename from x-pack/plugins/painless_lab/server/lib/index.ts rename to x-pack/plugins/cross_cluster_replication/server/shared_imports.ts index a9a3c61472d8c..454beda5394c7 100644 --- a/x-pack/plugins/painless_lab/server/lib/index.ts +++ b/x-pack/plugins/cross_cluster_replication/server/shared_imports.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { isEsError } from './is_es_error'; +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/cross_cluster_replication/server/types.ts b/x-pack/plugins/cross_cluster_replication/server/types.ts index 049d440e3d85d..c287acf86eb2b 100644 --- a/x-pack/plugins/cross_cluster_replication/server/types.ts +++ b/x-pack/plugins/cross_cluster_replication/server/types.ts @@ -9,7 +9,7 @@ import { LicensingPluginSetup } from '../../licensing/server'; import { IndexManagementPluginSetup } from '../../index_management/server'; import { RemoteClustersPluginSetup } from '../../remote_clusters/server'; import { License } from './services'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; import { formatEsError } from './lib/format_es_error'; export interface Dependencies { diff --git a/x-pack/plugins/index_lifecycle_management/server/lib/is_es_error.ts b/x-pack/plugins/index_lifecycle_management/server/lib/is_es_error.ts deleted file mode 100644 index 2f514b93e5016..0000000000000 --- a/x-pack/plugins/index_lifecycle_management/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error): boolean { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/index_lifecycle_management/server/plugin.ts b/x-pack/plugins/index_lifecycle_management/server/plugin.ts index faeac67f62a21..79a9849e634b5 100644 --- a/x-pack/plugins/index_lifecycle_management/server/plugin.ts +++ b/x-pack/plugins/index_lifecycle_management/server/plugin.ts @@ -14,7 +14,7 @@ import { Dependencies } from './types'; import { registerApiRoutes } from './routes'; import { License } from './services'; import { IndexLifecycleManagementConfig } from './config'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; const indexLifecycleDataEnricher = async (indicesList: any, callAsCurrentUser: APICaller) => { if (!indicesList || !indicesList.length) { diff --git a/x-pack/plugins/remote_clusters/server/lib/is_es_error/index.ts b/x-pack/plugins/index_lifecycle_management/server/shared_imports.ts similarity index 76% rename from x-pack/plugins/remote_clusters/server/lib/is_es_error/index.ts rename to x-pack/plugins/index_lifecycle_management/server/shared_imports.ts index a9a3c61472d8c..454beda5394c7 100644 --- a/x-pack/plugins/remote_clusters/server/lib/is_es_error/index.ts +++ b/x-pack/plugins/index_lifecycle_management/server/shared_imports.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { isEsError } from './is_es_error'; +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/index_lifecycle_management/server/types.ts b/x-pack/plugins/index_lifecycle_management/server/types.ts index 734d05a82000e..8ea0956be0865 100644 --- a/x-pack/plugins/index_lifecycle_management/server/types.ts +++ b/x-pack/plugins/index_lifecycle_management/server/types.ts @@ -10,7 +10,7 @@ import { LicensingPluginSetup } from '../../licensing/server'; import { IndexManagementPluginSetup } from '../../index_management/server'; import { License } from './services'; import { IndexLifecycleManagementConfig } from './config'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; export interface Dependencies { licensing: LicensingPluginSetup; diff --git a/x-pack/plugins/index_management/server/lib/is_es_error.ts b/x-pack/plugins/index_management/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/index_management/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/index_management/server/plugin.ts b/x-pack/plugins/index_management/server/plugin.ts index c1b9945c2cd1d..94af8415bfd55 100644 --- a/x-pack/plugins/index_management/server/plugin.ts +++ b/x-pack/plugins/index_management/server/plugin.ts @@ -24,7 +24,7 @@ import { PLUGIN } from '../common'; import { Dependencies } from './types'; import { ApiRoutes } from './routes'; import { License, IndexDataEnricher } from './services'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; import { elasticsearchJsPlugin } from './client/elasticsearch'; export interface DataManagementContext { diff --git a/x-pack/plugins/watcher/server/lib/is_es_error/index.ts b/x-pack/plugins/index_management/server/shared_imports.ts similarity index 76% rename from x-pack/plugins/watcher/server/lib/is_es_error/index.ts rename to x-pack/plugins/index_management/server/shared_imports.ts index a9a3c61472d8c..454beda5394c7 100644 --- a/x-pack/plugins/watcher/server/lib/is_es_error/index.ts +++ b/x-pack/plugins/index_management/server/shared_imports.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { isEsError } from './is_es_error'; +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/index_management/server/types.ts b/x-pack/plugins/index_management/server/types.ts index 1482d9225c7b5..dc151f510a043 100644 --- a/x-pack/plugins/index_management/server/types.ts +++ b/x-pack/plugins/index_management/server/types.ts @@ -7,7 +7,7 @@ import { ScopedClusterClient, IRouter } from 'src/core/server'; import { LicensingPluginSetup } from '../../licensing/server'; import { SecurityPluginSetup } from '../../security/server'; import { License, IndexDataEnricher } from './services'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; export interface Dependencies { security: SecurityPluginSetup; diff --git a/x-pack/plugins/ingest_pipelines/server/lib/is_es_error.ts b/x-pack/plugins/ingest_pipelines/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/ingest_pipelines/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/ingest_pipelines/server/plugin.ts b/x-pack/plugins/ingest_pipelines/server/plugin.ts index 8cec03c49d439..7a78bf608b8e1 100644 --- a/x-pack/plugins/ingest_pipelines/server/plugin.ts +++ b/x-pack/plugins/ingest_pipelines/server/plugin.ts @@ -11,7 +11,7 @@ import { PLUGIN_ID, PLUGIN_MIN_LICENSE_TYPE } from '../common/constants'; import { License } from './services'; import { ApiRoutes } from './routes'; -import { isEsError } from './lib'; +import { isEsError } from './shared_imports'; import { Dependencies } from './types'; export class IngestPipelinesPlugin implements Plugin { diff --git a/x-pack/plugins/ingest_pipelines/server/lib/index.ts b/x-pack/plugins/ingest_pipelines/server/shared_imports.ts similarity index 76% rename from x-pack/plugins/ingest_pipelines/server/lib/index.ts rename to x-pack/plugins/ingest_pipelines/server/shared_imports.ts index a9a3c61472d8c..454beda5394c7 100644 --- a/x-pack/plugins/ingest_pipelines/server/lib/index.ts +++ b/x-pack/plugins/ingest_pipelines/server/shared_imports.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { isEsError } from './is_es_error'; +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/ingest_pipelines/server/types.ts b/x-pack/plugins/ingest_pipelines/server/types.ts index 70094859dff3f..261317daa26d9 100644 --- a/x-pack/plugins/ingest_pipelines/server/types.ts +++ b/x-pack/plugins/ingest_pipelines/server/types.ts @@ -8,7 +8,7 @@ import { IRouter } from 'src/core/server'; import { LicensingPluginSetup } from '../../licensing/server'; import { SecurityPluginSetup } from '../../security/server'; import { License } from './services'; -import { isEsError } from './lib'; +import { isEsError } from './shared_imports'; export interface Dependencies { security: SecurityPluginSetup; diff --git a/x-pack/plugins/license_management/server/lib/is_es_error.ts b/x-pack/plugins/license_management/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/license_management/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/license_management/server/plugin.ts b/x-pack/plugins/license_management/server/plugin.ts index 9546f5b1ef88a..7b1887e438024 100644 --- a/x-pack/plugins/license_management/server/plugin.ts +++ b/x-pack/plugins/license_management/server/plugin.ts @@ -7,7 +7,7 @@ import { Plugin, CoreSetup } from 'kibana/server'; import { ApiRoutes } from './routes'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; import { Dependencies } from './types'; export class LicenseManagementServerPlugin implements Plugin { diff --git a/x-pack/plugins/license_management/server/shared_imports.ts b/x-pack/plugins/license_management/server/shared_imports.ts new file mode 100644 index 0000000000000..454beda5394c7 --- /dev/null +++ b/x-pack/plugins/license_management/server/shared_imports.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/license_management/server/types.ts b/x-pack/plugins/license_management/server/types.ts index 37f4781ba1e02..11b1ed696874b 100644 --- a/x-pack/plugins/license_management/server/types.ts +++ b/x-pack/plugins/license_management/server/types.ts @@ -7,7 +7,7 @@ import { ScopedClusterClient, IRouter } from 'kibana/server'; import { LicensingPluginSetup } from '../../licensing/server'; import { SecurityPluginSetup } from '../../security/server'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; export interface Dependencies { licensing: LicensingPluginSetup; diff --git a/x-pack/plugins/painless_lab/server/lib/is_es_error.ts b/x-pack/plugins/painless_lab/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/painless_lab/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/painless_lab/server/routes/api/execute.ts b/x-pack/plugins/painless_lab/server/routes/api/execute.ts index 7d415761f04cb..7bb2d9f93c6fc 100644 --- a/x-pack/plugins/painless_lab/server/routes/api/execute.ts +++ b/x-pack/plugins/painless_lab/server/routes/api/execute.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { API_BASE_PATH } from '../../../common/constants'; import { RouteDependencies } from '../../types'; -import { isEsError } from '../../lib'; +import { isEsError } from '../../shared_imports'; const bodySchema = schema.string(); diff --git a/x-pack/plugins/painless_lab/server/shared_imports.ts b/x-pack/plugins/painless_lab/server/shared_imports.ts new file mode 100644 index 0000000000000..454beda5394c7 --- /dev/null +++ b/x-pack/plugins/painless_lab/server/shared_imports.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/remote_clusters/server/lib/is_es_error/is_es_error.ts b/x-pack/plugins/remote_clusters/server/lib/is_es_error/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/remote_clusters/server/lib/is_es_error/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/remote_clusters/server/routes/api/add_route.ts b/x-pack/plugins/remote_clusters/server/routes/api/add_route.ts index 38f11db18a088..c28d9f323cb57 100644 --- a/x-pack/plugins/remote_clusters/server/routes/api/add_route.ts +++ b/x-pack/plugins/remote_clusters/server/routes/api/add_route.ts @@ -13,7 +13,7 @@ import { serializeCluster, Cluster } from '../../../common/lib'; import { doesClusterExist } from '../../lib/does_cluster_exist'; import { API_BASE_PATH, PROXY_MODE, SNIFF_MODE } from '../../../common/constants'; import { licensePreRoutingFactory } from '../../lib/license_pre_routing_factory'; -import { isEsError } from '../../lib/is_es_error'; +import { isEsError } from '../../shared_imports'; import { RouteDependencies } from '../../types'; const bodyValidation = schema.object({ diff --git a/x-pack/plugins/remote_clusters/server/routes/api/delete_route.ts b/x-pack/plugins/remote_clusters/server/routes/api/delete_route.ts index 69760b7477e1b..030e7587f870d 100644 --- a/x-pack/plugins/remote_clusters/server/routes/api/delete_route.ts +++ b/x-pack/plugins/remote_clusters/server/routes/api/delete_route.ts @@ -14,7 +14,7 @@ import { serializeCluster } from '../../../common/lib'; import { API_BASE_PATH } from '../../../common/constants'; import { doesClusterExist } from '../../lib/does_cluster_exist'; import { licensePreRoutingFactory } from '../../lib/license_pre_routing_factory'; -import { isEsError } from '../../lib/is_es_error'; +import { isEsError } from '../../shared_imports'; const paramsValidation = schema.object({ nameOrNames: schema.string(), diff --git a/x-pack/plugins/remote_clusters/server/routes/api/get_route.ts b/x-pack/plugins/remote_clusters/server/routes/api/get_route.ts index 4e3fa34ac94c3..3ebb136356645 100644 --- a/x-pack/plugins/remote_clusters/server/routes/api/get_route.ts +++ b/x-pack/plugins/remote_clusters/server/routes/api/get_route.ts @@ -10,7 +10,7 @@ import { RequestHandler } from 'src/core/server'; import { deserializeCluster } from '../../../common/lib'; import { API_BASE_PATH } from '../../../common/constants'; import { licensePreRoutingFactory } from '../../lib/license_pre_routing_factory'; -import { isEsError } from '../../lib/is_es_error'; +import { isEsError } from '../../shared_imports'; import { RouteDependencies } from '../../types'; export const register = (deps: RouteDependencies): void => { diff --git a/x-pack/plugins/remote_clusters/server/routes/api/update_route.ts b/x-pack/plugins/remote_clusters/server/routes/api/update_route.ts index 0666a295de456..60671b4a80075 100644 --- a/x-pack/plugins/remote_clusters/server/routes/api/update_route.ts +++ b/x-pack/plugins/remote_clusters/server/routes/api/update_route.ts @@ -14,7 +14,7 @@ import { serializeCluster, deserializeCluster, Cluster, ClusterInfoEs } from '.. import { doesClusterExist } from '../../lib/does_cluster_exist'; import { RouteDependencies } from '../../types'; import { licensePreRoutingFactory } from '../../lib/license_pre_routing_factory'; -import { isEsError } from '../../lib/is_es_error'; +import { isEsError } from '../../shared_imports'; const bodyValidation = schema.object({ skipUnavailable: schema.boolean(), diff --git a/x-pack/plugins/remote_clusters/server/shared_imports.ts b/x-pack/plugins/remote_clusters/server/shared_imports.ts new file mode 100644 index 0000000000000..454beda5394c7 --- /dev/null +++ b/x-pack/plugins/remote_clusters/server/shared_imports.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/rollup/server/lib/is_es_error.ts b/x-pack/plugins/rollup/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/rollup/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/rollup/server/plugin.ts b/x-pack/plugins/rollup/server/plugin.ts index f5ddab70342de..0d795ab7dbfe1 100644 --- a/x-pack/plugins/rollup/server/plugin.ts +++ b/x-pack/plugins/rollup/server/plugin.ts @@ -35,7 +35,7 @@ import { rollupDataEnricher } from './rollup_data_enricher'; import { IndexPatternsFetcher } from './shared_imports'; import { registerRollupSearchStrategy } from './lib/search_strategies'; import { elasticsearchJsPlugin } from './client/elasticsearch_rollup'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; import { formatEsError } from './lib/format_es_error'; import { getCapabilitiesForRollupIndices } from './lib/map_capabilities'; import { mergeCapabilitiesWithFields } from './lib/merge_capabilities_with_fields'; diff --git a/x-pack/plugins/rollup/server/shared_imports.ts b/x-pack/plugins/rollup/server/shared_imports.ts index 09842f529abed..1e39a32318678 100644 --- a/x-pack/plugins/rollup/server/shared_imports.ts +++ b/x-pack/plugins/rollup/server/shared_imports.ts @@ -5,3 +5,5 @@ */ export { IndexPatternsFetcher } from '../../../../src/plugins/data/server'; + +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/rollup/server/types.ts b/x-pack/plugins/rollup/server/types.ts index c21d76400164e..6659ac2b02357 100644 --- a/x-pack/plugins/rollup/server/types.ts +++ b/x-pack/plugins/rollup/server/types.ts @@ -12,7 +12,7 @@ import { IndexManagementPluginSetup } from '../../index_management/server'; import { LicensingPluginSetup } from '../../licensing/server'; import { License } from './services'; import { IndexPatternsFetcher } from './shared_imports'; -import { isEsError } from './lib/is_es_error'; +import { isEsError } from './shared_imports'; import { formatEsError } from './lib/format_es_error'; import { getCapabilitiesForRollupIndices } from './lib/map_capabilities'; import { mergeCapabilitiesWithFields } from './lib/merge_capabilities_with_fields'; diff --git a/x-pack/plugins/snapshot_restore/server/lib/index.ts b/x-pack/plugins/snapshot_restore/server/lib/index.ts index 801f105fc5c07..4bec874b3abc7 100644 --- a/x-pack/plugins/snapshot_restore/server/lib/index.ts +++ b/x-pack/plugins/snapshot_restore/server/lib/index.ts @@ -12,5 +12,4 @@ export { cleanSettings } from './clean_settings'; export { getManagedRepositoryName } from './get_managed_repository_name'; export { getManagedPolicyNames } from './get_managed_policy_names'; export { deserializeRestoreShard } from './restore_serialization'; -export { isEsError } from './is_es_error'; export { wrapEsError } from './wrap_es_error'; diff --git a/x-pack/plugins/snapshot_restore/server/lib/is_es_error.ts b/x-pack/plugins/snapshot_restore/server/lib/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/snapshot_restore/server/lib/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/snapshot_restore/server/plugin.ts b/x-pack/plugins/snapshot_restore/server/plugin.ts index 1d28442332c55..10d259e28ee43 100644 --- a/x-pack/plugins/snapshot_restore/server/plugin.ts +++ b/x-pack/plugins/snapshot_restore/server/plugin.ts @@ -23,7 +23,8 @@ import { import { PLUGIN } from '../common'; import { License } from './services'; import { ApiRoutes } from './routes'; -import { isEsError, wrapEsError } from './lib'; +import { wrapEsError } from './lib'; +import { isEsError } from './shared_imports'; import { elasticsearchJsPlugin } from './client/elasticsearch_sr'; import { Dependencies } from './types'; import { SnapshotRestoreConfig } from './config'; diff --git a/x-pack/plugins/snapshot_restore/server/shared_imports.ts b/x-pack/plugins/snapshot_restore/server/shared_imports.ts new file mode 100644 index 0000000000000..454beda5394c7 --- /dev/null +++ b/x-pack/plugins/snapshot_restore/server/shared_imports.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; diff --git a/x-pack/plugins/snapshot_restore/server/test/helpers/route_dependencies.ts b/x-pack/plugins/snapshot_restore/server/test/helpers/route_dependencies.ts index a4c7ecac953d8..02ee022892260 100644 --- a/x-pack/plugins/snapshot_restore/server/test/helpers/route_dependencies.ts +++ b/x-pack/plugins/snapshot_restore/server/test/helpers/route_dependencies.ts @@ -4,7 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ import { License } from '../../services'; -import { isEsError, wrapEsError } from '../../lib'; +import { wrapEsError } from '../../lib'; +import { isEsError } from '../../shared_imports'; const license = new License(); license.getStatus = jest.fn().mockReturnValue({ isValid: true }); diff --git a/x-pack/plugins/snapshot_restore/server/types.ts b/x-pack/plugins/snapshot_restore/server/types.ts index 71d8dda7bc50d..9710f812abf23 100644 --- a/x-pack/plugins/snapshot_restore/server/types.ts +++ b/x-pack/plugins/snapshot_restore/server/types.ts @@ -8,7 +8,8 @@ import { LicensingPluginSetup } from '../../licensing/server'; import { SecurityPluginSetup } from '../../security/server'; import { CloudSetup } from '../../cloud/server'; import { License } from './services'; -import { isEsError, wrapEsError } from './lib'; +import { wrapEsError } from './lib'; +import { isEsError } from './shared_imports'; export interface Dependencies { licensing: LicensingPluginSetup; diff --git a/x-pack/plugins/watcher/server/lib/is_es_error/is_es_error.ts b/x-pack/plugins/watcher/server/lib/is_es_error/is_es_error.ts deleted file mode 100644 index 4137293cf39c0..0000000000000 --- a/x-pack/plugins/watcher/server/lib/is_es_error/is_es_error.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one - * or more contributor license agreements. Licensed under the Elastic License; - * you may not use this file except in compliance with the Elastic License. - */ - -import * as legacyElasticsearch from 'elasticsearch'; - -const esErrorsParent = legacyElasticsearch.errors._Abstract; - -export function isEsError(err: Error) { - return err instanceof esErrorsParent; -} diff --git a/x-pack/plugins/watcher/server/routes/api/indices/register_get_route.ts b/x-pack/plugins/watcher/server/routes/api/indices/register_get_route.ts index a1184cbebd139..6d5b359b53d39 100644 --- a/x-pack/plugins/watcher/server/routes/api/indices/register_get_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/indices/register_get_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; import { reduce, size } from 'lodash'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; diff --git a/x-pack/plugins/watcher/server/routes/api/register_list_fields_route.ts b/x-pack/plugins/watcher/server/routes/api/register_list_fields_route.ts index d72e5ad2f817d..e3c82ef3965f4 100644 --- a/x-pack/plugins/watcher/server/routes/api/register_list_fields_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/register_list_fields_route.ts @@ -6,7 +6,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; -import { isEsError } from '../../lib/is_es_error'; +import { isEsError } from '../../shared_imports'; // @ts-ignore import { Fields } from '../../models/fields/index'; import { licensePreRoutingFactory } from '../../lib/license_pre_routing_factory'; diff --git a/x-pack/plugins/watcher/server/routes/api/register_load_history_route.ts b/x-pack/plugins/watcher/server/routes/api/register_load_history_route.ts index 8c9068123ce8d..c61953db555d3 100644 --- a/x-pack/plugins/watcher/server/routes/api/register_load_history_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/register_load_history_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { get } from 'lodash'; import { IScopedClusterClient } from 'kibana/server'; -import { isEsError } from '../../lib/is_es_error'; +import { isEsError } from '../../shared_imports'; import { INDEX_NAMES } from '../../../common/constants'; import { RouteDependencies } from '../../types'; import { licensePreRoutingFactory } from '../../lib/license_pre_routing_factory'; diff --git a/x-pack/plugins/watcher/server/routes/api/settings/register_load_route.ts b/x-pack/plugins/watcher/server/routes/api/settings/register_load_route.ts index fe9dd32735692..9f501b56d4703 100644 --- a/x-pack/plugins/watcher/server/routes/api/settings/register_load_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/settings/register_load_route.ts @@ -5,7 +5,7 @@ */ import { IScopedClusterClient } from 'kibana/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; // @ts-ignore import { Settings } from '../../../models/settings/index'; import { RouteDependencies } from '../../../types'; diff --git a/x-pack/plugins/watcher/server/routes/api/watch/action/register_acknowledge_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/action/register_acknowledge_route.ts index 9e024a63b82c5..923714739065e 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/action/register_acknowledge_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/action/register_acknowledge_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { get } from 'lodash'; import { IScopedClusterClient } from 'kibana/server'; -import { isEsError } from '../../../../lib/is_es_error'; +import { isEsError } from '../../../../shared_imports'; // @ts-ignore import { WatchStatus } from '../../../../models/watch_status/index'; import { RouteDependencies } from '../../../../types'; diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_activate_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_activate_route.ts index 1afeeb4e80efb..e7e3f5e3d9ba3 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_activate_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_activate_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; import { get } from 'lodash'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; // @ts-ignore diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_deactivate_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_deactivate_route.ts index 3171d8ee2e1e5..de4b1dbb4b44d 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_deactivate_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_deactivate_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; import { get } from 'lodash'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; // @ts-ignore diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_delete_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_delete_route.ts index bfdf328550bbe..9f43d311a182f 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_delete_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_delete_route.ts @@ -6,7 +6,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_execute_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_execute_route.ts index 14a14a6f64d7b..9f27f3ca35bf6 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_execute_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_execute_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; import { get } from 'lodash'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; import { RouteDependencies } from '../../../types'; diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_history_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_history_route.ts index b64c28e114b72..faa860b3ce6dd 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_history_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_history_route.ts @@ -9,7 +9,7 @@ import { IScopedClusterClient } from 'kibana/server'; import { get } from 'lodash'; import { fetchAllFromScroll } from '../../../lib/fetch_all_from_scroll'; import { INDEX_NAMES, ES_SCROLL_SETTINGS } from '../../../../common/constants'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; // @ts-ignore diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_load_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_load_route.ts index 6363054921333..d8905bcebeef3 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_load_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_load_route.ts @@ -7,7 +7,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; import { get } from 'lodash'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; // @ts-ignore import { Watch } from '../../../models/watch/index'; diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_save_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_save_route.ts index 10ee0c4857862..d3054bfb3ce8c 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_save_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_save_route.ts @@ -8,7 +8,7 @@ import { schema } from '@kbn/config-schema'; import { i18n } from '@kbn/i18n'; import { WATCH_TYPES } from '../../../../common/constants'; import { serializeJsonWatch, serializeThresholdWatch } from '../../../../common/lib/serialization'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; diff --git a/x-pack/plugins/watcher/server/routes/api/watch/register_visualize_route.ts b/x-pack/plugins/watcher/server/routes/api/watch/register_visualize_route.ts index 90550731bf23a..2eb6d270e808a 100644 --- a/x-pack/plugins/watcher/server/routes/api/watch/register_visualize_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watch/register_visualize_route.ts @@ -6,7 +6,7 @@ import { schema } from '@kbn/config-schema'; import { IScopedClusterClient } from 'kibana/server'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; diff --git a/x-pack/plugins/watcher/server/routes/api/watches/register_list_route.ts b/x-pack/plugins/watcher/server/routes/api/watches/register_list_route.ts index 5e823a0a8d2de..ca93221bf1de7 100644 --- a/x-pack/plugins/watcher/server/routes/api/watches/register_list_route.ts +++ b/x-pack/plugins/watcher/server/routes/api/watches/register_list_route.ts @@ -8,7 +8,7 @@ import { IScopedClusterClient } from 'kibana/server'; import { get } from 'lodash'; import { fetchAllFromScroll } from '../../../lib/fetch_all_from_scroll'; import { INDEX_NAMES, ES_SCROLL_SETTINGS } from '../../../../common/constants'; -import { isEsError } from '../../../lib/is_es_error'; +import { isEsError } from '../../../shared_imports'; import { RouteDependencies } from '../../../types'; import { licensePreRoutingFactory } from '../../../lib/license_pre_routing_factory'; // @ts-ignore diff --git a/x-pack/plugins/watcher/server/shared_imports.ts b/x-pack/plugins/watcher/server/shared_imports.ts new file mode 100644 index 0000000000000..454beda5394c7 --- /dev/null +++ b/x-pack/plugins/watcher/server/shared_imports.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { isEsError } from '../../../../src/plugins/es_ui_shared/server'; From 99a868a1259239896bfa0b9b5e16188bf36f0929 Mon Sep 17 00:00:00 2001 From: Jean-Louis Leysens Date: Mon, 15 Jun 2020 14:56:33 +0200 Subject: [PATCH 07/39] [Console] Scrub the lead and trailing brackets from ipv6 host names (#68991) * scrub the lead and trailing brackets from ipv6 host names * Update comment * refactor: scrub -> sanitize Co-authored-by: Elastic Machine --- src/plugins/console/server/lib/proxy_request.ts | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/plugins/console/server/lib/proxy_request.ts b/src/plugins/console/server/lib/proxy_request.ts index 4c6c7c21f32a4..fb07b7c49a003 100644 --- a/src/plugins/console/server/lib/proxy_request.ts +++ b/src/plugins/console/server/lib/proxy_request.ts @@ -34,6 +34,13 @@ interface Args { rejectUnauthorized?: boolean; } +/** + * Node http request library does not expect there to be trailing "[" or "]" + * characters in ipv6 host names. + */ +const sanitizeHostname = (hostName: string): string => + hostName.trim().replace(/^\[/, '').replace(/\]$/, ''); + // We use a modified version of Hapi's Wreck because Hapi, Axios, and Superagent don't support GET requests // with bodies, but ES APIs do. Similarly with DELETE requests with bodies. Another library, `request` // diverged too much from current behaviour. @@ -67,7 +74,7 @@ export const proxyRequest = ({ method: method.toUpperCase(), // We support overriding this on a per request basis to support legacy proxy config. See ./proxy_config. rejectUnauthorized: typeof rejectUnauthorized === 'boolean' ? rejectUnauthorized : undefined, - host: hostname, + host: sanitizeHostname(hostname), port: port === '' ? undefined : parseInt(port, 10), protocol, path: `${pathname}${search || ''}`, From 4e864268ce7fb6feda1e9f0cae88597b7b75efc8 Mon Sep 17 00:00:00 2001 From: Stratoula Kalafateli Date: Mon, 15 Jun 2020 15:57:20 +0300 Subject: [PATCH 08/39] fix spec color highlighting not working on vega vis (#68995) Co-authored-by: Elastic Machine --- src/plugins/vis_type_vega/public/components/vega_vis_editor.tsx | 1 + 1 file changed, 1 insertion(+) diff --git a/src/plugins/vis_type_vega/public/components/vega_vis_editor.tsx b/src/plugins/vis_type_vega/public/components/vega_vis_editor.tsx index 31144065d7b40..1da5e7544850a 100644 --- a/src/plugins/vis_type_vega/public/components/vega_vis_editor.tsx +++ b/src/plugins/vis_type_vega/public/components/vega_vis_editor.tsx @@ -22,6 +22,7 @@ import { EuiCodeEditor } from '@elastic/eui'; import compactStringify from 'json-stringify-pretty-compact'; // @ts-ignore import hjson from 'hjson'; +import 'brace/mode/hjson'; import { i18n } from '@kbn/i18n'; import { VisOptionsProps } from 'src/plugins/vis_default_editor/public'; From 46ed40ec075e397a0600d735e114c56c298093d4 Mon Sep 17 00:00:00 2001 From: Xavier Mouligneau <189600+XavierM@users.noreply.github.com> Date: Mon, 15 Jun 2020 09:16:52 -0400 Subject: [PATCH 09/39] [SECURITY] rename server plugin to siem (#69044) * rename server plugin to siem to avoid privilege issue * review from alerting * missing change with rename * fix tests * missing api integration test * fix api integration spaces --- x-pack/plugins/security_solution/common/constants.ts | 1 + .../alerts/components/user_info/index.test.tsx | 2 +- .../public/alerts/components/user_info/index.tsx | 4 +--- .../public/common/lib/kibana/hooks.ts | 8 ++------ .../flyout/header_with_close_button/index.test.tsx | 2 +- .../components/timeline/properties/helpers.test.tsx | 2 +- .../components/timeline/properties/helpers.tsx | 2 +- .../components/timeline/properties/index.test.tsx | 2 +- .../properties/new_template_timeline.test.tsx | 4 ++-- .../timeline/properties/new_template_timeline.tsx | 2 +- .../timeline/properties/properties_right.test.tsx | 12 ++++++------ .../timeline/properties/properties_right.tsx | 2 +- .../public/timelines/pages/timelines_page.test.tsx | 4 ++-- .../public/timelines/pages/timelines_page.tsx | 2 +- .../notifications/rules_notification_alert_type.ts | 4 ++-- .../signals/signal_rule_alert_type.ts | 8 ++++++-- x-pack/plugins/security_solution/server/plugin.ts | 4 ++-- .../apis/features/features/features.ts | 2 +- .../test/api_integration/apis/security/privileges.ts | 2 +- .../apis/security/privileges_basic.ts | 2 +- .../apis/security_solution/feature_controls.ts | 2 +- 21 files changed, 36 insertions(+), 37 deletions(-) diff --git a/x-pack/plugins/security_solution/common/constants.ts b/x-pack/plugins/security_solution/common/constants.ts index 7a2b531346ac3..d7f271535228c 100644 --- a/x-pack/plugins/security_solution/common/constants.ts +++ b/x-pack/plugins/security_solution/common/constants.ts @@ -5,6 +5,7 @@ */ export const APP_ID = 'securitySolution'; +export const SERVER_APP_ID = 'siem'; export const APP_NAME = 'Security'; export const APP_ICON = 'securityAnalyticsApp'; export const APP_PATH = `/app/security`; diff --git a/x-pack/plugins/security_solution/public/alerts/components/user_info/index.test.tsx b/x-pack/plugins/security_solution/public/alerts/components/user_info/index.test.tsx index 1d0f0e2e24f77..b01edac2605eb 100644 --- a/x-pack/plugins/security_solution/public/alerts/components/user_info/index.test.tsx +++ b/x-pack/plugins/security_solution/public/alerts/components/user_info/index.test.tsx @@ -22,7 +22,7 @@ describe('useUserInfo', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, diff --git a/x-pack/plugins/security_solution/public/alerts/components/user_info/index.tsx b/x-pack/plugins/security_solution/public/alerts/components/user_info/index.tsx index fc3fec7c29c1f..50348578cb039 100644 --- a/x-pack/plugins/security_solution/public/alerts/components/user_info/index.tsx +++ b/x-pack/plugins/security_solution/public/alerts/components/user_info/index.tsx @@ -163,9 +163,7 @@ export const useUserInfo = (): State => { const uiCapabilities = useKibana().services.application.capabilities; const capabilitiesCanUserCRUD: boolean = - typeof uiCapabilities.securitySolution.crud === 'boolean' - ? uiCapabilities.securitySolution.crud - : false; + typeof uiCapabilities.siem.crud === 'boolean' ? uiCapabilities.siem.crud : false; useEffect(() => { if (loading !== privilegeLoading || indexNameLoading) { diff --git a/x-pack/plugins/security_solution/public/common/lib/kibana/hooks.ts b/x-pack/plugins/security_solution/public/common/lib/kibana/hooks.ts index bc16e8334e81c..813907d9af416 100644 --- a/x-pack/plugins/security_solution/public/common/lib/kibana/hooks.ts +++ b/x-pack/plugins/security_solution/public/common/lib/kibana/hooks.ts @@ -113,13 +113,9 @@ export const useGetUserSavedObjectPermissions = () => { useEffect(() => { const capabilitiesCanUserCRUD: boolean = - typeof uiCapabilities.securitySolution.crud === 'boolean' - ? uiCapabilities.securitySolution.crud - : false; + typeof uiCapabilities.siem.crud === 'boolean' ? uiCapabilities.siem.crud : false; const capabilitiesCanUserRead: boolean = - typeof uiCapabilities.securitySolution.show === 'boolean' - ? uiCapabilities.securitySolution.show - : false; + typeof uiCapabilities.siem.show === 'boolean' ? uiCapabilities.siem.show : false; setSavedObjectsPermissions({ crud: capabilitiesCanUserCRUD, read: capabilitiesCanUserRead, diff --git a/x-pack/plugins/security_solution/public/timelines/components/flyout/header_with_close_button/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/flyout/header_with_close_button/index.test.tsx index e5fc8b68b1cb7..ddb8fb023195a 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/flyout/header_with_close_button/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/flyout/header_with_close_button/index.test.tsx @@ -20,7 +20,7 @@ jest.mock('../../../../common/lib/kibana', () => ({ services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.test.tsx index fb91bbd5a1124..d8c9d2ed02cc6 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.test.tsx @@ -18,7 +18,7 @@ jest.mock('../../../../common/lib/kibana', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.tsx index 00a0e57324841..4d5c16dc30b8e 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/helpers.tsx @@ -222,7 +222,7 @@ export interface NewTimelineProps { export const NewTimeline = React.memo( ({ closeGearMenu, outline = false, timelineId, title = i18n.NEW_TIMELINE }) => { const uiCapabilities = useKibana().services.application.capabilities; - const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.securitySolution.crud; + const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.siem.crud; const { getButton } = useCreateTimelineButton({ timelineId, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/index.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/index.test.tsx index 505d0b8cba854..660beffd9a089 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/index.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/index.test.tsx @@ -30,7 +30,7 @@ jest.mock('../../../../common/lib/kibana', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.test.tsx index b9b6dadf6f9d7..879302d4a92c1 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.test.tsx @@ -35,7 +35,7 @@ describe('NewTemplateTimeline', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, @@ -76,7 +76,7 @@ describe('NewTemplateTimeline', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: false, }, }, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.tsx index 45b2ce62fb85b..e88ecee81d364 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/new_template_timeline.tsx @@ -25,7 +25,7 @@ export const NewTemplateTimelineComponent: React.FC = ({ timelineId = 'timeline-1', }) => { const uiCapabilities = useKibana().services.application.capabilities; - const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.securitySolution.crud; + const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.siem.crud; const { getButton } = useCreateTimelineButton({ timelineId, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.test.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.test.tsx index e297a3cc595d6..ae167515495f7 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.test.tsx @@ -78,7 +78,7 @@ describe('Properties Right', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, @@ -129,7 +129,7 @@ describe('Properties Right', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, @@ -158,7 +158,7 @@ describe('Properties Right', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, @@ -189,7 +189,7 @@ describe('Properties Right', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: false, }, }, @@ -236,7 +236,7 @@ describe('Properties Right', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: false, }, }, @@ -265,7 +265,7 @@ describe('Properties Right', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: false, }, }, diff --git a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.tsx b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.tsx index a9baf73676ffb..7d176d57b5d81 100644 --- a/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.tsx +++ b/x-pack/plugins/security_solution/public/timelines/components/timeline/properties/properties_right.tsx @@ -116,7 +116,7 @@ const PropertiesRightComponent: React.FC = ({ usersViewing, }) => { const uiCapabilities = useKibana().services.application.capabilities; - const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.securitySolution.crud; + const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.siem.crud; return ( diff --git a/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.test.tsx b/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.test.tsx index e7b66c4e8addb..3a5e3b56e5cc4 100644 --- a/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.test.tsx +++ b/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.test.tsx @@ -30,7 +30,7 @@ describe('TimelinesPageComponent', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: true, }, }, @@ -82,7 +82,7 @@ describe('TimelinesPageComponent', () => { services: { application: { capabilities: { - securitySolution: { + siem: { crud: false, }, }, diff --git a/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.tsx b/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.tsx index 2c692d850cd16..95a2e4f5fd0ee 100644 --- a/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.tsx +++ b/x-pack/plugins/security_solution/public/timelines/pages/timelines_page.tsx @@ -42,7 +42,7 @@ export const TimelinesPageComponent: React.FC = ({ apolloClient }) => }, [setImportDataModalToggle]); const uiCapabilities = useKibana().services.application.capabilities; - const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.securitySolution.crud; + const capabilitiesCanUserCRUD: boolean = !!uiCapabilities.siem.crud; return ( <> diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/rules_notification_alert_type.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/rules_notification_alert_type.ts index cf5a6aa01f29e..ab824957087fc 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/rules_notification_alert_type.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/notifications/rules_notification_alert_type.ts @@ -6,7 +6,7 @@ import { Logger } from 'src/core/server'; import { schema } from '@kbn/config-schema'; -import { NOTIFICATIONS_ID } from '../../../../common/constants'; +import { NOTIFICATIONS_ID, SERVER_APP_ID } from '../../../../common/constants'; import { NotificationAlertTypeDefinition } from './types'; import { getSignalsCount } from './get_signals_count'; @@ -25,7 +25,7 @@ export const rulesNotificationAlertType = ({ name: 'SIEM notification', actionGroups: siemRuleActionGroups, defaultActionGroupId: 'default', - producer: 'siem', + producer: SERVER_APP_ID, validate: { params: schema.object({ ruleAlertId: schema.string(), diff --git a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/signal_rule_alert_type.ts b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/signal_rule_alert_type.ts index 091ee54e3174e..728bd66b7d65c 100644 --- a/x-pack/plugins/security_solution/server/lib/detection_engine/signals/signal_rule_alert_type.ts +++ b/x-pack/plugins/security_solution/server/lib/detection_engine/signals/signal_rule_alert_type.ts @@ -8,7 +8,11 @@ import { Logger, KibanaRequest } from 'src/core/server'; -import { SIGNALS_ID, DEFAULT_SEARCH_AFTER_PAGE_SIZE } from '../../../../common/constants'; +import { + SIGNALS_ID, + DEFAULT_SEARCH_AFTER_PAGE_SIZE, + SERVER_APP_ID, +} from '../../../../common/constants'; import { isJobStarted, isMlRule } from '../../../../common/machine_learning/helpers'; import { SetupPlugins } from '../../../plugin'; @@ -55,7 +59,7 @@ export const signalRulesAlertType = ({ validate: { params: signalParamsSchema(), }, - producer: 'siem', + producer: SERVER_APP_ID, async executor({ previousStartedAt, alertId, diff --git a/x-pack/plugins/security_solution/server/plugin.ts b/x-pack/plugins/security_solution/server/plugin.ts index 00f2cba304c88..ebb2310ac5310 100644 --- a/x-pack/plugins/security_solution/server/plugin.ts +++ b/x-pack/plugins/security_solution/server/plugin.ts @@ -36,7 +36,7 @@ import { initSavedObjects, savedObjectTypes } from './saved_objects'; import { AppClientFactory } from './client'; import { createConfig$, ConfigType } from './config'; import { initUiSettings } from './ui_settings'; -import { APP_ID, APP_ICON } from '../common/constants'; +import { APP_ID, APP_ICON, SERVER_APP_ID } from '../common/constants'; import { registerEndpointRoutes } from './endpoint/routes/metadata'; import { registerResolverRoutes } from './endpoint/routes/resolver'; import { registerAlertRoutes } from './endpoint/alerts/routes'; @@ -125,7 +125,7 @@ export class Plugin implements IPlugin Date: Mon, 15 Jun 2020 16:32:08 +0300 Subject: [PATCH 10/39] Type safe browser.executeAsync (#69018) * make browserAsync type safe * adopt tests * prefer unknown over any * simplify signature --- test/functional/services/common/browser.ts | 24 +++++++++++++++---- .../test_suites/run_pipeline/helpers.ts | 14 +++++------ .../application_links/redirect_app_links.ts | 5 ++-- .../core_plugins/application_status.ts | 6 ++--- .../test_suites/core_plugins/ui_plugins.ts | 2 +- .../test_suites/core_plugins/ui_settings.ts | 2 +- .../test/licensing_plugin/public/updates.ts | 8 +++---- .../global_search/global_search_api.ts | 8 +++---- 8 files changed, 41 insertions(+), 28 deletions(-) diff --git a/test/functional/services/common/browser.ts b/test/functional/services/common/browser.ts index 3f71c16bd3c44..3297f6e094f7c 100644 --- a/test/functional/services/common/browser.ts +++ b/test/functional/services/common/browser.ts @@ -479,11 +479,27 @@ export async function BrowserProvider({ getService }: FtrProviderContext) { ); } - public async executeAsync( - fn: string | ((...args: any[]) => Promise), + public async executeAsync(fn: (cb: (value?: T) => void) => void): Promise; + public async executeAsync( + fn: (a1: A1, cb: (value?: T) => void) => void, + a1: A1 + ): Promise; + public async executeAsync( + fn: (a1: A1, a2: A2, cb: (value?: T) => void) => void, + a1: A1, + a2: A2 + ): Promise; + public async executeAsync( + fn: (a1: A1, a2: A2, a3: A3, cb: (value?: T) => void) => void, + a1: A1, + a2: A2, + a3: A3 + ): Promise; + public async executeAsync( + fn: (...args: any[]) => void, ...args: any[] - ): Promise { - return await driver.executeAsyncScript( + ): Promise { + return await driver.executeAsyncScript( fn, ...cloneDeep(args, (arg) => { if (arg instanceof WebElementWrapper) { diff --git a/test/interpreter_functional/test_suites/run_pipeline/helpers.ts b/test/interpreter_functional/test_suites/run_pipeline/helpers.ts index 2486fb0e1fbd0..bbf45b003c330 100644 --- a/test/interpreter_functional/test_suites/run_pipeline/helpers.ts +++ b/test/interpreter_functional/test_suites/run_pipeline/helpers.ts @@ -110,13 +110,13 @@ export function expectExpressionProvider({ stepContext: ExpressionValue = context ): Promise => { log.debug(`running expression ${step || expression}`); - return browser.executeAsync( - ( - _expression: string, - _currentContext: ExpressionValue & { type: string }, - _initialContext: ExpressionValue, - done: (expressionResult: ExpressionResult) => void - ) => { + return browser.executeAsync< + ExpressionResult, + string, + ExpressionValue & { type: string }, + ExpressionValue + >( + (_expression, _currentContext, _initialContext, done) => { if (!_currentContext) _currentContext = { type: 'null' }; if (!_currentContext.type) _currentContext.type = 'null'; return window diff --git a/test/plugin_functional/test_suites/application_links/redirect_app_links.ts b/test/plugin_functional/test_suites/application_links/redirect_app_links.ts index 54f7cdf1fdff5..9120018958bda 100644 --- a/test/plugin_functional/test_suites/application_links/redirect_app_links.ts +++ b/test/plugin_functional/test_suites/application_links/redirect_app_links.ts @@ -40,16 +40,15 @@ export default function ({ getService, getPageObjects }: PluginFunctionalProvide const testSubjects = getService('testSubjects'); const setNonReloadedFlag = () => { - return browser.executeAsync(async (cb: Function) => { + return browser.executeAsync(async (cb) => { window.__nonReloadedFlag = true; cb(); }); }; - const wasReloaded = (): Promise => { + const wasReloaded = () => { return browser.executeAsync(async (cb) => { const reloaded = window.__nonReloadedFlag !== true; cb(reloaded); - return reloaded; }); }; diff --git a/test/plugin_functional/test_suites/core_plugins/application_status.ts b/test/plugin_functional/test_suites/core_plugins/application_status.ts index 96bcda39f3981..31a1c28b50842 100644 --- a/test/plugin_functional/test_suites/core_plugins/application_status.ts +++ b/test/plugin_functional/test_suites/core_plugins/application_status.ts @@ -44,17 +44,17 @@ export default function ({ getService, getPageObjects }: PluginFunctionalProvide const testSubjects = getService('testSubjects'); const setAppStatus = async (s: Partial) => { - return browser.executeAsync(async (status: Partial, cb: Function) => { + return browser.executeAsync(async (status, cb) => { window.__coreAppStatus.setAppStatus(status); cb(); }, s); }; const navigateToApp = async (i: string) => { - return (await browser.executeAsync(async (appId, cb: Function) => { + return await browser.executeAsync(async (appId, cb) => { await window.__coreAppStatus.navigateToApp(appId); cb(); - }, i)) as any; + }, i); }; // FLAKY: https://github.com/elastic/kibana/issues/65423 diff --git a/test/plugin_functional/test_suites/core_plugins/ui_plugins.ts b/test/plugin_functional/test_suites/core_plugins/ui_plugins.ts index 929d5b68be93d..3a27be42a2a42 100644 --- a/test/plugin_functional/test_suites/core_plugins/ui_plugins.ts +++ b/test/plugin_functional/test_suites/core_plugins/ui_plugins.ts @@ -49,7 +49,7 @@ export default function ({ getService, getPageObjects }: PluginFunctionalProvide it('to start services via coreSetup.getStartServices', async () => { expect( - await browser.executeAsync(async (cb) => { + await browser.executeAsync(async (cb) => { const [coreStart] = await window.__coreProvider.setup.core.getStartServices(); cb(Boolean(coreStart.overlays)); }) diff --git a/test/plugin_functional/test_suites/core_plugins/ui_settings.ts b/test/plugin_functional/test_suites/core_plugins/ui_settings.ts index 6a0a5fed48e6d..3a618ceaeb22f 100644 --- a/test/plugin_functional/test_suites/core_plugins/ui_settings.ts +++ b/test/plugin_functional/test_suites/core_plugins/ui_settings.ts @@ -49,7 +49,7 @@ export default function ({ getService, getPageObjects }: PluginFunctionalProvide expect(settingsValue).to.be('2'); - const settingsValueViaObservables = await browser.executeAsync(async (callback: Function) => { + const settingsValueViaObservables = await browser.executeAsync(async (callback) => { window.__coreProvider.setup.core.uiSettings .get$('ui_settings_plugin') .subscribe((v) => callback(v)); diff --git a/x-pack/test/licensing_plugin/public/updates.ts b/x-pack/test/licensing_plugin/public/updates.ts index 4914513193cb4..4604cfe032b0b 100644 --- a/x-pack/test/licensing_plugin/public/updates.ts +++ b/x-pack/test/licensing_plugin/public/updates.ts @@ -27,7 +27,7 @@ export default function (ftrContext: FtrProviderContext) { await scenario.waitForPluginToDetectLicenseUpdate(); expect( - await browser.executeAsync(async (cb: Function) => { + await browser.executeAsync(async (cb) => { const { setup, testUtils } = window.__coreProvider; // this call enforces signature check to detect license update // and causes license re-fetch @@ -43,7 +43,7 @@ export default function (ftrContext: FtrProviderContext) { await scenario.waitForPluginToDetectLicenseUpdate(); expect( - await browser.executeAsync(async (cb: Function) => { + await browser.executeAsync(async (cb) => { const { setup, testUtils } = window.__coreProvider; // this call enforces signature check to detect license update // and causes license re-fetch @@ -59,7 +59,7 @@ export default function (ftrContext: FtrProviderContext) { await scenario.waitForPluginToDetectLicenseUpdate(); expect( - await browser.executeAsync(async (cb: Function) => { + await browser.executeAsync(async (cb) => { const { setup, testUtils } = window.__coreProvider; // this call enforces signature check to detect license update // and causes license re-fetch @@ -75,7 +75,7 @@ export default function (ftrContext: FtrProviderContext) { await scenario.waitForPluginToDetectLicenseUpdate(); expect( - await browser.executeAsync(async (cb: Function) => { + await browser.executeAsync(async (cb) => { const { setup, testUtils } = window.__coreProvider; // this call enforces signature check to detect license update // and causes license re-fetch diff --git a/x-pack/test/plugin_functional/test_suites/global_search/global_search_api.ts b/x-pack/test/plugin_functional/test_suites/global_search/global_search_api.ts index 4cc056fd51c2a..ee1745436b735 100644 --- a/x-pack/test/plugin_functional/test_suites/global_search/global_search_api.ts +++ b/x-pack/test/plugin_functional/test_suites/global_search/global_search_api.ts @@ -14,13 +14,11 @@ export default function ({ getPageObjects, getService }: FtrProviderContext) { const browser = getService('browser'); const findResultsWithAPI = async (t: string): Promise => { - return browser.executeAsync(async (term: string, cb: Function) => { + return browser.executeAsync(async (term, cb) => { const { start } = window.__coreProvider; const globalSearchTestApi: GlobalSearchTestApi = start.plugins.globalSearchTest; - globalSearchTestApi.findAll(term).then((results) => { - cb(results); - }); - }, t) as any; // executeAsync signature is broken. return type should be inferred from the cb param. + globalSearchTestApi.findAll(term).then(cb); + }, t); }; describe('GlobalSearch API', function () { From 80ab0d9792fecb775a93b319a15c12a663134e50 Mon Sep 17 00:00:00 2001 From: MadameSheema Date: Mon, 15 Jun 2020 16:58:47 +0200 Subject: [PATCH 11/39] fixes 'Configures a new connector' flaky test (#69011) Co-authored-by: Elastic Machine --- .../cypress/integration/cases_connectors.spec.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/x-pack/plugins/security_solution/cypress/integration/cases_connectors.spec.ts b/x-pack/plugins/security_solution/cypress/integration/cases_connectors.spec.ts index ae4bb82ebfee6..266d183ea1b85 100644 --- a/x-pack/plugins/security_solution/cypress/integration/cases_connectors.spec.ts +++ b/x-pack/plugins/security_solution/cypress/integration/cases_connectors.spec.ts @@ -17,8 +17,7 @@ import { loginAndWaitForPageWithoutDateRange } from '../tasks/login'; import { CASES } from '../urls/navigation'; -// FLAKY: https://github.com/elastic/kibana/issues/65278 -describe.skip('Cases connectors', () => { +describe('Cases connectors', () => { before(() => { cy.server(); cy.route('POST', '**/api/actions/action').as('createConnector'); @@ -33,6 +32,7 @@ describe.skip('Cases connectors', () => { cy.wait('@createConnector').its('status').should('eql', 200); cy.get(TOASTER).should('have.text', "Created 'New connector'"); + cy.get(TOASTER).should('not.exist'); selectLastConnectorCreated(); From 3d0552e03ce1ff2112a7ca50555575c2cd828c1b Mon Sep 17 00:00:00 2001 From: Anton Dosov Date: Mon, 15 Jun 2020 17:13:31 +0200 Subject: [PATCH 12/39] Embed dashboard by value example & some embeddable clean up (#67783) Added example for using dashboard container by value 1.1 Refactored embeddable explorer e2e test to use new example, removed not needed kbn_tp_embeddable_explorer plugin. For embeddable explorer examples went away from using getFactoryById() to improve type checks There is new component a replacement for EmbeddableFactoryRenderer with slightly more flexible api: EmbeddableRenderer. 3.1 We can improve it going forward to support more use case --- .../dashboard_embeddable_examples/README.md | 1 + .../dashboard_embeddable_examples/kibana.json | 9 + .../public/app.tsx | 112 ++++++++++++ .../public/by_value/embeddable.tsx | 120 +++++++++++++ .../public/by_value/input_editor.tsx | 56 ++++++ .../public}/index.ts | 4 +- .../public/plugin.tsx | 64 +++++++ .../tsconfig.json | 15 ++ .../hello_world_embeddable_factory.ts | 4 +- examples/embeddable_examples/public/index.ts | 13 +- .../public/list_container/index.ts | 2 +- .../public/list_container/list_container.tsx | 2 +- .../list_container/list_container_factory.ts | 6 +- .../multi_task_todo_embeddable_factory.ts | 17 +- examples/embeddable_examples/public/plugin.ts | 69 +++++--- .../public/searchable_list_container/index.ts | 5 +- .../searchable_list_container_factory.ts | 9 +- .../public/todo/todo_embeddable_factory.tsx | 10 +- .../todo/todo_ref_embeddable_factory.tsx | 10 +- examples/embeddable_explorer/public/app.tsx | 33 ++-- .../public/embeddable_panel_example.tsx | 8 +- .../public/hello_world_embeddable_example.tsx | 36 ++-- .../public/list_container_example.tsx | 41 +++-- .../embeddable_explorer/public/plugin.tsx | 1 + .../public/todo_embeddable_example.tsx | 89 +++------- package.json | 1 + renovate.json5 | 8 + .../embeddable/dashboard_container.tsx | 2 +- .../dashboard_container_by_value_renderer.tsx | 37 ++-- .../dashboard_container_factory.tsx | 9 +- .../public/application/embeddable/index.ts | 7 +- src/plugins/dashboard/public/index.ts | 2 +- src/plugins/dashboard/public/plugin.tsx | 37 ++-- src/plugins/embeddable/README.md | 8 +- src/plugins/embeddable/docs/README.md | 5 + .../docs/containers_and_inherited_state.md | 33 ++++ src/plugins/embeddable/public/index.ts | 3 +- .../embeddable_factory_renderer.test.tsx | 71 -------- .../embeddable_factory_renderer.tsx | 80 --------- .../embeddables/embeddable_renderer.test.tsx | 56 ++++++ .../lib/embeddables/embeddable_renderer.tsx | 164 ++++++++++++++++++ .../lib/embeddables/embeddable_root.test.tsx | 9 + .../lib/embeddables/embeddable_root.tsx | 22 ++- .../public/lib/embeddables/index.ts | 2 +- src/plugins/embeddable/public/plugin.tsx | 30 +++- .../embeddable/public/tests/container.test.ts | 6 +- .../public/tests/explicit_input.test.ts | 7 +- test/examples/embeddables/adding_children.ts | 2 +- .../embeddables/dashboard.ts} | 70 ++++++-- test/examples/embeddables/index.ts | 1 + test/plugin_functional/config.js | 1 - .../kbn_tp_embeddable_explorer/README.md | 17 -- .../kbn_tp_embeddable_explorer/kibana.json | 16 -- .../kbn_tp_embeddable_explorer/package.json | 22 --- .../public/README.md | 21 --- .../public/app/app.tsx | 79 --------- .../app/dashboard_container_example.tsx | 102 ----------- .../public/embeddable_api.ts | 25 --- .../public/index.ts | 30 ---- .../public/plugin.tsx | 98 ----------- .../kbn_tp_embeddable_explorer/tsconfig.json | 20 --- .../test_suites/embeddable_explorer/index.js | 42 ----- .../translations/translations/ja-JP.json | 1 - .../translations/translations/zh-CN.json | 1 - yarn.lock | 7 + 65 files changed, 1029 insertions(+), 861 deletions(-) create mode 100644 examples/dashboard_embeddable_examples/README.md create mode 100644 examples/dashboard_embeddable_examples/kibana.json create mode 100644 examples/dashboard_embeddable_examples/public/app.tsx create mode 100644 examples/dashboard_embeddable_examples/public/by_value/embeddable.tsx create mode 100644 examples/dashboard_embeddable_examples/public/by_value/input_editor.tsx rename {test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/app => examples/dashboard_embeddable_examples/public}/index.ts (86%) create mode 100644 examples/dashboard_embeddable_examples/public/plugin.tsx create mode 100644 examples/dashboard_embeddable_examples/tsconfig.json rename test/plugin_functional/test_suites/embeddable_explorer/dashboard_container.js => src/plugins/dashboard/public/application/embeddable/dashboard_container_by_value_renderer.tsx (55%) create mode 100644 src/plugins/embeddable/docs/README.md create mode 100644 src/plugins/embeddable/docs/containers_and_inherited_state.md delete mode 100644 src/plugins/embeddable/public/lib/embeddables/embeddable_factory_renderer.test.tsx delete mode 100644 src/plugins/embeddable/public/lib/embeddables/embeddable_factory_renderer.tsx create mode 100644 src/plugins/embeddable/public/lib/embeddables/embeddable_renderer.test.tsx create mode 100644 src/plugins/embeddable/public/lib/embeddables/embeddable_renderer.tsx rename test/{plugin_functional/plugins/kbn_tp_embeddable_explorer/public/app/dashboard_input.ts => examples/embeddables/dashboard.ts} (56%) delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/README.md delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/kibana.json delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/package.json delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/README.md delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/app/app.tsx delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/app/dashboard_container_example.tsx delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/embeddable_api.ts delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/index.ts delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/public/plugin.tsx delete mode 100644 test/plugin_functional/plugins/kbn_tp_embeddable_explorer/tsconfig.json delete mode 100644 test/plugin_functional/test_suites/embeddable_explorer/index.js diff --git a/examples/dashboard_embeddable_examples/README.md b/examples/dashboard_embeddable_examples/README.md new file mode 100644 index 0000000000000..e1528e36f4c4b --- /dev/null +++ b/examples/dashboard_embeddable_examples/README.md @@ -0,0 +1 @@ +Example of using dashboard container embeddable outside of dashboard app diff --git a/examples/dashboard_embeddable_examples/kibana.json b/examples/dashboard_embeddable_examples/kibana.json new file mode 100644 index 0000000000000..bb2ced569edb5 --- /dev/null +++ b/examples/dashboard_embeddable_examples/kibana.json @@ -0,0 +1,9 @@ +{ + "id": "dashboardEmbeddableExamples", + "version": "0.0.1", + "kibanaVersion": "kibana", + "server": false, + "ui": true, + "requiredPlugins": ["embeddable", "embeddableExamples", "dashboard", "developerExamples"], + "optionalPlugins": [] +} diff --git a/examples/dashboard_embeddable_examples/public/app.tsx b/examples/dashboard_embeddable_examples/public/app.tsx new file mode 100644 index 0000000000000..b166b8444f080 --- /dev/null +++ b/examples/dashboard_embeddable_examples/public/app.tsx @@ -0,0 +1,112 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import React from 'react'; +import ReactDOM from 'react-dom'; +import { BrowserRouter as Router, Route, RouteComponentProps, withRouter } from 'react-router-dom'; + +import { + EuiPage, + EuiPageContent, + EuiPageContentBody, + EuiPageSideBar, + EuiSideNav, +} from '@elastic/eui'; +import 'brace/mode/json'; +import { AppMountParameters } from '../../../src/core/public'; +import { DashboardEmbeddableByValue } from './by_value/embeddable'; +import { DashboardStart } from '../../../src/plugins/dashboard/public'; + +interface PageDef { + title: string; + id: string; + component: React.ReactNode; +} + +type NavProps = RouteComponentProps & { + pages: PageDef[]; +}; + +const Nav = withRouter(({ history, pages }: NavProps) => { + const navItems = pages.map((page) => ({ + id: page.id, + name: page.title, + onClick: () => history.push(`/${page.id}`), + 'data-test-subj': page.id, + })); + + return ( + + ); +}); + +interface Props { + basename: string; + DashboardContainerByValueRenderer: DashboardStart['DashboardContainerByValueRenderer']; +} + +const DashboardEmbeddableExplorerApp = ({ basename, DashboardContainerByValueRenderer }: Props) => { + const pages: PageDef[] = [ + { + title: 'By value dashboard embeddable', + id: 'dashboardEmbeddableByValue', + component: ( + + ), + }, + { + title: 'By ref dashboard embeddable', + id: 'dashboardEmbeddableByRef', + component:
TODO: Not implemented, but coming soon...
, + }, + ]; + + const routes = pages.map((page, i) => ( + page.component} /> + )); + + return ( + + + +