@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
@@ -0,0 +1,424 @@
1
+ import * as pathToRegexp from 'path-to-regexp';
2
+ import queryString from 'query-string';
3
+ import { mapFind, memoize } from '../misc/helpers';
4
+ import { Logger } from '../services/logger';
5
+ import { createConsoleLogger } from '../services/logger/console';
6
+
7
+ /* begin route structures */
8
+
9
+ /* Generic type meanings:
10
+ * R: route. usually a placeholder for a specific route.
11
+ * Ru: route union. union of all actual routes defined by the application.
12
+ * Ri: route input. the router input, could be `Window.Location`, or `APIGatewayProxyEventV2` or something like that
13
+ * Ro: route output. the interface for what routes return. could be a react component, or the `ApiResponse` defined below
14
+ * RoF: route output final. the route output after response middleware runs. for instance in an api Ro will usually include `undefined` but 404 handling middleware will remove make RoF always `ApiResponse`
15
+ * P: route params. the uri parameters of the route
16
+ * Sa: app services. the app services (or service drivers) defined by the app entrypoint.
17
+ * Sr: request services. the request services built by this routes middleware chain.
18
+ * Ex: extension type. for arbitrary extra stuff only used in certain context, like METHOD in api routes.
19
+ * N: route name. union discriminator, and used as the api client method name when using the ApiGateway service.
20
+ */
21
+
22
+ /** HTTP query parameters */
23
+ export type QueryParams = Record<string, string | undefined | string[] | null>;
24
+
25
+ /**
26
+ * The type for a map of string substitutions to use when building route paths, e.g. a route may
27
+ * be defined as `'/api/:id'` and then rendered as `'/api/123'` when the `id` route param is set
28
+ * to `'123'`
29
+ */
30
+ export type RouteParams = {[key: string]: string};
31
+
32
+ /** A type that is compatible with any `Route` type */
33
+ export type AnyRoute<R> = R extends Route<infer N, infer P, infer Sa, infer Sr, infer Ri, infer Ro> ? Route<N, P, Sa, Sr, Ri, Ro> : never;
34
+ export type AnySpecificRoute<R, Sa, Ri, Ro> = R extends Route<infer N, infer P, Sa, infer Sr, Ri, Ro> & infer E ? Route<N, P, Sa, Sr, Ri, Ro> & E : never;
35
+
36
+ /** The inferred "route output" (`Ro`) type for a given route */
37
+ export type OutputForRoute<R> = R extends Route<any, any, any, any, any, infer Ro> ? Ro : never;
38
+
39
+ /** The inferred type for the params of the provided route type, `R`; may be undefined */
40
+ export type ParamsForRoute<R> = R extends Route<any, infer P, any, any, any, any> ? P : never;
41
+
42
+ /** The inferred type for the request services of the provided route type, `R`. */
43
+ export type RequestServicesForRoute<R> = R extends Route<any, any, any, infer Sr, any, any> ? Sr : never;
44
+
45
+ /** The type for the params of the provided route type, `R`; will be `{}` if undefined */
46
+ export type ParamsForRouteOrEmpty<R> = ParamsForRoute<R> extends undefined ? {} : Exclude<ParamsForRoute<R>, undefined>;
47
+
48
+ /** derives the route match type for this route, which includes the route itself and the matching params. */
49
+ export type RouteMatchRecord<R> = R extends AnyRoute<R> ? {route: R; params: ParamsForRoute<R>} : never;
50
+
51
+
52
+ type Flatten<T> = T extends any ? { [K in keyof T]: T[K] } : never;
53
+ export type ExternalRoute<R> = R extends Route<infer N, infer P, infer Sa, infer Sr, infer Ri, infer Ro> & infer E
54
+ ? Route<N, P, Sa, Sr extends {payload: any} ? Flatten<Pick<Sr, 'payload'>> : Record<string, never>, Ri, Ro>
55
+ & Flatten<Omit<E, 'name' | 'path' | 'handler' | 'requestServiceProvider'>>
56
+ : never;
57
+
58
+ /** this utility simplifies the route type to remove stuff that is only
59
+ * relevant internal to the route, like the service types, keeping only
60
+ * the payload type which is necessary for the apiGateway
61
+ *
62
+ * this helps avoid the "type too complicated" error that typescript throws
63
+ * when there are a lot of routes with complex services
64
+ **/
65
+ export const routesList = <R>(routes: R[]) => routes as ExternalRoute<R>[];
66
+
67
+ /**
68
+ * The conditional type for the payload for a given route, `R`. This isn't a route structure, its
69
+ * a convention based on the request middleware
70
+ */
71
+ export type PayloadForRoute<R> = RequestServicesForRoute<R> extends {payload: any}
72
+ ? RequestServicesForRoute<R>['payload']
73
+ : undefined;
74
+
75
+ /* begin route creation helpers */
76
+
77
+ // specifies `any` for output because i'm pretty sure it doesn't matter and it confuses the MakeRequestResponder type
78
+ type RequestServiceProvider<Sa, Sr, Ri> = (app: Sa) => <R>(middleware: {request: Ri; logger: Logger}, match: RouteMatchRecord<R>) => Sr;
79
+ type RouteHandler<P, Sr, Ro> = (params: P, request: Sr) => Ro;
80
+ type Route<N extends string, P extends RouteParams | undefined, Sa, Sr, Ri, Ro> =
81
+ (Sr extends undefined
82
+ ? {requestServiceProvider?: RequestServiceProvider<Sa, Sr, Ri> | undefined }
83
+ : {requestServiceProvider: RequestServiceProvider<Sa, Sr, Ri> }
84
+ )
85
+ &
86
+ {name: N; path: string; handler: (params: P, request: Sr) => Ro}
87
+ ;
88
+
89
+ type CreateRouteConfig<Sa, Sr, Ri, N extends string, Ex> =
90
+ (Sr extends undefined
91
+ ? {requestServiceProvider?: RequestServiceProvider<Sa, Sr, Ri> | undefined }
92
+ : {requestServiceProvider: RequestServiceProvider<Sa, Sr, Ri> }
93
+ )
94
+ &
95
+ {name: N; path: string}
96
+ & Ex
97
+ ;
98
+
99
+ /**
100
+ * Interface for a function that creates a route. There are two overloaded signatures, because
101
+ * sometimes typescript can't figure out the value of `Sr` between the handler and the service
102
+ * provider. Forcing it through the provider types first by putting the handler in a subsequent
103
+ * argument seems to help.
104
+ */
105
+ export interface CreateRoute<Sa, Ri, Ex> {
106
+ <N extends string, Ro, Sr extends unknown | undefined = undefined, P extends RouteParams | undefined = undefined>(config: CreateRouteConfig<Sa, Sr, Ri, N, Ex> & {handler: RouteHandler<P, Sr, Ro>}): Route<N, P, Sa, Sr, Ri, Ro> & Ex;
107
+ <N extends string, Ro, Sr extends unknown | undefined, P extends RouteParams | undefined = undefined>(config: CreateRouteConfig<Sa, Sr, Ri, N, Ex>, handler: RouteHandler<P, Sr, Ro>): Route<N, P, Sa, Sr, Ri, Ro> & Ex;
108
+ }
109
+
110
+ /**
111
+ * Makes a createRoute function that can be used to create routes (this is a factory factory). The
112
+ * `makeCreateRoute` function is typically called once in the backend and once in the frontend to
113
+ * set the types for the resulting `createRoute` function -- that latter function is called once
114
+ * per route. E.g. for the backend, the call could look like:
115
+ *
116
+ * ```
117
+ * export const createRoute = makeCreateRoute<AppServices, ApiRouteRequest, {
118
+ * method: METHOD;
119
+ * }>();
120
+ * ```
121
+ *
122
+ * Notes:
123
+ * * The `{method: METHOD}` defines the `Ex` extension type; here, the `method` property is only
124
+ * relevant to backend routes.
125
+ * * when defining the `createRoute` method, only the request input format is defined, the output
126
+ * format is derived from the routes.
127
+ *
128
+ * When calling the resulting `createRoute` function, the only required params of the route are the
129
+ * name, path, and handler. Other params can be added to the type and then later used in the
130
+ * routeMatcher.
131
+ *
132
+ * eg when defining requestServiceProvider in line, the types have a hard time, it helps to put in another argument:
133
+ * ```
134
+ * export const exampleRoute = createRoute({
135
+ * name: 'exampleRoute', method: METHOD.GET, path: '/api/example/:key',
136
+ * requestServiceProvider: composeServiceMiddleware({
137
+ * cookieAuthMiddleware,
138
+ * documentStoreMiddleware,
139
+ * }},
140
+ * async(params: {key: string}, services) => {
141
+ * const result = await services.myDocumentStore.getItem(params.key);
142
+ *
143
+ * if (!result) {
144
+ * throw new NotFoundError('requested item not found');
145
+ * }
146
+ *
147
+ * return apiJsonResponse(200, result);
148
+ * }
149
+ * );
150
+ * ```
151
+ * eg when using a pre-existing provider variable the types work better:
152
+ * ```
153
+ * export const exampleRoute = createRoute({
154
+ * name: 'exampleRoute', method: METHOD.GET, path: '/api/example/:key',
155
+ * requestServiceProvider,
156
+ * handler: async(params: {key: string}, services) => {
157
+ * const result = await services.myDocumentStore.getItem(params.key);
158
+ *
159
+ * if (!result) {
160
+ * throw new NotFoundError('requested item not found');
161
+ * }
162
+ *
163
+ * return apiJsonResponse(200, result);
164
+ * }
165
+ * });
166
+ * ```
167
+ */
168
+ export const makeCreateRoute = <Sa, Ri, Ex = {}>(): CreateRoute<Sa, Ri, Ex> => <N extends string, Ro, Sr, P extends RouteParams | undefined = undefined>(...args: [CreateRouteConfig<Sa, Sr, Ri, N, Ex> & {handler: RouteHandler<P, Sr, Ro>}] | [CreateRouteConfig<Sa, Sr, Ri, N, Ex>, RouteHandler<P, Sr, Ro>]): Route<N, P, Sa, Sr, Ri, Ro> & Ex => {
169
+
170
+ return (args.length === 1
171
+ ? args[0]
172
+ : {...args[0], handler: args[1]}
173
+ ) as Route<N, P, Sa, Sr, Ri, Ro> & Ex;
174
+ };
175
+
176
+ /* begin reverse routing utils */
177
+
178
+ /**
179
+ * Makes a renderRouteUrl function that can be used to render route paths (this is a factory
180
+ * factory). The returned function takes a `route`, `params`, and `query` and returns a string
181
+ * with the params and query substituted into the route path.
182
+ *
183
+ * this function is initialized using the Ru type which indicates the specific routes wired into
184
+ * the application, which means that if you try to build a url with a route which is not wired
185
+ * into the router you will get a type error. this is a feature to prevent referencing routes that
186
+ * don't exist or aren't handling requests properly.
187
+ *
188
+ * if you are making a helper function or need to render a route outside your application, you
189
+ * can use the `renderAnyRouteUrl` function
190
+ */
191
+ export const makeRenderRouteUrl = <Ru extends {path: string}>() => <R>(
192
+ route: ExternalRoute<R> extends Ru ? R & {path: string} : R extends Ru ? R : never,
193
+ params: ParamsForRoute<R>,
194
+ query: QueryParams = {}
195
+ ) => {
196
+ const getPathForParams = pathToRegexp.compile(route.path, { encode: encodeURIComponent });
197
+ const search = queryString.stringify(query);
198
+ const path = getPathForParams(params) + (search ? `?${search}` : '');
199
+
200
+ return path;
201
+ };
202
+
203
+ /**
204
+ * A pre-made result from `makeRenderRouteUrl`, this function interpolates parameter and query
205
+ * arguments into a route path.
206
+ *
207
+ * prefer using `renderRouteUrl` initialized with your applications route union
208
+ * when possible to help catch improperly initialized routes.
209
+ *
210
+ * @param route the route that has a `path` to be interpolated
211
+ * @param params the parameters to interpolate into the route path
212
+ * @param query the query parameters to add to the route path
213
+ * @returns the interpolated route path
214
+ */
215
+ export const renderAnyRouteUrl = makeRenderRouteUrl<any>();
216
+
217
+ /* begin request responder */
218
+
219
+ type RequestPathExtractor<Ri> = (request: Ri) => string;
220
+ type RequestLogExtractor<Ri> = (request: Ri) => JsonCompatibleStruct;
221
+ type RequestRouteMatcher<Ri, R> = (request: Ri, route: R) => boolean;
222
+ type AppBinder = <Sa, F extends ((app: Sa, appBinder?: AppBinder) => any)>(app: Sa, middleware: F) => ReturnType<F>;
223
+
224
+ const bindRoute = <Sa, R, Ri, Ro>(services: Sa, appBinder: AppBinder, pathExtractor: RequestPathExtractor<Ri>, matcher?: RequestRouteMatcher<Ri, AnySpecificRoute<R, Sa, Ri, Ro>>) => (route: AnySpecificRoute<R, Sa, Ri, Ro>) => {
225
+ const getParamsFromPath = pathToRegexp.match<ParamsForRouteOrEmpty<R>>(route.path, { decode: decodeURIComponent });
226
+ const boundServiceProvider = route.requestServiceProvider && appBinder(services, route.requestServiceProvider);
227
+
228
+ return (request: Ri, logger: Logger) => {
229
+ const path = pathExtractor(request);
230
+ const match = getParamsFromPath(path);
231
+
232
+ if ((!matcher || matcher(request, route)) && match) {
233
+ return {
234
+ name: route.name,
235
+ executor: () => route.handler(match.params, boundServiceProvider ? boundServiceProvider<R>({request, logger}, {route, params: match.params} as any) : undefined)
236
+ };
237
+ }
238
+ };
239
+ };
240
+
241
+ // this is a hack around weak type detection blocking use of the system without specifying a logger
242
+ // https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-4.html#weak-type-detection
243
+ type CompatibleServices<T1> = keyof T1 extends 'logger' ? T1 extends {logger: Logger} ? T1 : never : T1 & {logger?: Logger};
244
+
245
+ type RequestResponder<Sa, Ri, Ro> = {
246
+ (services: CompatibleServices<Sa>): (request: Ri) => Ro | undefined;
247
+ <RoF>(services: CompatibleServices<Sa>, responseMiddleware: (app: Sa) => (response: Ro | undefined, request: {request: Ri; logger: Logger}) => RoF): (request: Ri) => RoF;
248
+ };
249
+
250
+
251
+ /**
252
+ * A factory factory for creating request responders (functions that take a request and return a
253
+ * response -- these functions let us implement Lambda `handler` functions).
254
+ *
255
+ * Use it in two steps. First, call it with the general business logic that defines routes, logs,
256
+ * errors, etc:
257
+ * ```
258
+ * const getRequestResponder = makeGetRequestResponder<
259
+ * AppServices, TRoutes, ApiRouteRequest, Promise<ApiRouteResponse>
260
+ * >() // this empty invocation helps typescript mix defined and inferred types
261
+ * ({
262
+ * routes: apiRoutes, // the route definitions
263
+ * pathExtractor, // how to get the path out of the request format
264
+ * routeMatcher, // logic for matching route (beyond path matching, optional)
265
+ * errorHandler, // any special error handling
266
+ * });
267
+ * ```
268
+ * Note here that among other things we're specifying a generic response format that the response
269
+ * and error handling middleware can use, if any routes have responses that don't adhere to this
270
+ * it'll complain about it.
271
+ *
272
+ * Next, we use the `getRequestResponder` to create a responder for a specific lambda entrypoint:
273
+ * ```
274
+ * export const handler: (request: APIGatewayProxyEventV2): Promise<ApiRouteResponse> =>
275
+ * getRequestResponder(
276
+ * lambdaServices, // the AppServices for this entrypoint
277
+ * lambdaMiddleware // environment specific response middleware (like cors)
278
+ * );
279
+ * ```
280
+ */
281
+ export const makeGetRequestResponder = <Sa, Ru, Ri, Ro>() => (
282
+ {routes, pathExtractor, routeMatcher, errorHandler, logExtractor}: {
283
+ routes: () => AnySpecificRoute<Ru, Sa, Ri, Ro>[];
284
+ pathExtractor: RequestPathExtractor<Ri>;
285
+ logExtractor?: RequestLogExtractor<Ri>;
286
+ routeMatcher?: RequestRouteMatcher<Ri, AnySpecificRoute<Ru, Sa, Ri, Ro>>;
287
+ errorHandler?: (e: Error, logger: Logger) => Ro;
288
+ }
289
+ ): RequestResponder<Sa, Ri, Ro> => <RoF>(
290
+ services: CompatibleServices<Sa>,
291
+ responseMiddleware?: (app: Sa) => (response: Ro | undefined, request: {request: Ri; logger: Logger}) => RoF
292
+ ) => {
293
+ const appBinderImpl: AppBinder = (app, middleware) => middleware(app, appBinder);
294
+ const appBinder = memoize(appBinderImpl);
295
+ const boundRoutes = routes().map(bindRoute<Sa, Ru, Ri, Ro>(services, appBinder, pathExtractor, routeMatcher));
296
+ const boundResponseMiddleware = responseMiddleware ? responseMiddleware(services) : undefined;
297
+ const appLogger = services.logger || createConsoleLogger();
298
+
299
+ // *note* this opaque promise guard is less generic than i hoped so
300
+ // i'm leaving it here instead of the guards file.
301
+ //
302
+ // its less than ideal because it enforces that the handlers return
303
+ // the same type as the parent promise, usually a handler can be either a
304
+ // promise or a non-promise value and the promise figures it out, but those
305
+ // types are getting complicated quickly here.
306
+ const isPromise = <T>(thing: T): thing is T & {
307
+ catch: <R extends T>(handler: (e: any) => R) => T | R;
308
+ then: <R extends T>(handler: (p: unknown) => R) => R;
309
+ } => thing instanceof Promise;
310
+
311
+ return (request: Ri): undefined | Ro | RoF => {
312
+ const logger = appLogger.createSubContext();
313
+
314
+ if (logExtractor) {
315
+ logger.setContext(logExtractor(request));
316
+ }
317
+
318
+ logger.log('begin request');
319
+
320
+ try {
321
+ const route = mapFind(boundRoutes, (route) => route(request, logger));
322
+
323
+ if (route) {
324
+ logger.log(`route matched ${route.name}`);
325
+
326
+ const result = boundResponseMiddleware ?
327
+ boundResponseMiddleware(route.executor(), {request, logger}) : route.executor();
328
+
329
+ if (isPromise(result) && errorHandler) {
330
+ const errorHandlerWithMiddleware = (e: Error) => boundResponseMiddleware ?
331
+ boundResponseMiddleware(errorHandler(e, logger), {request, logger}) : errorHandler(e, logger);
332
+
333
+ return result.catch(errorHandlerWithMiddleware);
334
+ } else {
335
+ return result;
336
+ }
337
+ } else if (boundResponseMiddleware) {
338
+ logger.log('no route matched, returning 404');
339
+ return boundResponseMiddleware(undefined, {request, logger});
340
+ }
341
+ } catch (e) {
342
+ if (errorHandler && e instanceof Error) {
343
+ return boundResponseMiddleware
344
+ ? boundResponseMiddleware(errorHandler(e, logger), {request, logger})
345
+ : errorHandler(e, logger)
346
+ ;
347
+ }
348
+
349
+ throw e;
350
+ }
351
+
352
+ return undefined;
353
+ };
354
+ };
355
+
356
+ /* begin mixin utils for API side */
357
+
358
+ /** HTTP Headers */
359
+ export type HttpHeaders = {[key: string]: string | undefined | string[]};
360
+
361
+ /** A type that works in JSON */
362
+ export type JsonCompatibleValue = string | number | null | undefined | boolean;
363
+
364
+ /** A JSON array type */
365
+ export type JsonCompatibleArray = Array<JsonCompatibleValue | JsonCompatibleStruct | JsonCompatibleStruct>;
366
+
367
+ /** A JSON object type */
368
+ export type JsonCompatibleStruct = {[key: string]: JsonCompatibleStruct | JsonCompatibleValue | JsonCompatibleArray};
369
+
370
+ /** The type for an API response */
371
+ export type ApiResponse<S extends number, T> = {
372
+ isBase64Encoded?: boolean;
373
+ statusCode: S;
374
+ data: T;
375
+ body: string;
376
+ headers?: {[key: string]: string};
377
+ };
378
+
379
+ /**
380
+ * Returns a JSON response. Handles serializing the data to JSON and setting the content-type header.
381
+ * @param statusCode e.g. 201
382
+ * @param data the object to be serialized to JSON
383
+ * @param headers HTTP headers
384
+ * @example
385
+ * return apiJsonResponse(
386
+ * 200, {
387
+ * message: "hello, world!",
388
+ * foo: "bar",
389
+ * },
390
+ * { 'X-Frame-Options': 'DENY' }
391
+ * );
392
+ */
393
+ export const apiJsonResponse = <S extends number, T extends JsonCompatibleStruct>(statusCode: S, data: T, headers?: HttpHeaders): ApiResponse<S, T> => ({statusCode, data, body: JSON.stringify(data), headers: {...headers, 'content-type': 'application/json'}});
394
+
395
+ /**
396
+ * Returns a plain text response. Handles setting the content-type header.
397
+ * @param statusCode e.g. 201
398
+ * @param data some string
399
+ * @param headers HTTP headers
400
+ * @example return apiTextResponse(200, 'some text')
401
+ */
402
+ export const apiTextResponse = <S extends number>(statusCode: S, data: string, headers?: HttpHeaders): ApiResponse<S, string> => ({statusCode, data, body: data, headers: {...headers, 'content-type': 'text/plain'}});
403
+
404
+ /**
405
+ * Returns an HTML response. Handles setting the content-type header.
406
+ * @param statusCode e.g. 201
407
+ * @param data some string
408
+ * @param headers HTTP headers
409
+ * @example return apiHtmlResponse(200, '<b>some text</b>')
410
+ */
411
+ export const apiHtmlResponse = <S extends number>(statusCode: S, data: string, headers?: HttpHeaders): ApiResponse<S, string> => ({statusCode, data, body: data, headers: {...headers, 'content-type': 'text/html'}});
412
+
413
+ /** HTTP method enum */
414
+ export enum METHOD {
415
+ GET = 'GET',
416
+ HEAD = 'HEAD',
417
+ POST = 'POST',
418
+ PUT = 'PUT',
419
+ PATCH = 'PATCH',
420
+ DELETE = 'DELETE',
421
+ OPTIONS = 'OPTIONS',
422
+ }
423
+
424
+ export * from './helpers';
@@ -0,0 +1,16 @@
1
+ import * as z from 'zod';
2
+ import { ValidationError } from '../../errors';
3
+ import { zodPayloadValidator } from './zod';
4
+
5
+ describe('zodPayloadValidator', () => {
6
+
7
+ it('passes', () => {
8
+ const schema = z.object({field: z.string()});
9
+ expect(zodPayloadValidator(schema)({field: 'value'})).toBe(true);
10
+ });
11
+
12
+ it('fails', () => {
13
+ const schema = z.object({field: z.string()});
14
+ expect(() => zodPayloadValidator(schema)({field: 1})).toThrow(ValidationError);
15
+ });
16
+ });
@@ -0,0 +1,14 @@
1
+ /* spell-checker: ignore treeify */
2
+ import { treeifyError } from 'zod';
3
+ import type { z } from 'zod';
4
+ import { ValidationError } from '../../errors';
5
+
6
+ export const zodPayloadValidator = <T extends {}>(validator: z.ZodType<T, T>) => (input: {[key: string]: any}): input is T => {
7
+ const result = validator.safeParse(input);
8
+
9
+ if (result.success) {
10
+ return true;
11
+ }
12
+
13
+ throw new ValidationError(treeifyError(result.error));
14
+ };
@@ -0,0 +1,3 @@
1
+ # accountsGateway
2
+
3
+ Typing/formatting for interacting with OpenStax Accounts