@bitblit/ratchet-epsilon-common 4.0.85-alpha

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 (409) hide show
  1. package/CHANGELOG.md +177 -0
  2. package/License.txt +13 -0
  3. package/README.md +242 -0
  4. package/dist/cjs/background/background-dynamo-log-table-handler.js +38 -0
  5. package/dist/cjs/background/background-entry.js +2 -0
  6. package/dist/cjs/background/background-execution-event-type.js +11 -0
  7. package/dist/cjs/background/background-execution-event.js +2 -0
  8. package/dist/cjs/background/background-execution-listener.js +2 -0
  9. package/dist/cjs/background/background-handler.js +269 -0
  10. package/dist/cjs/background/background-http-adapter-handler.js +127 -0
  11. package/dist/cjs/background/background-meta-response-internal.js +2 -0
  12. package/dist/cjs/background/background-process-handling.js +8 -0
  13. package/dist/cjs/background/background-process-log-table-entry.js +2 -0
  14. package/dist/cjs/background/background-queue-response-internal.js +2 -0
  15. package/dist/cjs/background/background-validator.js +88 -0
  16. package/dist/cjs/background/epsilon-background-process-error.js +93 -0
  17. package/dist/cjs/background/internal-background-entry.js +2 -0
  18. package/dist/cjs/background/manager/abstract-background-manager.js +92 -0
  19. package/dist/cjs/background/manager/aws-sqs-sns-background-manager.js +153 -0
  20. package/dist/cjs/background/manager/background-manager-like.js +2 -0
  21. package/dist/cjs/background/manager/single-thread-local-background-manager.js +49 -0
  22. package/dist/cjs/background/s3-background-transaction-logger.js +54 -0
  23. package/dist/cjs/build/ratchet-epsilon-common-info.js +18 -0
  24. package/dist/cjs/built-in/background/echo-processor.js +18 -0
  25. package/dist/cjs/built-in/background/log-and-enqueue-echo-processor.js +16 -0
  26. package/dist/cjs/built-in/background/log-message-background-error-processor.js +10 -0
  27. package/dist/cjs/built-in/background/no-op-processor.js +13 -0
  28. package/dist/cjs/built-in/background/retry-processor.js +41 -0
  29. package/dist/cjs/built-in/background/sample-delay-processor.js +16 -0
  30. package/dist/cjs/built-in/background/sample-input-validated-processor-data.js +2 -0
  31. package/dist/cjs/built-in/background/sample-input-validated-processor.js +16 -0
  32. package/dist/cjs/built-in/built-in-trace-id-generators.js +25 -0
  33. package/dist/cjs/built-in/daemon/daemon-authorizer-function.js +2 -0
  34. package/dist/cjs/built-in/daemon/daemon-config.js +2 -0
  35. package/dist/cjs/built-in/daemon/daemon-group-selection-function.js +2 -0
  36. package/dist/cjs/built-in/daemon/daemon-handler.js +62 -0
  37. package/dist/cjs/built-in/daemon/daemon-process-state-list.js +2 -0
  38. package/dist/cjs/built-in/http/apollo-filter.js +63 -0
  39. package/dist/cjs/built-in/http/built-in-auth-filters.js +115 -0
  40. package/dist/cjs/built-in/http/built-in-authorizers.js +43 -0
  41. package/dist/cjs/built-in/http/built-in-filters.js +222 -0
  42. package/dist/cjs/built-in/http/built-in-handlers.js +73 -0
  43. package/dist/cjs/built-in/http/log-level-manipulation-filter.js +20 -0
  44. package/dist/cjs/built-in/http/run-handler-as-filter.js +64 -0
  45. package/dist/cjs/cli-bootstrap/epsilon-run-background-process-from-command-line-dry-run.js +20 -0
  46. package/dist/cjs/config/background/background-aws-config.js +2 -0
  47. package/dist/cjs/config/background/background-config.js +2 -0
  48. package/dist/cjs/config/background/background-error-processor.js +2 -0
  49. package/dist/cjs/config/background/background-processor.js +2 -0
  50. package/dist/cjs/config/background/background-transaction-log.js +2 -0
  51. package/dist/cjs/config/background/background-transaction-logger.js +2 -0
  52. package/dist/cjs/config/cron/abstract-cron-entry.js +2 -0
  53. package/dist/cjs/config/cron/cron-background-entry.js +2 -0
  54. package/dist/cjs/config/cron/cron-config.js +2 -0
  55. package/dist/cjs/config/dynamo-db-config.js +2 -0
  56. package/dist/cjs/config/epsilon-config.js +2 -0
  57. package/dist/cjs/config/epsilon-lambda-event-handler.js +2 -0
  58. package/dist/cjs/config/epsilon-logger-config.js +2 -0
  59. package/dist/cjs/config/generic-aws-event-handler-function.js +2 -0
  60. package/dist/cjs/config/http/authorizer-function.js +2 -0
  61. package/dist/cjs/config/http/epsilon-authorization-context.js +2 -0
  62. package/dist/cjs/config/http/extended-api-gateway-event.js +2 -0
  63. package/dist/cjs/config/http/filter-chain-context.js +2 -0
  64. package/dist/cjs/config/http/filter-function.js +2 -0
  65. package/dist/cjs/config/http/handler-function.js +2 -0
  66. package/dist/cjs/config/http/http-config.js +2 -0
  67. package/dist/cjs/config/http/http-processing-config.js +2 -0
  68. package/dist/cjs/config/http/mapped-http-processing-config.js +2 -0
  69. package/dist/cjs/config/http/null-returned-object-handling.js +9 -0
  70. package/dist/cjs/config/inter-api/inter-api-aws-config.js +2 -0
  71. package/dist/cjs/config/inter-api/inter-api-config.js +2 -0
  72. package/dist/cjs/config/inter-api/inter-api-process-mapping.js +2 -0
  73. package/dist/cjs/config/logging-trace-id-generator.js +2 -0
  74. package/dist/cjs/config/open-api/open-api-document-components.js +2 -0
  75. package/dist/cjs/config/open-api/open-api-document-path.js +2 -0
  76. package/dist/cjs/config/open-api/open-api-document.js +2 -0
  77. package/dist/cjs/config/s3-config.js +2 -0
  78. package/dist/cjs/config/sns-config.js +2 -0
  79. package/dist/cjs/epsilon-build-properties.js +28 -0
  80. package/dist/cjs/epsilon-constants.js +49 -0
  81. package/dist/cjs/epsilon-global-handler.js +155 -0
  82. package/dist/cjs/epsilon-instance.js +2 -0
  83. package/dist/cjs/epsilon-logging-extension-processor.js +19 -0
  84. package/dist/cjs/http/auth/api-gateway-adapter-authentication-handler.js +75 -0
  85. package/dist/cjs/http/auth/auth0-web-token-manipulator.js +62 -0
  86. package/dist/cjs/http/auth/basic-auth-token.js +2 -0
  87. package/dist/cjs/http/auth/google-web-token-manipulator.js +72 -0
  88. package/dist/cjs/http/auth/jwt-ratchet-local-web-token-manipulator.js +29 -0
  89. package/dist/cjs/http/auth/local-web-token-manipulator.js +74 -0
  90. package/dist/cjs/http/auth/web-token-manipulator.js +2 -0
  91. package/dist/cjs/http/error/bad-gateway.js +12 -0
  92. package/dist/cjs/http/error/bad-request-error.js +12 -0
  93. package/dist/cjs/http/error/conflict-error.js +12 -0
  94. package/dist/cjs/http/error/epsilon-http-error.js +132 -0
  95. package/dist/cjs/http/error/forbidden-error.js +12 -0
  96. package/dist/cjs/http/error/gateway-timeout.js +12 -0
  97. package/dist/cjs/http/error/method-not-allowed-error.js +12 -0
  98. package/dist/cjs/http/error/misconfigured-error.js +12 -0
  99. package/dist/cjs/http/error/not-found-error.js +12 -0
  100. package/dist/cjs/http/error/not-implemented.js +12 -0
  101. package/dist/cjs/http/error/request-timeout-error.js +12 -0
  102. package/dist/cjs/http/error/service-unavailable.js +12 -0
  103. package/dist/cjs/http/error/too-many-requests-error.js +12 -0
  104. package/dist/cjs/http/error/unauthorized-error.js +12 -0
  105. package/dist/cjs/http/event-util.js +180 -0
  106. package/dist/cjs/http/response-util.js +146 -0
  107. package/dist/cjs/http/route/epsilon-router.js +2 -0
  108. package/dist/cjs/http/route/extended-auth-response-context.js +2 -0
  109. package/dist/cjs/http/route/route-mapping.js +2 -0
  110. package/dist/cjs/http/route/route-validator-config.js +2 -0
  111. package/dist/cjs/http/route/router-util.js +238 -0
  112. package/dist/cjs/http/web-handler.js +122 -0
  113. package/dist/cjs/http/web-v2-handler.js +25 -0
  114. package/dist/cjs/index.js +136 -0
  115. package/dist/cjs/inter-api/inter-api-entry.js +2 -0
  116. package/dist/cjs/inter-api/inter-api-util.js +62 -0
  117. package/dist/cjs/inter-api-manager.js +67 -0
  118. package/dist/cjs/lambda-event-handler/cron-epsilon-lambda-event-handler.js +76 -0
  119. package/dist/cjs/lambda-event-handler/dynamo-epsilon-lambda-event-handler.js +36 -0
  120. package/dist/cjs/lambda-event-handler/generic-sns-epsilon-lambda-event-handler.js +32 -0
  121. package/dist/cjs/lambda-event-handler/inter-api-epsilon-lambda-event-handler.js +26 -0
  122. package/dist/cjs/lambda-event-handler/s3-epsilon-lambda-event-handler.js +44 -0
  123. package/dist/cjs/local-container-server.js +79 -0
  124. package/dist/cjs/local-server-cert.js +71 -0
  125. package/dist/cjs/local-server.js +145 -0
  126. package/dist/cjs/open-api-util/open-api-doc-modifications.js +2 -0
  127. package/dist/cjs/open-api-util/open-api-doc-modifier.js +83 -0
  128. package/dist/cjs/open-api-util/yaml-combiner.js +32 -0
  129. package/dist/cjs/run-background-process-from-command-line.js +37 -0
  130. package/dist/cjs/sample/sample-batch-only-local-server.js +19 -0
  131. package/dist/cjs/sample/sample-local-server.js +30 -0
  132. package/dist/cjs/sample/sample-server-components.js +197 -0
  133. package/dist/cjs/test-error-server.js +48 -0
  134. package/dist/cjs/util/aws-util.js +69 -0
  135. package/dist/cjs/util/context-util.js +104 -0
  136. package/dist/cjs/util/cron-util.js +72 -0
  137. package/dist/cjs/util/epsilon-config-parser.js +70 -0
  138. package/dist/es/background/background-dynamo-log-table-handler.js +33 -0
  139. package/dist/es/background/background-entry.js +1 -0
  140. package/dist/es/background/background-execution-event-type.js +8 -0
  141. package/dist/es/background/background-execution-event.js +1 -0
  142. package/dist/es/background/background-execution-listener.js +1 -0
  143. package/dist/es/background/background-handler.js +265 -0
  144. package/dist/es/background/background-http-adapter-handler.js +123 -0
  145. package/dist/es/background/background-meta-response-internal.js +1 -0
  146. package/dist/es/background/background-process-handling.js +5 -0
  147. package/dist/es/background/background-process-log-table-entry.js +1 -0
  148. package/dist/es/background/background-queue-response-internal.js +1 -0
  149. package/dist/es/background/background-validator.js +84 -0
  150. package/dist/es/background/epsilon-background-process-error.js +88 -0
  151. package/dist/es/background/internal-background-entry.js +1 -0
  152. package/dist/es/background/manager/abstract-background-manager.js +88 -0
  153. package/dist/es/background/manager/aws-sqs-sns-background-manager.js +149 -0
  154. package/dist/es/background/manager/background-manager-like.js +1 -0
  155. package/dist/es/background/manager/single-thread-local-background-manager.js +45 -0
  156. package/dist/es/background/s3-background-transaction-logger.js +49 -0
  157. package/dist/es/build/ratchet-epsilon-common-info.js +14 -0
  158. package/dist/es/built-in/background/echo-processor.js +14 -0
  159. package/dist/es/built-in/background/log-and-enqueue-echo-processor.js +12 -0
  160. package/dist/es/built-in/background/log-message-background-error-processor.js +6 -0
  161. package/dist/es/built-in/background/no-op-processor.js +9 -0
  162. package/dist/es/built-in/background/retry-processor.js +36 -0
  163. package/dist/es/built-in/background/sample-delay-processor.js +12 -0
  164. package/dist/es/built-in/background/sample-input-validated-processor-data.js +1 -0
  165. package/dist/es/built-in/background/sample-input-validated-processor.js +12 -0
  166. package/dist/es/built-in/built-in-trace-id-generators.js +21 -0
  167. package/dist/es/built-in/daemon/daemon-authorizer-function.js +1 -0
  168. package/dist/es/built-in/daemon/daemon-config.js +1 -0
  169. package/dist/es/built-in/daemon/daemon-group-selection-function.js +1 -0
  170. package/dist/es/built-in/daemon/daemon-handler.js +58 -0
  171. package/dist/es/built-in/daemon/daemon-process-state-list.js +1 -0
  172. package/dist/es/built-in/http/apollo-filter.js +58 -0
  173. package/dist/es/built-in/http/built-in-auth-filters.js +107 -0
  174. package/dist/es/built-in/http/built-in-authorizers.js +39 -0
  175. package/dist/es/built-in/http/built-in-filters.js +208 -0
  176. package/dist/es/built-in/http/built-in-handlers.js +69 -0
  177. package/dist/es/built-in/http/log-level-manipulation-filter.js +16 -0
  178. package/dist/es/built-in/http/run-handler-as-filter.js +60 -0
  179. package/dist/es/cli-bootstrap/epsilon-run-background-process-from-command-line-dry-run.js +17 -0
  180. package/dist/es/config/background/background-aws-config.js +1 -0
  181. package/dist/es/config/background/background-config.js +1 -0
  182. package/dist/es/config/background/background-error-processor.js +1 -0
  183. package/dist/es/config/background/background-processor.js +1 -0
  184. package/dist/es/config/background/background-transaction-log.js +1 -0
  185. package/dist/es/config/background/background-transaction-logger.js +1 -0
  186. package/dist/es/config/cron/abstract-cron-entry.js +1 -0
  187. package/dist/es/config/cron/cron-background-entry.js +1 -0
  188. package/dist/es/config/cron/cron-config.js +1 -0
  189. package/dist/es/config/dynamo-db-config.js +1 -0
  190. package/dist/es/config/epsilon-config.js +1 -0
  191. package/dist/es/config/epsilon-lambda-event-handler.js +1 -0
  192. package/dist/es/config/epsilon-logger-config.js +1 -0
  193. package/dist/es/config/generic-aws-event-handler-function.js +1 -0
  194. package/dist/es/config/http/authorizer-function.js +1 -0
  195. package/dist/es/config/http/epsilon-authorization-context.js +1 -0
  196. package/dist/es/config/http/extended-api-gateway-event.js +1 -0
  197. package/dist/es/config/http/filter-chain-context.js +1 -0
  198. package/dist/es/config/http/filter-function.js +1 -0
  199. package/dist/es/config/http/handler-function.js +1 -0
  200. package/dist/es/config/http/http-config.js +1 -0
  201. package/dist/es/config/http/http-processing-config.js +1 -0
  202. package/dist/es/config/http/mapped-http-processing-config.js +1 -0
  203. package/dist/es/config/http/null-returned-object-handling.js +6 -0
  204. package/dist/es/config/inter-api/inter-api-aws-config.js +1 -0
  205. package/dist/es/config/inter-api/inter-api-config.js +1 -0
  206. package/dist/es/config/inter-api/inter-api-process-mapping.js +1 -0
  207. package/dist/es/config/logging-trace-id-generator.js +1 -0
  208. package/dist/es/config/open-api/open-api-document-components.js +1 -0
  209. package/dist/es/config/open-api/open-api-document-path.js +1 -0
  210. package/dist/es/config/open-api/open-api-document.js +1 -0
  211. package/dist/es/config/s3-config.js +1 -0
  212. package/dist/es/config/sns-config.js +1 -0
  213. package/dist/es/epsilon-build-properties.js +24 -0
  214. package/dist/es/epsilon-constants.js +45 -0
  215. package/dist/es/epsilon-global-handler.js +149 -0
  216. package/dist/es/epsilon-instance.js +1 -0
  217. package/dist/es/epsilon-logging-extension-processor.js +15 -0
  218. package/dist/es/http/auth/api-gateway-adapter-authentication-handler.js +71 -0
  219. package/dist/es/http/auth/auth0-web-token-manipulator.js +56 -0
  220. package/dist/es/http/auth/basic-auth-token.js +1 -0
  221. package/dist/es/http/auth/google-web-token-manipulator.js +67 -0
  222. package/dist/es/http/auth/jwt-ratchet-local-web-token-manipulator.js +25 -0
  223. package/dist/es/http/auth/local-web-token-manipulator.js +70 -0
  224. package/dist/es/http/auth/web-token-manipulator.js +1 -0
  225. package/dist/es/http/error/bad-gateway.js +8 -0
  226. package/dist/es/http/error/bad-request-error.js +8 -0
  227. package/dist/es/http/error/conflict-error.js +8 -0
  228. package/dist/es/http/error/epsilon-http-error.js +127 -0
  229. package/dist/es/http/error/forbidden-error.js +8 -0
  230. package/dist/es/http/error/gateway-timeout.js +8 -0
  231. package/dist/es/http/error/method-not-allowed-error.js +8 -0
  232. package/dist/es/http/error/misconfigured-error.js +8 -0
  233. package/dist/es/http/error/not-found-error.js +8 -0
  234. package/dist/es/http/error/not-implemented.js +8 -0
  235. package/dist/es/http/error/request-timeout-error.js +8 -0
  236. package/dist/es/http/error/service-unavailable.js +8 -0
  237. package/dist/es/http/error/too-many-requests-error.js +8 -0
  238. package/dist/es/http/error/unauthorized-error.js +8 -0
  239. package/dist/es/http/event-util.js +175 -0
  240. package/dist/es/http/response-util.js +141 -0
  241. package/dist/es/http/route/epsilon-router.js +1 -0
  242. package/dist/es/http/route/extended-auth-response-context.js +1 -0
  243. package/dist/es/http/route/route-mapping.js +1 -0
  244. package/dist/es/http/route/route-validator-config.js +1 -0
  245. package/dist/es/http/route/router-util.js +233 -0
  246. package/dist/es/http/web-handler.js +116 -0
  247. package/dist/es/http/web-v2-handler.js +21 -0
  248. package/dist/es/index.js +133 -0
  249. package/dist/es/inter-api/inter-api-entry.js +1 -0
  250. package/dist/es/inter-api/inter-api-util.js +58 -0
  251. package/dist/es/inter-api-manager.js +63 -0
  252. package/dist/es/lambda-event-handler/cron-epsilon-lambda-event-handler.js +72 -0
  253. package/dist/es/lambda-event-handler/dynamo-epsilon-lambda-event-handler.js +32 -0
  254. package/dist/es/lambda-event-handler/generic-sns-epsilon-lambda-event-handler.js +28 -0
  255. package/dist/es/lambda-event-handler/inter-api-epsilon-lambda-event-handler.js +22 -0
  256. package/dist/es/lambda-event-handler/s3-epsilon-lambda-event-handler.js +40 -0
  257. package/dist/es/local-container-server.js +74 -0
  258. package/dist/es/local-server-cert.js +67 -0
  259. package/dist/es/local-server.js +140 -0
  260. package/dist/es/open-api-util/open-api-doc-modifications.js +1 -0
  261. package/dist/es/open-api-util/open-api-doc-modifier.js +78 -0
  262. package/dist/es/open-api-util/yaml-combiner.js +27 -0
  263. package/dist/es/run-background-process-from-command-line.js +32 -0
  264. package/dist/es/sample/sample-batch-only-local-server.js +17 -0
  265. package/dist/es/sample/sample-local-server.js +28 -0
  266. package/dist/es/sample/sample-server-components.js +192 -0
  267. package/dist/es/test-error-server.js +43 -0
  268. package/dist/es/util/aws-util.js +65 -0
  269. package/dist/es/util/context-util.js +95 -0
  270. package/dist/es/util/cron-util.js +68 -0
  271. package/dist/es/util/epsilon-config-parser.js +64 -0
  272. package/dist/tsconfig.cjs.tsbuildinfo +1 -0
  273. package/dist/tsconfig.es.tsbuildinfo +1 -0
  274. package/dist/tsconfig.types.tsbuildinfo +1 -0
  275. package/dist/types/background/background-dynamo-log-table-handler.d.ts +11 -0
  276. package/dist/types/background/background-entry.d.ts +4 -0
  277. package/dist/types/background/background-execution-event-type.d.ts +7 -0
  278. package/dist/types/background/background-execution-event.d.ts +8 -0
  279. package/dist/types/background/background-execution-listener.d.ts +5 -0
  280. package/dist/types/background/background-handler.d.ts +33 -0
  281. package/dist/types/background/background-http-adapter-handler.d.ts +26 -0
  282. package/dist/types/background/background-meta-response-internal.d.ts +5 -0
  283. package/dist/types/background/background-process-handling.d.ts +4 -0
  284. package/dist/types/background/background-process-log-table-entry.d.ts +11 -0
  285. package/dist/types/background/background-queue-response-internal.d.ts +8 -0
  286. package/dist/types/background/background-validator.d.ts +20 -0
  287. package/dist/types/background/epsilon-background-process-error.d.ts +30 -0
  288. package/dist/types/background/internal-background-entry.d.ts +7 -0
  289. package/dist/types/background/manager/abstract-background-manager.d.ts +26 -0
  290. package/dist/types/background/manager/aws-sqs-sns-background-manager.d.ts +30 -0
  291. package/dist/types/background/manager/background-manager-like.d.ts +24 -0
  292. package/dist/types/background/manager/single-thread-local-background-manager.d.ts +22 -0
  293. package/dist/types/background/s3-background-transaction-logger.d.ts +17 -0
  294. package/dist/types/build/ratchet-epsilon-common-info.d.ts +5 -0
  295. package/dist/types/built-in/background/echo-processor.d.ts +7 -0
  296. package/dist/types/built-in/background/log-and-enqueue-echo-processor.d.ts +6 -0
  297. package/dist/types/built-in/background/log-message-background-error-processor.d.ts +5 -0
  298. package/dist/types/built-in/background/no-op-processor.d.ts +6 -0
  299. package/dist/types/built-in/background/retry-processor.d.ts +16 -0
  300. package/dist/types/built-in/background/sample-delay-processor.d.ts +6 -0
  301. package/dist/types/built-in/background/sample-input-validated-processor-data.d.ts +4 -0
  302. package/dist/types/built-in/background/sample-input-validated-processor.d.ts +8 -0
  303. package/dist/types/built-in/built-in-trace-id-generators.d.ts +5 -0
  304. package/dist/types/built-in/daemon/daemon-authorizer-function.d.ts +5 -0
  305. package/dist/types/built-in/daemon/daemon-config.d.ts +8 -0
  306. package/dist/types/built-in/daemon/daemon-group-selection-function.d.ts +4 -0
  307. package/dist/types/built-in/daemon/daemon-handler.d.ts +22 -0
  308. package/dist/types/built-in/daemon/daemon-process-state-list.d.ts +8 -0
  309. package/dist/types/built-in/http/apollo-filter.d.ts +10 -0
  310. package/dist/types/built-in/http/built-in-auth-filters.d.ts +9 -0
  311. package/dist/types/built-in/http/built-in-authorizers.d.ts +8 -0
  312. package/dist/types/built-in/http/built-in-filters.d.ts +25 -0
  313. package/dist/types/built-in/http/built-in-handlers.d.ts +9 -0
  314. package/dist/types/built-in/http/log-level-manipulation-filter.d.ts +9 -0
  315. package/dist/types/built-in/http/run-handler-as-filter.d.ts +12 -0
  316. package/dist/types/cli-bootstrap/epsilon-run-background-process-from-command-line-dry-run.d.ts +2 -0
  317. package/dist/types/config/background/background-aws-config.d.ts +7 -0
  318. package/dist/types/config/background/background-config.d.ts +14 -0
  319. package/dist/types/config/background/background-error-processor.d.ts +4 -0
  320. package/dist/types/config/background/background-processor.d.ts +6 -0
  321. package/dist/types/config/background/background-transaction-log.d.ts +8 -0
  322. package/dist/types/config/background/background-transaction-logger.d.ts +5 -0
  323. package/dist/types/config/cron/abstract-cron-entry.d.ts +12 -0
  324. package/dist/types/config/cron/cron-background-entry.d.ts +15 -0
  325. package/dist/types/config/cron/cron-config.d.ts +6 -0
  326. package/dist/types/config/dynamo-db-config.d.ts +5 -0
  327. package/dist/types/config/epsilon-config.d.ts +20 -0
  328. package/dist/types/config/epsilon-lambda-event-handler.d.ts +7 -0
  329. package/dist/types/config/epsilon-logger-config.d.ts +12 -0
  330. package/dist/types/config/generic-aws-event-handler-function.d.ts +3 -0
  331. package/dist/types/config/http/authorizer-function.d.ts +6 -0
  332. package/dist/types/config/http/epsilon-authorization-context.d.ts +5 -0
  333. package/dist/types/config/http/extended-api-gateway-event.d.ts +7 -0
  334. package/dist/types/config/http/filter-chain-context.d.ts +14 -0
  335. package/dist/types/config/http/filter-function.d.ts +4 -0
  336. package/dist/types/config/http/handler-function.d.ts +5 -0
  337. package/dist/types/config/http/http-config.d.ts +15 -0
  338. package/dist/types/config/http/http-processing-config.d.ts +11 -0
  339. package/dist/types/config/http/mapped-http-processing-config.d.ts +7 -0
  340. package/dist/types/config/http/null-returned-object-handling.d.ts +5 -0
  341. package/dist/types/config/inter-api/inter-api-aws-config.d.ts +5 -0
  342. package/dist/types/config/inter-api/inter-api-config.d.ts +6 -0
  343. package/dist/types/config/inter-api/inter-api-process-mapping.d.ts +11 -0
  344. package/dist/types/config/logging-trace-id-generator.d.ts +4 -0
  345. package/dist/types/config/open-api/open-api-document-components.d.ts +4 -0
  346. package/dist/types/config/open-api/open-api-document-path.d.ts +2 -0
  347. package/dist/types/config/open-api/open-api-document.d.ts +6 -0
  348. package/dist/types/config/s3-config.d.ts +6 -0
  349. package/dist/types/config/sns-config.d.ts +5 -0
  350. package/dist/types/epsilon-build-properties.d.ts +9 -0
  351. package/dist/types/epsilon-constants.d.ts +16 -0
  352. package/dist/types/epsilon-global-handler.d.ts +23 -0
  353. package/dist/types/epsilon-instance.d.ts +19 -0
  354. package/dist/types/epsilon-logging-extension-processor.d.ts +5 -0
  355. package/dist/types/http/auth/api-gateway-adapter-authentication-handler.d.ts +18 -0
  356. package/dist/types/http/auth/auth0-web-token-manipulator.d.ts +13 -0
  357. package/dist/types/http/auth/basic-auth-token.d.ts +7 -0
  358. package/dist/types/http/auth/google-web-token-manipulator.d.ts +14 -0
  359. package/dist/types/http/auth/jwt-ratchet-local-web-token-manipulator.d.ts +13 -0
  360. package/dist/types/http/auth/local-web-token-manipulator.d.ts +20 -0
  361. package/dist/types/http/auth/web-token-manipulator.d.ts +7 -0
  362. package/dist/types/http/error/bad-gateway.d.ts +5 -0
  363. package/dist/types/http/error/bad-request-error.d.ts +5 -0
  364. package/dist/types/http/error/conflict-error.d.ts +5 -0
  365. package/dist/types/http/error/epsilon-http-error.d.ts +41 -0
  366. package/dist/types/http/error/forbidden-error.d.ts +5 -0
  367. package/dist/types/http/error/gateway-timeout.d.ts +5 -0
  368. package/dist/types/http/error/method-not-allowed-error.d.ts +5 -0
  369. package/dist/types/http/error/misconfigured-error.d.ts +5 -0
  370. package/dist/types/http/error/not-found-error.d.ts +5 -0
  371. package/dist/types/http/error/not-implemented.d.ts +5 -0
  372. package/dist/types/http/error/request-timeout-error.d.ts +5 -0
  373. package/dist/types/http/error/service-unavailable.d.ts +5 -0
  374. package/dist/types/http/error/too-many-requests-error.d.ts +5 -0
  375. package/dist/types/http/error/unauthorized-error.d.ts +5 -0
  376. package/dist/types/http/event-util.d.ts +47 -0
  377. package/dist/types/http/response-util.d.ts +11 -0
  378. package/dist/types/http/route/epsilon-router.d.ts +8 -0
  379. package/dist/types/http/route/extended-auth-response-context.d.ts +6 -0
  380. package/dist/types/http/route/route-mapping.d.ts +12 -0
  381. package/dist/types/http/route/route-validator-config.d.ts +5 -0
  382. package/dist/types/http/route/router-util.d.ts +26 -0
  383. package/dist/types/http/web-handler.d.ts +26 -0
  384. package/dist/types/http/web-v2-handler.d.ts +13 -0
  385. package/dist/types/index.d.ts +136 -0
  386. package/dist/types/inter-api/inter-api-entry.d.ts +7 -0
  387. package/dist/types/inter-api/inter-api-util.d.ts +10 -0
  388. package/dist/types/inter-api-manager.d.ts +17 -0
  389. package/dist/types/lambda-event-handler/cron-epsilon-lambda-event-handler.d.ts +14 -0
  390. package/dist/types/lambda-event-handler/dynamo-epsilon-lambda-event-handler.d.ts +11 -0
  391. package/dist/types/lambda-event-handler/generic-sns-epsilon-lambda-event-handler.d.ts +10 -0
  392. package/dist/types/lambda-event-handler/inter-api-epsilon-lambda-event-handler.d.ts +10 -0
  393. package/dist/types/lambda-event-handler/s3-epsilon-lambda-event-handler.d.ts +10 -0
  394. package/dist/types/local-container-server.d.ts +13 -0
  395. package/dist/types/local-server-cert.d.ts +5 -0
  396. package/dist/types/local-server.d.ts +19 -0
  397. package/dist/types/open-api-util/open-api-doc-modifications.d.ts +8 -0
  398. package/dist/types/open-api-util/open-api-doc-modifier.d.ts +10 -0
  399. package/dist/types/open-api-util/yaml-combiner.d.ts +3 -0
  400. package/dist/types/run-background-process-from-command-line.d.ts +13 -0
  401. package/dist/types/sample/sample-batch-only-local-server.d.ts +1 -0
  402. package/dist/types/sample/sample-local-server.d.ts +1 -0
  403. package/dist/types/sample/sample-server-components.d.ts +12 -0
  404. package/dist/types/test-error-server.d.ts +13 -0
  405. package/dist/types/util/aws-util.d.ts +8 -0
  406. package/dist/types/util/context-util.d.ts +33 -0
  407. package/dist/types/util/cron-util.d.ts +11 -0
  408. package/dist/types/util/epsilon-config-parser.d.ts +14 -0
  409. package/package.json +132 -0
