@openstax/ts-utils 1.33.0 → 1.34.0
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/.cfnlintrc +2 -0
- package/.github/CODEOWNERS +1 -0
- package/.github/workflows/ci.yml +36 -0
- package/.github/workflows/lint.yml +55 -0
- package/.nvmrc +1 -0
- package/.syncignore +4 -0
- package/.syncpackrc +18 -0
- package/CONTRIBUTING.md +96 -0
- package/LICENSE +661 -0
- package/Procfile +1 -0
- package/README.md +62 -90
- package/app.json +23 -0
- package/cspell.json +32 -0
- package/deploy/constants.env +21 -0
- package/deploy/deploy.bash +157 -0
- package/deploy/deployment-alt-region.cfn.yml +70 -0
- package/deploy/deployment.cfn.yml +650 -0
- package/deploy/destroy-deployment.bash +23 -0
- package/deploy/shared.cfn.yml +94 -0
- package/docs/lambda-build.md +35 -0
- package/package.json +12 -228
- package/packages/frontend/README.md +46 -0
- package/packages/frontend/package.json +101 -0
- package/packages/frontend/public/favicon.ico +0 -0
- package/packages/frontend/public/index.html +107 -0
- package/packages/frontend/public/maintenance.html +59 -0
- package/packages/frontend/public/manifest.json +15 -0
- package/packages/frontend/public/robots.txt +3 -0
- package/packages/frontend/script/make-certificate.bash +49 -0
- package/packages/frontend/script/server/cli.js +11 -0
- package/packages/frontend/script/server/index.js +47 -0
- package/packages/frontend/script/start.bash +22 -0
- package/packages/frontend/script/trust-localhost.bash +7 -0
- package/packages/frontend/src/auth/authProvider.ts +10 -0
- package/packages/frontend/src/auth/useAuth.ts +33 -0
- package/packages/frontend/src/components/Pagination.tsx +26 -0
- package/packages/frontend/src/configProvider/index.ts +53 -0
- package/packages/frontend/src/configProvider/use.ts +41 -0
- package/packages/frontend/src/core/context/services.spec.tsx +39 -0
- package/packages/frontend/src/core/context/services.tsx +16 -0
- package/packages/frontend/src/core/index.spec.ts +7 -0
- package/packages/frontend/src/core/index.ts +20 -0
- package/packages/frontend/src/core/services.tsx +14 -0
- package/packages/frontend/src/core/types.ts +3 -0
- package/packages/frontend/src/example/api.ts +28 -0
- package/packages/frontend/src/example/components/Layout.tsx +23 -0
- package/packages/frontend/src/example/screens/Home.spec.tsx +68 -0
- package/packages/frontend/src/example/screens/Home.tsx +78 -0
- package/packages/frontend/src/example/screens/ThingList.spec.tsx +60 -0
- package/packages/frontend/src/example/screens/ThingList.tsx +75 -0
- package/packages/frontend/src/example/screens/ThingView.spec.tsx +71 -0
- package/packages/frontend/src/example/screens/ThingView.tsx +47 -0
- package/packages/frontend/src/example/screens/index.ts +9 -0
- package/packages/frontend/src/index.css +159 -0
- package/packages/frontend/src/index.tsx +67 -0
- package/packages/frontend/src/react-app-env.d.ts +1 -0
- package/packages/frontend/src/routing/components/RouteLink.spec.tsx +55 -0
- package/packages/frontend/src/routing/components/RouteLink.tsx +35 -0
- package/packages/frontend/src/routing/middleware.ts +6 -0
- package/packages/frontend/src/routing/useQuery.ts +14 -0
- package/packages/frontend/src/setupProxy.js +19 -0
- package/packages/frontend/src/setupTests.ts +9 -0
- package/packages/frontend/src/tests/testServices.tsx +23 -0
- package/packages/frontend/tsconfig.json +27 -0
- package/packages/lambda/.eslintrc.js +64 -0
- package/packages/lambda/jest-global-setup.js +3 -0
- package/packages/lambda/jest-setup-after-env.js +1 -0
- package/packages/lambda/jest.config.js +31 -0
- package/packages/lambda/jest.resolver.js +17 -0
- package/packages/lambda/package.json +68 -0
- package/packages/lambda/script/build.bash +19 -0
- package/packages/lambda/script/bundle-functions.bash +10 -0
- package/packages/lambda/script/lambdaLocalProxy.js +16 -0
- package/packages/lambda/script/lambdaLocalProxy.spec.ts +147 -0
- package/packages/lambda/script/utils/getRouteData.ts +7 -0
- package/packages/lambda/script/utils/routeDataLoader.js +8 -0
- package/packages/lambda/script/utils/routeDataLoader.spec.ts +8 -0
- package/packages/lambda/src/functions/serviceApi/core/index.ts +7 -0
- package/packages/lambda/src/functions/serviceApi/core/request.spec.ts +38 -0
- package/packages/lambda/src/functions/serviceApi/core/request.ts +42 -0
- package/packages/lambda/src/functions/serviceApi/core/routes.spec.ts +7 -0
- package/packages/lambda/src/functions/serviceApi/core/routes.ts +10 -0
- package/packages/lambda/src/functions/serviceApi/core/services.ts +9 -0
- package/packages/lambda/src/functions/serviceApi/core/types.ts +13 -0
- package/packages/lambda/src/functions/serviceApi/entry/lambda/https-xray.ts +4 -0
- package/packages/lambda/src/functions/serviceApi/entry/lambda/index.spec.ts +48 -0
- package/packages/lambda/src/functions/serviceApi/entry/lambda/index.ts +58 -0
- package/packages/lambda/src/functions/serviceApi/entry/lambda/services.ts +36 -0
- package/packages/lambda/src/functions/serviceApi/entry/local.ts +71 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentSearchMiddleware.spec.ts +16 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentSearchMiddleware.ts +41 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentStoreMiddleware.spec.ts +78 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentStoreMiddleware.ts +70 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/routes.spec.ts +306 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/routes.ts +176 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/index.spec.ts +263 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/index.ts +134 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/authMiddleware.spec.ts +23 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/authMiddleware.ts +32 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/configMiddleware.spec.ts +10 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/configMiddleware.ts +7 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/frontendFileServerMiddleware.spec.ts +13 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/frontendFileServerMiddleware.ts +23 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/paginationMiddleware.spec.ts +9 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/paginationMiddleware.ts +9 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/searchMiddleware.spec.ts +12 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/searchMiddleware.ts +21 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/userRoleValidatorMiddleware.spec.ts +21 -0
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/userRoleValidatorMiddleware.ts +18 -0
- package/packages/lambda/tsconfig.json +30 -0
- package/packages/lambda/webpack.config.js +97 -0
- package/packages/utils/.eslintrc.js +64 -0
- package/packages/utils/README.md +118 -0
- package/packages/utils/jest-global-setup.js +3 -0
- package/packages/utils/jest.config.js +25 -0
- package/packages/utils/jest.resolver.js +17 -0
- package/packages/utils/package.json +238 -0
- package/packages/utils/src/assertions/index.spec.ts +126 -0
- package/{dist/esm/assertions/index.js → packages/utils/src/assertions/index.ts} +64 -49
- package/packages/utils/src/aws/ssmService.ts +7 -0
- package/packages/utils/src/config/awsParameterConfig.ts +24 -0
- package/packages/utils/src/config/envConfig.ts +58 -0
- package/packages/utils/src/config/index.spec.ts +165 -0
- package/{dist/esm/config/index.d.ts → packages/utils/src/config/index.ts} +29 -13
- package/packages/utils/src/config/lambdaParameterConfig.ts +49 -0
- package/{dist/esm/config/replaceConfig.js → packages/utils/src/config/replaceConfig.ts} +16 -6
- package/packages/utils/src/config/resolveConfigValue.ts +10 -0
- package/packages/utils/src/errors/index.spec.ts +35 -0
- package/{dist/esm/errors/index.js → packages/utils/src/errors/index.ts} +57 -41
- package/packages/utils/src/fetch/fetchStatusRetry.spec.ts +197 -0
- package/packages/utils/src/fetch/fetchStatusRetry.ts +33 -0
- package/packages/utils/src/fetch/index.spec.ts +34 -0
- package/packages/utils/src/fetch/index.ts +87 -0
- package/packages/utils/src/guards/index.spec.ts +58 -0
- package/{dist/esm/guards/index.d.ts → packages/utils/src/guards/index.ts} +10 -7
- package/packages/utils/src/index.spec.ts +471 -0
- package/packages/utils/src/middleware/apiErrorHandler.spec.ts +65 -0
- package/packages/utils/src/middleware/apiErrorHandler.ts +67 -0
- package/packages/utils/src/middleware/apiSlowResponseMiddleware.spec.ts +184 -0
- package/packages/utils/src/middleware/apiSlowResponseMiddleware.ts +71 -0
- package/packages/utils/src/middleware/index.spec.ts +99 -0
- package/{dist/cjs/middleware/index.d.ts → packages/utils/src/middleware/index.ts} +53 -5
- package/packages/utils/src/middleware/lambdaCorsResponseMiddleware.spec.ts +103 -0
- package/packages/utils/src/middleware/lambdaCorsResponseMiddleware.ts +52 -0
- package/packages/utils/src/middleware/throwNotFoundMiddleware.spec.ts +20 -0
- package/packages/utils/src/middleware/throwNotFoundMiddleware.ts +11 -0
- package/packages/utils/src/misc/hashValue.ts +18 -0
- package/packages/utils/src/misc/helpers.ts +259 -0
- package/packages/utils/src/misc/merge.ts +48 -0
- package/{dist/esm/misc/partitionSequence.js → packages/utils/src/misc/partitionSequence.ts} +23 -15
- package/packages/utils/src/pagination/index.spec.ts +150 -0
- package/packages/utils/src/pagination/index.ts +117 -0
- package/{dist/esm/routing/helpers.js → packages/utils/src/routing/helpers.ts} +42 -30
- package/packages/utils/src/routing/index.spec.ts +553 -0
- package/packages/utils/src/routing/index.ts +424 -0
- package/packages/utils/src/routing/validators/zod.spec.ts +16 -0
- package/packages/utils/src/routing/validators/zod.ts +14 -0
- package/packages/utils/src/services/accountsGateway/README.md +3 -0
- package/packages/utils/src/services/accountsGateway/index.spec.ts +518 -0
- package/packages/utils/src/services/accountsGateway/index.ts +251 -0
- package/packages/utils/src/services/apiGateway/README.md +93 -0
- package/packages/utils/src/services/apiGateway/index.spec.ts +254 -0
- package/packages/utils/src/services/apiGateway/index.ts +189 -0
- package/packages/utils/src/services/authProvider/README.md +21 -0
- package/packages/utils/src/services/authProvider/browser.spec.ts +391 -0
- package/packages/utils/src/services/authProvider/browser.ts +209 -0
- package/packages/utils/src/services/authProvider/decryption.spec.ts +337 -0
- package/packages/utils/src/services/authProvider/decryption.ts +98 -0
- package/packages/utils/src/services/authProvider/index.ts +93 -0
- package/packages/utils/src/services/authProvider/stub.spec.ts +29 -0
- package/packages/utils/src/services/authProvider/subrequest.spec.ts +105 -0
- package/packages/utils/src/services/authProvider/subrequest.ts +68 -0
- package/packages/utils/src/services/authProvider/utils/decryptAndVerify.spec.ts +128 -0
- package/packages/utils/src/services/authProvider/utils/decryptAndVerify.ts +106 -0
- package/packages/utils/src/services/authProvider/utils/embeddedAuthProvider.spec.ts +26 -0
- package/packages/utils/src/services/authProvider/utils/embeddedAuthProvider.ts +57 -0
- package/packages/utils/src/services/authProvider/utils/userRoleValidator.spec.ts +135 -0
- package/packages/utils/src/services/authProvider/utils/userRoleValidator.ts +49 -0
- package/packages/utils/src/services/authProvider/utils/userSubrequest.spec.ts +26 -0
- package/packages/utils/src/services/authProvider/utils/userSubrequest.ts +10 -0
- package/packages/utils/src/services/documentStore/dynamoEncoding.ts +57 -0
- package/packages/utils/src/services/documentStore/fileSystemAssert.spec.ts +43 -0
- package/packages/utils/src/services/documentStore/fileSystemAssert.ts +10 -0
- package/{dist/cjs/services/documentStore/index.d.ts → packages/utils/src/services/documentStore/index.ts} +8 -8
- package/packages/utils/src/services/documentStore/unversioned/README.md +13 -0
- package/packages/utils/src/services/documentStore/unversioned/dynamodb.spec.ts +859 -0
- package/packages/utils/src/services/documentStore/unversioned/dynamodb.ts +243 -0
- package/packages/utils/src/services/documentStore/unversioned/file-system.spec.ts +629 -0
- package/packages/utils/src/services/documentStore/unversioned/file-system.ts +194 -0
- package/{dist/cjs/services/documentStore/unversioned/index.d.ts → packages/utils/src/services/documentStore/unversioned/index.ts} +2 -0
- package/packages/utils/src/services/documentStore/versioned/README.md +13 -0
- package/packages/utils/src/services/documentStore/versioned/dynamodb.spec.ts +376 -0
- package/packages/utils/src/services/documentStore/versioned/dynamodb.ts +167 -0
- package/packages/utils/src/services/documentStore/versioned/file-system.spec.ts +262 -0
- package/packages/utils/src/services/documentStore/versioned/file-system.ts +90 -0
- package/packages/utils/src/services/documentStore/versioned/index.ts +25 -0
- package/packages/utils/src/services/exercisesGateway/README.md +5 -0
- package/packages/utils/src/services/exercisesGateway/index.spec.ts +326 -0
- package/packages/utils/src/services/exercisesGateway/index.ts +163 -0
- package/packages/utils/src/services/fileServer/index.spec.ts +88 -0
- package/packages/utils/src/services/fileServer/index.ts +43 -0
- package/packages/utils/src/services/fileServer/localFileServer.spec.ts +182 -0
- package/packages/utils/src/services/fileServer/localFileServer.ts +159 -0
- package/packages/utils/src/services/fileServer/s3FileServer.spec.ts +266 -0
- package/packages/utils/src/services/fileServer/s3FileServer.ts +155 -0
- package/packages/utils/src/services/launchParams/index.spec.ts +366 -0
- package/packages/utils/src/services/launchParams/signer.ts +73 -0
- package/packages/utils/src/services/launchParams/verifier.ts +120 -0
- package/packages/utils/src/services/logger/console.spec.ts +29 -0
- package/{dist/esm/services/logger/console.js → packages/utils/src/services/logger/console.ts} +5 -2
- package/packages/utils/src/services/logger/index.spec.ts +65 -0
- package/{dist/esm/services/logger/index.d.ts → packages/utils/src/services/logger/index.ts} +23 -9
- package/packages/utils/src/services/lrsGateway/README.md +5 -0
- package/packages/utils/src/services/lrsGateway/addStatementDefaultFields.ts +22 -0
- package/packages/utils/src/services/lrsGateway/attempt-utils.spec.ts +847 -0
- package/packages/utils/src/services/lrsGateway/attempt-utils.ts +358 -0
- package/packages/utils/src/services/lrsGateway/file-system.spec.ts +363 -0
- package/packages/utils/src/services/lrsGateway/file-system.ts +165 -0
- package/packages/utils/src/services/lrsGateway/index.spec.ts +194 -0
- package/packages/utils/src/services/lrsGateway/index.ts +257 -0
- package/packages/utils/src/services/lrsGateway/xapiUtils.spec.ts +887 -0
- package/packages/utils/src/services/lrsGateway/xapiUtils.ts +262 -0
- package/packages/utils/src/services/postgresConnection/index.spec.ts +170 -0
- package/packages/utils/src/services/postgresConnection/index.ts +84 -0
- package/packages/utils/src/services/searchProvider/README.md +3 -0
- package/packages/utils/src/services/searchProvider/index.ts +59 -0
- package/packages/utils/src/services/searchProvider/memorySearchTheBadWay.spec.ts +526 -0
- package/packages/utils/src/services/searchProvider/memorySearchTheBadWay.ts +223 -0
- package/packages/utils/src/services/searchProvider/openSearch.spec.ts +926 -0
- package/packages/utils/src/services/searchProvider/openSearch.ts +195 -0
- package/{dist/esm/types.d.ts → packages/utils/src/types.ts} +34 -6
- package/packages/utils/tsconfig.json +31 -0
- package/packages/utils/tsconfig.without-specs.cjs.json +7 -0
- package/packages/utils/tsconfig.without-specs.esm.json +7 -0
- package/packages/utils/tsconfig.without-specs.json +6 -0
- package/scripts/build.bash +24 -0
- package/scripts/ci.bash +10 -0
- package/scripts/start.bash +29 -0
- package/dist/cjs/assertions/index.d.ts +0 -89
- package/dist/cjs/assertions/index.js +0 -157
- package/dist/cjs/aws/ssmService.d.ts +0 -5
- package/dist/cjs/aws/ssmService.js +0 -9
- package/dist/cjs/config/awsParameterConfig.d.ts +0 -10
- package/dist/cjs/config/awsParameterConfig.js +0 -26
- package/dist/cjs/config/envConfig.d.ts +0 -24
- package/dist/cjs/config/envConfig.js +0 -57
- package/dist/cjs/config/index.d.ts +0 -48
- package/dist/cjs/config/index.js +0 -35
- package/dist/cjs/config/lambdaParameterConfig.d.ts +0 -12
- package/dist/cjs/config/lambdaParameterConfig.js +0 -45
- package/dist/cjs/config/replaceConfig.d.ts +0 -14
- package/dist/cjs/config/replaceConfig.js +0 -22
- package/dist/cjs/config/resolveConfigValue.d.ts +0 -5
- package/dist/cjs/config/resolveConfigValue.js +0 -12
- package/dist/cjs/errors/index.d.ts +0 -88
- package/dist/cjs/errors/index.js +0 -123
- package/dist/cjs/fetch/fetchStatusRetry.d.ts +0 -8
- package/dist/cjs/fetch/fetchStatusRetry.js +0 -27
- package/dist/cjs/fetch/index.d.ts +0 -64
- package/dist/cjs/fetch/index.js +0 -55
- package/dist/cjs/guards/index.d.ts +0 -38
- package/dist/cjs/guards/index.js +0 -44
- package/dist/cjs/index.js +0 -20
- package/dist/cjs/middleware/apiErrorHandler.d.ts +0 -24
- package/dist/cjs/middleware/apiErrorHandler.js +0 -42
- package/dist/cjs/middleware/apiSlowResponseMiddleware.d.ts +0 -23
- package/dist/cjs/middleware/apiSlowResponseMiddleware.js +0 -54
- package/dist/cjs/middleware/index.js +0 -48
- package/dist/cjs/middleware/lambdaCorsResponseMiddleware.d.ts +0 -20
- package/dist/cjs/middleware/lambdaCorsResponseMiddleware.js +0 -44
- package/dist/cjs/middleware/throwNotFoundMiddleware.d.ts +0 -4
- package/dist/cjs/middleware/throwNotFoundMiddleware.js +0 -14
- package/dist/cjs/misc/hashValue.d.ts +0 -10
- package/dist/cjs/misc/hashValue.js +0 -17
- package/dist/cjs/misc/helpers.d.ts +0 -124
- package/dist/cjs/misc/helpers.js +0 -214
- package/dist/cjs/misc/merge.d.ts +0 -21
- package/dist/cjs/misc/merge.js +0 -45
- package/dist/cjs/misc/partitionSequence.d.ts +0 -35
- package/dist/cjs/misc/partitionSequence.js +0 -55
- package/dist/cjs/pagination/index.d.ts +0 -91
- package/dist/cjs/pagination/index.js +0 -83
- package/dist/cjs/routing/helpers.d.ts +0 -57
- package/dist/cjs/routing/helpers.js +0 -90
- package/dist/cjs/routing/index.d.ts +0 -290
- package/dist/cjs/routing/index.js +0 -295
- package/dist/cjs/routing/validators/zod.d.ts +0 -4
- package/dist/cjs/routing/validators/zod.js +0 -14
- package/dist/cjs/services/accountsGateway/index.d.ts +0 -92
- package/dist/cjs/services/accountsGateway/index.js +0 -138
- package/dist/cjs/services/apiGateway/index.d.ts +0 -68
- package/dist/cjs/services/apiGateway/index.js +0 -118
- package/dist/cjs/services/authProvider/browser.d.ts +0 -40
- package/dist/cjs/services/authProvider/browser.js +0 -155
- package/dist/cjs/services/authProvider/decryption.d.ts +0 -19
- package/dist/cjs/services/authProvider/decryption.js +0 -73
- package/dist/cjs/services/authProvider/index.d.ts +0 -63
- package/dist/cjs/services/authProvider/index.js +0 -34
- package/dist/cjs/services/authProvider/subrequest.d.ts +0 -13
- package/dist/cjs/services/authProvider/subrequest.js +0 -49
- package/dist/cjs/services/authProvider/utils/decryptAndVerify.d.ts +0 -28
- package/dist/cjs/services/authProvider/utils/decryptAndVerify.js +0 -91
- package/dist/cjs/services/authProvider/utils/embeddedAuthProvider.d.ts +0 -26
- package/dist/cjs/services/authProvider/utils/embeddedAuthProvider.js +0 -47
- package/dist/cjs/services/authProvider/utils/userRoleValidator.d.ts +0 -13
- package/dist/cjs/services/authProvider/utils/userRoleValidator.js +0 -37
- package/dist/cjs/services/authProvider/utils/userSubrequest.d.ts +0 -3
- package/dist/cjs/services/authProvider/utils/userSubrequest.js +0 -13
- package/dist/cjs/services/documentStore/dynamoEncoding.d.ts +0 -10
- package/dist/cjs/services/documentStore/dynamoEncoding.js +0 -52
- package/dist/cjs/services/documentStore/fileSystemAssert.d.ts +0 -1
- package/dist/cjs/services/documentStore/fileSystemAssert.js +0 -14
- package/dist/cjs/services/documentStore/index.js +0 -2
- package/dist/cjs/services/documentStore/unversioned/dynamodb.d.ts +0 -31
- package/dist/cjs/services/documentStore/unversioned/dynamodb.js +0 -233
- package/dist/cjs/services/documentStore/unversioned/file-system.d.ts +0 -32
- package/dist/cjs/services/documentStore/unversioned/file-system.js +0 -214
- package/dist/cjs/services/documentStore/unversioned/index.js +0 -2
- package/dist/cjs/services/documentStore/versioned/dynamodb.d.ts +0 -25
- package/dist/cjs/services/documentStore/versioned/dynamodb.js +0 -143
- package/dist/cjs/services/documentStore/versioned/file-system.d.ts +0 -25
- package/dist/cjs/services/documentStore/versioned/file-system.js +0 -73
- package/dist/cjs/services/documentStore/versioned/index.d.ts +0 -17
- package/dist/cjs/services/documentStore/versioned/index.js +0 -2
- package/dist/cjs/services/exercisesGateway/index.d.ts +0 -67
- package/dist/cjs/services/exercisesGateway/index.js +0 -107
- package/dist/cjs/services/fileServer/index.d.ts +0 -30
- package/dist/cjs/services/fileServer/index.js +0 -19
- package/dist/cjs/services/fileServer/localFileServer.d.ts +0 -13
- package/dist/cjs/services/fileServer/localFileServer.js +0 -132
- package/dist/cjs/services/fileServer/s3FileServer.d.ts +0 -14
- package/dist/cjs/services/fileServer/s3FileServer.js +0 -131
- package/dist/cjs/services/launchParams/index.js +0 -7
- package/dist/cjs/services/launchParams/signer.d.ts +0 -23
- package/dist/cjs/services/launchParams/signer.js +0 -58
- package/dist/cjs/services/launchParams/verifier.d.ts +0 -21
- package/dist/cjs/services/launchParams/verifier.js +0 -129
- package/dist/cjs/services/logger/console.d.ts +0 -4
- package/dist/cjs/services/logger/console.js +0 -12
- package/dist/cjs/services/logger/index.d.ts +0 -39
- package/dist/cjs/services/logger/index.js +0 -31
- package/dist/cjs/services/lrsGateway/addStatementDefaultFields.d.ts +0 -5
- package/dist/cjs/services/lrsGateway/addStatementDefaultFields.js +0 -21
- package/dist/cjs/services/lrsGateway/attempt-utils.d.ts +0 -70
- package/dist/cjs/services/lrsGateway/attempt-utils.js +0 -258
- package/dist/cjs/services/lrsGateway/file-system.d.ts +0 -15
- package/dist/cjs/services/lrsGateway/file-system.js +0 -150
- package/dist/cjs/services/lrsGateway/index.d.ts +0 -122
- package/dist/cjs/services/lrsGateway/index.js +0 -148
- package/dist/cjs/services/lrsGateway/xapiUtils.d.ts +0 -68
- package/dist/cjs/services/lrsGateway/xapiUtils.js +0 -109
- package/dist/cjs/services/postgresConnection/index.d.ts +0 -28
- package/dist/cjs/services/postgresConnection/index.js +0 -65
- package/dist/cjs/services/searchProvider/index.d.ts +0 -67
- package/dist/cjs/services/searchProvider/index.js +0 -2
- package/dist/cjs/services/searchProvider/memorySearchTheBadWay.d.ts +0 -20
- package/dist/cjs/services/searchProvider/memorySearchTheBadWay.js +0 -191
- package/dist/cjs/services/searchProvider/openSearch.d.ts +0 -28
- package/dist/cjs/services/searchProvider/openSearch.js +0 -154
- package/dist/cjs/tsconfig.without-specs.cjs.tsbuildinfo +0 -1
- package/dist/cjs/types.d.ts +0 -31
- package/dist/cjs/types.js +0 -2
- package/dist/esm/assertions/index.d.ts +0 -89
- package/dist/esm/aws/ssmService.d.ts +0 -5
- package/dist/esm/aws/ssmService.js +0 -6
- package/dist/esm/config/awsParameterConfig.d.ts +0 -10
- package/dist/esm/config/awsParameterConfig.js +0 -22
- package/dist/esm/config/envConfig.d.ts +0 -24
- package/dist/esm/config/envConfig.js +0 -53
- package/dist/esm/config/index.js +0 -17
- package/dist/esm/config/lambdaParameterConfig.d.ts +0 -12
- package/dist/esm/config/lambdaParameterConfig.js +0 -38
- package/dist/esm/config/replaceConfig.d.ts +0 -14
- package/dist/esm/config/resolveConfigValue.d.ts +0 -5
- package/dist/esm/config/resolveConfigValue.js +0 -8
- package/dist/esm/errors/index.d.ts +0 -88
- package/dist/esm/fetch/fetchStatusRetry.d.ts +0 -8
- package/dist/esm/fetch/fetchStatusRetry.js +0 -23
- package/dist/esm/fetch/index.d.ts +0 -64
- package/dist/esm/fetch/index.js +0 -46
- package/dist/esm/guards/index.js +0 -36
- package/dist/esm/index.d.ts +0 -4
- package/dist/esm/index.js +0 -4
- package/dist/esm/middleware/apiErrorHandler.d.ts +0 -24
- package/dist/esm/middleware/apiErrorHandler.js +0 -38
- package/dist/esm/middleware/apiSlowResponseMiddleware.d.ts +0 -23
- package/dist/esm/middleware/apiSlowResponseMiddleware.js +0 -50
- package/dist/esm/middleware/index.d.ts +0 -47
- package/dist/esm/middleware/index.js +0 -44
- package/dist/esm/middleware/lambdaCorsResponseMiddleware.d.ts +0 -20
- package/dist/esm/middleware/lambdaCorsResponseMiddleware.js +0 -40
- package/dist/esm/middleware/throwNotFoundMiddleware.d.ts +0 -4
- package/dist/esm/middleware/throwNotFoundMiddleware.js +0 -10
- package/dist/esm/misc/hashValue.d.ts +0 -10
- package/dist/esm/misc/hashValue.js +0 -13
- package/dist/esm/misc/helpers.d.ts +0 -124
- package/dist/esm/misc/helpers.js +0 -199
- package/dist/esm/misc/merge.d.ts +0 -21
- package/dist/esm/misc/merge.js +0 -40
- package/dist/esm/misc/partitionSequence.d.ts +0 -35
- package/dist/esm/pagination/index.d.ts +0 -91
- package/dist/esm/pagination/index.js +0 -77
- package/dist/esm/routing/helpers.d.ts +0 -57
- package/dist/esm/routing/index.d.ts +0 -290
- package/dist/esm/routing/index.js +0 -246
- package/dist/esm/routing/validators/zod.d.ts +0 -4
- package/dist/esm/routing/validators/zod.js +0 -10
- package/dist/esm/services/accountsGateway/index.d.ts +0 -92
- package/dist/esm/services/accountsGateway/index.js +0 -131
- package/dist/esm/services/apiGateway/index.d.ts +0 -68
- package/dist/esm/services/apiGateway/index.js +0 -77
- package/dist/esm/services/authProvider/browser.d.ts +0 -40
- package/dist/esm/services/authProvider/browser.js +0 -151
- package/dist/esm/services/authProvider/decryption.d.ts +0 -19
- package/dist/esm/services/authProvider/decryption.js +0 -69
- package/dist/esm/services/authProvider/index.d.ts +0 -63
- package/dist/esm/services/authProvider/index.js +0 -26
- package/dist/esm/services/authProvider/subrequest.d.ts +0 -13
- package/dist/esm/services/authProvider/subrequest.js +0 -45
- package/dist/esm/services/authProvider/utils/decryptAndVerify.d.ts +0 -28
- package/dist/esm/services/authProvider/utils/decryptAndVerify.js +0 -85
- package/dist/esm/services/authProvider/utils/embeddedAuthProvider.d.ts +0 -26
- package/dist/esm/services/authProvider/utils/embeddedAuthProvider.js +0 -40
- package/dist/esm/services/authProvider/utils/userRoleValidator.d.ts +0 -13
- package/dist/esm/services/authProvider/utils/userRoleValidator.js +0 -33
- package/dist/esm/services/authProvider/utils/userSubrequest.d.ts +0 -3
- package/dist/esm/services/authProvider/utils/userSubrequest.js +0 -6
- package/dist/esm/services/documentStore/dynamoEncoding.d.ts +0 -10
- package/dist/esm/services/documentStore/dynamoEncoding.js +0 -45
- package/dist/esm/services/documentStore/fileSystemAssert.d.ts +0 -1
- package/dist/esm/services/documentStore/fileSystemAssert.js +0 -10
- package/dist/esm/services/documentStore/index.d.ts +0 -14
- package/dist/esm/services/documentStore/index.js +0 -1
- package/dist/esm/services/documentStore/unversioned/dynamodb.d.ts +0 -31
- package/dist/esm/services/documentStore/unversioned/dynamodb.js +0 -226
- package/dist/esm/services/documentStore/unversioned/file-system.d.ts +0 -32
- package/dist/esm/services/documentStore/unversioned/file-system.js +0 -174
- package/dist/esm/services/documentStore/unversioned/index.d.ts +0 -2
- package/dist/esm/services/documentStore/unversioned/index.js +0 -1
- package/dist/esm/services/documentStore/versioned/dynamodb.d.ts +0 -25
- package/dist/esm/services/documentStore/versioned/dynamodb.js +0 -139
- package/dist/esm/services/documentStore/versioned/file-system.d.ts +0 -25
- package/dist/esm/services/documentStore/versioned/file-system.js +0 -69
- package/dist/esm/services/documentStore/versioned/index.d.ts +0 -17
- package/dist/esm/services/documentStore/versioned/index.js +0 -1
- package/dist/esm/services/exercisesGateway/index.d.ts +0 -67
- package/dist/esm/services/exercisesGateway/index.js +0 -70
- package/dist/esm/services/fileServer/index.d.ts +0 -30
- package/dist/esm/services/fileServer/index.js +0 -13
- package/dist/esm/services/fileServer/localFileServer.d.ts +0 -13
- package/dist/esm/services/fileServer/localFileServer.js +0 -125
- package/dist/esm/services/fileServer/s3FileServer.d.ts +0 -14
- package/dist/esm/services/fileServer/s3FileServer.js +0 -124
- package/dist/esm/services/launchParams/index.d.ts +0 -2
- package/dist/esm/services/launchParams/index.js +0 -2
- package/dist/esm/services/launchParams/signer.d.ts +0 -23
- package/dist/esm/services/launchParams/signer.js +0 -51
- package/dist/esm/services/launchParams/verifier.d.ts +0 -21
- package/dist/esm/services/launchParams/verifier.js +0 -92
- package/dist/esm/services/logger/console.d.ts +0 -4
- package/dist/esm/services/logger/index.js +0 -27
- package/dist/esm/services/lrsGateway/addStatementDefaultFields.d.ts +0 -5
- package/dist/esm/services/lrsGateway/addStatementDefaultFields.js +0 -14
- package/dist/esm/services/lrsGateway/attempt-utils.d.ts +0 -70
- package/dist/esm/services/lrsGateway/attempt-utils.js +0 -236
- package/dist/esm/services/lrsGateway/file-system.d.ts +0 -15
- package/dist/esm/services/lrsGateway/file-system.js +0 -110
- package/dist/esm/services/lrsGateway/index.d.ts +0 -122
- package/dist/esm/services/lrsGateway/index.js +0 -111
- package/dist/esm/services/lrsGateway/xapiUtils.d.ts +0 -68
- package/dist/esm/services/lrsGateway/xapiUtils.js +0 -99
- package/dist/esm/services/postgresConnection/index.d.ts +0 -28
- package/dist/esm/services/postgresConnection/index.js +0 -58
- package/dist/esm/services/searchProvider/index.d.ts +0 -67
- package/dist/esm/services/searchProvider/index.js +0 -1
- package/dist/esm/services/searchProvider/memorySearchTheBadWay.d.ts +0 -20
- package/dist/esm/services/searchProvider/memorySearchTheBadWay.js +0 -187
- package/dist/esm/services/searchProvider/openSearch.d.ts +0 -28
- package/dist/esm/services/searchProvider/openSearch.js +0 -150
- package/dist/esm/tsconfig.without-specs.esm.tsbuildinfo +0 -1
- package/dist/esm/types.js +0 -1
- /package/{script → packages/utils/script}/bin/copy-from-template.bash +0 -0
- /package/{script → packages/utils/script}/bin/delete-stack.bash +0 -0
- /package/{script → packages/utils/script}/bin/deploy.bash +0 -0
- /package/{script → packages/utils/script}/bin/destroy-deployment.bash +0 -0
- /package/{script → packages/utils/script}/bin/empty-bucket.bash +0 -0
- /package/{script → packages/utils/script}/bin/get-arg.bash +0 -0
- /package/{script → packages/utils/script}/bin/get-deployed-environments.bash +0 -0
- /package/{script → packages/utils/script}/bin/get-env-param.bash +0 -0
- /package/{script → packages/utils/script}/bin/get-kwarg.bash +0 -0
- /package/{script → packages/utils/script}/bin/get-stack-param.bash +0 -0
- /package/{script → packages/utils/script}/bin/has-flag.bash +0 -0
- /package/{script → packages/utils/script}/bin/init-constants-script.bash +0 -0
- /package/{script → packages/utils/script}/bin/init-params-script.bash +0 -0
- /package/{script → packages/utils/script}/bin/stack-exists.bash +0 -0
- /package/{script → packages/utils/script}/bin/update-utils.bash +0 -0
- /package/{script → packages/utils/script}/bin/upload-pager-duty-endpoints.bash +0 -0
- /package/{script → packages/utils/script}/bin/upload-params.bash +0 -0
- /package/{script → packages/utils/script}/bin/which.bash +0 -0
- /package/{script → packages/utils/script}/bin-entry.bash +0 -0
- /package/{script → packages/utils/script}/build.bash +0 -0
- /package/{dist/cjs/index.d.ts → packages/utils/src/index.ts} +0 -0
- /package/{dist/cjs/services/launchParams/index.d.ts → packages/utils/src/services/launchParams/index.ts} +0 -0
|
@@ -1,233 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.dynamoUnversionedDocumentStore = void 0;
|
|
7
|
-
const client_dynamodb_1 = require("@aws-sdk/client-dynamodb");
|
|
8
|
-
const tiny_async_pool_1 = __importDefault(require("tiny-async-pool"));
|
|
9
|
-
const __1 = require("../../..");
|
|
10
|
-
const config_1 = require("../../../config");
|
|
11
|
-
const errors_1 = require("../../../errors");
|
|
12
|
-
const guards_1 = require("../../../guards");
|
|
13
|
-
const dynamoEncoding_1 = require("../dynamoEncoding");
|
|
14
|
-
const dynamoUnversionedDocumentStore = (initializer) => {
|
|
15
|
-
const init = (0, guards_1.ifDefined)(initializer, {});
|
|
16
|
-
const dynamodb = (0, __1.once)(() => { var _a; return (_a = init.dynamoClient) !== null && _a !== void 0 ? _a : new client_dynamodb_1.DynamoDB({ apiVersion: '2012-08-10' }); });
|
|
17
|
-
return () => (configProvider) => (_, hashKey, options) => {
|
|
18
|
-
const tableName = (0, __1.once)(() => (0, config_1.resolveConfigValue)(configProvider[(0, guards_1.ifDefined)(init.configSpace, 'dynamodb')].tableName));
|
|
19
|
-
return {
|
|
20
|
-
loadAllDocumentsTheBadWay: async () => {
|
|
21
|
-
const loadAllResults = async (ExclusiveStartKey) => {
|
|
22
|
-
var _a, _b;
|
|
23
|
-
const cmd = new client_dynamodb_1.ScanCommand({ TableName: await tableName(), ExclusiveStartKey });
|
|
24
|
-
const result = await dynamodb().send(cmd);
|
|
25
|
-
const resultItems = (_b = (_a = result.Items) === null || _a === void 0 ? void 0 : _a.map((item) => (0, dynamoEncoding_1.decodeDynamoDocument)(item))) !== null && _b !== void 0 ? _b : [];
|
|
26
|
-
if (result.LastEvaluatedKey) {
|
|
27
|
-
return [...resultItems, ...await loadAllResults(result.LastEvaluatedKey)];
|
|
28
|
-
}
|
|
29
|
-
return resultItems;
|
|
30
|
-
};
|
|
31
|
-
return loadAllResults();
|
|
32
|
-
},
|
|
33
|
-
/*
|
|
34
|
-
* requires that a global secondary index exist on the table
|
|
35
|
-
*/
|
|
36
|
-
getItemsByField: async (key, value, pageKey) => {
|
|
37
|
-
var _a, _b;
|
|
38
|
-
const ExclusiveStartKey = pageKey
|
|
39
|
-
? JSON.parse(Buffer.from(pageKey, 'base64').toString('utf-8'))
|
|
40
|
-
: undefined;
|
|
41
|
-
const table = await tableName();
|
|
42
|
-
const cmd = new client_dynamodb_1.QueryCommand({
|
|
43
|
-
TableName: table,
|
|
44
|
-
IndexName: key.toString(),
|
|
45
|
-
ExclusiveStartKey,
|
|
46
|
-
KeyConditionExpression: '#hk = :hkv',
|
|
47
|
-
ExpressionAttributeValues: {
|
|
48
|
-
':hkv': (0, dynamoEncoding_1.encodeDynamoAttribute)(value),
|
|
49
|
-
},
|
|
50
|
-
ExpressionAttributeNames: {
|
|
51
|
-
'#hk': key.toString(),
|
|
52
|
-
},
|
|
53
|
-
});
|
|
54
|
-
const response = await dynamodb().send(cmd);
|
|
55
|
-
const items = (_b = (_a = response.Items) === null || _a === void 0 ? void 0 : _a.map((item) => (0, dynamoEncoding_1.decodeDynamoDocument)(item))) !== null && _b !== void 0 ? _b : [];
|
|
56
|
-
const nextPageToken = response.LastEvaluatedKey;
|
|
57
|
-
return {
|
|
58
|
-
items,
|
|
59
|
-
nextPageToken: nextPageToken
|
|
60
|
-
? Buffer.from(JSON.stringify(nextPageToken)).toString('base64')
|
|
61
|
-
: undefined,
|
|
62
|
-
};
|
|
63
|
-
},
|
|
64
|
-
batchGetItem: async (ids) => {
|
|
65
|
-
const table = await tableName();
|
|
66
|
-
const key = hashKey.toString();
|
|
67
|
-
const getBatches = async (requestItems) => {
|
|
68
|
-
const cmd = new client_dynamodb_1.BatchGetItemCommand({
|
|
69
|
-
RequestItems: requestItems !== null && requestItems !== void 0 ? requestItems : { [table]: { Keys: ids.map((id) => ({ [key]: (0, dynamoEncoding_1.encodeDynamoAttribute)(id) })) } },
|
|
70
|
-
});
|
|
71
|
-
const response = await dynamodb().send(cmd);
|
|
72
|
-
const currentResponses = response.Responses ?
|
|
73
|
-
response.Responses[table].map(response => (0, dynamoEncoding_1.decodeDynamoDocument)(response)) : [];
|
|
74
|
-
return currentResponses.concat(response.UnprocessedKeys ? await getBatches(response.UnprocessedKeys) : []);
|
|
75
|
-
};
|
|
76
|
-
return getBatches();
|
|
77
|
-
},
|
|
78
|
-
getItem: async (id) => {
|
|
79
|
-
const cmd = new client_dynamodb_1.GetItemCommand({
|
|
80
|
-
Key: { [hashKey.toString()]: (0, dynamoEncoding_1.encodeDynamoAttribute)(id) },
|
|
81
|
-
TableName: await tableName(),
|
|
82
|
-
});
|
|
83
|
-
return dynamodb().send(cmd).then(result => result.Item ? (0, dynamoEncoding_1.decodeDynamoDocument)(result.Item) : undefined);
|
|
84
|
-
},
|
|
85
|
-
/* atomically increments the given item attribute by 1 */
|
|
86
|
-
incrementItemAttribute: async (id, attribute) => {
|
|
87
|
-
const key = hashKey.toString();
|
|
88
|
-
const field = attribute.toString();
|
|
89
|
-
const cmd = new client_dynamodb_1.UpdateItemCommand({
|
|
90
|
-
Key: { [key]: (0, dynamoEncoding_1.encodeDynamoAttribute)(id) },
|
|
91
|
-
TableName: await tableName(),
|
|
92
|
-
UpdateExpression: 'ADD #f :one',
|
|
93
|
-
ConditionExpression: 'attribute_exists(#k)',
|
|
94
|
-
ExpressionAttributeNames: { '#k': hashKey.toString(), '#f': field },
|
|
95
|
-
ExpressionAttributeValues: { ':one': { N: '1' } },
|
|
96
|
-
ReturnValues: 'ALL_NEW',
|
|
97
|
-
});
|
|
98
|
-
return dynamodb().send(cmd).then(async (item) => {
|
|
99
|
-
var _a, _b, _c;
|
|
100
|
-
const result = (_b = (_a = item.Attributes) === null || _a === void 0 ? void 0 : _a[field]) === null || _b === void 0 ? void 0 : _b['N'];
|
|
101
|
-
if (!item.Attributes) {
|
|
102
|
-
throw new errors_1.NotFoundError(`Item with ${key} "${id}" does not exist`);
|
|
103
|
-
}
|
|
104
|
-
if (!result) {
|
|
105
|
-
throw new errors_1.NotFoundError(`Item with ${key} "${id}" did not produce field "${field}"`);
|
|
106
|
-
}
|
|
107
|
-
const updatedDoc = (0, dynamoEncoding_1.decodeDynamoDocument)(item.Attributes);
|
|
108
|
-
await ((_c = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _c === void 0 ? void 0 : _c.call(options, updatedDoc));
|
|
109
|
-
return parseFloat(result);
|
|
110
|
-
}).catch((error) => {
|
|
111
|
-
throw error.name === 'ConditionalCheckFailedException' ?
|
|
112
|
-
new errors_1.NotFoundError(`Item with ${key} "${id}" does not exist`) : error;
|
|
113
|
-
});
|
|
114
|
-
},
|
|
115
|
-
/* replaces only specified attributes with the given data */
|
|
116
|
-
patchItem: async (item) => {
|
|
117
|
-
const id = item[hashKey];
|
|
118
|
-
const key = hashKey.toString();
|
|
119
|
-
if (!id) {
|
|
120
|
-
throw new Error(`Key attribute "${key}" is required for patchItem`);
|
|
121
|
-
}
|
|
122
|
-
const entries = Object.entries(item).filter(([field]) => field !== key);
|
|
123
|
-
if (entries.length === 0) {
|
|
124
|
-
throw new Error('No attributes to update');
|
|
125
|
-
}
|
|
126
|
-
const updates = [];
|
|
127
|
-
const expressionAttributeNames = { '#k': key };
|
|
128
|
-
const expressionAttributeValues = {};
|
|
129
|
-
entries.forEach(([field, value], index) => {
|
|
130
|
-
updates.push(`#f${index} = :f${index}`);
|
|
131
|
-
expressionAttributeNames[`#f${index}`] = field;
|
|
132
|
-
expressionAttributeValues[`:f${index}`] = (0, dynamoEncoding_1.encodeDynamoAttribute)(value);
|
|
133
|
-
});
|
|
134
|
-
const cmd = new client_dynamodb_1.UpdateItemCommand({
|
|
135
|
-
Key: { [key]: (0, dynamoEncoding_1.encodeDynamoAttribute)(id) },
|
|
136
|
-
TableName: await tableName(),
|
|
137
|
-
UpdateExpression: `SET ${updates.join(', ')}`,
|
|
138
|
-
ConditionExpression: 'attribute_exists(#k)',
|
|
139
|
-
ExpressionAttributeNames: expressionAttributeNames,
|
|
140
|
-
ExpressionAttributeValues: expressionAttributeValues,
|
|
141
|
-
ReturnValues: 'ALL_NEW',
|
|
142
|
-
});
|
|
143
|
-
return dynamodb().send(cmd).then(async (item) => {
|
|
144
|
-
var _a;
|
|
145
|
-
if (!item.Attributes) {
|
|
146
|
-
throw new errors_1.NotFoundError(`Item with ${key} "${id}" does not exist`);
|
|
147
|
-
}
|
|
148
|
-
const updatedDoc = (0, dynamoEncoding_1.decodeDynamoDocument)(item.Attributes);
|
|
149
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, updatedDoc));
|
|
150
|
-
return updatedDoc;
|
|
151
|
-
}).catch((error) => {
|
|
152
|
-
throw error.name === 'ConditionalCheckFailedException' ?
|
|
153
|
-
new errors_1.NotFoundError(`Item with ${key} "${id}" does not exist`) : error;
|
|
154
|
-
});
|
|
155
|
-
},
|
|
156
|
-
/* replaces the entire document with the given data */
|
|
157
|
-
putItem: async (item) => {
|
|
158
|
-
var _a;
|
|
159
|
-
const cmd = new client_dynamodb_1.PutItemCommand({
|
|
160
|
-
TableName: await tableName(),
|
|
161
|
-
Item: (0, dynamoEncoding_1.encodeDynamoDocument)(item),
|
|
162
|
-
});
|
|
163
|
-
const updatedDoc = await dynamodb().send(cmd).then(() => item);
|
|
164
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, updatedDoc));
|
|
165
|
-
return updatedDoc;
|
|
166
|
-
},
|
|
167
|
-
/* creates a new document, fails if the primary key already exists */
|
|
168
|
-
createItem: async (item) => {
|
|
169
|
-
const cmd = new client_dynamodb_1.PutItemCommand({
|
|
170
|
-
TableName: await tableName(),
|
|
171
|
-
Item: (0, dynamoEncoding_1.encodeDynamoDocument)(item),
|
|
172
|
-
ConditionExpression: 'attribute_not_exists(#k)',
|
|
173
|
-
ExpressionAttributeNames: {
|
|
174
|
-
'#k': hashKey.toString(),
|
|
175
|
-
},
|
|
176
|
-
});
|
|
177
|
-
return await dynamodb().send(cmd).then(() => item).catch((error) => {
|
|
178
|
-
throw error.name === 'ConditionalCheckFailedException' ?
|
|
179
|
-
new errors_1.ConflictError(`Item with ${String(hashKey)} "${item[hashKey]}" already exists`) : error;
|
|
180
|
-
}).then(async (createdDoc) => {
|
|
181
|
-
var _a;
|
|
182
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, createdDoc));
|
|
183
|
-
return createdDoc;
|
|
184
|
-
});
|
|
185
|
-
},
|
|
186
|
-
/* creates multiple new documents, returns successful and failed items separately */
|
|
187
|
-
batchCreateItem: async (items, concurrency = 10) => {
|
|
188
|
-
if (items.length === 0)
|
|
189
|
-
return { successful: [], failed: [] };
|
|
190
|
-
const successful = [];
|
|
191
|
-
const failed = [];
|
|
192
|
-
// Process using async iterator (tiny-async-pool v2)
|
|
193
|
-
for await (const result of (0, tiny_async_pool_1.default)(concurrency, items, async (item) => {
|
|
194
|
-
var _a;
|
|
195
|
-
try {
|
|
196
|
-
const cmd = new client_dynamodb_1.PutItemCommand({
|
|
197
|
-
TableName: await tableName(),
|
|
198
|
-
Item: (0, dynamoEncoding_1.encodeDynamoDocument)(item),
|
|
199
|
-
ConditionExpression: 'attribute_not_exists(#k)',
|
|
200
|
-
ExpressionAttributeNames: {
|
|
201
|
-
'#k': hashKey.toString(),
|
|
202
|
-
},
|
|
203
|
-
});
|
|
204
|
-
await dynamodb().send(cmd);
|
|
205
|
-
// Only call individual afterWrite if batchAfterWrite is not defined
|
|
206
|
-
if (!(options === null || options === void 0 ? void 0 : options.batchAfterWrite)) {
|
|
207
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, item));
|
|
208
|
-
}
|
|
209
|
-
return { success: true, item };
|
|
210
|
-
}
|
|
211
|
-
catch (error) {
|
|
212
|
-
const processedError = error.name === 'ConditionalCheckFailedException' ?
|
|
213
|
-
new errors_1.ConflictError(`Item with ${String(hashKey)} "${item[hashKey]}" already exists`) : error;
|
|
214
|
-
return { success: false, item, error: processedError };
|
|
215
|
-
}
|
|
216
|
-
})) {
|
|
217
|
-
if (result.success) {
|
|
218
|
-
successful.push(result.item);
|
|
219
|
-
}
|
|
220
|
-
else {
|
|
221
|
-
failed.push({ item: result.item, error: result.error });
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
// Call batchAfterWrite with all successful items if defined
|
|
225
|
-
if ((options === null || options === void 0 ? void 0 : options.batchAfterWrite) && successful.length > 0) {
|
|
226
|
-
await options.batchAfterWrite(successful);
|
|
227
|
-
}
|
|
228
|
-
return { successful, failed };
|
|
229
|
-
},
|
|
230
|
-
};
|
|
231
|
-
};
|
|
232
|
-
};
|
|
233
|
-
exports.dynamoUnversionedDocumentStore = dynamoUnversionedDocumentStore;
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { Config, TDocument } from '..';
|
|
2
|
-
import { ConfigProviderForConfig } from '../../../config';
|
|
3
|
-
interface Initializer<C> {
|
|
4
|
-
dataDir: string;
|
|
5
|
-
fs?: Pick<typeof import('fs'), 'mkdir' | 'readdir' | 'readFile' | 'writeFile'>;
|
|
6
|
-
configSpace?: C;
|
|
7
|
-
}
|
|
8
|
-
export declare const fileSystemUnversionedDocumentStore: <C extends string = "fileSystem">(initializer: Initializer<C>) => <T extends TDocument<T>>() => (configProvider: { [_key in C]: ConfigProviderForConfig<Config>; }) => <K extends keyof T>(_: {}, hashKey: K, options?: {
|
|
9
|
-
afterWrite?: (item: T) => void | Promise<void>;
|
|
10
|
-
batchAfterWrite?: (items: T[]) => void | Promise<void>;
|
|
11
|
-
skipAssert?: boolean;
|
|
12
|
-
}) => {
|
|
13
|
-
loadAllDocumentsTheBadWay: () => Promise<T[]>;
|
|
14
|
-
getItemsByField: (key: keyof T, value: T[K], pageKey?: string) => Promise<{
|
|
15
|
-
items: T[];
|
|
16
|
-
nextPageToken: string | undefined;
|
|
17
|
-
}>;
|
|
18
|
-
batchGetItem: (ids: T[K][]) => Promise<Exclude<Awaited<T>, undefined>[]>;
|
|
19
|
-
getItem: (id: T[K]) => Promise<T | undefined>;
|
|
20
|
-
incrementItemAttribute: (id: T[K], attribute: keyof T) => Promise<number>;
|
|
21
|
-
patchItem: (item: Partial<T>) => Promise<T>;
|
|
22
|
-
putItem: (item: T) => Promise<T>;
|
|
23
|
-
createItem: (item: T) => Promise<T>;
|
|
24
|
-
batchCreateItem: (items: T[], _concurrency?: number) => Promise<{
|
|
25
|
-
successful: T[];
|
|
26
|
-
failed: Array<{
|
|
27
|
-
item: T;
|
|
28
|
-
error: Error;
|
|
29
|
-
}>;
|
|
30
|
-
}>;
|
|
31
|
-
};
|
|
32
|
-
export {};
|
|
@@ -1,214 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
-
};
|
|
38
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.fileSystemUnversionedDocumentStore = void 0;
|
|
40
|
-
const fsModule = __importStar(require("fs"));
|
|
41
|
-
const path_1 = __importDefault(require("path"));
|
|
42
|
-
const __1 = require("../../..");
|
|
43
|
-
const config_1 = require("../../../config");
|
|
44
|
-
const errors_1 = require("../../../errors");
|
|
45
|
-
const guards_1 = require("../../../guards");
|
|
46
|
-
const fileSystemAssert_1 = require("../fileSystemAssert");
|
|
47
|
-
const fileSystemUnversionedDocumentStore = (initializer) => () => (configProvider) => (_, hashKey, options) => {
|
|
48
|
-
var _a;
|
|
49
|
-
const tableName = (0, config_1.resolveConfigValue)(configProvider[initializer.configSpace || 'fileSystem'].tableName);
|
|
50
|
-
const tablePath = tableName.then((table) => path_1.default.join(initializer.dataDir, table));
|
|
51
|
-
const { mkdir, readdir, readFile, writeFile } = (0, guards_1.ifDefined)(initializer.fs, fsModule);
|
|
52
|
-
const skipAssert = (_a = options === null || options === void 0 ? void 0 : options.skipAssert) !== null && _a !== void 0 ? _a : false;
|
|
53
|
-
const mkTableDir = new Promise((resolve, reject) => tablePath.then((path) => mkdir(path, { recursive: true }, (err) => err && err.code !== 'EEXIST' ? reject(err) : resolve())));
|
|
54
|
-
const hashFilename = (value) => `${(0, __1.hashValue)(value)}.json`;
|
|
55
|
-
const filePath = async (filename) => path_1.default.join(await tablePath, filename);
|
|
56
|
-
const load = async (filename) => {
|
|
57
|
-
const path = await filePath(filename);
|
|
58
|
-
await mkTableDir;
|
|
59
|
-
return new Promise((resolve, reject) => {
|
|
60
|
-
readFile(path, (err, readData) => {
|
|
61
|
-
if (err) {
|
|
62
|
-
err.code === 'ENOENT' ? resolve(undefined) : reject(err);
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
try {
|
|
66
|
-
const data = JSON.parse(readData.toString());
|
|
67
|
-
typeof data === 'object' ? resolve(data) : reject(new Error('unexpected non-object JSON'));
|
|
68
|
-
}
|
|
69
|
-
catch (err) {
|
|
70
|
-
reject(err);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
};
|
|
76
|
-
const loadAllDocumentsTheBadWay = async () => {
|
|
77
|
-
const path = await tablePath;
|
|
78
|
-
await mkTableDir;
|
|
79
|
-
return new Promise((resolve, reject) => readdir(path, (err, files) => err ?
|
|
80
|
-
reject(err) :
|
|
81
|
-
Promise.all(files.map((file) => load(file)))
|
|
82
|
-
.then((allData) => resolve(allData.filter(guards_1.isDefined)), (err) => reject(err))));
|
|
83
|
-
};
|
|
84
|
-
return {
|
|
85
|
-
loadAllDocumentsTheBadWay,
|
|
86
|
-
getItemsByField: async (key, value, pageKey) => {
|
|
87
|
-
if (!skipAssert)
|
|
88
|
-
(0, fileSystemAssert_1.assertNoUndefined)(value, [key]);
|
|
89
|
-
const pageSize = 10;
|
|
90
|
-
const items = await loadAllDocumentsTheBadWay();
|
|
91
|
-
const filteredItems = items.filter((item) => item[key] === value);
|
|
92
|
-
const startIndex = pageKey ? parseInt(pageKey, 10) : 0;
|
|
93
|
-
const paginatedItems = filteredItems.slice(startIndex, startIndex + pageSize);
|
|
94
|
-
const nextPageToken = startIndex + pageSize < filteredItems.length
|
|
95
|
-
? (startIndex + pageSize).toString()
|
|
96
|
-
: undefined;
|
|
97
|
-
return { items: paginatedItems, nextPageToken };
|
|
98
|
-
},
|
|
99
|
-
batchGetItem: async (ids) => {
|
|
100
|
-
const items = await Promise.all(ids.map((id) => {
|
|
101
|
-
if (!skipAssert)
|
|
102
|
-
(0, fileSystemAssert_1.assertNoUndefined)(id, ['id']);
|
|
103
|
-
return load(hashFilename(id));
|
|
104
|
-
}));
|
|
105
|
-
return items.filter(guards_1.isDefined);
|
|
106
|
-
},
|
|
107
|
-
getItem: (id) => {
|
|
108
|
-
if (!skipAssert)
|
|
109
|
-
(0, fileSystemAssert_1.assertNoUndefined)(id, ['id']);
|
|
110
|
-
return load(hashFilename(id));
|
|
111
|
-
},
|
|
112
|
-
incrementItemAttribute: async (id, attribute) => {
|
|
113
|
-
if (!skipAssert)
|
|
114
|
-
(0, fileSystemAssert_1.assertNoUndefined)(id, ['id']);
|
|
115
|
-
const filename = hashFilename(id);
|
|
116
|
-
const path = await filePath(filename);
|
|
117
|
-
await mkTableDir;
|
|
118
|
-
const data = await load(filename);
|
|
119
|
-
if (!data) {
|
|
120
|
-
throw new errors_1.NotFoundError(`Item with ${hashKey.toString()} "${id}" does not exist`);
|
|
121
|
-
}
|
|
122
|
-
const newValue = typeof data[attribute] === 'number' ? data[attribute] + 1 : 1;
|
|
123
|
-
const newItem = { ...data, [hashKey]: id, [attribute]: newValue };
|
|
124
|
-
return new Promise((resolve, reject) => {
|
|
125
|
-
writeFile(path, JSON.stringify(newItem, null, 2), (err) => err ? reject(err) : resolve(newValue));
|
|
126
|
-
});
|
|
127
|
-
},
|
|
128
|
-
patchItem: async (item) => {
|
|
129
|
-
const id = item[hashKey];
|
|
130
|
-
if (!id) {
|
|
131
|
-
throw new Error(`Key attribute "${hashKey.toString()}" is required for patchItem`);
|
|
132
|
-
}
|
|
133
|
-
// This check is just to make this adapter consistent with the dynamo adapter
|
|
134
|
-
if (Object.keys(item).filter((key) => key !== hashKey.toString()).length === 0) {
|
|
135
|
-
throw new Error('No attributes to update');
|
|
136
|
-
}
|
|
137
|
-
const filename = hashFilename(id);
|
|
138
|
-
const path = await filePath(filename);
|
|
139
|
-
await mkTableDir;
|
|
140
|
-
const data = await load(filename);
|
|
141
|
-
if (!data) {
|
|
142
|
-
throw new errors_1.NotFoundError(`Item with ${hashKey.toString()} "${id}" does not exist`);
|
|
143
|
-
}
|
|
144
|
-
const newItem = { ...data, ...item };
|
|
145
|
-
if (!skipAssert)
|
|
146
|
-
(0, fileSystemAssert_1.assertNoUndefined)(newItem);
|
|
147
|
-
return new Promise((resolve, reject) => {
|
|
148
|
-
writeFile(path, JSON.stringify(newItem, null, 2), (err) => err ? reject(err) : resolve(newItem));
|
|
149
|
-
});
|
|
150
|
-
},
|
|
151
|
-
putItem: async (item) => {
|
|
152
|
-
if (!skipAssert)
|
|
153
|
-
(0, fileSystemAssert_1.assertNoUndefined)(item);
|
|
154
|
-
const path = await filePath(hashFilename(item[hashKey]));
|
|
155
|
-
await mkTableDir;
|
|
156
|
-
return new Promise((resolve, reject) => {
|
|
157
|
-
writeFile(path, JSON.stringify(item, null, 2), (err) => err ? reject(err) : resolve(item));
|
|
158
|
-
});
|
|
159
|
-
},
|
|
160
|
-
createItem: async (item) => {
|
|
161
|
-
if (!skipAssert)
|
|
162
|
-
(0, fileSystemAssert_1.assertNoUndefined)(item);
|
|
163
|
-
const hashed = hashFilename(item[hashKey]);
|
|
164
|
-
const existingItem = await load(hashed);
|
|
165
|
-
if (existingItem) {
|
|
166
|
-
throw new errors_1.ConflictError(`Item with ${String(hashKey)} "${item[hashKey]}" already exists`);
|
|
167
|
-
}
|
|
168
|
-
const path = await filePath(hashed);
|
|
169
|
-
await mkTableDir;
|
|
170
|
-
return new Promise((resolve, reject) => {
|
|
171
|
-
writeFile(path, JSON.stringify(item, null, 2), (err) => err ? reject(err) : resolve(item));
|
|
172
|
-
});
|
|
173
|
-
},
|
|
174
|
-
batchCreateItem: async (items, _concurrency = 1) => {
|
|
175
|
-
var _a;
|
|
176
|
-
if (items.length === 0)
|
|
177
|
-
return { successful: [], failed: [] };
|
|
178
|
-
const successful = [];
|
|
179
|
-
const failed = [];
|
|
180
|
-
// Process items sequentially to ensure consistent conflict detection
|
|
181
|
-
// Note: concurrency parameter is ignored for filesystem to avoid race conditions
|
|
182
|
-
for (const item of items) {
|
|
183
|
-
if (!skipAssert)
|
|
184
|
-
(0, fileSystemAssert_1.assertNoUndefined)(item);
|
|
185
|
-
try {
|
|
186
|
-
const hashed = hashFilename(item[hashKey]);
|
|
187
|
-
const existingItem = await load(hashed);
|
|
188
|
-
if (existingItem) {
|
|
189
|
-
throw new errors_1.ConflictError(`Item with ${String(hashKey)} "${item[hashKey]}" already exists`);
|
|
190
|
-
}
|
|
191
|
-
const path = await filePath(hashed);
|
|
192
|
-
await mkTableDir;
|
|
193
|
-
const createdItem = await new Promise((resolve, reject) => {
|
|
194
|
-
writeFile(path, JSON.stringify(item, null, 2), (err) => err ? reject(err) : resolve(item));
|
|
195
|
-
});
|
|
196
|
-
successful.push(createdItem);
|
|
197
|
-
// Only call individual afterWrite if batchAfterWrite is not defined
|
|
198
|
-
if (!(options === null || options === void 0 ? void 0 : options.batchAfterWrite)) {
|
|
199
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, createdItem));
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
catch (error) {
|
|
203
|
-
failed.push({ item, error: error });
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
// Call batchAfterWrite with all successful items if defined
|
|
207
|
-
if ((options === null || options === void 0 ? void 0 : options.batchAfterWrite) && successful.length > 0) {
|
|
208
|
-
await options.batchAfterWrite(successful);
|
|
209
|
-
}
|
|
210
|
-
return { successful, failed };
|
|
211
|
-
},
|
|
212
|
-
};
|
|
213
|
-
};
|
|
214
|
-
exports.fileSystemUnversionedDocumentStore = fileSystemUnversionedDocumentStore;
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { DynamoDB } from '@aws-sdk/client-dynamodb';
|
|
2
|
-
import { Config } from '..';
|
|
3
|
-
import { ConfigProviderForConfig } from '../../../config';
|
|
4
|
-
import { VersionedDocumentAuthor, VersionedTDocument } from '.';
|
|
5
|
-
interface Initializer<C> {
|
|
6
|
-
configSpace?: C;
|
|
7
|
-
dynamoClient?: DynamoDB;
|
|
8
|
-
}
|
|
9
|
-
export declare const dynamoVersionedDocumentStore: <C extends string = "dynamodb">(initializer?: Initializer<C>) => <T extends VersionedTDocument<T>>() => (configProvider: { [_key in C]: ConfigProviderForConfig<Config>; }) => <K extends keyof T, A extends undefined | ((...a: any[]) => Promise<VersionedDocumentAuthor>)>(_: {}, hashKey: K, options?: {
|
|
10
|
-
afterWrite?: (item: T) => void | Promise<void>;
|
|
11
|
-
getAuthor?: A;
|
|
12
|
-
}) => {
|
|
13
|
-
loadAllDocumentsTheBadWay: () => Promise<T[]>;
|
|
14
|
-
getVersions: (id: T[K], startVersion?: number) => Promise<{
|
|
15
|
-
items: T[];
|
|
16
|
-
nextPageToken: number | undefined;
|
|
17
|
-
} | undefined>;
|
|
18
|
-
getItem: (id: T[K], timestamp?: number) => Promise<T | undefined>;
|
|
19
|
-
prepareItem: (item: Omit<T, "timestamp" | "author">, ...authorArgs: A extends Function ? Parameters<A> : [VersionedDocumentAuthor]) => Promise<{
|
|
20
|
-
document: T;
|
|
21
|
-
save: (changes?: Partial<Omit<T, "timestamp" | "author">>) => Promise<T>;
|
|
22
|
-
}>;
|
|
23
|
-
putItem: (item: Omit<T, "timestamp" | "author">, ...authorArgs: A extends Function ? Parameters<A> : [VersionedDocumentAuthor]) => Promise<T>;
|
|
24
|
-
};
|
|
25
|
-
export {};
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.dynamoVersionedDocumentStore = void 0;
|
|
4
|
-
const client_dynamodb_1 = require("@aws-sdk/client-dynamodb");
|
|
5
|
-
const __1 = require("../../..");
|
|
6
|
-
const config_1 = require("../../../config");
|
|
7
|
-
const guards_1 = require("../../../guards");
|
|
8
|
-
const dynamoEncoding_1 = require("../dynamoEncoding");
|
|
9
|
-
// i'm not really excited about getAuthor being required, but ts is getting confused about the type when unspecified
|
|
10
|
-
const dynamoVersionedDocumentStore = (initializer) => {
|
|
11
|
-
const init = (0, guards_1.ifDefined)(initializer, {});
|
|
12
|
-
const dynamodb = (0, __1.once)(() => { var _a; return (_a = init.dynamoClient) !== null && _a !== void 0 ? _a : new client_dynamodb_1.DynamoDB({ apiVersion: '2012-08-10' }); });
|
|
13
|
-
return () => (configProvider) => (_, hashKey, options) => {
|
|
14
|
-
const tableName = (0, __1.once)(() => (0, config_1.resolveConfigValue)(configProvider[(0, guards_1.ifDefined)(init.configSpace, 'dynamodb')].tableName));
|
|
15
|
-
return {
|
|
16
|
-
loadAllDocumentsTheBadWay: async () => {
|
|
17
|
-
const loadAllResults = async (ExclusiveStartKey) => {
|
|
18
|
-
var _a;
|
|
19
|
-
const cmd = new client_dynamodb_1.ScanCommand({ TableName: await tableName(), ExclusiveStartKey });
|
|
20
|
-
const result = await dynamodb().send(cmd);
|
|
21
|
-
const resultItems = ((_a = result.Items) === null || _a === void 0 ? void 0 : _a.map(dynamoEncoding_1.decodeDynamoDocument)) || [];
|
|
22
|
-
if (result.LastEvaluatedKey) {
|
|
23
|
-
return [...resultItems, ...await loadAllResults(result.LastEvaluatedKey)];
|
|
24
|
-
}
|
|
25
|
-
return resultItems;
|
|
26
|
-
};
|
|
27
|
-
const allResults = await loadAllResults().then(results => results.reduce((result, document) => {
|
|
28
|
-
const current = result.get(document[hashKey]);
|
|
29
|
-
if (!current || current.timestamp < document.timestamp) {
|
|
30
|
-
return result.set(document[hashKey], document);
|
|
31
|
-
}
|
|
32
|
-
return result;
|
|
33
|
-
}, new Map()));
|
|
34
|
-
return Array.from(allResults.values());
|
|
35
|
-
},
|
|
36
|
-
getVersions: async (id, startVersion) => {
|
|
37
|
-
const cmd = new client_dynamodb_1.QueryCommand({
|
|
38
|
-
TableName: await tableName(),
|
|
39
|
-
KeyConditionExpression: '#hk = :hkv',
|
|
40
|
-
ExpressionAttributeValues: {
|
|
41
|
-
':hkv': (0, dynamoEncoding_1.encodeDynamoAttribute)(id)
|
|
42
|
-
},
|
|
43
|
-
ExpressionAttributeNames: {
|
|
44
|
-
'#hk': hashKey.toString()
|
|
45
|
-
},
|
|
46
|
-
...(startVersion
|
|
47
|
-
? { ExclusiveStartKey: {
|
|
48
|
-
[hashKey]: (0, dynamoEncoding_1.encodeDynamoAttribute)(id),
|
|
49
|
-
timestamp: { N: startVersion.toString() }
|
|
50
|
-
} }
|
|
51
|
-
: {}),
|
|
52
|
-
ScanIndexForward: false,
|
|
53
|
-
});
|
|
54
|
-
return dynamodb().send(cmd).then(result => {
|
|
55
|
-
var _a;
|
|
56
|
-
const items = (_a = result.Items) === null || _a === void 0 ? void 0 : _a.map(dynamoEncoding_1.decodeDynamoDocument);
|
|
57
|
-
if (!items || items.length === 0) {
|
|
58
|
-
return undefined;
|
|
59
|
-
}
|
|
60
|
-
return {
|
|
61
|
-
items,
|
|
62
|
-
nextPageToken: result.LastEvaluatedKey ? (0, dynamoEncoding_1.decodeDynamoDocument)(result.LastEvaluatedKey).timestamp : undefined
|
|
63
|
-
};
|
|
64
|
-
});
|
|
65
|
-
},
|
|
66
|
-
getItem: async (id, timestamp) => {
|
|
67
|
-
let keyConditionExpression = '#hk = :hkv';
|
|
68
|
-
const expressionAttributeNames = {
|
|
69
|
-
'#hk': hashKey.toString()
|
|
70
|
-
};
|
|
71
|
-
const expressionAttributeValues = {
|
|
72
|
-
':hkv': (0, dynamoEncoding_1.encodeDynamoAttribute)(id)
|
|
73
|
-
};
|
|
74
|
-
if (timestamp) {
|
|
75
|
-
keyConditionExpression += ' and #ts = :tsv';
|
|
76
|
-
expressionAttributeNames['#ts'] = 'timestamp';
|
|
77
|
-
expressionAttributeValues[':tsv'] = (0, dynamoEncoding_1.encodeDynamoAttribute)(timestamp);
|
|
78
|
-
}
|
|
79
|
-
const cmd = new client_dynamodb_1.QueryCommand({
|
|
80
|
-
TableName: await tableName(),
|
|
81
|
-
KeyConditionExpression: keyConditionExpression,
|
|
82
|
-
ExpressionAttributeNames: expressionAttributeNames,
|
|
83
|
-
ExpressionAttributeValues: expressionAttributeValues,
|
|
84
|
-
ScanIndexForward: false,
|
|
85
|
-
Limit: 1
|
|
86
|
-
});
|
|
87
|
-
return dynamodb().send(cmd).then(result => {
|
|
88
|
-
var _a;
|
|
89
|
-
return (_a = result.Items) === null || _a === void 0 ? void 0 : _a.map(dynamoEncoding_1.decodeDynamoDocument)[0];
|
|
90
|
-
});
|
|
91
|
-
},
|
|
92
|
-
/* prepares a new version of a document with the given data, then allows some additional
|
|
93
|
-
* changes to be input to a `save` function that actually saves it. useful for additional
|
|
94
|
-
* changes based on the new document version or author. the document version and author
|
|
95
|
-
* cannot be modified */
|
|
96
|
-
prepareItem: async (item, ...authorArgs) => {
|
|
97
|
-
// this getAuthor type is terrible
|
|
98
|
-
const author = (options === null || options === void 0 ? void 0 : options.getAuthor) ? await options.getAuthor(...authorArgs) : authorArgs[0];
|
|
99
|
-
const timestamp = new Date().getTime();
|
|
100
|
-
return {
|
|
101
|
-
document: { ...item, timestamp, author },
|
|
102
|
-
save: async (changes) => {
|
|
103
|
-
var _a;
|
|
104
|
-
const document = {
|
|
105
|
-
...item,
|
|
106
|
-
...changes,
|
|
107
|
-
timestamp,
|
|
108
|
-
author
|
|
109
|
-
};
|
|
110
|
-
const cmd = new client_dynamodb_1.PutItemCommand({
|
|
111
|
-
TableName: await tableName(),
|
|
112
|
-
Item: (0, dynamoEncoding_1.encodeDynamoDocument)(document),
|
|
113
|
-
});
|
|
114
|
-
const updatedDoc = await dynamodb().send(cmd)
|
|
115
|
-
.then(() => document);
|
|
116
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, updatedDoc));
|
|
117
|
-
return updatedDoc;
|
|
118
|
-
}
|
|
119
|
-
};
|
|
120
|
-
},
|
|
121
|
-
/* saves a new version of a document with the given data */
|
|
122
|
-
putItem: async (item, ...authorArgs) => {
|
|
123
|
-
var _a;
|
|
124
|
-
// this getAuthor type is terrible
|
|
125
|
-
const author = (options === null || options === void 0 ? void 0 : options.getAuthor) ? await options.getAuthor(...authorArgs) : authorArgs[0];
|
|
126
|
-
const document = {
|
|
127
|
-
...item,
|
|
128
|
-
timestamp: new Date().getTime(),
|
|
129
|
-
author
|
|
130
|
-
};
|
|
131
|
-
const cmd = new client_dynamodb_1.PutItemCommand({
|
|
132
|
-
TableName: await tableName(),
|
|
133
|
-
Item: (0, dynamoEncoding_1.encodeDynamoDocument)(document),
|
|
134
|
-
});
|
|
135
|
-
const updatedDoc = await dynamodb().send(cmd)
|
|
136
|
-
.then(() => document);
|
|
137
|
-
await ((_a = options === null || options === void 0 ? void 0 : options.afterWrite) === null || _a === void 0 ? void 0 : _a.call(options, updatedDoc));
|
|
138
|
-
return updatedDoc;
|
|
139
|
-
},
|
|
140
|
-
};
|
|
141
|
-
};
|
|
142
|
-
};
|
|
143
|
-
exports.dynamoVersionedDocumentStore = dynamoVersionedDocumentStore;
|