@webiny/api-sync-system 6.3.0 → 6.4.0-beta.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/constants.js +2 -1
- package/constants.js.map +1 -1
- package/index.js +0 -2
- package/package.json +14 -14
- package/resolver/app/RecordHandler.js +83 -105
- package/resolver/app/RecordHandler.js.map +1 -1
- package/resolver/app/RecordsValidation.js +11 -14
- package/resolver/app/RecordsValidation.js.map +1 -1
- package/resolver/app/ResolverApplication.js +24 -31
- package/resolver/app/ResolverApplication.js.map +1 -1
- package/resolver/app/abstractions/RecordHandler.js +0 -3
- package/resolver/app/abstractions/RecordsValidation.js +0 -3
- package/resolver/app/abstractions/ResolverApplication.js +0 -3
- package/resolver/app/abstractions/ResolverRecord.js +0 -3
- package/resolver/app/bundler/BaseBundle.js +17 -16
- package/resolver/app/bundler/BaseBundle.js.map +1 -1
- package/resolver/app/bundler/Bundler.js +13 -18
- package/resolver/app/bundler/Bundler.js.map +1 -1
- package/resolver/app/bundler/Bundles.js +21 -26
- package/resolver/app/bundler/Bundles.js.map +1 -1
- package/resolver/app/bundler/CommandBundle.js +7 -16
- package/resolver/app/bundler/CommandBundle.js.map +1 -1
- package/resolver/app/bundler/TableBundle.js +6 -13
- package/resolver/app/bundler/TableBundle.js.map +1 -1
- package/resolver/app/bundler/types.js +0 -3
- package/resolver/app/commandHandler/DeleteCommandHandler.js +22 -29
- package/resolver/app/commandHandler/DeleteCommandHandler.js.map +1 -1
- package/resolver/app/commandHandler/PutCommandHandler.js +16 -22
- package/resolver/app/commandHandler/PutCommandHandler.js.map +1 -1
- package/resolver/app/commandHandler/delete.js +11 -12
- package/resolver/app/commandHandler/delete.js.map +1 -1
- package/resolver/app/commandHandler/put.js +11 -12
- package/resolver/app/commandHandler/put.js.map +1 -1
- package/resolver/app/data/SourceDataContainer.js +28 -30
- package/resolver/app/data/SourceDataContainer.js.map +1 -1
- package/resolver/app/data/types.js +0 -3
- package/resolver/app/fetcher/Fetcher.js +84 -109
- package/resolver/app/fetcher/Fetcher.js.map +1 -1
- package/resolver/app/fetcher/types.js +0 -3
- package/resolver/app/ingestor/Ingestor.js +27 -32
- package/resolver/app/ingestor/Ingestor.js.map +1 -1
- package/resolver/app/ingestor/IngestorResult.js +28 -32
- package/resolver/app/ingestor/IngestorResult.js.map +1 -1
- package/resolver/app/ingestor/types.js +0 -3
- package/resolver/app/storer/Storer.js +71 -85
- package/resolver/app/storer/Storer.js.map +1 -1
- package/resolver/app/storer/types.js +0 -3
- package/resolver/app/transform/TransformHandler.js +45 -56
- package/resolver/app/transform/TransformHandler.js.map +1 -1
- package/resolver/app/transform/middleware.js +13 -20
- package/resolver/app/transform/middleware.js.map +1 -1
- package/resolver/app/utils/Retry.js +21 -24
- package/resolver/app/utils/Retry.js.map +1 -1
- package/resolver/app/utils/sleep.js +4 -5
- package/resolver/app/utils/sleep.js.map +1 -1
- package/resolver/app/validation/body.js +26 -31
- package/resolver/app/validation/body.js.map +1 -1
- package/resolver/app/validation/createJsonTransform.js +12 -13
- package/resolver/app/validation/createJsonTransform.js.map +1 -1
- package/resolver/app/validation/detail.js +30 -35
- package/resolver/app/validation/detail.js.map +1 -1
- package/resolver/app/validation/event.js +17 -18
- package/resolver/app/validation/event.js.map +1 -1
- package/resolver/app/validation/numericString.js +8 -11
- package/resolver/app/validation/numericString.js.map +1 -1
- package/resolver/app/validation/system.js +8 -9
- package/resolver/app/validation/system.js.map +1 -1
- package/resolver/createEventHandlerPlugin.js +70 -99
- package/resolver/createEventHandlerPlugin.js.map +1 -1
- package/resolver/createResolverHandler.js +49 -57
- package/resolver/createResolverHandler.js.map +1 -1
- package/resolver/deployment/Deployment.js +28 -31
- package/resolver/deployment/Deployment.js.map +1 -1
- package/resolver/deployment/Deployments.js +20 -23
- package/resolver/deployment/Deployments.js.map +1 -1
- package/resolver/deployment/DeploymentsFetcher.js +75 -84
- package/resolver/deployment/DeploymentsFetcher.js.map +1 -1
- package/resolver/deployment/types.js +0 -3
- package/resolver/lambda/LambdaTrigger.js +24 -26
- package/resolver/lambda/LambdaTrigger.js.map +1 -1
- package/resolver/plugins/CommandHandlerPlugin.js +16 -15
- package/resolver/plugins/CommandHandlerPlugin.js.map +1 -1
- package/resolver/plugins/StorerAfterEachPlugin.js +20 -19
- package/resolver/plugins/StorerAfterEachPlugin.js.map +1 -1
- package/resolver/plugins/TransformRecordPlugin.js +19 -18
- package/resolver/plugins/TransformRecordPlugin.js.map +1 -1
- package/resolver/recordTypes/fileManager/CopyFile.js +44 -67
- package/resolver/recordTypes/fileManager/CopyFile.js.map +1 -1
- package/resolver/recordTypes/fileManager/DeleteFile.js +40 -58
- package/resolver/recordTypes/fileManager/DeleteFile.js.map +1 -1
- package/resolver/recordTypes/fileManager/fileManager.js +5 -3
- package/resolver/recordTypes/fileManager/fileManager.js.map +1 -1
- package/resolver/recordTypes/fileManager/fileManagerOnDelete.js +24 -35
- package/resolver/recordTypes/fileManager/fileManagerOnDelete.js.map +1 -1
- package/resolver/recordTypes/fileManager/fileManagerOnPut.js +24 -35
- package/resolver/recordTypes/fileManager/fileManagerOnPut.js.map +1 -1
- package/resolver/recordTypes/fileManager/shouldBeHandled.js +10 -27
- package/resolver/recordTypes/fileManager/shouldBeHandled.js.map +1 -1
- package/resolver/recordTypes/fileManager/types.js +0 -3
- package/resolver/recordTypes/users/CopyUser.js +44 -54
- package/resolver/recordTypes/users/CopyUser.js.map +1 -1
- package/resolver/recordTypes/users/DeleteUser.js +40 -51
- package/resolver/recordTypes/users/DeleteUser.js.map +1 -1
- package/resolver/recordTypes/users/shouldBeHandled.js +10 -26
- package/resolver/recordTypes/users/shouldBeHandled.js.map +1 -1
- package/resolver/recordTypes/users/types.js +0 -3
- package/resolver/recordTypes/users/users.js +5 -3
- package/resolver/recordTypes/users/users.js.map +1 -1
- package/resolver/recordTypes/users/usersOnDelete.js +23 -34
- package/resolver/recordTypes/users/usersOnDelete.js.map +1 -1
- package/resolver/recordTypes/users/usersOnPut.js +24 -35
- package/resolver/recordTypes/users/usersOnPut.js.map +1 -1
- package/sync/FilterOutRecord.js +9 -17
- package/sync/FilterOutRecord.js.map +1 -1
- package/sync/attachToDynamoDbDocument.js +46 -65
- package/sync/attachToDynamoDbDocument.js.map +1 -1
- package/sync/createHandler.js +31 -40
- package/sync/createHandler.js.map +1 -1
- package/sync/createSendDataToEventBridgeOnRequestEnd.js +32 -37
- package/sync/createSendDataToEventBridgeOnRequestEnd.js.map +1 -1
- package/sync/createSyncSystem.js +24 -26
- package/sync/createSyncSystem.js.map +1 -1
- package/sync/filter/createDefaultFilterOutRecordPlugins.js +37 -76
- package/sync/filter/createDefaultFilterOutRecordPlugins.js.map +1 -1
- package/sync/handler/Handler.js +64 -76
- package/sync/handler/Handler.js.map +1 -1
- package/sync/handler/HandlerConverter.js +21 -29
- package/sync/handler/HandlerConverter.js.map +1 -1
- package/sync/handler/converter/BatchGetCommandConverter.js +12 -11
- package/sync/handler/converter/BatchGetCommandConverter.js.map +1 -1
- package/sync/handler/converter/BatchWriteCommandConverter.js +12 -11
- package/sync/handler/converter/BatchWriteCommandConverter.js.map +1 -1
- package/sync/handler/converter/DeleteCommandConverter.js +12 -11
- package/sync/handler/converter/DeleteCommandConverter.js.map +1 -1
- package/sync/handler/converter/GetCommandConverter.js +12 -11
- package/sync/handler/converter/GetCommandConverter.js.map +1 -1
- package/sync/handler/converter/PutCommandConverter.js +12 -11
- package/sync/handler/converter/PutCommandConverter.js.map +1 -1
- package/sync/handler/converter/QueryCommandConverter.js +12 -11
- package/sync/handler/converter/QueryCommandConverter.js.map +1 -1
- package/sync/handler/converter/ScanCommandConverter.js +12 -11
- package/sync/handler/converter/ScanCommandConverter.js.map +1 -1
- package/sync/handler/converter/UpdateCommandConverter.js +12 -11
- package/sync/handler/converter/UpdateCommandConverter.js.map +1 -1
- package/sync/handler/converter/commands/BatchWriteCommandValue.js +34 -37
- package/sync/handler/converter/commands/BatchWriteCommandValue.js.map +1 -1
- package/sync/handler/converter/commands/DeleteCommandValue.js +19 -16
- package/sync/handler/converter/commands/DeleteCommandValue.js.map +1 -1
- package/sync/handler/converter/commands/NullCommandValue.js +8 -8
- package/sync/handler/converter/commands/NullCommandValue.js.map +1 -1
- package/sync/handler/converter/commands/PutCommandValue.js +19 -16
- package/sync/handler/converter/commands/PutCommandValue.js.map +1 -1
- package/sync/handler/converter/commands/UpdateCommandValue.js +19 -16
- package/sync/handler/converter/commands/UpdateCommandValue.js.map +1 -1
- package/sync/handler/types.js +0 -3
- package/sync/plugins/FilterOutRecordPlugin.js +17 -19
- package/sync/plugins/FilterOutRecordPlugin.js.map +1 -1
- package/sync/requestPlugin.js +33 -48
- package/sync/requestPlugin.js.map +1 -1
- package/sync/types.js +0 -3
- package/sync/utils/getTableType.js +10 -9
- package/sync/utils/getTableType.js.map +1 -1
- package/sync/utils/manifest.js +28 -35
- package/sync/utils/manifest.js.map +1 -1
- package/sync/utils/validateSystemInput.js +21 -29
- package/sync/utils/validateSystemInput.js.map +1 -1
- package/types.js +6 -5
- package/types.js.map +1 -1
- package/utils/createSystemName.js +5 -3
- package/utils/createSystemName.js.map +1 -1
- package/worker/actions/copyFile/CopyFile.js +183 -258
- package/worker/actions/copyFile/CopyFile.js.map +1 -1
- package/worker/actions/copyFile/copyFileAction.js +26 -34
- package/worker/actions/copyFile/copyFileAction.js.map +1 -1
- package/worker/actions/copyFile/copyFileSchema.js +13 -14
- package/worker/actions/copyFile/copyFileSchema.js.map +1 -1
- package/worker/actions/copyFile/types.js +0 -3
- package/worker/actions/createUser/CreateUser.js +51 -74
- package/worker/actions/createUser/CreateUser.js.map +1 -1
- package/worker/actions/createUser/createUserAction.js +24 -28
- package/worker/actions/createUser/createUserAction.js.map +1 -1
- package/worker/actions/createUser/createUserSchema.js +13 -14
- package/worker/actions/createUser/createUserSchema.js.map +1 -1
- package/worker/actions/createUser/types.js +0 -3
- package/worker/actions/deleteFile/DeleteFile.js +52 -67
- package/worker/actions/deleteFile/DeleteFile.js.map +1 -1
- package/worker/actions/deleteFile/deleteFileAction.js +21 -29
- package/worker/actions/deleteFile/deleteFileAction.js.map +1 -1
- package/worker/actions/deleteFile/deleteFileSchema.js +13 -14
- package/worker/actions/deleteFile/deleteFileSchema.js.map +1 -1
- package/worker/actions/deleteFile/types.js +0 -3
- package/worker/actions/deleteUser/DeleteUser.js +38 -52
- package/worker/actions/deleteUser/DeleteUser.js.map +1 -1
- package/worker/actions/deleteUser/deleteUserAction.js +22 -26
- package/worker/actions/deleteUser/deleteUserAction.js.map +1 -1
- package/worker/actions/deleteUser/deleteUserSchema.js +12 -13
- package/worker/actions/deleteUser/deleteUserSchema.js.map +1 -1
- package/worker/actions/deleteUser/types.js +0 -3
- package/worker/actions/logValidationError.js +5 -6
- package/worker/actions/logValidationError.js.map +1 -1
- package/worker/actions/removeCognitoUserAttributes.js +9 -15
- package/worker/actions/removeCognitoUserAttributes.js.map +1 -1
- package/worker/actions/updateUser/UpdateUser.js +48 -65
- package/worker/actions/updateUser/UpdateUser.js.map +1 -1
- package/worker/actions/updateUser/types.js +0 -3
- package/worker/actions/updateUser/updateUserAction.js +24 -28
- package/worker/actions/updateUser/updateUserAction.js.map +1 -1
- package/worker/actions/updateUser/updateUserSchema.js +13 -14
- package/worker/actions/updateUser/updateUserSchema.js.map +1 -1
- package/worker/createWorkerHandler.js +24 -30
- package/worker/createWorkerHandler.js.map +1 -1
- package/worker/handler/WorkerActionHandler.js +19 -21
- package/worker/handler/WorkerActionHandler.js.map +1 -1
- package/worker/handler/eventHandler.js +14 -16
- package/worker/handler/eventHandler.js.map +1 -1
- package/worker/plugins/WorkerActionPlugin.js +17 -16
- package/worker/plugins/WorkerActionPlugin.js.map +1 -1
- package/worker/types.js +0 -3
- package/index.js.map +0 -1
- package/resolver/app/abstractions/RecordHandler.js.map +0 -1
- package/resolver/app/abstractions/RecordsValidation.js.map +0 -1
- package/resolver/app/abstractions/ResolverApplication.js.map +0 -1
- package/resolver/app/abstractions/ResolverRecord.js.map +0 -1
- package/resolver/app/bundler/types.js.map +0 -1
- package/resolver/app/data/types.js.map +0 -1
- package/resolver/app/fetcher/types.js.map +0 -1
- package/resolver/app/ingestor/types.js.map +0 -1
- package/resolver/app/storer/types.js.map +0 -1
- package/resolver/deployment/types.js.map +0 -1
- package/resolver/recordTypes/fileManager/types.js.map +0 -1
- package/resolver/recordTypes/users/types.js.map +0 -1
- package/sync/handler/types.js.map +0 -1
- package/sync/types.js.map +0 -1
- package/worker/actions/copyFile/types.js.map +0 -1
- package/worker/actions/createUser/types.js.map +0 -1
- package/worker/actions/deleteFile/types.js.map +0 -1
- package/worker/actions/deleteUser/types.js.map +0 -1
- package/worker/actions/updateUser/types.js.map +0 -1
- package/worker/types.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/fileManager/CopyFile.js","sources":["../../../../src/resolver/recordTypes/fileManager/CopyFile.ts"],"sourcesContent":["import type { HeadObjectCommandInput, S3Client } from \"@webiny/aws-sdk/client-s3/index.js\";\nimport { HeadObjectCommand } from \"@webiny/aws-sdk/client-s3/index.js\";\nimport type {\n ICopyFile,\n ICopyFileHandleParams,\n ICreateS3ClientCb,\n IGetLambdaTriggerCb\n} from \"./types.js\";\nimport type { InvokeCommandOutput } from \"@webiny/aws-sdk/client-lambda/index.js\";\nimport type { ICopyFileLambdaPayload } from \"~/types.js\";\n\ninterface IExistsParams {\n client: Pick<S3Client, \"send\">;\n bucket: string;\n key: string;\n}\n\nexport interface ICopyFileParams {\n createS3Client: ICreateS3ClientCb;\n getLambdaTrigger: IGetLambdaTriggerCb<ICopyFileLambdaPayload>;\n}\n\nexport class CopyFile implements ICopyFile {\n private readonly createS3Client: ICreateS3ClientCb;\n private readonly getLambdaTrigger: IGetLambdaTriggerCb<ICopyFileLambdaPayload>;\n\n public constructor(params: ICopyFileParams) {\n this.createS3Client = params.createS3Client;\n this.getLambdaTrigger = params.getLambdaTrigger;\n }\n\n public async handle(params: ICopyFileHandleParams): Promise<InvokeCommandOutput | null> {\n const { key, source, target } = params;\n /**\n * We need to check on the target if the file already exists.\n */\n const targetClient = this.createS3Client({\n region: target.region\n });\n\n const exists = await this.exists({\n client: targetClient,\n bucket: target.services.s3Id,\n key\n });\n\n if (exists) {\n // If the file already exists, we can skip copying it.\n return null;\n }\n\n /**\n * Then we can safely trigger a Lambda function that will copy the file.\n */\n\n return await this.getLambdaTrigger().handle({\n invocationType: \"Event\",\n payload: {\n action: \"copyFile\",\n key,\n source: {\n region: source.region,\n bucket: source.services.s3Id\n },\n target: {\n region: target.region,\n bucket: target.services.s3Id\n }\n }\n });\n }\n\n private async exists(params: IExistsParams): Promise<boolean> {\n const { client, bucket, key } = params;\n const input: HeadObjectCommandInput = {\n Bucket: bucket,\n Key: key\n };\n const cmd = new HeadObjectCommand(input);\n try {\n const result = await client.send(cmd);\n return result.$metadata?.httpStatusCode === 200 && !!result.ETag;\n } catch {\n /**\n * TODO What happens if this fails? To we continue with the copy or end the process?\n * Do we log the error?\n * For now, we will assume that file does not exist.\n */\n return false;\n }\n }\n}\n"],"names":["CopyFile","params","key","source","target","targetClient","exists","client","bucket","input","cmd","HeadObjectCommand","result"],"mappings":";AAsBO,MAAMA;IAIT,YAAmBC,MAAuB,CAAE;QACxC,IAAI,CAAC,cAAc,GAAGA,OAAO,cAAc;QAC3C,IAAI,CAAC,gBAAgB,GAAGA,OAAO,gBAAgB;IACnD;IAEA,MAAa,OAAOA,MAA6B,EAAuC;QACpF,MAAM,EAAEC,GAAG,EAAEC,MAAM,EAAEC,MAAM,EAAE,GAAGH;QAIhC,MAAMI,eAAe,IAAI,CAAC,cAAc,CAAC;YACrC,QAAQD,OAAO,MAAM;QACzB;QAEA,MAAME,SAAS,MAAM,IAAI,CAAC,MAAM,CAAC;YAC7B,QAAQD;YACR,QAAQD,OAAO,QAAQ,CAAC,IAAI;YAC5BF;QACJ;QAEA,IAAII,QAEA,OAAO;QAOX,OAAO,MAAM,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC;YACxC,gBAAgB;YAChB,SAAS;gBACL,QAAQ;gBACRJ;gBACA,QAAQ;oBACJ,QAAQC,OAAO,MAAM;oBACrB,QAAQA,OAAO,QAAQ,CAAC,IAAI;gBAChC;gBACA,QAAQ;oBACJ,QAAQC,OAAO,MAAM;oBACrB,QAAQA,OAAO,QAAQ,CAAC,IAAI;gBAChC;YACJ;QACJ;IACJ;IAEA,MAAc,OAAOH,MAAqB,EAAoB;QAC1D,MAAM,EAAEM,MAAM,EAAEC,MAAM,EAAEN,GAAG,EAAE,GAAGD;QAChC,MAAMQ,QAAgC;YAClC,QAAQD;YACR,KAAKN;QACT;QACA,MAAMQ,MAAM,IAAIC,kBAAkBF;QAClC,IAAI;YACA,MAAMG,SAAS,MAAML,OAAO,IAAI,CAACG;YACjC,OAAOE,OAAO,SAAS,EAAE,mBAAmB,OAAO,CAAC,CAACA,OAAO,IAAI;QACpE,EAAE,OAAM;YAMJ,OAAO;QACX;IACJ;AACJ"}
|
|
@@ -1,65 +1,47 @@
|
|
|
1
1
|
import { HeadObjectCommand } from "@webiny/aws-sdk/client-s3/index.js";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
}
|
|
7
|
-
async handle(params) {
|
|
8
|
-
const {
|
|
9
|
-
key,
|
|
10
|
-
target
|
|
11
|
-
} = params;
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* We need to check on the target if the file already exists.
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
const targetClient = this.createS3Client({
|
|
18
|
-
region: target.region
|
|
19
|
-
});
|
|
20
|
-
const exists = await this.exists({
|
|
21
|
-
client: targetClient,
|
|
22
|
-
bucket: target.services.s3Id,
|
|
23
|
-
key
|
|
24
|
-
});
|
|
25
|
-
if (!exists) {
|
|
26
|
-
// If the file does not exist, we can skip the deletion.
|
|
27
|
-
return null;
|
|
2
|
+
class DeleteFile {
|
|
3
|
+
constructor(params){
|
|
4
|
+
this.createS3Client = params.createS3Client;
|
|
5
|
+
this.getLambdaTrigger = params.getLambdaTrigger;
|
|
28
6
|
}
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
7
|
+
async handle(params) {
|
|
8
|
+
const { key, target } = params;
|
|
9
|
+
const targetClient = this.createS3Client({
|
|
10
|
+
region: target.region
|
|
11
|
+
});
|
|
12
|
+
const exists = await this.exists({
|
|
13
|
+
client: targetClient,
|
|
14
|
+
bucket: target.services.s3Id,
|
|
15
|
+
key
|
|
16
|
+
});
|
|
17
|
+
if (!exists) return null;
|
|
18
|
+
return await this.getLambdaTrigger().handle({
|
|
19
|
+
invocationType: "Event",
|
|
20
|
+
payload: {
|
|
21
|
+
action: "deleteFile",
|
|
22
|
+
key,
|
|
23
|
+
target: {
|
|
24
|
+
region: target.region,
|
|
25
|
+
bucket: target.services.s3Id
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
async exists(params) {
|
|
31
|
+
const { client, bucket, key } = params;
|
|
32
|
+
const input = {
|
|
33
|
+
Bucket: bucket,
|
|
34
|
+
Key: key
|
|
35
|
+
};
|
|
36
|
+
const cmd = new HeadObjectCommand(input);
|
|
37
|
+
try {
|
|
38
|
+
const result = await client.send(cmd);
|
|
39
|
+
return result.$metadata?.httpStatusCode === 200;
|
|
40
|
+
} catch {
|
|
41
|
+
return false;
|
|
41
42
|
}
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
async exists(params) {
|
|
46
|
-
const {
|
|
47
|
-
client,
|
|
48
|
-
bucket,
|
|
49
|
-
key
|
|
50
|
-
} = params;
|
|
51
|
-
const input = {
|
|
52
|
-
Bucket: bucket,
|
|
53
|
-
Key: key
|
|
54
|
-
};
|
|
55
|
-
const cmd = new HeadObjectCommand(input);
|
|
56
|
-
try {
|
|
57
|
-
const result = await client.send(cmd);
|
|
58
|
-
return result.$metadata?.httpStatusCode === 200;
|
|
59
|
-
} catch {
|
|
60
|
-
return false;
|
|
61
43
|
}
|
|
62
|
-
}
|
|
63
44
|
}
|
|
45
|
+
export { DeleteFile };
|
|
64
46
|
|
|
65
47
|
//# sourceMappingURL=DeleteFile.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/fileManager/DeleteFile.js","sources":["../../../../src/resolver/recordTypes/fileManager/DeleteFile.ts"],"sourcesContent":["import type {\n ICreateS3ClientCb,\n IDeleteFile,\n IDeleteFileHandleParams,\n IGetLambdaTriggerCb\n} from \"~/resolver/recordTypes/fileManager/types.js\";\nimport type { HeadObjectCommandInput, S3Client } from \"@webiny/aws-sdk/client-s3/index.js\";\nimport { HeadObjectCommand } from \"@webiny/aws-sdk/client-s3/index.js\";\nimport type { InvokeCommandOutput } from \"@webiny/aws-sdk/client-lambda/index.js\";\nimport type { IDeleteFileLambdaPayload } from \"~/types.js\";\n\ninterface IExistsParams {\n client: Pick<S3Client, \"send\">;\n bucket: string;\n key: string;\n}\n\nexport interface IDeleteFileParams {\n createS3Client: ICreateS3ClientCb;\n getLambdaTrigger: IGetLambdaTriggerCb<IDeleteFileLambdaPayload>;\n}\n\nexport class DeleteFile implements IDeleteFile {\n private readonly createS3Client: ICreateS3ClientCb;\n private readonly getLambdaTrigger: IGetLambdaTriggerCb<IDeleteFileLambdaPayload>;\n\n public constructor(params: IDeleteFileParams) {\n this.createS3Client = params.createS3Client;\n this.getLambdaTrigger = params.getLambdaTrigger;\n }\n\n public async handle(params: IDeleteFileHandleParams): Promise<InvokeCommandOutput | null> {\n const { key, target } = params;\n\n /**\n * We need to check on the target if the file already exists.\n */\n\n const targetClient = this.createS3Client({\n region: target.region\n });\n\n const exists = await this.exists({\n client: targetClient,\n bucket: target.services.s3Id,\n key\n });\n if (!exists) {\n // If the file does not exist, we can skip the deletion.\n return null;\n }\n\n /**\n * Then we can safely trigger a Lambda function that will delete the file.\n */\n return await this.getLambdaTrigger().handle({\n invocationType: \"Event\",\n payload: {\n action: \"deleteFile\",\n key,\n target: {\n region: target.region,\n bucket: target.services.s3Id\n }\n }\n });\n }\n\n private async exists(params: IExistsParams): Promise<boolean> {\n const { client, bucket, key } = params;\n const input: HeadObjectCommandInput = {\n Bucket: bucket,\n Key: key\n };\n const cmd = new HeadObjectCommand(input);\n try {\n const result = await client.send(cmd);\n return result.$metadata?.httpStatusCode === 200;\n } catch {\n return false;\n }\n }\n}\n"],"names":["DeleteFile","params","key","target","targetClient","exists","client","bucket","input","cmd","HeadObjectCommand","result"],"mappings":";AAsBO,MAAMA;IAIT,YAAmBC,MAAyB,CAAE;QAC1C,IAAI,CAAC,cAAc,GAAGA,OAAO,cAAc;QAC3C,IAAI,CAAC,gBAAgB,GAAGA,OAAO,gBAAgB;IACnD;IAEA,MAAa,OAAOA,MAA+B,EAAuC;QACtF,MAAM,EAAEC,GAAG,EAAEC,MAAM,EAAE,GAAGF;QAMxB,MAAMG,eAAe,IAAI,CAAC,cAAc,CAAC;YACrC,QAAQD,OAAO,MAAM;QACzB;QAEA,MAAME,SAAS,MAAM,IAAI,CAAC,MAAM,CAAC;YAC7B,QAAQD;YACR,QAAQD,OAAO,QAAQ,CAAC,IAAI;YAC5BD;QACJ;QACA,IAAI,CAACG,QAED,OAAO;QAMX,OAAO,MAAM,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC;YACxC,gBAAgB;YAChB,SAAS;gBACL,QAAQ;gBACRH;gBACA,QAAQ;oBACJ,QAAQC,OAAO,MAAM;oBACrB,QAAQA,OAAO,QAAQ,CAAC,IAAI;gBAChC;YACJ;QACJ;IACJ;IAEA,MAAc,OAAOF,MAAqB,EAAoB;QAC1D,MAAM,EAAEK,MAAM,EAAEC,MAAM,EAAEL,GAAG,EAAE,GAAGD;QAChC,MAAMO,QAAgC;YAClC,QAAQD;YACR,KAAKL;QACT;QACA,MAAMO,MAAM,IAAIC,kBAAkBF;QAClC,IAAI;YACA,MAAMG,SAAS,MAAML,OAAO,IAAI,CAACG;YACjC,OAAOE,OAAO,SAAS,EAAE,mBAAmB;QAChD,EAAE,OAAM;YACJ,OAAO;QACX;IACJ;AACJ"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { createFileManagerOnPutPlugin } from "./fileManagerOnPut.js";
|
|
2
2
|
import { createFileManagerOnDeletePlugin } from "./fileManagerOnDelete.js";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
const createFileManagerPlugins = (params)=>[
|
|
4
|
+
createFileManagerOnPutPlugin(params),
|
|
5
|
+
createFileManagerOnDeletePlugin(params)
|
|
6
|
+
];
|
|
7
|
+
export { createFileManagerPlugins };
|
|
6
8
|
|
|
7
9
|
//# sourceMappingURL=fileManager.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/fileManager/fileManager.js","sources":["../../../../src/resolver/recordTypes/fileManager/fileManager.ts"],"sourcesContent":["import { createFileManagerOnPutPlugin } from \"./fileManagerOnPut.js\";\nimport { createFileManagerOnDeletePlugin } from \"./fileManagerOnDelete.js\";\nimport type { ICopyFile, IDeleteFile } from \"~/resolver/recordTypes/fileManager/types.js\";\n\nexport interface ICreateFileManagerPluginsParams {\n copyFile: ICopyFile;\n deleteFile: IDeleteFile;\n}\n\nexport const createFileManagerPlugins = (params: ICreateFileManagerPluginsParams) => {\n return [createFileManagerOnPutPlugin(params), createFileManagerOnDeletePlugin(params)];\n};\n"],"names":["createFileManagerPlugins","params","createFileManagerOnPutPlugin","createFileManagerOnDeletePlugin"],"mappings":";;AASO,MAAMA,2BAA2B,CAACC,SAC9B;QAACC,6BAA6BD;QAASE,gCAAgCF;KAAQ"}
|
|
@@ -1,41 +1,30 @@
|
|
|
1
1
|
import { createStorerAfterEachPluginWithName } from "../../plugins/StorerAfterEachPlugin.js";
|
|
2
2
|
import { shouldBeHandled } from "./shouldBeHandled.js";
|
|
3
3
|
import { convertException } from "@webiny/utils";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
try {
|
|
28
|
-
await deleteFile.handle({
|
|
29
|
-
target: params.target,
|
|
30
|
-
source: params.source,
|
|
31
|
-
key
|
|
32
|
-
});
|
|
33
|
-
} catch (ex) {
|
|
34
|
-
console.error("Error while handling file manager onDelete plugin.");
|
|
35
|
-
console.log(convertException(ex));
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
});
|
|
4
|
+
const createFileManagerOnDeletePlugin = (params)=>{
|
|
5
|
+
const { deleteFile } = params;
|
|
6
|
+
return createStorerAfterEachPluginWithName("fileManager.onDelete", {
|
|
7
|
+
canHandle: (params)=>{
|
|
8
|
+
const { command } = params;
|
|
9
|
+
if ("delete" !== command) return false;
|
|
10
|
+
return shouldBeHandled(params);
|
|
11
|
+
},
|
|
12
|
+
handle: async (params)=>{
|
|
13
|
+
const { item } = params;
|
|
14
|
+
const key = item.values["text@key"] || item.values["key"];
|
|
15
|
+
try {
|
|
16
|
+
await deleteFile.handle({
|
|
17
|
+
target: params.target,
|
|
18
|
+
source: params.source,
|
|
19
|
+
key
|
|
20
|
+
});
|
|
21
|
+
} catch (ex) {
|
|
22
|
+
console.error("Error while handling file manager onDelete plugin.");
|
|
23
|
+
console.log(convertException(ex));
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
});
|
|
39
27
|
};
|
|
28
|
+
export { createFileManagerOnDeletePlugin };
|
|
40
29
|
|
|
41
30
|
//# sourceMappingURL=fileManagerOnDelete.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/fileManager/fileManagerOnDelete.js","sources":["../../../../src/resolver/recordTypes/fileManager/fileManagerOnDelete.ts"],"sourcesContent":["import { createStorerAfterEachPluginWithName } from \"~/resolver/plugins/StorerAfterEachPlugin.js\";\nimport { shouldBeHandled } from \"./shouldBeHandled.js\";\nimport { convertException } from \"@webiny/utils\";\nimport type { IDeleteFile } from \"./types.js\";\n\nexport interface ICreateFileManagerOnDeletePluginParams {\n deleteFile: IDeleteFile;\n}\n\nexport const createFileManagerOnDeletePlugin = (params: ICreateFileManagerOnDeletePluginParams) => {\n const { deleteFile } = params;\n\n return createStorerAfterEachPluginWithName(\"fileManager.onDelete\", {\n canHandle: params => {\n const { command } = params;\n if (command !== \"delete\") {\n return false;\n }\n return shouldBeHandled(params);\n },\n handle: async params => {\n const { item } = params;\n /**\n * We are 100% positive that the key exists here because canHandle would not allow for handle to be called.\n */\n // @ts-expect-error\n const key = (item.values[\"text@key\"] || item.values[\"key\"]) as string;\n try {\n await deleteFile.handle({\n target: params.target,\n source: params.source,\n key\n });\n } catch (ex) {\n console.error(\"Error while handling file manager onDelete plugin.\");\n console.log(convertException(ex));\n }\n }\n });\n};\n"],"names":["createFileManagerOnDeletePlugin","params","deleteFile","createStorerAfterEachPluginWithName","command","shouldBeHandled","item","key","ex","console","convertException"],"mappings":";;;AASO,MAAMA,kCAAkC,CAACC;IAC5C,MAAM,EAAEC,UAAU,EAAE,GAAGD;IAEvB,OAAOE,oCAAoC,wBAAwB;QAC/D,WAAWF,CAAAA;YACP,MAAM,EAAEG,OAAO,EAAE,GAAGH;YACpB,IAAIG,AAAY,aAAZA,SACA,OAAO;YAEX,OAAOC,gBAAgBJ;QAC3B;QACA,QAAQ,OAAMA;YACV,MAAM,EAAEK,IAAI,EAAE,GAAGL;YAKjB,MAAMM,MAAOD,KAAK,MAAM,CAAC,WAAW,IAAIA,KAAK,MAAM,CAAC,MAAM;YAC1D,IAAI;gBACA,MAAMJ,WAAW,MAAM,CAAC;oBACpB,QAAQD,OAAO,MAAM;oBACrB,QAAQA,OAAO,MAAM;oBACrBM;gBACJ;YACJ,EAAE,OAAOC,IAAI;gBACTC,QAAQ,KAAK,CAAC;gBACdA,QAAQ,GAAG,CAACC,iBAAiBF;YACjC;QACJ;IACJ;AACJ"}
|
|
@@ -1,41 +1,30 @@
|
|
|
1
1
|
import { createStorerAfterEachPluginWithName } from "../../plugins/StorerAfterEachPlugin.js";
|
|
2
2
|
import { shouldBeHandled } from "./shouldBeHandled.js";
|
|
3
3
|
import { convertException } from "@webiny/utils";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
try {
|
|
28
|
-
await copyFile.handle({
|
|
29
|
-
target: params.target,
|
|
30
|
-
source: params.source,
|
|
31
|
-
key
|
|
32
|
-
});
|
|
33
|
-
} catch (ex) {
|
|
34
|
-
console.error("Error while handling file manager onPut plugin.");
|
|
35
|
-
console.log(convertException(ex));
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
});
|
|
4
|
+
const createFileManagerOnPutPlugin = (params)=>{
|
|
5
|
+
const { copyFile } = params;
|
|
6
|
+
return createStorerAfterEachPluginWithName("fileManager.onPut", {
|
|
7
|
+
canHandle: (params)=>{
|
|
8
|
+
const { command } = params;
|
|
9
|
+
if ("put" !== command) return false;
|
|
10
|
+
return shouldBeHandled(params);
|
|
11
|
+
},
|
|
12
|
+
handle: async (params)=>{
|
|
13
|
+
const { item } = params;
|
|
14
|
+
const key = item.values["text@key"] || item.values["key"];
|
|
15
|
+
try {
|
|
16
|
+
await copyFile.handle({
|
|
17
|
+
target: params.target,
|
|
18
|
+
source: params.source,
|
|
19
|
+
key
|
|
20
|
+
});
|
|
21
|
+
} catch (ex) {
|
|
22
|
+
console.error("Error while handling file manager onPut plugin.");
|
|
23
|
+
console.log(convertException(ex));
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
});
|
|
39
27
|
};
|
|
28
|
+
export { createFileManagerOnPutPlugin };
|
|
40
29
|
|
|
41
30
|
//# sourceMappingURL=fileManagerOnPut.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/fileManager/fileManagerOnPut.js","sources":["../../../../src/resolver/recordTypes/fileManager/fileManagerOnPut.ts"],"sourcesContent":["import { createStorerAfterEachPluginWithName } from \"~/resolver/plugins/StorerAfterEachPlugin.js\";\nimport { shouldBeHandled } from \"./shouldBeHandled.js\";\nimport { convertException } from \"@webiny/utils\";\nimport type { ICopyFile } from \"./types.js\";\n\nexport interface ICreateFileManagerOnPutPluginParams {\n copyFile: ICopyFile;\n}\n\nexport const createFileManagerOnPutPlugin = (params: ICreateFileManagerOnPutPluginParams) => {\n const { copyFile } = params;\n\n return createStorerAfterEachPluginWithName(\"fileManager.onPut\", {\n canHandle: params => {\n const { command } = params;\n if (command !== \"put\") {\n return false;\n }\n return shouldBeHandled(params);\n },\n handle: async params => {\n const { item } = params;\n /**\n * We are 100% positive that the key exists here because canHandle would not allow for handle to be called.\n */\n // @ts-expect-error\n const key = (item.values[\"text@key\"] || item.values[\"key\"]) as string;\n try {\n await copyFile.handle({\n target: params.target,\n source: params.source,\n key\n });\n } catch (ex) {\n console.error(\"Error while handling file manager onPut plugin.\");\n console.log(convertException(ex));\n }\n }\n });\n};\n"],"names":["createFileManagerOnPutPlugin","params","copyFile","createStorerAfterEachPluginWithName","command","shouldBeHandled","item","key","ex","console","convertException"],"mappings":";;;AASO,MAAMA,+BAA+B,CAACC;IACzC,MAAM,EAAEC,QAAQ,EAAE,GAAGD;IAErB,OAAOE,oCAAoC,qBAAqB;QAC5D,WAAWF,CAAAA;YACP,MAAM,EAAEG,OAAO,EAAE,GAAGH;YACpB,IAAIG,AAAY,UAAZA,SACA,OAAO;YAEX,OAAOC,gBAAgBJ;QAC3B;QACA,QAAQ,OAAMA;YACV,MAAM,EAAEK,IAAI,EAAE,GAAGL;YAKjB,MAAMM,MAAOD,KAAK,MAAM,CAAC,WAAW,IAAIA,KAAK,MAAM,CAAC,MAAM;YAC1D,IAAI;gBACA,MAAMJ,SAAS,MAAM,CAAC;oBAClB,QAAQD,OAAO,MAAM;oBACrB,QAAQA,OAAO,MAAM;oBACrBM;gBACJ;YACJ,EAAE,OAAOC,IAAI;gBACTC,QAAQ,KAAK,CAAC;gBACdA,QAAQ,GAAG,CAACC,iBAAiBF;YACjC;QACJ;IACJ;AACJ"}
|
|
@@ -1,30 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return
|
|
10
|
-
}
|
|
11
|
-
// TODO use constant from fileManager
|
|
12
|
-
else if (item.modelId !== "fmFile") {
|
|
13
|
-
return false;
|
|
14
|
-
} else if (!item.values) {
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
// @ts-expect-error
|
|
19
|
-
const key = item.values["text@key"] || item.values["key"];
|
|
20
|
-
if (!key) {
|
|
21
|
-
return false;
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* We can check length for being more than 2 characters,
|
|
25
|
-
* because we know that the key is a string.
|
|
26
|
-
*/
|
|
27
|
-
return typeof key === "string" && key.length > 2;
|
|
1
|
+
const shouldBeHandled = (params)=>{
|
|
2
|
+
const { item, table } = params;
|
|
3
|
+
if ("regular" !== table.type) return false;
|
|
4
|
+
if ("L" !== item.SK) return false;
|
|
5
|
+
if ("fmFile" !== item.modelId) return false;
|
|
6
|
+
if (!item.values) return false;
|
|
7
|
+
const key = item.values["text@key"] || item.values["key"];
|
|
8
|
+
if (!key) return false;
|
|
9
|
+
return "string" == typeof key && key.length > 2;
|
|
28
10
|
};
|
|
11
|
+
export { shouldBeHandled };
|
|
29
12
|
|
|
30
13
|
//# sourceMappingURL=shouldBeHandled.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/fileManager/shouldBeHandled.js","sources":["../../../../src/resolver/recordTypes/fileManager/shouldBeHandled.ts"],"sourcesContent":["import type { IStorerAfterEachPluginCanHandleParams } from \"~/resolver/plugins/StorerAfterEachPlugin.js\";\n\nexport const shouldBeHandled = (params: IStorerAfterEachPluginCanHandleParams): boolean => {\n const { item, table } = params;\n if (table.type !== \"regular\") {\n return false;\n } else if (item.SK !== \"L\") {\n return false;\n }\n // TODO use constant from fileManager\n else if (item.modelId !== \"fmFile\") {\n return false;\n } else if (!item.values) {\n return false;\n }\n\n // @ts-expect-error\n const key = item.values[\"text@key\"] || item.values[\"key\"];\n if (!key) {\n return false;\n }\n /**\n * We can check length for being more than 2 characters,\n * because we know that the key is a string.\n */\n return typeof key === \"string\" && key.length > 2;\n};\n"],"names":["shouldBeHandled","params","item","table","key"],"mappings":"AAEO,MAAMA,kBAAkB,CAACC;IAC5B,MAAM,EAAEC,IAAI,EAAEC,KAAK,EAAE,GAAGF;IACxB,IAAIE,AAAe,cAAfA,MAAM,IAAI,EACV,OAAO;IACJ,IAAID,AAAY,QAAZA,KAAK,EAAE,EACd,OAAO;IAGN,IAAIA,AAAiB,aAAjBA,KAAK,OAAO,EACjB,OAAO;IACJ,IAAI,CAACA,KAAK,MAAM,EACnB,OAAO;IAIX,MAAME,MAAMF,KAAK,MAAM,CAAC,WAAW,IAAIA,KAAK,MAAM,CAAC,MAAM;IACzD,IAAI,CAACE,KACD,OAAO;IAMX,OAAO,AAAe,YAAf,OAAOA,OAAoBA,IAAI,MAAM,GAAG;AACnD"}
|
|
@@ -1,60 +1,50 @@
|
|
|
1
1
|
import { AdminGetUserCommand } from "@webiny/aws-sdk/client-cognito-identity-provider/index.js";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
2
|
+
class CopyUser {
|
|
3
|
+
constructor(params){
|
|
4
|
+
this.createCognitoIdentityProviderClient = params.createCognitoIdentityProviderClient;
|
|
5
|
+
this.getLambdaTrigger = params.getLambdaTrigger;
|
|
6
|
+
}
|
|
7
|
+
async handle(params) {
|
|
8
|
+
const { username, target, source } = params;
|
|
9
|
+
const exists = await this.userExists({
|
|
10
|
+
username,
|
|
11
|
+
userPoolId: target.services.cognitoUserPoolId,
|
|
12
|
+
region: target.region
|
|
13
|
+
});
|
|
14
|
+
return await this.getLambdaTrigger().handle({
|
|
15
|
+
invocationType: "Event",
|
|
16
|
+
payload: {
|
|
17
|
+
action: exists ? "updateUser" : "createUser",
|
|
18
|
+
username,
|
|
19
|
+
source: {
|
|
20
|
+
region: source.region,
|
|
21
|
+
userPoolId: source.services.cognitoUserPoolId
|
|
22
|
+
},
|
|
23
|
+
target: {
|
|
24
|
+
region: target.region,
|
|
25
|
+
userPoolId: target.services.cognitoUserPoolId
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
async userExists(params) {
|
|
31
|
+
const { userPoolId, username, region } = params;
|
|
32
|
+
const provider = this.createCognitoIdentityProviderClient({
|
|
33
|
+
region
|
|
34
|
+
});
|
|
35
|
+
const input = {
|
|
36
|
+
UserPoolId: userPoolId,
|
|
37
|
+
Username: username
|
|
38
|
+
};
|
|
39
|
+
const cmd = new AdminGetUserCommand(input);
|
|
40
|
+
try {
|
|
41
|
+
const result = await provider.send(cmd);
|
|
42
|
+
return result.$metadata?.httpStatusCode === 200;
|
|
43
|
+
} catch {
|
|
44
|
+
return false;
|
|
33
45
|
}
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
async userExists(params) {
|
|
38
|
-
const {
|
|
39
|
-
userPoolId,
|
|
40
|
-
username,
|
|
41
|
-
region
|
|
42
|
-
} = params;
|
|
43
|
-
const provider = this.createCognitoIdentityProviderClient({
|
|
44
|
-
region
|
|
45
|
-
});
|
|
46
|
-
const input = {
|
|
47
|
-
UserPoolId: userPoolId,
|
|
48
|
-
Username: username
|
|
49
|
-
};
|
|
50
|
-
const cmd = new AdminGetUserCommand(input);
|
|
51
|
-
try {
|
|
52
|
-
const result = await provider.send(cmd);
|
|
53
|
-
return result.$metadata?.httpStatusCode === 200;
|
|
54
|
-
} catch {
|
|
55
|
-
return false;
|
|
56
46
|
}
|
|
57
|
-
}
|
|
58
47
|
}
|
|
48
|
+
export { CopyUser };
|
|
59
49
|
|
|
60
50
|
//# sourceMappingURL=CopyUser.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"resolver/recordTypes/users/CopyUser.js","sources":["../../../../src/resolver/recordTypes/users/CopyUser.ts"],"sourcesContent":["import type {\n ICopyUser,\n ICopyUserHandleParams,\n ICreateCognitoIdentityProviderClientCb\n} from \"./types.js\";\nimport type { LambdaTrigger } from \"~/resolver/lambda/LambdaTrigger.js\";\nimport type { InvokeCommandOutput } from \"@webiny/aws-sdk/client-lambda/index.js\";\nimport type { AdminGetUserCommandInput } from \"@webiny/aws-sdk/client-cognito-identity-provider/index.js\";\nimport { AdminGetUserCommand } from \"@webiny/aws-sdk/client-cognito-identity-provider/index.js\";\nimport type { ICopyUserLambdaPayload } from \"~/types.js\";\n\ninterface IGetUserParams {\n username: string;\n userPoolId: string;\n region: string;\n}\n\nexport interface IGetLambdaTriggerCb {\n (): LambdaTrigger<ICopyUserLambdaPayload>;\n}\n\nexport interface ICopyUserParams {\n createCognitoIdentityProviderClient: ICreateCognitoIdentityProviderClientCb;\n getLambdaTrigger: IGetLambdaTriggerCb;\n}\n\nexport class CopyUser implements ICopyUser {\n private readonly createCognitoIdentityProviderClient: ICreateCognitoIdentityProviderClientCb;\n private readonly getLambdaTrigger: IGetLambdaTriggerCb;\n\n public constructor(params: ICopyUserParams) {\n this.createCognitoIdentityProviderClient = params.createCognitoIdentityProviderClient;\n this.getLambdaTrigger = params.getLambdaTrigger;\n }\n\n public async handle(params: ICopyUserHandleParams): Promise<InvokeCommandOutput | null> {\n const { username, target, source } = params;\n\n const exists = await this.userExists({\n username,\n userPoolId: target.services.cognitoUserPoolId,\n region: target.region\n });\n\n return await this.getLambdaTrigger().handle({\n invocationType: \"Event\",\n payload: {\n /**\n * We need to be able to create or update a user, depending on whether it already exists in the target user pool.\n */\n action: exists ? \"updateUser\" : \"createUser\",\n username,\n source: {\n region: source.region,\n userPoolId: source.services.cognitoUserPoolId\n },\n target: {\n region: target.region,\n userPoolId: target.services.cognitoUserPoolId\n }\n }\n });\n }\n\n private async userExists(params: IGetUserParams): Promise<boolean> {\n const { userPoolId, username, region } = params;\n\n const provider = this.createCognitoIdentityProviderClient({\n region\n });\n\n const input: AdminGetUserCommandInput = {\n UserPoolId: userPoolId,\n Username: username\n };\n const cmd = new AdminGetUserCommand(input);\n try {\n const result = await provider.send(cmd);\n return result.$metadata?.httpStatusCode === 200;\n } catch {\n return false;\n }\n }\n}\n"],"names":["CopyUser","params","username","target","source","exists","userPoolId","region","provider","input","cmd","AdminGetUserCommand","result"],"mappings":";AA0BO,MAAMA;IAIT,YAAmBC,MAAuB,CAAE;QACxC,IAAI,CAAC,mCAAmC,GAAGA,OAAO,mCAAmC;QACrF,IAAI,CAAC,gBAAgB,GAAGA,OAAO,gBAAgB;IACnD;IAEA,MAAa,OAAOA,MAA6B,EAAuC;QACpF,MAAM,EAAEC,QAAQ,EAAEC,MAAM,EAAEC,MAAM,EAAE,GAAGH;QAErC,MAAMI,SAAS,MAAM,IAAI,CAAC,UAAU,CAAC;YACjCH;YACA,YAAYC,OAAO,QAAQ,CAAC,iBAAiB;YAC7C,QAAQA,OAAO,MAAM;QACzB;QAEA,OAAO,MAAM,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC;YACxC,gBAAgB;YAChB,SAAS;gBAIL,QAAQE,SAAS,eAAe;gBAChCH;gBACA,QAAQ;oBACJ,QAAQE,OAAO,MAAM;oBACrB,YAAYA,OAAO,QAAQ,CAAC,iBAAiB;gBACjD;gBACA,QAAQ;oBACJ,QAAQD,OAAO,MAAM;oBACrB,YAAYA,OAAO,QAAQ,CAAC,iBAAiB;gBACjD;YACJ;QACJ;IACJ;IAEA,MAAc,WAAWF,MAAsB,EAAoB;QAC/D,MAAM,EAAEK,UAAU,EAAEJ,QAAQ,EAAEK,MAAM,EAAE,GAAGN;QAEzC,MAAMO,WAAW,IAAI,CAAC,mCAAmC,CAAC;YACtDD;QACJ;QAEA,MAAME,QAAkC;YACpC,YAAYH;YACZ,UAAUJ;QACd;QACA,MAAMQ,MAAM,IAAIC,oBAAoBF;QACpC,IAAI;YACA,MAAMG,SAAS,MAAMJ,SAAS,IAAI,CAACE;YACnC,OAAOE,OAAO,SAAS,EAAE,mBAAmB;QAChD,EAAE,OAAM;YACJ,OAAO;QACX;IACJ;AACJ"}
|