@openstax/ts-utils 1.33.1 → 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.
Files changed (504) hide show
  1. package/.cfnlintrc +2 -0
  2. package/.github/CODEOWNERS +1 -0
  3. package/.github/workflows/ci.yml +36 -0
  4. package/.github/workflows/lint.yml +55 -0
  5. package/.nvmrc +1 -0
  6. package/.syncignore +4 -0
  7. package/.syncpackrc +18 -0
  8. package/CONTRIBUTING.md +96 -0
  9. package/LICENSE +661 -0
  10. package/Procfile +1 -0
  11. package/README.md +62 -90
  12. package/app.json +23 -0
  13. package/cspell.json +32 -0
  14. package/deploy/constants.env +21 -0
  15. package/deploy/deploy.bash +157 -0
  16. package/deploy/deployment-alt-region.cfn.yml +70 -0
  17. package/deploy/deployment.cfn.yml +650 -0
  18. package/deploy/destroy-deployment.bash +23 -0
  19. package/deploy/shared.cfn.yml +94 -0
  20. package/docs/lambda-build.md +35 -0
  21. package/package.json +12 -228
  22. package/packages/frontend/README.md +46 -0
  23. package/packages/frontend/package.json +101 -0
  24. package/packages/frontend/public/favicon.ico +0 -0
  25. package/packages/frontend/public/index.html +107 -0
  26. package/packages/frontend/public/maintenance.html +59 -0
  27. package/packages/frontend/public/manifest.json +15 -0
  28. package/packages/frontend/public/robots.txt +3 -0
  29. package/packages/frontend/script/make-certificate.bash +49 -0
  30. package/packages/frontend/script/server/cli.js +11 -0
  31. package/packages/frontend/script/server/index.js +47 -0
  32. package/packages/frontend/script/start.bash +22 -0
  33. package/packages/frontend/script/trust-localhost.bash +7 -0
  34. package/packages/frontend/src/auth/authProvider.ts +10 -0
  35. package/packages/frontend/src/auth/useAuth.ts +33 -0
  36. package/packages/frontend/src/components/Pagination.tsx +26 -0
  37. package/packages/frontend/src/configProvider/index.ts +53 -0
  38. package/packages/frontend/src/configProvider/use.ts +41 -0
  39. package/packages/frontend/src/core/context/services.spec.tsx +39 -0
  40. package/packages/frontend/src/core/context/services.tsx +16 -0
  41. package/packages/frontend/src/core/index.spec.ts +7 -0
  42. package/packages/frontend/src/core/index.ts +20 -0
  43. package/packages/frontend/src/core/services.tsx +14 -0
  44. package/packages/frontend/src/core/types.ts +3 -0
  45. package/packages/frontend/src/example/api.ts +28 -0
  46. package/packages/frontend/src/example/components/Layout.tsx +23 -0
  47. package/packages/frontend/src/example/screens/Home.spec.tsx +68 -0
  48. package/packages/frontend/src/example/screens/Home.tsx +78 -0
  49. package/packages/frontend/src/example/screens/ThingList.spec.tsx +60 -0
  50. package/packages/frontend/src/example/screens/ThingList.tsx +75 -0
  51. package/packages/frontend/src/example/screens/ThingView.spec.tsx +71 -0
  52. package/packages/frontend/src/example/screens/ThingView.tsx +47 -0
  53. package/packages/frontend/src/example/screens/index.ts +9 -0
  54. package/packages/frontend/src/index.css +159 -0
  55. package/packages/frontend/src/index.tsx +67 -0
  56. package/packages/frontend/src/react-app-env.d.ts +1 -0
  57. package/packages/frontend/src/routing/components/RouteLink.spec.tsx +55 -0
  58. package/packages/frontend/src/routing/components/RouteLink.tsx +35 -0
  59. package/packages/frontend/src/routing/middleware.ts +6 -0
  60. package/packages/frontend/src/routing/useQuery.ts +14 -0
  61. package/packages/frontend/src/setupProxy.js +19 -0
  62. package/packages/frontend/src/setupTests.ts +9 -0
  63. package/packages/frontend/src/tests/testServices.tsx +23 -0
  64. package/packages/frontend/tsconfig.json +27 -0
  65. package/packages/lambda/.eslintrc.js +64 -0
  66. package/packages/lambda/jest-global-setup.js +3 -0
  67. package/packages/lambda/jest-setup-after-env.js +1 -0
  68. package/packages/lambda/jest.config.js +31 -0
  69. package/packages/lambda/jest.resolver.js +17 -0
  70. package/packages/lambda/package.json +68 -0
  71. package/packages/lambda/script/build.bash +19 -0
  72. package/packages/lambda/script/bundle-functions.bash +10 -0
  73. package/packages/lambda/script/lambdaLocalProxy.js +16 -0
  74. package/packages/lambda/script/lambdaLocalProxy.spec.ts +147 -0
  75. package/packages/lambda/script/utils/getRouteData.ts +7 -0
  76. package/packages/lambda/script/utils/routeDataLoader.js +8 -0
  77. package/packages/lambda/script/utils/routeDataLoader.spec.ts +8 -0
  78. package/packages/lambda/src/functions/serviceApi/core/index.ts +7 -0
  79. package/packages/lambda/src/functions/serviceApi/core/request.spec.ts +38 -0
  80. package/packages/lambda/src/functions/serviceApi/core/request.ts +42 -0
  81. package/packages/lambda/src/functions/serviceApi/core/routes.spec.ts +7 -0
  82. package/packages/lambda/src/functions/serviceApi/core/routes.ts +10 -0
  83. package/packages/lambda/src/functions/serviceApi/core/services.ts +9 -0
  84. package/packages/lambda/src/functions/serviceApi/core/types.ts +13 -0
  85. package/packages/lambda/src/functions/serviceApi/entry/lambda/https-xray.ts +4 -0
  86. package/packages/lambda/src/functions/serviceApi/entry/lambda/index.spec.ts +48 -0
  87. package/packages/lambda/src/functions/serviceApi/entry/lambda/index.ts +58 -0
  88. package/packages/lambda/src/functions/serviceApi/entry/lambda/services.ts +36 -0
  89. package/packages/lambda/src/functions/serviceApi/entry/local.ts +71 -0
  90. package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentSearchMiddleware.spec.ts +16 -0
  91. package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentSearchMiddleware.ts +41 -0
  92. package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentStoreMiddleware.spec.ts +78 -0
  93. package/packages/lambda/src/functions/serviceApi/versions/v0/example/documentStoreMiddleware.ts +70 -0
  94. package/packages/lambda/src/functions/serviceApi/versions/v0/example/routes.spec.ts +306 -0
  95. package/packages/lambda/src/functions/serviceApi/versions/v0/example/routes.ts +176 -0
  96. package/packages/lambda/src/functions/serviceApi/versions/v0/index.spec.ts +263 -0
  97. package/packages/lambda/src/functions/serviceApi/versions/v0/index.ts +134 -0
  98. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/authMiddleware.spec.ts +23 -0
  99. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/authMiddleware.ts +32 -0
  100. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/configMiddleware.spec.ts +10 -0
  101. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/configMiddleware.ts +7 -0
  102. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/frontendFileServerMiddleware.spec.ts +13 -0
  103. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/frontendFileServerMiddleware.ts +23 -0
  104. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/paginationMiddleware.spec.ts +9 -0
  105. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/paginationMiddleware.ts +9 -0
  106. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/searchMiddleware.spec.ts +12 -0
  107. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/searchMiddleware.ts +21 -0
  108. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/userRoleValidatorMiddleware.spec.ts +21 -0
  109. package/packages/lambda/src/functions/serviceApi/versions/v0/middleware/userRoleValidatorMiddleware.ts +18 -0
  110. package/packages/lambda/tsconfig.json +30 -0
  111. package/packages/lambda/webpack.config.js +97 -0
  112. package/packages/utils/.eslintrc.js +64 -0
  113. package/packages/utils/README.md +118 -0
  114. package/packages/utils/jest-global-setup.js +3 -0
  115. package/packages/utils/jest.config.js +25 -0
  116. package/packages/utils/jest.resolver.js +17 -0
  117. package/packages/utils/package.json +238 -0
  118. package/packages/utils/src/assertions/index.spec.ts +126 -0
  119. package/{dist/esm/assertions/index.js → packages/utils/src/assertions/index.ts} +64 -49
  120. package/packages/utils/src/aws/ssmService.ts +7 -0
  121. package/packages/utils/src/config/awsParameterConfig.ts +24 -0
  122. package/packages/utils/src/config/envConfig.ts +58 -0
  123. package/packages/utils/src/config/index.spec.ts +165 -0
  124. package/{dist/esm/config/index.d.ts → packages/utils/src/config/index.ts} +29 -13
  125. package/packages/utils/src/config/lambdaParameterConfig.ts +49 -0
  126. package/{dist/esm/config/replaceConfig.js → packages/utils/src/config/replaceConfig.ts} +16 -6
  127. package/packages/utils/src/config/resolveConfigValue.ts +10 -0
  128. package/packages/utils/src/errors/index.spec.ts +35 -0
  129. package/{dist/esm/errors/index.js → packages/utils/src/errors/index.ts} +57 -41
  130. package/packages/utils/src/fetch/fetchStatusRetry.spec.ts +197 -0
  131. package/packages/utils/src/fetch/fetchStatusRetry.ts +33 -0
  132. package/packages/utils/src/fetch/index.spec.ts +34 -0
  133. package/packages/utils/src/fetch/index.ts +87 -0
  134. package/packages/utils/src/guards/index.spec.ts +58 -0
  135. package/{dist/esm/guards/index.d.ts → packages/utils/src/guards/index.ts} +10 -7
  136. package/packages/utils/src/index.spec.ts +471 -0
  137. package/packages/utils/src/middleware/apiErrorHandler.spec.ts +65 -0
  138. package/packages/utils/src/middleware/apiErrorHandler.ts +67 -0
  139. package/packages/utils/src/middleware/apiSlowResponseMiddleware.spec.ts +184 -0
  140. package/packages/utils/src/middleware/apiSlowResponseMiddleware.ts +71 -0
  141. package/packages/utils/src/middleware/index.spec.ts +99 -0
  142. package/{dist/cjs/middleware/index.d.ts → packages/utils/src/middleware/index.ts} +53 -5
  143. package/packages/utils/src/middleware/lambdaCorsResponseMiddleware.spec.ts +103 -0
  144. package/packages/utils/src/middleware/lambdaCorsResponseMiddleware.ts +52 -0
  145. package/packages/utils/src/middleware/throwNotFoundMiddleware.spec.ts +20 -0
  146. package/packages/utils/src/middleware/throwNotFoundMiddleware.ts +11 -0
  147. package/packages/utils/src/misc/hashValue.ts +18 -0
  148. package/packages/utils/src/misc/helpers.ts +259 -0
  149. package/packages/utils/src/misc/merge.ts +48 -0
  150. package/{dist/esm/misc/partitionSequence.js → packages/utils/src/misc/partitionSequence.ts} +23 -15
  151. package/packages/utils/src/pagination/index.spec.ts +150 -0
  152. package/packages/utils/src/pagination/index.ts +117 -0
  153. package/{dist/esm/routing/helpers.js → packages/utils/src/routing/helpers.ts} +42 -30
  154. package/packages/utils/src/routing/index.spec.ts +553 -0
  155. package/packages/utils/src/routing/index.ts +424 -0
  156. package/packages/utils/src/routing/validators/zod.spec.ts +16 -0
  157. package/packages/utils/src/routing/validators/zod.ts +14 -0
  158. package/packages/utils/src/services/accountsGateway/README.md +3 -0
  159. package/packages/utils/src/services/accountsGateway/index.spec.ts +518 -0
  160. package/packages/utils/src/services/accountsGateway/index.ts +251 -0
  161. package/packages/utils/src/services/apiGateway/README.md +93 -0
  162. package/packages/utils/src/services/apiGateway/index.spec.ts +254 -0
  163. package/packages/utils/src/services/apiGateway/index.ts +189 -0
  164. package/packages/utils/src/services/authProvider/README.md +21 -0
  165. package/packages/utils/src/services/authProvider/browser.spec.ts +391 -0
  166. package/packages/utils/src/services/authProvider/browser.ts +209 -0
  167. package/packages/utils/src/services/authProvider/decryption.spec.ts +337 -0
  168. package/packages/utils/src/services/authProvider/decryption.ts +98 -0
  169. package/packages/utils/src/services/authProvider/index.ts +93 -0
  170. package/packages/utils/src/services/authProvider/stub.spec.ts +29 -0
  171. package/packages/utils/src/services/authProvider/subrequest.spec.ts +105 -0
  172. package/packages/utils/src/services/authProvider/subrequest.ts +68 -0
  173. package/packages/utils/src/services/authProvider/utils/decryptAndVerify.spec.ts +128 -0
  174. package/packages/utils/src/services/authProvider/utils/decryptAndVerify.ts +106 -0
  175. package/packages/utils/src/services/authProvider/utils/embeddedAuthProvider.spec.ts +26 -0
  176. package/packages/utils/src/services/authProvider/utils/embeddedAuthProvider.ts +57 -0
  177. package/packages/utils/src/services/authProvider/utils/userRoleValidator.spec.ts +135 -0
  178. package/packages/utils/src/services/authProvider/utils/userRoleValidator.ts +49 -0
  179. package/packages/utils/src/services/authProvider/utils/userSubrequest.spec.ts +26 -0
  180. package/packages/utils/src/services/authProvider/utils/userSubrequest.ts +10 -0
  181. package/packages/utils/src/services/documentStore/dynamoEncoding.ts +57 -0
  182. package/packages/utils/src/services/documentStore/fileSystemAssert.spec.ts +43 -0
  183. package/packages/utils/src/services/documentStore/fileSystemAssert.ts +10 -0
  184. package/{dist/cjs/services/documentStore/index.d.ts → packages/utils/src/services/documentStore/index.ts} +8 -8
  185. package/packages/utils/src/services/documentStore/unversioned/README.md +13 -0
  186. package/packages/utils/src/services/documentStore/unversioned/dynamodb.spec.ts +859 -0
  187. package/packages/utils/src/services/documentStore/unversioned/dynamodb.ts +243 -0
  188. package/packages/utils/src/services/documentStore/unversioned/file-system.spec.ts +629 -0
  189. package/packages/utils/src/services/documentStore/unversioned/file-system.ts +194 -0
  190. package/{dist/cjs/services/documentStore/unversioned/index.d.ts → packages/utils/src/services/documentStore/unversioned/index.ts} +2 -0
  191. package/packages/utils/src/services/documentStore/versioned/README.md +13 -0
  192. package/packages/utils/src/services/documentStore/versioned/dynamodb.spec.ts +376 -0
  193. package/packages/utils/src/services/documentStore/versioned/dynamodb.ts +167 -0
  194. package/packages/utils/src/services/documentStore/versioned/file-system.spec.ts +262 -0
  195. package/packages/utils/src/services/documentStore/versioned/file-system.ts +90 -0
  196. package/packages/utils/src/services/documentStore/versioned/index.ts +25 -0
  197. package/packages/utils/src/services/exercisesGateway/README.md +5 -0
  198. package/packages/utils/src/services/exercisesGateway/index.spec.ts +326 -0
  199. package/packages/utils/src/services/exercisesGateway/index.ts +163 -0
  200. package/packages/utils/src/services/fileServer/index.spec.ts +88 -0
  201. package/packages/utils/src/services/fileServer/index.ts +43 -0
  202. package/packages/utils/src/services/fileServer/localFileServer.spec.ts +182 -0
  203. package/packages/utils/src/services/fileServer/localFileServer.ts +159 -0
  204. package/packages/utils/src/services/fileServer/s3FileServer.spec.ts +266 -0
  205. package/packages/utils/src/services/fileServer/s3FileServer.ts +155 -0
  206. package/packages/utils/src/services/launchParams/index.spec.ts +366 -0
  207. package/packages/utils/src/services/launchParams/signer.ts +73 -0
  208. package/packages/utils/src/services/launchParams/verifier.ts +120 -0
  209. package/packages/utils/src/services/logger/console.spec.ts +29 -0
  210. package/{dist/esm/services/logger/console.js → packages/utils/src/services/logger/console.ts} +5 -2
  211. package/packages/utils/src/services/logger/index.spec.ts +65 -0
  212. package/{dist/esm/services/logger/index.d.ts → packages/utils/src/services/logger/index.ts} +23 -9
  213. package/packages/utils/src/services/lrsGateway/README.md +5 -0
  214. package/packages/utils/src/services/lrsGateway/addStatementDefaultFields.ts +22 -0
  215. package/packages/utils/src/services/lrsGateway/attempt-utils.spec.ts +847 -0
  216. package/packages/utils/src/services/lrsGateway/attempt-utils.ts +358 -0
  217. package/packages/utils/src/services/lrsGateway/file-system.spec.ts +363 -0
  218. package/packages/utils/src/services/lrsGateway/file-system.ts +165 -0
  219. package/packages/utils/src/services/lrsGateway/index.spec.ts +194 -0
  220. package/packages/utils/src/services/lrsGateway/index.ts +257 -0
  221. package/packages/utils/src/services/lrsGateway/xapiUtils.spec.ts +887 -0
  222. package/packages/utils/src/services/lrsGateway/xapiUtils.ts +262 -0
  223. package/packages/utils/src/services/postgresConnection/index.spec.ts +170 -0
  224. package/packages/utils/src/services/postgresConnection/index.ts +84 -0
  225. package/packages/utils/src/services/searchProvider/README.md +3 -0
  226. package/packages/utils/src/services/searchProvider/index.ts +59 -0
  227. package/packages/utils/src/services/searchProvider/memorySearchTheBadWay.spec.ts +526 -0
  228. package/packages/utils/src/services/searchProvider/memorySearchTheBadWay.ts +223 -0
  229. package/packages/utils/src/services/searchProvider/openSearch.spec.ts +926 -0
  230. package/packages/utils/src/services/searchProvider/openSearch.ts +195 -0
  231. package/{dist/esm/types.d.ts → packages/utils/src/types.ts} +34 -6
  232. package/packages/utils/tsconfig.json +31 -0
  233. package/packages/utils/tsconfig.without-specs.cjs.json +7 -0
  234. package/packages/utils/tsconfig.without-specs.esm.json +7 -0
  235. package/packages/utils/tsconfig.without-specs.json +6 -0
  236. package/scripts/build.bash +24 -0
  237. package/scripts/ci.bash +10 -0
  238. package/scripts/start.bash +29 -0
  239. package/dist/cjs/assertions/index.d.ts +0 -89
  240. package/dist/cjs/assertions/index.js +0 -157
  241. package/dist/cjs/aws/ssmService.d.ts +0 -5
  242. package/dist/cjs/aws/ssmService.js +0 -9
  243. package/dist/cjs/config/awsParameterConfig.d.ts +0 -10
  244. package/dist/cjs/config/awsParameterConfig.js +0 -26
  245. package/dist/cjs/config/envConfig.d.ts +0 -24
  246. package/dist/cjs/config/envConfig.js +0 -57
  247. package/dist/cjs/config/index.d.ts +0 -48
  248. package/dist/cjs/config/index.js +0 -35
  249. package/dist/cjs/config/lambdaParameterConfig.d.ts +0 -12
  250. package/dist/cjs/config/lambdaParameterConfig.js +0 -45
  251. package/dist/cjs/config/replaceConfig.d.ts +0 -14
  252. package/dist/cjs/config/replaceConfig.js +0 -22
  253. package/dist/cjs/config/resolveConfigValue.d.ts +0 -5
  254. package/dist/cjs/config/resolveConfigValue.js +0 -12
  255. package/dist/cjs/errors/index.d.ts +0 -88
  256. package/dist/cjs/errors/index.js +0 -123
  257. package/dist/cjs/fetch/fetchStatusRetry.d.ts +0 -8
  258. package/dist/cjs/fetch/fetchStatusRetry.js +0 -27
  259. package/dist/cjs/fetch/index.d.ts +0 -64
  260. package/dist/cjs/fetch/index.js +0 -55
  261. package/dist/cjs/guards/index.d.ts +0 -38
  262. package/dist/cjs/guards/index.js +0 -44
  263. package/dist/cjs/index.js +0 -20
  264. package/dist/cjs/middleware/apiErrorHandler.d.ts +0 -24
  265. package/dist/cjs/middleware/apiErrorHandler.js +0 -42
  266. package/dist/cjs/middleware/apiSlowResponseMiddleware.d.ts +0 -23
  267. package/dist/cjs/middleware/apiSlowResponseMiddleware.js +0 -54
  268. package/dist/cjs/middleware/index.js +0 -48
  269. package/dist/cjs/middleware/lambdaCorsResponseMiddleware.d.ts +0 -20
  270. package/dist/cjs/middleware/lambdaCorsResponseMiddleware.js +0 -44
  271. package/dist/cjs/middleware/throwNotFoundMiddleware.d.ts +0 -4
  272. package/dist/cjs/middleware/throwNotFoundMiddleware.js +0 -14
  273. package/dist/cjs/misc/hashValue.d.ts +0 -10
  274. package/dist/cjs/misc/hashValue.js +0 -17
  275. package/dist/cjs/misc/helpers.d.ts +0 -124
  276. package/dist/cjs/misc/helpers.js +0 -214
  277. package/dist/cjs/misc/merge.d.ts +0 -21
  278. package/dist/cjs/misc/merge.js +0 -45
  279. package/dist/cjs/misc/partitionSequence.d.ts +0 -35
  280. package/dist/cjs/misc/partitionSequence.js +0 -55
  281. package/dist/cjs/pagination/index.d.ts +0 -91
  282. package/dist/cjs/pagination/index.js +0 -83
  283. package/dist/cjs/routing/helpers.d.ts +0 -57
  284. package/dist/cjs/routing/helpers.js +0 -90
  285. package/dist/cjs/routing/index.d.ts +0 -290
  286. package/dist/cjs/routing/index.js +0 -295
  287. package/dist/cjs/routing/validators/zod.d.ts +0 -4
  288. package/dist/cjs/routing/validators/zod.js +0 -14
  289. package/dist/cjs/services/accountsGateway/index.d.ts +0 -92
  290. package/dist/cjs/services/accountsGateway/index.js +0 -138
  291. package/dist/cjs/services/apiGateway/index.d.ts +0 -68
  292. package/dist/cjs/services/apiGateway/index.js +0 -118
  293. package/dist/cjs/services/authProvider/browser.d.ts +0 -40
  294. package/dist/cjs/services/authProvider/browser.js +0 -155
  295. package/dist/cjs/services/authProvider/decryption.d.ts +0 -19
  296. package/dist/cjs/services/authProvider/decryption.js +0 -73
  297. package/dist/cjs/services/authProvider/index.d.ts +0 -63
  298. package/dist/cjs/services/authProvider/index.js +0 -34
  299. package/dist/cjs/services/authProvider/subrequest.d.ts +0 -13
  300. package/dist/cjs/services/authProvider/subrequest.js +0 -49
  301. package/dist/cjs/services/authProvider/utils/decryptAndVerify.d.ts +0 -28
  302. package/dist/cjs/services/authProvider/utils/decryptAndVerify.js +0 -91
  303. package/dist/cjs/services/authProvider/utils/embeddedAuthProvider.d.ts +0 -26
  304. package/dist/cjs/services/authProvider/utils/embeddedAuthProvider.js +0 -47
  305. package/dist/cjs/services/authProvider/utils/userRoleValidator.d.ts +0 -13
  306. package/dist/cjs/services/authProvider/utils/userRoleValidator.js +0 -37
  307. package/dist/cjs/services/authProvider/utils/userSubrequest.d.ts +0 -3
  308. package/dist/cjs/services/authProvider/utils/userSubrequest.js +0 -13
  309. package/dist/cjs/services/documentStore/dynamoEncoding.d.ts +0 -10
  310. package/dist/cjs/services/documentStore/dynamoEncoding.js +0 -52
  311. package/dist/cjs/services/documentStore/fileSystemAssert.d.ts +0 -1
  312. package/dist/cjs/services/documentStore/fileSystemAssert.js +0 -14
  313. package/dist/cjs/services/documentStore/index.js +0 -2
  314. package/dist/cjs/services/documentStore/unversioned/dynamodb.d.ts +0 -31
  315. package/dist/cjs/services/documentStore/unversioned/dynamodb.js +0 -233
  316. package/dist/cjs/services/documentStore/unversioned/file-system.d.ts +0 -32
  317. package/dist/cjs/services/documentStore/unversioned/file-system.js +0 -214
  318. package/dist/cjs/services/documentStore/unversioned/index.js +0 -2
  319. package/dist/cjs/services/documentStore/versioned/dynamodb.d.ts +0 -25
  320. package/dist/cjs/services/documentStore/versioned/dynamodb.js +0 -143
  321. package/dist/cjs/services/documentStore/versioned/file-system.d.ts +0 -25
  322. package/dist/cjs/services/documentStore/versioned/file-system.js +0 -73
  323. package/dist/cjs/services/documentStore/versioned/index.d.ts +0 -17
  324. package/dist/cjs/services/documentStore/versioned/index.js +0 -2
  325. package/dist/cjs/services/exercisesGateway/index.d.ts +0 -67
  326. package/dist/cjs/services/exercisesGateway/index.js +0 -107
  327. package/dist/cjs/services/fileServer/index.d.ts +0 -30
  328. package/dist/cjs/services/fileServer/index.js +0 -19
  329. package/dist/cjs/services/fileServer/localFileServer.d.ts +0 -13
  330. package/dist/cjs/services/fileServer/localFileServer.js +0 -132
  331. package/dist/cjs/services/fileServer/s3FileServer.d.ts +0 -14
  332. package/dist/cjs/services/fileServer/s3FileServer.js +0 -132
  333. package/dist/cjs/services/launchParams/index.js +0 -7
  334. package/dist/cjs/services/launchParams/signer.d.ts +0 -23
  335. package/dist/cjs/services/launchParams/signer.js +0 -58
  336. package/dist/cjs/services/launchParams/verifier.d.ts +0 -21
  337. package/dist/cjs/services/launchParams/verifier.js +0 -129
  338. package/dist/cjs/services/logger/console.d.ts +0 -4
  339. package/dist/cjs/services/logger/console.js +0 -12
  340. package/dist/cjs/services/logger/index.d.ts +0 -39
  341. package/dist/cjs/services/logger/index.js +0 -31
  342. package/dist/cjs/services/lrsGateway/addStatementDefaultFields.d.ts +0 -5
  343. package/dist/cjs/services/lrsGateway/addStatementDefaultFields.js +0 -21
  344. package/dist/cjs/services/lrsGateway/attempt-utils.d.ts +0 -70
  345. package/dist/cjs/services/lrsGateway/attempt-utils.js +0 -258
  346. package/dist/cjs/services/lrsGateway/file-system.d.ts +0 -15
  347. package/dist/cjs/services/lrsGateway/file-system.js +0 -150
  348. package/dist/cjs/services/lrsGateway/index.d.ts +0 -122
  349. package/dist/cjs/services/lrsGateway/index.js +0 -148
  350. package/dist/cjs/services/lrsGateway/xapiUtils.d.ts +0 -68
  351. package/dist/cjs/services/lrsGateway/xapiUtils.js +0 -109
  352. package/dist/cjs/services/postgresConnection/index.d.ts +0 -28
  353. package/dist/cjs/services/postgresConnection/index.js +0 -65
  354. package/dist/cjs/services/searchProvider/index.d.ts +0 -67
  355. package/dist/cjs/services/searchProvider/index.js +0 -2
  356. package/dist/cjs/services/searchProvider/memorySearchTheBadWay.d.ts +0 -20
  357. package/dist/cjs/services/searchProvider/memorySearchTheBadWay.js +0 -191
  358. package/dist/cjs/services/searchProvider/openSearch.d.ts +0 -28
  359. package/dist/cjs/services/searchProvider/openSearch.js +0 -154
  360. package/dist/cjs/tsconfig.without-specs.cjs.tsbuildinfo +0 -1
  361. package/dist/cjs/types.d.ts +0 -31
  362. package/dist/cjs/types.js +0 -2
  363. package/dist/esm/assertions/index.d.ts +0 -89
  364. package/dist/esm/aws/ssmService.d.ts +0 -5
  365. package/dist/esm/aws/ssmService.js +0 -6
  366. package/dist/esm/config/awsParameterConfig.d.ts +0 -10
  367. package/dist/esm/config/awsParameterConfig.js +0 -22
  368. package/dist/esm/config/envConfig.d.ts +0 -24
  369. package/dist/esm/config/envConfig.js +0 -53
  370. package/dist/esm/config/index.js +0 -17
  371. package/dist/esm/config/lambdaParameterConfig.d.ts +0 -12
  372. package/dist/esm/config/lambdaParameterConfig.js +0 -38
  373. package/dist/esm/config/replaceConfig.d.ts +0 -14
  374. package/dist/esm/config/resolveConfigValue.d.ts +0 -5
  375. package/dist/esm/config/resolveConfigValue.js +0 -8
  376. package/dist/esm/errors/index.d.ts +0 -88
  377. package/dist/esm/fetch/fetchStatusRetry.d.ts +0 -8
  378. package/dist/esm/fetch/fetchStatusRetry.js +0 -23
  379. package/dist/esm/fetch/index.d.ts +0 -64
  380. package/dist/esm/fetch/index.js +0 -46
  381. package/dist/esm/guards/index.js +0 -36
  382. package/dist/esm/index.d.ts +0 -4
  383. package/dist/esm/index.js +0 -4
  384. package/dist/esm/middleware/apiErrorHandler.d.ts +0 -24
  385. package/dist/esm/middleware/apiErrorHandler.js +0 -38
  386. package/dist/esm/middleware/apiSlowResponseMiddleware.d.ts +0 -23
  387. package/dist/esm/middleware/apiSlowResponseMiddleware.js +0 -50
  388. package/dist/esm/middleware/index.d.ts +0 -47
  389. package/dist/esm/middleware/index.js +0 -44
  390. package/dist/esm/middleware/lambdaCorsResponseMiddleware.d.ts +0 -20
  391. package/dist/esm/middleware/lambdaCorsResponseMiddleware.js +0 -40
  392. package/dist/esm/middleware/throwNotFoundMiddleware.d.ts +0 -4
  393. package/dist/esm/middleware/throwNotFoundMiddleware.js +0 -10
  394. package/dist/esm/misc/hashValue.d.ts +0 -10
  395. package/dist/esm/misc/hashValue.js +0 -13
  396. package/dist/esm/misc/helpers.d.ts +0 -124
  397. package/dist/esm/misc/helpers.js +0 -199
  398. package/dist/esm/misc/merge.d.ts +0 -21
  399. package/dist/esm/misc/merge.js +0 -40
  400. package/dist/esm/misc/partitionSequence.d.ts +0 -35
  401. package/dist/esm/pagination/index.d.ts +0 -91
  402. package/dist/esm/pagination/index.js +0 -77
  403. package/dist/esm/routing/helpers.d.ts +0 -57
  404. package/dist/esm/routing/index.d.ts +0 -290
  405. package/dist/esm/routing/index.js +0 -246
  406. package/dist/esm/routing/validators/zod.d.ts +0 -4
  407. package/dist/esm/routing/validators/zod.js +0 -10
  408. package/dist/esm/services/accountsGateway/index.d.ts +0 -92
  409. package/dist/esm/services/accountsGateway/index.js +0 -131
  410. package/dist/esm/services/apiGateway/index.d.ts +0 -68
  411. package/dist/esm/services/apiGateway/index.js +0 -77
  412. package/dist/esm/services/authProvider/browser.d.ts +0 -40
  413. package/dist/esm/services/authProvider/browser.js +0 -151
  414. package/dist/esm/services/authProvider/decryption.d.ts +0 -19
  415. package/dist/esm/services/authProvider/decryption.js +0 -69
  416. package/dist/esm/services/authProvider/index.d.ts +0 -63
  417. package/dist/esm/services/authProvider/index.js +0 -26
  418. package/dist/esm/services/authProvider/subrequest.d.ts +0 -13
  419. package/dist/esm/services/authProvider/subrequest.js +0 -45
  420. package/dist/esm/services/authProvider/utils/decryptAndVerify.d.ts +0 -28
  421. package/dist/esm/services/authProvider/utils/decryptAndVerify.js +0 -85
  422. package/dist/esm/services/authProvider/utils/embeddedAuthProvider.d.ts +0 -26
  423. package/dist/esm/services/authProvider/utils/embeddedAuthProvider.js +0 -40
  424. package/dist/esm/services/authProvider/utils/userRoleValidator.d.ts +0 -13
  425. package/dist/esm/services/authProvider/utils/userRoleValidator.js +0 -33
  426. package/dist/esm/services/authProvider/utils/userSubrequest.d.ts +0 -3
  427. package/dist/esm/services/authProvider/utils/userSubrequest.js +0 -6
  428. package/dist/esm/services/documentStore/dynamoEncoding.d.ts +0 -10
  429. package/dist/esm/services/documentStore/dynamoEncoding.js +0 -45
  430. package/dist/esm/services/documentStore/fileSystemAssert.d.ts +0 -1
  431. package/dist/esm/services/documentStore/fileSystemAssert.js +0 -10
  432. package/dist/esm/services/documentStore/index.d.ts +0 -14
  433. package/dist/esm/services/documentStore/index.js +0 -1
  434. package/dist/esm/services/documentStore/unversioned/dynamodb.d.ts +0 -31
  435. package/dist/esm/services/documentStore/unversioned/dynamodb.js +0 -226
  436. package/dist/esm/services/documentStore/unversioned/file-system.d.ts +0 -32
  437. package/dist/esm/services/documentStore/unversioned/file-system.js +0 -174
  438. package/dist/esm/services/documentStore/unversioned/index.d.ts +0 -2
  439. package/dist/esm/services/documentStore/unversioned/index.js +0 -1
  440. package/dist/esm/services/documentStore/versioned/dynamodb.d.ts +0 -25
  441. package/dist/esm/services/documentStore/versioned/dynamodb.js +0 -139
  442. package/dist/esm/services/documentStore/versioned/file-system.d.ts +0 -25
  443. package/dist/esm/services/documentStore/versioned/file-system.js +0 -69
  444. package/dist/esm/services/documentStore/versioned/index.d.ts +0 -17
  445. package/dist/esm/services/documentStore/versioned/index.js +0 -1
  446. package/dist/esm/services/exercisesGateway/index.d.ts +0 -67
  447. package/dist/esm/services/exercisesGateway/index.js +0 -70
  448. package/dist/esm/services/fileServer/index.d.ts +0 -30
  449. package/dist/esm/services/fileServer/index.js +0 -13
  450. package/dist/esm/services/fileServer/localFileServer.d.ts +0 -13
  451. package/dist/esm/services/fileServer/localFileServer.js +0 -125
  452. package/dist/esm/services/fileServer/s3FileServer.d.ts +0 -14
  453. package/dist/esm/services/fileServer/s3FileServer.js +0 -125
  454. package/dist/esm/services/launchParams/index.d.ts +0 -2
  455. package/dist/esm/services/launchParams/index.js +0 -2
  456. package/dist/esm/services/launchParams/signer.d.ts +0 -23
  457. package/dist/esm/services/launchParams/signer.js +0 -51
  458. package/dist/esm/services/launchParams/verifier.d.ts +0 -21
  459. package/dist/esm/services/launchParams/verifier.js +0 -92
  460. package/dist/esm/services/logger/console.d.ts +0 -4
  461. package/dist/esm/services/logger/index.js +0 -27
  462. package/dist/esm/services/lrsGateway/addStatementDefaultFields.d.ts +0 -5
  463. package/dist/esm/services/lrsGateway/addStatementDefaultFields.js +0 -14
  464. package/dist/esm/services/lrsGateway/attempt-utils.d.ts +0 -70
  465. package/dist/esm/services/lrsGateway/attempt-utils.js +0 -236
  466. package/dist/esm/services/lrsGateway/file-system.d.ts +0 -15
  467. package/dist/esm/services/lrsGateway/file-system.js +0 -110
  468. package/dist/esm/services/lrsGateway/index.d.ts +0 -122
  469. package/dist/esm/services/lrsGateway/index.js +0 -111
  470. package/dist/esm/services/lrsGateway/xapiUtils.d.ts +0 -68
  471. package/dist/esm/services/lrsGateway/xapiUtils.js +0 -99
  472. package/dist/esm/services/postgresConnection/index.d.ts +0 -28
  473. package/dist/esm/services/postgresConnection/index.js +0 -58
  474. package/dist/esm/services/searchProvider/index.d.ts +0 -67
  475. package/dist/esm/services/searchProvider/index.js +0 -1
  476. package/dist/esm/services/searchProvider/memorySearchTheBadWay.d.ts +0 -20
  477. package/dist/esm/services/searchProvider/memorySearchTheBadWay.js +0 -187
  478. package/dist/esm/services/searchProvider/openSearch.d.ts +0 -28
  479. package/dist/esm/services/searchProvider/openSearch.js +0 -150
  480. package/dist/esm/tsconfig.without-specs.esm.tsbuildinfo +0 -1
  481. package/dist/esm/types.js +0 -1
  482. package/script/bin/.init-params-script.bash.swp +0 -0
  483. /package/{script → packages/utils/script}/bin/copy-from-template.bash +0 -0
  484. /package/{script → packages/utils/script}/bin/delete-stack.bash +0 -0
  485. /package/{script → packages/utils/script}/bin/deploy.bash +0 -0
  486. /package/{script → packages/utils/script}/bin/destroy-deployment.bash +0 -0
  487. /package/{script → packages/utils/script}/bin/empty-bucket.bash +0 -0
  488. /package/{script → packages/utils/script}/bin/get-arg.bash +0 -0
  489. /package/{script → packages/utils/script}/bin/get-deployed-environments.bash +0 -0
  490. /package/{script → packages/utils/script}/bin/get-env-param.bash +0 -0
  491. /package/{script → packages/utils/script}/bin/get-kwarg.bash +0 -0
  492. /package/{script → packages/utils/script}/bin/get-stack-param.bash +0 -0
  493. /package/{script → packages/utils/script}/bin/has-flag.bash +0 -0
  494. /package/{script → packages/utils/script}/bin/init-constants-script.bash +0 -0
  495. /package/{script → packages/utils/script}/bin/init-params-script.bash +0 -0
  496. /package/{script → packages/utils/script}/bin/stack-exists.bash +0 -0
  497. /package/{script → packages/utils/script}/bin/update-utils.bash +0 -0
  498. /package/{script → packages/utils/script}/bin/upload-pager-duty-endpoints.bash +0 -0
  499. /package/{script → packages/utils/script}/bin/upload-params.bash +0 -0
  500. /package/{script → packages/utils/script}/bin/which.bash +0 -0
  501. /package/{script → packages/utils/script}/bin-entry.bash +0 -0
  502. /package/{script → packages/utils/script}/build.bash +0 -0
  503. /package/{dist/cjs/index.d.ts → packages/utils/src/index.ts} +0 -0
  504. /package/{dist/cjs/services/launchParams/index.d.ts → packages/utils/src/services/launchParams/index.ts} +0 -0
