@webiny/api-headless-cms-tasks 6.0.0-beta.0 → 6.0.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +10 -14
- package/constants.d.ts +1 -0
- package/constants.js +3 -0
- package/constants.js.map +1 -0
- package/features/DeleteModelTask/DeleteModel.d.ts +16 -0
- package/features/DeleteModelTask/DeleteModel.js +131 -0
- package/features/DeleteModelTask/DeleteModel.js.map +1 -0
- package/features/DeleteModelTask/DeleteModelTask.d.ts +24 -0
- package/features/DeleteModelTask/DeleteModelTask.js +39 -0
- package/features/DeleteModelTask/DeleteModelTask.js.map +1 -0
- package/features/DeleteModelTask/feature.d.ts +1 -0
- package/features/DeleteModelTask/feature.js +10 -0
- package/features/DeleteModelTask/feature.js.map +1 -0
- package/features/DeleteModelTask/types.d.ts +32 -0
- package/features/DeleteModelTask/types.js +9 -0
- package/features/DeleteModelTask/types.js.map +1 -0
- package/features/DisableModel/BlockActionIfModelDisabled.d.ts +8 -0
- package/features/DisableModel/BlockActionIfModelDisabled.js +15 -0
- package/features/DisableModel/BlockActionIfModelDisabled.js.map +1 -0
- package/features/DisableModel/abstractions.d.ts +8 -0
- package/features/DisableModel/abstractions.js +4 -0
- package/features/DisableModel/abstractions.js.map +1 -0
- package/features/DisableModel/feature.d.ts +5 -0
- package/features/DisableModel/feature.js +36 -0
- package/features/DisableModel/feature.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeCreate.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeCreate.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeCreate.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeMove.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeMove.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeMove.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforePublish.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforePublish.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforePublish.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeRepublish.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeRepublish.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeRepublish.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeRestoreFromBin.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeRestoreFromBin.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeRestoreFromBin.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeUnpublish.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeUnpublish.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeUnpublish.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeUpdate.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeUpdate.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryBeforeUpdate.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryRevisionBeforeCreate.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryRevisionBeforeCreate.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnEntryRevisionBeforeCreate.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnModelBeforeCreateFrom.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnModelBeforeCreateFrom.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnModelBeforeCreateFrom.js.map +1 -0
- package/features/DisableModel/handlers/BlockModelActionOnModelBeforeUpdate.d.ts +11 -0
- package/features/DisableModel/handlers/BlockModelActionOnModelBeforeUpdate.js +16 -0
- package/features/DisableModel/handlers/BlockModelActionOnModelBeforeUpdate.js.map +1 -0
- package/features/DisableModel/index.d.ts +1 -0
- package/features/DisableModel/index.js +3 -0
- package/features/DisableModel/index.js.map +1 -0
- package/graphql/deleteModel/cancelDeleteModel.d.ts +7 -0
- package/graphql/deleteModel/cancelDeleteModel.js +58 -0
- package/graphql/deleteModel/cancelDeleteModel.js.map +1 -0
- package/graphql/deleteModel/crud.d.ts +3 -0
- package/graphql/deleteModel/crud.js +72 -0
- package/graphql/deleteModel/crud.js.map +1 -0
- package/graphql/deleteModel/fullyDeleteModel.d.ts +7 -0
- package/graphql/deleteModel/fullyDeleteModel.js +56 -0
- package/graphql/deleteModel/fullyDeleteModel.js.map +1 -0
- package/graphql/deleteModel/getDeleteModelProgress.d.ts +7 -0
- package/graphql/deleteModel/getDeleteModelProgress.js +59 -0
- package/graphql/deleteModel/getDeleteModelProgress.js.map +1 -0
- package/graphql/deleteModel/index.d.ts +3 -0
- package/graphql/deleteModel/index.js +163 -0
- package/graphql/deleteModel/index.js.map +1 -0
- package/graphql/deleteModel/status.d.ts +3 -0
- package/graphql/deleteModel/status.js +17 -0
- package/graphql/deleteModel/status.js.map +1 -0
- package/helpers/confirmation.d.ts +6 -0
- package/helpers/confirmation.js +15 -0
- package/helpers/confirmation.js.map +1 -0
- package/helpers/store.d.ts +9 -0
- package/helpers/store.js +16 -0
- package/helpers/store.js.map +1 -0
- package/index.d.ts +2 -2
- package/index.js +13 -24
- package/index.js.map +1 -1
- package/package.json +24 -29
- package/types.d.ts +13 -43
- package/types.js +1 -21
- package/types.js.map +1 -1
- package/graphql.d.ts +0 -3
- package/graphql.js +0 -53
- package/graphql.js.map +0 -1
- package/handlers/eventBridgeEventHandler.d.ts +0 -1
- package/handlers/eventBridgeEventHandler.js +0 -50
- package/handlers/eventBridgeEventHandler.js.map +0 -1
- package/handlers/index.d.ts +0 -1
- package/handlers/index.js +0 -14
- package/handlers/index.js.map +0 -1
- package/handlers/setupEventsTenant.d.ts +0 -1
- package/handlers/setupEventsTenant.js +0 -19
- package/handlers/setupEventsTenant.js.map +0 -1
- package/tasks/IUseCase.d.ts +0 -3
- package/tasks/IUseCase.js +0 -7
- package/tasks/IUseCase.js.map +0 -1
- package/tasks/common/index.d.ts +0 -1
- package/tasks/common/index.js +0 -18
- package/tasks/common/index.js.map +0 -1
- package/tasks/common/useCases/ChildTasksCleanup/ChildTasksCleanup.d.ts +0 -13
- package/tasks/common/useCases/ChildTasksCleanup/ChildTasksCleanup.js +0 -63
- package/tasks/common/useCases/ChildTasksCleanup/ChildTasksCleanup.js.map +0 -1
- package/tasks/common/useCases/ChildTasksCleanup/index.d.ts +0 -1
- package/tasks/common/useCases/ChildTasksCleanup/index.js +0 -18
- package/tasks/common/useCases/ChildTasksCleanup/index.js.map +0 -1
- package/tasks/common/useCases/index.d.ts +0 -1
- package/tasks/common/useCases/index.js +0 -18
- package/tasks/common/useCases/index.js.map +0 -1
- package/tasks/entries/deleteTrashBinEntriesTask.d.ts +0 -2
- package/tasks/entries/deleteTrashBinEntriesTask.js +0 -55
- package/tasks/entries/deleteTrashBinEntriesTask.js.map +0 -1
- package/tasks/entries/emptyTrashBinByModelTask.d.ts +0 -2
- package/tasks/entries/emptyTrashBinByModelTask.js +0 -55
- package/tasks/entries/emptyTrashBinByModelTask.js.map +0 -1
- package/tasks/entries/emptyTrashBinsTask.d.ts +0 -2
- package/tasks/entries/emptyTrashBinsTask.js +0 -55
- package/tasks/entries/emptyTrashBinsTask.js.map +0 -1
- package/tasks/entries/index.d.ts +0 -2
- package/tasks/entries/index.js +0 -30
- package/tasks/entries/index.js.map +0 -1
- package/tasks/entries/useCases/DeleteTrashBinEntries/DeleteTrashBinEntries.d.ts +0 -6
- package/tasks/entries/useCases/DeleteTrashBinEntries/DeleteTrashBinEntries.js +0 -68
- package/tasks/entries/useCases/DeleteTrashBinEntries/DeleteTrashBinEntries.js.map +0 -1
- package/tasks/entries/useCases/DeleteTrashBinEntries/TaskRepository.d.ts +0 -9
- package/tasks/entries/useCases/DeleteTrashBinEntries/TaskRepository.js +0 -29
- package/tasks/entries/useCases/DeleteTrashBinEntries/TaskRepository.js.map +0 -1
- package/tasks/entries/useCases/DeleteTrashBinEntries/TaskRepositoryFactory.d.ts +0 -7
- package/tasks/entries/useCases/DeleteTrashBinEntries/TaskRepositoryFactory.js +0 -24
- package/tasks/entries/useCases/DeleteTrashBinEntries/TaskRepositoryFactory.js.map +0 -1
- package/tasks/entries/useCases/DeleteTrashBinEntries/index.d.ts +0 -1
- package/tasks/entries/useCases/DeleteTrashBinEntries/index.js +0 -18
- package/tasks/entries/useCases/DeleteTrashBinEntries/index.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/CreateDeleteEntriesTasks.d.ts +0 -7
- package/tasks/entries/useCases/EmptyTrashBinByModel/CreateDeleteEntriesTasks.js +0 -97
- package/tasks/entries/useCases/EmptyTrashBinByModel/CreateDeleteEntriesTasks.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/EmptyTrashBinByModel.d.ts +0 -6
- package/tasks/entries/useCases/EmptyTrashBinByModel/EmptyTrashBinByModel.js +0 -29
- package/tasks/entries/useCases/EmptyTrashBinByModel/EmptyTrashBinByModel.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/ProcessDeleteEntriesTasks.d.ts +0 -6
- package/tasks/entries/useCases/EmptyTrashBinByModel/ProcessDeleteEntriesTasks.js +0 -51
- package/tasks/entries/useCases/EmptyTrashBinByModel/ProcessDeleteEntriesTasks.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/TaskCache.d.ts +0 -11
- package/tasks/entries/useCases/EmptyTrashBinByModel/TaskCache.js +0 -24
- package/tasks/entries/useCases/EmptyTrashBinByModel/TaskCache.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/TaskTrigger.d.ts +0 -8
- package/tasks/entries/useCases/EmptyTrashBinByModel/TaskTrigger.js +0 -39
- package/tasks/entries/useCases/EmptyTrashBinByModel/TaskTrigger.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/index.d.ts +0 -1
- package/tasks/entries/useCases/EmptyTrashBinByModel/index.js +0 -18
- package/tasks/entries/useCases/EmptyTrashBinByModel/index.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBins/EmptyTrashBins.d.ts +0 -7
- package/tasks/entries/useCases/EmptyTrashBins/EmptyTrashBins.js +0 -60
- package/tasks/entries/useCases/EmptyTrashBins/EmptyTrashBins.js.map +0 -1
- package/tasks/entries/useCases/EmptyTrashBins/index.d.ts +0 -1
- package/tasks/entries/useCases/EmptyTrashBins/index.js +0 -18
- package/tasks/entries/useCases/EmptyTrashBins/index.js.map +0 -1
- package/tasks/entries/useCases/index.d.ts +0 -3
- package/tasks/entries/useCases/index.js +0 -40
- package/tasks/entries/useCases/index.js.map +0 -1
- package/tasks/index.d.ts +0 -1
- package/tasks/index.js +0 -13
- package/tasks/index.js.map +0 -1
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EntryBeforeRestoreFromBinEventHandler } from "@webiny/api-headless-cms/features/contentEntry/RestoreEntryFromBin/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
declare class BlockModelActionOnEntryBeforeRestoreFromBinImpl implements EntryBeforeRestoreFromBinEventHandler.Interface {
|
|
4
|
+
private blockAction;
|
|
5
|
+
constructor(blockAction: BlockActionIfModelDisabled.Interface);
|
|
6
|
+
handle(event: EntryBeforeRestoreFromBinEventHandler.Event): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const BlockModelActionOnEntryBeforeRestoreFromBin: typeof BlockModelActionOnEntryBeforeRestoreFromBinImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<import("@webiny/api-core/features/EventPublisher").IEventHandler<import("@webiny/api-headless-cms/features/contentEntry/RestoreEntryFromBin/events.js").EntryBeforeRestoreFromBinEvent>>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EntryBeforeRestoreFromBinEventHandler } from "@webiny/api-headless-cms/features/contentEntry/RestoreEntryFromBin/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
class BlockModelActionOnEntryBeforeRestoreFromBinImpl {
|
|
4
|
+
constructor(blockAction) {
|
|
5
|
+
this.blockAction = blockAction;
|
|
6
|
+
}
|
|
7
|
+
async handle(event) {
|
|
8
|
+
await this.blockAction.execute(event.payload.model);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export const BlockModelActionOnEntryBeforeRestoreFromBin = EntryBeforeRestoreFromBinEventHandler.createImplementation({
|
|
12
|
+
implementation: BlockModelActionOnEntryBeforeRestoreFromBinImpl,
|
|
13
|
+
dependencies: [BlockActionIfModelDisabled]
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=BlockModelActionOnEntryBeforeRestoreFromBin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["EntryBeforeRestoreFromBinEventHandler","BlockActionIfModelDisabled","BlockModelActionOnEntryBeforeRestoreFromBinImpl","constructor","blockAction","handle","event","execute","payload","model","BlockModelActionOnEntryBeforeRestoreFromBin","createImplementation","implementation","dependencies"],"sources":["BlockModelActionOnEntryBeforeRestoreFromBin.ts"],"sourcesContent":["import { EntryBeforeRestoreFromBinEventHandler } from \"@webiny/api-headless-cms/features/contentEntry/RestoreEntryFromBin/events.js\";\nimport { BlockActionIfModelDisabled } from \"../abstractions.js\";\n\nclass BlockModelActionOnEntryBeforeRestoreFromBinImpl\n implements EntryBeforeRestoreFromBinEventHandler.Interface\n{\n constructor(private blockAction: BlockActionIfModelDisabled.Interface) {}\n\n async handle(event: EntryBeforeRestoreFromBinEventHandler.Event): Promise<void> {\n await this.blockAction.execute(event.payload.model);\n }\n}\n\nexport const BlockModelActionOnEntryBeforeRestoreFromBin =\n EntryBeforeRestoreFromBinEventHandler.createImplementation({\n implementation: BlockModelActionOnEntryBeforeRestoreFromBinImpl,\n dependencies: [BlockActionIfModelDisabled]\n });\n"],"mappings":"AAAA,SAASA,qCAAqC,QAAQ,8EAA8E;AACpI,SAASC,0BAA0B;AAEnC,MAAMC,+CAA+C,CAErD;EACIC,WAAWA,CAASC,WAAiD,EAAE;IAAA,KAAnDA,WAAiD,GAAjDA,WAAiD;EAAG;EAExE,MAAMC,MAAMA,CAACC,KAAkD,EAAiB;IAC5E,MAAM,IAAI,CAACF,WAAW,CAACG,OAAO,CAACD,KAAK,CAACE,OAAO,CAACC,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMC,2CAA2C,GACpDV,qCAAqC,CAACW,oBAAoB,CAAC;EACvDC,cAAc,EAAEV,+CAA+C;EAC/DW,YAAY,EAAE,CAACZ,0BAA0B;AAC7C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EntryBeforeUnpublishEventHandler } from "@webiny/api-headless-cms/features/contentEntry/UnpublishEntry/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
declare class BlockModelActionOnEntryBeforeUnpublishImpl implements EntryBeforeUnpublishEventHandler.Interface {
|
|
4
|
+
private blockAction;
|
|
5
|
+
constructor(blockAction: BlockActionIfModelDisabled.Interface);
|
|
6
|
+
handle(event: EntryBeforeUnpublishEventHandler.Event): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const BlockModelActionOnEntryBeforeUnpublish: typeof BlockModelActionOnEntryBeforeUnpublishImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<import("@webiny/api-core/features/EventPublisher").IEventHandler<import("@webiny/api-headless-cms/features/contentEntry/UnpublishEntry/events.js").EntryBeforeUnpublishEvent>>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EntryBeforeUnpublishEventHandler } from "@webiny/api-headless-cms/features/contentEntry/UnpublishEntry/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
class BlockModelActionOnEntryBeforeUnpublishImpl {
|
|
4
|
+
constructor(blockAction) {
|
|
5
|
+
this.blockAction = blockAction;
|
|
6
|
+
}
|
|
7
|
+
async handle(event) {
|
|
8
|
+
await this.blockAction.execute(event.payload.model);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export const BlockModelActionOnEntryBeforeUnpublish = EntryBeforeUnpublishEventHandler.createImplementation({
|
|
12
|
+
implementation: BlockModelActionOnEntryBeforeUnpublishImpl,
|
|
13
|
+
dependencies: [BlockActionIfModelDisabled]
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=BlockModelActionOnEntryBeforeUnpublish.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["EntryBeforeUnpublishEventHandler","BlockActionIfModelDisabled","BlockModelActionOnEntryBeforeUnpublishImpl","constructor","blockAction","handle","event","execute","payload","model","BlockModelActionOnEntryBeforeUnpublish","createImplementation","implementation","dependencies"],"sources":["BlockModelActionOnEntryBeforeUnpublish.ts"],"sourcesContent":["import { EntryBeforeUnpublishEventHandler } from \"@webiny/api-headless-cms/features/contentEntry/UnpublishEntry/events.js\";\nimport { BlockActionIfModelDisabled } from \"../abstractions.js\";\n\nclass BlockModelActionOnEntryBeforeUnpublishImpl\n implements EntryBeforeUnpublishEventHandler.Interface\n{\n constructor(private blockAction: BlockActionIfModelDisabled.Interface) {}\n\n async handle(event: EntryBeforeUnpublishEventHandler.Event): Promise<void> {\n await this.blockAction.execute(event.payload.model);\n }\n}\n\nexport const BlockModelActionOnEntryBeforeUnpublish =\n EntryBeforeUnpublishEventHandler.createImplementation({\n implementation: BlockModelActionOnEntryBeforeUnpublishImpl,\n dependencies: [BlockActionIfModelDisabled]\n });\n"],"mappings":"AAAA,SAASA,gCAAgC,QAAQ,yEAAyE;AAC1H,SAASC,0BAA0B;AAEnC,MAAMC,0CAA0C,CAEhD;EACIC,WAAWA,CAASC,WAAiD,EAAE;IAAA,KAAnDA,WAAiD,GAAjDA,WAAiD;EAAG;EAExE,MAAMC,MAAMA,CAACC,KAA6C,EAAiB;IACvE,MAAM,IAAI,CAACF,WAAW,CAACG,OAAO,CAACD,KAAK,CAACE,OAAO,CAACC,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMC,sCAAsC,GAC/CV,gCAAgC,CAACW,oBAAoB,CAAC;EAClDC,cAAc,EAAEV,0CAA0C;EAC1DW,YAAY,EAAE,CAACZ,0BAA0B;AAC7C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EntryBeforeUpdateEventHandler } from "@webiny/api-headless-cms/features/contentEntry/UpdateEntry/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
declare class BlockModelActionOnEntryBeforeUpdateImpl implements EntryBeforeUpdateEventHandler.Interface {
|
|
4
|
+
private blockAction;
|
|
5
|
+
constructor(blockAction: BlockActionIfModelDisabled.Interface);
|
|
6
|
+
handle(event: EntryBeforeUpdateEventHandler.Event): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const BlockModelActionOnEntryBeforeUpdate: typeof BlockModelActionOnEntryBeforeUpdateImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<import("@webiny/api-core/features/EventPublisher").IEventHandler<import("@webiny/api-headless-cms/features/contentEntry/UpdateEntry/events.js").EntryBeforeUpdateEvent>>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EntryBeforeUpdateEventHandler } from "@webiny/api-headless-cms/features/contentEntry/UpdateEntry/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
class BlockModelActionOnEntryBeforeUpdateImpl {
|
|
4
|
+
constructor(blockAction) {
|
|
5
|
+
this.blockAction = blockAction;
|
|
6
|
+
}
|
|
7
|
+
async handle(event) {
|
|
8
|
+
await this.blockAction.execute(event.payload.model);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export const BlockModelActionOnEntryBeforeUpdate = EntryBeforeUpdateEventHandler.createImplementation({
|
|
12
|
+
implementation: BlockModelActionOnEntryBeforeUpdateImpl,
|
|
13
|
+
dependencies: [BlockActionIfModelDisabled]
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=BlockModelActionOnEntryBeforeUpdate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["EntryBeforeUpdateEventHandler","BlockActionIfModelDisabled","BlockModelActionOnEntryBeforeUpdateImpl","constructor","blockAction","handle","event","execute","payload","model","BlockModelActionOnEntryBeforeUpdate","createImplementation","implementation","dependencies"],"sources":["BlockModelActionOnEntryBeforeUpdate.ts"],"sourcesContent":["import { EntryBeforeUpdateEventHandler } from \"@webiny/api-headless-cms/features/contentEntry/UpdateEntry/events.js\";\nimport { BlockActionIfModelDisabled } from \"../abstractions.js\";\n\nclass BlockModelActionOnEntryBeforeUpdateImpl implements EntryBeforeUpdateEventHandler.Interface {\n constructor(private blockAction: BlockActionIfModelDisabled.Interface) {}\n\n async handle(event: EntryBeforeUpdateEventHandler.Event): Promise<void> {\n await this.blockAction.execute(event.payload.model);\n }\n}\n\nexport const BlockModelActionOnEntryBeforeUpdate =\n EntryBeforeUpdateEventHandler.createImplementation({\n implementation: BlockModelActionOnEntryBeforeUpdateImpl,\n dependencies: [BlockActionIfModelDisabled]\n });\n"],"mappings":"AAAA,SAASA,6BAA6B,QAAQ,sEAAsE;AACpH,SAASC,0BAA0B;AAEnC,MAAMC,uCAAuC,CAAoD;EAC7FC,WAAWA,CAASC,WAAiD,EAAE;IAAA,KAAnDA,WAAiD,GAAjDA,WAAiD;EAAG;EAExE,MAAMC,MAAMA,CAACC,KAA0C,EAAiB;IACpE,MAAM,IAAI,CAACF,WAAW,CAACG,OAAO,CAACD,KAAK,CAACE,OAAO,CAACC,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMC,mCAAmC,GAC5CV,6BAA6B,CAACW,oBAAoB,CAAC;EAC/CC,cAAc,EAAEV,uCAAuC;EACvDW,YAAY,EAAE,CAACZ,0BAA0B;AAC7C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EntryRevisionBeforeCreateEventHandler } from "@webiny/api-headless-cms/features/contentEntry/CreateEntryRevisionFrom/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
declare class BlockModelActionOnEntryRevisionBeforeCreateImpl implements EntryRevisionBeforeCreateEventHandler.Interface {
|
|
4
|
+
private blockAction;
|
|
5
|
+
constructor(blockAction: BlockActionIfModelDisabled.Interface);
|
|
6
|
+
handle(event: EntryRevisionBeforeCreateEventHandler.Event): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const BlockModelActionOnEntryRevisionBeforeCreate: typeof BlockModelActionOnEntryRevisionBeforeCreateImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<import("@webiny/api-core/features/EventPublisher").IEventHandler<import("@webiny/api-headless-cms/features/contentEntry/CreateEntryRevisionFrom/events.js").EntryRevisionBeforeCreateEvent>>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EntryRevisionBeforeCreateEventHandler } from "@webiny/api-headless-cms/features/contentEntry/CreateEntryRevisionFrom/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
class BlockModelActionOnEntryRevisionBeforeCreateImpl {
|
|
4
|
+
constructor(blockAction) {
|
|
5
|
+
this.blockAction = blockAction;
|
|
6
|
+
}
|
|
7
|
+
async handle(event) {
|
|
8
|
+
await this.blockAction.execute(event.payload.model);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export const BlockModelActionOnEntryRevisionBeforeCreate = EntryRevisionBeforeCreateEventHandler.createImplementation({
|
|
12
|
+
implementation: BlockModelActionOnEntryRevisionBeforeCreateImpl,
|
|
13
|
+
dependencies: [BlockActionIfModelDisabled]
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=BlockModelActionOnEntryRevisionBeforeCreate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["EntryRevisionBeforeCreateEventHandler","BlockActionIfModelDisabled","BlockModelActionOnEntryRevisionBeforeCreateImpl","constructor","blockAction","handle","event","execute","payload","model","BlockModelActionOnEntryRevisionBeforeCreate","createImplementation","implementation","dependencies"],"sources":["BlockModelActionOnEntryRevisionBeforeCreate.ts"],"sourcesContent":["import { EntryRevisionBeforeCreateEventHandler } from \"@webiny/api-headless-cms/features/contentEntry/CreateEntryRevisionFrom/events.js\";\nimport { BlockActionIfModelDisabled } from \"../abstractions.js\";\n\nclass BlockModelActionOnEntryRevisionBeforeCreateImpl\n implements EntryRevisionBeforeCreateEventHandler.Interface\n{\n constructor(private blockAction: BlockActionIfModelDisabled.Interface) {}\n\n async handle(event: EntryRevisionBeforeCreateEventHandler.Event): Promise<void> {\n await this.blockAction.execute(event.payload.model);\n }\n}\n\nexport const BlockModelActionOnEntryRevisionBeforeCreate =\n EntryRevisionBeforeCreateEventHandler.createImplementation({\n implementation: BlockModelActionOnEntryRevisionBeforeCreateImpl,\n dependencies: [BlockActionIfModelDisabled]\n });\n"],"mappings":"AAAA,SAASA,qCAAqC,QAAQ,kFAAkF;AACxI,SAASC,0BAA0B;AAEnC,MAAMC,+CAA+C,CAErD;EACIC,WAAWA,CAASC,WAAiD,EAAE;IAAA,KAAnDA,WAAiD,GAAjDA,WAAiD;EAAG;EAExE,MAAMC,MAAMA,CAACC,KAAkD,EAAiB;IAC5E,MAAM,IAAI,CAACF,WAAW,CAACG,OAAO,CAACD,KAAK,CAACE,OAAO,CAACC,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMC,2CAA2C,GACpDV,qCAAqC,CAACW,oBAAoB,CAAC;EACvDC,cAAc,EAAEV,+CAA+C;EAC/DW,YAAY,EAAE,CAACZ,0BAA0B;AAC7C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ModelBeforeCreateFromEventHandler } from "@webiny/api-headless-cms/features/contentModel/CreateModelFrom/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
declare class BlockModelActionOnModelBeforeCreateFromImpl implements ModelBeforeCreateFromEventHandler.Interface {
|
|
4
|
+
private blockAction;
|
|
5
|
+
constructor(blockAction: BlockActionIfModelDisabled.Interface);
|
|
6
|
+
handle(event: ModelBeforeCreateFromEventHandler.Event): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const BlockModelActionOnModelBeforeCreateFrom: typeof BlockModelActionOnModelBeforeCreateFromImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<import("@webiny/api-core/features/EventPublisher").IEventHandler<import("@webiny/api-headless-cms/features/contentModel/CreateModelFrom/events.js").ModelBeforeCreateFromEvent>>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ModelBeforeCreateFromEventHandler } from "@webiny/api-headless-cms/features/contentModel/CreateModelFrom/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
class BlockModelActionOnModelBeforeCreateFromImpl {
|
|
4
|
+
constructor(blockAction) {
|
|
5
|
+
this.blockAction = blockAction;
|
|
6
|
+
}
|
|
7
|
+
async handle(event) {
|
|
8
|
+
await this.blockAction.execute(event.payload.model);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export const BlockModelActionOnModelBeforeCreateFrom = ModelBeforeCreateFromEventHandler.createImplementation({
|
|
12
|
+
implementation: BlockModelActionOnModelBeforeCreateFromImpl,
|
|
13
|
+
dependencies: [BlockActionIfModelDisabled]
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=BlockModelActionOnModelBeforeCreateFrom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["ModelBeforeCreateFromEventHandler","BlockActionIfModelDisabled","BlockModelActionOnModelBeforeCreateFromImpl","constructor","blockAction","handle","event","execute","payload","model","BlockModelActionOnModelBeforeCreateFrom","createImplementation","implementation","dependencies"],"sources":["BlockModelActionOnModelBeforeCreateFrom.ts"],"sourcesContent":["import { ModelBeforeCreateFromEventHandler } from \"@webiny/api-headless-cms/features/contentModel/CreateModelFrom/events.js\";\nimport { BlockActionIfModelDisabled } from \"../abstractions.js\";\n\nclass BlockModelActionOnModelBeforeCreateFromImpl\n implements ModelBeforeCreateFromEventHandler.Interface\n{\n constructor(private blockAction: BlockActionIfModelDisabled.Interface) {}\n\n async handle(event: ModelBeforeCreateFromEventHandler.Event): Promise<void> {\n await this.blockAction.execute(event.payload.model);\n }\n}\n\nexport const BlockModelActionOnModelBeforeCreateFrom =\n ModelBeforeCreateFromEventHandler.createImplementation({\n implementation: BlockModelActionOnModelBeforeCreateFromImpl,\n dependencies: [BlockActionIfModelDisabled]\n });\n"],"mappings":"AAAA,SAASA,iCAAiC,QAAQ,0EAA0E;AAC5H,SAASC,0BAA0B;AAEnC,MAAMC,2CAA2C,CAEjD;EACIC,WAAWA,CAASC,WAAiD,EAAE;IAAA,KAAnDA,WAAiD,GAAjDA,WAAiD;EAAG;EAExE,MAAMC,MAAMA,CAACC,KAA8C,EAAiB;IACxE,MAAM,IAAI,CAACF,WAAW,CAACG,OAAO,CAACD,KAAK,CAACE,OAAO,CAACC,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMC,uCAAuC,GAChDV,iCAAiC,CAACW,oBAAoB,CAAC;EACnDC,cAAc,EAAEV,2CAA2C;EAC3DW,YAAY,EAAE,CAACZ,0BAA0B;AAC7C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ModelBeforeUpdateEventHandler } from "@webiny/api-headless-cms/features/contentModel/UpdateModel/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
declare class BlockModelActionOnModelBeforeUpdateImpl implements ModelBeforeUpdateEventHandler.Interface {
|
|
4
|
+
private blockAction;
|
|
5
|
+
constructor(blockAction: BlockActionIfModelDisabled.Interface);
|
|
6
|
+
handle(event: ModelBeforeUpdateEventHandler.Event): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const BlockModelActionOnModelBeforeUpdate: typeof BlockModelActionOnModelBeforeUpdateImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<import("@webiny/api-core/features/EventPublisher").IEventHandler<import("@webiny/api-headless-cms/features/contentModel/UpdateModel/events.js").ModelBeforeUpdateEvent>>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ModelBeforeUpdateEventHandler } from "@webiny/api-headless-cms/features/contentModel/UpdateModel/events.js";
|
|
2
|
+
import { BlockActionIfModelDisabled } from "../abstractions.js";
|
|
3
|
+
class BlockModelActionOnModelBeforeUpdateImpl {
|
|
4
|
+
constructor(blockAction) {
|
|
5
|
+
this.blockAction = blockAction;
|
|
6
|
+
}
|
|
7
|
+
async handle(event) {
|
|
8
|
+
await this.blockAction.execute(event.payload.model);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export const BlockModelActionOnModelBeforeUpdate = ModelBeforeUpdateEventHandler.createImplementation({
|
|
12
|
+
implementation: BlockModelActionOnModelBeforeUpdateImpl,
|
|
13
|
+
dependencies: [BlockActionIfModelDisabled]
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=BlockModelActionOnModelBeforeUpdate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["ModelBeforeUpdateEventHandler","BlockActionIfModelDisabled","BlockModelActionOnModelBeforeUpdateImpl","constructor","blockAction","handle","event","execute","payload","model","BlockModelActionOnModelBeforeUpdate","createImplementation","implementation","dependencies"],"sources":["BlockModelActionOnModelBeforeUpdate.ts"],"sourcesContent":["import { ModelBeforeUpdateEventHandler } from \"@webiny/api-headless-cms/features/contentModel/UpdateModel/events.js\";\nimport { BlockActionIfModelDisabled } from \"../abstractions.js\";\n\nclass BlockModelActionOnModelBeforeUpdateImpl implements ModelBeforeUpdateEventHandler.Interface {\n constructor(private blockAction: BlockActionIfModelDisabled.Interface) {}\n\n async handle(event: ModelBeforeUpdateEventHandler.Event): Promise<void> {\n await this.blockAction.execute(event.payload.model);\n }\n}\n\nexport const BlockModelActionOnModelBeforeUpdate =\n ModelBeforeUpdateEventHandler.createImplementation({\n implementation: BlockModelActionOnModelBeforeUpdateImpl,\n dependencies: [BlockActionIfModelDisabled]\n });\n"],"mappings":"AAAA,SAASA,6BAA6B,QAAQ,sEAAsE;AACpH,SAASC,0BAA0B;AAEnC,MAAMC,uCAAuC,CAAoD;EAC7FC,WAAWA,CAASC,WAAiD,EAAE;IAAA,KAAnDA,WAAiD,GAAjDA,WAAiD;EAAG;EAExE,MAAMC,MAAMA,CAACC,KAA0C,EAAiB;IACpE,MAAM,IAAI,CAACF,WAAW,CAACG,OAAO,CAACD,KAAK,CAACE,OAAO,CAACC,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMC,mCAAmC,GAC5CV,6BAA6B,CAACW,oBAAoB,CAAC;EAC/CC,cAAc,EAAEV,uCAAuC;EACvDW,YAAY,EAAE,CAACZ,0BAA0B;AAC7C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { DisableModelFeature } from "./feature.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DisableModelFeature"],"sources":["index.ts"],"sourcesContent":["export { DisableModelFeature } from \"./feature.js\";\n"],"mappings":"AAAA,SAASA,mBAAmB","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { HcmsTasksContext } from "../../types.js";
|
|
2
|
+
import type { IDeleteCmsModelTask } from "../../features/DeleteModelTask/types.js";
|
|
3
|
+
export interface ICancelDeleteModelParams {
|
|
4
|
+
readonly context: Pick<HcmsTasksContext, "cms" | "tasks" | "db">;
|
|
5
|
+
readonly modelId: string;
|
|
6
|
+
}
|
|
7
|
+
export declare const cancelDeleteModel: (params: ICancelDeleteModelParams) => Promise<IDeleteCmsModelTask>;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { WebinyError } from "@webiny/error";
|
|
2
|
+
import { createStoreKey } from "../../helpers/store.js";
|
|
3
|
+
import { DELETE_MODEL_TASK } from "../../constants.js";
|
|
4
|
+
import { getStatus } from "./status.js";
|
|
5
|
+
export const cancelDeleteModel = async params => {
|
|
6
|
+
const {
|
|
7
|
+
context,
|
|
8
|
+
modelId
|
|
9
|
+
} = params;
|
|
10
|
+
const model = await context.cms.getModel(modelId);
|
|
11
|
+
await context.cms.accessControl.ensureCanAccessModel({
|
|
12
|
+
model,
|
|
13
|
+
rwd: "d"
|
|
14
|
+
});
|
|
15
|
+
await context.cms.accessControl.ensureCanAccessEntry({
|
|
16
|
+
model,
|
|
17
|
+
rwd: "w"
|
|
18
|
+
});
|
|
19
|
+
const storeKey = createStoreKey(model);
|
|
20
|
+
const result = await context.db.store.getValue(storeKey);
|
|
21
|
+
const taskId = result.data?.task;
|
|
22
|
+
await context.db.store.removeValue(storeKey);
|
|
23
|
+
if (!taskId) {
|
|
24
|
+
if (result.error) {
|
|
25
|
+
throw WebinyError.from(result.error, {
|
|
26
|
+
code: "DELETE_MODEL_NO_TASK_DEFINED"
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
throw new WebinyError({
|
|
30
|
+
message: `Model "${modelId}" is not being deleted.`,
|
|
31
|
+
code: "MODEL_NOT_BEING_DELETED"
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
const task = await context.tasks.getTask(taskId);
|
|
35
|
+
if (task?.definitionId !== DELETE_MODEL_TASK) {
|
|
36
|
+
throw new WebinyError({
|
|
37
|
+
message: `The task which is deleting a model cannot be found. Please check Step Functions for more info. Task id: ${taskId}`,
|
|
38
|
+
code: "DELETE_MODEL_TASK_NOT_FOUND",
|
|
39
|
+
data: {
|
|
40
|
+
model: model.modelId,
|
|
41
|
+
task: taskId
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
const abortResult = await context.tasks.abort({
|
|
46
|
+
id: task.id,
|
|
47
|
+
message: "User canceled the task."
|
|
48
|
+
});
|
|
49
|
+
const canceledTask = abortResult.value;
|
|
50
|
+
return {
|
|
51
|
+
id: canceledTask.id,
|
|
52
|
+
status: getStatus(canceledTask.taskStatus),
|
|
53
|
+
total: canceledTask.output?.total || 0,
|
|
54
|
+
deleted: canceledTask.output?.deleted || 0
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
//# sourceMappingURL=cancelDeleteModel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["WebinyError","createStoreKey","DELETE_MODEL_TASK","getStatus","cancelDeleteModel","params","context","modelId","model","cms","getModel","accessControl","ensureCanAccessModel","rwd","ensureCanAccessEntry","storeKey","result","db","store","getValue","taskId","data","task","removeValue","error","from","code","message","tasks","getTask","definitionId","abortResult","abort","id","canceledTask","value","status","taskStatus","total","output","deleted"],"sources":["cancelDeleteModel.ts"],"sourcesContent":["import type { HcmsTasksContext } from \"~/types.js\";\nimport { WebinyError } from \"@webiny/error\";\nimport type {\n IDeleteCmsModelTask,\n IDeleteModelTaskInput,\n IDeleteModelTaskOutput,\n IStoreValue\n} from \"~/features/DeleteModelTask/types.js\";\nimport { createStoreKey } from \"~/helpers/store.js\";\nimport { DELETE_MODEL_TASK } from \"~/constants.js\";\nimport { getStatus } from \"~/graphql/deleteModel/status.js\";\n\nexport interface ICancelDeleteModelParams {\n readonly context: Pick<HcmsTasksContext, \"cms\" | \"tasks\" | \"db\">;\n readonly modelId: string;\n}\n\nexport const cancelDeleteModel = async (\n params: ICancelDeleteModelParams\n): Promise<IDeleteCmsModelTask> => {\n const { context, modelId } = params;\n\n const model = await context.cms.getModel(modelId);\n\n await context.cms.accessControl.ensureCanAccessModel({\n model,\n rwd: \"d\"\n });\n\n await context.cms.accessControl.ensureCanAccessEntry({\n model,\n rwd: \"w\"\n });\n\n const storeKey = createStoreKey(model);\n\n const result = await context.db.store.getValue<IStoreValue>(storeKey);\n\n const taskId = result.data?.task;\n\n await context.db.store.removeValue(storeKey);\n if (!taskId) {\n if (result.error) {\n throw WebinyError.from(result.error, {\n code: \"DELETE_MODEL_NO_TASK_DEFINED\"\n });\n }\n throw new WebinyError({\n message: `Model \"${modelId}\" is not being deleted.`,\n code: \"MODEL_NOT_BEING_DELETED\"\n });\n }\n\n const task = await context.tasks.getTask<IDeleteModelTaskInput, IDeleteModelTaskOutput>(taskId);\n if (task?.definitionId !== DELETE_MODEL_TASK) {\n throw new WebinyError({\n message: `The task which is deleting a model cannot be found. Please check Step Functions for more info. Task id: ${taskId}`,\n code: \"DELETE_MODEL_TASK_NOT_FOUND\",\n data: {\n model: model.modelId,\n task: taskId\n }\n });\n }\n\n const abortResult = await context.tasks.abort<IDeleteModelTaskInput, IDeleteModelTaskOutput>({\n id: task.id,\n message: \"User canceled the task.\"\n });\n\n const canceledTask = abortResult.value;\n\n return {\n id: canceledTask.id,\n status: getStatus(canceledTask.taskStatus),\n total: canceledTask.output?.total || 0,\n deleted: canceledTask.output?.deleted || 0\n };\n};\n"],"mappings":"AACA,SAASA,WAAW,QAAQ,eAAe;AAO3C,SAASC,cAAc;AACvB,SAASC,iBAAiB;AAC1B,SAASC,SAAS;AAOlB,OAAO,MAAMC,iBAAiB,GAAG,MAC7BC,MAAgC,IACD;EAC/B,MAAM;IAAEC,OAAO;IAAEC;EAAQ,CAAC,GAAGF,MAAM;EAEnC,MAAMG,KAAK,GAAG,MAAMF,OAAO,CAACG,GAAG,CAACC,QAAQ,CAACH,OAAO,CAAC;EAEjD,MAAMD,OAAO,CAACG,GAAG,CAACE,aAAa,CAACC,oBAAoB,CAAC;IACjDJ,KAAK;IACLK,GAAG,EAAE;EACT,CAAC,CAAC;EAEF,MAAMP,OAAO,CAACG,GAAG,CAACE,aAAa,CAACG,oBAAoB,CAAC;IACjDN,KAAK;IACLK,GAAG,EAAE;EACT,CAAC,CAAC;EAEF,MAAME,QAAQ,GAAGd,cAAc,CAACO,KAAK,CAAC;EAEtC,MAAMQ,MAAM,GAAG,MAAMV,OAAO,CAACW,EAAE,CAACC,KAAK,CAACC,QAAQ,CAAcJ,QAAQ,CAAC;EAErE,MAAMK,MAAM,GAAGJ,MAAM,CAACK,IAAI,EAAEC,IAAI;EAEhC,MAAMhB,OAAO,CAACW,EAAE,CAACC,KAAK,CAACK,WAAW,CAACR,QAAQ,CAAC;EAC5C,IAAI,CAACK,MAAM,EAAE;IACT,IAAIJ,MAAM,CAACQ,KAAK,EAAE;MACd,MAAMxB,WAAW,CAACyB,IAAI,CAACT,MAAM,CAACQ,KAAK,EAAE;QACjCE,IAAI,EAAE;MACV,CAAC,CAAC;IACN;IACA,MAAM,IAAI1B,WAAW,CAAC;MAClB2B,OAAO,EAAE,UAAUpB,OAAO,yBAAyB;MACnDmB,IAAI,EAAE;IACV,CAAC,CAAC;EACN;EAEA,MAAMJ,IAAI,GAAG,MAAMhB,OAAO,CAACsB,KAAK,CAACC,OAAO,CAAgDT,MAAM,CAAC;EAC/F,IAAIE,IAAI,EAAEQ,YAAY,KAAK5B,iBAAiB,EAAE;IAC1C,MAAM,IAAIF,WAAW,CAAC;MAClB2B,OAAO,EAAE,2GAA2GP,MAAM,EAAE;MAC5HM,IAAI,EAAE,6BAA6B;MACnCL,IAAI,EAAE;QACFb,KAAK,EAAEA,KAAK,CAACD,OAAO;QACpBe,IAAI,EAAEF;MACV;IACJ,CAAC,CAAC;EACN;EAEA,MAAMW,WAAW,GAAG,MAAMzB,OAAO,CAACsB,KAAK,CAACI,KAAK,CAAgD;IACzFC,EAAE,EAAEX,IAAI,CAACW,EAAE;IACXN,OAAO,EAAE;EACb,CAAC,CAAC;EAEF,MAAMO,YAAY,GAAGH,WAAW,CAACI,KAAK;EAEtC,OAAO;IACHF,EAAE,EAAEC,YAAY,CAACD,EAAE;IACnBG,MAAM,EAAEjC,SAAS,CAAC+B,YAAY,CAACG,UAAU,CAAC;IAC1CC,KAAK,EAAEJ,YAAY,CAACK,MAAM,EAAED,KAAK,IAAI,CAAC;IACtCE,OAAO,EAAEN,YAAY,CAACK,MAAM,EAAEC,OAAO,IAAI;EAC7C,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { createCacheKey } from "@webiny/api-headless-cms/utils/index.js";
|
|
2
|
+
import { createMemoryCache } from "@webiny/api-headless-cms/utils/index.js";
|
|
3
|
+
import { ContextPlugin } from "@webiny/api";
|
|
4
|
+
import { DisableModelFeature } from "../../features/DisableModel/feature.js";
|
|
5
|
+
import { createStoreNamespace } from "../../helpers/store.js";
|
|
6
|
+
import { fullyDeleteModel } from "./fullyDeleteModel.js";
|
|
7
|
+
import { cancelDeleteModel } from "./cancelDeleteModel.js";
|
|
8
|
+
import { getDeleteModelProgress } from "./getDeleteModelProgress.js";
|
|
9
|
+
export const createDeleteModelCrud = () => {
|
|
10
|
+
const plugin = new ContextPlugin(async context => {
|
|
11
|
+
const getTenant = () => {
|
|
12
|
+
return context.tenancy.getCurrentTenant().id;
|
|
13
|
+
};
|
|
14
|
+
const cache = createMemoryCache();
|
|
15
|
+
context.cms.listModelsBeingDeleted = async () => {
|
|
16
|
+
const tenant = getTenant();
|
|
17
|
+
const cacheKey = createCacheKey({
|
|
18
|
+
tenant: getTenant(),
|
|
19
|
+
type: "deleteModel"
|
|
20
|
+
});
|
|
21
|
+
const result = await cache.getOrSet(cacheKey, async () => {
|
|
22
|
+
const beginsWith = createStoreNamespace({
|
|
23
|
+
tenant
|
|
24
|
+
});
|
|
25
|
+
return await context.db.store.listValues({
|
|
26
|
+
beginsWith
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
if (result.error) {
|
|
30
|
+
throw result.error;
|
|
31
|
+
} else if (!result.data) {
|
|
32
|
+
return [];
|
|
33
|
+
}
|
|
34
|
+
return Object.values(result.data);
|
|
35
|
+
};
|
|
36
|
+
context.cms.isModelBeingDeleted = async modelId => {
|
|
37
|
+
const items = await context.cms.listModelsBeingDeleted();
|
|
38
|
+
return items.some(item => item.modelId === modelId);
|
|
39
|
+
};
|
|
40
|
+
context.cms.fullyDeleteModel = async modelId => {
|
|
41
|
+
const result = await fullyDeleteModel({
|
|
42
|
+
context,
|
|
43
|
+
modelId
|
|
44
|
+
});
|
|
45
|
+
cache.clear();
|
|
46
|
+
return result;
|
|
47
|
+
};
|
|
48
|
+
context.cms.cancelFullyDeleteModel = async modelId => {
|
|
49
|
+
const result = await cancelDeleteModel({
|
|
50
|
+
context,
|
|
51
|
+
modelId
|
|
52
|
+
});
|
|
53
|
+
cache.clear();
|
|
54
|
+
return result;
|
|
55
|
+
};
|
|
56
|
+
context.cms.getDeleteModelProgress = async modelId => {
|
|
57
|
+
return await getDeleteModelProgress({
|
|
58
|
+
context,
|
|
59
|
+
modelId
|
|
60
|
+
});
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
// Register feature
|
|
64
|
+
DisableModelFeature.register(context.container, {
|
|
65
|
+
isModelBeingDeleted: context.cms.isModelBeingDeleted
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
plugin.name = "headlessCms.context.cms.fullyDeleteModel";
|
|
69
|
+
return plugin;
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
//# sourceMappingURL=crud.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createCacheKey","createMemoryCache","ContextPlugin","DisableModelFeature","createStoreNamespace","fullyDeleteModel","cancelDeleteModel","getDeleteModelProgress","createDeleteModelCrud","plugin","context","getTenant","tenancy","getCurrentTenant","id","cache","cms","listModelsBeingDeleted","tenant","cacheKey","type","result","getOrSet","beginsWith","db","store","listValues","error","data","Object","values","isModelBeingDeleted","modelId","items","some","item","clear","cancelFullyDeleteModel","register","container","name"],"sources":["crud.ts"],"sourcesContent":["import type { HcmsTasksContext } from \"~/types.js\";\nimport { createCacheKey } from \"@webiny/api-headless-cms/utils/index.js\";\nimport { createMemoryCache } from \"@webiny/api-headless-cms/utils/index.js\";\nimport type { IStoreValue } from \"~/features/DeleteModelTask/types.js\";\nimport type { ListStoreKeysResult } from \"~/features/DeleteModelTask/types.js\";\nimport type { GenericRecord } from \"@webiny/api/types.js\";\nimport { ContextPlugin } from \"@webiny/api\";\nimport { DisableModelFeature } from \"~/features/DisableModel/feature.js\";\nimport { createStoreNamespace } from \"~/helpers/store.js\";\nimport { fullyDeleteModel } from \"~/graphql/deleteModel/fullyDeleteModel.js\";\nimport { cancelDeleteModel } from \"~/graphql/deleteModel/cancelDeleteModel.js\";\nimport { getDeleteModelProgress } from \"~/graphql/deleteModel/getDeleteModelProgress.js\";\n\nexport const createDeleteModelCrud = () => {\n const plugin = new ContextPlugin<HcmsTasksContext>(async context => {\n const getTenant = (): string => {\n return context.tenancy.getCurrentTenant().id;\n };\n\n const cache = createMemoryCache<ListStoreKeysResult>();\n\n context.cms.listModelsBeingDeleted = async () => {\n const tenant = getTenant();\n const cacheKey = createCacheKey({\n tenant: getTenant(),\n type: \"deleteModel\"\n });\n\n const result = await cache.getOrSet(cacheKey, async () => {\n const beginsWith = createStoreNamespace({\n tenant\n });\n return await context.db.store.listValues<GenericRecord<string, IStoreValue>>({\n beginsWith\n });\n });\n\n if (result.error) {\n throw result.error;\n } else if (!result.data) {\n return [];\n }\n return Object.values(result.data);\n };\n\n context.cms.isModelBeingDeleted = async (modelId: string) => {\n const items = await context.cms.listModelsBeingDeleted();\n return items.some(item => item.modelId === modelId);\n };\n context.cms.fullyDeleteModel = async (modelId: string) => {\n const result = await fullyDeleteModel({\n context,\n modelId\n });\n cache.clear();\n return result;\n };\n\n context.cms.cancelFullyDeleteModel = async (modelId: string) => {\n const result = await cancelDeleteModel({\n context,\n modelId\n });\n cache.clear();\n return result;\n };\n\n context.cms.getDeleteModelProgress = async (modelId: string) => {\n return await getDeleteModelProgress({\n context,\n modelId\n });\n };\n\n // Register feature\n DisableModelFeature.register(context.container, {\n isModelBeingDeleted: context.cms.isModelBeingDeleted\n });\n });\n\n plugin.name = \"headlessCms.context.cms.fullyDeleteModel\";\n\n return plugin;\n};\n"],"mappings":"AACA,SAASA,cAAc,QAAQ,yCAAyC;AACxE,SAASC,iBAAiB,QAAQ,yCAAyC;AAI3E,SAASC,aAAa,QAAQ,aAAa;AAC3C,SAASC,mBAAmB;AAC5B,SAASC,oBAAoB;AAC7B,SAASC,gBAAgB;AACzB,SAASC,iBAAiB;AAC1B,SAASC,sBAAsB;AAE/B,OAAO,MAAMC,qBAAqB,GAAGA,CAAA,KAAM;EACvC,MAAMC,MAAM,GAAG,IAAIP,aAAa,CAAmB,MAAMQ,OAAO,IAAI;IAChE,MAAMC,SAAS,GAAGA,CAAA,KAAc;MAC5B,OAAOD,OAAO,CAACE,OAAO,CAACC,gBAAgB,CAAC,CAAC,CAACC,EAAE;IAChD,CAAC;IAED,MAAMC,KAAK,GAAGd,iBAAiB,CAAsB,CAAC;IAEtDS,OAAO,CAACM,GAAG,CAACC,sBAAsB,GAAG,YAAY;MAC7C,MAAMC,MAAM,GAAGP,SAAS,CAAC,CAAC;MAC1B,MAAMQ,QAAQ,GAAGnB,cAAc,CAAC;QAC5BkB,MAAM,EAAEP,SAAS,CAAC,CAAC;QACnBS,IAAI,EAAE;MACV,CAAC,CAAC;MAEF,MAAMC,MAAM,GAAG,MAAMN,KAAK,CAACO,QAAQ,CAACH,QAAQ,EAAE,YAAY;QACtD,MAAMI,UAAU,GAAGnB,oBAAoB,CAAC;UACpCc;QACJ,CAAC,CAAC;QACF,OAAO,MAAMR,OAAO,CAACc,EAAE,CAACC,KAAK,CAACC,UAAU,CAAqC;UACzEH;QACJ,CAAC,CAAC;MACN,CAAC,CAAC;MAEF,IAAIF,MAAM,CAACM,KAAK,EAAE;QACd,MAAMN,MAAM,CAACM,KAAK;MACtB,CAAC,MAAM,IAAI,CAACN,MAAM,CAACO,IAAI,EAAE;QACrB,OAAO,EAAE;MACb;MACA,OAAOC,MAAM,CAACC,MAAM,CAACT,MAAM,CAACO,IAAI,CAAC;IACrC,CAAC;IAEDlB,OAAO,CAACM,GAAG,CAACe,mBAAmB,GAAG,MAAOC,OAAe,IAAK;MACzD,MAAMC,KAAK,GAAG,MAAMvB,OAAO,CAACM,GAAG,CAACC,sBAAsB,CAAC,CAAC;MACxD,OAAOgB,KAAK,CAACC,IAAI,CAACC,IAAI,IAAIA,IAAI,CAACH,OAAO,KAAKA,OAAO,CAAC;IACvD,CAAC;IACDtB,OAAO,CAACM,GAAG,CAACX,gBAAgB,GAAG,MAAO2B,OAAe,IAAK;MACtD,MAAMX,MAAM,GAAG,MAAMhB,gBAAgB,CAAC;QAClCK,OAAO;QACPsB;MACJ,CAAC,CAAC;MACFjB,KAAK,CAACqB,KAAK,CAAC,CAAC;MACb,OAAOf,MAAM;IACjB,CAAC;IAEDX,OAAO,CAACM,GAAG,CAACqB,sBAAsB,GAAG,MAAOL,OAAe,IAAK;MAC5D,MAAMX,MAAM,GAAG,MAAMf,iBAAiB,CAAC;QACnCI,OAAO;QACPsB;MACJ,CAAC,CAAC;MACFjB,KAAK,CAACqB,KAAK,CAAC,CAAC;MACb,OAAOf,MAAM;IACjB,CAAC;IAEDX,OAAO,CAACM,GAAG,CAACT,sBAAsB,GAAG,MAAOyB,OAAe,IAAK;MAC5D,OAAO,MAAMzB,sBAAsB,CAAC;QAChCG,OAAO;QACPsB;MACJ,CAAC,CAAC;IACN,CAAC;;IAED;IACA7B,mBAAmB,CAACmC,QAAQ,CAAC5B,OAAO,CAAC6B,SAAS,EAAE;MAC5CR,mBAAmB,EAAErB,OAAO,CAACM,GAAG,CAACe;IACrC,CAAC,CAAC;EACN,CAAC,CAAC;EAEFtB,MAAM,CAAC+B,IAAI,GAAG,0CAA0C;EAExD,OAAO/B,MAAM;AACjB,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { HcmsTasksContext } from "../../types.js";
|
|
2
|
+
import type { IDeleteCmsModelTask } from "../../features/DeleteModelTask/types.js";
|
|
3
|
+
export interface IFullyDeleteModelParams {
|
|
4
|
+
readonly context: Pick<HcmsTasksContext, "cms" | "tasks" | "db" | "security">;
|
|
5
|
+
readonly modelId: string;
|
|
6
|
+
}
|
|
7
|
+
export declare const fullyDeleteModel: (params: IFullyDeleteModelParams) => Promise<IDeleteCmsModelTask>;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { createStoreKey, createStoreValue } from "../../helpers/store.js";
|
|
2
|
+
import { DELETE_MODEL_TASK } from "../../constants.js";
|
|
3
|
+
import { getStatus } from "./status.js";
|
|
4
|
+
export const fullyDeleteModel = async params => {
|
|
5
|
+
const {
|
|
6
|
+
context,
|
|
7
|
+
modelId
|
|
8
|
+
} = params;
|
|
9
|
+
const model = await context.cms.getModel(modelId);
|
|
10
|
+
if (model.isPrivate) {
|
|
11
|
+
throw new Error(`Cannot delete private model.`);
|
|
12
|
+
}
|
|
13
|
+
await context.cms.accessControl.ensureCanAccessModel({
|
|
14
|
+
model,
|
|
15
|
+
rwd: "d"
|
|
16
|
+
});
|
|
17
|
+
await context.cms.accessControl.ensureCanAccessEntry({
|
|
18
|
+
model,
|
|
19
|
+
rwd: "w"
|
|
20
|
+
});
|
|
21
|
+
if (!model) {
|
|
22
|
+
throw new Error(`Model "${modelId}" not found.`);
|
|
23
|
+
}
|
|
24
|
+
const storeKey = createStoreKey(model);
|
|
25
|
+
const result = await context.db.store.getValue(storeKey);
|
|
26
|
+
const taskId = result.data?.task;
|
|
27
|
+
if (taskId) {
|
|
28
|
+
throw new Error(`Model "${modelId}" is already getting deleted. Task id: ${taskId}.`);
|
|
29
|
+
}
|
|
30
|
+
const triggerResult = await context.tasks.trigger({
|
|
31
|
+
input: {
|
|
32
|
+
modelId
|
|
33
|
+
},
|
|
34
|
+
definition: DELETE_MODEL_TASK,
|
|
35
|
+
name: `Fully delete model: ${modelId}`
|
|
36
|
+
});
|
|
37
|
+
const task = triggerResult.value;
|
|
38
|
+
const identity = context.security.getIdentity();
|
|
39
|
+
await context.db.store.storeValue(storeKey, createStoreValue({
|
|
40
|
+
...model,
|
|
41
|
+
identity: {
|
|
42
|
+
id: identity.id,
|
|
43
|
+
type: identity.type,
|
|
44
|
+
displayName: identity.displayName
|
|
45
|
+
},
|
|
46
|
+
task: task.id
|
|
47
|
+
}));
|
|
48
|
+
return {
|
|
49
|
+
id: task.id,
|
|
50
|
+
status: getStatus(task.taskStatus),
|
|
51
|
+
total: 0,
|
|
52
|
+
deleted: 0
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
//# sourceMappingURL=fullyDeleteModel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createStoreKey","createStoreValue","DELETE_MODEL_TASK","getStatus","fullyDeleteModel","params","context","modelId","model","cms","getModel","isPrivate","Error","accessControl","ensureCanAccessModel","rwd","ensureCanAccessEntry","storeKey","result","db","store","getValue","taskId","data","task","triggerResult","tasks","trigger","input","definition","name","value","identity","security","getIdentity","storeValue","id","type","displayName","status","taskStatus","total","deleted"],"sources":["fullyDeleteModel.ts"],"sourcesContent":["import type { HcmsTasksContext } from \"~/types.js\";\nimport type {\n IDeleteCmsModelTask,\n IDeleteModelTaskInput,\n IStoreValue\n} from \"~/features/DeleteModelTask/types.js\";\nimport { createStoreKey, createStoreValue } from \"~/helpers/store.js\";\nimport { DELETE_MODEL_TASK } from \"~/constants.js\";\nimport { getStatus } from \"~/graphql/deleteModel/status.js\";\n\nexport interface IFullyDeleteModelParams {\n readonly context: Pick<HcmsTasksContext, \"cms\" | \"tasks\" | \"db\" | \"security\">;\n readonly modelId: string;\n}\n\nexport const fullyDeleteModel = async (\n params: IFullyDeleteModelParams\n): Promise<IDeleteCmsModelTask> => {\n const { context, modelId } = params;\n\n const model = await context.cms.getModel(modelId);\n\n if (model.isPrivate) {\n throw new Error(`Cannot delete private model.`);\n }\n\n await context.cms.accessControl.ensureCanAccessModel({\n model,\n rwd: \"d\"\n });\n\n await context.cms.accessControl.ensureCanAccessEntry({\n model,\n rwd: \"w\"\n });\n\n if (!model) {\n throw new Error(`Model \"${modelId}\" not found.`);\n }\n const storeKey = createStoreKey(model);\n const result = await context.db.store.getValue<IStoreValue>(storeKey);\n const taskId = result.data?.task;\n if (taskId) {\n throw new Error(`Model \"${modelId}\" is already getting deleted. Task id: ${taskId}.`);\n }\n\n const triggerResult = await context.tasks.trigger<IDeleteModelTaskInput>({\n input: {\n modelId\n },\n definition: DELETE_MODEL_TASK,\n name: `Fully delete model: ${modelId}`\n });\n\n const task = triggerResult.value;\n\n const identity = context.security.getIdentity();\n\n await context.db.store.storeValue(\n storeKey,\n createStoreValue({\n ...model,\n identity: {\n id: identity.id,\n type: identity.type,\n displayName: identity.displayName\n },\n task: task.id\n })\n );\n\n return {\n id: task.id,\n status: getStatus(task.taskStatus),\n total: 0,\n deleted: 0\n };\n};\n"],"mappings":"AAMA,SAASA,cAAc,EAAEC,gBAAgB;AACzC,SAASC,iBAAiB;AAC1B,SAASC,SAAS;AAOlB,OAAO,MAAMC,gBAAgB,GAAG,MAC5BC,MAA+B,IACA;EAC/B,MAAM;IAAEC,OAAO;IAAEC;EAAQ,CAAC,GAAGF,MAAM;EAEnC,MAAMG,KAAK,GAAG,MAAMF,OAAO,CAACG,GAAG,CAACC,QAAQ,CAACH,OAAO,CAAC;EAEjD,IAAIC,KAAK,CAACG,SAAS,EAAE;IACjB,MAAM,IAAIC,KAAK,CAAC,8BAA8B,CAAC;EACnD;EAEA,MAAMN,OAAO,CAACG,GAAG,CAACI,aAAa,CAACC,oBAAoB,CAAC;IACjDN,KAAK;IACLO,GAAG,EAAE;EACT,CAAC,CAAC;EAEF,MAAMT,OAAO,CAACG,GAAG,CAACI,aAAa,CAACG,oBAAoB,CAAC;IACjDR,KAAK;IACLO,GAAG,EAAE;EACT,CAAC,CAAC;EAEF,IAAI,CAACP,KAAK,EAAE;IACR,MAAM,IAAII,KAAK,CAAC,UAAUL,OAAO,cAAc,CAAC;EACpD;EACA,MAAMU,QAAQ,GAAGjB,cAAc,CAACQ,KAAK,CAAC;EACtC,MAAMU,MAAM,GAAG,MAAMZ,OAAO,CAACa,EAAE,CAACC,KAAK,CAACC,QAAQ,CAAcJ,QAAQ,CAAC;EACrE,MAAMK,MAAM,GAAGJ,MAAM,CAACK,IAAI,EAAEC,IAAI;EAChC,IAAIF,MAAM,EAAE;IACR,MAAM,IAAIV,KAAK,CAAC,UAAUL,OAAO,0CAA0Ce,MAAM,GAAG,CAAC;EACzF;EAEA,MAAMG,aAAa,GAAG,MAAMnB,OAAO,CAACoB,KAAK,CAACC,OAAO,CAAwB;IACrEC,KAAK,EAAE;MACHrB;IACJ,CAAC;IACDsB,UAAU,EAAE3B,iBAAiB;IAC7B4B,IAAI,EAAE,uBAAuBvB,OAAO;EACxC,CAAC,CAAC;EAEF,MAAMiB,IAAI,GAAGC,aAAa,CAACM,KAAK;EAEhC,MAAMC,QAAQ,GAAG1B,OAAO,CAAC2B,QAAQ,CAACC,WAAW,CAAC,CAAC;EAE/C,MAAM5B,OAAO,CAACa,EAAE,CAACC,KAAK,CAACe,UAAU,CAC7BlB,QAAQ,EACRhB,gBAAgB,CAAC;IACb,GAAGO,KAAK;IACRwB,QAAQ,EAAE;MACNI,EAAE,EAAEJ,QAAQ,CAACI,EAAE;MACfC,IAAI,EAAEL,QAAQ,CAACK,IAAI;MACnBC,WAAW,EAAEN,QAAQ,CAACM;IAC1B,CAAC;IACDd,IAAI,EAAEA,IAAI,CAACY;EACf,CAAC,CACL,CAAC;EAED,OAAO;IACHA,EAAE,EAAEZ,IAAI,CAACY,EAAE;IACXG,MAAM,EAAEpC,SAAS,CAACqB,IAAI,CAACgB,UAAU,CAAC;IAClCC,KAAK,EAAE,CAAC;IACRC,OAAO,EAAE;EACb,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { HcmsTasksContext } from "../../types.js";
|
|
2
|
+
import type { IDeleteCmsModelTask } from "../../features/DeleteModelTask/types.js";
|
|
3
|
+
export interface IGetDeleteModelProgress {
|
|
4
|
+
readonly context: Pick<HcmsTasksContext, "cms" | "tasks" | "db">;
|
|
5
|
+
readonly modelId: string;
|
|
6
|
+
}
|
|
7
|
+
export declare const getDeleteModelProgress: (params: IGetDeleteModelProgress) => Promise<IDeleteCmsModelTask>;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { WebinyError } from "@webiny/error";
|
|
2
|
+
import { NotFoundError } from "@webiny/handler-graphql";
|
|
3
|
+
import { createStoreKey } from "../../helpers/store.js";
|
|
4
|
+
import { DELETE_MODEL_TASK } from "../../constants.js";
|
|
5
|
+
import { getStatus } from "./status.js";
|
|
6
|
+
export const getDeleteModelProgress = async params => {
|
|
7
|
+
const {
|
|
8
|
+
context,
|
|
9
|
+
modelId
|
|
10
|
+
} = params;
|
|
11
|
+
let model;
|
|
12
|
+
try {
|
|
13
|
+
model = await context.cms.getModel(modelId);
|
|
14
|
+
} catch (ex) {
|
|
15
|
+
if (ex instanceof NotFoundError === false) {
|
|
16
|
+
throw ex;
|
|
17
|
+
}
|
|
18
|
+
throw new WebinyError({
|
|
19
|
+
message: "Model not found. It must have been deleted already.",
|
|
20
|
+
code: "MODEL_ALREADY_DELETED_FOUND",
|
|
21
|
+
data: {
|
|
22
|
+
model: modelId
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
await context.cms.accessControl.ensureCanAccessModel({
|
|
27
|
+
model,
|
|
28
|
+
rwd: "d"
|
|
29
|
+
});
|
|
30
|
+
await context.cms.accessControl.ensureCanAccessEntry({
|
|
31
|
+
model,
|
|
32
|
+
rwd: "w"
|
|
33
|
+
});
|
|
34
|
+
const storeKey = createStoreKey(model);
|
|
35
|
+
const result = await context.db.store.getValue(storeKey);
|
|
36
|
+
const taskId = result.data?.task;
|
|
37
|
+
if (!taskId) {
|
|
38
|
+
throw new Error(`Model "${modelId}" is not being deleted.`);
|
|
39
|
+
}
|
|
40
|
+
const task = await context.tasks.getTask(taskId);
|
|
41
|
+
if (task?.definitionId !== DELETE_MODEL_TASK) {
|
|
42
|
+
throw new WebinyError({
|
|
43
|
+
message: `The task which is deleting a model cannot be found.`,
|
|
44
|
+
code: "DELETE_MODEL_TASK_NOT_FOUND",
|
|
45
|
+
data: {
|
|
46
|
+
model: model.modelId,
|
|
47
|
+
task: taskId
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
id: task.id,
|
|
53
|
+
status: getStatus(task.taskStatus),
|
|
54
|
+
total: task.output?.total || 0,
|
|
55
|
+
deleted: task.output?.deleted || 0
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
//# sourceMappingURL=getDeleteModelProgress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["WebinyError","NotFoundError","createStoreKey","DELETE_MODEL_TASK","getStatus","getDeleteModelProgress","params","context","modelId","model","cms","getModel","ex","message","code","data","accessControl","ensureCanAccessModel","rwd","ensureCanAccessEntry","storeKey","result","db","store","getValue","taskId","task","Error","tasks","getTask","definitionId","id","status","taskStatus","total","output","deleted"],"sources":["getDeleteModelProgress.ts"],"sourcesContent":["import type { HcmsTasksContext } from \"~/types.js\";\nimport { WebinyError } from \"@webiny/error\";\nimport { NotFoundError } from \"@webiny/handler-graphql\";\nimport type { CmsModel } from \"@webiny/api-headless-cms/types/index.js\";\nimport type {\n IDeleteCmsModelTask,\n IDeleteModelTaskInput,\n IDeleteModelTaskOutput,\n IStoreValue\n} from \"~/features/DeleteModelTask/types.js\";\nimport { createStoreKey } from \"~/helpers/store.js\";\nimport { DELETE_MODEL_TASK } from \"~/constants.js\";\nimport { getStatus } from \"~/graphql/deleteModel/status.js\";\n\nexport interface IGetDeleteModelProgress {\n readonly context: Pick<HcmsTasksContext, \"cms\" | \"tasks\" | \"db\">;\n readonly modelId: string;\n}\n\nexport const getDeleteModelProgress = async (\n params: IGetDeleteModelProgress\n): Promise<IDeleteCmsModelTask> => {\n const { context, modelId } = params;\n\n let model: CmsModel;\n try {\n model = await context.cms.getModel(modelId);\n } catch (ex) {\n if (ex instanceof NotFoundError === false) {\n throw ex;\n }\n throw new WebinyError({\n message: \"Model not found. It must have been deleted already.\",\n code: \"MODEL_ALREADY_DELETED_FOUND\",\n data: {\n model: modelId\n }\n });\n }\n\n await context.cms.accessControl.ensureCanAccessModel({\n model,\n rwd: \"d\"\n });\n\n await context.cms.accessControl.ensureCanAccessEntry({\n model,\n rwd: \"w\"\n });\n\n const storeKey = createStoreKey(model);\n const result = await context.db.store.getValue<IStoreValue>(storeKey);\n\n const taskId = result.data?.task;\n if (!taskId) {\n throw new Error(`Model \"${modelId}\" is not being deleted.`);\n }\n\n const task = await context.tasks.getTask<IDeleteModelTaskInput, IDeleteModelTaskOutput>(taskId);\n if (task?.definitionId !== DELETE_MODEL_TASK) {\n throw new WebinyError({\n message: `The task which is deleting a model cannot be found.`,\n code: \"DELETE_MODEL_TASK_NOT_FOUND\",\n data: {\n model: model.modelId,\n task: taskId\n }\n });\n }\n return {\n id: task.id,\n status: getStatus(task.taskStatus),\n total: task.output?.total || 0,\n deleted: task.output?.deleted || 0\n };\n};\n"],"mappings":"AACA,SAASA,WAAW,QAAQ,eAAe;AAC3C,SAASC,aAAa,QAAQ,yBAAyB;AAQvD,SAASC,cAAc;AACvB,SAASC,iBAAiB;AAC1B,SAASC,SAAS;AAOlB,OAAO,MAAMC,sBAAsB,GAAG,MAClCC,MAA+B,IACA;EAC/B,MAAM;IAAEC,OAAO;IAAEC;EAAQ,CAAC,GAAGF,MAAM;EAEnC,IAAIG,KAAe;EACnB,IAAI;IACAA,KAAK,GAAG,MAAMF,OAAO,CAACG,GAAG,CAACC,QAAQ,CAACH,OAAO,CAAC;EAC/C,CAAC,CAAC,OAAOI,EAAE,EAAE;IACT,IAAIA,EAAE,YAAYX,aAAa,KAAK,KAAK,EAAE;MACvC,MAAMW,EAAE;IACZ;IACA,MAAM,IAAIZ,WAAW,CAAC;MAClBa,OAAO,EAAE,qDAAqD;MAC9DC,IAAI,EAAE,6BAA6B;MACnCC,IAAI,EAAE;QACFN,KAAK,EAAED;MACX;IACJ,CAAC,CAAC;EACN;EAEA,MAAMD,OAAO,CAACG,GAAG,CAACM,aAAa,CAACC,oBAAoB,CAAC;IACjDR,KAAK;IACLS,GAAG,EAAE;EACT,CAAC,CAAC;EAEF,MAAMX,OAAO,CAACG,GAAG,CAACM,aAAa,CAACG,oBAAoB,CAAC;IACjDV,KAAK;IACLS,GAAG,EAAE;EACT,CAAC,CAAC;EAEF,MAAME,QAAQ,GAAGlB,cAAc,CAACO,KAAK,CAAC;EACtC,MAAMY,MAAM,GAAG,MAAMd,OAAO,CAACe,EAAE,CAACC,KAAK,CAACC,QAAQ,CAAcJ,QAAQ,CAAC;EAErE,MAAMK,MAAM,GAAGJ,MAAM,CAACN,IAAI,EAAEW,IAAI;EAChC,IAAI,CAACD,MAAM,EAAE;IACT,MAAM,IAAIE,KAAK,CAAC,UAAUnB,OAAO,yBAAyB,CAAC;EAC/D;EAEA,MAAMkB,IAAI,GAAG,MAAMnB,OAAO,CAACqB,KAAK,CAACC,OAAO,CAAgDJ,MAAM,CAAC;EAC/F,IAAIC,IAAI,EAAEI,YAAY,KAAK3B,iBAAiB,EAAE;IAC1C,MAAM,IAAIH,WAAW,CAAC;MAClBa,OAAO,EAAE,qDAAqD;MAC9DC,IAAI,EAAE,6BAA6B;MACnCC,IAAI,EAAE;QACFN,KAAK,EAAEA,KAAK,CAACD,OAAO;QACpBkB,IAAI,EAAED;MACV;IACJ,CAAC,CAAC;EACN;EACA,OAAO;IACHM,EAAE,EAAEL,IAAI,CAACK,EAAE;IACXC,MAAM,EAAE5B,SAAS,CAACsB,IAAI,CAACO,UAAU,CAAC;IAClCC,KAAK,EAAER,IAAI,CAACS,MAAM,EAAED,KAAK,IAAI,CAAC;IAC9BE,OAAO,EAAEV,IAAI,CAACS,MAAM,EAAEC,OAAO,IAAI;EACrC,CAAC;AACL,CAAC","ignoreList":[]}
|