From ede3cb19c548397bfbc6790736a31362472a861a Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 24 Aug 2022 18:28:41 +0000 Subject: [PATCH 01/39] Change alignment of Snapshot Management panels in pages/Main/Main.tsx Signed-off-by: Chris Hesterman --- public/pages/Main/Main.tsx | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/public/pages/Main/Main.tsx b/public/pages/Main/Main.tsx index caa574bab..2db1e7abc 100644 --- a/public/pages/Main/Main.tsx +++ b/public/pages/Main/Main.tsx @@ -171,23 +171,29 @@ export default class Main extends Component { ( - +
+ +
)} /> ( - +
+ +
)} /> ( - +
+ +
)} /> { ( -
+
)} From a5fa7fbc85a127f225c2e435715227802671fdc5 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 24 Aug 2022 21:30:40 +0000 Subject: [PATCH 02/39] Unify vertical button alignment across panels, ContentPanel.tsx Signed-off-by: Chris Hesterman --- public/components/ContentPanel/ContentPanel.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/public/components/ContentPanel/ContentPanel.tsx b/public/components/ContentPanel/ContentPanel.tsx index 59fe0e600..5beae96e2 100644 --- a/public/components/ContentPanel/ContentPanel.tsx +++ b/public/components/ContentPanel/ContentPanel.tsx @@ -40,7 +40,7 @@ const ContentPanel: React.SFC = ({ children, }) => ( - + {typeof title === "string" ? ( From 61455936d6ea2b40517aa1ebb1631e3ab3ea63c9 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 24 Aug 2022 22:37:50 +0000 Subject: [PATCH 03/39] Update jest snapshots, add ROUTE_STYLE variable Signed-off-by: Chris Hesterman --- .../__snapshots__/ContentPanel.test.tsx.snap | 2 +- .../ChangeManagedIndices.test.tsx.snap | 2 +- .../__snapshots__/NewPolicy.test.tsx.snap | 2 +- .../__snapshots__/ChangePolicy.test.tsx.snap | 4 +-- .../ConfigurePolicy.test.tsx.snap | 2 +- .../__snapshots__/DefinePolicy.test.tsx.snap | 2 +- .../__snapshots__/CreatePolicy.test.tsx.snap | 8 ++--- .../CreateRollupForm.test.tsx.snap | 4 +-- .../CreateTransformForm.test.tsx.snap | 4 +-- .../__snapshots__/EditRollup.test.tsx.snap | 4 +-- .../__snapshots__/Indices.test.tsx.snap | 2 +- public/pages/Main/Main.tsx | 32 ++++++++++--------- .../ManagedIndices.test.tsx.snap | 2 +- .../__snapshots__/Policies.test.tsx.snap | 2 +- .../PolicySettings.test.tsx.snap | 2 +- .../containers/Snapshots/Snapshots.tsx | 1 + .../__snapshots__/EditTransform.test.tsx.snap | 6 ++-- .../__snapshots__/ISMTemplates.test.tsx.snap | 2 +- .../__snapshots__/PolicyInfo.test.tsx.snap | 2 +- .../States/__snapshots__/States.test.tsx.snap | 2 +- .../ErrorNotification.test.tsx.snap | 2 +- 21 files changed, 46 insertions(+), 43 deletions(-) diff --git a/public/components/ContentPanel/__snapshots__/ContentPanel.test.tsx.snap b/public/components/ContentPanel/__snapshots__/ContentPanel.test.tsx.snap index 2b892c14e..4ae35fa25 100644 --- a/public/components/ContentPanel/__snapshots__/ContentPanel.test.tsx.snap +++ b/public/components/ContentPanel/__snapshots__/ContentPanel.test.tsx.snap @@ -6,7 +6,7 @@ exports[` spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the create component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the create component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the edit component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the edit component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding: 20px 20px;" >
spec renders the component 1`] = ` style="padding: 20px 20px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
{ const { landingPage } = this.props; + const ROUTE_STYLE = { padding: "25px 25px" }; + return ( {(core: CoreStart | null) => @@ -171,7 +173,7 @@ export default class Main extends Component { ( -
+
{ ( -
+
)} @@ -191,7 +193,7 @@ export default class Main extends Component { ( -
+
)} @@ -273,7 +275,7 @@ export default class Main extends Component { ( -
+
)} @@ -281,7 +283,7 @@ export default class Main extends Component { ( -
+
)} @@ -289,7 +291,7 @@ export default class Main extends Component { ( -
+
)} @@ -297,7 +299,7 @@ export default class Main extends Component { ( -
+
)} @@ -305,7 +307,7 @@ export default class Main extends Component { ( -
+
)} @@ -313,7 +315,7 @@ export default class Main extends Component { ( -
+
)} @@ -321,7 +323,7 @@ export default class Main extends Component { ( -
+
)} @@ -329,7 +331,7 @@ export default class Main extends Component { ( -
+
)} @@ -337,7 +339,7 @@ export default class Main extends Component { ( -
+
)} @@ -345,7 +347,7 @@ export default class Main extends Component { ( -
+
{ ( -
+
)} @@ -366,7 +368,7 @@ export default class Main extends Component { ( -
+
)} diff --git a/public/pages/ManagedIndices/containers/ManagedIndices/__snapshots__/ManagedIndices.test.tsx.snap b/public/pages/ManagedIndices/containers/ManagedIndices/__snapshots__/ManagedIndices.test.tsx.snap index ef9d37583..2bc6ce8f9 100644 --- a/public/pages/ManagedIndices/containers/ManagedIndices/__snapshots__/ManagedIndices.test.tsx.snap +++ b/public/pages/ManagedIndices/containers/ManagedIndices/__snapshots__/ManagedIndices.test.tsx.snap @@ -45,7 +45,7 @@ exports[` spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
Take snapshot , + Restore, ]; const subTitleText = ( diff --git a/public/pages/Transforms/containers/Transforms/__snapshots__/EditTransform.test.tsx.snap b/public/pages/Transforms/containers/Transforms/__snapshots__/EditTransform.test.tsx.snap index 5768aaffb..088b2fd32 100644 --- a/public/pages/Transforms/containers/Transforms/__snapshots__/EditTransform.test.tsx.snap +++ b/public/pages/Transforms/containers/Transforms/__snapshots__/EditTransform.test.tsx.snap @@ -17,7 +17,7 @@ exports[` spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
spec renders the component 1`] = ` style="padding-left: 0px; padding-right: 0px;" >
Date: Wed, 24 Aug 2022 23:17:45 +0000 Subject: [PATCH 04/39] Add placeholder restore button to Snapshots panel Signed-off-by: Chris Hesterman --- public/pages/Snapshots/containers/Snapshots/Snapshots.tsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index eccc32b7f..b41e09ba1 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -269,7 +269,9 @@ export default class Snapshots extends Component Take snapshot , - Restore, + + Restore + , ]; const subTitleText = ( From 8001349b23097cbed299ec2d0d88f9d60a13d27b Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Fri, 26 Aug 2022 22:40:10 +0000 Subject: [PATCH 05/39] Comment out line 20 rollups_spec.js in cypress/integration/ Signed-off-by: Chris Hesterman --- cypress/integration/rollups_spec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cypress/integration/rollups_spec.js b/cypress/integration/rollups_spec.js index 70aa508e2..d4fbb1aa3 100644 --- a/cypress/integration/rollups_spec.js +++ b/cypress/integration/rollups_spec.js @@ -17,7 +17,7 @@ describe("Rollups", () => { cy.visit(`${Cypress.env("opensearch_dashboards")}/app/home#/tutorial_directory/sampleData`); // Click on "Sample data" tab - cy.contains("Sample data").click({ force: true }); + // cy.contains("Sample data").click({ force: true }); // Load sample eCommerce data cy.get(`button[data-test-subj="addSampleDataSetecommerce"]`).click({ force: true }); From f27c4e471df1c5e53dedd5fe1682bb637ac3317f Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Fri, 26 Aug 2022 23:11:02 +0000 Subject: [PATCH 06/39] Remove unused code and comment cypress/integration/rollups_spec.js Signed-off-by: Chris Hesterman --- cypress/integration/rollups_spec.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/cypress/integration/rollups_spec.js b/cypress/integration/rollups_spec.js index d4fbb1aa3..896a06271 100644 --- a/cypress/integration/rollups_spec.js +++ b/cypress/integration/rollups_spec.js @@ -16,8 +16,6 @@ describe("Rollups", () => { // Go to sample data page cy.visit(`${Cypress.env("opensearch_dashboards")}/app/home#/tutorial_directory/sampleData`); - // Click on "Sample data" tab - // cy.contains("Sample data").click({ force: true }); // Load sample eCommerce data cy.get(`button[data-test-subj="addSampleDataSetecommerce"]`).click({ force: true }); From 391159fe84d1da9fd42d89ac58806d47a99e0760 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 10:42:54 -0700 Subject: [PATCH 07/39] Starting adaptation/use of existing code for Restore functionality Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 220 ++++++++++++++++++ .../components/RestoreSnapshotFlyout/index.ts | 8 + 2 files changed, 228 insertions(+) create mode 100644 public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx create mode 100644 public/pages/Snapshots/components/RestoreSnapshotFlyout/index.ts diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx new file mode 100644 index 000000000..ac55a625f --- /dev/null +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -0,0 +1,220 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { + EuiAccordion, + EuiComboBoxOptionOption, + EuiFieldText, + EuiFlyout, + EuiFlyoutBody, + EuiFlyoutFooter, + EuiFlyoutHeader, + EuiFormRow, + EuiSpacer, + EuiTitle, +} from "@elastic/eui"; +import _ from "lodash"; + +import React, { Component } from "react"; +import FlyoutFooter from "../../../VisualCreatePolicy/components/FlyoutFooter"; +import { CoreServicesContext } from "../../../../components/core_services"; +import { IndexService, SnapshotManagementService } from "../../../../services"; +import { getErrorMessage, wildcardOption } from "../../../../utils/helpers"; +import { IndexItem, Snapshot } from "../../../../../models/interfaces"; +import { CatRepository } from "../../../../../server/models/interfaces"; +import CustomLabel from "../../../../components/CustomLabel"; +import { getEmptySnapshot } from "../CreateSnapshotFlyout/constants"; +import SnapshotAdvancedSettings from "../../../CreateSnapshotPolicy/components/SnapshotAdvancedSettings"; +import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; +import { ChangeEvent } from "react"; +import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; + +interface RestoreSnapshotProps { + snapshotManagementService: SnapshotManagementService; + indexService: IndexService; + onCloseFlyout: () => void; + restoreSnapshot: (snapshotId: string, repository: string) => void; +} + +interface RestoreSnapshotState { + indexOptions: EuiComboBoxOptionOption[]; + selectedIndexOptions: EuiComboBoxOptionOption[]; + + repositories: CatRepository[]; + selectedRepoValue: string; + + snapshot: Snapshot; + snapshotId: string; + + repoError: string; + snapshotIdError: string; +} + +export default class RestoreSnapshotFlyout extends Component { + static contextType = CoreServicesContext; + constructor(props: RestoreSnapshotProps) { + super(props); + + this.state = { + indexOptions: [], + selectedIndexOptions: [], + repositories: [], + selectedRepoValue: "", + snapshot: getEmptySnapshot(), + snapshotId: "", + repoError: "", + snapshotIdError: "", + }; + } + + async componentDidMount() { + await this.getIndexOptions(""); + await this.getRepos(); + } + + onClickAction = () => { + const { restoreSnapshot } = this.props; + const { snapshotId, selectedRepoValue } = this.state; + let repoError = ""; + if (!snapshotId.trim()) { + this.setState({ snapshotIdError: "Required" }); + return; + } + if (!selectedRepoValue) { + repoError = ERROR_PROMPT.REPO; + this.setState({ repoError }); + return; + } + restoreSnapshot(snapshotId, selectedRepoValue); + }; + + onIndicesSelectionChange = (selectedOptions: EuiComboBoxOptionOption[]) => { + const selectedIndexOptions = selectedOptions.map((o) => o.label); + let newJSON = this.state.snapshot; + newJSON.indices = selectedIndexOptions.toString(); + this.setState({ snapshot: newJSON, selectedIndexOptions: selectedOptions }); + }; + + getIndexOptions = async (searchValue: string) => { + const { indexService } = this.props; + this.setState({ indexOptions: [] }); + try { + const optionsResponse = await indexService.getDataStreamsAndIndicesNames(searchValue); + if (optionsResponse.ok) { + // Adding wildcard to search value + const options = searchValue.trim() ? [{ label: wildcardOption(searchValue) }, { label: searchValue }] : []; + // const dataStreams = optionsResponse.response.dataStreams.map((label) => ({ label })); + const indices = optionsResponse.response.indices.map((label) => ({ label })); + // this.setState({ indexOptions: options.concat(dataStreams, indices)}); + this.setState({ indexOptions: options.concat(indices) }); + } else { + if (optionsResponse.error.startsWith("[index_not_found_exception]")) { + this.context.notifications.toasts.addDanger("No index available"); + } else { + this.context.notifications.toasts.addDanger(optionsResponse.error); + } + } + } catch (err) { + this.context.notifications.toasts.addDanger(getErrorMessage(err, "There was a problem fetching index options.")); + } + }; + + onCreateOption = (searchValue: string, options: Array>) => { + const normalizedSearchValue = searchValue.trim().toLowerCase(); + if (!normalizedSearchValue) { + return; + } + const newOption = { + label: searchValue, + }; + // Create the option if it doesn't exist. + if (options.findIndex((option) => option.label.trim().toLowerCase() === normalizedSearchValue) === -1) { + this.setState({ indexOptions: [...this.state.indexOptions, newOption] }); + } + + const selectedIndexOptions = [...this.state.selectedIndexOptions, newOption]; + this.setState({ selectedIndexOptions: selectedIndexOptions }); + }; + + getRepos = async () => { + try { + const { snapshotManagementService } = this.props; + const response = await snapshotManagementService.catRepositories(); + if (response.ok) { + const selectedRepoValue = response.response.length > 0 ? response.response[0].id : ""; + this.setState({ repositories: response.response, selectedRepoValue }); + } else { + this.context.notifications.toasts.addDanger(response.error); + } + } catch (err) { + this.context.notifications.toasts.addDanger(getErrorMessage(err, "There was a problem loading the snapshots.")); + } + }; + + onRepoSelectionChange = (e: React.ChangeEvent) => { + const selectedRepo = e.target.value; + let repoError = ""; + if (!selectedRepo) { + repoError = ERROR_PROMPT.REPO; + } + this.setState({ selectedRepoValue: selectedRepo, repoError }); + }; + + // onIncludeGlobalStateToggle = (e: ChangeEvent) => { + // this.setState({ snapshot: _.set(this.state.snapshot, "include_global_state", e.target.checked) }); + // }; + + // onIgnoreUnavailableToggle = (e: ChangeEvent) => { + // this.setState({ snapshot: _.set(this.state.snapshot, "ignore_unavailable", e.target.checked) }); + // }; + + // onPartialToggle = (e: ChangeEvent) => { + // const { checked } = e.target; + // let newJSON = this.state.snapshot; + // newJSON.partial = checked; + // this.setState({ snapshot: newJSON }); + // }; + + render() { + const { onCloseFlyout } = this.props; + const { indexOptions, selectedIndexOptions, repositories, selectedRepoValue, snapshotId, repoError, snapshotIdError } = this.state; + + const repoOptions = repositories.map((r) => ({ value: r.id, text: r.id })); + + return ( + + + +

Restore snapshot

+
+
+ + + + + + + + + + + + + + +
+ ); + } +} diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/index.ts b/public/pages/Snapshots/components/RestoreSnapshotFlyout/index.ts new file mode 100644 index 000000000..b5a24d1da --- /dev/null +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import RestoreSnapshotFlyout from "./RestoreSnapshotFlyout"; + +export default RestoreSnapshotFlyout; From 983ed48035a72fbcde1689ef7ce83a0bf1bd9aee Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 10:53:11 -0700 Subject: [PATCH 08/39] Adapt Snapshots.tsx to include RestoreSnapshotFlyout Signed-off-by: Chris Hesterman --- .../containers/Snapshots/Snapshots.tsx | 37 +++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index b41e09ba1..ec8929b89 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -15,6 +15,7 @@ import { CatSnapshotWithRepoAndPolicy as SnapshotsWithRepoAndPolicy } from "../. import { ContentPanel } from "../../../../components/ContentPanel"; import SnapshotFlyout from "../../components/SnapshotFlyout/SnapshotFlyout"; import CreateSnapshotFlyout from "../../components/CreateSnapshotFlyout/CreateSnapshotFlyout"; +import RestoreSnapshotFlyout from "../../components/RestoreSnapshotFlyout/RestoreSnapshotFlyout"; import { Snapshot } from "../../../../../models/interfaces"; import { BREADCRUMBS, RESTORE_SNAPSHOT_DOCUMENTATION_URL, ROUTES } from "../../../../utils/constants"; import { renderTimestampMillis } from "../../../SnapshotPolicies/helpers"; @@ -38,6 +39,7 @@ interface SnapshotsState { flyoutSnapshotRepo: string; showCreateFlyout: boolean; + showRestoreFlyout: boolean; message?: React.ReactNode; @@ -60,6 +62,7 @@ export default class Snapshots extends Component flyoutSnapshotId: "", flyoutSnapshotRepo: "", showCreateFlyout: false, + showRestoreFlyout: false, message: null, isDeleteModalVisible: false, }; @@ -215,6 +218,30 @@ export default class Snapshots extends Component } }; + restoreSnapshot = async (snapshotId: string, repository: string) => { + try { + const { snapshotManagementService } = this.props; + const response = await snapshotManagementService.restoreSnapshot(snapshotId, repository); + if (response.ok) { + this.context.notifications.toasts.addSuccess(`Restored snapshot ${snapshotId} to repository ${repository}.`); + } else { + this.context.notifications.toasts.addDanger(response.error); + } + } catch (err) { + this.context.notifications.toasts.addDanger(getErrorMessage(err, "There was a problem restoring the snapshot.")); + } + }; + + onClickRestore = async () => { + const { selectedItems } = this.state; + await this.restoreSnapshot(selectedItems[0].id, selectedItems[0].repository); + this.setState({ showRestoreFlyout: true }); + }; + + onCloseRestoreFlyout = () => { + this.setState({ showRestoreFlyout: false }); + }; + render() { const { snapshots, @@ -225,6 +252,7 @@ export default class Snapshots extends Component flyoutSnapshotId, flyoutSnapshotRepo, showCreateFlyout, + showRestoreFlyout, isDeleteModalVisible, } = this.state; @@ -326,6 +354,15 @@ export default class Snapshots extends Component /> )} + {showRestoreFlyout && ( + + )} + {isDeleteModalVisible && ( Date: Mon, 29 Aug 2022 11:01:04 -0700 Subject: [PATCH 09/39] Add restoreSnapshot method to SMservice,RestoreSnapshotResponse int Signed-off-by: Chris Hesterman --- public/services/SnapshotManagementService.ts | 7 +++++++ server/models/interfaces.ts | 4 ++++ 2 files changed, 11 insertions(+) diff --git a/public/services/SnapshotManagementService.ts b/public/services/SnapshotManagementService.ts index 7035bed04..e985381d0 100644 --- a/public/services/SnapshotManagementService.ts +++ b/public/services/SnapshotManagementService.ts @@ -13,6 +13,7 @@ import { CreateRepositoryBody, AcknowledgedResponse, CreateSnapshotResponse, + RestoreSnapshotResponse, } from "../../server/models/interfaces"; import { ServerResponse } from "../../server/models/types"; import { DocumentSMPolicy, DocumentSMPolicyWithMetadata, SMPolicy, Snapshot } from "../../models/interfaces"; @@ -50,6 +51,12 @@ export default class SnapshotManagementService { return response; }; + restoreSnapshot = async (snapshotId: string, repository: string): Promise> => { + let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; + const response = (await this.httpClient.put(url, { query: { repository } })) as ServerResponse; + return response; + }; + createPolicy = async (policyId: string, policy: SMPolicy): Promise> => { let url = `..${NODE_API.SMPolicies}/${policyId}`; const response = (await this.httpClient.post(url, { body: JSON.stringify(policy) })) as ServerResponse; diff --git a/server/models/interfaces.ts b/server/models/interfaces.ts index f93626352..9592cc7a5 100644 --- a/server/models/interfaces.ts +++ b/server/models/interfaces.ts @@ -386,6 +386,10 @@ export interface CreateSnapshotResponse { snapshot: GetSnapshot; } +export interface RestoreSnapshotResponse { + snapshot: GetSnapshot; +} + export interface GetSnapshot { snapshot: string; uuid: string; From b3141bd7758db4b7d12c8fe82c4bdd791375eac9 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 11:08:07 -0700 Subject: [PATCH 10/39] Implement RestoreSnapshotFlyout open/close Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx | 13 +------------ .../Snapshots/containers/Snapshots/Snapshots.tsx | 4 ++-- 2 files changed, 3 insertions(+), 14 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index ac55a625f..b57614ff3 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -3,18 +3,7 @@ * SPDX-License-Identifier: Apache-2.0 */ -import { - EuiAccordion, - EuiComboBoxOptionOption, - EuiFieldText, - EuiFlyout, - EuiFlyoutBody, - EuiFlyoutFooter, - EuiFlyoutHeader, - EuiFormRow, - EuiSpacer, - EuiTitle, -} from "@elastic/eui"; +import { EuiComboBoxOptionOption, EuiFlyout, EuiFlyoutBody, EuiFlyoutFooter, EuiFlyoutHeader, EuiSpacer, EuiTitle } from "@elastic/eui"; import _ from "lodash"; import React, { Component } from "react"; diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index ec8929b89..e57c35afd 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -297,7 +297,7 @@ export default class Snapshots extends Component Take snapshot , - + Restore , ]; @@ -358,7 +358,7 @@ export default class Snapshots extends Component )} From 7bfdb86956e46958d584a5cd7bc08a2245ceb49c Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 11:18:06 -0700 Subject: [PATCH 11/39] Make Snapshot name appear on RestoreSnapshotFlyout Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx | 8 +++++--- public/pages/Snapshots/containers/Snapshots/Snapshots.tsx | 1 + 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index b57614ff3..d82d3e2ed 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -25,6 +25,7 @@ interface RestoreSnapshotProps { indexService: IndexService; onCloseFlyout: () => void; restoreSnapshot: (snapshotId: string, repository: string) => void; + snapshotId: string; } interface RestoreSnapshotState { @@ -167,8 +168,8 @@ export default class RestoreSnapshotFlyout extends Component ({ value: r.id, text: r.id })); @@ -176,12 +177,13 @@ export default class RestoreSnapshotFlyout extends Component -

Restore snapshot

+

Restore snapshot

+

{snapshotId}

diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index e57c35afd..98318683c 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -360,6 +360,7 @@ export default class Snapshots extends Component indexService={this.props.indexService} onCloseFlyout={this.onCloseRestoreFlyout} restoreSnapshot={this.restoreSnapshot} + snapshotId={snapshots[0].id} /> )} From 845cca2129f296cf4f9681c8d3a1c5dcb5c12197 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 11:29:54 -0700 Subject: [PATCH 12/39] Add/adapt restoreSnapshot to server/SnapshotManagementService Signed-off-by: Chris Hesterman --- server/services/SnapshotManagementService.ts | 32 ++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/server/services/SnapshotManagementService.ts b/server/services/SnapshotManagementService.ts index 84d405fca..014ad2762 100644 --- a/server/services/SnapshotManagementService.ts +++ b/server/services/SnapshotManagementService.ts @@ -23,6 +23,7 @@ import { GetRepositoryResponse, AcknowledgedResponse, CreateSnapshotResponse, + RestoreSnapshotResponse, } from "../models/interfaces"; import { FailedServerResponse, ServerResponse } from "../models/types"; @@ -187,6 +188,37 @@ export default class SnapshotManagementService { } }; + restoreSnapshot = async ( + context: RequestHandlerContext, + request: OpenSearchDashboardsRequest, + response: OpenSearchDashboardsResponseFactory + ): Promise>> => { + try { + const { id } = request.params as { + id: string; + }; + const { repository } = request.query as { + repository: string; + }; + const params = { + repository: repository, + snapshot: id, + }; + const { callAsCurrentUser: callWithRequest } = this.osDriver.asScoped(request); + const resp: RestoreSnapshotResponse = await callWithRequest("snapshot.restore", params); + + return response.custom({ + statusCode: 200, + body: { + ok: true, + response: resp, + }, + }); + } catch (err) { + return this.errorResponse(response, err, "restoreSnapshot"); + } + }; + createPolicy = async ( context: RequestHandlerContext, request: OpenSearchDashboardsRequest, From 703d93b31c90c69ac8dd42f64406d945bf0fb06f Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 11:38:26 -0700 Subject: [PATCH 13/39] Add route for restoreSnapshot in server/routes.ts Signed-off-by: Chris Hesterman --- server/routes/snapshotManagement.ts | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/server/routes/snapshotManagement.ts b/server/routes/snapshotManagement.ts index 13cf02a4b..ba64335bb 100644 --- a/server/routes/snapshotManagement.ts +++ b/server/routes/snapshotManagement.ts @@ -65,6 +65,21 @@ export default function (services: NodeServices, router: IRouter) { snapshotManagementService.createSnapshot ); + router.post( + { + path: `${NODE_API._SNAPSHOTS}/{id}`, + validate: { + params: schema.object({ + id: schema.string(), + }), + query: schema.object({ + repository: schema.string(), + }), + }, + }, + snapshotManagementService.restoreSnapshot + ); + router.post( { path: `${NODE_API.SMPolicies}/{id}`, From 78095b705c1b63c0255eb2f436e944512c617dd3 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 15:00:21 -0700 Subject: [PATCH 14/39] Rudimentary restore from snapshot functionality reached, buggy Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 73 +++++++------------ .../SnapshotFlyout/SnapshotFlyout.tsx | 1 + .../containers/Snapshots/Snapshots.tsx | 2 - public/services/SnapshotManagementService.ts | 2 +- 4 files changed, 30 insertions(+), 48 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index d82d3e2ed..7e7d484ee 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -5,19 +5,16 @@ import { EuiComboBoxOptionOption, EuiFlyout, EuiFlyoutBody, EuiFlyoutFooter, EuiFlyoutHeader, EuiSpacer, EuiTitle } from "@elastic/eui"; import _ from "lodash"; - import React, { Component } from "react"; import FlyoutFooter from "../../../VisualCreatePolicy/components/FlyoutFooter"; import { CoreServicesContext } from "../../../../components/core_services"; import { IndexService, SnapshotManagementService } from "../../../../services"; -import { getErrorMessage, wildcardOption } from "../../../../utils/helpers"; -import { IndexItem, Snapshot } from "../../../../../models/interfaces"; -import { CatRepository } from "../../../../../server/models/interfaces"; +import { getErrorMessage } from "../../../../utils/helpers"; +import { IndexItem } from "../../../../../models/interfaces"; +import { CatRepository, GetSnapshot } from "../../../../../server/models/interfaces"; import CustomLabel from "../../../../components/CustomLabel"; -import { getEmptySnapshot } from "../CreateSnapshotFlyout/constants"; import SnapshotAdvancedSettings from "../../../CreateSnapshotPolicy/components/SnapshotAdvancedSettings"; import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; -import { ChangeEvent } from "react"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; interface RestoreSnapshotProps { @@ -35,7 +32,7 @@ interface RestoreSnapshotState { repositories: CatRepository[]; selectedRepoValue: string; - snapshot: Snapshot; + snapshot: GetSnapshot | null; snapshotId: string; repoError: string; @@ -52,7 +49,7 @@ export default class RestoreSnapshotFlyout extends Component { - const { restoreSnapshot } = this.props; - const { snapshotId, selectedRepoValue } = this.state; + const { restoreSnapshot, snapshotId } = this.props; + const { selectedRepoValue } = this.state; let repoError = ""; + console.log("clicked"); if (!snapshotId.trim()) { this.setState({ snapshotIdError: "Required" }); + return; } if (!selectedRepoValue) { repoError = ERROR_PROMPT.REPO; this.setState({ repoError }); + return; } restoreSnapshot(snapshotId, selectedRepoValue); @@ -83,34 +83,32 @@ export default class RestoreSnapshotFlyout extends Component[]) => { const selectedIndexOptions = selectedOptions.map((o) => o.label); let newJSON = this.state.snapshot; - newJSON.indices = selectedIndexOptions.toString(); + // newJSON.indices = selectedIndexOptions.toString(); this.setState({ snapshot: newJSON, selectedIndexOptions: selectedOptions }); }; - getIndexOptions = async (searchValue: string) => { - const { indexService } = this.props; - this.setState({ indexOptions: [] }); + getSnapshot = async (snapshotId: string, repository: string) => { + console.log("flyout", [repository, snapshotId]); + console.log("repositories", [...this.state.repositories]); + const { snapshotManagementService } = this.props; try { - const optionsResponse = await indexService.getDataStreamsAndIndicesNames(searchValue); - if (optionsResponse.ok) { - // Adding wildcard to search value - const options = searchValue.trim() ? [{ label: wildcardOption(searchValue) }, { label: searchValue }] : []; - // const dataStreams = optionsResponse.response.dataStreams.map((label) => ({ label })); - const indices = optionsResponse.response.indices.map((label) => ({ label })); - // this.setState({ indexOptions: options.concat(dataStreams, indices)}); - this.setState({ indexOptions: options.concat(indices) }); - } else { - if (optionsResponse.error.startsWith("[index_not_found_exception]")) { - this.context.notifications.toasts.addDanger("No index available"); - } else { - this.context.notifications.toasts.addDanger(optionsResponse.error); - } + const response = await snapshotManagementService.getSnapshot(snapshotId, repository); + console.log("my response", response); + if (response.ok) { + const newOptions = response.response.indices.map((index) => { + return { label: index }; + }); + this.setState({ snapshot: response.response, indexOptions: [...newOptions] }); } } catch (err) { - this.context.notifications.toasts.addDanger(getErrorMessage(err, "There was a problem fetching index options.")); + this.context.notifications.toasts.addDanger(getErrorMessage(err, "There was a problem loading the snapshot.")); } }; + getIndexOptions = () => { + this.getSnapshot(this.props.snapshotId, this.state.selectedRepoValue); + }; + onCreateOption = (searchValue: string, options: Array>) => { const normalizedSearchValue = searchValue.trim().toLowerCase(); if (!normalizedSearchValue) { @@ -152,21 +150,6 @@ export default class RestoreSnapshotFlyout extends Component) => { - // this.setState({ snapshot: _.set(this.state.snapshot, "include_global_state", e.target.checked) }); - // }; - - // onIgnoreUnavailableToggle = (e: ChangeEvent) => { - // this.setState({ snapshot: _.set(this.state.snapshot, "ignore_unavailable", e.target.checked) }); - // }; - - // onPartialToggle = (e: ChangeEvent) => { - // const { checked } = e.target; - // let newJSON = this.state.snapshot; - // newJSON.partial = checked; - // this.setState({ snapshot: newJSON }); - // }; - render() { const { onCloseFlyout, snapshotId } = this.props; const { indexOptions, selectedIndexOptions, repositories, selectedRepoValue, repoError } = this.state; diff --git a/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx b/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx index 8901f9ef6..7864dafbc 100644 --- a/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx @@ -55,6 +55,7 @@ export default class SnapshotFlyout extends Component { + console.log("flyout"); const { snapshotManagementService } = this.props; try { const response = await snapshotManagementService.getSnapshot(snapshotId, repository); diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index 98318683c..4bbec9c5b 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -233,8 +233,6 @@ export default class Snapshots extends Component }; onClickRestore = async () => { - const { selectedItems } = this.state; - await this.restoreSnapshot(selectedItems[0].id, selectedItems[0].repository); this.setState({ showRestoreFlyout: true }); }; diff --git a/public/services/SnapshotManagementService.ts b/public/services/SnapshotManagementService.ts index e985381d0..564358e66 100644 --- a/public/services/SnapshotManagementService.ts +++ b/public/services/SnapshotManagementService.ts @@ -53,7 +53,7 @@ export default class SnapshotManagementService { restoreSnapshot = async (snapshotId: string, repository: string): Promise> => { let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; - const response = (await this.httpClient.put(url, { query: { repository } })) as ServerResponse; + const response = (await this.httpClient.post(url, { query: { repository } })) as ServerResponse; return response; }; From e16528b2a82e8200455ab543e4722d06a001a724 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 29 Aug 2022 16:27:39 -0700 Subject: [PATCH 15/39] Fix index list-snapshot restore, restrict restore to single selection Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx | 1 + .../Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx | 1 - public/pages/Snapshots/containers/Snapshots/Snapshots.tsx | 4 ++-- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 7e7d484ee..b70e772b2 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -78,6 +78,7 @@ export default class RestoreSnapshotFlyout extends Component[]) => { diff --git a/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx b/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx index 7864dafbc..8901f9ef6 100644 --- a/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/SnapshotFlyout/SnapshotFlyout.tsx @@ -55,7 +55,6 @@ export default class SnapshotFlyout extends Component { - console.log("flyout"); const { snapshotManagementService } = this.props; try { const response = await snapshotManagementService.getSnapshot(snapshotId, repository); diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index 4bbec9c5b..f67007921 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -295,7 +295,7 @@ export default class Snapshots extends Component Take snapshot , - + Restore , ]; @@ -358,7 +358,7 @@ export default class Snapshots extends Component indexService={this.props.indexService} onCloseFlyout={this.onCloseRestoreFlyout} restoreSnapshot={this.restoreSnapshot} - snapshotId={snapshots[0].id} + snapshotId={selectedItems[0].id} /> )} From 75e1dfeb03176838c250d41117ba96bb6ca2bf05 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Tue, 6 Sep 2022 14:53:38 -0700 Subject: [PATCH 16/39] Remove console.logs, commented out code Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index b70e772b2..af5c4ecaf 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -65,7 +65,7 @@ export default class RestoreSnapshotFlyout extends Component[]) => { const selectedIndexOptions = selectedOptions.map((o) => o.label); let newJSON = this.state.snapshot; - // newJSON.indices = selectedIndexOptions.toString(); + this.setState({ snapshot: newJSON, selectedIndexOptions: selectedOptions }); }; From 02d651cc2abfe019d9b94def2cfdb1312e7145d7 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Tue, 30 Aug 2022 11:20:01 -0700 Subject: [PATCH 17/39] Create Advanced options accordion for Snapshot restore. Signed-off-by: Chris Hesterman Currently only visually functional. TODO - make it apply the options Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 93 +++++++++++--- .../SnapshotRestoreAdvancedOptions.tsx | 114 ++++++++++++++++++ .../SnapshotRestoreAdvancedOptions/index.ts | 8 ++ 3 files changed, 198 insertions(+), 17 deletions(-) create mode 100644 public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx create mode 100644 public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/index.ts diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index af5c4ecaf..268f3356b 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -3,9 +3,21 @@ * SPDX-License-Identifier: Apache-2.0 */ -import { EuiComboBoxOptionOption, EuiFlyout, EuiFlyoutBody, EuiFlyoutFooter, EuiFlyoutHeader, EuiSpacer, EuiTitle } from "@elastic/eui"; +import { + EuiComboBoxOptionOption, + EuiFlyout, + EuiFlyoutBody, + EuiFlyoutFooter, + EuiFlyoutHeader, + EuiSpacer, + EuiTitle, + EuiFlexGroup, + EuiFlexItem, + EuiRadioGroup, + EuiAccordion, +} from "@elastic/eui"; import _ from "lodash"; -import React, { Component } from "react"; +import React, { Component, ChangeEvent } from "react"; import FlyoutFooter from "../../../VisualCreatePolicy/components/FlyoutFooter"; import { CoreServicesContext } from "../../../../components/core_services"; import { IndexService, SnapshotManagementService } from "../../../../services"; @@ -13,7 +25,7 @@ import { getErrorMessage } from "../../../../utils/helpers"; import { IndexItem } from "../../../../../models/interfaces"; import { CatRepository, GetSnapshot } from "../../../../../server/models/interfaces"; import CustomLabel from "../../../../components/CustomLabel"; -import SnapshotAdvancedSettings from "../../../CreateSnapshotPolicy/components/SnapshotAdvancedSettings"; +import SnapshotRestoreAdvancedOptions from "../SnapshotRestoreAdvancedOptions"; import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; @@ -151,14 +163,38 @@ export default class RestoreSnapshotFlyout extends Component) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "restore_aliases", e.target.checked) }); + }; + + onRestoreClusterStateToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "restore_cluster_state", e.target.checked) }); + }; + + onIgnoreUnavailableToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "ignore_unavailable", e.target.checked) }); + }; + + onRestorePartialToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "restore_partial", e.target.checked) }); + }; + + onCustomizeIndexSettingsToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "customize_index_settings", e.target.checked) }); + }; + + onIgnoreIndexSettingsToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "ignore_index_settings", e.target.checked) }); + }; + render() { - const { onCloseFlyout, snapshotId } = this.props; - const { indexOptions, selectedIndexOptions, repositories, selectedRepoValue, repoError } = this.state; + const { onCloseFlyout } = this.props; + const { indexOptions, selectedIndexOptions, repositories, selectedRepoValue, restoreSpecific, repoError, snapshot } = this.state; const repoOptions = repositories.map((r) => ({ value: r.id, text: r.id })); return ( - +

Restore snapshot

@@ -171,17 +207,40 @@ export default class RestoreSnapshotFlyout extends Component - + {restoreSpecific && ( + + )} + + + + + + +
diff --git a/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx b/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx new file mode 100644 index 000000000..9de6f79ca --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx @@ -0,0 +1,114 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { EuiCheckbox, EuiSpacer, EuiText } from "@elastic/eui"; +import CustomLabel from "../../../../components/CustomLabel"; +import React, { ChangeEvent } from "react"; + +interface SnapshotAdvancedOptionsProps { + restoreAliases: boolean; + onRestoreAliasesToggle: (e: ChangeEvent) => void; + restoreClusterState: boolean; + onRestoreClusterStateToggle: (e: ChangeEvent) => void; + ignoreUnavailable: boolean; + onIgnoreUnavailableToggle: (e: ChangeEvent) => void; + restorePartial: boolean; + onRestorePartialToggle: (e: ChangeEvent) => void; + customizeIndexSettings: boolean; + onCustomizeIndexSettingsToggle: (e: ChangeEvent) => void; + ignoreIndexSettings: boolean; + onIgnoreIndexSettingsToggle: (e: ChangeEvent) => void; + width?: string; +} + +const SnapshotRestoreAdvancedOptions = ({ + restoreAliases, + onRestoreAliasesToggle, + ignoreUnavailable, + onIgnoreUnavailableToggle, + restoreClusterState, + onRestoreClusterStateToggle, + restorePartial, + onRestorePartialToggle, + customizeIndexSettings, + onCustomizeIndexSettingsToggle, + ignoreIndexSettings, + onIgnoreIndexSettingsToggle, + width, +}: SnapshotAdvancedOptionsProps) => ( +
+ } + checked={restoreAliases} + onChange={onRestoreAliasesToggle} + /> + + + + } + checked={restoreClusterState} + onChange={onRestoreClusterStateToggle} + /> + + + + + } + checked={ignoreUnavailable} + onChange={onIgnoreUnavailableToggle} + /> + + + + } + checked={restorePartial} + onChange={onRestorePartialToggle} + /> + + + +
Custom index settings
+ +

+ By default, index settings are restored from indices in snapshots. You can choose to +
+ customize index settings on restore. +

+
+ + + + } + checked={customizeIndexSettings} + onChange={onCustomizeIndexSettingsToggle} + /> + + + + + } + checked={ignoreIndexSettings} + onChange={onIgnoreIndexSettingsToggle} + /> +
+); + +export default SnapshotRestoreAdvancedOptions; diff --git a/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/index.ts b/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/index.ts new file mode 100644 index 000000000..940d333c3 --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import SnapshotRestoreAdvancedOptions from "./SnapshotRestoreAdvancedOptions"; + +export default SnapshotRestoreAdvancedOptions; From bf4a4a56e29a467c67b96d45bef4b8b8126f6c6d Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Tue, 30 Aug 2022 13:19:58 -0700 Subject: [PATCH 18/39] Add initial restore/rename options to ui. Only visual functionality Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 46 ++++++++- .../SnapshotRestoreInitialOptions.tsx | 96 +++++++++++++++++++ .../SnapshotRestoreInitialOptions/index.ts | 8 ++ 3 files changed, 145 insertions(+), 5 deletions(-) create mode 100644 public/pages/Snapshots/components/SnapshotRestoreInitialOptions/SnapshotRestoreInitialOptions.tsx create mode 100644 public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 268f3356b..ca8866990 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -13,7 +13,6 @@ import { EuiTitle, EuiFlexGroup, EuiFlexItem, - EuiRadioGroup, EuiAccordion, } from "@elastic/eui"; import _ from "lodash"; @@ -26,6 +25,7 @@ import { IndexItem } from "../../../../../models/interfaces"; import { CatRepository, GetSnapshot } from "../../../../../server/models/interfaces"; import CustomLabel from "../../../../components/CustomLabel"; import SnapshotRestoreAdvancedOptions from "../SnapshotRestoreAdvancedOptions"; +import SnapshotRestoreInitialOptions from "../SnapshotRestoreInitialOptions"; import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; @@ -63,6 +63,7 @@ export default class RestoreSnapshotFlyout extends Component { - console.log("flyout", [repository, snapshotId]); - console.log("repositories", [...this.state.repositories]); const { snapshotManagementService } = this.props; + try { const response = await snapshotManagementService.getSnapshot(snapshotId, repository); - console.log("my response", response); + if (response.ok) { const newOptions = response.response.indices.map((index) => { return { label: index }; @@ -163,6 +163,26 @@ export default class RestoreSnapshotFlyout extends Component) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "restore_all_indices", e.target.checked) }); + }; + + onRestoreSpecificIndicesToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "restore_specific_indices", e.target.checked) }); + }; + + onDoNotRenameToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "do_not_rename", e.target.checked) }); + }; + + onAddPrefixToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "add_prefix", e.target.checked) }); + }; + + onRenameIndicesToggle = (e: ChangeEvent) => { + this.setState({ snapshot: _.set(this.state.snapshot!, "rename_indices", e.target.checked) }); + }; + onRestoreAliasesToggle = (e: ChangeEvent) => { this.setState({ snapshot: _.set(this.state.snapshot!, "restore_aliases", e.target.checked) }); }; @@ -205,7 +225,23 @@ export default class RestoreSnapshotFlyout extends Component

{snapshotId}

