diff --git a/config/opensearch_dashboards.yml b/config/opensearch_dashboards.yml
index 6bb4f63bbbde..7a7667a6d43f 100644
--- a/config/opensearch_dashboards.yml
+++ b/config/opensearch_dashboards.yml
@@ -231,9 +231,14 @@
# Set the value of this setting to true to enable the experimental multiple data source
# support feature. Use with caution.
-#data_source.enabled: false
+data_source.enabled: false
# Set the value of these settings to customize crypto materials to encryption saved credentials
# in data sources.
-#data_source.encryption.wrappingKeyName: 'changeme'
-#data_source.encryption.wrappingKeyNamespace: 'changeme'
-#data_source.encryption.wrappingKey: [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
+data_source.encryption.wrappingKeyName: 'changeme'
+data_source.encryption.wrappingKeyNamespace: 'changeme'
+data_source.encryption.wrappingKey: [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
+pit.enabled: true
+opensearch.hosts: ["http://localhost:9200"]
+opensearch.username: "admin" # Default username on the docker image
+opensearch.password: "admin" # Default password on the docker image
+opensearch.ssl.verificationMode: none
\ No newline at end of file
diff --git a/package.json b/package.json
index 1e96cc9bdda5..d74a34384a85 100644
--- a/package.json
+++ b/package.json
@@ -134,7 +134,7 @@
"@hapi/podium": "^4.1.3",
"@hapi/vision": "^6.1.0",
"@hapi/wreck": "^17.1.0",
- "@opensearch-project/opensearch": "^2.1.0",
+ "@opensearch-project/opensearch": "^2.2.0",
"@osd/ace": "1.0.0",
"@osd/analytics": "1.0.0",
"@osd/apm-config-loader": "1.0.0",
diff --git a/src/plugins/point_in_time_management/opensearch_dashboards.json b/src/plugins/point_in_time_management/opensearch_dashboards.json
index 1757278f19a6..c369a1595e58 100644
--- a/src/plugins/point_in_time_management/opensearch_dashboards.json
+++ b/src/plugins/point_in_time_management/opensearch_dashboards.json
@@ -4,7 +4,15 @@
"opensearchDashboardsVersion": "opensearchDashboards",
"server": true,
"ui": true,
- "requiredPlugins": ["navigation", "management"],
- "optionalPlugins": [],
- "requiredBundles": ["opensearchDashboardsReact"]
-}
+ "requiredPlugins": [
+ "navigation",
+ "management",
+ "data"
+ ],
+ "optionalPlugins": [
+ "dataSource"
+ ],
+ "requiredBundles": [
+ "opensearchDashboardsReact"
+ ]
+}
\ No newline at end of file
diff --git a/src/plugins/point_in_time_management/public/components/breadcrumbs.ts b/src/plugins/point_in_time_management/public/components/breadcrumbs.ts
new file mode 100644
index 000000000000..c20af07652b9
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/breadcrumbs.ts
@@ -0,0 +1,17 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { i18n } from '@osd/i18n';
+
+export function getListBreadcrumbs() {
+ return [
+ {
+ text: i18n.translate('pitManagement.listBreadcrumb', {
+ defaultMessage: 'Point in time',
+ }),
+ href: `/`,
+ },
+ ];
+}
diff --git a/src/plugins/point_in_time_management/public/components/empty_state/__snapshots__/empty_state.test.tsx.snap b/src/plugins/point_in_time_management/public/components/empty_state/__snapshots__/empty_state.test.tsx.snap
index cc1ee347208f..43c1e58e1acc 100644
--- a/src/plugins/point_in_time_management/public/components/empty_state/__snapshots__/empty_state.test.tsx.snap
+++ b/src/plugins/point_in_time_management/public/components/empty_state/__snapshots__/empty_state.test.tsx.snap
@@ -1,3 +1,8 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`EmptyState should render normally 1`] = `
diff --git a/src/plugins/point_in_time_management/public/components/index.ts b/src/plugins/point_in_time_management/public/components/index.ts
index c903066cdbb0..2cdabdd2c047 100644
--- a/src/plugins/point_in_time_management/public/components/index.ts
+++ b/src/plugins/point_in_time_management/public/components/index.ts
@@ -3,4 +3,4 @@
* SPDX-License-Identifier: Apache-2.0
*/
-export { EmptyState } from './empty_state';
+export { PITTableWithRouter } from './pit_table';
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/empty_state/__snapshots__/empty_state.test.tsx.snap b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/__snapshots__/empty_state.test.tsx.snap
new file mode 100644
index 000000000000..414686fcb7bc
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/__snapshots__/empty_state.test.tsx.snap
@@ -0,0 +1,32 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[`EmptyState should render normally 1`] = `
+
+
+
+ }
+ body={
+
+
+
+ }
+/>
+`;
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/empty_state/empty_state.test.tsx b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/empty_state.test.tsx
new file mode 100644
index 000000000000..82393e830152
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/empty_state.test.tsx
@@ -0,0 +1,16 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import React from 'react';
+import { EmptyState } from './empty_state';
+import { shallow } from 'enzyme';
+
+describe('EmptyState', () => {
+ it('should render normally', () => {
+ const component = shallow();
+
+ expect(component).toMatchSnapshot();
+ });
+});
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/empty_state/empty_state.tsx b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/empty_state.tsx
new file mode 100644
index 000000000000..e0babd5db8b5
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/empty_state.tsx
@@ -0,0 +1,29 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { EuiButton, EuiEmptyPrompt } from '@elastic/eui';
+import { FormattedMessage } from '@osd/i18n/react';
+import React from 'react';
+
+export const EmptyState = () => (
+
+
+
+ }
+ actions={
+
+
+
+ }
+ />
+);
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/empty_state/index.ts b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/index.ts
new file mode 100644
index 000000000000..3b18ca75b42e
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/empty_state/index.ts
@@ -0,0 +1,6 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+export { EmptyState } from './empty_state';
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/index.ts b/src/plugins/point_in_time_management/public/components/pit_table/index.ts
new file mode 100644
index 000000000000..35a1f8acc63f
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/index.ts
@@ -0,0 +1,6 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+export { PITTableWithRouter } from './pit_table';
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/page_header/__snapshots__/page_header.test.tsx.snap b/src/plugins/point_in_time_management/public/components/pit_table/page_header/__snapshots__/page_header.test.tsx.snap
new file mode 100644
index 000000000000..84f28b4592f6
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/page_header/__snapshots__/page_header.test.tsx.snap
@@ -0,0 +1,46 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[`PageHeader should render normally 1`] = `
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+`;
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/page_header/index.ts b/src/plugins/point_in_time_management/public/components/pit_table/page_header/index.ts
new file mode 100644
index 000000000000..0328fce3768d
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/page_header/index.ts
@@ -0,0 +1,6 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+export { PageHeader } from './page_header';
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/page_header/page_header.test.tsx b/src/plugins/point_in_time_management/public/components/pit_table/page_header/page_header.test.tsx
new file mode 100644
index 000000000000..ea595f4363e4
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/page_header/page_header.test.tsx
@@ -0,0 +1,16 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import React from 'react';
+import { PageHeader } from './page_header';
+import { shallow } from 'enzyme';
+
+describe('PageHeader', () => {
+ it('should render normally', () => {
+ const component = shallow();
+
+ expect(component).toMatchSnapshot();
+ });
+});
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/page_header/page_header.tsx b/src/plugins/point_in_time_management/public/components/pit_table/page_header/page_header.tsx
new file mode 100644
index 000000000000..3c0c60e69ac9
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/page_header/page_header.tsx
@@ -0,0 +1,39 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import {
+ EuiButton,
+ EuiPageContentHeader,
+ EuiPageContentHeaderSection,
+ EuiText,
+ EuiTitle,
+} from '@elastic/eui';
+import { FormattedMessage } from '@osd/i18n/react';
+import React from 'react';
+
+export const PageHeader = () => (
+ <>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ >
+);
diff --git a/src/plugins/point_in_time_management/public/components/pit_table/pit_table.tsx b/src/plugins/point_in_time_management/public/components/pit_table/pit_table.tsx
new file mode 100644
index 000000000000..2f8339547bc8
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/pit_table/pit_table.tsx
@@ -0,0 +1,230 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import React, { useEffect, useState } from 'react';
+import { RouteComponentProps, withRouter } from 'react-router-dom';
+import { useEffectOnce, useMount } from 'react-use';
+import {
+ EuiButton,
+ EuiInMemoryTable,
+ EuiPageContent,
+ EuiPageContentBody,
+ EuiSpacer,
+ EuiSearchBarProps,
+ Query,
+} from '@elastic/eui';
+import { i18n } from '@osd/i18n';
+import { FormattedMessage } from '@osd/i18n/react';
+import { getListBreadcrumbs } from '../breadcrumbs';
+import { PointInTimeManagementContext } from '../../types';
+import { useOpenSearchDashboards } from '../../../../opensearch_dashboards_react/public';
+import { getDataSources } from '../utils';
+import { EmptyState } from './empty_state';
+import { PageHeader } from './page_header';
+import { getServices, Services } from '../../services';
+// import { dataSource } from 'src/plugins/data_source/server/saved_objects';
+
+export interface DataSourceItem {
+ id: string;
+ title: string;
+ sort: string;
+}
+
+export interface PitItem {
+ pit_id: string;
+ creation_time: number;
+ keep_alive: number;
+}
+
+const PITTable = ({ history }: RouteComponentProps) => {
+ const {
+ setBreadcrumbs,
+ savedObjects,
+ notifications: { toasts },
+ http,
+ } = useOpenSearchDashboards().services;
+
+ useMount(() => {
+ setBreadcrumbs(getListBreadcrumbs());
+ });
+
+ const services: Services = getServices(http);
+
+ // TODO: update this for cases when some data source name is default
+ const defaultDataSource: DataSourceItem = { id: '', title: 'Default', sort: '0' };
+
+ // TODO: use APIs to fetch PITs and update the table and message
+ const [loading, setLoading] = useState(false);
+ const [pits, setPits] = useState([]);
+ const [message, setMessage] = useState();
+
+ const [dataSources, setDataSources] = useState([defaultDataSource]);
+ const [dataSource, setDataSource] = useState('default');
+
+ useEffectOnce(() => {
+ fetchDataSources();
+ });
+
+ useEffect(() => {
+ getPits(dataSource);
+ }, [dataSource]);
+
+ const fetchDataSources = () => {
+ getDataSources(savedObjects.client)
+ .then((fetchedDataSources) => {
+ if (fetchedDataSources?.length) {
+ setDataSources(
+ fetchedDataSources
+ .concat([defaultDataSource])
+ .sort((a, b) => a.sort.localeCompare(b.sort))
+ );
+ }
+ })
+ .catch(() => {
+ toasts.addDanger(
+ i18n.translate('pitManagement.pitTable.fetchDataSourceError', {
+ defaultMessage: 'Unable to find existing data sources',
+ })
+ );
+ });
+ };
+
+ const getPits = (dataSourceId?: string) => {
+ // setMessage(<>Loading PITs...>);
+ setLoading(true);
+ if (dataSourceId === 'default') {
+ dataSourceId = undefined;
+ }
+ services
+ .getAllPits(dataSourceId)
+ .then((fetchedPits) => {
+ setLoading(false);
+ setPits(fetchedPits?.resp?.pits);
+ })
+ .catch(() => {
+ setLoading(false);
+ toasts.addDanger(
+ i18n.translate('pitManagement.pitTable.fetchDataSourceError', {
+ defaultMessage: 'Unable to fetch point in time objects.',
+ })
+ );
+ });
+ };
+
+ const columns = [
+ {
+ field: 'pit_id',
+ name: i18n.translate('pitManagement.pitTable.nameColumnName', {
+ defaultMessage: 'Name',
+ }),
+ },
+ {
+ field: 'expires',
+ name: i18n.translate('pitManagement.pitTable.expiresColumnName', {
+ defaultMessage: 'Expires',
+ }),
+ sortable: true,
+ },
+ {
+ field: 'dataSource',
+ name: i18n.translate('pitManagement.pitTable.dataSourceColumnName', {
+ defaultMessage: 'Data Source',
+ }),
+ },
+ {
+ field: 'creation_time',
+ name: i18n.translate('pitManagement.pitTable.createdColumnName', {
+ defaultMessage: 'Created',
+ }),
+ sortable: true,
+ },
+ {
+ field: 'actions',
+ name: i18n.translate('pitManagement.pitTable.actionsColumnName', {
+ defaultMessage: 'Actions',
+ }),
+ },
+ ];
+
+ const renderToolsRight = () => {
+ return [
+
+
+ ,
+ ];
+ };
+
+ function onQueryChange({ query }: { query: Query }) {
+ if (query.ast.getFieldClauses('dataSource')) {
+ const selectedDataSource = query.ast.getFieldClauses('dataSource')[0].value as string;
+ setDataSource(selectedDataSource);
+ }
+ }
+
+ const search: EuiSearchBarProps = {
+ toolsRight: renderToolsRight(),
+ defaultQuery: 'dataSource:""',
+ onChange: onQueryChange,
+ box: {
+ incremental: true,
+ schema: true,
+ disabled: pits.length === 0,
+ },
+ filters: [
+ {
+ type: 'field_value_selection',
+ searchThreshold: 5,
+ field: 'dataSource',
+ name: i18n.translate('pitManagement.pitTable.dataSourceFilterName', {
+ defaultMessage: 'Data Source',
+ }),
+ multiSelect: false,
+ options: dataSources.map((source) => ({
+ value: source.id,
+ name: source.title,
+ view: `${source.title}`,
+ })),
+ },
+ ],
+ };
+
+ const pagination = {
+ initialPageSize: 10,
+ pageSizeOptions: [5, 10, 25, 50],
+ };
+
+ return (
+ <>
+
+
+
+
+
+
+
+ >
+ );
+};
+
+export const PITTableWithRouter = withRouter(PITTable);
diff --git a/src/plugins/point_in_time_management/public/components/utils.ts b/src/plugins/point_in_time_management/public/components/utils.ts
new file mode 100644
index 000000000000..c06490d2ec17
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/components/utils.ts
@@ -0,0 +1,30 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { SavedObjectsClientContract } from 'src/core/public';
+import { DataSourceAttributes } from 'src/plugins/data_source/common/data_sources';
+
+export async function getDataSources(savedObjectsClient: SavedObjectsClientContract) {
+ return savedObjectsClient
+ .find({
+ type: 'data-source',
+ fields: ['title', 'id'],
+ perPage: 10000,
+ })
+ .then((response) => {
+ return (
+ response.savedObjects.map((dataSource) => {
+ const id = dataSource.id;
+ const title = dataSource.get('title');
+
+ return {
+ id,
+ title,
+ sort: `${title}`,
+ };
+ }) || []
+ );
+ });
+}
diff --git a/src/plugins/point_in_time_management/public/management_app/mount_management_section.tsx b/src/plugins/point_in_time_management/public/management_app/mount_management_section.tsx
index 96c87fc73538..10aad5d5a7b7 100644
--- a/src/plugins/point_in_time_management/public/management_app/mount_management_section.tsx
+++ b/src/plugins/point_in_time_management/public/management_app/mount_management_section.tsx
@@ -6,26 +6,37 @@
import React from 'react';
import ReactDOM from 'react-dom';
import { I18nProvider } from '@osd/i18n/react';
+import { Route, Router, Switch } from 'react-router-dom';
import { ManagementAppMountParams } from '../../../management/public';
import { PointInTimeManagementStartDependencies } from '../plugin';
import { StartServicesAccessor } from '../../../../core/public';
import { PointInTimeManagementContext } from '../types';
import { OpenSearchDashboardsContextProvider } from '../../../opensearch_dashboards_react/public';
-import { EmptyState } from '../components';
+import { PITTableWithRouter } from '../components';
export async function mountManagementSection(
getStartServices: StartServicesAccessor,
params: ManagementAppMountParams
) {
- const [{ chrome, application }] = await getStartServices();
+ const [{ chrome, application, savedObjects, notifications, http }] = await getStartServices();
const deps: PointInTimeManagementContext = {
chrome,
application,
+ notifications,
+ savedObjects,
+ http,
+ setBreadcrumbs: params.setBreadcrumbs,
};
ReactDOM.render(
-
+
+
+
+
+
+
+
,
params.element
diff --git a/src/plugins/point_in_time_management/public/plugin.ts b/src/plugins/point_in_time_management/public/plugin.ts
index 53a1421926e4..ce2bb4b3c8c1 100644
--- a/src/plugins/point_in_time_management/public/plugin.ts
+++ b/src/plugins/point_in_time_management/public/plugin.ts
@@ -4,6 +4,8 @@
*/
import { i18n } from '@osd/i18n';
+import { DataPublicPluginStart } from 'src/plugins/data/public';
+import { DataSourcePluginStart } from 'src/plugins/data_source/public';
import { CoreSetup, CoreStart, Plugin } from '../../../core/public';
import { PointInTimeManagementPluginSetup, PointInTimeManagementPluginStart } from './types';
import { ManagementSetup } from '../../management/public';
@@ -12,8 +14,10 @@ export interface PointInTimeManagementSetupDependencies {
management: ManagementSetup;
}
-// eslint-disable-next-line @typescript-eslint/no-empty-interface
-export interface PointInTimeManagementStartDependencies {}
+export interface PointInTimeManagementStartDependencies {
+ data: DataPublicPluginStart;
+ dataSource?: DataSourcePluginStart;
+}
const sectionsHeader = i18n.translate('pointInTimeManagement.pointInTime.sectionsHeader', {
defaultMessage: 'Point In Time',
diff --git a/src/plugins/point_in_time_management/public/services.ts b/src/plugins/point_in_time_management/public/services.ts
new file mode 100644
index 000000000000..05bc96d30418
--- /dev/null
+++ b/src/plugins/point_in_time_management/public/services.ts
@@ -0,0 +1,27 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { CoreStart, HttpFetchError } from 'opensearch-dashboards/public';
+
+export interface Services {
+ getAllPits: (dataSourceId?: string) => Promise;
+}
+
+export function getServices(http: CoreStart['http']): Services {
+ return {
+ getAllPits: async (dataSourceId?: string) => {
+ try {
+ const response = await http.post('/api/pit/all', {
+ body: JSON.stringify({
+ dataSourceId: dataSourceId ? dataSourceId : '',
+ }),
+ });
+ return response;
+ } catch (e) {
+ return e;
+ }
+ },
+ };
+}
diff --git a/src/plugins/point_in_time_management/public/types.ts b/src/plugins/point_in_time_management/public/types.ts
index fc0c5b7038c8..c4625e843080 100644
--- a/src/plugins/point_in_time_management/public/types.ts
+++ b/src/plugins/point_in_time_management/public/types.ts
@@ -3,13 +3,19 @@
* SPDX-License-Identifier: Apache-2.0
*/
-import { ApplicationStart, ChromeStart } from 'opensearch-dashboards/public';
+import { ApplicationStart, ChromeStart, HttpSetup } from 'opensearch-dashboards/public';
+import { NotificationsStart, SavedObjectsStart } from 'src/core/public';
import { NavigationPublicPluginStart } from '../../navigation/public';
+import { ManagementAppMountParams } from '../../management/public';
import { ManagementSetup } from '../../management/public';
export interface PointInTimeManagementContext {
chrome: ChromeStart;
application: ApplicationStart;
+ notifications: NotificationsStart;
+ savedObjects: SavedObjectsStart;
+ http: HttpSetup;
+ setBreadcrumbs: ManagementAppMountParams['setBreadcrumbs'];
}
// eslint-disable-next-line @typescript-eslint/no-empty-interface
diff --git a/src/plugins/point_in_time_management/server/plugin.ts b/src/plugins/point_in_time_management/server/plugin.ts
index 876e4271d432..b4711ee6ab80 100644
--- a/src/plugins/point_in_time_management/server/plugin.ts
+++ b/src/plugins/point_in_time_management/server/plugin.ts
@@ -12,7 +12,7 @@ import {
} from '../../../core/server';
import { PointInTimeManagementPluginSetup, PointInTimeManagementPluginStart } from './types';
-import { defineRoutes } from './routes';
+import { registerPitRoutes } from './routes';
export class PointInTimeManagementPlugin
implements Plugin {
@@ -26,7 +26,7 @@ export class PointInTimeManagementPlugin
this.logger.debug('pointInTimeManagement: Setup');
const router = core.http.createRouter();
- defineRoutes(router);
+ registerPitRoutes(router);
return {};
}
diff --git a/src/plugins/point_in_time_management/server/routes/index.ts b/src/plugins/point_in_time_management/server/routes/index.ts
index b56d1871d7dd..49517bb34813 100644
--- a/src/plugins/point_in_time_management/server/routes/index.ts
+++ b/src/plugins/point_in_time_management/server/routes/index.ts
@@ -3,20 +3,4 @@
* SPDX-License-Identifier: Apache-2.0
*/
-import { IRouter } from '../../../../core/server';
-
-export function defineRoutes(router: IRouter) {
- router.get(
- {
- path: '/api/point_in_time_management/test',
- validate: false,
- },
- async (context, request, response) => {
- return response.ok({
- body: {
- time: new Date().toISOString(),
- },
- });
- }
- );
-}
+export { registerPitRoutes } from './opensearch';
diff --git a/src/plugins/point_in_time_management/server/routes/opensearch.ts b/src/plugins/point_in_time_management/server/routes/opensearch.ts
new file mode 100644
index 000000000000..05493741318a
--- /dev/null
+++ b/src/plugins/point_in_time_management/server/routes/opensearch.ts
@@ -0,0 +1,121 @@
+/*
+ * Copyright OpenSearch Contributors
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { schema } from '@osd/config-schema';
+import {
+ IRouter,
+ OpenSearchClient,
+ OpenSearchDashboardsRequest,
+ RequestHandlerContext,
+} from 'opensearch-dashboards/server';
+
+export function registerPitRoutes(router: IRouter) {
+ router.post(
+ {
+ path: '/api/pit/all',
+ validate: {
+ body: schema.object({
+ dataSourceId: schema.string(),
+ }),
+ },
+ },
+ async (context, req, res) => {
+ const client: OpenSearchClient = await getClient(req, context);
+ try {
+ const pits = await client.getAllPits({});
+ return res.ok({
+ body: {
+ ok: true,
+ resp: pits.body,
+ },
+ });
+ } catch (err: any) {
+ return res.ok({
+ body: {
+ ok: false,
+ resp: err.message,
+ },
+ });
+ }
+ }
+ );
+
+ // router.post(
+ // {
+ // path: '/api/geospatial/_search',
+ // validate: {
+ // body: schema.object({
+ // index: schema.string(),
+ // }),
+ // },
+ // },
+ // async (context, req, res) => {
+ // const client = context.core.opensearch.client.asCurrentUser;
+ // try {
+ // const { index } = req.body;
+ // const params = { index, body: {} };
+ // const results = await client.search(params);
+ // return res.ok({
+ // body: {
+ // ok: true,
+ // resp: results.body,
+ // },
+ // });
+ // } catch (err: any) {
+ // return res.ok({
+ // body: {
+ // ok: false,
+ // resp: err.message,
+ // },
+ // });
+ // }
+ // }
+ // );
+
+ // router.post(
+ // {
+ // path: '/api/geospatial/_mappings',
+ // validate: {
+ // body: schema.object({
+ // index: schema.string(),
+ // }),
+ // },
+ // },
+ // async (context, req, res) => {
+ // const client = context.core.opensearch.client.asCurrentUser;
+ // try {
+ // const { index } = req.body;
+ // const mappings = await client.indices.getMapping({ index });
+ // return res.ok({
+ // body: {
+ // ok: true,
+ // resp: mappings.body,
+ // },
+ // });
+ // } catch (err: any) {
+ // return res.ok({
+ // body: {
+ // ok: false,
+ // resp: err.message,
+ // },
+ // });
+ // }
+ // }
+ // );
+}
+
+async function getClient(
+ req: OpenSearchDashboardsRequest<
+ unknown,
+ unknown,
+ Readonly<{} & { dataSourceId: string }>,
+ 'post'
+ >,
+ context: RequestHandlerContext
+): Promise {
+ return req.body.dataSourceId && req.body.dataSourceId !== 'default' && context.dataSource
+ ? await context.dataSource.opensearch.getClient(req.body.dataSourceId)
+ : context.core.opensearch.client.asCurrentUser;
+}
diff --git a/yarn.lock b/yarn.lock
index 2728b79ee99e..1a037f5af282 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -2349,6 +2349,17 @@
ms "^2.1.3"
secure-json-parse "^2.4.0"
+"@opensearch-project/opensearch@^2.2.0":
+ version "2.2.0"
+ resolved "https://registry.yarnpkg.com/@opensearch-project/opensearch/-/opensearch-2.2.0.tgz#2a31a67242bf3bacedc9644a0c68893eb5fb9420"
+ integrity sha512-E0f2Hooruz9y+17AF69oyyruikVMAEr1TxcQBNEQV4aQnI3o0+6CjqZS+t94SCZdWRTuN7HjIIVGbaYCJDpxgA==
+ dependencies:
+ aws4 "^1.11.0"
+ debug "^4.3.1"
+ hpagent "^1.2.0"
+ ms "^2.1.3"
+ secure-json-parse "^2.4.0"
+
"@percy/cli-app@1.10.4":
version "1.10.4"
resolved "https://registry.yarnpkg.com/@percy/cli-app/-/cli-app-1.10.4.tgz#3c27b71269d41ca3bd5af6d69ec5493cf5a16d1a"
@@ -9635,6 +9646,11 @@ hpagent@^0.1.1:
resolved "https://registry.yarnpkg.com/hpagent/-/hpagent-0.1.2.tgz#cab39c66d4df2d4377dbd212295d878deb9bdaa9"
integrity sha512-ePqFXHtSQWAFXYmj+JtOTHr84iNrII4/QRlAAPPE+zqnKy4xJo7Ie1Y4kC7AdB+LxLxSTTzBMASsEcy0q8YyvQ==
+hpagent@^1.2.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/hpagent/-/hpagent-1.2.0.tgz#0ae417895430eb3770c03443456b8d90ca464903"
+ integrity sha512-A91dYTeIB6NoXG+PxTQpCCDDnfHsW9kc06Lvpu1TEe9gnd6ZFeiBoRO9JvzEv6xK7EX97/dUE8g/vBMTqTS3CA==
+
html-element-map@^1.2.0:
version "1.3.1"
resolved "https://registry.yarnpkg.com/html-element-map/-/html-element-map-1.3.1.tgz#44b2cbcfa7be7aa4ff59779e47e51012e1c73c08"