@@ -1,55 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.stateHasError = exports.stateHasData = exports.fetchIdle = exports.fetchSuccess = exports.fetchError = exports.fetchLoading = exports.FetchStateType = void 0;
4
- /*
5
- * these are just helpers for formatting responses, they don't actually do any loading. especially in UI development they
6
- * help with continuity over loading, reloading, saving, and errors. this is pretty nice in typescript because you have to deal
7
- * with the possibility that the result state is in a loading or error state. if you avoid dealing with those states you need
8
- * to write very clear code to ignore them, which easily presents missing functionality like errors that are not being messaged
9
- * to the user.
10
- * */
11
- var FetchStateType;
12
- (function (FetchStateType) {
13
- FetchStateType["SUCCESS"] = "success";
14
- FetchStateType["ERROR"] = "error";
15
- FetchStateType["LOADING"] = "loading";
16
- FetchStateType["IDLE"] = "idle";
17
- })(FetchStateType || (exports.FetchStateType = FetchStateType = {}));
18
- /*
19
- * keeps existing data but sets the new status
20
- *
21
- * const state = fetchLoading(previousState)
22
- * */
23
- const fetchLoading = (previous) => ({ type: FetchStateType.LOADING, ...(previous && 'data' in previous ? { data: previous.data } : {}) });
24
- exports.fetchLoading = fetchLoading;
25
- /*
26
- * keeps existing data but sets the new status and error value
27
- *
28
- * const state = fetchError(error, previousState)
29
- * */
30
- const fetchError = (error, previous) => ({ ...previous, type: FetchStateType.ERROR, error });
31
- exports.fetchError = fetchError;
32
- /*
33
- * formats data with success type
34
- *
35
- * const state = fetchSuccess(newData)
36
- * */
37
- const fetchSuccess = (data) => ({ type: FetchStateType.SUCCESS, data });
38
- exports.fetchSuccess = fetchSuccess;
39
- /*
40
- * formats data with idle type
41
- *
42
- * const state = fetchIdle(newData)
43
- * */
44
- const fetchIdle = () => ({ type: FetchStateType.IDLE });
45
- exports.fetchIdle = fetchIdle;
46
- /*
47
- * guard for checking if the state has result data, it might be true for any state type.
48
- * */
49
- const stateHasData = (state) => 'data' in state;
50
- exports.stateHasData = stateHasData;
51
- /*
52
- * guard for checking if the state has an error, it might be true for error or loading states.
53
- * */
54
- const stateHasError = (state) => 'error' in state;
55
- exports.stateHasError = stateHasError;
@@ -1,38 +0,0 @@
1
- /**
2
- * checks if a thing is defined. while often easy to do with a simple if statement, in certain
3
- * situations the guard is required and its nice to have one pre-defined. E.g. in the following
4
- * example, the result is `Array<string>`.
5
- *
6
- * `const result = (array as Array<string | undefined>).filter(isDefined);`
7
- */
8
- export declare const isDefined: <X>(x: X) => x is Exclude<X, undefined>;
9
- /**
10
- * checks if a thing is not null. while often easy to do with a simple if statement,
11
- * in certain situations the guard is required and its nice to have one pre-defined.
12
- * E.g. in the following example, the result is `Array<string>`.
13
- *
14
- * `const result = (array as Array<string | null>).filter(isNotNull);`
15
- */
16
- export declare const isNotNull: <X>(x: X) => x is Exclude<X, null>;
17
- /**
18
- * checks if a thing is a number. while often easy to do with a simple if statement, in certain
19
- * situations the guard is required and its nice to have one pre-defined. E.g. in the following
20
- * example, the result is `Array<number>`.
21
- *
22
- * `const result = (array as Array<number | undefined>).filter(isNumber);`
23
- */
24
- export declare const isNumber: (x: any) => x is number;
25
- /**
26
- * a guard for plain old javascript objects that are not based on some other prototype,
27
- * for example making them safe to JSON stringify and stuff
28
- */
29
- export declare const isPlainObject: (thing: any) => thing is {
30
- [key: string]: any;
31
- };
32
- /**
33
- * if the first thing is defined it uses it, otherwise it returns the second thing. this isn't
34
- * really a guard its just a way to provide a default value without creating a coverage branch.
35
- *
36
- * @example const valueWithDefault = ifDefined(thing, 'default value')
37
- */
38
- export declare const ifDefined: <X, D>(x: X, d: D) => D | Exclude<X, undefined>;
@@ -1,44 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ifDefined = exports.isPlainObject = exports.isNumber = exports.isNotNull = exports.isDefined = void 0;
4
- /**
5
- * checks if a thing is defined. while often easy to do with a simple if statement, in certain
6
- * situations the guard is required and its nice to have one pre-defined. E.g. in the following
7
- * example, the result is `Array<string>`.
8
- *
9
- * `const result = (array as Array<string | undefined>).filter(isDefined);`
10
- */
11
- const isDefined = (x) => x !== undefined;
12
- exports.isDefined = isDefined;
13
- /**
14
- * checks if a thing is not null. while often easy to do with a simple if statement,
15
- * in certain situations the guard is required and its nice to have one pre-defined.
16
- * E.g. in the following example, the result is `Array<string>`.
17
- *
18
- * `const result = (array as Array<string | null>).filter(isNotNull);`
19
- */
20
- const isNotNull = (x) => x !== null;
21
- exports.isNotNull = isNotNull;
22
- /**
23
- * checks if a thing is a number. while often easy to do with a simple if statement, in certain
24
- * situations the guard is required and its nice to have one pre-defined. E.g. in the following
25
- * example, the result is `Array<number>`.
26
- *
27
- * `const result = (array as Array<number | undefined>).filter(isNumber);`
28
- */
29
- const isNumber = (x) => typeof x === 'number';
30
- exports.isNumber = isNumber;
31
- /**
32
- * a guard for plain old javascript objects that are not based on some other prototype,
33
- * for example making them safe to JSON stringify and stuff
34
- */
35
- const isPlainObject = (thing) => thing instanceof Object && thing.__proto__.constructor.name === 'Object';
36
- exports.isPlainObject = isPlainObject;
37
- /**
38
- * if the first thing is defined it uses it, otherwise it returns the second thing. this isn't
39
- * really a guard its just a way to provide a default value without creating a coverage branch.
40
- *
41
- * @example const valueWithDefault = ifDefined(thing, 'default value')
42
- */
43
- const ifDefined = (x, d) => (0, exports.isDefined)(x) ? x : d;
44
- exports.ifDefined = ifDefined;
package/dist/cjs/index.js DELETED
@@ -1,20 +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 __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./misc/partitionSequence"), exports);
18
- __exportStar(require("./misc/helpers"), exports);
19
- __exportStar(require("./misc/merge"), exports);
20
- __exportStar(require("./misc/hashValue"), exports);
@@ -1,24 +0,0 @@
1
- import { ForbiddenError, InvalidRequestError, NotFoundError, SessionExpiredError, UnauthorizedError, ValidationError } from '../errors';
2
- import type { ApiResponse } from '../routing';
3
- import type { Logger } from '../services/logger';
4
- export type DefaultErrors = {
5
- InvalidRequestError: InvalidRequestError;
6
- UnauthorizedError: UnauthorizedError;
7
- ForbiddenError: ForbiddenError;
8
- NotFoundError: NotFoundError;
9
- ValidationError: ValidationError;
10
- SessionExpiredError: SessionExpiredError;
11
- };
12
- export type Handlers<E> = {
13
- [T in keyof E]?: (e: E[T], logger: Logger) => ApiResponse<number, any>;
14
- };
15
- export declare const defaultHandlers: Handlers<DefaultErrors>;
16
- /**
17
- * Creates an error handler. Provides default handlers for `UnauthorizedError`,
18
- * `SessionExpiredError`, `NotFoundError`, and `InvalidRequestError`. User-specified
19
- * handlers can be added to these. If no handler is found, the error is logged and
20
- * a 500 text response is returned.
21
- *
22
- * @param inputHandlers a map of errors to handler functions
23
- */
24
- export declare const createErrorHandler: <Errors = DefaultErrors>(inputHandlers?: Handlers<Errors>) => (e: Error, logger: Logger) => Promise<ApiResponse<number, any>>;
@@ -1,42 +0,0 @@
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;
@@ -1,23 +0,0 @@
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 {};
@@ -1,54 +0,0 @@
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,48 +0,0 @@
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;
@@ -1,20 +0,0 @@
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 {};
@@ -1,44 +0,0 @@
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;
@@ -1,4 +0,0 @@
1
- /**
2
- * Creates response middleware that throws a `NotFoundError` if the response is undefined.
3
- */
4
- export declare const createThrowNotFoundMiddleware: <Ro>() => () => (response: Promise<Ro> | undefined) => Promise<Ro>;
@@ -1,14 +0,0 @@
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;
@@ -1,10 +0,0 @@
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;
@@ -1,17 +0,0 @@
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;
@@ -1,124 +0,0 @@
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 {};