@@ -0,0 +1,67 @@
1
+ import { Logger } from '@bitblit/ratchet-common';
2
+ import { StringRatchet } from '@bitblit/ratchet-common';
3
+ import jwt from 'jsonwebtoken';
4
+ import jwks from 'jwks-rsa';
5
+ import fetch from 'cross-fetch';
6
+ export class GoogleWebTokenManipulator {
7
+ constructor(clientId) {
8
+ this.clientId = clientId;
9
+ }
10
+ async extractTokenFromAuthorizationHeader(authHeader) {
11
+ let tokenString = StringRatchet.trimToEmpty(authHeader);
12
+ if (tokenString.toLowerCase().startsWith('bearer ')) {
13
+ tokenString = tokenString.substring(7);
14
+ }
15
+ const validated = !!tokenString ? await this.parseAndValidateGoogleToken(tokenString, false) : null;
16
+ return validated;
17
+ }
18
+ async parseAndValidateGoogleToken(googleToken, allowExpired = false) {
19
+ Logger.debug('Auth : %s', StringRatchet.obscure(googleToken, 4));
20
+ const fullToken = jwt.decode(googleToken, { complete: true });
21
+ const kid = fullToken.header.kid;
22
+ const nowEpochSeconds = Math.floor(new Date().getTime() / 1000);
23
+ const pubKey = await this.fetchSigningKey(kid);
24
+ const validated = jwt.verify(googleToken, pubKey, {
25
+ audience: this.clientId,
26
+ issuer: ['https://accounts.google.com', 'accounts.google.com'],
27
+ ignoreExpiration: allowExpired,
28
+ clockTimestamp: nowEpochSeconds,
29
+ });
30
+ return validated;
31
+ }
32
+ async fetchSigningKey(kid) {
33
+ const jClient = await this.fetchJwksClient();
34
+ return new Promise((res, rej) => {
35
+ jClient.getSigningKey(kid, (err, key) => {
36
+ if (err) {
37
+ rej(err);
38
+ }
39
+ else {
40
+ res(key.publicKey || key.rsaPublicKey);
41
+ }
42
+ });
43
+ });
44
+ }
45
+ async fetchJwksClient() {
46
+ if (!this.jwksClient) {
47
+ const discDoc = await this.fetchGoogleDiscoveryDocument();
48
+ const client = jwks({
49
+ cache: true,
50
+ cacheMaxEntries: 5,
51
+ cacheMaxAge: 1000 * 60 * 60 * 10,
52
+ jwksUri: discDoc.jwks_uri,
53
+ });
54
+ this.jwksClient = client;
55
+ }
56
+ return this.jwksClient;
57
+ }
58
+ async fetchGoogleDiscoveryDocument() {
59
+ if (!this.cacheGoogleDiscoveryDocument) {
60
+ const resp = await fetch(GoogleWebTokenManipulator.GOOGLE_DISCOVERY_DOCUMENT);
61
+ const doc = await resp.json();
62
+ this.cacheGoogleDiscoveryDocument = doc;
63
+ }
64
+ return this.cacheGoogleDiscoveryDocument;
65
+ }
66
+ }
67
+ GoogleWebTokenManipulator.GOOGLE_DISCOVERY_DOCUMENT = 'https://accounts.google.com/.well-known/openid-configuration';
@@ -0,0 +1,25 @@
1
+ import { StringRatchet } from '@bitblit/ratchet-common';
2
+ import { RequireRatchet } from '@bitblit/ratchet-common';
3
+ import { ExpiredJwtHandling } from '@bitblit/ratchet-common';
4
+ export class JwtRatchetLocalWebTokenManipulator {
5
+ constructor(_jwtRatchet, _issuer) {
6
+ this._jwtRatchet = _jwtRatchet;
7
+ this._issuer = _issuer;
8
+ RequireRatchet.notNullOrUndefined(_jwtRatchet, '_jwtRatchet');
9
+ RequireRatchet.notNullOrUndefined(StringRatchet.trimToNull(_issuer), '_issuer');
10
+ }
11
+ get jwtRatchet() {
12
+ return this._jwtRatchet;
13
+ }
14
+ get issuer() {
15
+ return this._issuer;
16
+ }
17
+ async extractTokenFromAuthorizationHeader(header) {
18
+ let tokenString = StringRatchet.trimToEmpty(header);
19
+ if (tokenString.toLowerCase().startsWith('bearer ')) {
20
+ tokenString = tokenString.substring(7);
21
+ }
22
+ const validated = !!tokenString ? await this.jwtRatchet.decodeToken(tokenString, ExpiredJwtHandling.THROW_EXCEPTION) : null;
23
+ return validated;
24
+ }
25
+ }
@@ -0,0 +1,70 @@
1
+ import { Logger } from '@bitblit/ratchet-common';
2
+ import { UnauthorizedError } from '../error/unauthorized-error';
3
+ import { StringRatchet } from '@bitblit/ratchet-common';
4
+ import { RequireRatchet } from '@bitblit/ratchet-common';
5
+ import { ExpiredJwtHandling, JwtRatchet } from '@bitblit/ratchet-common';
6
+ export class LocalWebTokenManipulator {
7
+ constructor(encryptionKeys, issuer) {
8
+ this.encryptionKeys = encryptionKeys;
9
+ this.issuer = issuer;
10
+ RequireRatchet.notNullOrUndefined(encryptionKeys, 'encryptionKeys');
11
+ RequireRatchet.noNullOrUndefinedValuesInArray(encryptionKeys, encryptionKeys.length);
12
+ this._ratchet = new JwtRatchet(Promise.resolve(encryptionKeys));
13
+ }
14
+ withExtraDecryptionKeys(keys) {
15
+ RequireRatchet.notNullOrUndefined(keys, 'keys');
16
+ RequireRatchet.noNullOrUndefinedValuesInArray(keys, keys.length);
17
+ this._ratchet = new JwtRatchet(this._ratchet.encryptionKeyPromise, Promise.resolve(keys), this._ratchet.jtiGenerator, this._ratchet.decryptOnlyKeyUseLogLevel, this._ratchet.parseFailureLogLevel);
18
+ return this;
19
+ }
20
+ withParseFailureLogLevel(logLevel) {
21
+ this._ratchet = new JwtRatchet(this._ratchet.encryptionKeyPromise, this._ratchet.decryptKeysPromise, this._ratchet.jtiGenerator, this._ratchet.decryptOnlyKeyUseLogLevel, logLevel);
22
+ return this;
23
+ }
24
+ withOldKeyUseLogLevel(logLevel) {
25
+ this._ratchet = new JwtRatchet(this._ratchet.encryptionKeyPromise, this._ratchet.decryptKeysPromise, this._ratchet.jtiGenerator, logLevel, this._ratchet.parseFailureLogLevel);
26
+ return this;
27
+ }
28
+ get jwtRatchet() {
29
+ return this._ratchet;
30
+ }
31
+ get selectRandomEncryptionKey() {
32
+ return this._ratchet.selectRandomEncryptionKey();
33
+ }
34
+ createRefreshedJWTString(tokenString, expirationSeconds, allowExpired) {
35
+ return this._ratchet.refreshJWTString(tokenString, allowExpired || false, expirationSeconds);
36
+ }
37
+ async parseAndValidateJWTStringAsync(tokenString) {
38
+ const payload = await this._ratchet.decodeToken(tokenString, ExpiredJwtHandling.ADD_FLAG);
39
+ if (JwtRatchet.hasExpiredFlag(payload)) {
40
+ throw new UnauthorizedError('Failing JWT token read/validate - token expired on ' + payload.exp);
41
+ }
42
+ else {
43
+ return payload;
44
+ }
45
+ }
46
+ async createJWTStringAsync(principal, userObject, roles = ['USER'], expirationSeconds = 3600, proxyUser = null) {
47
+ Logger.info('Creating JWT token for %s that expires in %s', principal, expirationSeconds);
48
+ const now = new Date().getTime();
49
+ const expires = now + expirationSeconds * 1000;
50
+ const tokenData = {
51
+ exp: expires,
52
+ iss: this.issuer,
53
+ sub: principal,
54
+ iat: now,
55
+ user: userObject,
56
+ proxy: proxyUser,
57
+ roles: roles,
58
+ };
59
+ const token = await this._ratchet.createTokenString(tokenData, expirationSeconds);
60
+ return token;
61
+ }
62
+ async extractTokenFromAuthorizationHeader(header) {
63
+ let tokenString = StringRatchet.trimToEmpty(header);
64
+ if (tokenString.toLowerCase().startsWith('bearer ')) {
65
+ tokenString = tokenString.substring(7);
66
+ }
67
+ const validated = !!tokenString ? await this.parseAndValidateJWTStringAsync(tokenString) : null;
68
+ return validated;
69
+ }
70
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class BadGateway extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(BadGateway.HTTP_CODE);
6
+ }
7
+ }
8
+ BadGateway.HTTP_CODE = 502;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class BadRequestError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(BadRequestError.HTTP_CODE);
6
+ }
7
+ }
8
+ BadRequestError.HTTP_CODE = 400;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class ConflictError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(ConflictError.HTTP_CODE);
6
+ }
7
+ }
8
+ ConflictError.HTTP_CODE = 409;
@@ -0,0 +1,127 @@
1
+ import util from 'util';
2
+ import { NumberRatchet } from '@bitblit/ratchet-common';
3
+ export class EpsilonHttpError extends Error {
4
+ constructor(...errors) {
5
+ super(EpsilonHttpError.combineErrorStringsWithDefault(errors));
6
+ this._httpStatusCode = 500;
7
+ Object.setPrototypeOf(this, EpsilonHttpError.prototype);
8
+ this._errors = errors;
9
+ this[EpsilonHttpError.EPSILON_HTTP_ERROR_FLAG_KEY] = true;
10
+ }
11
+ static combineErrorStringsWithDefault(errors, defMessage = 'Internal Server Error') {
12
+ return errors && errors.length > 0 ? errors.join(',') : defMessage;
13
+ }
14
+ setFormattedErrorMessage(format, ...input) {
15
+ const msg = util.format(format, ...input);
16
+ this.errors = [msg];
17
+ }
18
+ withFormattedErrorMessage(format, ...input) {
19
+ this.setFormattedErrorMessage(format, ...input);
20
+ return this;
21
+ }
22
+ withHttpStatusCode(httpStatusCode) {
23
+ this.httpStatusCode = httpStatusCode;
24
+ return this;
25
+ }
26
+ withErrors(errors) {
27
+ this.errors = errors;
28
+ return this;
29
+ }
30
+ withDetailErrorCode(detailErrorCode) {
31
+ this._detailErrorCode = detailErrorCode;
32
+ return this;
33
+ }
34
+ withEndUserErrors(endUserErrors) {
35
+ this._endUserErrors = endUserErrors;
36
+ return this;
37
+ }
38
+ withDetails(details) {
39
+ this._details = details;
40
+ return this;
41
+ }
42
+ withRequestId(requestId) {
43
+ this._requestId = requestId;
44
+ return this;
45
+ }
46
+ withWrappedError(err) {
47
+ this._wrappedError = err;
48
+ return this;
49
+ }
50
+ isWrappedError() {
51
+ return !!this._wrappedError;
52
+ }
53
+ static wrapError(err) {
54
+ let rval = null;
55
+ if (EpsilonHttpError.objectIsEpsilonHttpError(err)) {
56
+ rval = err;
57
+ }
58
+ else {
59
+ rval = new EpsilonHttpError(err.message).withWrappedError(err).withHttpStatusCode(500);
60
+ }
61
+ return rval;
62
+ }
63
+ static objectIsEpsilonHttpError(obj) {
64
+ return obj && obj['__epsilonHttpErrorFlag'] === true;
65
+ }
66
+ get httpStatusCode() {
67
+ return this._httpStatusCode;
68
+ }
69
+ get errors() {
70
+ return this._errors;
71
+ }
72
+ get detailErrorCode() {
73
+ return this._detailErrorCode;
74
+ }
75
+ get endUserErrors() {
76
+ return this._endUserErrors;
77
+ }
78
+ get details() {
79
+ return this._details;
80
+ }
81
+ get requestId() {
82
+ return this._requestId;
83
+ }
84
+ get wrappedError() {
85
+ return this._wrappedError;
86
+ }
87
+ set httpStatusCode(value) {
88
+ this._httpStatusCode = value || 500;
89
+ }
90
+ set errors(value) {
91
+ this._errors = value || ['Internal Server Error'];
92
+ this.message = EpsilonHttpError.combineErrorStringsWithDefault(this._errors);
93
+ }
94
+ set detailErrorCode(value) {
95
+ this._detailErrorCode = value;
96
+ }
97
+ set endUserErrors(value) {
98
+ this._endUserErrors = value;
99
+ }
100
+ set details(value) {
101
+ this._details = value;
102
+ }
103
+ set requestId(value) {
104
+ this._requestId = value || 'MISSING';
105
+ }
106
+ set wrappedError(value) {
107
+ this._wrappedError = value;
108
+ }
109
+ static errorIsX0x(errIn, xClass) {
110
+ let rval = false;
111
+ if (errIn && EpsilonHttpError.objectIsEpsilonHttpError(errIn)) {
112
+ const err = errIn;
113
+ const val = NumberRatchet.safeNumber(err.httpStatusCode);
114
+ const bot = xClass * 100;
115
+ const top = bot + 99;
116
+ rval = val >= bot && val <= top;
117
+ }
118
+ return rval;
119
+ }
120
+ static errorIs40x(err) {
121
+ return EpsilonHttpError.errorIsX0x(err, 4);
122
+ }
123
+ static errorIs50x(err) {
124
+ return EpsilonHttpError.errorIsX0x(err, 5);
125
+ }
126
+ }
127
+ EpsilonHttpError.EPSILON_HTTP_ERROR_FLAG_KEY = '__epsilonHttpErrorFlag';
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class ForbiddenError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(ForbiddenError.HTTP_CODE);
6
+ }
7
+ }
8
+ ForbiddenError.HTTP_CODE = 403;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class GatewayTimeout extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(GatewayTimeout.HTTP_CODE);
6
+ }
7
+ }
8
+ GatewayTimeout.HTTP_CODE = 504;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class MethodNotAllowedError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(MethodNotAllowedError.HTTP_CODE);
6
+ }
7
+ }
8
+ MethodNotAllowedError.HTTP_CODE = 405;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class MisconfiguredError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(MisconfiguredError.HTTP_CODE);
6
+ }
7
+ }
8
+ MisconfiguredError.HTTP_CODE = 500;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class NotFoundError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(NotFoundError.HTTP_CODE);
6
+ }
7
+ }
8
+ NotFoundError.HTTP_CODE = 404;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class NotImplemented extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(NotImplemented.HTTP_CODE);
6
+ }
7
+ }
8
+ NotImplemented.HTTP_CODE = 501;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class RequestTimeoutError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(RequestTimeoutError.HTTP_CODE);
6
+ }
7
+ }
8
+ RequestTimeoutError.HTTP_CODE = 500;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class ServiceUnavailable extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(ServiceUnavailable.HTTP_CODE);
6
+ }
7
+ }
8
+ ServiceUnavailable.HTTP_CODE = 503;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class TooManyRequestsError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(TooManyRequestsError.HTTP_CODE);
6
+ }
7
+ }
8
+ TooManyRequestsError.HTTP_CODE = 429;
@@ -0,0 +1,8 @@
1
+ import { EpsilonHttpError } from './epsilon-http-error';
2
+ export class UnauthorizedError extends EpsilonHttpError {
3
+ constructor(...errors) {
4
+ super(...errors);
5
+ this.withHttpStatusCode(UnauthorizedError.HTTP_CODE);
6
+ }
7
+ }
8
+ UnauthorizedError.HTTP_CODE = 401;
@@ -0,0 +1,175 @@
1
+ import { UnauthorizedError } from './error/unauthorized-error';
2
+ import { Logger } from '@bitblit/ratchet-common';
3
+ import { BadRequestError } from './error/bad-request-error';
4
+ import { MapRatchet } from '@bitblit/ratchet-common';
5
+ import jwt from 'jsonwebtoken';
6
+ import { Base64Ratchet } from '@bitblit/ratchet-common';
7
+ import { StringRatchet } from '@bitblit/ratchet-common';
8
+ import { EpsilonConstants } from '../epsilon-constants';
9
+ import { EnumRatchet, LoggerLevelName } from '@bitblit/ratchet-common';
10
+ export class EventUtil {
11
+ constructor() { }
12
+ static extractStage(event) {
13
+ if (!event.path.startsWith('/')) {
14
+ throw new BadRequestError('Path should start with / but does not : ' + event.path);
15
+ }
16
+ const idx = event.path.indexOf('/', 1);
17
+ if (idx == -1) {
18
+ throw new BadRequestError('No second / found in the path : ' + event.path);
19
+ }
20
+ return event.path.substring(1, idx);
21
+ }
22
+ static extractHostHeader(event) {
23
+ return MapRatchet.extractValueFromMapIgnoreCase(event.headers, 'Host');
24
+ }
25
+ static extractProtocol(event) {
26
+ return MapRatchet.extractValueFromMapIgnoreCase(event.headers, 'X-Forwarded-Proto');
27
+ }
28
+ static extractApiGatewayStage(event) {
29
+ const rc = EventUtil.extractRequestContext(event);
30
+ return rc ? rc.stage : null;
31
+ }
32
+ static extractRequestContext(event) {
33
+ return event.requestContext;
34
+ }
35
+ static extractAuthorizer(event) {
36
+ const rc = EventUtil.extractRequestContext(event);
37
+ return rc ? rc.authorizer : null;
38
+ }
39
+ static ipAddressChain(event) {
40
+ const headerVal = event && event.headers ? MapRatchet.extractValueFromMapIgnoreCase(event.headers, 'X-Forwarded-For') : null;
41
+ let headerList = headerVal ? String(headerVal).split(',') : [];
42
+ headerList = headerList.map((s) => s.trim());
43
+ return headerList;
44
+ }
45
+ static ipAddress(event) {
46
+ const list = EventUtil.ipAddressChain(event);
47
+ return list && list.length > 0 ? list[0] : null;
48
+ }
49
+ static extractFullPath(event, overrideProtocol = null) {
50
+ const protocol = overrideProtocol || EventUtil.extractProtocol(event) || 'https';
51
+ return protocol + '://' + event.requestContext['domainName'] + event.requestContext.path;
52
+ }
53
+ static extractFullPrefix(event, overrideProtocol = null) {
54
+ const protocol = overrideProtocol || EventUtil.extractProtocol(event) || 'https';
55
+ const prefix = event.requestContext.path.substring(0, event.requestContext.path.indexOf('/', 1));
56
+ return protocol + '://' + event.requestContext['domainName'] + prefix;
57
+ }
58
+ static jsonBodyToObject(event) {
59
+ let rval = null;
60
+ if (event.body) {
61
+ const contentType = MapRatchet.extractValueFromMapIgnoreCase(event.headers, 'Content-Type') || 'application/octet-stream';
62
+ rval = event.body;
63
+ if (event.isBase64Encoded) {
64
+ rval = Buffer.from(rval, 'base64');
65
+ }
66
+ if (contentType.startsWith('application/json')) {
67
+ rval = JSON.parse(rval.toString('ascii'));
68
+ }
69
+ }
70
+ return rval;
71
+ }
72
+ static calcLogLevelViaEventOrEnvParam(curLevel, event, rConfig) {
73
+ let rval = curLevel;
74
+ if (rConfig?.envParamLogLevelName && process.env[rConfig.envParamLogLevelName]) {
75
+ rval = EnumRatchet.keyToEnum(LoggerLevelName, process.env[rConfig.envParamLogLevelName]);
76
+ Logger.silly('Found env log level : %s', rval);
77
+ }
78
+ if (rConfig &&
79
+ rConfig.queryParamLogLevelName &&
80
+ event &&
81
+ event.queryStringParameters &&
82
+ event.queryStringParameters[rConfig.queryParamLogLevelName]) {
83
+ rval = EnumRatchet.keyToEnum(LoggerLevelName, event.queryStringParameters[rConfig.queryParamLogLevelName]);
84
+ Logger.silly('Found query log level : %s', rval);
85
+ }
86
+ return rval;
87
+ }
88
+ static fixStillEncodedQueryParams(event) {
89
+ if (event?.queryStringParameters) {
90
+ const newParams = {};
91
+ Object.keys(event.queryStringParameters).forEach((k) => {
92
+ const val = event.queryStringParameters[k];
93
+ if (k.toLowerCase().startsWith('amp;')) {
94
+ newParams[k.substring(4)] = val;
95
+ }
96
+ else {
97
+ newParams[k] = val;
98
+ }
99
+ });
100
+ event.queryStringParameters = newParams;
101
+ }
102
+ if (event?.multiValueQueryStringParameters) {
103
+ const newParams = {};
104
+ Object.keys(event.multiValueQueryStringParameters).forEach((k) => {
105
+ const val = event.multiValueQueryStringParameters[k];
106
+ if (k.toLowerCase().startsWith('amp;')) {
107
+ newParams[k.substring(4)] = val;
108
+ }
109
+ else {
110
+ newParams[k] = val;
111
+ }
112
+ });
113
+ event.multiValueQueryStringParameters = newParams;
114
+ }
115
+ }
116
+ static applyTokenToEventForTesting(event, jwtToken) {
117
+ const jwtFullData = jwt.decode(jwtToken, { complete: true });
118
+ if (!jwtFullData['payload']) {
119
+ throw new Error('No payload found in passed token');
120
+ }
121
+ const jwtData = jwtFullData['payload'];
122
+ event.headers = event.headers || {};
123
+ event.headers[EpsilonConstants.AUTH_HEADER_NAME.toLowerCase()] = 'Bearer ' + jwtToken;
124
+ event.requestContext = event.requestContext || {};
125
+ const newAuth = Object.assign({}, event.requestContext.authorizer);
126
+ newAuth.userData = jwtData;
127
+ newAuth.userDataJSON = jwtData ? JSON.stringify(jwtData) : null;
128
+ newAuth.srcData = jwtToken;
129
+ event.requestContext.authorizer = newAuth;
130
+ }
131
+ static extractBasicAuthenticationToken(event, throwErrorOnMissingBad = false) {
132
+ let rval = null;
133
+ if (!!event && !!event.headers) {
134
+ const headerVal = EventUtil.extractAuthorizationHeaderCaseInsensitive(event);
135
+ if (!!headerVal && headerVal.startsWith('Basic ')) {
136
+ const parsed = Base64Ratchet.base64StringToString(headerVal.substring(6));
137
+ const sp = parsed.split(':');
138
+ Logger.silly('Parsed to %j', sp);
139
+ if (!!sp && sp.length === 2) {
140
+ rval = {
141
+ username: sp[0],
142
+ password: sp[1],
143
+ };
144
+ }
145
+ }
146
+ }
147
+ if (!rval && throwErrorOnMissingBad) {
148
+ throw new UnauthorizedError('Could not find valid basic authentication header');
149
+ }
150
+ return rval;
151
+ }
152
+ static eventIsAGraphQLIntrospection(event) {
153
+ let rval = false;
154
+ if (!!event) {
155
+ if (!!event.httpMethod && 'post' === event.httpMethod.toLowerCase()) {
156
+ if (!!event.path && event.path.endsWith('/graphql')) {
157
+ const body = EventUtil.jsonBodyToObject(event);
158
+ rval = !!body && !!body['operationName'] && body['operationName'] === 'IntrospectionQuery';
159
+ }
160
+ }
161
+ }
162
+ return rval;
163
+ }
164
+ static extractAuthorizationHeaderCaseInsensitive(evt) {
165
+ return MapRatchet.caseInsensitiveAccess(evt?.headers || {}, EpsilonConstants.AUTH_HEADER_NAME);
166
+ }
167
+ static extractBearerTokenFromEvent(evt) {
168
+ let rval = null;
169
+ const authHeader = StringRatchet.trimToEmpty(EventUtil.extractAuthorizationHeaderCaseInsensitive(evt));
170
+ if (authHeader.toLowerCase().startsWith('bearer ')) {
171
+ rval = authHeader.substring(7);
172
+ }
173
+ return rval;
174
+ }
175
+ }