@openstax/ts-utils 1.34.0 → 1.35.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/README.md +90 -62
- package/dist/cjs/assertions/index.d.ts +89 -0
- package/dist/cjs/assertions/index.js +157 -0
- package/dist/cjs/aws/ssmService.d.ts +5 -0
- package/dist/cjs/aws/ssmService.js +9 -0
- package/dist/cjs/config/awsParameterConfig.d.ts +10 -0
- package/dist/cjs/config/awsParameterConfig.js +26 -0
- package/dist/cjs/config/envConfig.d.ts +24 -0
- package/dist/cjs/config/envConfig.js +57 -0
- package/{packages/utils/src/config/index.ts → dist/cjs/config/index.d.ts} +13 -29
- package/dist/cjs/config/index.js +35 -0
- package/dist/cjs/config/lambdaParameterConfig.d.ts +12 -0
- package/dist/cjs/config/lambdaParameterConfig.js +45 -0
- package/dist/cjs/config/replaceConfig.d.ts +14 -0
- package/dist/cjs/config/replaceConfig.js +22 -0
- package/dist/cjs/config/resolveConfigValue.d.ts +5 -0
- package/dist/cjs/config/resolveConfigValue.js +12 -0
- package/dist/cjs/errors/index.d.ts +88 -0
- package/dist/cjs/errors/index.js +123 -0
- package/dist/cjs/fetch/fetchStatusRetry.d.ts +8 -0
- package/dist/cjs/fetch/fetchStatusRetry.js +27 -0
- package/dist/cjs/fetch/index.d.ts +64 -0
- package/dist/cjs/fetch/index.js +55 -0
- package/{packages/utils/src/guards/index.ts → dist/cjs/guards/index.d.ts} +7 -10
- package/dist/cjs/guards/index.js +44 -0
- package/dist/cjs/index.js +20 -0
- package/dist/cjs/middleware/apiErrorHandler.d.ts +24 -0
- package/dist/cjs/middleware/apiErrorHandler.js +42 -0
- package/dist/cjs/middleware/apiSlowResponseMiddleware.d.ts +23 -0
- package/dist/cjs/middleware/apiSlowResponseMiddleware.js +54 -0
- package/{packages/utils/src/middleware/index.ts → dist/cjs/middleware/index.d.ts} +5 -53
- package/dist/cjs/middleware/index.js +48 -0
- package/dist/cjs/middleware/lambdaCorsResponseMiddleware.d.ts +20 -0
- package/dist/cjs/middleware/lambdaCorsResponseMiddleware.js +44 -0
- package/dist/cjs/middleware/throwNotFoundMiddleware.d.ts +4 -0
- package/dist/cjs/middleware/throwNotFoundMiddleware.js +14 -0
- package/dist/cjs/misc/hashValue.d.ts +10 -0
- package/dist/cjs/misc/hashValue.js +17 -0
- package/dist/cjs/misc/helpers.d.ts +124 -0
- package/dist/cjs/misc/helpers.js +214 -0
- package/dist/cjs/misc/merge.d.ts +21 -0
- package/dist/cjs/misc/merge.js +45 -0
- package/dist/cjs/misc/partitionSequence.d.ts +35 -0
- package/dist/cjs/misc/partitionSequence.js +55 -0
- package/dist/cjs/pagination/index.d.ts +91 -0
- package/dist/cjs/pagination/index.js +83 -0
- package/dist/cjs/routing/helpers.d.ts +57 -0
- package/dist/cjs/routing/helpers.js +90 -0
- package/dist/cjs/routing/index.d.ts +290 -0
- package/dist/cjs/routing/index.js +295 -0
- package/dist/cjs/routing/validators/zod.d.ts +4 -0
- package/dist/cjs/routing/validators/zod.js +14 -0
- package/dist/cjs/services/accountsGateway/index.d.ts +92 -0
- package/dist/cjs/services/accountsGateway/index.js +138 -0
- package/dist/cjs/services/apiGateway/index.d.ts +68 -0
- package/dist/cjs/services/apiGateway/index.js +118 -0
- package/dist/cjs/services/authProvider/browser.d.ts +40 -0
- package/dist/cjs/services/authProvider/browser.js +155 -0
- package/dist/cjs/services/authProvider/decryption.d.ts +19 -0
- package/dist/cjs/services/authProvider/decryption.js +73 -0
- package/dist/cjs/services/authProvider/index.d.ts +63 -0
- package/dist/cjs/services/authProvider/index.js +34 -0
- package/dist/cjs/services/authProvider/subrequest.d.ts +13 -0
- package/dist/cjs/services/authProvider/subrequest.js +49 -0
- package/dist/cjs/services/authProvider/utils/decryptAndVerify.d.ts +28 -0
- package/dist/cjs/services/authProvider/utils/decryptAndVerify.js +91 -0
- package/dist/cjs/services/authProvider/utils/embeddedAuthProvider.d.ts +26 -0
- package/dist/cjs/services/authProvider/utils/embeddedAuthProvider.js +47 -0
- package/dist/cjs/services/authProvider/utils/userRoleValidator.d.ts +13 -0
- package/dist/cjs/services/authProvider/utils/userRoleValidator.js +37 -0
- package/dist/cjs/services/authProvider/utils/userSubrequest.d.ts +3 -0
- package/dist/cjs/services/authProvider/utils/userSubrequest.js +13 -0
- package/dist/cjs/services/documentStore/dynamoEncoding.d.ts +10 -0
- package/dist/cjs/services/documentStore/dynamoEncoding.js +52 -0
- package/dist/cjs/services/documentStore/fileSystemAssert.d.ts +1 -0
- package/dist/cjs/services/documentStore/fileSystemAssert.js +14 -0
- package/{packages/utils/src/services/documentStore/index.ts → dist/cjs/services/documentStore/index.d.ts} +8 -8
- package/dist/cjs/services/documentStore/index.js +2 -0
- package/dist/cjs/services/documentStore/unversioned/dynamodb.d.ts +31 -0
- package/dist/cjs/services/documentStore/unversioned/dynamodb.js +233 -0
- package/dist/cjs/services/documentStore/unversioned/file-system.d.ts +32 -0
- package/dist/cjs/services/documentStore/unversioned/file-system.js +214 -0
- package/{packages/utils/src/services/documentStore/unversioned/index.ts → dist/cjs/services/documentStore/unversioned/index.d.ts} +0 -2
- package/dist/cjs/services/documentStore/unversioned/index.js +2 -0
- package/dist/cjs/services/documentStore/versioned/dynamodb.d.ts +25 -0
- package/dist/cjs/services/documentStore/versioned/dynamodb.js +143 -0
- package/dist/cjs/services/documentStore/versioned/file-system.d.ts +25 -0
- package/dist/cjs/services/documentStore/versioned/file-system.js +73 -0
- package/dist/cjs/services/documentStore/versioned/index.d.ts +17 -0
- package/dist/cjs/services/documentStore/versioned/index.js +2 -0
- package/dist/cjs/services/exercisesGateway/index.d.ts +67 -0
- package/dist/cjs/services/exercisesGateway/index.js +107 -0
- package/dist/cjs/services/fileServer/index.d.ts +30 -0
- package/dist/cjs/services/fileServer/index.js +19 -0
- package/dist/cjs/services/fileServer/localFileServer.d.ts +13 -0
- package/dist/cjs/services/fileServer/localFileServer.js +132 -0
- package/dist/cjs/services/fileServer/s3FileServer.d.ts +14 -0
- package/dist/cjs/services/fileServer/s3FileServer.js +131 -0
- package/dist/cjs/services/launchParams/index.js +7 -0
- package/dist/cjs/services/launchParams/signer.d.ts +23 -0
- package/dist/cjs/services/launchParams/signer.js +58 -0
- package/dist/cjs/services/launchParams/verifier.d.ts +21 -0
- package/dist/cjs/services/launchParams/verifier.js +129 -0
- package/dist/cjs/services/logger/console.d.ts +4 -0
- package/dist/cjs/services/logger/console.js +12 -0
- package/{packages/utils/src/services/logger/index.ts → dist/cjs/services/logger/index.d.ts} +9 -23
- package/dist/cjs/services/logger/index.js +31 -0
- package/dist/cjs/services/lrsGateway/addStatementDefaultFields.d.ts +5 -0
- package/dist/cjs/services/lrsGateway/addStatementDefaultFields.js +21 -0
- package/dist/cjs/services/lrsGateway/attempt-utils.d.ts +72 -0
- package/dist/cjs/services/lrsGateway/attempt-utils.js +283 -0
- package/dist/cjs/services/lrsGateway/file-system.d.ts +15 -0
- package/dist/cjs/services/lrsGateway/file-system.js +150 -0
- package/dist/cjs/services/lrsGateway/index.d.ts +122 -0
- package/dist/cjs/services/lrsGateway/index.js +148 -0
- package/dist/cjs/services/lrsGateway/xapiUtils.d.ts +71 -0
- package/dist/cjs/services/lrsGateway/xapiUtils.js +145 -0
- package/dist/cjs/services/postgresConnection/index.d.ts +28 -0
- package/dist/cjs/services/postgresConnection/index.js +65 -0
- package/dist/cjs/services/searchProvider/index.d.ts +69 -0
- package/dist/cjs/services/searchProvider/index.js +2 -0
- package/dist/cjs/services/searchProvider/memorySearchTheBadWay.d.ts +20 -0
- package/dist/cjs/services/searchProvider/memorySearchTheBadWay.js +191 -0
- package/dist/cjs/services/searchProvider/openSearch.d.ts +28 -0
- package/dist/cjs/services/searchProvider/openSearch.js +162 -0
- package/dist/cjs/services/searchProvider/streamIndexer.d.ts +17 -0
- package/dist/cjs/services/searchProvider/streamIndexer.js +41 -0
- package/dist/cjs/tsconfig.without-specs.cjs.tsbuildinfo +1 -0
- package/{packages/utils/src/types.ts → dist/cjs/types.d.ts} +6 -34
- package/dist/cjs/types.js +2 -0
- package/dist/esm/assertions/index.d.ts +89 -0
- package/{packages/utils/src/assertions/index.ts → dist/esm/assertions/index.js} +49 -64
- package/dist/esm/aws/ssmService.d.ts +5 -0
- package/dist/esm/aws/ssmService.js +6 -0
- package/dist/esm/config/awsParameterConfig.d.ts +10 -0
- package/dist/esm/config/awsParameterConfig.js +22 -0
- package/dist/esm/config/envConfig.d.ts +24 -0
- package/dist/esm/config/envConfig.js +53 -0
- package/dist/esm/config/index.d.ts +48 -0
- package/dist/esm/config/index.js +17 -0
- package/dist/esm/config/lambdaParameterConfig.d.ts +12 -0
- package/dist/esm/config/lambdaParameterConfig.js +38 -0
- package/dist/esm/config/replaceConfig.d.ts +14 -0
- package/{packages/utils/src/config/replaceConfig.ts → dist/esm/config/replaceConfig.js} +6 -16
- package/dist/esm/config/resolveConfigValue.d.ts +5 -0
- package/dist/esm/config/resolveConfigValue.js +8 -0
- package/dist/esm/errors/index.d.ts +88 -0
- package/{packages/utils/src/errors/index.ts → dist/esm/errors/index.js} +41 -57
- package/dist/esm/fetch/fetchStatusRetry.d.ts +8 -0
- package/dist/esm/fetch/fetchStatusRetry.js +23 -0
- package/dist/esm/fetch/index.d.ts +64 -0
- package/dist/esm/fetch/index.js +46 -0
- package/dist/esm/guards/index.d.ts +38 -0
- package/dist/esm/guards/index.js +36 -0
- package/dist/esm/index.d.ts +4 -0
- package/dist/esm/index.js +4 -0
- package/dist/esm/middleware/apiErrorHandler.d.ts +24 -0
- package/dist/esm/middleware/apiErrorHandler.js +38 -0
- package/dist/esm/middleware/apiSlowResponseMiddleware.d.ts +23 -0
- package/dist/esm/middleware/apiSlowResponseMiddleware.js +50 -0
- package/dist/esm/middleware/index.d.ts +47 -0
- package/dist/esm/middleware/index.js +44 -0
- package/dist/esm/middleware/lambdaCorsResponseMiddleware.d.ts +20 -0
- package/dist/esm/middleware/lambdaCorsResponseMiddleware.js +40 -0
- package/dist/esm/middleware/throwNotFoundMiddleware.d.ts +4 -0
- package/dist/esm/middleware/throwNotFoundMiddleware.js +10 -0
- package/dist/esm/misc/hashValue.d.ts +10 -0
- package/dist/esm/misc/hashValue.js +13 -0
- package/dist/esm/misc/helpers.d.ts +124 -0
- package/dist/esm/misc/helpers.js +199 -0
- package/dist/esm/misc/merge.d.ts +21 -0
- package/dist/esm/misc/merge.js +40 -0
- package/dist/esm/misc/partitionSequence.d.ts +35 -0
- package/{packages/utils/src/misc/partitionSequence.ts → dist/esm/misc/partitionSequence.js} +15 -23
- package/dist/esm/pagination/index.d.ts +91 -0
- package/dist/esm/pagination/index.js +77 -0
- package/dist/esm/routing/helpers.d.ts +57 -0
- package/{packages/utils/src/routing/helpers.ts → dist/esm/routing/helpers.js} +30 -42
- package/dist/esm/routing/index.d.ts +290 -0
- package/dist/esm/routing/index.js +246 -0
- package/dist/esm/routing/validators/zod.d.ts +4 -0
- package/dist/esm/routing/validators/zod.js +10 -0
- package/dist/esm/services/accountsGateway/index.d.ts +92 -0
- package/dist/esm/services/accountsGateway/index.js +131 -0
- package/dist/esm/services/apiGateway/index.d.ts +68 -0
- package/dist/esm/services/apiGateway/index.js +77 -0
- package/dist/esm/services/authProvider/browser.d.ts +40 -0
- package/dist/esm/services/authProvider/browser.js +151 -0
- package/dist/esm/services/authProvider/decryption.d.ts +19 -0
- package/dist/esm/services/authProvider/decryption.js +69 -0
- package/dist/esm/services/authProvider/index.d.ts +63 -0
- package/dist/esm/services/authProvider/index.js +26 -0
- package/dist/esm/services/authProvider/subrequest.d.ts +13 -0
- package/dist/esm/services/authProvider/subrequest.js +45 -0
- package/dist/esm/services/authProvider/utils/decryptAndVerify.d.ts +28 -0
- package/dist/esm/services/authProvider/utils/decryptAndVerify.js +85 -0
- package/dist/esm/services/authProvider/utils/embeddedAuthProvider.d.ts +26 -0
- package/dist/esm/services/authProvider/utils/embeddedAuthProvider.js +40 -0
- package/dist/esm/services/authProvider/utils/userRoleValidator.d.ts +13 -0
- package/dist/esm/services/authProvider/utils/userRoleValidator.js +33 -0
- package/dist/esm/services/authProvider/utils/userSubrequest.d.ts +3 -0
- package/dist/esm/services/authProvider/utils/userSubrequest.js +6 -0
- package/dist/esm/services/documentStore/dynamoEncoding.d.ts +10 -0
- package/dist/esm/services/documentStore/dynamoEncoding.js +45 -0
- package/dist/esm/services/documentStore/fileSystemAssert.d.ts +1 -0
- package/dist/esm/services/documentStore/fileSystemAssert.js +10 -0
- package/dist/esm/services/documentStore/index.d.ts +14 -0
- package/dist/esm/services/documentStore/index.js +1 -0
- package/dist/esm/services/documentStore/unversioned/dynamodb.d.ts +31 -0
- package/dist/esm/services/documentStore/unversioned/dynamodb.js +226 -0
- package/dist/esm/services/documentStore/unversioned/file-system.d.ts +32 -0
- package/dist/esm/services/documentStore/unversioned/file-system.js +174 -0
- package/dist/esm/services/documentStore/unversioned/index.d.ts +2 -0
- package/dist/esm/services/documentStore/unversioned/index.js +1 -0
- package/dist/esm/services/documentStore/versioned/dynamodb.d.ts +25 -0
- package/dist/esm/services/documentStore/versioned/dynamodb.js +139 -0
- package/dist/esm/services/documentStore/versioned/file-system.d.ts +25 -0
- package/dist/esm/services/documentStore/versioned/file-system.js +69 -0
- package/dist/esm/services/documentStore/versioned/index.d.ts +17 -0
- package/dist/esm/services/documentStore/versioned/index.js +1 -0
- package/dist/esm/services/exercisesGateway/index.d.ts +67 -0
- package/dist/esm/services/exercisesGateway/index.js +70 -0
- package/dist/esm/services/fileServer/index.d.ts +30 -0
- package/dist/esm/services/fileServer/index.js +13 -0
- package/dist/esm/services/fileServer/localFileServer.d.ts +13 -0
- package/dist/esm/services/fileServer/localFileServer.js +125 -0
- package/dist/esm/services/fileServer/s3FileServer.d.ts +14 -0
- package/dist/esm/services/fileServer/s3FileServer.js +124 -0
- package/dist/esm/services/launchParams/index.d.ts +2 -0
- package/dist/esm/services/launchParams/index.js +2 -0
- package/dist/esm/services/launchParams/signer.d.ts +23 -0
- package/dist/esm/services/launchParams/signer.js +51 -0
- package/dist/esm/services/launchParams/verifier.d.ts +21 -0
- package/dist/esm/services/launchParams/verifier.js +92 -0
- package/dist/esm/services/logger/console.d.ts +4 -0
- package/{packages/utils/src/services/logger/console.ts → dist/esm/services/logger/console.js} +2 -5
- package/dist/esm/services/logger/index.d.ts +39 -0
- package/dist/esm/services/logger/index.js +27 -0
- package/dist/esm/services/lrsGateway/addStatementDefaultFields.d.ts +5 -0
- package/dist/esm/services/lrsGateway/addStatementDefaultFields.js +14 -0
- package/dist/esm/services/lrsGateway/attempt-utils.d.ts +72 -0
- package/dist/esm/services/lrsGateway/attempt-utils.js +261 -0
- package/dist/esm/services/lrsGateway/file-system.d.ts +15 -0
- package/dist/esm/services/lrsGateway/file-system.js +110 -0
- package/dist/esm/services/lrsGateway/index.d.ts +122 -0
- package/dist/esm/services/lrsGateway/index.js +111 -0
- package/dist/esm/services/lrsGateway/xapiUtils.d.ts +71 -0
- package/dist/esm/services/lrsGateway/xapiUtils.js +134 -0
- package/dist/esm/services/postgresConnection/index.d.ts +28 -0
- package/dist/esm/services/postgresConnection/index.js +58 -0
- package/dist/esm/services/searchProvider/index.d.ts +69 -0
- package/dist/esm/services/searchProvider/index.js +1 -0
- package/dist/esm/services/searchProvider/memorySearchTheBadWay.d.ts +20 -0
- package/dist/esm/services/searchProvider/memorySearchTheBadWay.js +187 -0
- package/dist/esm/services/searchProvider/openSearch.d.ts +28 -0
- package/dist/esm/services/searchProvider/openSearch.js +158 -0
- package/dist/esm/services/searchProvider/streamIndexer.d.ts +17 -0
- package/dist/esm/services/searchProvider/streamIndexer.js +37 -0
- package/dist/esm/tsconfig.without-specs.esm.tsbuildinfo +1 -0
- package/dist/esm/types.d.ts +31 -0
- package/dist/esm/types.js +1 -0
- package/package.json +234 -12
- package/.cfnlintrc +0 -2
- package/.github/CODEOWNERS +0 -1
- package/.github/workflows/ci.yml +0 -36
- package/.github/workflows/lint.yml +0 -55
- package/.nvmrc +0 -1
- package/.syncignore +0 -4
- package/.syncpackrc +0 -18
- package/CONTRIBUTING.md +0 -96
- package/LICENSE +0 -661
- package/Procfile +0 -1
- package/app.json +0 -23
- package/cspell.json +0 -32
- package/deploy/constants.env +0 -21
- package/deploy/deploy.bash +0 -157
- package/deploy/deployment-alt-region.cfn.yml +0 -70
- package/deploy/deployment.cfn.yml +0 -650
- package/deploy/destroy-deployment.bash +0 -23
- package/deploy/shared.cfn.yml +0 -94
- package/docs/lambda-build.md +0 -35
- package/packages/frontend/README.md +0 -46
- package/packages/frontend/package.json +0 -101
- package/packages/frontend/public/favicon.ico +0 -0
- package/packages/frontend/public/index.html +0 -107
- package/packages/frontend/public/maintenance.html +0 -59
- package/packages/frontend/public/manifest.json +0 -15
- package/packages/frontend/public/robots.txt +0 -3
- package/packages/frontend/script/make-certificate.bash +0 -49
- package/packages/frontend/script/server/cli.js +0 -11
- package/packages/frontend/script/server/index.js +0 -47
- package/packages/frontend/script/start.bash +0 -22
- package/packages/frontend/script/trust-localhost.bash +0 -7
- package/packages/frontend/src/auth/authProvider.ts +0 -10
- package/packages/frontend/src/auth/useAuth.ts +0 -33
- package/packages/frontend/src/components/Pagination.tsx +0 -26
- package/packages/frontend/src/configProvider/index.ts +0 -53
- package/packages/frontend/src/configProvider/use.ts +0 -41
- package/packages/frontend/src/core/context/services.spec.tsx +0 -39
- package/packages/frontend/src/core/context/services.tsx +0 -16
- package/packages/frontend/src/core/index.spec.ts +0 -7
- package/packages/frontend/src/core/index.ts +0 -20
- package/packages/frontend/src/core/services.tsx +0 -14
- package/packages/frontend/src/core/types.ts +0 -3
- package/packages/frontend/src/example/api.ts +0 -28
- package/packages/frontend/src/example/components/Layout.tsx +0 -23
- package/packages/frontend/src/example/screens/Home.spec.tsx +0 -68
- package/packages/frontend/src/example/screens/Home.tsx +0 -78
- package/packages/frontend/src/example/screens/ThingList.spec.tsx +0 -60
- package/packages/frontend/src/example/screens/ThingList.tsx +0 -75
- package/packages/frontend/src/example/screens/ThingView.spec.tsx +0 -71
- package/packages/frontend/src/example/screens/ThingView.tsx +0 -47
- package/packages/frontend/src/example/screens/index.ts +0 -9
- package/packages/frontend/src/index.css +0 -159
- package/packages/frontend/src/index.tsx +0 -67
- package/packages/frontend/src/react-app-env.d.ts +0 -1
- package/packages/frontend/src/routing/components/RouteLink.spec.tsx +0 -55
- package/packages/frontend/src/routing/components/RouteLink.tsx +0 -35
- package/packages/frontend/src/routing/middleware.ts +0 -6
- package/packages/frontend/src/routing/useQuery.ts +0 -14
- package/packages/frontend/src/setupProxy.js +0 -19
- package/packages/frontend/src/setupTests.ts +0 -9
- package/packages/frontend/src/tests/testServices.tsx +0 -23
- package/packages/frontend/tsconfig.json +0 -27
- package/packages/lambda/.eslintrc.js +0 -64
- package/packages/lambda/jest-global-setup.js +0 -3
- package/packages/lambda/jest-setup-after-env.js +0 -1
- package/packages/lambda/jest.config.js +0 -31
- package/packages/lambda/jest.resolver.js +0 -17
- package/packages/lambda/package.json +0 -68
- package/packages/lambda/script/build.bash +0 -19
- package/packages/lambda/script/bundle-functions.bash +0 -10
- package/packages/lambda/script/lambdaLocalProxy.js +0 -16
- package/packages/lambda/script/lambdaLocalProxy.spec.ts +0 -147
- package/packages/lambda/script/utils/getRouteData.ts +0 -7
- package/packages/lambda/script/utils/routeDataLoader.js +0 -8
- package/packages/lambda/script/utils/routeDataLoader.spec.ts +0 -8
- package/packages/lambda/src/functions/serviceApi/core/index.ts +0 -7
- package/packages/lambda/src/functions/serviceApi/core/request.spec.ts +0 -38
- package/packages/lambda/src/functions/serviceApi/core/request.ts +0 -42
- package/packages/lambda/src/functions/serviceApi/core/routes.spec.ts +0 -7
- package/packages/lambda/src/functions/serviceApi/core/routes.ts +0 -10
- package/packages/lambda/src/functions/serviceApi/core/services.ts +0 -9
- package/packages/lambda/src/functions/serviceApi/core/types.ts +0 -13
- package/packages/lambda/src/functions/serviceApi/entry/lambda/https-xray.ts +0 -4
- package/packages/lambda/src/functions/serviceApi/entry/lambda/index.spec.ts +0 -48
- package/packages/lambda/src/functions/serviceApi/entry/lambda/index.ts +0 -58
- package/packages/lambda/src/functions/serviceApi/entry/lambda/services.ts +0 -36
- package/packages/lambda/src/functions/serviceApi/entry/local.ts +0 -71
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentSearchMiddleware.spec.ts +0 -16
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentSearchMiddleware.ts +0 -41
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentStoreMiddleware.spec.ts +0 -78
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentStoreMiddleware.ts +0 -70
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/routes.spec.ts +0 -306
- package/packages/lambda/src/functions/serviceApi/versions/v0/example/routes.ts +0 -176
- package/packages/lambda/src/functions/serviceApi/versions/v0/index.spec.ts +0 -263
- package/packages/lambda/src/functions/serviceApi/versions/v0/index.ts +0 -134
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/authMiddleware.spec.ts +0 -23
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/authMiddleware.ts +0 -32
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/configMiddleware.spec.ts +0 -10
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/configMiddleware.ts +0 -7
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/frontendFileServerMiddleware.spec.ts +0 -13
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/frontendFileServerMiddleware.ts +0 -23
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/paginationMiddleware.spec.ts +0 -9
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/paginationMiddleware.ts +0 -9
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/searchMiddleware.spec.ts +0 -12
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/searchMiddleware.ts +0 -21
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/userRoleValidatorMiddleware.spec.ts +0 -21
- package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/userRoleValidatorMiddleware.ts +0 -18
- package/packages/lambda/tsconfig.json +0 -30
- package/packages/lambda/webpack.config.js +0 -97
- package/packages/utils/.eslintrc.js +0 -64
- package/packages/utils/README.md +0 -118
- package/packages/utils/jest-global-setup.js +0 -3
- package/packages/utils/jest.config.js +0 -25
- package/packages/utils/jest.resolver.js +0 -17
- package/packages/utils/package.json +0 -238
- package/packages/utils/src/assertions/index.spec.ts +0 -126
- package/packages/utils/src/aws/ssmService.ts +0 -7
- package/packages/utils/src/config/awsParameterConfig.ts +0 -24
- package/packages/utils/src/config/envConfig.ts +0 -58
- package/packages/utils/src/config/index.spec.ts +0 -165
- package/packages/utils/src/config/lambdaParameterConfig.ts +0 -49
- package/packages/utils/src/config/resolveConfigValue.ts +0 -10
- package/packages/utils/src/errors/index.spec.ts +0 -35
- package/packages/utils/src/fetch/fetchStatusRetry.spec.ts +0 -197
- package/packages/utils/src/fetch/fetchStatusRetry.ts +0 -33
- package/packages/utils/src/fetch/index.spec.ts +0 -34
- package/packages/utils/src/fetch/index.ts +0 -87
- package/packages/utils/src/guards/index.spec.ts +0 -58
- package/packages/utils/src/index.spec.ts +0 -471
- package/packages/utils/src/middleware/apiErrorHandler.spec.ts +0 -65
- package/packages/utils/src/middleware/apiErrorHandler.ts +0 -67
- package/packages/utils/src/middleware/apiSlowResponseMiddleware.spec.ts +0 -184
- package/packages/utils/src/middleware/apiSlowResponseMiddleware.ts +0 -71
- package/packages/utils/src/middleware/index.spec.ts +0 -99
- package/packages/utils/src/middleware/lambdaCorsResponseMiddleware.spec.ts +0 -103
- package/packages/utils/src/middleware/lambdaCorsResponseMiddleware.ts +0 -52
- package/packages/utils/src/middleware/throwNotFoundMiddleware.spec.ts +0 -20
- package/packages/utils/src/middleware/throwNotFoundMiddleware.ts +0 -11
- package/packages/utils/src/misc/hashValue.ts +0 -18
- package/packages/utils/src/misc/helpers.ts +0 -259
- package/packages/utils/src/misc/merge.ts +0 -48
- package/packages/utils/src/pagination/index.spec.ts +0 -150
- package/packages/utils/src/pagination/index.ts +0 -117
- package/packages/utils/src/routing/index.spec.ts +0 -553
- package/packages/utils/src/routing/index.ts +0 -424
- package/packages/utils/src/routing/validators/zod.spec.ts +0 -16
- package/packages/utils/src/routing/validators/zod.ts +0 -14
- package/packages/utils/src/services/accountsGateway/README.md +0 -3
- package/packages/utils/src/services/accountsGateway/index.spec.ts +0 -518
- package/packages/utils/src/services/accountsGateway/index.ts +0 -251
- package/packages/utils/src/services/apiGateway/README.md +0 -93
- package/packages/utils/src/services/apiGateway/index.spec.ts +0 -254
- package/packages/utils/src/services/apiGateway/index.ts +0 -189
- package/packages/utils/src/services/authProvider/README.md +0 -21
- package/packages/utils/src/services/authProvider/browser.spec.ts +0 -391
- package/packages/utils/src/services/authProvider/browser.ts +0 -209
- package/packages/utils/src/services/authProvider/decryption.spec.ts +0 -337
- package/packages/utils/src/services/authProvider/decryption.ts +0 -98
- package/packages/utils/src/services/authProvider/index.ts +0 -93
- package/packages/utils/src/services/authProvider/stub.spec.ts +0 -29
- package/packages/utils/src/services/authProvider/subrequest.spec.ts +0 -105
- package/packages/utils/src/services/authProvider/subrequest.ts +0 -68
- package/packages/utils/src/services/authProvider/utils/decryptAndVerify.spec.ts +0 -128
- package/packages/utils/src/services/authProvider/utils/decryptAndVerify.ts +0 -106
- package/packages/utils/src/services/authProvider/utils/embeddedAuthProvider.spec.ts +0 -26
- package/packages/utils/src/services/authProvider/utils/embeddedAuthProvider.ts +0 -57
- package/packages/utils/src/services/authProvider/utils/userRoleValidator.spec.ts +0 -135
- package/packages/utils/src/services/authProvider/utils/userRoleValidator.ts +0 -49
- package/packages/utils/src/services/authProvider/utils/userSubrequest.spec.ts +0 -26
- package/packages/utils/src/services/authProvider/utils/userSubrequest.ts +0 -10
- package/packages/utils/src/services/documentStore/dynamoEncoding.ts +0 -57
- package/packages/utils/src/services/documentStore/fileSystemAssert.spec.ts +0 -43
- package/packages/utils/src/services/documentStore/fileSystemAssert.ts +0 -10
- package/packages/utils/src/services/documentStore/unversioned/README.md +0 -13
- package/packages/utils/src/services/documentStore/unversioned/dynamodb.spec.ts +0 -859
- package/packages/utils/src/services/documentStore/unversioned/dynamodb.ts +0 -243
- package/packages/utils/src/services/documentStore/unversioned/file-system.spec.ts +0 -629
- package/packages/utils/src/services/documentStore/unversioned/file-system.ts +0 -194
- package/packages/utils/src/services/documentStore/versioned/README.md +0 -13
- package/packages/utils/src/services/documentStore/versioned/dynamodb.spec.ts +0 -376
- package/packages/utils/src/services/documentStore/versioned/dynamodb.ts +0 -167
- package/packages/utils/src/services/documentStore/versioned/file-system.spec.ts +0 -262
- package/packages/utils/src/services/documentStore/versioned/file-system.ts +0 -90
- package/packages/utils/src/services/documentStore/versioned/index.ts +0 -25
- package/packages/utils/src/services/exercisesGateway/README.md +0 -5
- package/packages/utils/src/services/exercisesGateway/index.spec.ts +0 -326
- package/packages/utils/src/services/exercisesGateway/index.ts +0 -163
- package/packages/utils/src/services/fileServer/index.spec.ts +0 -88
- package/packages/utils/src/services/fileServer/index.ts +0 -43
- package/packages/utils/src/services/fileServer/localFileServer.spec.ts +0 -182
- package/packages/utils/src/services/fileServer/localFileServer.ts +0 -159
- package/packages/utils/src/services/fileServer/s3FileServer.spec.ts +0 -266
- package/packages/utils/src/services/fileServer/s3FileServer.ts +0 -155
- package/packages/utils/src/services/launchParams/index.spec.ts +0 -366
- package/packages/utils/src/services/launchParams/signer.ts +0 -73
- package/packages/utils/src/services/launchParams/verifier.ts +0 -120
- package/packages/utils/src/services/logger/console.spec.ts +0 -29
- package/packages/utils/src/services/logger/index.spec.ts +0 -65
- package/packages/utils/src/services/lrsGateway/README.md +0 -5
- package/packages/utils/src/services/lrsGateway/addStatementDefaultFields.ts +0 -22
- package/packages/utils/src/services/lrsGateway/attempt-utils.spec.ts +0 -847
- package/packages/utils/src/services/lrsGateway/attempt-utils.ts +0 -358
- package/packages/utils/src/services/lrsGateway/file-system.spec.ts +0 -363
- package/packages/utils/src/services/lrsGateway/file-system.ts +0 -165
- package/packages/utils/src/services/lrsGateway/index.spec.ts +0 -194
- package/packages/utils/src/services/lrsGateway/index.ts +0 -257
- package/packages/utils/src/services/lrsGateway/xapiUtils.spec.ts +0 -887
- package/packages/utils/src/services/lrsGateway/xapiUtils.ts +0 -262
- package/packages/utils/src/services/postgresConnection/index.spec.ts +0 -170
- package/packages/utils/src/services/postgresConnection/index.ts +0 -84
- package/packages/utils/src/services/searchProvider/README.md +0 -3
- package/packages/utils/src/services/searchProvider/index.ts +0 -59
- package/packages/utils/src/services/searchProvider/memorySearchTheBadWay.spec.ts +0 -526
- package/packages/utils/src/services/searchProvider/memorySearchTheBadWay.ts +0 -223
- package/packages/utils/src/services/searchProvider/openSearch.spec.ts +0 -926
- package/packages/utils/src/services/searchProvider/openSearch.ts +0 -195
- package/packages/utils/tsconfig.json +0 -31
- package/packages/utils/tsconfig.without-specs.cjs.json +0 -7
- package/packages/utils/tsconfig.without-specs.esm.json +0 -7
- package/packages/utils/tsconfig.without-specs.json +0 -6
- package/scripts/build.bash +0 -24
- package/scripts/ci.bash +0 -10
- package/scripts/start.bash +0 -29
- /package/{packages/utils/src/index.ts → dist/cjs/index.d.ts} +0 -0
- /package/{packages/utils/src/services/launchParams/index.ts → dist/cjs/services/launchParams/index.d.ts} +0 -0
- /package/{packages/utils/script → script}/bin/copy-from-template.bash +0 -0
- /package/{packages/utils/script → script}/bin/delete-stack.bash +0 -0
- /package/{packages/utils/script → script}/bin/deploy.bash +0 -0
- /package/{packages/utils/script → script}/bin/destroy-deployment.bash +0 -0
- /package/{packages/utils/script → script}/bin/empty-bucket.bash +0 -0
- /package/{packages/utils/script → script}/bin/get-arg.bash +0 -0
- /package/{packages/utils/script → script}/bin/get-deployed-environments.bash +0 -0
- /package/{packages/utils/script → script}/bin/get-env-param.bash +0 -0
- /package/{packages/utils/script → script}/bin/get-kwarg.bash +0 -0
- /package/{packages/utils/script → script}/bin/get-stack-param.bash +0 -0
- /package/{packages/utils/script → script}/bin/has-flag.bash +0 -0
- /package/{packages/utils/script → script}/bin/init-constants-script.bash +0 -0
- /package/{packages/utils/script → script}/bin/init-params-script.bash +0 -0
- /package/{packages/utils/script → script}/bin/stack-exists.bash +0 -0
- /package/{packages/utils/script → script}/bin/update-utils.bash +0 -0
- /package/{packages/utils/script → script}/bin/upload-pager-duty-endpoints.bash +0 -0
- /package/{packages/utils/script → script}/bin/upload-params.bash +0 -0
- /package/{packages/utils/script → script}/bin/which.bash +0 -0
- /package/{packages/utils/script → script}/bin-entry.bash +0 -0
- /package/{packages/utils/script → script}/build.bash +0 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createErrorHandler = exports.defaultHandlers = void 0;
|
|
4
|
+
const errors_1 = require("../errors");
|
|
5
|
+
const routing_1 = require("../routing");
|
|
6
|
+
const logger_1 = require("../services/logger");
|
|
7
|
+
exports.defaultHandlers = {
|
|
8
|
+
InvalidRequestError: (e) => (0, routing_1.apiTextResponse)(400, `400 ${e.message}`),
|
|
9
|
+
UnauthorizedError: (e) => (0, routing_1.apiTextResponse)(401, `401 ${e.message}`),
|
|
10
|
+
ForbiddenError: (e) => (0, routing_1.apiTextResponse)(403, `403 ${e.message}`),
|
|
11
|
+
NotFoundError: (e) => (0, routing_1.apiTextResponse)(404, `404 ${e.message}`),
|
|
12
|
+
ValidationError: (e) => (0, routing_1.apiJsonResponse)(422, e.getData()),
|
|
13
|
+
SessionExpiredError: (e) => (0, routing_1.apiTextResponse)(440, `440 ${e.message}`),
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Creates an error handler. Provides default handlers for `UnauthorizedError`,
|
|
17
|
+
* `SessionExpiredError`, `NotFoundError`, and `InvalidRequestError`. User-specified
|
|
18
|
+
* handlers can be added to these. If no handler is found, the error is logged and
|
|
19
|
+
* a 500 text response is returned.
|
|
20
|
+
*
|
|
21
|
+
* @param inputHandlers a map of errors to handler functions
|
|
22
|
+
*/
|
|
23
|
+
const createErrorHandler = (inputHandlers) => {
|
|
24
|
+
const handlers = { ...exports.defaultHandlers, ...inputHandlers };
|
|
25
|
+
return async (e, logger) => {
|
|
26
|
+
const name = (0, errors_1.isAppError)(e) ? e.constructor.TYPE : e.constructor.name;
|
|
27
|
+
const handler = handlers[name];
|
|
28
|
+
const logLevel = handler ? logger_1.Level.Info : logger_1.Level.Error;
|
|
29
|
+
logger.logEvent(logLevel, {
|
|
30
|
+
name: e.name,
|
|
31
|
+
message: e.message,
|
|
32
|
+
stack: e.stack,
|
|
33
|
+
});
|
|
34
|
+
if (handler) {
|
|
35
|
+
// convincing typescript that this error is the right kind for the handler
|
|
36
|
+
// we looked up based on the errors name is very annoying
|
|
37
|
+
return handler(e, logger);
|
|
38
|
+
}
|
|
39
|
+
return (0, routing_1.apiTextResponse)(500, '500 Error');
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
exports.createErrorHandler = createErrorHandler;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { ConfigProviderForConfig } from '../config';
|
|
2
|
+
import type { ApiResponse } from '../routing';
|
|
3
|
+
import type { Logger } from '../services/logger';
|
|
4
|
+
type Config = {
|
|
5
|
+
logResponseSlowerThan: string;
|
|
6
|
+
timeoutResponseAfter: string;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Creates response middleware that logs slow responses and times out responses that take too long. lambda functions have a timeout setting, but when a lambda times out there is no way to log anything helpful before it exists. this middleware allows the logger context to show up for timeout requests. just make sure that the `timeoutResponseAfter` is set to something slightly shorter than the lambda timeout so that it has time to run.
|
|
10
|
+
*
|
|
11
|
+
* @param config
|
|
12
|
+
* @param config.logResponseSlowerThan the config that specifies the threshold for a slow response
|
|
13
|
+
* @param config.timeoutResponseAfter the config that specifies the timeout for a response
|
|
14
|
+
* @example
|
|
15
|
+
* createSlowResponseMiddleware({
|
|
16
|
+
* logResponseSlowerThan: envConfig('LOG_SLOW_RESPONSE', 'runtime', '1000'),
|
|
17
|
+
* timeoutResponseAfter: envConfig('RESPONSE_TIMEOUT', 'runtime', '28000'),
|
|
18
|
+
* });
|
|
19
|
+
*/
|
|
20
|
+
export declare const createSlowResponseMiddleware: (config: ConfigProviderForConfig<Config>) => () => (response: Promise<ApiResponse<number, any>> | undefined, { logger }: {
|
|
21
|
+
logger: Logger;
|
|
22
|
+
}) => Promise<ApiResponse<number, string>> | undefined;
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createSlowResponseMiddleware = void 0;
|
|
4
|
+
const resolveConfigValue_1 = require("../config/resolveConfigValue");
|
|
5
|
+
const helpers_1 = require("../misc/helpers");
|
|
6
|
+
const routing_1 = require("../routing");
|
|
7
|
+
const logger_1 = require("../services/logger");
|
|
8
|
+
/**
|
|
9
|
+
* Creates response middleware that logs slow responses and times out responses that take too long. lambda functions have a timeout setting, but when a lambda times out there is no way to log anything helpful before it exists. this middleware allows the logger context to show up for timeout requests. just make sure that the `timeoutResponseAfter` is set to something slightly shorter than the lambda timeout so that it has time to run.
|
|
10
|
+
*
|
|
11
|
+
* @param config
|
|
12
|
+
* @param config.logResponseSlowerThan the config that specifies the threshold for a slow response
|
|
13
|
+
* @param config.timeoutResponseAfter the config that specifies the timeout for a response
|
|
14
|
+
* @example
|
|
15
|
+
* createSlowResponseMiddleware({
|
|
16
|
+
* logResponseSlowerThan: envConfig('LOG_SLOW_RESPONSE', 'runtime', '1000'),
|
|
17
|
+
* timeoutResponseAfter: envConfig('RESPONSE_TIMEOUT', 'runtime', '28000'),
|
|
18
|
+
* });
|
|
19
|
+
*/
|
|
20
|
+
const createSlowResponseMiddleware = (config) => {
|
|
21
|
+
const getSlowThreshold = (0, helpers_1.once)(() => (0, resolveConfigValue_1.resolveConfigValue)(config.logResponseSlowerThan).then(result => parseInt(result, 10)));
|
|
22
|
+
const getTimeoutAfter = (0, helpers_1.once)(() => (0, resolveConfigValue_1.resolveConfigValue)(config.timeoutResponseAfter).then(result => parseInt(result, 10)));
|
|
23
|
+
return () => (response, { logger }) => {
|
|
24
|
+
const start = Date.now();
|
|
25
|
+
if (!response) {
|
|
26
|
+
return response;
|
|
27
|
+
}
|
|
28
|
+
return Promise.all([getSlowThreshold(), getTimeoutAfter()]).then(([slowThreshold, timeoutAfter]) => {
|
|
29
|
+
let timeout = undefined;
|
|
30
|
+
const timeoutPromise = isNaN(timeoutAfter)
|
|
31
|
+
? undefined
|
|
32
|
+
: new Promise(resolve => timeout = setTimeout(() => {
|
|
33
|
+
logger.logEvent(logger_1.Level.Error, {
|
|
34
|
+
message: 'request processing timed out',
|
|
35
|
+
});
|
|
36
|
+
resolve((0, routing_1.apiTextResponse)(504, '504 Gateway Timeout'));
|
|
37
|
+
}, timeoutAfter));
|
|
38
|
+
const requestPromise = response.finally(() => {
|
|
39
|
+
const time = Date.now() - start;
|
|
40
|
+
if (timeout !== undefined) {
|
|
41
|
+
clearTimeout(timeout);
|
|
42
|
+
}
|
|
43
|
+
if (time > slowThreshold) {
|
|
44
|
+
logger.logEvent(logger_1.Level.Warn, {
|
|
45
|
+
message: 'slow response',
|
|
46
|
+
time,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
return timeoutPromise ? Promise.race([timeoutPromise, requestPromise]) : requestPromise;
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
exports.createSlowResponseMiddleware = createSlowResponseMiddleware;
|
|
@@ -1,51 +1,11 @@
|
|
|
1
1
|
import { TupleZip } from '../types';
|
|
2
|
-
|
|
3
|
-
// this is a more standard flow provider that takes input and produces an unrelated output
|
|
4
|
-
export type MiddlewareProvider<Sa, M, A extends any[], R> = (
|
|
5
|
-
app: Sa,
|
|
6
|
-
appBinder?: ((app: Sa, provider: MiddlewareProvider<Sa, M, A, R>) => (middleware: M, ...args: A) => R)
|
|
7
|
-
) => (middleware: M, ...args: A) => R;
|
|
8
|
-
|
|
9
|
-
// this detects generics that forward the input to the output while modifying or adding properties
|
|
2
|
+
export type MiddlewareProvider<Sa, M, A extends any[], R> = (app: Sa, appBinder?: ((app: Sa, provider: MiddlewareProvider<Sa, M, A, R>) => (middleware: M, ...args: A) => R)) => (middleware: M, ...args: A) => R;
|
|
10
3
|
export type MiddlewareTransformProvider<Sa, M, A extends any[], R> = (app: Sa) => (middleware: M, ...args: A) => Omit<M, keyof R> & R;
|
|
11
|
-
|
|
12
4
|
export type MiddlewareInput<S> = S extends MiddlewareProvider<any, infer M, any, any> ? M : never;
|
|
13
|
-
|
|
14
|
-
export type ServiceMiddlewareProviderResult<M, S> = [M] extends [never]
|
|
15
|
-
? never
|
|
16
|
-
: [M] extends [MiddlewareInput<S>]
|
|
17
|
-
? S extends MiddlewareTransformProvider<any, M, any, infer R>
|
|
18
|
-
? (Omit<R, keyof M> & M) extends R
|
|
19
|
-
? Omit<R, keyof M> & M // if R includes any keys from M, the M keys are more specific, use M
|
|
20
|
-
: R extends M
|
|
21
|
-
? R // R is a more specific version of M, use R
|
|
22
|
-
: Omit<M, keyof R> & R // R overwrites some type from M, use R
|
|
23
|
-
: S extends MiddlewareProvider<any, M, any, infer R>
|
|
24
|
-
? R
|
|
25
|
-
: never
|
|
26
|
-
: never;
|
|
27
|
-
|
|
5
|
+
export type ServiceMiddlewareProviderResult<M, S> = [M] extends [never] ? never : [M] extends [MiddlewareInput<S>] ? S extends MiddlewareTransformProvider<any, M, any, infer R> ? (Omit<R, keyof M> & M) extends R ? Omit<R, keyof M> & M : R extends M ? R : Omit<M, keyof R> & R : S extends MiddlewareProvider<any, M, any, infer R> ? R : never : never;
|
|
28
6
|
export type ServiceMiddlewareProviderArgs<S> = S extends MiddlewareProvider<any, any, infer A, any> ? A : never;
|
|
29
|
-
|
|
30
|
-
export type
|
|
31
|
-
? S extends never[]
|
|
32
|
-
? ServiceMiddlewareProviderResult<M, S1>
|
|
33
|
-
: ServiceMiddlewareProviderChainResult<S,
|
|
34
|
-
ServiceMiddlewareProviderResult<M, S1>
|
|
35
|
-
>
|
|
36
|
-
: C extends unknown
|
|
37
|
-
? M
|
|
38
|
-
: never
|
|
39
|
-
;
|
|
40
|
-
export type ServiceMiddlewareProviderChainArgs<C> = C extends [infer S1, ...infer S]
|
|
41
|
-
? S extends never[]
|
|
42
|
-
? ServiceMiddlewareProviderArgs<S1>
|
|
43
|
-
: TupleZip<ServiceMiddlewareProviderChainArgs<S>, ServiceMiddlewareProviderArgs<S1>>
|
|
44
|
-
: C extends unknown
|
|
45
|
-
? []
|
|
46
|
-
: never
|
|
47
|
-
;
|
|
48
|
-
|
|
7
|
+
export type ServiceMiddlewareProviderChainResult<C, M> = C extends [infer S1, ...infer S] ? S extends never[] ? ServiceMiddlewareProviderResult<M, S1> : ServiceMiddlewareProviderChainResult<S, ServiceMiddlewareProviderResult<M, S1>> : C extends unknown ? M : never;
|
|
8
|
+
export type ServiceMiddlewareProviderChainArgs<C> = C extends [infer S1, ...infer S] ? S extends never[] ? ServiceMiddlewareProviderArgs<S1> : TupleZip<ServiceMiddlewareProviderChainArgs<S>, ServiceMiddlewareProviderArgs<S1>> : C extends unknown ? [] : never;
|
|
49
9
|
/**
|
|
50
10
|
* Creates a middleware composer for given AppServices and input value types. The composer accepts a list of middleware
|
|
51
11
|
* that it assembles into a chain. The function returned by the composer takes a value of the given input value type,
|
|
@@ -84,12 +44,4 @@ export type ServiceMiddlewareProviderChainArgs<C> = C extends [infer S1, ...infe
|
|
|
84
44
|
* eg: const myThing: myType = makeComposeMiddleware()(...);
|
|
85
45
|
* ```
|
|
86
46
|
*/
|
|
87
|
-
export const makeComposeMiddleware
|
|
88
|
-
...chain: C
|
|
89
|
-
): MiddlewareProvider<Sa, M, ServiceMiddlewareProviderChainArgs<C>, ServiceMiddlewareProviderChainResult<C, M>> => (app, appBinder) => {
|
|
90
|
-
const boundChain = chain.map(provider => appBinder ? appBinder(app, provider) : provider(app));
|
|
91
|
-
|
|
92
|
-
return (middleware: M, ...args) => {
|
|
93
|
-
return boundChain.reduce((result, provider) => provider(result, ...args), middleware);
|
|
94
|
-
};
|
|
95
|
-
};
|
|
47
|
+
export declare const makeComposeMiddleware: <Sa, M>() => <C extends any[]>(...chain: C) => MiddlewareProvider<Sa, M, ServiceMiddlewareProviderChainArgs<C>, ServiceMiddlewareProviderChainResult<C, M>>;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeComposeMiddleware = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Creates a middleware composer for given AppServices and input value types. The composer accepts a list of middleware
|
|
6
|
+
* that it assembles into a chain. The function returned by the composer takes a value of the given input value type,
|
|
7
|
+
* passes that value through the chain, and returns the result of the last element in the chain. The ending value will
|
|
8
|
+
* depend on the composed middleware.
|
|
9
|
+
*
|
|
10
|
+
* Examples:
|
|
11
|
+
*
|
|
12
|
+
* ```
|
|
13
|
+
* export const composeServiceMiddleware =
|
|
14
|
+
* makeComposeMiddleware<AppServices, {request: ApiRouteRequest}>();
|
|
15
|
+
* export const composeResponseMiddleware =
|
|
16
|
+
* makeComposeMiddleware<AppServices, Promise<ApiRouteResponse> | undefined>();
|
|
17
|
+
*
|
|
18
|
+
* // `requestServiceProvider` is a function that expects
|
|
19
|
+
* //`{request: ApiRouteRequest}` (specified in the call to
|
|
20
|
+
* //`makeComposeMiddleware`); for requestServiceProviders as part of routes in
|
|
21
|
+
* // particular, the request responder calls this when it resolves the routes.
|
|
22
|
+
*
|
|
23
|
+
* const requestServiceProvider = composeServiceMiddleware(
|
|
24
|
+
* cookieAuthMiddleware, // expects `request` (from input), adds `authProvider`
|
|
25
|
+
* myDocumentStoreMiddleware, // expects authProvider, adds the document store
|
|
26
|
+
* myDocumentSearchMiddleware, // expects document store, adds search provider
|
|
27
|
+
* ); // if you try to specify them in the wrong order it'll yell at you
|
|
28
|
+
* ```
|
|
29
|
+
*
|
|
30
|
+
* WARNING: depending on how you use it, typescript _sometimes_ explodes on these recursive types. if you have problems in your build
|
|
31
|
+
* with memory, you will have to specify the expected result type when calling the middleware reducer. this is a little annoying,
|
|
32
|
+
* but it will still correctly error if the type you specify is wrong, so you've still got the type safety.
|
|
33
|
+
*
|
|
34
|
+
* ```
|
|
35
|
+
* // this might work, or it might make your compiler run out of memory
|
|
36
|
+
* eg: const myThing = makeComposeMiddleware()(...);
|
|
37
|
+
*
|
|
38
|
+
* // this helps typescript figure out what is going on
|
|
39
|
+
* eg: const myThing: myType = makeComposeMiddleware()(...);
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
const makeComposeMiddleware = () => (...chain) => (app, appBinder) => {
|
|
43
|
+
const boundChain = chain.map(provider => appBinder ? appBinder(app, provider) : provider(app));
|
|
44
|
+
return (middleware, ...args) => {
|
|
45
|
+
return boundChain.reduce((result, provider) => provider(result, ...args), middleware);
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
exports.makeComposeMiddleware = makeComposeMiddleware;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { APIGatewayProxyEventV2 } from 'aws-lambda';
|
|
2
|
+
import { ConfigProviderForConfig } from '../config';
|
|
3
|
+
import { ApiResponse } from '../routing';
|
|
4
|
+
type Config = {
|
|
5
|
+
corsAllowedHostRegex: string;
|
|
6
|
+
};
|
|
7
|
+
/**
|
|
8
|
+
* Creates response middleware that adds CORS headers to responses from approved hosts.
|
|
9
|
+
*
|
|
10
|
+
* @param config the config object
|
|
11
|
+
* @param config.corsAllowedHostRegex the config that specifies the regex for allowed hosts
|
|
12
|
+
* @example
|
|
13
|
+
* createLambdaCorsResponseMiddleware({
|
|
14
|
+
* corsAllowedHostRegex: '(openstax.org|herokuapp.com)$'
|
|
15
|
+
* }),
|
|
16
|
+
*/
|
|
17
|
+
export declare const createLambdaCorsResponseMiddleware: (config: ConfigProviderForConfig<Config>) => () => (responsePromise: Promise<ApiResponse<number, any>> | undefined, { request }: {
|
|
18
|
+
request: APIGatewayProxyEventV2;
|
|
19
|
+
}) => Promise<ApiResponse<number, any>> | undefined;
|
|
20
|
+
export {};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createLambdaCorsResponseMiddleware = void 0;
|
|
4
|
+
const resolveConfigValue_1 = require("../config/resolveConfigValue");
|
|
5
|
+
const helpers_1 = require("../misc/helpers");
|
|
6
|
+
const routing_1 = require("../routing");
|
|
7
|
+
/**
|
|
8
|
+
* Creates response middleware that adds CORS headers to responses from approved hosts.
|
|
9
|
+
*
|
|
10
|
+
* @param config the config object
|
|
11
|
+
* @param config.corsAllowedHostRegex the config that specifies the regex for allowed hosts
|
|
12
|
+
* @example
|
|
13
|
+
* createLambdaCorsResponseMiddleware({
|
|
14
|
+
* corsAllowedHostRegex: '(openstax.org|herokuapp.com)$'
|
|
15
|
+
* }),
|
|
16
|
+
*/
|
|
17
|
+
const createLambdaCorsResponseMiddleware = (config) => () => (responsePromise, { request }) => {
|
|
18
|
+
const getAllowedHostRegex = (0, helpers_1.once)(() => (0, resolveConfigValue_1.resolveConfigValue)(config.corsAllowedHostRegex));
|
|
19
|
+
const cors = async () => {
|
|
20
|
+
const allowedHost = await getAllowedHostRegex();
|
|
21
|
+
if (request.headers.origin && request.headers.origin !== 'null' && new URL(request.headers.origin).hostname.match(new RegExp(allowedHost))) {
|
|
22
|
+
return {
|
|
23
|
+
'Access-Control-Allow-Origin': request.headers.origin,
|
|
24
|
+
'Access-Control-Allow-Credentials': 'true',
|
|
25
|
+
'Access-Control-Allow-Headers': 'content-type, x-request-id',
|
|
26
|
+
'Access-Control-Allow-Methods': 'POST, GET, PUT, PATCH, DELETE, OPTIONS',
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
if (responsePromise) {
|
|
31
|
+
return responsePromise.then(async (response) => {
|
|
32
|
+
response.headers = {
|
|
33
|
+
...await cors(),
|
|
34
|
+
...response.headers
|
|
35
|
+
};
|
|
36
|
+
return response;
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
if (request.requestContext.http.method === 'OPTIONS') {
|
|
40
|
+
return cors().then(headers => (0, routing_1.apiTextResponse)(200, '', headers));
|
|
41
|
+
}
|
|
42
|
+
return responsePromise;
|
|
43
|
+
};
|
|
44
|
+
exports.createLambdaCorsResponseMiddleware = createLambdaCorsResponseMiddleware;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createThrowNotFoundMiddleware = void 0;
|
|
4
|
+
const errors_1 = require("../errors");
|
|
5
|
+
/**
|
|
6
|
+
* Creates response middleware that throws a `NotFoundError` if the response is undefined.
|
|
7
|
+
*/
|
|
8
|
+
const createThrowNotFoundMiddleware = () => () => (response) => {
|
|
9
|
+
if (!response) {
|
|
10
|
+
throw new errors_1.NotFoundError('not found');
|
|
11
|
+
}
|
|
12
|
+
return response;
|
|
13
|
+
};
|
|
14
|
+
exports.createThrowNotFoundMiddleware = createThrowNotFoundMiddleware;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type HashValue = string | number | boolean | null | HashCompoundValue;
|
|
2
|
+
export type HashCompoundValue = Array<HashValue> | {
|
|
3
|
+
[key: string]: HashValue;
|
|
4
|
+
};
|
|
5
|
+
/**
|
|
6
|
+
* creates a string hash of lots of different kinds of things.
|
|
7
|
+
*
|
|
8
|
+
* @example hashValue({someKey: 'someValue'})
|
|
9
|
+
*/
|
|
10
|
+
export declare const hashValue: (value: HashValue) => string;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.hashValue = void 0;
|
|
4
|
+
const crypto_1 = require("crypto");
|
|
5
|
+
/**
|
|
6
|
+
* creates a string hash of lots of different kinds of things.
|
|
7
|
+
*
|
|
8
|
+
* @example hashValue({someKey: 'someValue'})
|
|
9
|
+
*/
|
|
10
|
+
const hashValue = (value) => {
|
|
11
|
+
// hack for sorting keys https://stackoverflow.com/a/53593328/14809536
|
|
12
|
+
const allKeys = new Set();
|
|
13
|
+
JSON.stringify(value, (k, v) => (allKeys.add(k), v));
|
|
14
|
+
const strValue = JSON.stringify(value, Array.from(allKeys).sort());
|
|
15
|
+
return (0, crypto_1.createHash)('sha1').update(strValue).digest('hex');
|
|
16
|
+
};
|
|
17
|
+
exports.hashValue = hashValue;
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import type { Logger } from '../services/logger';
|
|
2
|
+
/**
|
|
3
|
+
* Returns a function that gets the value of the given key from an object
|
|
4
|
+
*
|
|
5
|
+
* @param key
|
|
6
|
+
* @example
|
|
7
|
+
* const getAuthor = getKeyValue('author');
|
|
8
|
+
* const author = getAuthor(book);
|
|
9
|
+
*/
|
|
10
|
+
export declare const getKeyValue: <K extends string>(key: K) => <O extends { [_key in K]?: any; }>(obj: O) => O[K];
|
|
11
|
+
/**
|
|
12
|
+
* Returns a function that gets the value of the given key from an object, or the given default
|
|
13
|
+
* value if the key is not present.
|
|
14
|
+
*
|
|
15
|
+
* @param key
|
|
16
|
+
* @param defaultValue a default value matching the type of the value at the given key
|
|
17
|
+
* @example
|
|
18
|
+
* const getAuthorOrNope = getKeyValueOr('author', 'nope');
|
|
19
|
+
* const authorOrNope = getAuthorOrNope(book);
|
|
20
|
+
*/
|
|
21
|
+
export declare const getKeyValueOr: <K extends string, V, Od extends { [_key in K]?: any; } = { [_key in K]?: any; }>(key: K, defaultValue: V) => <O extends (Od extends undefined ? { [_key in K]?: any; } : Od)>(obj: O) => NonNullable<O[K]> | V;
|
|
22
|
+
/**
|
|
23
|
+
* Returns a function that sets the value of the given key on an object.
|
|
24
|
+
*
|
|
25
|
+
* @param key
|
|
26
|
+
* @example
|
|
27
|
+
* const putAuthor = putKeyValue('author');
|
|
28
|
+
* const newBook = putAuthor(book, 'tom');
|
|
29
|
+
*/
|
|
30
|
+
export declare const putKeyValue: <K extends string>(key: K) => <O extends { [_key in K]?: any; }>(obj: O, value: O[K]) => O;
|
|
31
|
+
/**
|
|
32
|
+
* Coerces a value into an array. If the value is already an array, it is returned as-is.
|
|
33
|
+
* If the value is undefined, an empty array is returned.
|
|
34
|
+
*
|
|
35
|
+
* @param thing the value
|
|
36
|
+
* @returns an array
|
|
37
|
+
*/
|
|
38
|
+
export declare const coerceArray: <T>(thing: undefined | T | T[]) => T[];
|
|
39
|
+
type FlowFn<A, R> = (...args: [A]) => R;
|
|
40
|
+
type AnyFlowFn = FlowFn<any, any>;
|
|
41
|
+
type FlowFnResult<F, A> = F extends FlowFn<A, infer R> ? R : never;
|
|
42
|
+
type FlowResult<C, A> = C extends [infer F1, ...infer Cr] ? F1 extends AnyFlowFn ? Cr extends never[] ? FlowFnResult<F1, A> : FlowResult<Cr, FlowFnResult<F1, A>> : never : never;
|
|
43
|
+
type FlowChainArg<C> = C extends [infer F1, ...infer _] ? F1 extends FlowFn<infer A, any> ? A : never : never;
|
|
44
|
+
/**
|
|
45
|
+
* this is like lodash/flow but it uses a recursive type instead of hard-coding parameters
|
|
46
|
+
*/
|
|
47
|
+
export declare const flow: <C extends AnyFlowFn[]>(...chain: C) => (param: FlowChainArg<C>) => FlowResult<C, FlowChainArg<C>>;
|
|
48
|
+
export type RetryOptions = {
|
|
49
|
+
logger?: Logger;
|
|
50
|
+
wait?: number;
|
|
51
|
+
splay?: number;
|
|
52
|
+
retries?: number;
|
|
53
|
+
n?: number;
|
|
54
|
+
};
|
|
55
|
+
/**
|
|
56
|
+
* Retries a function with a delay between retries.
|
|
57
|
+
* @param fn The function to retry
|
|
58
|
+
* @param [options] retry options
|
|
59
|
+
* @param [options.wait=100] base wait of first retry (number), further retries are: t=n*wait,
|
|
60
|
+
* default: 100
|
|
61
|
+
* @param [options.splay=0.5] percentage to modify t by. 0.5 is 50%, which would make
|
|
62
|
+
* t=n*wait+rand(wait*splay*-1, wait*splay), default: 0.5
|
|
63
|
+
* @param [options.retries=2] number of times to retry. (2 retries means it'll try a max of 3 times),
|
|
64
|
+
* default: 2
|
|
65
|
+
* @param [options.n=0] the starting retry index. probably don't set this. unless you really want a very steep
|
|
66
|
+
* initial wait cliff with incremental increases, then maybe you'd set this. default: 0
|
|
67
|
+
* @returns A promise that resolves with the result of the function, or rejects with the last error.
|
|
68
|
+
*/
|
|
69
|
+
export declare const retryWithDelay: <R>(fn: (abort?: (e: Error) => never) => Promise<R>, options?: RetryOptions) => Promise<R>;
|
|
70
|
+
/**
|
|
71
|
+
* a shameful helper to avoid needing to test code coverage of branches
|
|
72
|
+
*/
|
|
73
|
+
export declare const fnIf: <T1, T2>(condition: boolean, trueValue: T1, falseValue: T2) => T1 | T2;
|
|
74
|
+
/**
|
|
75
|
+
* maps the array and returns the first result that matches the predicate
|
|
76
|
+
* avoids processing extra elements that would happen with .map().find() or .reduce
|
|
77
|
+
*
|
|
78
|
+
* eg the third element of the array is never processed:
|
|
79
|
+
* const result = mapFind([1,2,3], x => 'hello'.charAt(x), x => x === 'l');
|
|
80
|
+
*/
|
|
81
|
+
export declare const mapFind: <I, R>(array: I[], mapper: (item: I) => R, predicate?: (result: R) => boolean) => R | undefined;
|
|
82
|
+
/**
|
|
83
|
+
* returns a function that will only ever call the given function once, returning the first result for every subsequent call
|
|
84
|
+
*
|
|
85
|
+
* does not cache rejected promises, to avoid cache poisoning on failed async requests
|
|
86
|
+
*
|
|
87
|
+
* eg:
|
|
88
|
+
* const heavyFunction = () => 'hello';
|
|
89
|
+
* const butOnlyOnce = once(() => 'hello');
|
|
90
|
+
*
|
|
91
|
+
* heavyFunction() // returns `hello`;
|
|
92
|
+
* butOnlyOnce() // returns `hello`;
|
|
93
|
+
*/
|
|
94
|
+
export declare const once: <F extends (...args: any[]) => any>(fn: F) => F;
|
|
95
|
+
/**
|
|
96
|
+
* memoizes a function with any number of arguments
|
|
97
|
+
*
|
|
98
|
+
* does not cache rejected promises, to avoid cache poisoning on failed async requests
|
|
99
|
+
*/
|
|
100
|
+
export declare const memoize: <F extends (...args: any[]) => any>(fn: F) => F;
|
|
101
|
+
/**
|
|
102
|
+
* rounds number to given number of places
|
|
103
|
+
*
|
|
104
|
+
* eg:
|
|
105
|
+
* roundToPrecision(1234.123, 2); // returns 1200
|
|
106
|
+
* roundToPrecision(1234.123, -2); // returns 1234.12
|
|
107
|
+
* roundToPrecision(1234.125, -2); // returns 1234.13
|
|
108
|
+
*/
|
|
109
|
+
export declare const roundToPrecision: (num: number, places: number) => number;
|
|
110
|
+
/**
|
|
111
|
+
* a silly utility to help typescript realize an array is a tuple
|
|
112
|
+
*
|
|
113
|
+
* eg:
|
|
114
|
+
* const a = [5, 'string'] // type is `Array<string | number>`
|
|
115
|
+
* const t = tuple(5, 'string') type is `[5, 'string']`
|
|
116
|
+
*
|
|
117
|
+
* both have the same javascript value, but one is forced to be a tuple, which
|
|
118
|
+
* is nice if its structure is important. examples are like the React.useState
|
|
119
|
+
* pattern where there are two return values in a tuple, or if you're feeding
|
|
120
|
+
* Object.fromEntries
|
|
121
|
+
*
|
|
122
|
+
*/
|
|
123
|
+
export declare const tuple: <A extends any[]>(...args: A) => A;
|
|
124
|
+
export {};
|