mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 17:59:23 -04:00
* Expose core api types in /public and /server * Export CoreStart from core/public * Export Server and Public from 'kibana' * Cast frozen object type back to original The exported type `InjectedMetadataStart` derives it's type from the returned values. Since it's internal state is frozen the type changes to `ReadOnly<`. However, consumers of the API shouldn't have to know or care about this type. * Be more selective with what gets exported * Fix type imports in tests * Fix type errors * Remove src/type_exports.ts * More remove src/type_exports.ts * Remove build:types * Fix bootstrap import * Expose internal API's at the top level Exposing the internal API's at the top level of core/public and core/server makes it obvious that these API's are consumed outside these modules. Marking these @internal ensures they don't get exported as part of the documentation. * Fix tests * Put core/{public/server} in their own namespaces
57 lines
2.4 KiB
TypeScript
57 lines
2.4 KiB
TypeScript
/*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* All exports from TS source files (where the implementation is actually done in TS).
|
|
*/
|
|
export { Public, Server } from 'src/core';
|
|
|
|
/**
|
|
* All exports from TS ambient definitions (where types are added for JS source in a .d.ts file).
|
|
*/
|
|
import * as LegacyElasticsearch from './src/legacy/core_plugins/elasticsearch';
|
|
import * as LegacyKibanaPluginSpec from './src/legacy/plugin_discovery/plugin_spec/plugin_spec_options';
|
|
import * as LegacyKibanaServer from './src/legacy/server/kbn_server';
|
|
|
|
/**
|
|
* Re-export legacy types under a namespace.
|
|
*/
|
|
// tslint:disable:no-namespace
|
|
export namespace Legacy {
|
|
export type IndexPatternsService = LegacyKibanaServer.IndexPatternsService;
|
|
export type KibanaConfig = LegacyKibanaServer.KibanaConfig;
|
|
export type Request = LegacyKibanaServer.Request;
|
|
export type ResponseToolkit = LegacyKibanaServer.ResponseToolkit;
|
|
export type SavedObjectsClient = LegacyKibanaServer.SavedObjectsClient;
|
|
export type SavedObjectsService = LegacyKibanaServer.SavedObjectsService;
|
|
export type Server = LegacyKibanaServer.Server;
|
|
|
|
export type InitPluginFunction = LegacyKibanaPluginSpec.InitPluginFunction;
|
|
export type UiExports = LegacyKibanaPluginSpec.UiExports;
|
|
export type PluginSpecOptions = LegacyKibanaPluginSpec.PluginSpecOptions;
|
|
|
|
export namespace Plugins {
|
|
export namespace elasticsearch {
|
|
export type Plugin = LegacyElasticsearch.ElasticsearchPlugin;
|
|
export type Cluster = LegacyElasticsearch.Cluster;
|
|
export type ClusterConfig = LegacyElasticsearch.ClusterConfig;
|
|
export type CallClusterOptions = LegacyElasticsearch.CallClusterOptions;
|
|
}
|
|
}
|
|
}
|