- + + + {!restoreSpecific && ( + + )} {restoreSpecific && ( ) => void; + restoreSpecificIndices: boolean; + onRestoreSpecificIndicesToggle: (e: ChangeEvent) => void; + doNotRename: boolean; + onDoNotRenameToggle: (e: ChangeEvent) => void; + addPrefix: boolean; + onAddPrefixToggle: (e: ChangeEvent) => void; + renameIndices: boolean; + onRenameIndicesToggle: (e: ChangeEvent) => void; + width: string; +} + +const SnapshotRestoreInitialOptions = ({ + restoreAllIndices, + onRestoreAllIndicesToggle, + restoreSpecificIndices, + onRestoreSpecificIndicesToggle, + doNotRename, + onDoNotRenameToggle, + addPrefix, + onAddPrefixToggle, + renameIndices, + onRenameIndicesToggle, + width, +}: SnapshotInitialOptionsProps) => ( +
+
Specify restore option
+ + + + } + checked={true} + onChange={onRestoreAllIndicesToggle} + /> + + + + } + checked={restoreSpecificIndices} + onChange={onRestoreSpecificIndicesToggle} + /> + + + +
Rename restored indices
+ + + + } + checked={true} + onChange={onDoNotRenameToggle} + /> + + + + } + checked={addPrefix} + onChange={onAddPrefixToggle} + /> + + + + } + checked={renameIndices} + onChange={onRenameIndicesToggle} + /> +
+); + +export default SnapshotRestoreInitialOptions; diff --git a/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts b/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts new file mode 100644 index 000000000..73e864820 --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import SnapshotRestoreInitialOptions from "./SnapshotRestoreInitialOptions"; + +export default SnapshotRestoreInitialOptions; From e8e46eac265ce5d0cb16b716b8f5f76575629952 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 31 Aug 2022 16:19:40 -0700 Subject: [PATCH 19/39] Resolve radio button events not firing Signed-off-by: Chris Hesterman Split radio buttons into SnapshotRestoreOption and SnapshotRenameOptions Signed-off-by: Chris Hesterman Move 'restore' button between 'delete' and 'take snapshot' Signed-off-by: Chris Hesterman Set default rename option to 'add prefix' Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 156 +++++++----------- .../SnapshotIndicesInput.tsx | 46 ++++++ .../components/SnapshotIndicesInput/index.ts | 8 + .../SnapshotRenameOptions.tsx | 64 +++++++ .../components/SnapshotRenameOptions/index.ts | 8 + .../SnapshotRestoreInitialOptions.tsx | 6 +- .../SnapshotRestoreOption.tsx | 50 ++++++ .../components/SnapshotRestoreOption/index.ts | 8 + .../containers/Snapshots/Snapshots.tsx | 6 +- .../components/FlyoutFooter/FlyoutFooter.tsx | 5 +- public/services/SnapshotManagementService.ts | 9 +- server/routes/snapshotManagement.ts | 1 + server/services/SnapshotManagementService.ts | 4 + 13 files changed, 265 insertions(+), 106 deletions(-) create mode 100644 public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx create mode 100644 public/pages/Snapshots/components/SnapshotIndicesInput/index.ts create mode 100644 public/pages/Snapshots/components/SnapshotRenameOptions/SnapshotRenameOptions.tsx create mode 100644 public/pages/Snapshots/components/SnapshotRenameOptions/index.ts create mode 100644 public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx create mode 100644 public/pages/Snapshots/components/SnapshotRestoreOption/index.ts diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index ca8866990..984e03460 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -25,21 +25,24 @@ import { IndexItem } from "../../../../../models/interfaces"; import { CatRepository, GetSnapshot } from "../../../../../server/models/interfaces"; import CustomLabel from "../../../../components/CustomLabel"; import SnapshotRestoreAdvancedOptions from "../SnapshotRestoreAdvancedOptions"; -import SnapshotRestoreInitialOptions from "../SnapshotRestoreInitialOptions"; -import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; +import SnapshotRestoreOption from "../SnapshotRestoreOption"; +import SnapshotRenameOptions from "../SnapshotRenameOptions"; +// import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; +import SnapshotIndicesInput from "../SnapshotIndicesInput"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; interface RestoreSnapshotProps { snapshotManagementService: SnapshotManagementService; indexService: IndexService; onCloseFlyout: () => void; - restoreSnapshot: (snapshotId: string, repository: string) => void; + restoreSnapshot: (snapshotId: string, repository: string, indices: string) => void; snapshotId: string; } interface RestoreSnapshotState { indexOptions: EuiComboBoxOptionOption[]; selectedIndexOptions: EuiComboBoxOptionOption[]; + renameIndices: string; repositories: CatRepository[]; selectedRepoValue: string; @@ -55,10 +58,10 @@ export default class RestoreSnapshotFlyout extends Component { const { restoreSnapshot, snapshotId } = this.props; - const { selectedRepoValue } = this.state; + const { selectedRepoValue, snapshot } = this.state; + const indices = snapshot?.indices.join(","); let repoError = ""; if (!snapshotId.trim()) { @@ -90,14 +94,14 @@ export default class RestoreSnapshotFlyout extends Component[]) => { const selectedIndexOptions = selectedOptions.map((o) => o.label); let newJSON = this.state.snapshot; - + newJSON!.indices = [...selectedIndexOptions]; this.setState({ snapshot: newJSON, selectedIndexOptions: selectedOptions }); }; @@ -154,64 +158,26 @@ export default class RestoreSnapshotFlyout extends Component) => { - const selectedRepo = e.target.value; - let repoError = ""; - if (!selectedRepo) { - repoError = ERROR_PROMPT.REPO; + onToggle = (e: ChangeEvent) => { + if (e.target.id === "restore_specific_indices") { + this.setState({ restoreSpecific: true, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); + return; + } + if (e.target.id === "restore_all_indices") { + this.setState({ restoreSpecific: false, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); + return; + } + if (e.target.name === "rename_option") { + this.setState({ renameIndices: e.target.id, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); + return; } - this.setState({ selectedRepoValue: selectedRepo, repoError }); - }; - - onRestoreAllIndicesToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "restore_all_indices", e.target.checked) }); - }; - - onRestoreSpecificIndicesToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "restore_specific_indices", e.target.checked) }); - }; - - onDoNotRenameToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "do_not_rename", e.target.checked) }); - }; - - onAddPrefixToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "add_prefix", e.target.checked) }); - }; - - onRenameIndicesToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "rename_indices", e.target.checked) }); - }; - - onRestoreAliasesToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "restore_aliases", e.target.checked) }); - }; - - onRestoreClusterStateToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "restore_cluster_state", e.target.checked) }); - }; - - onIgnoreUnavailableToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "ignore_unavailable", e.target.checked) }); - }; - - onRestorePartialToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "restore_partial", e.target.checked) }); - }; - - onCustomizeIndexSettingsToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "customize_index_settings", e.target.checked) }); - }; - onIgnoreIndexSettingsToggle = (e: ChangeEvent) => { - this.setState({ snapshot: _.set(this.state.snapshot!, "ignore_index_settings", e.target.checked) }); + this.setState({ snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); }; render() { const { onCloseFlyout } = this.props; - const { indexOptions, selectedIndexOptions, repositories, selectedRepoValue, restoreSpecific, repoError, snapshot } = this.state; - - const repoOptions = repositories.map((r) => ({ value: r.id, text: r.id })); + const { indexOptions, selectedIndexOptions, repositories, selectedRepoValue, restoreSpecific, snapshot, renameIndices } = this.state; return ( @@ -227,62 +193,62 @@ export default class RestoreSnapshotFlyout extends Component - {!restoreSpecific && ( - - )} + + + - {restoreSpecific && ( - - )} - + + {restoreSpecific && ( + + )} - + ); diff --git a/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx b/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx new file mode 100644 index 000000000..93914b963 --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx @@ -0,0 +1,46 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { EuiComboBox, EuiComboBoxOptionOption, EuiSpacer } from "@elastic/eui"; +import React from "react"; +import { IndexItem } from "../../../../../models/interfaces"; +import CustomLabel from "../../../../components/CustomLabel"; + +interface SnapshotIndicesProps { + indexOptions: EuiComboBoxOptionOption[]; + selectedIndexOptions: EuiComboBoxOptionOption[]; + onIndicesSelectionChange: (selectedOptions: EuiComboBoxOptionOption[]) => void; + getIndexOptions: (searchValue: string) => void; + onCreateOption: (searchValue: string, options: Array>) => void; + selectedRepoValue: string; + isClearable: boolean; +} + +const SnapshotIndicesInput = ({ + indexOptions, + selectedIndexOptions, + onIndicesSelectionChange, + getIndexOptions, + onCreateOption, +}: SnapshotIndicesProps) => { + return ( + <> + + + + + + ); +}; + +export default SnapshotIndicesInput; diff --git a/public/pages/Snapshots/components/SnapshotIndicesInput/index.ts b/public/pages/Snapshots/components/SnapshotIndicesInput/index.ts new file mode 100644 index 000000000..2029cf583 --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotIndicesInput/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import SnapshotIndicesInput from "./SnapshotIndicesInput"; + +export default SnapshotIndicesInput; diff --git a/public/pages/Snapshots/components/SnapshotRenameOptions/SnapshotRenameOptions.tsx b/public/pages/Snapshots/components/SnapshotRenameOptions/SnapshotRenameOptions.tsx new file mode 100644 index 000000000..c634b1bcd --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRenameOptions/SnapshotRenameOptions.tsx @@ -0,0 +1,64 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { EuiRadio, EuiSpacer } from "@elastic/eui"; +import CustomLabel from "../../../../components/CustomLabel"; +import React, { ChangeEvent } from "react"; + +interface SnapshotRenameOptionsProps { + doNotRename: boolean; + onDoNotRenameToggle: (e: ChangeEvent) => void; + addPrefix: boolean; + onAddPrefixToggle: (e: ChangeEvent) => void; + renameIndices: boolean; + onRenameIndicesToggle: (e: ChangeEvent) => void; + width: string; +} + +const SnapshotRenameOptions = ({ + doNotRename, + onDoNotRenameToggle, + addPrefix, + onAddPrefixToggle, + renameIndices, + onRenameIndicesToggle, + width, +}: SnapshotRenameOptionsProps) => ( +
+
Rename restored indices
+ + + + } + checked={doNotRename} + onChange={onDoNotRenameToggle} + /> + + + + } + checked={addPrefix} + onChange={onAddPrefixToggle} + /> + + + + } + checked={renameIndices} + onChange={onRenameIndicesToggle} + /> +
+); + +export default SnapshotRenameOptions; diff --git a/public/pages/Snapshots/components/SnapshotRenameOptions/index.ts b/public/pages/Snapshots/components/SnapshotRenameOptions/index.ts new file mode 100644 index 000000000..532fb263d --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRenameOptions/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import SnapshotRenameOptions from "./SnapshotRenameOptions"; + +export default SnapshotRenameOptions; diff --git a/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/SnapshotRestoreInitialOptions.tsx b/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/SnapshotRestoreInitialOptions.tsx index 3c82a7137..edf41e228 100644 --- a/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/SnapshotRestoreInitialOptions.tsx +++ b/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/SnapshotRestoreInitialOptions.tsx @@ -3,7 +3,7 @@ * SPDX-License-Identifier: Apache-2.0 */ -import { EuiRadio, EuiSpacer, EuiText } from "@elastic/eui"; +import { EuiRadio, EuiSpacer } from "@elastic/eui"; import CustomLabel from "../../../../components/CustomLabel"; import React, { ChangeEvent } from "react"; @@ -43,7 +43,7 @@ const SnapshotRestoreInitialOptions = ({ id="restore_all_indices" name="restore_option" label={} - checked={true} + checked={restoreAllIndices} onChange={onRestoreAllIndicesToggle} /> @@ -67,7 +67,7 @@ const SnapshotRestoreInitialOptions = ({ id="do_not_rename" name="rename_option" label={} - checked={true} + checked={doNotRename} onChange={onDoNotRenameToggle} /> diff --git a/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx b/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx new file mode 100644 index 000000000..6d5e3b88c --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx @@ -0,0 +1,50 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { EuiRadio, EuiSpacer } from "@elastic/eui"; +import CustomLabel from "../../../../components/CustomLabel"; +import React, { ChangeEvent } from "react"; + +interface SnapshotRestoreOptionProps { + restoreAllIndices: boolean; + onRestoreAllIndicesToggle: (e: ChangeEvent) => void; + restoreSpecificIndices: boolean; + onRestoreSpecificIndicesToggle: (e: ChangeEvent) => void; + width: string; +} + +const SnapshotRestoreOption = ({ + restoreAllIndices, + onRestoreAllIndicesToggle, + restoreSpecificIndices, + onRestoreSpecificIndicesToggle, + width, +}: SnapshotRestoreOptionProps) => ( +
+
Specify restore option
+ + + + } + checked={restoreAllIndices} + onChange={onRestoreAllIndicesToggle} + /> + + + + } + checked={restoreSpecificIndices} + onChange={onRestoreSpecificIndicesToggle} + /> +
+); + +export default SnapshotRestoreOption; diff --git a/public/pages/Snapshots/components/SnapshotRestoreOption/index.ts b/public/pages/Snapshots/components/SnapshotRestoreOption/index.ts new file mode 100644 index 000000000..50f5c8958 --- /dev/null +++ b/public/pages/Snapshots/components/SnapshotRestoreOption/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import SnapshotRestoreOption from "./SnapshotRestoreOption"; + +export default SnapshotRestoreOption; diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index f67007921..22c666736 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -292,12 +292,12 @@ export default class Snapshots extends Component Delete , - - Take snapshot - , Restore , + + Take snapshot + , ]; const subTitleText = ( diff --git a/public/pages/VisualCreatePolicy/components/FlyoutFooter/FlyoutFooter.tsx b/public/pages/VisualCreatePolicy/components/FlyoutFooter/FlyoutFooter.tsx index 3186668f9..6ccde3c67 100644 --- a/public/pages/VisualCreatePolicy/components/FlyoutFooter/FlyoutFooter.tsx +++ b/public/pages/VisualCreatePolicy/components/FlyoutFooter/FlyoutFooter.tsx @@ -13,9 +13,10 @@ interface FlyoutFooterProps { onClickCancel: () => void; onClickAction: () => void; save?: boolean; + restore?: boolean; } -const FlyoutFooter = ({ edit, action, disabledAction = false, onClickCancel, onClickAction, save }: FlyoutFooterProps) => ( +const FlyoutFooter = ({ edit, action, disabledAction = false, onClickCancel, onClickAction, save, restore }: FlyoutFooterProps) => ( @@ -24,7 +25,7 @@ const FlyoutFooter = ({ edit, action, disabledAction = false, onClickCancel, onC - {!save ? `${edit ? "Edit" : "Add"} ${action}` : save ? "Save" : "Create"} + {restore ? "Restore snapshot" : !save ? `${edit ? "Edit" : "Add"} ${action}` : save ? "Save" : "Create"} diff --git a/public/services/SnapshotManagementService.ts b/public/services/SnapshotManagementService.ts index 564358e66..ae03bcf46 100644 --- a/public/services/SnapshotManagementService.ts +++ b/public/services/SnapshotManagementService.ts @@ -44,16 +44,19 @@ export default class SnapshotManagementService { }; createSnapshot = async (snapshotId: string, repository: string, snapshot: Snapshot): Promise> => { - let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; + let url = `..${NODE_API._SNAPSHOTS}/${repository}/${snapshotId}`; const response = (await this.httpClient.put(url, { query: { repository }, body: JSON.stringify(snapshot) })) as ServerResponse< CreateSnapshotResponse >; return response; }; - restoreSnapshot = async (snapshotId: string, repository: string): Promise> => { + restoreSnapshot = async (snapshotId: string, repository: string, indices: string): Promise> => { let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; - const response = (await this.httpClient.post(url, { query: { repository } })) as ServerResponse; + const response = (await this.httpClient.post(url, { + query: { repository }, + body: JSON.stringify({ indices: indices }), + })) as ServerResponse; return response; }; diff --git a/server/routes/snapshotManagement.ts b/server/routes/snapshotManagement.ts index ba64335bb..6a280b78d 100644 --- a/server/routes/snapshotManagement.ts +++ b/server/routes/snapshotManagement.ts @@ -75,6 +75,7 @@ export default function (services: NodeServices, router: IRouter) { query: schema.object({ repository: schema.string(), }), + body: schema.any(), }, }, snapshotManagementService.restoreSnapshot diff --git a/server/services/SnapshotManagementService.ts b/server/services/SnapshotManagementService.ts index 014ad2762..36b519a37 100644 --- a/server/services/SnapshotManagementService.ts +++ b/server/services/SnapshotManagementService.ts @@ -200,9 +200,13 @@ export default class SnapshotManagementService { const { repository } = request.query as { repository: string; }; + const { indices } = request.body as { + indices: string; + }; const params = { repository: repository, snapshot: id, + indices: indices, }; const { callAsCurrentUser: callWithRequest } = this.osDriver.asScoped(request); const resp: RestoreSnapshotResponse = await callWithRequest("snapshot.restore", params); From 5cd9afc835fcd9bd1d12b8682377c7eed28c6e2c Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 31 Aug 2022 17:37:09 -0700 Subject: [PATCH 20/39] Add AddPrefixInput, remove unused component RestoreSnapshotInitialOptions Signed-off-by: Chris Hesterman --- .../AddPrefixInput/AddPrefixInput.tsx | 36 +++++++ .../components/AddPrefixInput/index.ts | 8 ++ .../RestoreSnapshotFlyout.tsx | 44 ++++++--- .../SnapshotIndicesInput.tsx | 8 +- .../SnapshotRestoreInitialOptions.tsx | 96 ------------------- .../SnapshotRestoreInitialOptions/index.ts | 8 -- 6 files changed, 77 insertions(+), 123 deletions(-) create mode 100644 public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx create mode 100644 public/pages/Snapshots/components/AddPrefixInput/index.ts delete mode 100644 public/pages/Snapshots/components/SnapshotRestoreInitialOptions/SnapshotRestoreInitialOptions.tsx delete mode 100644 public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts diff --git a/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx b/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx new file mode 100644 index 000000000..ff92318a5 --- /dev/null +++ b/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx @@ -0,0 +1,36 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { EuiFormRow, EuiFieldText, EuiSpacer } from "@elastic/eui"; +import React, { useState, ChangeEvent } from "react"; +import CustomLabel from "../../../../components/CustomLabel"; + +interface AddPrefixesInputProps { + getPrefix: (prefix: string) => void; +} + +const AddPrefixesInput = ({ getPrefix }: AddPrefixesInputProps) => { + const [prefix, setPrefix] = useState(""); + + const handleChange = (e: ChangeEvent) => { + setPrefix(e.target.value); + getPrefix(e.target.value); + }; + + return ( + <> + + + + + + + + + + ); +}; + +export default AddPrefixesInput; diff --git a/public/pages/Snapshots/components/AddPrefixInput/index.ts b/public/pages/Snapshots/components/AddPrefixInput/index.ts new file mode 100644 index 000000000..2ae205f75 --- /dev/null +++ b/public/pages/Snapshots/components/AddPrefixInput/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import AddPrefixInput from "./AddPrefixInput"; + +export default AddPrefixInput; diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 984e03460..7b00397f7 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -27,6 +27,7 @@ import CustomLabel from "../../../../components/CustomLabel"; import SnapshotRestoreAdvancedOptions from "../SnapshotRestoreAdvancedOptions"; import SnapshotRestoreOption from "../SnapshotRestoreOption"; import SnapshotRenameOptions from "../SnapshotRenameOptions"; +import AddPrefixInput from "../AddPrefixInput"; // import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; import SnapshotIndicesInput from "../SnapshotIndicesInput"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; @@ -43,12 +44,15 @@ interface RestoreSnapshotState { indexOptions: EuiComboBoxOptionOption[]; selectedIndexOptions: EuiComboBoxOptionOption[]; renameIndices: string; + prefix: string; repositories: CatRepository[]; selectedRepoValue: string; snapshot: GetSnapshot | null; snapshotId: string; + restoreSpecific: boolean; + restoreAliases: boolean; repoError: string; snapshotIdError: string; @@ -62,11 +66,13 @@ export default class RestoreSnapshotFlyout extends Component { + this.setState({ prefix: prefix }); + }; + onToggle = (e: ChangeEvent) => { if (e.target.id === "restore_specific_indices") { this.setState({ restoreSpecific: true, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); @@ -177,7 +187,7 @@ export default class RestoreSnapshotFlyout extends Component @@ -201,6 +211,22 @@ export default class RestoreSnapshotFlyout extends Component + + + {restoreSpecific && ( + + )} + + + + {renameIndices === "add_prefix" && } + @@ -231,20 +259,6 @@ export default class RestoreSnapshotFlyout extends Component - - - - {restoreSpecific && ( - - )} diff --git a/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx b/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx index 93914b963..8de4d962f 100644 --- a/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx +++ b/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx @@ -8,7 +8,7 @@ import React from "react"; import { IndexItem } from "../../../../../models/interfaces"; import CustomLabel from "../../../../components/CustomLabel"; -interface SnapshotIndicesProps { +interface SnapshotIndicesInputProps { indexOptions: EuiComboBoxOptionOption[]; selectedIndexOptions: EuiComboBoxOptionOption[]; onIndicesSelectionChange: (selectedOptions: EuiComboBoxOptionOption[]) => void; @@ -24,12 +24,12 @@ const SnapshotIndicesInput = ({ onIndicesSelectionChange, getIndexOptions, onCreateOption, -}: SnapshotIndicesProps) => { +}: SnapshotIndicesInputProps) => { return ( <> - + ) => void; - restoreSpecificIndices: boolean; - onRestoreSpecificIndicesToggle: (e: ChangeEvent) => void; - doNotRename: boolean; - onDoNotRenameToggle: (e: ChangeEvent) => void; - addPrefix: boolean; - onAddPrefixToggle: (e: ChangeEvent) => void; - renameIndices: boolean; - onRenameIndicesToggle: (e: ChangeEvent) => void; - width: string; -} - -const SnapshotRestoreInitialOptions = ({ - restoreAllIndices, - onRestoreAllIndicesToggle, - restoreSpecificIndices, - onRestoreSpecificIndicesToggle, - doNotRename, - onDoNotRenameToggle, - addPrefix, - onAddPrefixToggle, - renameIndices, - onRenameIndicesToggle, - width, -}: SnapshotInitialOptionsProps) => ( -
-
Specify restore option
- - - - } - checked={restoreAllIndices} - onChange={onRestoreAllIndicesToggle} - /> - - - - } - checked={restoreSpecificIndices} - onChange={onRestoreSpecificIndicesToggle} - /> - - - -
Rename restored indices
- - - - } - checked={doNotRename} - onChange={onDoNotRenameToggle} - /> - - - - } - checked={addPrefix} - onChange={onAddPrefixToggle} - /> - - - - } - checked={renameIndices} - onChange={onRenameIndicesToggle} - /> -
-); - -export default SnapshotRestoreInitialOptions; diff --git a/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts b/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts deleted file mode 100644 index 73e864820..000000000 --- a/public/pages/Snapshots/components/SnapshotRestoreInitialOptions/index.ts +++ /dev/null @@ -1,8 +0,0 @@ -/* - * Copyright OpenSearch Contributors - * SPDX-License-Identifier: Apache-2.0 - */ - -import SnapshotRestoreInitialOptions from "./SnapshotRestoreInitialOptions"; - -export default SnapshotRestoreInitialOptions; From a80656fb13c9ff846fa6f7de42eed4dcf0ad40e4 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 1 Sep 2022 13:01:23 -0700 Subject: [PATCH 21/39] Fix issues with restore specific indices Signed-off-by: Chris Hesterman Implement first 4 Advanced restore options functionality Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 27 +++++++++++++------ .../SnapshotRestoreAdvancedOptions.tsx | 4 +-- .../containers/Snapshots/Snapshots.tsx | 4 +-- public/services/SnapshotManagementService.ts | 9 ++++--- server/models/interfaces.ts | 5 ++++ server/services/SnapshotManagementService.ts | 5 +--- 6 files changed, 35 insertions(+), 19 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 7b00397f7..7419025e1 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -36,7 +36,7 @@ interface RestoreSnapshotProps { snapshotManagementService: SnapshotManagementService; indexService: IndexService; onCloseFlyout: () => void; - restoreSnapshot: (snapshotId: string, repository: string, indices: string) => void; + restoreSnapshot: (snapshotId: string, repository: string, options: object) => void; snapshotId: string; } @@ -53,6 +53,7 @@ interface RestoreSnapshotState { snapshotId: string; restoreSpecific: boolean; restoreAliases: boolean; + partial: boolean; repoError: string; snapshotIdError: string; @@ -73,6 +74,7 @@ export default class RestoreSnapshotFlyout extends Component { const { restoreSnapshot, snapshotId } = this.props; - const { selectedRepoValue, snapshot } = this.state; - const indices = snapshot?.indices.join(","); + const { selectedRepoValue, selectedIndexOptions, snapshot, partial, prefix } = this.state; + const selectedIndices = selectedIndexOptions.map((option) => option.label).join(","); + const options = { + indices: selectedIndices, + ignore_unavailable: snapshot?.ignore_unavailable || false, + include_global_state: snapshot?.include_global_state, + rename_pattern: snapshot?.rename_pattern || "", + rename_replacement: snapshot?.rename_replacement || "", + include_aliases: snapshot?.restore_aliases || false, + partial: snapshot?.partial || false, + }; let repoError = ""; if (!snapshotId.trim()) { @@ -100,8 +111,8 @@ export default class RestoreSnapshotFlyout extends Component[]) => { @@ -187,7 +198,7 @@ export default class RestoreSnapshotFlyout extends Component @@ -246,11 +257,11 @@ export default class RestoreSnapshotFlyout extends Component } checked={restoreClusterState} onChange={onRestoreClusterStateToggle} @@ -72,7 +72,7 @@ const SnapshotRestoreAdvancedOptions = ({ } checked={restorePartial} onChange={onRestorePartialToggle} diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index 22c666736..aa15965d6 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -218,10 +218,10 @@ export default class Snapshots extends Component } }; - restoreSnapshot = async (snapshotId: string, repository: string) => { + restoreSnapshot = async (snapshotId: string, repository: string, options: object) => { try { const { snapshotManagementService } = this.props; - const response = await snapshotManagementService.restoreSnapshot(snapshotId, repository); + const response = await snapshotManagementService.restoreSnapshot(snapshotId, repository, options); if (response.ok) { this.context.notifications.toasts.addSuccess(`Restored snapshot ${snapshotId} to repository ${repository}.`); } else { diff --git a/public/services/SnapshotManagementService.ts b/public/services/SnapshotManagementService.ts index ae03bcf46..75b08bc14 100644 --- a/public/services/SnapshotManagementService.ts +++ b/public/services/SnapshotManagementService.ts @@ -44,18 +44,21 @@ export default class SnapshotManagementService { }; createSnapshot = async (snapshotId: string, repository: string, snapshot: Snapshot): Promise> => { - let url = `..${NODE_API._SNAPSHOTS}/${repository}/${snapshotId}`; + let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; const response = (await this.httpClient.put(url, { query: { repository }, body: JSON.stringify(snapshot) })) as ServerResponse< CreateSnapshotResponse >; return response; }; - restoreSnapshot = async (snapshotId: string, repository: string, indices: string): Promise> => { + restoreSnapshot = async (snapshotId: string, repository: string, options: object): Promise> => { let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; + + console.log("to be sent to server", [url, options]); + const response = (await this.httpClient.post(url, { query: { repository }, - body: JSON.stringify({ indices: indices }), + body: JSON.stringify(options), })) as ServerResponse; return response; }; diff --git a/server/models/interfaces.ts b/server/models/interfaces.ts index 9592cc7a5..8b380c943 100644 --- a/server/models/interfaces.ts +++ b/server/models/interfaces.ts @@ -409,6 +409,11 @@ export interface GetSnapshot { successful: number; failed: number; }; + restore_aliases?: boolean; + ignore_unavailable?: boolean; + rename_pattern?: string; + rename_replacement?: string; + partial?: boolean; metadata?: { sm_policy?: string; }; diff --git a/server/services/SnapshotManagementService.ts b/server/services/SnapshotManagementService.ts index 36b519a37..2be52b265 100644 --- a/server/services/SnapshotManagementService.ts +++ b/server/services/SnapshotManagementService.ts @@ -200,13 +200,10 @@ export default class SnapshotManagementService { const { repository } = request.query as { repository: string; }; - const { indices } = request.body as { - indices: string; - }; const params = { repository: repository, snapshot: id, - indices: indices, + body: JSON.stringify(request.body), }; const { callAsCurrentUser: callWithRequest } = this.osDriver.asScoped(request); const resp: RestoreSnapshotResponse = await callWithRequest("snapshot.restore", params); From aa46d71f732ea3473bae113821f3eaea8478d02c Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 1 Sep 2022 16:45:28 -0700 Subject: [PATCH 22/39] Begin cypress testing for snapshots Signed-off-by: Chris Hesterman Passing tests for create repo and create snapshot Signed-off-by: Chris Hesterman --- cypress/integration/snapshots_spec.js | 95 +++++++++++++++++++ .../CreateRepositoryFlyout.tsx | 7 +- .../CreateSnapshotFlyout.tsx | 1 + 3 files changed, 102 insertions(+), 1 deletion(-) create mode 100644 cypress/integration/snapshots_spec.js diff --git a/cypress/integration/snapshots_spec.js b/cypress/integration/snapshots_spec.js new file mode 100644 index 000000000..d05716c63 --- /dev/null +++ b/cypress/integration/snapshots_spec.js @@ -0,0 +1,95 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { PLUGIN_NAME } from "../support/constants"; + +describe("Snapshots", () => { + before(() => { + // Load ecommerce data + cy.request({ + method: "POST", + url: `${Cypress.env("opensearch_dashboards")}/api/sample_data/ecommerce`, + headers: { + "osd-xsrf": true, + }, + }).then((response) => { + expect(response.status).equal(200); + }); + + // Load flight data + cy.request({ + method: "POST", + url: `${Cypress.env("opensearch_dashboards")}/api/sample_data/flights`, + headers: { + "osd-xsrf": true, + }, + }).then((response) => { + expect(response.status).equal(200); + }); + + // Load web log data + cy.request({ + method: "POST", + url: `${Cypress.env("opensearch_dashboards")}/api/sample_data/logs`, + headers: { + "osd-xsrf": true, + }, + }).then((response) => { + expect(response.status).equal(200); + }); + }); + + beforeEach(() => { + // Set welcome screen tracking to false + localStorage.setItem("home:welcome:show", "false"); + + // Visit ISM Snapshots Dashboard + cy.visit(`${Cypress.env("opensearch_dashboards")}/app/${PLUGIN_NAME}#/snapshots`); + + // Common text to wait for to confirm page loaded, give up to 60 seconds for initial load + cy.contains("Restore", { timeout: 60000 }); + }); + + describe("Repository can be created", () => { + it("successfully creates a new repository", () => { + // Create repository to store snapshots + cy.visit(`${Cypress.env("opensearch_dashboards")}/app/${PLUGIN_NAME}#/repositories`); + + // Route to create repository page + cy.contains("Create repository").click({ force: true }); + + // Type in repository name + cy.get(`input[data-test-subj="repoNameInput"]`).focus().type("test_repo"); + + // Type in repository location + cy.get(`input[placeholder="e.g., /mnt/snapshots"]`).focus().type("~/Desktop"); + + // Click Add button + cy.get("button").contains("Add").click({ force: true }); + + // Confirm repository created + cy.contains("test_repo"); + }); + }); + + describe("Snapshot can be created", () => { + it("successfully creates a new snapshot", () => { + // Click Take snapshot button + cy.get("button").contains("Take snapshot").click({ force: true }); + + // Type in Snapshot name + cy.get(`input[data-test-subj="snapshotNameInput"]`).focus().type("test_snapshot"); + + // Select indexes to be included + cy.get(`button[data-test-subj="comboBoxToggleListButton"]`).first().click({ force: true }); + + // Confirm test_repo exists + cy.contains("test_repo"); + + // Click 'Add' button to create snapshot + cy.get("button").contains("Add").click({ force: true }); + }); + }); +}); diff --git a/public/pages/Repositories/components/CreateRepositoryFlyout/CreateRepositoryFlyout.tsx b/public/pages/Repositories/components/CreateRepositoryFlyout/CreateRepositoryFlyout.tsx index 686c0c015..5d23cd6ed 100644 --- a/public/pages/Repositories/components/CreateRepositoryFlyout/CreateRepositoryFlyout.tsx +++ b/public/pages/Repositories/components/CreateRepositoryFlyout/CreateRepositoryFlyout.tsx @@ -258,7 +258,12 @@ export default class CreateRepositoryFlyout extends Component - this.setState({ repoName: e.target.value })} /> + this.setState({ repoName: e.target.value })} + /> diff --git a/public/pages/Snapshots/components/CreateSnapshotFlyout/CreateSnapshotFlyout.tsx b/public/pages/Snapshots/components/CreateSnapshotFlyout/CreateSnapshotFlyout.tsx index 2ab6397d9..4657ad5f6 100644 --- a/public/pages/Snapshots/components/CreateSnapshotFlyout/CreateSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/CreateSnapshotFlyout/CreateSnapshotFlyout.tsx @@ -208,6 +208,7 @@ export default class CreateSnapshotFlyout extends Component { this.setState({ snapshotId: e.target.value }); }} + data-test-subj="snapshotNameInput" /> From 3cf371103fb1f4f5d389be46580c0f230874e93d Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Fri, 2 Sep 2022 12:36:47 -0700 Subject: [PATCH 23/39] Begin cypress testing Snapshots. Create repo and Create snapshot done Signed-off-by: Chris Hesterman --- cypress/integration/snapshots_spec.js | 21 ++++++++++++++-- .../SnapshotIndicesRepoInput.tsx | 1 + .../RestoreSnapshotFlyout.tsx | 24 ++++++++++++++++--- .../containers/Snapshots/Snapshots.tsx | 4 ++-- 4 files changed, 43 insertions(+), 7 deletions(-) diff --git a/cypress/integration/snapshots_spec.js b/cypress/integration/snapshots_spec.js index d05716c63..c025e2a1e 100644 --- a/cypress/integration/snapshots_spec.js +++ b/cypress/integration/snapshots_spec.js @@ -7,6 +7,9 @@ import { PLUGIN_NAME } from "../support/constants"; describe("Snapshots", () => { before(() => { + // Delete any existing indices + cy.deleteAllIndices(); + // Load ecommerce data cy.request({ method: "POST", @@ -80,16 +83,30 @@ describe("Snapshots", () => { cy.get("button").contains("Take snapshot").click({ force: true }); // Type in Snapshot name - cy.get(`input[data-test-subj="snapshotNameInput"]`).focus().type("test_snapshot"); + cy.get(`input[data-test-subj="snapshotNameInput"]`).type("test_snapshot{enter}"); // Select indexes to be included - cy.get(`button[data-test-subj="comboBoxToggleListButton"]`).first().click({ force: true }); + cy.get(`[data-test-subj="indicesComboBoxInput"]`).type("open*{enter}"); // Confirm test_repo exists cy.contains("test_repo"); // Click 'Add' button to create snapshot cy.get("button").contains("Add").click({ force: true }); + + // check for success status and snapshot name + cy.contains("In_progress"); + cy.contains("test_snapshot"); }); }); + + // describe("Snapshots can be restored", () => { + // it("Successfully restores all indices", () => { + // // Delete existing indices + // cy.deleteAllIndices(); + + // // Select snapshot to restore + // cy.get("checkbox").contains("test") + // }) + // }) }); diff --git a/public/pages/CreateSnapshotPolicy/components/SnapshotIndicesRepoInput/SnapshotIndicesRepoInput.tsx b/public/pages/CreateSnapshotPolicy/components/SnapshotIndicesRepoInput/SnapshotIndicesRepoInput.tsx index 9c63bbec6..590889cdc 100644 --- a/public/pages/CreateSnapshotPolicy/components/SnapshotIndicesRepoInput/SnapshotIndicesRepoInput.tsx +++ b/public/pages/CreateSnapshotPolicy/components/SnapshotIndicesRepoInput/SnapshotIndicesRepoInput.tsx @@ -73,6 +73,7 @@ const SnapshotIndicesRepoInput = ({ onSearchChange={getIndexOptions} onCreateOption={onCreateOption} isClearable={true} + data-test-subj="indicesComboBoxInput" /> diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 7419025e1..723a6b92d 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -45,6 +45,7 @@ interface RestoreSnapshotState { selectedIndexOptions: EuiComboBoxOptionOption[]; renameIndices: string; prefix: string; + listIndices: boolean; repositories: CatRepository[]; selectedRepoValue: string; @@ -68,6 +69,7 @@ export default class RestoreSnapshotFlyout extends Component { + this.setState({ listIndices: true }); + }; + onIndicesSelectionChange = (selectedOptions: EuiComboBoxOptionOption[]) => { const selectedIndexOptions = selectedOptions.map((o) => o.label); let newJSON = this.state.snapshot; @@ -198,7 +204,7 @@ export default class RestoreSnapshotFlyout extends Component @@ -209,8 +215,20 @@ export default class RestoreSnapshotFlyout extends Component - -

{snapshotId}

+ + + +

{snapshot?.snapshot}

+
+ + +

{snapshot?.state}

+
+ + + {snapshot?.indices.length} + +
diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index aa15965d6..108693266 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -14,8 +14,8 @@ import { getErrorMessage } from "../../../../utils/helpers"; import { CatSnapshotWithRepoAndPolicy as SnapshotsWithRepoAndPolicy } from "../../../../../server/models/interfaces"; import { ContentPanel } from "../../../../components/ContentPanel"; import SnapshotFlyout from "../../components/SnapshotFlyout/SnapshotFlyout"; -import CreateSnapshotFlyout from "../../components/CreateSnapshotFlyout/CreateSnapshotFlyout"; -import RestoreSnapshotFlyout from "../../components/RestoreSnapshotFlyout/RestoreSnapshotFlyout"; +import CreateSnapshotFlyout from "../../components/CreateSnapshotFlyout"; +import RestoreSnapshotFlyout from "../../components/RestoreSnapshotFlyout"; import { Snapshot } from "../../../../../models/interfaces"; import { BREADCRUMBS, RESTORE_SNAPSHOT_DOCUMENTATION_URL, ROUTES } from "../../../../utils/constants"; import { renderTimestampMillis } from "../../../SnapshotPolicies/helpers"; From b9ad019b0aaf20fa72f256c54b5d09449d3d3254 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Fri, 2 Sep 2022 13:33:40 -0700 Subject: [PATCH 24/39] Implement add_prefix functionality for snapshot restore Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 723a6b92d..c6584c984 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -89,14 +89,15 @@ export default class RestoreSnapshotFlyout extends Component { const { restoreSnapshot, snapshotId } = this.props; - const { selectedRepoValue, selectedIndexOptions, snapshot, partial, prefix } = this.state; + const { selectedRepoValue, selectedIndexOptions, snapshot, renameIndices, prefix } = this.state; const selectedIndices = selectedIndexOptions.map((option) => option.label).join(","); + const renamePattern = renameIndices === "add_prefix" ? "(? Date: Fri, 2 Sep 2022 15:46:54 -0700 Subject: [PATCH 25/39] Implement rename indices option for restore snapshot Signed-off-by: Chris Hesterman --- .../AddPrefixInput/AddPrefixInput.tsx | 4 +- .../components/RenameInput/RenameInput.tsx | 53 +++++++++++++++++++ .../Snapshots/components/RenameInput/index.ts | 8 +++ .../RestoreSnapshotFlyout.tsx | 40 +++++++++++--- public/services/SnapshotManagementService.ts | 2 - server/services/SnapshotManagementService.ts | 2 +- 6 files changed, 98 insertions(+), 11 deletions(-) create mode 100644 public/pages/Snapshots/components/RenameInput/RenameInput.tsx create mode 100644 public/pages/Snapshots/components/RenameInput/index.ts diff --git a/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx b/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx index ff92318a5..59abedf74 100644 --- a/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx +++ b/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx @@ -14,7 +14,7 @@ interface AddPrefixesInputProps { const AddPrefixesInput = ({ getPrefix }: AddPrefixesInputProps) => { const [prefix, setPrefix] = useState(""); - const handleChange = (e: ChangeEvent) => { + const onPrefixChange = (e: ChangeEvent) => { setPrefix(e.target.value); getPrefix(e.target.value); }; @@ -25,7 +25,7 @@ const AddPrefixesInput = ({ getPrefix }: AddPrefixesInputProps) => { - + diff --git a/public/pages/Snapshots/components/RenameInput/RenameInput.tsx b/public/pages/Snapshots/components/RenameInput/RenameInput.tsx new file mode 100644 index 000000000..f35019fde --- /dev/null +++ b/public/pages/Snapshots/components/RenameInput/RenameInput.tsx @@ -0,0 +1,53 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import { EuiFormRow, EuiFieldText, EuiSpacer } from "@elastic/eui"; +import React, { useState, ChangeEvent } from "react"; +import CustomLabel from "../../../../components/CustomLabel"; + +interface RenameInputProps { + getRenamePattern: (prefix: string) => void; + getRenameReplacement: (prefix: string) => void; +} + +const RenameInput = ({ getRenamePattern, getRenameReplacement }: RenameInputProps) => { + const [renamePattern, setRenamePattern] = useState(""); + const [renameReplacement, setRenameReplacement] = useState(""); + + const onPatternChange = (e: ChangeEvent) => { + setRenamePattern(e.target.value); + getRenamePattern(e.target.value); + }; + + const onReplacementChange = (e: ChangeEvent) => { + setRenameReplacement(e.target.value); + getRenameReplacement(e.target.value); + }; + + const patternHelpText = + "Use regular expressiojn to define how index names will be renamed. By default, input (.+) to reuse the entire index name [Learn more]"; + const replacementHelpText = + "Define the format of renamed inices. Use $0 to include the entire matching index name, $1 to include the content of the first capture group, etc. [Learn more]"; + + return ( + <> + + + + + + + + + + + + + + + ); +}; + +export default RenameInput; diff --git a/public/pages/Snapshots/components/RenameInput/index.ts b/public/pages/Snapshots/components/RenameInput/index.ts new file mode 100644 index 000000000..5fe87f5f0 --- /dev/null +++ b/public/pages/Snapshots/components/RenameInput/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright OpenSearch Contributors + * SPDX-License-Identifier: Apache-2.0 + */ + +import RenameInput from "./RenameInput"; + +export default RenameInput; diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index c6584c984..a5078953a 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -28,6 +28,7 @@ import SnapshotRestoreAdvancedOptions from "../SnapshotRestoreAdvancedOptions"; import SnapshotRestoreOption from "../SnapshotRestoreOption"; import SnapshotRenameOptions from "../SnapshotRenameOptions"; import AddPrefixInput from "../AddPrefixInput"; +import RenameInput from "../RenameInput"; // import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; import SnapshotIndicesInput from "../SnapshotIndicesInput"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; @@ -45,6 +46,8 @@ interface RestoreSnapshotState { selectedIndexOptions: EuiComboBoxOptionOption[]; renameIndices: string; prefix: string; + renamePattern: string; + renameReplacement: string; listIndices: boolean; repositories: CatRepository[]; @@ -69,6 +72,8 @@ export default class RestoreSnapshotFlyout extends Component { const { restoreSnapshot, snapshotId } = this.props; - const { selectedRepoValue, selectedIndexOptions, snapshot, renameIndices, prefix } = this.state; + const { + selectedRepoValue, + restoreSpecific, + selectedIndexOptions, + indexOptions, + snapshot, + renameIndices, + prefix, + renamePattern, + renameReplacement, + } = this.state; const selectedIndices = selectedIndexOptions.map((option) => option.label).join(","); - const renamePattern = renameIndices === "add_prefix" ? "(? option.label).join(","); + const pattern = renameIndices === "add_prefix" ? "(? { + this.setState({ renamePattern: renamePattern }); + }; + + getRenameReplacement = (renameReplacement: string) => { + this.setState({ renameReplacement: renameReplacement }); + }; + onToggle = (e: ChangeEvent) => { if (e.target.id === "restore_specific_indices") { this.setState({ restoreSpecific: true, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); @@ -205,7 +230,7 @@ export default class RestoreSnapshotFlyout extends Component @@ -268,6 +293,9 @@ export default class RestoreSnapshotFlyout extends Component {renameIndices === "add_prefix" && } + {renameIndices === "rename_indices" && ( + + )} diff --git a/public/services/SnapshotManagementService.ts b/public/services/SnapshotManagementService.ts index 75b08bc14..574fc78cb 100644 --- a/public/services/SnapshotManagementService.ts +++ b/public/services/SnapshotManagementService.ts @@ -54,8 +54,6 @@ export default class SnapshotManagementService { restoreSnapshot = async (snapshotId: string, repository: string, options: object): Promise> => { let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; - console.log("to be sent to server", [url, options]); - const response = (await this.httpClient.post(url, { query: { repository }, body: JSON.stringify(options), diff --git a/server/services/SnapshotManagementService.ts b/server/services/SnapshotManagementService.ts index 2be52b265..379055b7a 100644 --- a/server/services/SnapshotManagementService.ts +++ b/server/services/SnapshotManagementService.ts @@ -312,7 +312,7 @@ export default class SnapshotManagementService { queryString: queryString.trim() ? `${queryString.trim()}` : "*", }; const res = await callWithRequest("ism.getSMPolicies", params); - + console.log("policy response", res); const policies: DocumentSMPolicy[] = res.policies.map( (p: { _id: string; _seq_no: number; _primary_term: number; sm_policy: SMPolicy }) => ({ seqNo: p._seq_no, From 5af4208147c540957c408397a890a003724858dc Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 5 Sep 2022 08:30:34 -0700 Subject: [PATCH 26/39] Remove console.logs, unusted variables in SnapshotFlyout, SMservice Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx | 4 +--- public/services/SnapshotManagementService.ts | 1 - 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index a5078953a..591d66643 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -29,7 +29,6 @@ import SnapshotRestoreOption from "../SnapshotRestoreOption"; import SnapshotRenameOptions from "../SnapshotRenameOptions"; import AddPrefixInput from "../AddPrefixInput"; import RenameInput from "../RenameInput"; -// import SnapshotIndicesRepoInput from "../../../CreateSnapshotPolicy/components/SnapshotIndicesRepoInput"; import SnapshotIndicesInput from "../SnapshotIndicesInput"; import { ERROR_PROMPT } from "../../../CreateSnapshotPolicy/constants"; @@ -131,7 +130,6 @@ export default class RestoreSnapshotFlyout extends Component diff --git a/public/services/SnapshotManagementService.ts b/public/services/SnapshotManagementService.ts index 574fc78cb..f98272a80 100644 --- a/public/services/SnapshotManagementService.ts +++ b/public/services/SnapshotManagementService.ts @@ -53,7 +53,6 @@ export default class SnapshotManagementService { restoreSnapshot = async (snapshotId: string, repository: string, options: object): Promise> => { let url = `..${NODE_API._SNAPSHOTS}/${snapshotId}`; - const response = (await this.httpClient.post(url, { query: { repository }, body: JSON.stringify(options), From 5cf239f61029cdab5d517e0d2b39b97c44d42d10 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 7 Sep 2022 09:39:19 -0700 Subject: [PATCH 27/39] Add full stop to help text/errors, add RESTORE_OPTIONS enum Signed-off-by: Chris Hesterman --- cypress/integration/snapshots_spec.js | 10 -- public/models/interfaces.ts | 14 ++ .../AddPrefixInput/AddPrefixInput.tsx | 2 +- .../components/RenameInput/RenameInput.tsx | 4 +- .../RestoreSnapshotFlyout.tsx | 52 +++--- .../SnapshotIndicesInput.tsx | 2 +- .../SnapshotRenameOptions.tsx | 66 ++++---- .../SnapshotRestoreAdvancedOptions.tsx | 159 ++++++++++-------- .../SnapshotRestoreOption.tsx | 57 ++++--- 9 files changed, 202 insertions(+), 164 deletions(-) diff --git a/cypress/integration/snapshots_spec.js b/cypress/integration/snapshots_spec.js index c025e2a1e..b412fbd74 100644 --- a/cypress/integration/snapshots_spec.js +++ b/cypress/integration/snapshots_spec.js @@ -99,14 +99,4 @@ describe("Snapshots", () => { cy.contains("test_snapshot"); }); }); - - // describe("Snapshots can be restored", () => { - // it("Successfully restores all indices", () => { - // // Delete existing indices - // cy.deleteAllIndices(); - - // // Select snapshot to restore - // cy.get("checkbox").contains("test") - // }) - // }) }); diff --git a/public/models/interfaces.ts b/public/models/interfaces.ts index 5a645fecc..e1eb26f39 100644 --- a/public/models/interfaces.ts +++ b/public/models/interfaces.ts @@ -55,3 +55,17 @@ export interface LatestActivities { cause?: string; }; } + +export enum RESTORE_OPTIONS { + restore_specific_indices = "restore_specific_indices", + restore_all_indices = "restore_all_indices", + do_not_rename = "do_not_rename", + add_prefix = "add_prefix", + rename_indices = "rename_indices", + restore_aliases = "restore_aliases", + include_global_state = "include_global_state", + ignore_unavailable = "ignore_unavailable", + partial = "partial", + customize_index_settings = "customize_index_settings", + ignore_index_settings = "ignore_index_settings", +} diff --git a/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx b/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx index 59abedf74..4f6dd08c3 100644 --- a/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx +++ b/public/pages/Snapshots/components/AddPrefixInput/AddPrefixInput.tsx @@ -23,7 +23,7 @@ const AddPrefixesInput = ({ getPrefix }: AddPrefixesInputProps) => { <> - + diff --git a/public/pages/Snapshots/components/RenameInput/RenameInput.tsx b/public/pages/Snapshots/components/RenameInput/RenameInput.tsx index f35019fde..b549d1b92 100644 --- a/public/pages/Snapshots/components/RenameInput/RenameInput.tsx +++ b/public/pages/Snapshots/components/RenameInput/RenameInput.tsx @@ -27,9 +27,9 @@ const RenameInput = ({ getRenamePattern, getRenameReplacement }: RenameInputProp }; const patternHelpText = - "Use regular expressiojn to define how index names will be renamed. By default, input (.+) to reuse the entire index name [Learn more]"; + "Use regular expressiojn to define how index names will be renamed. By default, input (.+) to reuse the entire index name. [Learn more]"; const replacementHelpText = - "Define the format of renamed inices. Use $0 to include the entire matching index name, $1 to include the content of the first capture group, etc. [Learn more]"; + "Define the format of renamed indices. Use $0 to include the entire matching index name, $1 to include the content of the first capture group, etc. [Learn more]"; return ( <> diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 591d66643..9d7734362 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -20,6 +20,7 @@ import React, { Component, ChangeEvent } from "react"; import FlyoutFooter from "../../../VisualCreatePolicy/components/FlyoutFooter"; import { CoreServicesContext } from "../../../../components/core_services"; import { IndexService, SnapshotManagementService } from "../../../../services"; +import { RESTORE_OPTIONS } from "../../../../models/interfaces"; import { getErrorMessage } from "../../../../utils/helpers"; import { IndexItem } from "../../../../../models/interfaces"; import { CatRepository, GetSnapshot } from "../../../../../server/models/interfaces"; @@ -55,7 +56,6 @@ interface RestoreSnapshotState { snapshot: GetSnapshot | null; snapshotId: string; restoreSpecific: boolean; - restoreAliases: boolean; partial: boolean; repoError: string; @@ -79,7 +79,6 @@ export default class RestoreSnapshotFlyout extends Component option.label).join(","); const allIndices = indexOptions.map((option) => option.label).join(","); - const pattern = renameIndices === "add_prefix" ? "(?) => { - if (e.target.id === "restore_specific_indices") { + const { restore_specific_indices, restore_all_indices } = RESTORE_OPTIONS; + + if (e.target.id === restore_specific_indices) { this.setState({ restoreSpecific: true, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); return; } - if (e.target.id === "restore_all_indices") { + if (e.target.id === restore_all_indices) { this.setState({ restoreSpecific: false, snapshot: _.set(this.state.snapshot!, e.target.id, e.target.checked) }); return; } @@ -230,6 +232,18 @@ export default class RestoreSnapshotFlyout extends Component @@ -281,17 +295,17 @@ export default class RestoreSnapshotFlyout extends Component - {renameIndices === "add_prefix" && } - {renameIndices === "rename_indices" && ( + {renameIndices === add_prefix && } + {renameIndices === rename_indices && ( )} @@ -300,17 +314,17 @@ export default class RestoreSnapshotFlyout extends Component diff --git a/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx b/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx index 8de4d962f..06c2dd536 100644 --- a/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx +++ b/public/pages/Snapshots/components/SnapshotIndicesInput/SnapshotIndicesInput.tsx @@ -29,7 +29,7 @@ const SnapshotIndicesInput = ({ <> ) => void; @@ -25,40 +25,44 @@ const SnapshotRenameOptions = ({ renameIndices, onRenameIndicesToggle, width, -}: SnapshotRenameOptionsProps) => ( -
-
Rename restored indices
+}: SnapshotRenameOptionsProps) => { + const { do_not_rename, add_prefix, rename_indices } = RESTORE_OPTIONS; + + return ( +
+
Rename restored indices
- + - } - checked={doNotRename} - onChange={onDoNotRenameToggle} - /> + } + checked={doNotRename} + onChange={onDoNotRenameToggle} + /> - + - } - checked={addPrefix} - onChange={onAddPrefixToggle} - /> + } + checked={addPrefix} + onChange={onAddPrefixToggle} + /> - + - } - checked={renameIndices} - onChange={onRenameIndicesToggle} - /> -
-); + } + checked={renameIndices} + onChange={onRenameIndicesToggle} + /> +
+ ); +}; export default SnapshotRenameOptions; diff --git a/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx b/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx index 5ae6f799b..a7a583b23 100644 --- a/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx +++ b/public/pages/Snapshots/components/SnapshotRestoreAdvancedOptions/SnapshotRestoreAdvancedOptions.tsx @@ -3,9 +3,10 @@ * SPDX-License-Identifier: Apache-2.0 */ +import React, { ChangeEvent } from "react"; import { EuiCheckbox, EuiSpacer, EuiText } from "@elastic/eui"; import CustomLabel from "../../../../components/CustomLabel"; -import React, { ChangeEvent } from "react"; +import { RESTORE_OPTIONS } from "../../../../models/interfaces"; interface SnapshotAdvancedOptionsProps { restoreAliases: boolean; @@ -37,78 +38,88 @@ const SnapshotRestoreAdvancedOptions = ({ ignoreIndexSettings, onIgnoreIndexSettingsToggle, width, -}: SnapshotAdvancedOptionsProps) => ( -
- } - checked={restoreAliases} - onChange={onRestoreAliasesToggle} - /> - - - - } - checked={restoreClusterState} - onChange={onRestoreClusterStateToggle} - /> - - - - - } - checked={ignoreUnavailable} - onChange={onIgnoreUnavailableToggle} - /> - - - - } - checked={restorePartial} - onChange={onRestorePartialToggle} - /> - - - -
Custom index settings
- -

- By default, index settings are restored from indices in snapshots. You can choose to -
- customize index settings on restore. -

-
- - - - } - checked={customizeIndexSettings} - onChange={onCustomizeIndexSettingsToggle} - /> - - - - - } - checked={ignoreIndexSettings} - onChange={onIgnoreIndexSettingsToggle} - /> -
-); +}: SnapshotAdvancedOptionsProps) => { + const { + restore_aliases, + include_global_state, + ignore_unavailable, + partial, + customize_index_settings, + ignore_index_settings, + } = RESTORE_OPTIONS; + return ( +
+ } + checked={restoreAliases} + onChange={onRestoreAliasesToggle} + /> + + + + } + checked={restoreClusterState} + onChange={onRestoreClusterStateToggle} + /> + + + + + } + checked={ignoreUnavailable} + onChange={onIgnoreUnavailableToggle} + /> + + + + } + checked={restorePartial} + onChange={onRestorePartialToggle} + /> + + + +
Custom index settings
+ +

+ By default, index settings are restored from indices in snapshots. You can choose to +
+ customize index settings on restore. +

+
+ + + + } + checked={customizeIndexSettings} + onChange={onCustomizeIndexSettingsToggle} + /> + + + + + } + checked={ignoreIndexSettings} + onChange={onIgnoreIndexSettingsToggle} + /> +
+ ); +}; export default SnapshotRestoreAdvancedOptions; diff --git a/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx b/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx index 6d5e3b88c..49dd2fec4 100644 --- a/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx +++ b/public/pages/Snapshots/components/SnapshotRestoreOption/SnapshotRestoreOption.tsx @@ -3,9 +3,10 @@ * SPDX-License-Identifier: Apache-2.0 */ +import React, { ChangeEvent } from "react"; import { EuiRadio, EuiSpacer } from "@elastic/eui"; import CustomLabel from "../../../../components/CustomLabel"; -import React, { ChangeEvent } from "react"; +import { RESTORE_OPTIONS } from "../../../../models/interfaces"; interface SnapshotRestoreOptionProps { restoreAllIndices: boolean; @@ -21,30 +22,34 @@ const SnapshotRestoreOption = ({ restoreSpecificIndices, onRestoreSpecificIndicesToggle, width, -}: SnapshotRestoreOptionProps) => ( -
-
Specify restore option
- - - - } - checked={restoreAllIndices} - onChange={onRestoreAllIndicesToggle} - /> - - - - } - checked={restoreSpecificIndices} - onChange={onRestoreSpecificIndicesToggle} - /> -
-); +}: SnapshotRestoreOptionProps) => { + const { restore_all_indices, restore_specific_indices } = RESTORE_OPTIONS; + + return ( +
+
Specify restore option
+ + + + } + checked={restoreAllIndices} + onChange={onRestoreAllIndicesToggle} + /> + + + + } + checked={restoreSpecificIndices} + onChange={onRestoreSpecificIndicesToggle} + /> +
+ ); +}; export default SnapshotRestoreOption; From fd77a64a29554331b1909b3b2bdf313d49ebd15a Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 12 Sep 2022 12:08:32 -0700 Subject: [PATCH 28/39] Add back line 20 in rollups_spec, required by changes in 2.3 release. Signed-off-by: Chris Hesterman --- cypress/integration/rollups_spec.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/cypress/integration/rollups_spec.js b/cypress/integration/rollups_spec.js index 896a06271..866e49ab1 100644 --- a/cypress/integration/rollups_spec.js +++ b/cypress/integration/rollups_spec.js @@ -16,6 +16,9 @@ describe("Rollups", () => { // Go to sample data page cy.visit(`${Cypress.env("opensearch_dashboards")}/app/home#/tutorial_directory/sampleData`); + // Click on "Sample data" tab + cy.contains("Sample data").click({ force: true }); + // Load sample eCommerce data cy.get(`button[data-test-subj="addSampleDataSetecommerce"]`).click({ force: true }); From fb7f19e354d14a844ac288adc7bc356db84c74f3 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Wed, 14 Sep 2022 17:28:13 -0700 Subject: [PATCH 29/39] Remove unused getRepos func, add repo prop, trim state in RestoreFlyout Signed-off-by: Chris Hesterman --- .../RestoreSnapshotFlyout.tsx | 40 +++++-------------- .../containers/Snapshots/Snapshots.tsx | 1 + 2 files changed, 11 insertions(+), 30 deletions(-) diff --git a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx index 9d7734362..b9aba4925 100644 --- a/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx +++ b/public/pages/Snapshots/components/RestoreSnapshotFlyout/RestoreSnapshotFlyout.tsx @@ -23,7 +23,7 @@ import { IndexService, SnapshotManagementService } from "../../../../services"; import { RESTORE_OPTIONS } from "../../../../models/interfaces"; import { getErrorMessage } from "../../../../utils/helpers"; import { IndexItem } from "../../../../../models/interfaces"; -import { CatRepository, GetSnapshot } from "../../../../../server/models/interfaces"; +import { GetSnapshot } from "../../../../../server/models/interfaces"; import CustomLabel from "../../../../components/CustomLabel"; import SnapshotRestoreAdvancedOptions from "../SnapshotRestoreAdvancedOptions"; import SnapshotRestoreOption from "../SnapshotRestoreOption"; @@ -39,6 +39,7 @@ interface RestoreSnapshotProps { onCloseFlyout: () => void; restoreSnapshot: (snapshotId: string, repository: string, options: object) => void; snapshotId: string; + repository: string; } interface RestoreSnapshotState { @@ -50,9 +51,6 @@ interface RestoreSnapshotState { renameReplacement: string; listIndices: boolean; - repositories: CatRepository[]; - selectedRepoValue: string; - snapshot: GetSnapshot | null; snapshotId: string; restoreSpecific: boolean; @@ -74,8 +72,6 @@ export default class RestoreSnapshotFlyout extends Component { - const { restoreSnapshot, snapshotId } = this.props; + const { restoreSnapshot, snapshotId, repository } = this.props; const { - selectedRepoValue, restoreSpecific, selectedIndexOptions, indexOptions, @@ -106,6 +100,7 @@ export default class RestoreSnapshotFlyout extends Component option.label).join(","); const allIndices = indexOptions.map((option) => option.label).join(","); + // TODO replace unintelligible regex below with (.+) and add $1 to user provided prefix then add that to renameReplacement const pattern = renameIndices === add_prefix ? "(? { @@ -162,7 +157,7 @@ export default class RestoreSnapshotFlyout extends Component { - this.getSnapshot(this.props.snapshotId, this.state.selectedRepoValue); + this.getSnapshot(this.props.snapshotId, this.props.repository); }; onCreateOption = (searchValue: string, options: Array>) => { @@ -182,21 +177,6 @@ export default class RestoreSnapshotFlyout extends Component { - try { - const { snapshotManagementService } = this.props; - const response = await snapshotManagementService.catRepositories(); - if (response.ok) { - const selectedRepoValue = response.response.length > 0 ? response.response[0].id : ""; - this.setState({ repositories: response.response, selectedRepoValue }); - } else { - this.context.notifications.toasts.addDanger(response.error); - } - } catch (err) { - this.context.notifications.toasts.addDanger(getErrorMessage(err, "There was a problem loading the snapshots.")); - } - }; - getPrefix = (prefix: string) => { this.setState({ prefix: prefix }); }; @@ -229,8 +209,8 @@ export default class RestoreSnapshotFlyout extends Component )} diff --git a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx index 108693266..d8e3fbd19 100644 --- a/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx +++ b/public/pages/Snapshots/containers/Snapshots/Snapshots.tsx @@ -359,6 +359,7 @@ export default class Snapshots extends Component onCloseFlyout={this.onCloseRestoreFlyout} restoreSnapshot={this.restoreSnapshot} snapshotId={selectedItems[0].id} + repository={selectedItems[0].repository} /> )} From f553dbe1f17f781875b91181d88d920f0ef90c35 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 15 Sep 2022 09:18:41 -0700 Subject: [PATCH 30/39] Add increment to 2.3.0 Signed-off-by: Chris Hesterman --- .github/workflows/cypress-workflow.yml | 4 ++-- opensearch_dashboards.json | 14 +++++++++----- package.json | 4 ++-- 3 files changed, 13 insertions(+), 9 deletions(-) diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index e6ed61a83..f4761673f 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -7,8 +7,8 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.2' - OPENSEARCH_VERSION: '2.2.1-SNAPSHOT' + OPENSEARCH_DASHBOARDS_VERSION: '2.3' + OPENSEARCH_VERSION: '2.3.0-SNAPSHOT' jobs: tests: name: Run Cypress E2E tests diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index cc814397a..c1418c582 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,9 +1,13 @@ { "id": "indexManagementDashboards", - "version": "2.2.1.0", - "opensearchDashboardsVersion": "2.2.1", - "configPath": ["opensearch_index_management"], - "requiredPlugins": ["navigation"], + "version": "2.3.0.0", + "opensearchDashboardsVersion": "2.3.0", + "configPath": [ + "opensearch_index_management" + ], + "requiredPlugins": [ + "navigation" + ], "server": true, "ui": true -} +} \ No newline at end of file diff --git a/package.json b/package.json index 1375eaf89..4e1fb56e4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "opensearch_index_management_dashboards", - "version": "2.2.1.0", + "version": "2.3.0.0", "description": "Opensearch Dashboards plugin for Index Management", "main": "index.js", "license": "Apache-2.0", @@ -64,4 +64,4 @@ "engines": { "yarn": "^1.21.1" } -} +} \ No newline at end of file From b2f913275021c5032e858e0c6845f407c7754c3c Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Tue, 4 Oct 2022 09:08:55 -0700 Subject: [PATCH 31/39] Version bump 2.3.0 to 2.3 1 Signed-off-by: Chris Hesterman --- .github/workflows/cypress-workflow.yml | 2 +- opensearch_dashboards.json | 4 ++-- package.json | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index f4761673f..b45915b94 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -7,7 +7,7 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.3' + OPENSEARCH_DASHBOARDS_VERSION: '2.3.1' OPENSEARCH_VERSION: '2.3.0-SNAPSHOT' jobs: tests: diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index c1418c582..3eecb0b46 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,7 +1,7 @@ { "id": "indexManagementDashboards", - "version": "2.3.0.0", - "opensearchDashboardsVersion": "2.3.0", + "version": "2.3.1.0", + "opensearchDashboardsVersion": "2.3.1", "configPath": [ "opensearch_index_management" ], diff --git a/package.json b/package.json index 4e1fb56e4..88bc8ad73 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "opensearch_index_management_dashboards", - "version": "2.3.0.0", + "version": "2.3.1.0", "description": "Opensearch Dashboards plugin for Index Management", "main": "index.js", "license": "Apache-2.0", From 98cc0eef033b3b8d6355dd783c70c08ee3e3fa26 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Tue, 4 Oct 2022 09:38:44 -0700 Subject: [PATCH 32/39] Add version bump 2.3.1 for OS in cypress-workflow.yml Signed-off-by: Chris Hesterman --- .github/workflows/cypress-workflow.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index b45915b94..9ea057717 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -8,7 +8,7 @@ on: - "*" env: OPENSEARCH_DASHBOARDS_VERSION: '2.3.1' - OPENSEARCH_VERSION: '2.3.0-SNAPSHOT' + OPENSEARCH_VERSION: '2.3.1-SNAPSHOT' jobs: tests: name: Run Cypress E2E tests From 9315502bd6c91b3f2fa45aaef4b9b151e0aa3f3c Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Tue, 4 Oct 2022 17:14:15 -0700 Subject: [PATCH 33/39] Remove 2.3.1 bump Signed-off-by: Chris Hesterman --- .github/workflows/cypress-workflow.yml | 4 ++-- opensearch_dashboards.json | 4 ++-- package.json | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index 9ea057717..da3beabd2 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -7,8 +7,8 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.3.1' - OPENSEARCH_VERSION: '2.3.1-SNAPSHOT' + OPENSEARCH_DASHBOARDS_VERSION: '2.3.0' + OPENSEARCH_VERSION: '2.3.0-SNAPSHOT' jobs: tests: name: Run Cypress E2E tests diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index 3eecb0b46..c1418c582 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,7 +1,7 @@ { "id": "indexManagementDashboards", - "version": "2.3.1.0", - "opensearchDashboardsVersion": "2.3.1", + "version": "2.3.0.0", + "opensearchDashboardsVersion": "2.3.0", "configPath": [ "opensearch_index_management" ], diff --git a/package.json b/package.json index 88bc8ad73..4e1fb56e4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "opensearch_index_management_dashboards", - "version": "2.3.1.0", + "version": "2.3.0.0", "description": "Opensearch Dashboards plugin for Index Management", "main": "index.js", "license": "Apache-2.0", From 762c60d1bedc2815561e4d734ef232463bf03156 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 17 Oct 2022 16:13:06 -0700 Subject: [PATCH 34/39] Change 2.4 to 2.4.0 opensearch_dashboards.json Signed-off-by: Chris Hesterman --- opensearch_dashboards.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index 225228670..536e87f7a 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,7 +1,7 @@ { "id": "indexManagementDashboards", "version": "2.4.0.0", - "opensearchDashboardsVersion": "2.4", + "opensearchDashboardsVersion": "2.4.0", "configPath": [ "opensearch_index_management" ], From edc71acd45298d2865326dae95c83dc28056944f Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Mon, 7 Nov 2022 08:21:49 -0800 Subject: [PATCH 35/39] Update package.json, opensearch-dashboards.json Signed-off-by: Chris Hesterman --- opensearch_dashboards.json | 4 ++-- package.json | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index 536e87f7a..c1418c582 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,7 +1,7 @@ { "id": "indexManagementDashboards", - "version": "2.4.0.0", - "opensearchDashboardsVersion": "2.4.0", + "version": "2.3.0.0", + "opensearchDashboardsVersion": "2.3.0", "configPath": [ "opensearch_index_management" ], diff --git a/package.json b/package.json index 3a7db4108..84f15816a 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "opensearch_index_management_dashboards", - "version": "2.4.0", + "version": "2.3.0", "description": "Opensearch Dashboards plugin for Index Management", "main": "index.js", "license": "Apache-2.0", @@ -64,4 +64,4 @@ "engines": { "yarn": "^1.21.1" } -} +} \ No newline at end of file From c7f18b7f8331545ed70c709e4632a289374d6f8d Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 17 Nov 2022 09:58:55 -0800 Subject: [PATCH 36/39] Update package.json, opensearch_dashboards.json Signed-off-by: Chris Hesterman --- opensearch_dashboards.json | 12 ++++-------- package.json | 4 ++-- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index c1418c582..3ea0c5c6c 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,13 +1,9 @@ { "id": "indexManagementDashboards", - "version": "2.3.0.0", + "version": "2.4.0.0", "opensearchDashboardsVersion": "2.3.0", - "configPath": [ - "opensearch_index_management" - ], - "requiredPlugins": [ - "navigation" - ], + "configPath": ["opensearch_index_management"], + "requiredPlugins": ["navigation"], "server": true, "ui": true -} \ No newline at end of file +} diff --git a/package.json b/package.json index 84f15816a..3a7db4108 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "opensearch_index_management_dashboards", - "version": "2.3.0", + "version": "2.4.0", "description": "Opensearch Dashboards plugin for Index Management", "main": "index.js", "license": "Apache-2.0", @@ -64,4 +64,4 @@ "engines": { "yarn": "^1.21.1" } -} \ No newline at end of file +} From 2f78649c27a18e6a75c9d4b3e7e8d078d6310613 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 17 Nov 2022 12:47:23 -0800 Subject: [PATCH 37/39] Update OSD to 2.4.1, update loader-utils, ts-loader, webpack Signed-off-by: Chris Hesterman --- .github/workflows/cypress-workflow.yml | 2 +- .github/workflows/unit-tests-workflow.yml | 2 +- opensearch_dashboards.json | 2 +- package.json | 5 +- yarn.lock | 1697 +++++---------------- 5 files changed, 417 insertions(+), 1291 deletions(-) diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index de77002b4..a3d76e996 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -7,7 +7,7 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.4' + OPENSEARCH_DASHBOARDS_VERSION: '2.4.1' OPENSEARCH_VERSION: '2.4.0-SNAPSHOT' jobs: tests: diff --git a/.github/workflows/unit-tests-workflow.yml b/.github/workflows/unit-tests-workflow.yml index b6fa18fd3..42da15cf4 100644 --- a/.github/workflows/unit-tests-workflow.yml +++ b/.github/workflows/unit-tests-workflow.yml @@ -7,7 +7,7 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.4' + OPENSEARCH_DASHBOARDS_VERSION: '2.4.1' jobs: tests: name: Run unit tests diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index 3ea0c5c6c..d48fa6e0e 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,7 +1,7 @@ { "id": "indexManagementDashboards", "version": "2.4.0.0", - "opensearchDashboardsVersion": "2.3.0", + "opensearchDashboardsVersion": "2.4.1", "configPath": ["opensearch_index_management"], "requiredPlugins": ["navigation"], "server": true, diff --git a/package.json b/package.json index 3a7db4108..d4801f1e8 100644 --- a/package.json +++ b/package.json @@ -39,13 +39,16 @@ "glob-parent": "^5.1.2", "ssri": "^6.0.2", "lodash": "^4.17.21", + "loader-utils": "^2.0.3", "hosted-git-info": "^2.8.9", "json-schema": "^0.4.0", "ansi-regex": "^5.0.1", "minimist": "^1.2.6", "moment": "^2.29.4", "async": "^3.2.3", - "terser": "^4.8.1" + "terser": "^4.8.1", + "ts-loader": "^8.4.0", + "webpack": "^5.75.0" }, "devDependencies": { "@elastic/elastic-eslint-config-kibana": "link:../../packages/opensearch-eslint-config-opensearch-dashboards", diff --git a/yarn.lock b/yarn.lock index cd8db2e66..715b2a5ff 100644 --- a/yarn.lock +++ b/yarn.lock @@ -112,6 +112,24 @@ "@types/istanbul-reports" "^1.1.1" "@types/yargs" "^13.0.0" +"@jridgewell/resolve-uri@3.1.0": + version "3.1.0" + resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz#2203b118c157721addfe69d47b70465463066d78" + integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w== + +"@jridgewell/sourcemap-codec@1.4.14": + version "1.4.14" + resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz#add4c98d341472a289190b424efbdb096991bb24" + integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw== + +"@jridgewell/trace-mapping@^0.3.14": + version "0.3.17" + resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz#793041277af9073b0951a7fe0f0d8c4c98c36985" + integrity sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g== + dependencies: + "@jridgewell/resolve-uri" "3.1.0" + "@jridgewell/sourcemap-codec" "1.4.14" + "@nodelib/fs.scandir@2.1.4": version "2.1.4" resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.4.tgz#d4b3549a5db5de2683e0c1071ab4f140904bbf69" @@ -171,6 +189,32 @@ resolved "https://registry.yarnpkg.com/@types/aria-query/-/aria-query-4.2.1.tgz#78b5433344e2f92e8b306c06a5622c50c245bf6b" integrity sha512-S6oPal772qJZHoRZLFc/XoZW2gFvwXusYUmXPXkgxJLuEk2vOt7jc4Yo6z/vtI0EBkbPBVrJJ0B+prLIKiWqHg== +"@types/eslint-scope@^3.7.3": + version "3.7.4" + resolved "https://registry.yarnpkg.com/@types/eslint-scope/-/eslint-scope-3.7.4.tgz#37fc1223f0786c39627068a12e94d6e6fc61de16" + integrity sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA== + dependencies: + "@types/eslint" "*" + "@types/estree" "*" + +"@types/eslint@*": + version "8.4.10" + resolved "https://registry.yarnpkg.com/@types/eslint/-/eslint-8.4.10.tgz#19731b9685c19ed1552da7052b6f668ed7eb64bb" + integrity sha512-Sl/HOqN8NKPmhWo2VBEPm0nvHnu2LL3v9vKo8MEq0EtbJ4eVzGPl41VNPvn5E1i5poMk4/XD8UriLHpJvEP/Nw== + dependencies: + "@types/estree" "*" + "@types/json-schema" "*" + +"@types/estree@*": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.0.tgz#5fb2e536c1ae9bf35366eed879e827fa59ca41c2" + integrity sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ== + +"@types/estree@^0.0.51": + version "0.0.51" + resolved "https://registry.yarnpkg.com/@types/estree/-/estree-0.0.51.tgz#cfd70924a25a3fd32b218e5e420e6897e1ac4f40" + integrity sha512-CuPgU6f3eT/XgKKPqKd/gLZV1Xmvf1a2R5POBOGQa6uv82xpls89HU5zKeVoyR8XzHd1RGNOlQlvUe3CFkjWNQ== + "@types/glob@^7.1.1": version "7.1.3" resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.1.3.tgz#e6ba80f36b7daad2c685acd9266382e68985c183" @@ -216,6 +260,11 @@ dependencies: jest-diff "^24.3.0" +"@types/json-schema@*", "@types/json-schema@^7.0.8": + version "7.0.11" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.11.tgz#d421b6c527a3037f7c84433fd2c4229e016863d3" + integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== + "@types/minimatch@*": version "3.0.3" resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d" @@ -295,149 +344,125 @@ dependencies: "@types/yargs-parser" "*" -"@webassemblyjs/ast@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.9.0.tgz#bd850604b4042459a5a41cd7d338cbed695ed964" - integrity sha512-C6wW5L+b7ogSDVqymbkkvuW9kruN//YisMED04xzeBBqjHa2FYnmvOlS6Xj68xWQRgWvI9cIglsjFowH/RJyEA== - dependencies: - "@webassemblyjs/helper-module-context" "1.9.0" - "@webassemblyjs/helper-wasm-bytecode" "1.9.0" - "@webassemblyjs/wast-parser" "1.9.0" - -"@webassemblyjs/floating-point-hex-parser@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.9.0.tgz#3c3d3b271bddfc84deb00f71344438311d52ffb4" - integrity sha512-TG5qcFsS8QB4g4MhrxK5TqfdNe7Ey/7YL/xN+36rRjl/BlGE/NcBvJcqsRgCP6Z92mRE+7N50pRIi8SmKUbcQA== - -"@webassemblyjs/helper-api-error@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.9.0.tgz#203f676e333b96c9da2eeab3ccef33c45928b6a2" - integrity sha512-NcMLjoFMXpsASZFxJ5h2HZRcEhDkvnNFOAKneP5RbKRzaWJN36NC4jqQHKwStIhGXu5mUWlUUk7ygdtrO8lbmw== - -"@webassemblyjs/helper-buffer@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.9.0.tgz#a1442d269c5feb23fcbc9ef759dac3547f29de00" - integrity sha512-qZol43oqhq6yBPx7YM3m9Bv7WMV9Eevj6kMi6InKOuZxhw+q9hOkvq5e/PpKSiLfyetpaBnogSbNCfBwyB00CA== - -"@webassemblyjs/helper-code-frame@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.9.0.tgz#647f8892cd2043a82ac0c8c5e75c36f1d9159f27" - integrity sha512-ERCYdJBkD9Vu4vtjUYe8LZruWuNIToYq/ME22igL+2vj2dQ2OOujIZr3MEFvfEaqKoVqpsFKAGsRdBSBjrIvZA== - dependencies: - "@webassemblyjs/wast-printer" "1.9.0" - -"@webassemblyjs/helper-fsm@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-fsm/-/helper-fsm-1.9.0.tgz#c05256b71244214671f4b08ec108ad63b70eddb8" - integrity sha512-OPRowhGbshCb5PxJ8LocpdX9Kl0uB4XsAjl6jH/dWKlk/mzsANvhwbiULsaiqT5GZGT9qinTICdj6PLuM5gslw== - -"@webassemblyjs/helper-module-context@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-module-context/-/helper-module-context-1.9.0.tgz#25d8884b76839871a08a6c6f806c3979ef712f07" - integrity sha512-MJCW8iGC08tMk2enck1aPW+BE5Cw8/7ph/VGZxwyvGbJwjktKkDK7vy7gAmMDx88D7mhDTCNKAW5tED+gZ0W8g== - dependencies: - "@webassemblyjs/ast" "1.9.0" - -"@webassemblyjs/helper-wasm-bytecode@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.9.0.tgz#4fed8beac9b8c14f8c58b70d124d549dd1fe5790" - integrity sha512-R7FStIzyNcd7xKxCZH5lE0Bqy+hGTwS3LJjuv1ZVxd9O7eHCedSdrId/hMOd20I+v8wDXEn+bjfKDLzTepoaUw== - -"@webassemblyjs/helper-wasm-section@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.9.0.tgz#5a4138d5a6292ba18b04c5ae49717e4167965346" - integrity sha512-XnMB8l3ek4tvrKUUku+IVaXNHz2YsJyOOmz+MMkZvh8h1uSJpSen6vYnw3IoQ7WwEuAhL8Efjms1ZWjqh2agvw== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/helper-buffer" "1.9.0" - "@webassemblyjs/helper-wasm-bytecode" "1.9.0" - "@webassemblyjs/wasm-gen" "1.9.0" - -"@webassemblyjs/ieee754@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/ieee754/-/ieee754-1.9.0.tgz#15c7a0fbaae83fb26143bbacf6d6df1702ad39e4" - integrity sha512-dcX8JuYU/gvymzIHc9DgxTzUUTLexWwt8uCTWP3otys596io0L5aW02Gb1RjYpx2+0Jus1h4ZFqjla7umFniTg== +"@webassemblyjs/ast@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.11.1.tgz#2bfd767eae1a6996f432ff7e8d7fc75679c0b6a7" + integrity sha512-ukBh14qFLjxTQNTXocdyksN5QdM28S1CxHt2rdskFyL+xFV7VremuBLVbmCePj+URalXBENx/9Lm7lnhihtCSw== dependencies: - "@xtuc/ieee754" "^1.2.0" + "@webassemblyjs/helper-numbers" "1.11.1" + "@webassemblyjs/helper-wasm-bytecode" "1.11.1" -"@webassemblyjs/leb128@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/leb128/-/leb128-1.9.0.tgz#f19ca0b76a6dc55623a09cffa769e838fa1e1c95" - integrity sha512-ENVzM5VwV1ojs9jam6vPys97B/S65YQtv/aanqnU7D8aSoHFX8GyhGg0CMfyKNIHBuAVjy3tlzd5QMMINa7wpw== +"@webassemblyjs/floating-point-hex-parser@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.1.tgz#f6c61a705f0fd7a6aecaa4e8198f23d9dc179e4f" + integrity sha512-iGRfyc5Bq+NnNuX8b5hwBrRjzf0ocrJPI6GWFodBFzmFnyvrQ83SHKhmilCU/8Jv67i4GJZBMhEzltxzcNagtQ== + +"@webassemblyjs/helper-api-error@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.1.tgz#1a63192d8788e5c012800ba6a7a46c705288fd16" + integrity sha512-RlhS8CBCXfRUR/cwo2ho9bkheSXG0+NwooXcc3PAILALf2QLdFyj7KGsKRbVc95hZnhnERon4kW/D3SZpp6Tcg== + +"@webassemblyjs/helper-buffer@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.1.tgz#832a900eb444884cde9a7cad467f81500f5e5ab5" + integrity sha512-gwikF65aDNeeXa8JxXa2BAk+REjSyhrNC9ZwdT0f8jc4dQQeDQ7G4m0f2QCLPJiMTTO6wfDmRmj/pW0PsUvIcA== + +"@webassemblyjs/helper-numbers@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.1.tgz#64d81da219fbbba1e3bd1bfc74f6e8c4e10a62ae" + integrity sha512-vDkbxiB8zfnPdNK9Rajcey5C0w+QJugEglN0of+kmO8l7lDb77AnlKYQF7aarZuCrv+l0UvqL+68gSDr3k9LPQ== dependencies: + "@webassemblyjs/floating-point-hex-parser" "1.11.1" + "@webassemblyjs/helper-api-error" "1.11.1" "@xtuc/long" "4.2.2" -"@webassemblyjs/utf8@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/utf8/-/utf8-1.9.0.tgz#04d33b636f78e6a6813227e82402f7637b6229ab" - integrity sha512-GZbQlWtopBTP0u7cHrEx+73yZKrQoBMpwkGEIqlacljhXCkVM1kMQge/Mf+csMJAjEdSwhOyLAS0AoR3AG5P8w== - -"@webassemblyjs/wasm-edit@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.9.0.tgz#3fe6d79d3f0f922183aa86002c42dd256cfee9cf" - integrity sha512-FgHzBm80uwz5M8WKnMTn6j/sVbqilPdQXTWraSjBwFXSYGirpkSWE2R9Qvz9tNiTKQvoKILpCuTjBKzOIm0nxw== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/helper-buffer" "1.9.0" - "@webassemblyjs/helper-wasm-bytecode" "1.9.0" - "@webassemblyjs/helper-wasm-section" "1.9.0" - "@webassemblyjs/wasm-gen" "1.9.0" - "@webassemblyjs/wasm-opt" "1.9.0" - "@webassemblyjs/wasm-parser" "1.9.0" - "@webassemblyjs/wast-printer" "1.9.0" - -"@webassemblyjs/wasm-gen@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.9.0.tgz#50bc70ec68ded8e2763b01a1418bf43491a7a49c" - integrity sha512-cPE3o44YzOOHvlsb4+E9qSqjc9Qf9Na1OO/BHFy4OI91XDE14MjFN4lTMezzaIWdPqHnsTodGGNP+iRSYfGkjA== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/helper-wasm-bytecode" "1.9.0" - "@webassemblyjs/ieee754" "1.9.0" - "@webassemblyjs/leb128" "1.9.0" - "@webassemblyjs/utf8" "1.9.0" - -"@webassemblyjs/wasm-opt@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.9.0.tgz#2211181e5b31326443cc8112eb9f0b9028721a61" - integrity sha512-Qkjgm6Anhm+OMbIL0iokO7meajkzQD71ioelnfPEj6r4eOFuqm4YC3VBPqXjFyyNwowzbMD+hizmprP/Fwkl2A== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/helper-buffer" "1.9.0" - "@webassemblyjs/wasm-gen" "1.9.0" - "@webassemblyjs/wasm-parser" "1.9.0" - -"@webassemblyjs/wasm-parser@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.9.0.tgz#9d48e44826df4a6598294aa6c87469d642fff65e" - integrity sha512-9+wkMowR2AmdSWQzsPEjFU7njh8HTO5MqO8vjwEHuM+AMHioNqSBONRdr0NQQ3dVQrzp0s8lTcYqzUdb7YgELA== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/helper-api-error" "1.9.0" - "@webassemblyjs/helper-wasm-bytecode" "1.9.0" - "@webassemblyjs/ieee754" "1.9.0" - "@webassemblyjs/leb128" "1.9.0" - "@webassemblyjs/utf8" "1.9.0" - -"@webassemblyjs/wast-parser@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-parser/-/wast-parser-1.9.0.tgz#3031115d79ac5bd261556cecc3fa90a3ef451914" - integrity sha512-qsqSAP3QQ3LyZjNC/0jBJ/ToSxfYJ8kYyuiGvtn/8MK89VrNEfwj7BPQzJVHi0jGTRK2dGdJ5PRqhtjzoww+bw== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/floating-point-hex-parser" "1.9.0" - "@webassemblyjs/helper-api-error" "1.9.0" - "@webassemblyjs/helper-code-frame" "1.9.0" - "@webassemblyjs/helper-fsm" "1.9.0" - "@xtuc/long" "4.2.2" +"@webassemblyjs/helper-wasm-bytecode@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.1.tgz#f328241e41e7b199d0b20c18e88429c4433295e1" + integrity sha512-PvpoOGiJwXeTrSf/qfudJhwlvDQxFgelbMqtq52WWiXC6Xgg1IREdngmPN3bs4RoO83PnL/nFrxucXj1+BX62Q== -"@webassemblyjs/wast-printer@1.9.0": - version "1.9.0" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-printer/-/wast-printer-1.9.0.tgz#4935d54c85fef637b00ce9f52377451d00d47899" - integrity sha512-2J0nE95rHXHyQ24cWjMKJ1tqB/ds8z/cyeOZxJhcb+rW+SQASVjuznUSmdz5GpVJTzU8JkhYut0D3siFDD6wsA== +"@webassemblyjs/helper-wasm-section@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.1.tgz#21ee065a7b635f319e738f0dd73bfbda281c097a" + integrity sha512-10P9No29rYX1j7F3EVPX3JvGPQPae+AomuSTPiF9eBQeChHI6iqjMIwR9JmOJXwpnn/oVGDk7I5IlskuMwU/pg== dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/wast-parser" "1.9.0" + "@webassemblyjs/ast" "1.11.1" + "@webassemblyjs/helper-buffer" "1.11.1" + "@webassemblyjs/helper-wasm-bytecode" "1.11.1" + "@webassemblyjs/wasm-gen" "1.11.1" + +"@webassemblyjs/ieee754@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/ieee754/-/ieee754-1.11.1.tgz#963929e9bbd05709e7e12243a099180812992614" + integrity sha512-hJ87QIPtAMKbFq6CGTkZYJivEwZDbQUgYd3qKSadTNOhVY7p+gfP6Sr0lLRVTaG1JjFj+r3YchoqRYxNH3M0GQ== + dependencies: + "@xtuc/ieee754" "^1.2.0" + +"@webassemblyjs/leb128@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/leb128/-/leb128-1.11.1.tgz#ce814b45574e93d76bae1fb2644ab9cdd9527aa5" + integrity sha512-BJ2P0hNZ0u+Th1YZXJpzW6miwqQUGcIHT1G/sf72gLVD9DZ5AdYTqPNbHZh6K1M5VmKvFXwGSWZADz+qBWxeRw== + dependencies: + "@xtuc/long" "4.2.2" + +"@webassemblyjs/utf8@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/utf8/-/utf8-1.11.1.tgz#d1f8b764369e7c6e6bae350e854dec9a59f0a3ff" + integrity sha512-9kqcxAEdMhiwQkHpkNiorZzqpGrodQQ2IGrHHxCy+Ozng0ofyMA0lTqiLkVs1uzTRejX+/O0EOT7KxqVPuXosQ== + +"@webassemblyjs/wasm-edit@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.1.tgz#ad206ebf4bf95a058ce9880a8c092c5dec8193d6" + integrity sha512-g+RsupUC1aTHfR8CDgnsVRVZFJqdkFHpsHMfJuWQzWU3tvnLC07UqHICfP+4XyL2tnr1amvl1Sdp06TnYCmVkA== + dependencies: + "@webassemblyjs/ast" "1.11.1" + "@webassemblyjs/helper-buffer" "1.11.1" + "@webassemblyjs/helper-wasm-bytecode" "1.11.1" + "@webassemblyjs/helper-wasm-section" "1.11.1" + "@webassemblyjs/wasm-gen" "1.11.1" + "@webassemblyjs/wasm-opt" "1.11.1" + "@webassemblyjs/wasm-parser" "1.11.1" + "@webassemblyjs/wast-printer" "1.11.1" + +"@webassemblyjs/wasm-gen@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.1.tgz#86c5ea304849759b7d88c47a32f4f039ae3c8f76" + integrity sha512-F7QqKXwwNlMmsulj6+O7r4mmtAlCWfO/0HdgOxSklZfQcDu0TpLiD1mRt/zF25Bk59FIjEuGAIyn5ei4yMfLhA== + dependencies: + "@webassemblyjs/ast" "1.11.1" + "@webassemblyjs/helper-wasm-bytecode" "1.11.1" + "@webassemblyjs/ieee754" "1.11.1" + "@webassemblyjs/leb128" "1.11.1" + "@webassemblyjs/utf8" "1.11.1" + +"@webassemblyjs/wasm-opt@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.1.tgz#657b4c2202f4cf3b345f8a4c6461c8c2418985f2" + integrity sha512-VqnkNqnZlU5EB64pp1l7hdm3hmQw7Vgqa0KF/KCNO9sIpI6Fk6brDEiX+iCOYrvMuBWDws0NkTOxYEb85XQHHw== + dependencies: + "@webassemblyjs/ast" "1.11.1" + "@webassemblyjs/helper-buffer" "1.11.1" + "@webassemblyjs/wasm-gen" "1.11.1" + "@webassemblyjs/wasm-parser" "1.11.1" + +"@webassemblyjs/wasm-parser@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.1.tgz#86ca734534f417e9bd3c67c7a1c75d8be41fb199" + integrity sha512-rrBujw+dJu32gYB7/Lup6UhdkPx9S9SnobZzRVL7VcBH9Bt9bCBLEuX/YXOOtBsOZ4NQrRykKhffRWHvigQvOA== + dependencies: + "@webassemblyjs/ast" "1.11.1" + "@webassemblyjs/helper-api-error" "1.11.1" + "@webassemblyjs/helper-wasm-bytecode" "1.11.1" + "@webassemblyjs/ieee754" "1.11.1" + "@webassemblyjs/leb128" "1.11.1" + "@webassemblyjs/utf8" "1.11.1" + +"@webassemblyjs/wast-printer@1.11.1": + version "1.11.1" + resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-printer/-/wast-printer-1.11.1.tgz#d0c73beda8eec5426f10ae8ef55cee5e7084c2f0" + integrity sha512-IQboUWM4eKzWW+N/jij2sRatKMh99QEelo3Eb2q0qXkvPRISAj8Qxtmw5itwqK+TTkBuUIE45AxYPToqPtL5gg== + dependencies: + "@webassemblyjs/ast" "1.11.1" "@xtuc/long" "4.2.2" "@xtuc/ieee754@^1.2.0": @@ -450,10 +475,15 @@ resolved "https://registry.yarnpkg.com/@xtuc/long/-/long-4.2.2.tgz#d291c6a4e97989b5c61d9acf396ae4fe133a718d" integrity sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ== -acorn@^6.4.1: - version "6.4.2" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-6.4.2.tgz#35866fd710528e92de10cf06016498e47e39e1e6" - integrity sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ== +acorn-import-assertions@^1.7.6: + version "1.8.0" + resolved "https://registry.yarnpkg.com/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz#ba2b5939ce62c238db6d93d81c9b111b29b855e9" + integrity sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw== + +acorn@^8.7.1: + version "8.8.1" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.1.tgz#0a3f9cbecc4ec3bea6f0a80b66ae8dd2da250b73" + integrity sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA== aggregate-error@^3.0.0: version "3.1.0" @@ -463,17 +493,12 @@ aggregate-error@^3.0.0: clean-stack "^2.0.0" indent-string "^4.0.0" -ajv-errors@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/ajv-errors/-/ajv-errors-1.0.1.tgz#f35986aceb91afadec4102fbd85014950cefa64d" - integrity sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ== - -ajv-keywords@^3.1.0, ajv-keywords@^3.4.1: +ajv-keywords@^3.5.2: version "3.5.2" resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz#31f29da5ab6e00d1c2d329acf7b5929614d5014d" integrity sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ== -ajv@^6.1.0, ajv@^6.10.2, ajv@^6.12.3: +ajv@^6.12.3, ajv@^6.12.5: version "6.12.6" resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== @@ -522,27 +547,6 @@ any-observable@^0.3.0: resolved "https://registry.yarnpkg.com/any-observable/-/any-observable-0.3.0.tgz#af933475e5806a67d0d7df090dd5e8bef65d119b" integrity sha512-/FQM1EDkTsf63Ub2C6O7GuYFDsSXUwsaZDurV0np41ocwq0jthUAYCmhBX9f+KwlaCgIuWyr/4WlUQUBfKfZog== -anymatch@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-2.0.0.tgz#bcb24b4f37934d9aa7ac17b4adaf89e7c76ef2eb" - integrity sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw== - dependencies: - micromatch "^3.1.4" - normalize-path "^2.1.1" - -anymatch@~3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.1.tgz#c55ecf02185e2469259399310c173ce31233b142" - integrity sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg== - dependencies: - normalize-path "^3.0.0" - picomatch "^2.0.4" - -aproba@^1.1.1: - version "1.2.0" - resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a" - integrity sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw== - arch@^2.1.2: version "2.2.0" resolved "https://registry.yarnpkg.com/arch/-/arch-2.2.0.tgz#1bc47818f305764f23ab3306b0bfc086c5a29d11" @@ -560,21 +564,6 @@ aria-query@^5.0.0: resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-5.0.0.tgz#210c21aaf469613ee8c9a62c7f86525e058db52c" integrity sha512-V+SM7AbUwJ+EBnB8+DXs0hPZHO0W6pqBcc0dW90OwtVG02PswOu/teuARoLQjdDOH+t9pJgGnW5/Qmouf3gPJg== -arr-diff@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz#d6461074febfec71e7e15235761a329a5dc7c520" - integrity sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA= - -arr-flatten@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" - integrity sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg== - -arr-union@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz#e39b09aea9def866a8f206e288af63919bae39c4" - integrity sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ= - array-find@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/array-find/-/array-find-1.0.0.tgz#6c8e286d11ed768327f8e62ecee87353ca3e78b8" @@ -585,11 +574,6 @@ array-union@^2.1.0: resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== -array-unique@^0.3.2: - version "0.3.2" - resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428" - integrity sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg= - asn1.js@^5.2.0: version "5.4.1" resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-5.4.1.tgz#11a980b84ebb91781ce35b0fdc2ee294e3783f07" @@ -620,16 +604,6 @@ assert@^1.1.1: object-assign "^4.1.1" util "0.10.3" -assign-symbols@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367" - integrity sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c= - -async-each@^1.0.1: - version "1.0.3" - resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.3.tgz#b727dbf87d7651602f06f4d4ac387f47d91b0cbf" - integrity sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ== - async@^3.2.0, async@^3.2.3: version "3.2.3" resolved "https://registry.yarnpkg.com/async/-/async-3.2.3.tgz#ac53dafd3f4720ee9e8a160628f18ea91df196c9" @@ -645,11 +619,6 @@ at-least-node@^1.0.0: resolved "https://registry.yarnpkg.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" integrity sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg== -atob@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" - integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== - aws-sign2@~0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" @@ -670,19 +639,6 @@ base64-js@^1.0.2: resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== -base@^0.11.1: - version "0.11.2" - resolved "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz#7bde5ced145b6d551a90db87f83c558b4eb48a8f" - integrity sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg== - dependencies: - cache-base "^1.0.1" - class-utils "^0.3.5" - component-emitter "^1.2.1" - define-property "^1.0.0" - isobject "^3.0.1" - mixin-deep "^1.2.0" - pascalcase "^0.1.1" - bcrypt-pbkdf@^1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e" @@ -695,29 +651,12 @@ big.js@^5.2.2: resolved "https://registry.yarnpkg.com/big.js/-/big.js-5.2.2.tgz#65f0af382f578bcdc742bd9c281e9cb2d7768328" integrity sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ== -binary-extensions@^1.0.0: - version "1.13.1" - resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-1.13.1.tgz#598afe54755b2868a5330d2aff9d4ebb53209b65" - integrity sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw== - -binary-extensions@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" - integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== - -bindings@^1.5.0: - version "1.5.0" - resolved "https://registry.yarnpkg.com/bindings/-/bindings-1.5.0.tgz#10353c9e945334bc0511a6d90b38fbc7c9c504df" - integrity sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ== - dependencies: - file-uri-to-path "1.0.0" - blob-util@2.0.2: version "2.0.2" resolved "https://registry.yarnpkg.com/blob-util/-/blob-util-2.0.2.tgz#3b4e3c281111bb7f11128518006cdc60b403a1eb" integrity sha512-T7JQa+zsXXEa6/8ZhHcQEW1UFfVM49Ts65uBkFL6fz2QmrElqmbajIDJvuA0tEhRe5eIjpV9ZF+0RfZR9voJFQ== -bluebird@^3.5.5, bluebird@^3.7.2: +bluebird@^3.7.2: version "3.7.2" resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== @@ -740,23 +679,7 @@ brace-expansion@^1.1.7: balanced-match "^1.0.0" concat-map "0.0.1" -braces@^2.3.1, braces@^2.3.2: - version "2.3.2" - resolved "https://registry.yarnpkg.com/braces/-/braces-2.3.2.tgz#5979fd3f14cd531565e5fa2df1abfff1dfaee729" - integrity sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w== - dependencies: - arr-flatten "^1.1.0" - array-unique "^0.3.2" - extend-shallow "^2.0.1" - fill-range "^4.0.0" - isobject "^3.0.1" - repeat-element "^1.1.2" - snapdragon "^0.8.1" - snapdragon-node "^2.0.1" - split-string "^3.0.2" - to-regex "^3.0.1" - -braces@^3.0.1, braces@~3.0.2: +braces@^3.0.1: version "3.0.2" resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== @@ -829,6 +752,16 @@ browserify-zlib@^0.2.0: dependencies: pako "~1.0.5" +browserslist@^4.14.5: + version "4.21.4" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.21.4.tgz#e7496bbc67b9e39dd0f98565feccdcb0d4ff6987" + integrity sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw== + dependencies: + caniuse-lite "^1.0.30001400" + electron-to-chromium "^1.4.251" + node-releases "^2.0.6" + update-browserslist-db "^1.0.9" + buffer-crc32@~0.2.3: version "0.2.13" resolved "https://registry.yarnpkg.com/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242" @@ -858,42 +791,6 @@ builtin-status-codes@^3.0.0: resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8" integrity sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug= -cacache@^12.0.2: - version "12.0.4" - resolved "https://registry.yarnpkg.com/cacache/-/cacache-12.0.4.tgz#668bcbd105aeb5f1d92fe25570ec9525c8faa40c" - integrity sha512-a0tMB40oefvuInr4Cwb3GerbL9xTj1D5yg0T5xrjGCGyfvbxseIXX7BAO/u/hIXdafzOI5JC3wDwHyf24buOAQ== - dependencies: - bluebird "^3.5.5" - chownr "^1.1.1" - figgy-pudding "^3.5.1" - glob "^7.1.4" - graceful-fs "^4.1.15" - infer-owner "^1.0.3" - lru-cache "^5.1.1" - mississippi "^3.0.0" - mkdirp "^0.5.1" - move-concurrently "^1.0.1" - promise-inflight "^1.0.1" - rimraf "^2.6.3" - ssri "^6.0.1" - unique-filename "^1.1.1" - y18n "^4.0.0" - -cache-base@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2" - integrity sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ== - dependencies: - collection-visit "^1.0.0" - component-emitter "^1.2.1" - get-value "^2.0.6" - has-value "^1.0.0" - isobject "^3.0.1" - set-value "^2.0.0" - to-object-path "^0.3.0" - union-value "^1.0.0" - unset-value "^1.0.0" - cachedir@^2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/cachedir/-/cachedir-2.3.0.tgz#0c75892a052198f0b21c7c1804d8331edfcae0e8" @@ -923,6 +820,11 @@ camelcase@^5.0.0: resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== +caniuse-lite@^1.0.30001400: + version "1.0.30001431" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001431.tgz#e7c59bd1bc518fae03a4656be442ce6c4887a795" + integrity sha512-zBUoFU0ZcxpvSt9IU66dXVT/3ctO1cy4y9cscs1szkPlcWb6pasYM144GqrUygUbT+k7cmUCW61cvskjcv0enQ== + caseless@~0.12.0: version "0.12.0" resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" @@ -961,45 +863,6 @@ check-more-types@^2.24.0: resolved "https://registry.yarnpkg.com/check-more-types/-/check-more-types-2.24.0.tgz#1420ffb10fd444dcfc79b43891bbfffd32a84600" integrity sha1-FCD/sQ/URNz8ebQ4kbv//TKoRgA= -chokidar@^2.1.8: - version "2.1.8" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-2.1.8.tgz#804b3a7b6a99358c3c5c61e71d8728f041cff917" - integrity sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg== - dependencies: - anymatch "^2.0.0" - async-each "^1.0.1" - braces "^2.3.2" - glob-parent "^3.1.0" - inherits "^2.0.3" - is-binary-path "^1.0.0" - is-glob "^4.0.0" - normalize-path "^3.0.0" - path-is-absolute "^1.0.0" - readdirp "^2.2.1" - upath "^1.1.1" - optionalDependencies: - fsevents "^1.2.7" - -chokidar@^3.4.1: - version "3.5.1" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.1.tgz#ee9ce7bbebd2b79f49f304799d5468e31e14e68a" - integrity sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw== - dependencies: - anymatch "~3.1.1" - braces "~3.0.2" - glob-parent "~5.1.0" - is-binary-path "~2.1.0" - is-glob "~4.0.1" - normalize-path "~3.0.0" - readdirp "~3.5.0" - optionalDependencies: - fsevents "~2.3.1" - -chownr@^1.1.1: - version "1.1.4" - resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" - integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== - chrome-trace-event@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/chrome-trace-event/-/chrome-trace-event-1.0.2.tgz#234090ee97c7d4ad1a2c4beae27505deffc608a4" @@ -1020,16 +883,6 @@ cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: inherits "^2.0.1" safe-buffer "^5.0.1" -class-utils@^0.3.5: - version "0.3.6" - resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463" - integrity sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg== - dependencies: - arr-union "^3.1.0" - define-property "^0.2.5" - isobject "^3.0.0" - static-extend "^0.1.1" - clean-stack@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" @@ -1081,14 +934,6 @@ code-point-at@^1.0.0: resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" integrity sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c= -collection-visit@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz#4bc0373c164bc3291b4d368c829cf1a80a59dca0" - integrity sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA= - dependencies: - map-visit "^1.0.0" - object-visit "^1.0.0" - color-convert@^1.9.0: version "1.9.3" resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" @@ -1140,22 +985,12 @@ common-tags@^1.8.0: resolved "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.0.tgz#8e3153e542d4a39e9b10554434afaaf98956a937" integrity sha512-6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw== -commondir@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" - integrity sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs= - -component-emitter@^1.2.1: - version "1.3.0" - resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz#16e4070fba8ae29b679f2215853ee181ab2eabc0" - integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== - concat-map@0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= -concat-stream@^1.5.0, concat-stream@^1.6.2: +concat-stream@^1.6.2: version "1.6.2" resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz#904bdf194cd3122fc675c77fc4ac3d4ff0fd1a34" integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== @@ -1175,23 +1010,6 @@ constants-browserify@^1.0.0: resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-1.0.0.tgz#c20b96d8c617748aaf1c16021760cd27fcb8cb75" integrity sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U= -copy-concurrently@^1.0.0: - version "1.0.5" - resolved "https://registry.yarnpkg.com/copy-concurrently/-/copy-concurrently-1.0.5.tgz#92297398cae34937fcafd6ec8139c18051f0b5e0" - integrity sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A== - dependencies: - aproba "^1.1.1" - fs-write-stream-atomic "^1.0.8" - iferr "^0.1.5" - mkdirp "^0.5.1" - rimraf "^2.5.4" - run-queue "^1.0.0" - -copy-descriptor@^0.1.0: - version "0.1.1" - resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d" - integrity sha1-Z29us8OZl8LuGsOpJP1hJHSPV40= - core-util-is@1.0.2, core-util-is@~1.0.0: version "1.0.2" resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" @@ -1280,11 +1098,6 @@ csstype@^3.0.2: resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.0.6.tgz#865d0b5833d7d8d40f4e5b8a6d76aea3de4725ef" integrity sha512-+ZAmfyWMT7TiIlzdqJgjMb7S4f1beorDbWbsocyK4RaiqA5RTX3K14bnBWmmA9QEM0gRdsjyyrEmcyga8Zsxmw== -cyclist@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/cyclist/-/cyclist-1.0.1.tgz#596e9698fd0c80e12038c2b82d6eb1b35b6224d9" - integrity sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk= - cypress@^6.0.0: version "6.8.0" resolved "https://registry.yarnpkg.com/cypress/-/cypress-6.8.0.tgz#8338f39212a8f71e91ff8c017a1b6e22d823d8c1" @@ -1355,7 +1168,7 @@ debug@4.3.2: dependencies: ms "2.1.2" -debug@^2.2.0, debug@^2.3.3, debug@^2.6.8, debug@^2.6.9: +debug@^2.6.8, debug@^2.6.9: version "2.6.9" resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== @@ -1381,38 +1194,11 @@ decamelize@^1.2.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA= -decode-uri-component@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" - integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= - dedent@^0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" integrity sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw= -define-property@^0.2.5: - version "0.2.5" - resolved "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz#c35b1ef918ec3c990f9a5bc57be04aacec5c8116" - integrity sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY= - dependencies: - is-descriptor "^0.1.0" - -define-property@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz#769ebaaf3f4a63aad3af9e8d304c9bbe79bfb0e6" - integrity sha1-dp66rz9KY6rTr56NMEybvnm/sOY= - dependencies: - is-descriptor "^1.0.0" - -define-property@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz#d459689e8d654ba77e02a817f8710d702cb16e9d" - integrity sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ== - dependencies: - is-descriptor "^1.0.2" - isobject "^3.0.1" - del@^5.0.0: version "5.1.0" resolved "https://registry.yarnpkg.com/del/-/del-5.1.0.tgz#d9487c94e367410e6eff2925ee58c0c84a75b3a7" @@ -1471,16 +1257,6 @@ domain-browser@^1.1.1: resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.2.0.tgz#3d31f50191a6749dd1375a7f522e823d42e54eda" integrity sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA== -duplexify@^3.4.2, duplexify@^3.6.0: - version "3.7.1" - resolved "https://registry.yarnpkg.com/duplexify/-/duplexify-3.7.1.tgz#2a4df5317f6ccfd91f86d6fd25d8d8a103b88309" - integrity sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g== - dependencies: - end-of-stream "^1.0.0" - inherits "^2.0.1" - readable-stream "^2.0.0" - stream-shift "^1.0.0" - ecc-jsbn@~0.1.1: version "0.1.2" resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9" @@ -1489,6 +1265,11 @@ ecc-jsbn@~0.1.1: jsbn "~0.1.0" safer-buffer "^2.1.0" +electron-to-chromium@^1.4.251: + version "1.4.284" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz#61046d1e4cab3a25238f6bf7413795270f125592" + integrity sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA== + elegant-spinner@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/elegant-spinner/-/elegant-spinner-1.0.1.tgz#db043521c95d7e303fd8f345bedc3349cfb0729e" @@ -1517,14 +1298,14 @@ emojis-list@^3.0.0: resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== -end-of-stream@^1.0.0, end-of-stream@^1.1.0: +end-of-stream@^1.1.0: version "1.4.4" resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== dependencies: once "^1.4.0" -enhanced-resolve@^4.0.0, enhanced-resolve@^4.5.0: +enhanced-resolve@^4.0.0: version "4.5.0" resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-4.5.0.tgz#2f3cfd84dbe3b487f18f2db2ef1e064a571ca5ec" integrity sha512-Nv9m36S/vxpsI+Hc4/ZGRs0n9mXqSWGGq49zxb/cJfPAQMbUtttJAlNPS4AQzaBdw/pKskw5bMbekT/Y7W/Wlg== @@ -1533,6 +1314,14 @@ enhanced-resolve@^4.0.0, enhanced-resolve@^4.5.0: memory-fs "^0.5.0" tapable "^1.0.0" +enhanced-resolve@^5.10.0: + version "5.10.0" + resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.10.0.tgz#0dc579c3bb2a1032e357ac45b8f3a6f3ad4fb1e6" + integrity sha512-T0yTFjdpldGY8PmuXXR0PyQ1ufZpEGiHVrp7zHKB7jdR4qlmZHhONVM5AQOAWXuF/w3dnHbEQVrNptJgt7F+cQ== + dependencies: + graceful-fs "^4.2.4" + tapable "^2.2.0" + enhanced-resolve@~0.9.0: version "0.9.1" resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-0.9.1.tgz#4d6e689b3725f86090927ccc86cd9f1635b89e2e" @@ -1542,7 +1331,7 @@ enhanced-resolve@~0.9.0: memory-fs "^0.2.0" tapable "^0.1.8" -errno@^0.1.3, errno@~0.1.7: +errno@^0.1.3: version "0.1.8" resolved "https://registry.yarnpkg.com/errno/-/errno-0.1.8.tgz#8bb3e9c7d463be4976ff888f76b4809ebc2e811f" integrity sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A== @@ -1556,6 +1345,16 @@ error-ex@^1.3.1: dependencies: is-arrayish "^0.2.1" +es-module-lexer@^0.9.0: + version "0.9.3" + resolved "https://registry.yarnpkg.com/es-module-lexer/-/es-module-lexer-0.9.3.tgz#6f13db00cc38417137daf74366f535c8eb438f19" + integrity sha512-1HQ2M2sPtxwnvOvT1ZClHyQDiggdNjURWpY2we6aMKCQiUVxTmVs2UYPLIrD84sS+kMdUwfBSylbJPwNnBrnHQ== + +escalade@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" + integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== + escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" @@ -1595,12 +1394,12 @@ eslint-plugin-prefer-object-spread@^1.2.1: resolved "https://registry.yarnpkg.com/eslint-plugin-prefer-object-spread/-/eslint-plugin-prefer-object-spread-1.2.1.tgz#27fb91853690cceb3ae6101d9c8aecc6a67a402c" integrity sha1-J/uRhTaQzOs65hAdnIrsxqZ6QCw= -eslint-scope@^4.0.3: - version "4.0.3" - resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-4.0.3.tgz#ca03833310f6889a3264781aa82e63eb9cfe7848" - integrity sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg== +eslint-scope@5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" + integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== dependencies: - esrecurse "^4.1.0" + esrecurse "^4.3.0" estraverse "^4.1.1" eslint-utils@^1.4.2: @@ -1620,7 +1419,7 @@ esprima@^4.0.0: resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== -esrecurse@^4.1.0: +esrecurse@^4.3.0: version "4.3.0" resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== @@ -1647,6 +1446,11 @@ events@^3.0.0: resolved "https://registry.yarnpkg.com/events/-/events-3.2.0.tgz#93b87c18f8efcd4202a461aec4dfc0556b639379" integrity sha512-/46HWwbfCX2xTawVfkKLGxMifJYQBWMwY1mjywRtb4c9x8l5NP3KoJtnIOiL1hfdRkIuYhETxQlo62IF8tcnlg== +events@^3.2.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" + integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== + evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" @@ -1710,53 +1514,11 @@ exit-hook@^1.0.0: resolved "https://registry.yarnpkg.com/exit-hook/-/exit-hook-1.1.1.tgz#f05ca233b48c05d54fff07765df8507e95c02ff8" integrity sha1-8FyiM7SMBdVP/wd2XfhQfpXAL/g= -expand-brackets@^2.1.4: - version "2.1.4" - resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz#b77735e315ce30f6b6eff0f83b04151a22449622" - integrity sha1-t3c14xXOMPa27/D4OwQVGiJEliI= - dependencies: - debug "^2.3.3" - define-property "^0.2.5" - extend-shallow "^2.0.1" - posix-character-classes "^0.1.0" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.1" - -extend-shallow@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" - integrity sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8= - dependencies: - is-extendable "^0.1.0" - -extend-shallow@^3.0.0, extend-shallow@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz#26a71aaf073b39fb2127172746131c2704028db8" - integrity sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg= - dependencies: - assign-symbols "^1.0.0" - is-extendable "^1.0.1" - extend@~3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== -extglob@^2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543" - integrity sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw== - dependencies: - array-unique "^0.3.2" - define-property "^1.0.0" - expand-brackets "^2.1.4" - extend-shallow "^2.0.1" - fragment-cache "^0.2.1" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.1" - extract-zip@^1.7.0: version "1.7.0" resolved "https://registry.yarnpkg.com/extract-zip/-/extract-zip-1.7.0.tgz#556cc3ae9df7f452c493a0cfb51cc30277940927" @@ -1833,21 +1595,6 @@ figures@^2.0.0: dependencies: escape-string-regexp "^1.0.5" -file-uri-to-path@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" - integrity sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw== - -fill-range@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7" - integrity sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc= - dependencies: - extend-shallow "^2.0.1" - is-number "^3.0.0" - repeat-string "^1.6.1" - to-regex-range "^2.1.0" - fill-range@^7.0.1: version "7.0.1" resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" @@ -1855,27 +1602,11 @@ fill-range@^7.0.1: dependencies: to-regex-range "^5.0.1" -find-cache-dir@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-2.1.0.tgz#8d0f94cd13fe43c6c7c261a0d86115ca918c05f7" - integrity sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ== - dependencies: - commondir "^1.0.1" - make-dir "^2.0.0" - pkg-dir "^3.0.0" - find-root@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/find-root/-/find-root-1.1.0.tgz#abcfc8ba76f708c42a97b3d685b7e9450bfb9ce4" integrity sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng== -find-up@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" - integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== - dependencies: - locate-path "^3.0.0" - find-up@^4.0.0, find-up@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" @@ -1884,19 +1615,6 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" -flush-write-stream@^1.0.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/flush-write-stream/-/flush-write-stream-1.1.1.tgz#8dd7d873a1babc207d94ead0c2e0e44276ebf2e8" - integrity sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w== - dependencies: - inherits "^2.0.3" - readable-stream "^2.3.6" - -for-in@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" - integrity sha1-gQaNKVqBQuwKxybG4iAMMPttXoA= - forever-agent@~0.6.1: version "0.6.1" resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" @@ -1911,21 +1629,6 @@ form-data@~2.3.2: combined-stream "^1.0.6" mime-types "^2.1.12" -fragment-cache@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19" - integrity sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk= - dependencies: - map-cache "^0.2.2" - -from2@^2.1.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/from2/-/from2-2.3.0.tgz#8bfb5502bde4a4d36cfdeea007fcca21d7e382af" - integrity sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8= - dependencies: - inherits "^2.0.1" - readable-stream "^2.0.0" - fs-extra@^9.0.1: version "9.1.0" resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" @@ -1936,34 +1639,11 @@ fs-extra@^9.0.1: jsonfile "^6.0.1" universalify "^2.0.0" -fs-write-stream-atomic@^1.0.8: - version "1.0.10" - resolved "https://registry.yarnpkg.com/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz#b47df53493ef911df75731e70a9ded0189db40c9" - integrity sha1-tH31NJPvkR33VzHnCp3tAYnbQMk= - dependencies: - graceful-fs "^4.1.2" - iferr "^0.1.5" - imurmurhash "^0.1.4" - readable-stream "1 || 2" - fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= -fsevents@^1.2.7: - version "1.2.13" - resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.2.13.tgz#f325cb0455592428bcf11b383370ef70e3bfcc38" - integrity sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw== - dependencies: - bindings "^1.5.0" - nan "^2.12.1" - -fsevents@~2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.1.tgz#b209ab14c61012636c8863507edf7fb68cc54e9f" - integrity sha512-YR47Eg4hChJGAB1O3yEAOkGO+rlzutoICGqGo9EZ4lKWokzZRSyIW1QmTzqjtw8MJdj9srP869CuWw/hyzSiBw== - function-bind@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" @@ -1998,11 +1678,6 @@ get-stream@^5.0.0: dependencies: pump "^3.0.0" -get-value@^2.0.3, get-value@^2.0.6: - version "2.0.6" - resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" - integrity sha1-3BXKHGcjh8p2vTesCjlbogQqLCg= - getos@^3.2.1: version "3.2.1" resolved "https://registry.yarnpkg.com/getos/-/getos-3.2.1.tgz#0134d1f4e00eb46144c5a9c0ac4dc087cbb27dc5" @@ -2025,14 +1700,19 @@ glob-all@^3.2.1: glob "^7.1.2" yargs "^15.3.1" -glob-parent@^3.1.0, glob-parent@^5.1.0, glob-parent@^5.1.2, glob-parent@~5.1.0: +glob-parent@^5.1.0, glob-parent@^5.1.2: version "5.1.2" resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== dependencies: is-glob "^4.0.1" -glob@^7.1.2, glob@^7.1.3, glob@^7.1.4: +glob-to-regexp@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz#c75297087c851b9a578bd217dd59a92f59fe546e" + integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw== + +glob@^7.1.2, glob@^7.1.3: version "7.1.6" resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== @@ -2065,11 +1745,16 @@ globby@^10.0.1: merge2 "^1.2.3" slash "^3.0.0" -graceful-fs@^4.1.11, graceful-fs@^4.1.15, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.2: +graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.2: version "4.2.4" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.4.tgz#2256bde14d3632958c465ebc96dc467ca07a29fb" integrity sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw== +graceful-fs@^4.2.4, graceful-fs@^4.2.9: + version "4.2.10" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" + integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== + har-schema@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" @@ -2100,37 +1785,6 @@ has-flag@^4.0.0: resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== -has-value@^0.3.1: - version "0.3.1" - resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f" - integrity sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8= - dependencies: - get-value "^2.0.3" - has-values "^0.1.4" - isobject "^2.0.0" - -has-value@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz#18b281da585b1c5c51def24c930ed29a0be6b177" - integrity sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc= - dependencies: - get-value "^2.0.6" - has-values "^1.0.0" - isobject "^3.0.0" - -has-values@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz#6d61de95d91dfca9b9a02089ad384bff8f62b771" - integrity sha1-bWHeldkd/Km5oCCJrThL/49it3E= - -has-values@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz#95b0b63fec2146619a6fe57fe75628d5a39efe4f" - integrity sha1-lbC2P+whRmGab+V/51Yo1aOe/k8= - dependencies: - is-number "^3.0.0" - kind-of "^4.0.0" - has@^1.0.1, has@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" @@ -2210,11 +1864,6 @@ ieee754@^1.1.4: resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== -iferr@^0.1.5: - version "0.1.5" - resolved "https://registry.yarnpkg.com/iferr/-/iferr-0.1.5.tgz#c60eed69e6d8fdb6b3104a1fcbca1c192dc5b501" - integrity sha1-xg7taebY/bazEEofy8ocGS3FtQE= - ignore@^5.1.1: version "5.1.8" resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.1.8.tgz#f150a8b50a34289b33e22f5889abd4d8016f0e57" @@ -2228,11 +1877,6 @@ import-fresh@^2.0.0: caller-path "^2.0.0" resolve-from "^3.0.0" -imurmurhash@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" - integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= - indent-string@^3.0.0: version "3.2.0" resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-3.2.0.tgz#4a5fd6d27cc332f37e5419a504dbb837105c9289" @@ -2243,11 +1887,6 @@ indent-string@^4.0.0: resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== -infer-owner@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" - integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== - inflight@^1.0.4: version "1.0.6" resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" @@ -2281,39 +1920,11 @@ interpret@^1.0.0: resolved "https://registry.yarnpkg.com/interpret/-/interpret-1.4.0.tgz#665ab8bc4da27a774a40584e812e3e0fa45b1a1e" integrity sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA== -is-accessor-descriptor@^0.1.6: - version "0.1.6" - resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz#a9e12cb3ae8d876727eeef3843f8a0897b5c98d6" - integrity sha1-qeEss66Nh2cn7u84Q/igiXtcmNY= - dependencies: - kind-of "^3.0.2" - -is-accessor-descriptor@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz#169c2f6d3df1f992618072365c9b0ea1f6878656" - integrity sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ== - dependencies: - kind-of "^6.0.0" - is-arrayish@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" integrity sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0= -is-binary-path@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898" - integrity sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg= - dependencies: - binary-extensions "^1.0.0" - -is-binary-path@~2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" - integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== - dependencies: - binary-extensions "^2.0.0" - is-ci@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz#6bc6334181810e04b5c22b3d589fdca55026404c" @@ -2328,55 +1939,11 @@ is-core-module@^2.1.0: dependencies: has "^1.0.3" -is-data-descriptor@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56" - integrity sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y= - dependencies: - kind-of "^3.0.2" - -is-data-descriptor@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz#d84876321d0e7add03990406abbbbd36ba9268c7" - integrity sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ== - dependencies: - kind-of "^6.0.0" - -is-descriptor@^0.1.0: - version "0.1.6" - resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz#366d8240dde487ca51823b1ab9f07a10a78251ca" - integrity sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg== - dependencies: - is-accessor-descriptor "^0.1.6" - is-data-descriptor "^0.1.4" - kind-of "^5.0.0" - -is-descriptor@^1.0.0, is-descriptor@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz#3b159746a66604b04f8c81524ba365c5f14d86ec" - integrity sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg== - dependencies: - is-accessor-descriptor "^1.0.0" - is-data-descriptor "^1.0.0" - kind-of "^6.0.2" - is-directory@^0.3.1: version "0.3.1" resolved "https://registry.yarnpkg.com/is-directory/-/is-directory-0.3.1.tgz#61339b6f2475fc772fd9c9d83f5c8575dc154ae1" integrity sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE= -is-extendable@^0.1.0, is-extendable@^0.1.1: - version "0.1.1" - resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" - integrity sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik= - -is-extendable@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz#a7470f9e426733d81bd81e1155264e3a3507cab4" - integrity sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA== - dependencies: - is-plain-object "^2.0.4" - is-extglob@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" @@ -2399,7 +1966,7 @@ is-fullwidth-code-point@^3.0.0: resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== -is-glob@^4.0.0, is-glob@^4.0.1, is-glob@~4.0.1: +is-glob@^4.0.1: version "4.0.1" resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== @@ -2414,13 +1981,6 @@ is-installed-globally@^0.3.2: global-dirs "^2.0.1" is-path-inside "^3.0.1" -is-number@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" - integrity sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU= - dependencies: - kind-of "^3.0.2" - is-number@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" @@ -2448,13 +2008,6 @@ is-path-inside@^3.0.1: resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.2.tgz#f5220fc82a3e233757291dddc9c5877f2a1f3017" integrity sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg== -is-plain-object@^2.0.3, is-plain-object@^2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" - integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== - dependencies: - isobject "^3.0.1" - is-promise@^2.1.0: version "2.2.2" resolved "https://registry.yarnpkg.com/is-promise/-/is-promise-2.2.2.tgz#39ab959ccbf9a774cf079f7b40c7a26f763135f1" @@ -2485,17 +2038,7 @@ is-unicode-supported@^0.1.0: resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== -is-windows@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz#d1850eb9791ecd18e6182ce12a30f396634bb19d" - integrity sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA== - -is-wsl@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-1.1.0.tgz#1f16e4aa22b04d1336b66188a66af3c600c3a66d" - integrity sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0= - -isarray@1.0.0, isarray@^1.0.0, isarray@~1.0.0: +isarray@^1.0.0, isarray@~1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= @@ -2505,18 +2048,6 @@ isexe@^2.0.0: resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" integrity sha1-6PvzdNxVb/iUehDcsFctYz8s+hA= -isobject@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" - integrity sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk= - dependencies: - isarray "1.0.0" - -isobject@^3.0.0, isobject@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" - integrity sha1-TkMekrEalzFjaqH5yNHMvP2reN8= - isstream@~0.1.2: version "0.1.2" resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" @@ -2537,6 +2068,15 @@ jest-get-type@^24.9.0: resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-24.9.0.tgz#1684a0c8a50f2e4901b6644ae861f579eed2ef0e" integrity sha512-lUseMzAley4LhIcpSP9Jf+fTrQ4a1yHQwLNeeVa2cEmbCGeoZAtYPOIv8JaxLD/sUpKxetKGP+gsHl8f8TSj8Q== +jest-worker@^27.4.5: + version "27.5.1" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.5.1.tgz#8d146f0900e8973b106b6f73cc1e9a8cb86f8db0" + integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg== + dependencies: + "@types/node" "*" + merge-stream "^2.0.0" + supports-color "^8.0.0" + js-tokens@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" @@ -2555,12 +2095,12 @@ jsbn@~0.1.0: resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" integrity sha1-peZUwuWi3rXyAdls77yoDA7y9RM= -json-parse-better-errors@^1.0.1, json-parse-better-errors@^1.0.2: +json-parse-better-errors@^1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz#bb867cfb3450e69107c131d1c514bab3dc8bcaa9" integrity sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw== -json-parse-even-better-errors@^2.3.0: +json-parse-even-better-errors@^2.3.0, json-parse-even-better-errors@^2.3.1: version "2.3.1" resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== @@ -2580,12 +2120,10 @@ json-stringify-safe@~5.0.1: resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" integrity sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus= -json5@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" - integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== - dependencies: - minimist "^1.2.0" +json5@^2.1.2: + version "2.2.1" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.1.tgz#655d50ed1e6f95ad1a3caababd2b0efda10b395c" + integrity sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA== jsonfile@^6.0.1: version "6.1.0" @@ -2606,7 +2144,7 @@ jsprim@^1.2.2: json-schema "0.2.3" verror "1.10.0" -kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0, kind-of@^4.0.0, kind-of@^5.0.0, kind-of@^6.0.0, kind-of@^6.0.2, kind-of@^6.0.3: +kind-of@^6.0.3: version "6.0.3" resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== @@ -2685,27 +2223,19 @@ listr@^0.14.3: p-map "^2.0.0" rxjs "^6.3.3" -loader-runner@^2.4.0: - version "2.4.0" - resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-2.4.0.tgz#ed47066bfe534d7e84c4c7b9998c2a75607d9357" - integrity sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw== +loader-runner@^4.2.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-4.3.0.tgz#c1b4a163b99f614830353b16755e7149ac2314e1" + integrity sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg== -loader-utils@^1.0.2, loader-utils@^1.2.3: - version "1.4.0" - resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-1.4.0.tgz#c579b5e34cb34b1a74edc6c1fb36bfa371d5a613" - integrity sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA== +loader-utils@^1.0.2, loader-utils@^2.0.0, loader-utils@^2.0.3: + version "2.0.4" + resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.4.tgz#8b5cb38b5c34a9a018ee1fc0e6a066d1dfcc528c" + integrity sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw== dependencies: big.js "^5.2.2" emojis-list "^3.0.0" - json5 "^1.0.1" - -locate-path@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" - integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== - dependencies: - p-locate "^3.0.0" - path-exists "^3.0.0" + json5 "^2.1.2" locate-path@^5.0.0: version "5.0.0" @@ -2763,38 +2293,18 @@ lru-cache@^4.1.5: pseudomap "^1.0.2" yallist "^2.1.2" -lru-cache@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" - integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== dependencies: - yallist "^3.0.2" + yallist "^4.0.0" lz-string@^1.4.4: version "1.4.4" resolved "https://registry.yarnpkg.com/lz-string/-/lz-string-1.4.4.tgz#c0d8eaf36059f705796e1e344811cf4c498d3a26" integrity sha1-wNjq82BZ9wV5bh40SBHPTEmNOiY= -make-dir@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" - integrity sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA== - dependencies: - pify "^4.0.1" - semver "^5.6.0" - -map-cache@^0.2.2: - version "0.2.2" - resolved "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz#c32abd0bd6525d9b051645bb4f26ac5dc98a0dbf" - integrity sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8= - -map-visit@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz#ecdca8f13144e660f1b5bd41f12f3479d98dfb8f" - integrity sha1-7Nyo8TFE5mDxtb1B8S80edmN+48= - dependencies: - object-visit "^1.0.0" - md5.js@^1.3.4: version "1.3.5" resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.5.tgz#b5d07b8e3216e3e27cd728d72f70d1e6a342005f" @@ -2809,14 +2319,6 @@ memory-fs@^0.2.0: resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.2.0.tgz#f2bb25368bc121e391c2520de92969caee0a0290" integrity sha1-8rslNovBIeORwlIN6Slpyu4KApA= -memory-fs@^0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.4.1.tgz#3a9a20b8462523e447cfbc7e8bb80ed667bfc552" - integrity sha1-OpoguEYlI+RHz7x+i7gO1me/xVI= - dependencies: - errno "^0.1.3" - readable-stream "^2.0.1" - memory-fs@^0.5.0: version "0.5.0" resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.5.0.tgz#324c01288b88652966d161db77838720845a8e3c" @@ -2835,25 +2337,6 @@ merge2@^1.2.3, merge2@^1.3.0: resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== -micromatch@^3.1.10, micromatch@^3.1.4: - version "3.1.10" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz#70859bc95c9840952f359a068a3fc49f9ecfac23" - integrity sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg== - dependencies: - arr-diff "^4.0.0" - array-unique "^0.3.2" - braces "^2.3.1" - define-property "^2.0.2" - extend-shallow "^3.0.2" - extglob "^2.0.4" - fragment-cache "^0.2.1" - kind-of "^6.0.2" - nanomatch "^1.2.9" - object.pick "^1.3.0" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.2" - micromatch@^4.0.0, micromatch@^4.0.2: version "4.0.2" resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.2.tgz#4fcb0999bf9fbc2fcbdd212f6d629b9a56c39259" @@ -2875,6 +2358,11 @@ mime-db@1.45.0: resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.45.0.tgz#cceeda21ccd7c3a745eba2decd55d4b73e7879ea" integrity sha512-CkqLUxUk15hofLoLyljJSrukZi8mAtgd+yE5uO4tqRZsdsAJKv0O+rFMhVDRJgozy+yG6md5KwuXhD4ocIoP+w== +mime-db@1.52.0: + version "1.52.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + mime-types@^2.1.12, mime-types@~2.1.19: version "2.1.28" resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.28.tgz#1160c4757eab2c5363888e005273ecf79d2a0ecd" @@ -2882,6 +2370,13 @@ mime-types@^2.1.12, mime-types@~2.1.19: dependencies: mime-db "1.45.0" +mime-types@^2.1.27: + version "2.1.35" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + mimic-fn@^1.0.0: version "1.2.0" resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz#820c86a39334640e99516928bd03fca88057d022" @@ -2909,36 +2404,12 @@ minimatch@^3.0.4: dependencies: brace-expansion "^1.1.7" -minimist@^1.2.0, minimist@^1.2.5, minimist@^1.2.6: +minimist@^1.2.5, minimist@^1.2.6: version "1.2.6" resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== -mississippi@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/mississippi/-/mississippi-3.0.0.tgz#ea0a3291f97e0b5e8776b363d5f0a12d94c67022" - integrity sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA== - dependencies: - concat-stream "^1.5.0" - duplexify "^3.4.2" - end-of-stream "^1.1.0" - flush-write-stream "^1.0.0" - from2 "^2.1.0" - parallel-transform "^1.1.0" - pump "^3.0.0" - pumpify "^1.3.3" - stream-each "^1.1.0" - through2 "^2.0.0" - -mixin-deep@^1.2.0: - version "1.3.2" - resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" - integrity sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA== - dependencies: - for-in "^1.0.2" - is-extendable "^1.0.1" - -mkdirp@^0.5.1, mkdirp@^0.5.3, mkdirp@^0.5.4: +mkdirp@^0.5.4: version "0.5.5" resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz#d91cefd62d1436ca0f41620e251288d420099def" integrity sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ== @@ -2950,18 +2421,6 @@ moment@^2.29.1, moment@^2.29.4: resolved "https://registry.yarnpkg.com/moment/-/moment-2.29.4.tgz#3dbe052889fe7c1b2ed966fcb3a77328964ef108" integrity sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w== -move-concurrently@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/move-concurrently/-/move-concurrently-1.0.1.tgz#be2c005fda32e0b29af1f05d7c4b33214c701f92" - integrity sha1-viwAX9oy4LKa8fBdfEszIUxwH5I= - dependencies: - aproba "^1.1.1" - copy-concurrently "^1.0.0" - fs-write-stream-atomic "^1.0.8" - mkdirp "^0.5.1" - rimraf "^2.5.4" - run-queue "^1.0.3" - ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" @@ -2977,29 +2436,7 @@ ms@^2.1.1: resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== -nan@^2.12.1: - version "2.14.2" - resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.2.tgz#f5376400695168f4cc694ac9393d0c9585eeea19" - integrity sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ== - -nanomatch@^1.2.9: - version "1.2.13" - resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" - integrity sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA== - dependencies: - arr-diff "^4.0.0" - array-unique "^0.3.2" - define-property "^2.0.2" - extend-shallow "^3.0.2" - fragment-cache "^0.2.1" - is-windows "^1.0.2" - kind-of "^6.0.2" - object.pick "^1.3.0" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.1" - -neo-async@^2.5.0, neo-async@^2.6.1: +neo-async@^2.6.2: version "2.6.2" resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== @@ -3009,7 +2446,7 @@ nice-try@^1.0.4: resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== -"node-libs-browser@^1.0.0 || ^2.0.0", node-libs-browser@^2.2.1: +"node-libs-browser@^1.0.0 || ^2.0.0": version "2.2.1" resolved "https://registry.yarnpkg.com/node-libs-browser/-/node-libs-browser-2.2.1.tgz#b64f513d18338625f90346d27b0d235e631f6425" integrity sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q== @@ -3038,6 +2475,11 @@ nice-try@^1.0.4: util "^0.11.0" vm-browserify "^1.0.1" +node-releases@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.6.tgz#8a7088c63a55e493845683ebf3c828d8c51c5503" + integrity sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg== + normalize-package-data@^2.5.0: version "2.5.0" resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" @@ -3048,14 +2490,7 @@ normalize-package-data@^2.5.0: semver "2 || 3 || 4 || 5" validate-npm-package-license "^3.0.1" -normalize-path@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.1.1.tgz#1ab28b556e198363a8c1a6f7e6fa20137fe6aed9" - integrity sha1-GrKLVW4Zg2Oowab35vogE3/mrtk= - dependencies: - remove-trailing-separator "^1.0.1" - -normalize-path@^3.0.0, normalize-path@~3.0.0: +normalize-path@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== @@ -3096,29 +2531,6 @@ object-assign@^4.1.0, object-assign@^4.1.1: resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= -object-copy@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c" - integrity sha1-fn2Fi3gb18mRpBupde04EnVOmYw= - dependencies: - copy-descriptor "^0.1.0" - define-property "^0.2.5" - kind-of "^3.0.3" - -object-visit@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz#f79c4493af0c5377b59fe39d395e41042dd045bb" - integrity sha1-95xEk68MU3e1n+OdOV5BBC3QRbs= - dependencies: - isobject "^3.0.0" - -object.pick@^1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747" - integrity sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c= - dependencies: - isobject "^3.0.1" - once@^1.3.0, once@^1.3.1, once@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" @@ -3170,20 +2582,13 @@ p-finally@^2.0.0: resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-2.0.1.tgz#bd6fcaa9c559a096b680806f4d657b3f0f240561" integrity sha512-vpm09aKwq6H9phqRQzecoDpD8TmVyGw70qmWlyq5onxY7tqyTTFVvxMykxQSQKILBSFlbXpypIw2T1Ml7+DDtw== -p-limit@^2.0.0, p-limit@^2.2.0: +p-limit@^2.2.0: version "2.3.0" resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== dependencies: p-try "^2.0.0" -p-locate@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" - integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== - dependencies: - p-limit "^2.0.0" - p-locate@^4.1.0: version "4.1.0" resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" @@ -3213,15 +2618,6 @@ pako@~1.0.5: resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== -parallel-transform@^1.1.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/parallel-transform/-/parallel-transform-1.2.0.tgz#9049ca37d6cb2182c3b1d2c720be94d14a5814fc" - integrity sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg== - dependencies: - cyclist "^1.0.1" - inherits "^2.0.3" - readable-stream "^2.1.5" - parse-asn1@^5.0.0, parse-asn1@^5.1.5: version "5.1.6" resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.6.tgz#385080a3ec13cb62a62d39409cb3e88844cdaed4" @@ -3251,21 +2647,11 @@ parse-json@^5.0.0: json-parse-even-better-errors "^2.3.0" lines-and-columns "^1.1.6" -pascalcase@^0.1.1: - version "0.1.1" - resolved "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz#b363e55e8006ca6fe21784d2db22bd15d7917f14" - integrity sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ= - path-browserify@0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-0.0.1.tgz#e6c4ddd7ed3aa27c68a20cc4e50e1a4ee83bbc4a" integrity sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ== -path-exists@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" - integrity sha1-zg6+ql94yxiSXqfYENe1mwEP1RU= - path-exists@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" @@ -3317,7 +2703,12 @@ performance-now@^2.1.0: resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" integrity sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns= -picomatch@^2.0.4, picomatch@^2.0.5, picomatch@^2.2.1: +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.0.5, picomatch@^2.2.1: version "2.2.2" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== @@ -3327,18 +2718,6 @@ pify@^2.2.0: resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" integrity sha1-7RQaasBDqEnqWISY59yosVMw6Qw= -pify@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/pify/-/pify-4.0.1.tgz#4b2cd25c50d598735c50292224fd8c6df41e3231" - integrity sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g== - -pkg-dir@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-3.0.0.tgz#2749020f239ed990881b1f71210d51eb6523bea3" - integrity sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw== - dependencies: - find-up "^3.0.0" - pkg-dir@^4.2.0: version "4.2.0" resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" @@ -3353,11 +2732,6 @@ please-upgrade-node@^3.1.1, please-upgrade-node@^3.2.0: dependencies: semver-compare "^1.0.0" -posix-character-classes@^0.1.0: - version "0.1.1" - resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" - integrity sha1-AerA/jta9xoqbAL+q7jB/vfgDqs= - pretty-bytes@^5.4.1: version "5.6.0" resolved "https://registry.yarnpkg.com/pretty-bytes/-/pretty-bytes-5.6.0.tgz#356256f643804773c82f64723fe78c92c62beaeb" @@ -3392,11 +2766,6 @@ process@^0.11.10: resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" integrity sha1-czIwDoQBYb2j5podHZGn1LwW8YI= -promise-inflight@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" - integrity sha1-mEcocL8igTL8vdhoEputEsPAKeM= - prr@~1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/prr/-/prr-1.0.1.tgz#d3fc114ba06995a45ec6893f484ceb1d78f5f476" @@ -3424,14 +2793,6 @@ public-encrypt@^4.0.0: randombytes "^2.0.1" safe-buffer "^5.1.2" -pump@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/pump/-/pump-2.0.1.tgz#12399add6e4cf7526d973cbc8b5ce2e2908b3909" - integrity sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA== - dependencies: - end-of-stream "^1.1.0" - once "^1.3.1" - pump@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" @@ -3440,15 +2801,6 @@ pump@^3.0.0: end-of-stream "^1.1.0" once "^1.3.1" -pumpify@^1.3.3: - version "1.5.1" - resolved "https://registry.yarnpkg.com/pumpify/-/pumpify-1.5.1.tgz#36513be246ab27570b1a374a5ce278bfd74370ce" - integrity sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ== - dependencies: - duplexify "^3.6.0" - inherits "^2.0.3" - pump "^2.0.0" - punycode@1.3.2: version "1.3.2" resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d" @@ -3519,7 +2871,7 @@ read-pkg@^5.2.0: parse-json "^5.0.0" type-fest "^0.6.0" -"readable-stream@1 || 2", readable-stream@^2.0.0, readable-stream@^2.0.1, readable-stream@^2.0.2, readable-stream@^2.1.5, readable-stream@^2.2.2, readable-stream@^2.3.3, readable-stream@^2.3.6, readable-stream@~2.3.6: +readable-stream@^2.0.1, readable-stream@^2.0.2, readable-stream@^2.2.2, readable-stream@^2.3.3, readable-stream@^2.3.6: version "2.3.7" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== @@ -3541,50 +2893,11 @@ readable-stream@^3.6.0: string_decoder "^1.1.1" util-deprecate "^1.0.1" -readdirp@^2.2.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-2.2.1.tgz#0e87622a3325aa33e892285caf8b4e846529a525" - integrity sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ== - dependencies: - graceful-fs "^4.1.11" - micromatch "^3.1.10" - readable-stream "^2.0.2" - -readdirp@~3.5.0: - version "3.5.0" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.5.0.tgz#9ba74c019b15d365278d2e91bb8c48d7b4d42c9e" - integrity sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ== - dependencies: - picomatch "^2.2.1" - regenerator-runtime@^0.13.4: version "0.13.7" resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.7.tgz#cac2dacc8a1ea675feaabaeb8ae833898ae46f55" integrity sha512-a54FxoJDIr27pgf7IgeQGxmqUNYrcV338lf/6gH456HZ/PhX+5BcwHXG9ajESmwe6WRO0tAzRUrRmNONWgkrew== -regex-not@^1.0.0, regex-not@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c" - integrity sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A== - dependencies: - extend-shallow "^3.0.2" - safe-regex "^1.1.0" - -remove-trailing-separator@^1.0.1: - version "1.1.0" - resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" - integrity sha1-wkvOKig62tW8P1jg1IJJuSN52O8= - -repeat-element@^1.1.2: - version "1.1.3" - resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.3.tgz#782e0d825c0c5a3bb39731f84efee6b742e6b1ce" - integrity sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g== - -repeat-string@^1.6.1: - version "1.6.1" - resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" - integrity sha1-jcrkcOHIirwtYA//Sndihtp15jc= - request-progress@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/request-progress/-/request-progress-3.0.0.tgz#4ca754081c7fec63f505e4faa825aa06cd669dbe" @@ -3607,11 +2920,6 @@ resolve-from@^3.0.0: resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz#b22c7af7d9d6881bc8b6e653335eebcb0a188748" integrity sha1-six699nWiBvItuZTM17rywoYh0g= -resolve-url@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a" - integrity sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo= - resolve@^1.10.0, resolve@^1.5.0, resolve@^1.7.1: version "1.19.0" resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.19.0.tgz#1af5bf630409734a067cae29318aac7fa29a267c" @@ -3636,23 +2944,11 @@ restore-cursor@^2.0.0: onetime "^2.0.0" signal-exit "^3.0.2" -ret@~0.1.10: - version "0.1.15" - resolved "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz#b8a4825d5bdb1fc3f6f53c2bc33f81388681c7bc" - integrity sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg== - reusify@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== -rimraf@^2.5.4, rimraf@^2.6.3: - version "2.7.1" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" - integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== - dependencies: - glob "^7.1.3" - rimraf@^3.0.0: version "3.0.2" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" @@ -3678,13 +2974,6 @@ run-parallel@^1.1.9: resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.1.10.tgz#60a51b2ae836636c81377df16cb107351bcd13ef" integrity sha512-zb/1OuZ6flOlH6tQyMPUrE3x3Ulxjlo9WIVXR4yVYi4H9UXQaeIsPbLn2R3O3vQCnDKkAl2qHiuocKKX4Tz/Sw== -run-queue@^1.0.0, run-queue@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/run-queue/-/run-queue-1.0.3.tgz#e848396f057d223f24386924618e25694161ec47" - integrity sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec= - dependencies: - aproba "^1.1.1" - rxjs@^6.3.3: version "6.6.3" resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-6.6.3.tgz#8ca84635c4daa900c0d3967a6ee7ac60271ee552" @@ -3702,33 +2991,26 @@ safe-buffer@~5.1.0, safe-buffer@~5.1.1: resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== -safe-regex@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e" - integrity sha1-QKNmnzsHfR6UPURinhV91IAjvy4= - dependencies: - ret "~0.1.10" - safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: version "2.1.2" resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== -schema-utils@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-1.0.0.tgz#0b79a93204d7b600d4b2850d1f66c2a34951c770" - integrity sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g== +schema-utils@^3.1.0, schema-utils@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.1.1.tgz#bc74c4b6b6995c1d88f76a8b77bea7219e0c8281" + integrity sha512-Y5PQxS4ITlC+EahLuXaY86TXfR7Dc5lw294alXOq86JAHCihAIZfqv8nNCWvaEJvaC51uN9hbLGeV0cFBdH+Fw== dependencies: - ajv "^6.1.0" - ajv-errors "^1.0.0" - ajv-keywords "^3.1.0" + "@types/json-schema" "^7.0.8" + ajv "^6.12.5" + ajv-keywords "^3.5.2" semver-compare@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/semver-compare/-/semver-compare-1.0.0.tgz#0dee216a1c941ab37e9efb1788f6afc5ff5537fc" integrity sha1-De4hahyUGrN+nvsXiPavxf9VN/w= -"semver@2 || 3 || 4 || 5", semver@^5.3.0, semver@^5.5.0, semver@^5.6.0: +"semver@2 || 3 || 4 || 5", semver@^5.3.0, semver@^5.5.0: version "5.7.1" resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== @@ -3738,10 +3020,17 @@ semver@^6.0.0: resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== -serialize-javascript@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-4.0.0.tgz#b525e1238489a5ecfc42afacc3fe99e666f4b1aa" - integrity sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw== +semver@^7.3.4: + version "7.3.8" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.8.tgz#07a78feafb3f7b32347d725e33de7e2a2df67798" + integrity sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A== + dependencies: + lru-cache "^6.0.0" + +serialize-javascript@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.0.tgz#efae5d88f45d7924141da8b5c3a7a7e663fefeb8" + integrity sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag== dependencies: randombytes "^2.1.0" @@ -3750,16 +3039,6 @@ set-blocking@^2.0.0: resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc= -set-value@^2.0.0, set-value@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b" - integrity sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw== - dependencies: - extend-shallow "^2.0.1" - is-extendable "^0.1.1" - is-plain-object "^2.0.3" - split-string "^3.0.1" - setimmediate@^1.0.4: version "1.0.5" resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" @@ -3812,52 +3091,6 @@ slice-ansi@0.0.4: resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-0.0.4.tgz#edbf8903f66f7ce2f8eafd6ceed65e264c831b35" integrity sha1-7b+JA/ZvfOL46v1s7tZeJkyDGzU= -snapdragon-node@^2.0.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b" - integrity sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw== - dependencies: - define-property "^1.0.0" - isobject "^3.0.0" - snapdragon-util "^3.0.1" - -snapdragon-util@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz#f956479486f2acd79700693f6f7b805e45ab56e2" - integrity sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ== - dependencies: - kind-of "^3.2.0" - -snapdragon@^0.8.1: - version "0.8.2" - resolved "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz#64922e7c565b0e14204ba1aa7d6964278d25182d" - integrity sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg== - dependencies: - base "^0.11.1" - debug "^2.2.0" - define-property "^0.2.5" - extend-shallow "^2.0.1" - map-cache "^0.2.2" - source-map "^0.5.6" - source-map-resolve "^0.5.0" - use "^3.1.0" - -source-list-map@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/source-list-map/-/source-list-map-2.0.1.tgz#3993bd873bfc48479cca9ea3a547835c7c154b34" - integrity sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw== - -source-map-resolve@^0.5.0: - version "0.5.3" - resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a" - integrity sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw== - dependencies: - atob "^2.1.2" - decode-uri-component "^0.2.0" - resolve-url "^0.2.1" - source-map-url "^0.4.0" - urix "^0.1.0" - source-map-support@~0.5.12: version "0.5.19" resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.19.tgz#a98b62f86dcaf4f67399648c085291ab9e8fed61" @@ -3866,17 +3099,7 @@ source-map-support@~0.5.12: buffer-from "^1.0.0" source-map "^0.6.0" -source-map-url@^0.4.0: - version "0.4.1" - resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.1.tgz#0af66605a745a5a2f91cf1bbf8a7afbc283dec56" - integrity sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw== - -source-map@^0.5.6: - version "0.5.7" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" - integrity sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w= - -source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: +source-map@^0.6.0, source-map@~0.6.1: version "0.6.1" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== @@ -3907,13 +3130,6 @@ spdx-license-ids@^3.0.0: resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.7.tgz#e9c18a410e5ed7e12442a549fbd8afa767038d65" integrity sha512-U+MTEOO0AiDzxwFvoa4JVnMV6mZlJKk2sBLt90s7G0Gd0Mlknc7kxEn3nuDPNZRta7O2uy8oLcZLVT+4sqNZHQ== -split-string@^3.0.1, split-string@^3.0.2: - version "3.1.0" - resolved "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz#7cb09dda3a86585705c64b39a6466038682e8fe2" - integrity sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw== - dependencies: - extend-shallow "^3.0.0" - sprintf-js@~1.0.2: version "1.0.3" resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" @@ -3934,21 +3150,13 @@ sshpk@^1.7.0: safer-buffer "^2.0.2" tweetnacl "~0.14.0" -ssri@^6.0.1, ssri@^6.0.2: +ssri@^6.0.2: version "6.0.2" resolved "https://registry.yarnpkg.com/ssri/-/ssri-6.0.2.tgz#157939134f20464e7301ddba3e90ffa8f7728ac5" integrity sha512-cepbSq/neFK7xB6A50KHN0xHDotYzq58wWCa5LeWqnPrHG8GzfEjO/4O8kpmcGW+oaxkvhEJCWgbgNk4/ZV93Q== dependencies: figgy-pudding "^3.5.1" -static-extend@^0.1.1: - version "0.1.2" - resolved "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz#60809c39cbff55337226fd5e0b520f341f1fb5c6" - integrity sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY= - dependencies: - define-property "^0.2.5" - object-copy "^0.1.0" - stream-browserify@^2.0.1: version "2.0.2" resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-2.0.2.tgz#87521d38a44aa7ee91ce1cd2a47df0cb49dd660b" @@ -3957,14 +3165,6 @@ stream-browserify@^2.0.1: inherits "~2.0.1" readable-stream "^2.0.2" -stream-each@^1.1.0: - version "1.2.3" - resolved "https://registry.yarnpkg.com/stream-each/-/stream-each-1.2.3.tgz#ebe27a0c389b04fbcc233642952e10731afa9bae" - integrity sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw== - dependencies: - end-of-stream "^1.1.0" - stream-shift "^1.0.0" - stream-http@^2.7.2: version "2.8.3" resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-2.8.3.tgz#b2d242469288a5a27ec4fe8933acf623de6514fc" @@ -3976,11 +3176,6 @@ stream-http@^2.7.2: to-arraybuffer "^1.0.0" xtend "^4.0.0" -stream-shift@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/stream-shift/-/stream-shift-1.0.1.tgz#d7088281559ab2778424279b0877da3c392d5a3d" - integrity sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ== - string-argv@^0.3.0: version "0.3.1" resolved "https://registry.yarnpkg.com/string-argv/-/string-argv-0.3.1.tgz#95e2fbec0427ae19184935f816d74aaa4c5c19da" @@ -4085,6 +3280,13 @@ supports-color@^7.1.0, supports-color@^7.2.0: dependencies: has-flag "^4.0.0" +supports-color@^8.0.0: + version "8.1.1" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" + integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== + dependencies: + has-flag "^4.0.0" + symbol-observable@^1.1.0: version "1.2.0" resolved "https://registry.yarnpkg.com/symbol-observable/-/symbol-observable-1.2.0.tgz#c22688aed4eab3cdc2dfeacbb561660560a00804" @@ -4095,27 +3297,28 @@ tapable@^0.1.8: resolved "https://registry.yarnpkg.com/tapable/-/tapable-0.1.10.tgz#29c35707c2b70e50d07482b5d202e8ed446dafd4" integrity sha1-KcNXB8K3DlDQdIK10gLo7URtr9Q= -tapable@^1.0.0, tapable@^1.1.3: +tapable@^1.0.0: version "1.1.3" resolved "https://registry.yarnpkg.com/tapable/-/tapable-1.1.3.tgz#a1fccc06b58db61fd7a45da2da44f5f3a3e67ba2" integrity sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA== -terser-webpack-plugin@^1.4.3: - version "1.4.5" - resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-1.4.5.tgz#a217aefaea330e734ffacb6120ec1fa312d6040b" - integrity sha512-04Rfe496lN8EYruwi6oPQkG0vo8C+HT49X687FZnpPF0qMAIHONI6HEXYPKDOE8e5HjXTyKfqRd/agHtH0kOtw== - dependencies: - cacache "^12.0.2" - find-cache-dir "^2.1.0" - is-wsl "^1.1.0" - schema-utils "^1.0.0" - serialize-javascript "^4.0.0" - source-map "^0.6.1" - terser "^4.1.2" - webpack-sources "^1.4.0" - worker-farm "^1.7.0" - -terser@^4.1.2, terser@^4.8.1: +tapable@^2.1.1, tapable@^2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.2.1.tgz#1967a73ef4060a82f12ab96af86d52fdb76eeca0" + integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== + +terser-webpack-plugin@^5.1.3: + version "5.3.6" + resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.6.tgz#5590aec31aa3c6f771ce1b1acca60639eab3195c" + integrity sha512-kfLFk+PoLUQIbLmB1+PZDMRSZS99Mp+/MHqDNmMA6tOItzRt+Npe3E+fsMs5mfcM0wCtrrdU387UnV+vnSffXQ== + dependencies: + "@jridgewell/trace-mapping" "^0.3.14" + jest-worker "^27.4.5" + schema-utils "^3.1.1" + serialize-javascript "^6.0.0" + terser "^5.14.1" + +terser@^4.8.1, terser@^5.14.1: version "4.8.1" resolved "https://registry.yarnpkg.com/terser/-/terser-4.8.1.tgz#a00e5634562de2239fd404c649051bf6fc21144f" integrity sha512-4GnLC0x667eJG0ewJTa6z/yXrbLGv80D9Ru6HIpCQmO+Q4PfEtBFi0ObSckqwL6VyQv/7ENJieXHo2ANmdQwgw== @@ -4129,14 +3332,6 @@ throttleit@^1.0.0: resolved "https://registry.yarnpkg.com/throttleit/-/throttleit-1.0.0.tgz#9e785836daf46743145a5984b6268d828528ac6c" integrity sha1-nnhYNtr0Z0MUWlmEtiaNgoUorGw= -through2@^2.0.0: - version "2.0.5" - resolved "https://registry.yarnpkg.com/through2/-/through2-2.0.5.tgz#01c1e39eb31d07cb7d03a96a70823260b23132cd" - integrity sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ== - dependencies: - readable-stream "~2.3.6" - xtend "~4.0.1" - timers-browserify@^2.0.4: version "2.0.12" resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-2.0.12.tgz#44a45c11fbf407f34f97bccd1577c652361b00ee" @@ -4156,21 +3351,6 @@ to-arraybuffer@^1.0.0: resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43" integrity sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M= -to-object-path@^0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz#297588b7b0e7e0ac08e04e672f85c1f4999e17af" - integrity sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68= - dependencies: - kind-of "^3.0.2" - -to-regex-range@^2.1.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz#7c80c17b9dfebe599e27367e0d4dd5590141db38" - integrity sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg= - dependencies: - is-number "^3.0.0" - repeat-string "^1.6.1" - to-regex-range@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" @@ -4178,16 +3358,6 @@ to-regex-range@^5.0.1: dependencies: is-number "^7.0.0" -to-regex@^3.0.1, to-regex@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz#13cfdd9b336552f30b51f33a8ae1b42a7a7599ce" - integrity sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw== - dependencies: - define-property "^2.0.2" - extend-shallow "^3.0.2" - regex-not "^1.0.2" - safe-regex "^1.1.0" - tough-cookie@~2.5.0: version "2.5.0" resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2" @@ -4207,6 +3377,17 @@ ts-loader@^6.2.1: micromatch "^4.0.0" semver "^6.0.0" +ts-loader@^8.4.0: + version "8.4.0" + resolved "https://registry.yarnpkg.com/ts-loader/-/ts-loader-8.4.0.tgz#e845ea0f38d140bdc3d7d60293ca18d12ff2720f" + integrity sha512-6nFY3IZ2//mrPc+ImY3hNWx1vCHyEhl6V+wLmL4CZcm6g1CqX7UKrkc6y0i4FwcfOhxyMPCfaEvh20f4r9GNpw== + dependencies: + chalk "^4.1.0" + enhanced-resolve "^4.0.0" + loader-utils "^2.0.0" + micromatch "^4.0.0" + semver "^7.3.4" + tslib@^1.9.0: version "1.14.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" @@ -4239,52 +3420,23 @@ typedarray@^0.0.6: resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c= -union-value@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz#0b6fe7b835aecda61c6ea4d4f02c14221e109847" - integrity sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg== - dependencies: - arr-union "^3.1.0" - get-value "^2.0.6" - is-extendable "^0.1.1" - set-value "^2.0.1" - -unique-filename@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-1.1.1.tgz#1d69769369ada0583103a1e6ae87681b56573230" - integrity sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ== - dependencies: - unique-slug "^2.0.0" - -unique-slug@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-2.0.2.tgz#baabce91083fc64e945b0f3ad613e264f7cd4e6c" - integrity sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w== - dependencies: - imurmurhash "^0.1.4" - universalify@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== -unset-value@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559" - integrity sha1-g3aHP30jNRef+x5vw6jtDfyKtVk= - dependencies: - has-value "^0.3.1" - isobject "^3.0.0" - untildify@^4.0.0: version "4.0.0" resolved "https://registry.yarnpkg.com/untildify/-/untildify-4.0.0.tgz#2bc947b953652487e4600949fb091e3ae8cd919b" integrity sha512-KK8xQ1mkzZeg9inewmFVDNkg3l5LUhoq9kN6iWYB/CC9YMG8HA+c1Q8HwDe6dEX7kErrEVNVBO3fWsVq5iDgtw== -upath@^1.1.1: - version "1.2.0" - resolved "https://registry.yarnpkg.com/upath/-/upath-1.2.0.tgz#8f66dbcd55a883acdae4408af8b035a5044c1894" - integrity sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg== +update-browserslist-db@^1.0.9: + version "1.0.10" + resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz#0f54b876545726f17d00cd9a2561e6dade943ff3" + integrity sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ== + dependencies: + escalade "^3.1.1" + picocolors "^1.0.0" uri-js@^4.2.2: version "4.4.1" @@ -4293,11 +3445,6 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" -urix@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72" - integrity sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI= - url@^0.11.0: version "0.11.0" resolved "https://registry.yarnpkg.com/url/-/url-0.11.0.tgz#3838e97cfc60521eb73c525a8e55bfdd9e2e28f1" @@ -4306,11 +3453,6 @@ url@^0.11.0: punycode "1.3.2" querystring "0.2.0" -use@^3.1.0: - version "3.1.1" - resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f" - integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ== - util-deprecate@^1.0.1, util-deprecate@~1.0.1: version "1.0.2" resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" @@ -4357,60 +3499,48 @@ vm-browserify@^1.0.1: resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-1.1.2.tgz#78641c488b8e6ca91a75f511e7a3b32a86e5dda0" integrity sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ== -watchpack-chokidar2@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz#38500072ee6ece66f3769936950ea1771be1c957" - integrity sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww== - dependencies: - chokidar "^2.1.8" - -watchpack@^1.7.4: - version "1.7.5" - resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-1.7.5.tgz#1267e6c55e0b9b5be44c2023aed5437a2c26c453" - integrity sha512-9P3MWk6SrKjHsGkLT2KHXdQ/9SNkyoJbabxnKOoJepsvJjJG8uYTR3yTPxPQvNDI3w4Nz1xnE0TLHK4RIVe/MQ== +watchpack@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-2.4.0.tgz#fa33032374962c78113f93c7f2fb4c54c9862a5d" + integrity sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg== dependencies: + glob-to-regexp "^0.4.1" graceful-fs "^4.1.2" - neo-async "^2.5.0" - optionalDependencies: - chokidar "^3.4.1" - watchpack-chokidar2 "^2.0.1" - -webpack-sources@^1.4.0, webpack-sources@^1.4.1: - version "1.4.3" - resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-1.4.3.tgz#eedd8ec0b928fbf1cbfe994e22d2d890f330a933" - integrity sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ== - dependencies: - source-list-map "^2.0.0" - source-map "~0.6.1" -webpack@^4.41.5: - version "4.46.0" - resolved "https://registry.yarnpkg.com/webpack/-/webpack-4.46.0.tgz#bf9b4404ea20a073605e0a011d188d77cb6ad542" - integrity sha512-6jJuJjg8znb/xRItk7bkT0+Q7AHCYjjFnvKIWQPkNIOyRqoCGvkOs0ipeQzrqz4l5FtN5ZI/ukEHroeX/o1/5Q== - dependencies: - "@webassemblyjs/ast" "1.9.0" - "@webassemblyjs/helper-module-context" "1.9.0" - "@webassemblyjs/wasm-edit" "1.9.0" - "@webassemblyjs/wasm-parser" "1.9.0" - acorn "^6.4.1" - ajv "^6.10.2" - ajv-keywords "^3.4.1" +webpack-sources@^3.2.3: + version "3.2.3" + resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-3.2.3.tgz#2d4daab8451fd4b240cc27055ff6a0c2ccea0cde" + integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w== + +webpack@^4.41.5, webpack@^5.75.0: + version "5.75.0" + resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.75.0.tgz#1e440468647b2505860e94c9ff3e44d5b582c152" + integrity sha512-piaIaoVJlqMsPtX/+3KTTO6jfvrSYgauFVdt8cr9LTHKmcq/AMd4mhzsiP7ZF/PGRNPGA8336jldh9l2Kt2ogQ== + dependencies: + "@types/eslint-scope" "^3.7.3" + "@types/estree" "^0.0.51" + "@webassemblyjs/ast" "1.11.1" + "@webassemblyjs/wasm-edit" "1.11.1" + "@webassemblyjs/wasm-parser" "1.11.1" + acorn "^8.7.1" + acorn-import-assertions "^1.7.6" + browserslist "^4.14.5" chrome-trace-event "^1.0.2" - enhanced-resolve "^4.5.0" - eslint-scope "^4.0.3" - json-parse-better-errors "^1.0.2" - loader-runner "^2.4.0" - loader-utils "^1.2.3" - memory-fs "^0.4.1" - micromatch "^3.1.10" - mkdirp "^0.5.3" - neo-async "^2.6.1" - node-libs-browser "^2.2.1" - schema-utils "^1.0.0" - tapable "^1.1.3" - terser-webpack-plugin "^1.4.3" - watchpack "^1.7.4" - webpack-sources "^1.4.1" + enhanced-resolve "^5.10.0" + es-module-lexer "^0.9.0" + eslint-scope "5.1.1" + events "^3.2.0" + glob-to-regexp "^0.4.1" + graceful-fs "^4.2.9" + json-parse-even-better-errors "^2.3.1" + loader-runner "^4.2.0" + mime-types "^2.1.27" + neo-async "^2.6.2" + schema-utils "^3.1.0" + tapable "^2.1.1" + terser-webpack-plugin "^5.1.3" + watchpack "^2.4.0" + webpack-sources "^3.2.3" which-module@^2.0.0: version "2.0.0" @@ -4431,13 +3561,6 @@ which@^2.0.1: dependencies: isexe "^2.0.0" -worker-farm@^1.7.0: - version "1.7.0" - resolved "https://registry.yarnpkg.com/worker-farm/-/worker-farm-1.7.0.tgz#26a94c5391bbca926152002f69b84a4bf772e5a8" - integrity sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw== - dependencies: - errno "~0.1.7" - wrap-ansi@^3.0.1: version "3.0.1" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-3.0.1.tgz#288a04d87eda5c286e060dfe8f135ce8d007f8ba" @@ -4460,7 +3583,7 @@ wrappy@1: resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= -xtend@^4.0.0, xtend@~4.0.1: +xtend@^4.0.0: version "4.0.2" resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== @@ -4475,10 +3598,10 @@ yallist@^2.1.2: resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52" integrity sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI= -yallist@^3.0.2: - version "3.1.1" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" - integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== yargs-parser@^18.1.2: version "18.1.3" From 9e87186ea70061e0c6a0823313829711309f7c9f Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 17 Nov 2022 13:22:09 -0800 Subject: [PATCH 38/39] Update loader-utils to 1.4.1 Signed-off-by: Chris Hesterman --- package.json | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/package.json b/package.json index d4801f1e8..4e22f3c03 100644 --- a/package.json +++ b/package.json @@ -39,16 +39,14 @@ "glob-parent": "^5.1.2", "ssri": "^6.0.2", "lodash": "^4.17.21", - "loader-utils": "^2.0.3", + "loader-utils": "^1.4.1", "hosted-git-info": "^2.8.9", "json-schema": "^0.4.0", "ansi-regex": "^5.0.1", "minimist": "^1.2.6", "moment": "^2.29.4", "async": "^3.2.3", - "terser": "^4.8.1", - "ts-loader": "^8.4.0", - "webpack": "^5.75.0" + "terser": "^4.8.1" }, "devDependencies": { "@elastic/elastic-eslint-config-kibana": "link:../../packages/opensearch-eslint-config-opensearch-dashboards", From 7cc680f0244ebea39b7097eecc5e53133cfdcd06 Mon Sep 17 00:00:00 2001 From: Chris Hesterman Date: Thu, 17 Nov 2022 13:28:06 -0800 Subject: [PATCH 39/39] Roll back to 2.4.0 OSD Signed-off-by: Chris Hesterman --- .github/workflows/cypress-workflow.yml | 2 +- .github/workflows/unit-tests-workflow.yml | 2 +- opensearch_dashboards.json | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/cypress-workflow.yml b/.github/workflows/cypress-workflow.yml index a3d76e996..451c68824 100644 --- a/.github/workflows/cypress-workflow.yml +++ b/.github/workflows/cypress-workflow.yml @@ -7,7 +7,7 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.4.1' + OPENSEARCH_DASHBOARDS_VERSION: '2.4.0' OPENSEARCH_VERSION: '2.4.0-SNAPSHOT' jobs: tests: diff --git a/.github/workflows/unit-tests-workflow.yml b/.github/workflows/unit-tests-workflow.yml index 42da15cf4..51e3338d6 100644 --- a/.github/workflows/unit-tests-workflow.yml +++ b/.github/workflows/unit-tests-workflow.yml @@ -7,7 +7,7 @@ on: branches: - "*" env: - OPENSEARCH_DASHBOARDS_VERSION: '2.4.1' + OPENSEARCH_DASHBOARDS_VERSION: '2.4.0' jobs: tests: name: Run unit tests diff --git a/opensearch_dashboards.json b/opensearch_dashboards.json index d48fa6e0e..c17b4fcdb 100644 --- a/opensearch_dashboards.json +++ b/opensearch_dashboards.json @@ -1,7 +1,7 @@ { "id": "indexManagementDashboards", "version": "2.4.0.0", - "opensearchDashboardsVersion": "2.4.1", + "opensearchDashboardsVersion": "2.4.0", "configPath": ["opensearch_index_management"], "requiredPlugins": ["navigation"], "server": true,