@toa.io/extensions.exposition 1.0.0-alpha.7 → 1.0.0-alpha.71

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 (434) hide show
  1. package/components/context.toa.yaml +2 -2
  2. package/components/identity.bans/manifest.toa.yaml +15 -7
  3. package/components/identity.bans/operations/transit.d.ts +14 -0
  4. package/components/identity.bans/operations/transit.js +11 -0
  5. package/components/identity.bans/operations/transit.js.map +1 -0
  6. package/components/identity.bans/operations/tsconfig.tsbuildinfo +1 -0
  7. package/components/identity.bans/source/transit.ts +21 -0
  8. package/components/identity.bans/tsconfig.json +9 -0
  9. package/components/identity.basic/manifest.toa.yaml +21 -10
  10. package/components/identity.basic/operations/authenticate.d.ts +5 -1
  11. package/components/identity.basic/operations/authenticate.js +5 -2
  12. package/components/identity.basic/operations/authenticate.js.map +1 -1
  13. package/components/identity.basic/operations/incept.d.ts +12 -0
  14. package/components/identity.basic/operations/incept.js +26 -0
  15. package/components/identity.basic/operations/incept.js.map +1 -0
  16. package/components/identity.basic/operations/transit.d.ts +4 -4
  17. package/components/identity.basic/operations/transit.js +5 -3
  18. package/components/identity.basic/operations/transit.js.map +1 -1
  19. package/components/identity.basic/operations/tsconfig.tsbuildinfo +1 -1
  20. package/components/identity.basic/operations/types.d.ts +8 -4
  21. package/components/identity.basic/source/authenticate.ts +16 -5
  22. package/components/identity.basic/source/incept.ts +38 -0
  23. package/components/identity.basic/source/transit.ts +8 -6
  24. package/components/identity.basic/source/types.ts +8 -4
  25. package/components/identity.federation/manifest.toa.yaml +32 -16
  26. package/components/identity.federation/operations/authenticate.d.ts +2 -2
  27. package/components/identity.federation/operations/authenticate.js +4 -11
  28. package/components/identity.federation/operations/authenticate.js.map +1 -1
  29. package/components/identity.federation/operations/incept.d.ts +11 -0
  30. package/components/identity.federation/operations/{create.js → incept.js} +6 -7
  31. package/components/identity.federation/operations/incept.js.map +1 -0
  32. package/components/identity.federation/operations/lib/assertions-as-values.js +2 -1
  33. package/components/identity.federation/operations/lib/assertions-as-values.js.map +1 -1
  34. package/components/identity.federation/operations/lib/jwt.d.ts +5 -5
  35. package/components/identity.federation/operations/lib/jwt.js +25 -12
  36. package/components/identity.federation/operations/lib/jwt.js.map +1 -1
  37. package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -1
  38. package/components/identity.federation/operations/types/configuration.d.ts +14 -0
  39. package/components/identity.federation/operations/types/configuration.js +3 -0
  40. package/components/identity.federation/operations/types/configuration.js.map +1 -0
  41. package/components/identity.federation/operations/{types.d.ts → types/context.d.ts} +15 -7
  42. package/components/identity.federation/operations/types/context.js +3 -0
  43. package/components/identity.federation/operations/types/context.js.map +1 -0
  44. package/components/identity.federation/operations/types/entity.d.ts +6 -0
  45. package/components/identity.federation/operations/types/entity.js +3 -0
  46. package/components/identity.federation/operations/types/entity.js.map +1 -0
  47. package/components/identity.federation/operations/types/index.d.ts +3 -0
  48. package/components/identity.federation/operations/types/index.js +20 -0
  49. package/components/identity.federation/operations/types/index.js.map +1 -0
  50. package/components/identity.federation/source/authenticate.ts +6 -19
  51. package/components/identity.federation/source/{create.ts → incept.ts} +10 -9
  52. package/components/identity.federation/source/lib/assertions-as-values.ts +4 -2
  53. package/components/identity.federation/source/lib/jwt.test.ts +123 -4
  54. package/components/identity.federation/source/lib/jwt.ts +36 -16
  55. package/components/identity.federation/source/types/configuration.ts +15 -0
  56. package/components/identity.federation/source/{types.ts → types/context.ts} +17 -6
  57. package/components/identity.federation/source/types/entity.ts +6 -0
  58. package/components/identity.federation/source/types/index.ts +3 -0
  59. package/components/identity.federation/tsconfig.json +5 -4
  60. package/components/identity.roles/manifest.toa.yaml +18 -7
  61. package/components/identity.roles/operations/grant.d.ts +10 -0
  62. package/components/identity.roles/operations/grant.js +21 -0
  63. package/components/identity.roles/operations/grant.js.map +1 -0
  64. package/components/identity.roles/operations/lib/Entity.d.ts +5 -0
  65. package/components/identity.roles/operations/lib/Entity.js +3 -0
  66. package/components/identity.roles/operations/lib/Entity.js.map +1 -0
  67. package/components/identity.roles/operations/list.d.ts +1 -4
  68. package/components/identity.roles/operations/list.js.map +1 -1
  69. package/components/identity.roles/operations/principal.d.ts +4 -6
  70. package/components/identity.roles/operations/principal.js +6 -1
  71. package/components/identity.roles/operations/principal.js.map +1 -1
  72. package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -1
  73. package/components/identity.roles/source/grant.ts +32 -0
  74. package/components/identity.roles/source/lib/Entity.ts +5 -0
  75. package/components/identity.roles/source/list.ts +2 -4
  76. package/components/identity.roles/source/principal.ts +10 -8
  77. package/components/identity.tokens/manifest.toa.yaml +19 -5
  78. package/components/identity.tokens/operations/authenticate.d.ts +2 -2
  79. package/components/identity.tokens/operations/authenticate.js +12 -5
  80. package/components/identity.tokens/operations/authenticate.js.map +1 -1
  81. package/components/identity.tokens/operations/decrypt.js +1 -0
  82. package/components/identity.tokens/operations/decrypt.js.map +1 -1
  83. package/components/identity.tokens/operations/encrypt.js +5 -1
  84. package/components/identity.tokens/operations/encrypt.js.map +1 -1
  85. package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -1
  86. package/components/identity.tokens/operations/types.d.ts +8 -2
  87. package/components/identity.tokens/receivers/identity.bans.created.js +3 -0
  88. package/components/identity.tokens/source/authenticate.test.ts +11 -4
  89. package/components/identity.tokens/source/authenticate.ts +14 -6
  90. package/components/identity.tokens/source/decrypt.test.ts +5 -3
  91. package/components/identity.tokens/source/decrypt.ts +9 -8
  92. package/components/identity.tokens/source/encrypt.test.ts +26 -2
  93. package/components/identity.tokens/source/encrypt.ts +5 -1
  94. package/components/identity.tokens/source/types.ts +9 -2
  95. package/components/octets.storage/manifest.toa.yaml +6 -7
  96. package/components/octets.storage/operations/get.js +2 -2
  97. package/components/octets.storage/operations/store.js +113 -3
  98. package/documentation/access.md +75 -38
  99. package/documentation/authorities.md +49 -0
  100. package/documentation/cache.md +8 -1
  101. package/documentation/components.md +47 -22
  102. package/documentation/flow.md +31 -0
  103. package/documentation/identity.md +17 -22
  104. package/documentation/introspection.md +82 -0
  105. package/documentation/octets.md +81 -23
  106. package/documentation/protocol.md +13 -3
  107. package/documentation/query.md +29 -4
  108. package/documentation/require.md +15 -0
  109. package/documentation/tree.md +13 -0
  110. package/documentation/vary.md +14 -14
  111. package/features/access.feature +78 -46
  112. package/features/annotation.feature +1 -0
  113. package/features/auth.claim.feature +170 -0
  114. package/features/authorities.basic.feature +141 -0
  115. package/features/authorities.feature +32 -0
  116. package/features/authorities.federation.feature +100 -0
  117. package/features/authorities.tokens.feature +117 -0
  118. package/features/body.feature +3 -0
  119. package/features/cache.feature +109 -5
  120. package/features/cors.feature +6 -1
  121. package/features/debug.feature +34 -0
  122. package/features/directives.feature +3 -0
  123. package/features/dynamic.feature +4 -0
  124. package/features/errors.feature +20 -7
  125. package/features/etag.feature +31 -0
  126. package/features/flow.feature +45 -0
  127. package/features/identity.bans.feature +137 -0
  128. package/features/identity.basic.feature +125 -23
  129. package/features/identity.feature +7 -2
  130. package/features/identity.federation.feature +66 -11
  131. package/features/identity.roles.feature +250 -7
  132. package/features/identity.tokens.feature +54 -4
  133. package/features/introspection.feature +153 -0
  134. package/features/io.feature +38 -1
  135. package/features/methods.feature +47 -0
  136. package/features/octets.download.feature +189 -0
  137. package/features/octets.entries.feature +8 -1
  138. package/features/octets.feature +82 -54
  139. package/features/octets.meta.feature +3 -0
  140. package/features/octets.workflows.feature +239 -19
  141. package/features/probes.feature +14 -0
  142. package/features/{queries.feature → query.feature} +65 -2
  143. package/features/realtime.feature +34 -0
  144. package/features/require.feature +67 -0
  145. package/features/response.feature +38 -3
  146. package/features/routes.feature +93 -2
  147. package/features/steps/Database.ts +17 -10
  148. package/features/steps/Gateway.ts +23 -6
  149. package/features/steps/IdP.ts +30 -25
  150. package/features/steps/Parameters.ts +4 -1
  151. package/features/steps/Realtime.ts +151 -0
  152. package/features/steps/components/echo/manifest.toa.yaml +14 -1
  153. package/features/steps/components/echo/operations/identity.js +7 -0
  154. package/features/steps/components/echo/operations/parameters.js +7 -0
  155. package/features/steps/components/echo.beacon/manifest.toa.yaml +2 -0
  156. package/features/steps/components/echo.beacon/operations/hello.js +5 -0
  157. package/features/steps/components/octets.tester/manifest.toa.yaml +22 -1
  158. package/features/steps/components/octets.tester/operations/authority.js +7 -0
  159. package/features/steps/components/octets.tester/operations/baz.js +1 -2
  160. package/features/steps/components/octets.tester/operations/diversify.js +3 -1
  161. package/features/steps/components/octets.tester/operations/foo.js +2 -2
  162. package/features/steps/components/octets.tester/operations/redirect.js +12 -0
  163. package/features/steps/components/octets.tester/operations/yex.js +16 -0
  164. package/features/steps/components/octets.tester/operations/yield.js +13 -0
  165. package/features/steps/components/pots/manifest.toa.yaml +14 -3
  166. package/features/steps/components/users/manifest.toa.yaml +0 -1
  167. package/features/steps/components/users.properties/manifest.toa.yaml +1 -1
  168. package/features/streams.feature +5 -0
  169. package/features/timing.feature +4 -1
  170. package/features/vary.feature +71 -0
  171. package/package.json +23 -14
  172. package/readme.md +19 -14
  173. package/schemas/annotation.cos.yaml +1 -1
  174. package/schemas/method.cos.yaml +1 -1
  175. package/schemas/node.cos.yaml +1 -0
  176. package/schemas/octets/store.cos.yaml +25 -3
  177. package/schemas/query.cos.yaml +4 -10
  178. package/source/Annotation.ts +3 -3
  179. package/source/Composition.ts +0 -6
  180. package/source/Directive.ts +4 -5
  181. package/source/Endpoint.ts +52 -12
  182. package/source/Factory.ts +10 -11
  183. package/source/Gateway.ts +48 -19
  184. package/source/HTTP/Context.ts +25 -2
  185. package/source/HTTP/Server.ts +52 -44
  186. package/source/HTTP/exceptions.ts +13 -1
  187. package/source/HTTP/formats/index.ts +3 -3
  188. package/source/HTTP/messages.test.ts +45 -2
  189. package/source/HTTP/messages.ts +23 -5
  190. package/source/Introspection.ts +11 -0
  191. package/source/Mapping.ts +63 -21
  192. package/source/Query.test.ts +3 -3
  193. package/source/Query.ts +117 -33
  194. package/source/RTD/Endpoint.ts +3 -0
  195. package/source/RTD/Method.ts +16 -0
  196. package/source/RTD/Node.ts +29 -13
  197. package/source/RTD/Route.ts +5 -4
  198. package/source/RTD/factory.ts +5 -2
  199. package/source/RTD/syntax/parse.ts +37 -24
  200. package/source/RTD/syntax/types.ts +6 -4
  201. package/source/Remotes.ts +2 -9
  202. package/source/Tenant.ts +0 -8
  203. package/source/deployment.ts +33 -23
  204. package/source/directives/auth/Authorization.ts +37 -14
  205. package/source/directives/auth/Delegate.ts +42 -0
  206. package/source/directives/auth/Federation.ts +84 -0
  207. package/source/directives/auth/Incept.ts +4 -3
  208. package/source/directives/auth/Role.test.ts +53 -6
  209. package/source/directives/auth/Role.ts +22 -14
  210. package/source/directives/auth/split.ts +1 -1
  211. package/source/directives/auth/types.ts +1 -1
  212. package/source/directives/cache/Cache.ts +13 -6
  213. package/source/directives/cache/Control.ts +42 -16
  214. package/source/directives/cors/CORS.ts +1 -1
  215. package/source/directives/dev/Development.ts +1 -1
  216. package/source/directives/flow/Fetch.ts +88 -0
  217. package/source/directives/flow/Flow.ts +34 -0
  218. package/source/directives/flow/index.ts +3 -0
  219. package/source/directives/flow/types.ts +6 -0
  220. package/source/directives/index.ts +3 -1
  221. package/source/directives/io/Input.ts +4 -4
  222. package/source/directives/io/Output.ts +4 -3
  223. package/source/directives/octets/Context.ts +3 -2
  224. package/source/directives/octets/Fetch.ts +11 -10
  225. package/source/directives/octets/List.ts +5 -5
  226. package/source/directives/octets/Octets.ts +1 -3
  227. package/source/directives/octets/Store.ts +30 -10
  228. package/source/directives/octets/bytes.test.ts +30 -0
  229. package/source/directives/octets/bytes.ts +18 -0
  230. package/source/directives/octets/schemas.ts +4 -6
  231. package/source/directives/octets/workflows/Execution.ts +60 -8
  232. package/source/directives/octets/workflows/Workflow.ts +2 -1
  233. package/source/directives/require/Directive.ts +5 -0
  234. package/source/directives/require/Headers.ts +20 -0
  235. package/source/directives/require/Require.ts +28 -0
  236. package/source/directives/require/index.ts +3 -0
  237. package/source/directives/vary/Directive.ts +2 -1
  238. package/source/directives/vary/Embed.ts +14 -8
  239. package/source/directives/vary/Vary.ts +6 -4
  240. package/source/directives/vary/embeddings/Authority.ts +8 -0
  241. package/source/directives/vary/embeddings/Embedding.ts +2 -1
  242. package/source/directives/vary/embeddings/Parameter.ts +14 -0
  243. package/source/directives/vary/embeddings/index.ts +6 -4
  244. package/source/exceptions.ts +23 -11
  245. package/source/manifest.ts +10 -11
  246. package/source/schemas.ts +1 -1
  247. package/transpiled/Annotation.d.ts +3 -3
  248. package/transpiled/Composition.d.ts +0 -1
  249. package/transpiled/Composition.js +0 -4
  250. package/transpiled/Composition.js.map +1 -1
  251. package/transpiled/Directive.js +4 -4
  252. package/transpiled/Directive.js.map +1 -1
  253. package/transpiled/Endpoint.d.ts +6 -4
  254. package/transpiled/Endpoint.js +32 -4
  255. package/transpiled/Endpoint.js.map +1 -1
  256. package/transpiled/Factory.d.ts +1 -1
  257. package/transpiled/Factory.js +9 -8
  258. package/transpiled/Factory.js.map +1 -1
  259. package/transpiled/Gateway.d.ts +2 -0
  260. package/transpiled/Gateway.js +36 -12
  261. package/transpiled/Gateway.js.map +1 -1
  262. package/transpiled/HTTP/Context.d.ts +8 -1
  263. package/transpiled/HTTP/Context.js +16 -2
  264. package/transpiled/HTTP/Context.js.map +1 -1
  265. package/transpiled/HTTP/Server.d.ts +13 -2
  266. package/transpiled/HTTP/Server.js +39 -36
  267. package/transpiled/HTTP/Server.js.map +1 -1
  268. package/transpiled/HTTP/exceptions.d.ts +7 -1
  269. package/transpiled/HTTP/exceptions.js +13 -1
  270. package/transpiled/HTTP/exceptions.js.map +1 -1
  271. package/transpiled/HTTP/formats/index.js +3 -3
  272. package/transpiled/HTTP/formats/index.js.map +1 -1
  273. package/transpiled/HTTP/messages.d.ts +1 -0
  274. package/transpiled/HTTP/messages.js +24 -5
  275. package/transpiled/HTTP/messages.js.map +1 -1
  276. package/transpiled/Introspection.d.ts +9 -0
  277. package/transpiled/Introspection.js +3 -0
  278. package/transpiled/Introspection.js.map +1 -0
  279. package/transpiled/Mapping.d.ts +10 -2
  280. package/transpiled/Mapping.js +48 -19
  281. package/transpiled/Mapping.js.map +1 -1
  282. package/transpiled/Query.d.ts +10 -1
  283. package/transpiled/Query.js +83 -30
  284. package/transpiled/Query.js.map +1 -1
  285. package/transpiled/RTD/Endpoint.d.ts +1 -0
  286. package/transpiled/RTD/Method.d.ts +4 -0
  287. package/transpiled/RTD/Method.js +11 -0
  288. package/transpiled/RTD/Method.js.map +1 -1
  289. package/transpiled/RTD/Node.d.ts +4 -1
  290. package/transpiled/RTD/Node.js +23 -12
  291. package/transpiled/RTD/Node.js.map +1 -1
  292. package/transpiled/RTD/Route.d.ts +1 -1
  293. package/transpiled/RTD/Route.js +0 -1
  294. package/transpiled/RTD/Route.js.map +1 -1
  295. package/transpiled/RTD/factory.js +5 -2
  296. package/transpiled/RTD/factory.js.map +1 -1
  297. package/transpiled/RTD/syntax/parse.js +34 -22
  298. package/transpiled/RTD/syntax/parse.js.map +1 -1
  299. package/transpiled/RTD/syntax/types.d.ts +5 -3
  300. package/transpiled/RTD/syntax/types.js +1 -1
  301. package/transpiled/RTD/syntax/types.js.map +1 -1
  302. package/transpiled/Remotes.d.ts +2 -4
  303. package/transpiled/Remotes.js +0 -5
  304. package/transpiled/Remotes.js.map +1 -1
  305. package/transpiled/Tenant.d.ts +0 -1
  306. package/transpiled/Tenant.js +0 -6
  307. package/transpiled/Tenant.js.map +1 -1
  308. package/transpiled/deployment.d.ts +1 -1
  309. package/transpiled/deployment.js +28 -20
  310. package/transpiled/deployment.js.map +1 -1
  311. package/transpiled/directives/auth/Authorization.js +26 -10
  312. package/transpiled/directives/auth/Authorization.js.map +1 -1
  313. package/transpiled/directives/auth/Delegate.d.ts +10 -0
  314. package/transpiled/directives/auth/Delegate.js +34 -0
  315. package/transpiled/directives/auth/Delegate.js.map +1 -0
  316. package/transpiled/directives/auth/Federation.d.ts +16 -0
  317. package/transpiled/directives/auth/Federation.js +57 -0
  318. package/transpiled/directives/auth/Federation.js.map +1 -0
  319. package/transpiled/directives/auth/Incept.js +4 -3
  320. package/transpiled/directives/auth/Incept.js.map +1 -1
  321. package/transpiled/directives/auth/Role.d.ts +4 -1
  322. package/transpiled/directives/auth/Role.js +20 -14
  323. package/transpiled/directives/auth/Role.js.map +1 -1
  324. package/transpiled/directives/auth/split.js +1 -1
  325. package/transpiled/directives/auth/split.js.map +1 -1
  326. package/transpiled/directives/cache/Cache.d.ts +3 -3
  327. package/transpiled/directives/cache/Cache.js +10 -4
  328. package/transpiled/directives/cache/Cache.js.map +1 -1
  329. package/transpiled/directives/cache/Control.d.ts +2 -1
  330. package/transpiled/directives/cache/Control.js +29 -12
  331. package/transpiled/directives/cache/Control.js.map +1 -1
  332. package/transpiled/directives/cors/CORS.js +1 -1
  333. package/transpiled/directives/cors/CORS.js.map +1 -1
  334. package/transpiled/directives/dev/Development.js +1 -1
  335. package/transpiled/directives/dev/Development.js.map +1 -1
  336. package/transpiled/directives/flow/Fetch.d.ts +13 -0
  337. package/transpiled/directives/flow/Fetch.js +59 -0
  338. package/transpiled/directives/flow/Fetch.js.map +1 -0
  339. package/transpiled/directives/flow/Flow.d.ts +10 -0
  340. package/transpiled/directives/flow/Flow.js +27 -0
  341. package/transpiled/directives/flow/Flow.js.map +1 -0
  342. package/transpiled/directives/flow/index.d.ts +2 -0
  343. package/transpiled/directives/flow/index.js +6 -0
  344. package/transpiled/directives/flow/index.js.map +1 -0
  345. package/transpiled/directives/flow/types.d.ts +5 -0
  346. package/transpiled/directives/flow/types.js.map +1 -0
  347. package/transpiled/directives/index.js +3 -1
  348. package/transpiled/directives/index.js.map +1 -1
  349. package/transpiled/directives/io/Input.js +2 -2
  350. package/transpiled/directives/io/Input.js.map +1 -1
  351. package/transpiled/directives/io/Output.js +2 -2
  352. package/transpiled/directives/io/Output.js.map +1 -1
  353. package/transpiled/directives/octets/Context.js +4 -24
  354. package/transpiled/directives/octets/Context.js.map +1 -1
  355. package/transpiled/directives/octets/Fetch.d.ts +3 -3
  356. package/transpiled/directives/octets/Fetch.js +8 -8
  357. package/transpiled/directives/octets/Fetch.js.map +1 -1
  358. package/transpiled/directives/octets/List.d.ts +3 -3
  359. package/transpiled/directives/octets/List.js +3 -3
  360. package/transpiled/directives/octets/List.js.map +1 -1
  361. package/transpiled/directives/octets/Octets.js +1 -3
  362. package/transpiled/directives/octets/Octets.js.map +1 -1
  363. package/transpiled/directives/octets/Store.d.ts +6 -1
  364. package/transpiled/directives/octets/Store.js +17 -7
  365. package/transpiled/directives/octets/Store.js.map +1 -1
  366. package/transpiled/directives/octets/bytes.d.ts +1 -0
  367. package/transpiled/directives/octets/bytes.js +21 -0
  368. package/transpiled/directives/octets/bytes.js.map +1 -0
  369. package/transpiled/directives/octets/schemas.d.ts +4 -6
  370. package/transpiled/directives/octets/schemas.js +1 -3
  371. package/transpiled/directives/octets/schemas.js.map +1 -1
  372. package/transpiled/directives/octets/workflows/Execution.d.ts +5 -1
  373. package/transpiled/directives/octets/workflows/Execution.js +44 -9
  374. package/transpiled/directives/octets/workflows/Execution.js.map +1 -1
  375. package/transpiled/directives/octets/workflows/Workflow.js +2 -1
  376. package/transpiled/directives/octets/workflows/Workflow.js.map +1 -1
  377. package/transpiled/directives/require/Directive.d.ts +4 -0
  378. package/transpiled/directives/require/Directive.js +3 -0
  379. package/transpiled/directives/require/Directive.js.map +1 -0
  380. package/transpiled/directives/require/Headers.d.ts +7 -0
  381. package/transpiled/directives/require/Headers.js +19 -0
  382. package/transpiled/directives/require/Headers.js.map +1 -0
  383. package/transpiled/directives/require/Require.d.ts +9 -0
  384. package/transpiled/directives/require/Require.js +27 -0
  385. package/transpiled/directives/require/Require.js.map +1 -0
  386. package/transpiled/directives/require/index.d.ts +2 -0
  387. package/transpiled/directives/require/index.js +6 -0
  388. package/transpiled/directives/require/index.js.map +1 -0
  389. package/transpiled/directives/vary/Directive.d.ts +2 -1
  390. package/transpiled/directives/vary/Embed.d.ts +2 -1
  391. package/transpiled/directives/vary/Embed.js +8 -6
  392. package/transpiled/directives/vary/Embed.js.map +1 -1
  393. package/transpiled/directives/vary/Vary.d.ts +2 -2
  394. package/transpiled/directives/vary/Vary.js +3 -3
  395. package/transpiled/directives/vary/Vary.js.map +1 -1
  396. package/transpiled/directives/vary/embeddings/Authority.d.ts +5 -0
  397. package/transpiled/directives/vary/embeddings/Authority.js +10 -0
  398. package/transpiled/directives/vary/embeddings/Authority.js.map +1 -0
  399. package/transpiled/directives/vary/embeddings/Embedding.d.ts +2 -1
  400. package/transpiled/directives/vary/embeddings/Parameter.d.ts +7 -0
  401. package/transpiled/directives/vary/embeddings/Parameter.js +14 -0
  402. package/transpiled/directives/vary/embeddings/Parameter.js.map +1 -0
  403. package/transpiled/directives/vary/embeddings/index.d.ts +2 -2
  404. package/transpiled/directives/vary/embeddings/index.js +8 -4
  405. package/transpiled/directives/vary/embeddings/index.js.map +1 -1
  406. package/transpiled/exceptions.d.ts +3 -2
  407. package/transpiled/exceptions.js +14 -7
  408. package/transpiled/exceptions.js.map +1 -1
  409. package/transpiled/manifest.js +10 -11
  410. package/transpiled/manifest.js.map +1 -1
  411. package/transpiled/schemas.d.ts +1 -1
  412. package/transpiled/schemas.js +2 -2
  413. package/transpiled/schemas.js.map +1 -1
  414. package/transpiled/tsconfig.tsbuildinfo +1 -1
  415. package/tsconfig.json +9 -7
  416. package/components/identity.basic/operations/create.d.ts +0 -10
  417. package/components/identity.basic/operations/create.js +0 -10
  418. package/components/identity.basic/operations/create.js.map +0 -1
  419. package/components/identity.basic/source/create.ts +0 -18
  420. package/components/identity.federation/operations/create.d.ts +0 -10
  421. package/components/identity.federation/operations/create.js.map +0 -1
  422. package/components/identity.federation/operations/schemas.d.ts +0 -59
  423. package/components/identity.federation/operations/schemas.js +0 -9
  424. package/components/identity.federation/operations/schemas.js.map +0 -1
  425. package/components/identity.federation/operations/types.js.map +0 -1
  426. package/components/identity.federation/source/schemas.ts +0 -61
  427. package/components/octets.storage/operations/permute.js +0 -7
  428. package/schemas/octets/context.cos.yaml +0 -1
  429. package/source/HTTP/Server.test.ts +0 -126
  430. package/source/directives/octets/Permute.ts +0 -44
  431. package/transpiled/directives/octets/Permute.d.ts +0 -11
  432. package/transpiled/directives/octets/Permute.js +0 -58
  433. package/transpiled/directives/octets/Permute.js.map +0 -1
  434. /package/{components/identity.federation/operations → transpiled/directives/flow}/types.js +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@toa.io/extensions.exposition",
3
- "version": "1.0.0-alpha.7",
3
+ "version": "1.0.0-alpha.71",
4
4
  "description": "Toa Exposition",
5
5
  "author": "temich <tema.gurtovoy@gmail.com>",
6
6
  "homepage": "https://github.com/toa-io/toa#readme",
@@ -17,37 +17,46 @@
17
17
  "access": "public"
18
18
  },
19
19
  "dependencies": {
20
- "@toa.io/core": "1.0.0-alpha.7",
21
- "@toa.io/generic": "1.0.0-alpha.7",
22
- "@toa.io/schemas": "1.0.0-alpha.7",
20
+ "@toa.io/core": "1.0.0-alpha.67",
21
+ "@toa.io/generic": "1.0.0-alpha.63",
22
+ "@toa.io/schemas": "1.0.0-alpha.63",
23
23
  "bcryptjs": "2.4.3",
24
24
  "error-value": "0.3.0",
25
25
  "js-yaml": "4.1.0",
26
26
  "matchacho": "0.3.5",
27
27
  "msgpackr": "1.10.1",
28
28
  "negotiator": "0.6.3",
29
- "paseto": "3.1.4"
29
+ "openspan": "1.0.0-alpha.67",
30
+ "paseto": "3.1.4",
31
+ "ultrafetch": "0.4.0"
30
32
  },
31
33
  "jest": {
32
- "preset": "ts-jest",
34
+ "transform": {
35
+ "^.+\\.ts$": "jest-esbuild"
36
+ },
33
37
  "testEnvironment": "node"
34
38
  },
35
39
  "scripts": {
36
40
  "test": "jest",
37
- "transpile": "tsc && npm run transpile:basic && npm run transpile:tokens && npm run transpile:roles && npm run transpile:federation",
41
+ "transpile": "tsc && npm run transpile:bans && npm run transpile:basic && npm run transpile:tokens && npm run transpile:roles && npm run transpile:federation",
42
+ "transpile:bans": "tsc -p ./components/identity.bans",
38
43
  "transpile:basic": "tsc -p ./components/identity.basic",
39
- "pretranspile:federation": "js-yaml components/identity.federation/manifest.toa.yaml | jq -M '{ type: \"object\", properties: {configuration: .configuration.schema, entity: .entity.schema }, additionalProperties: false}' > schemas.json && json2ts -i schemas.json -o components/identity.federation/source/schemas.ts && rm schemas.json",
40
- "transpile:federation": "tsc -p ./components/identity.federation",
41
44
  "transpile:tokens": "tsc -p ./components/identity.tokens",
42
45
  "transpile:roles": "tsc -p ./components/identity.roles",
43
- "features": "cucumber-js"
46
+ "transpile:federation": "tsc -p ./components/identity.federation",
47
+ "features": "cucumber-js",
48
+ "features:security": "cucumber-js --tags @security",
49
+ "features:octets": "cucumber-js features/octets.*"
44
50
  },
45
51
  "devDependencies": {
46
- "@toa.io/agent": "1.0.0-alpha.7",
47
- "@toa.io/extensions.storages": "1.0.0-alpha.7",
52
+ "@swc/core": "1.6.6",
53
+ "@swc/helpers": "0.5.11",
54
+ "@toa.io/agent": "1.0.0-alpha.71",
55
+ "@toa.io/extensions.storages": "1.0.0-alpha.71",
48
56
  "@types/bcryptjs": "2.4.3",
49
57
  "@types/cors": "2.8.13",
50
- "@types/negotiator": "0.6.1"
58
+ "@types/negotiator": "0.6.1",
59
+ "jest-esbuild": "0.3.0"
51
60
  },
52
- "gitHead": "4f5ac0bc342d4b7bd469fbe5c74266f050b55c9f"
61
+ "gitHead": "9de4765232a01dffebe48d73405b84f0a84c8eb1"
53
62
  }
package/readme.md CHANGED
@@ -20,7 +20,8 @@ exposition:
20
20
  # context.toa.yaml
21
21
 
22
22
  exposition:
23
- host: api.example.com
23
+ authorities:
24
+ example: api.example.com
24
25
  ```
25
26
 
26
27
  ```http
@@ -117,33 +118,36 @@ The Exposition annotation declares options for its deployment.
117
118
  ```yaml
118
119
  annotations:
119
120
  '@toa.io/extensions.exposition':
120
- host: the.exmaple.com
121
+ authorities:
122
+ example: the.example.com
121
123
  ```
122
124
 
123
125
  A shortcut is also available.
124
126
 
125
127
  ```yaml
126
128
  exposition:
127
- host: the.example.com
129
+ authorities:
130
+ example: the.example.com
128
131
  ```
129
132
 
130
- | Option | Type | Description |
131
- |---------------|-----------|-------------------------------------------------------------------------------------------------------------------|
132
- | `host` | `string` | Domain name to be used for the corresponding Kubernetes Ingress. |
133
- | `class` | `string` | Ingress class |
134
- | `annotations` | `object` | Ingress annotations |
135
- | `debug` | `boolean` | Output server errors. Default `false`. |
136
- | `trace` | `boolean` | Output [server timing](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Server-Timing). Default `false`. |
133
+ | Option | Description |
134
+ |---------------|-------------------------------------------------------------------------------------------------------------------|
135
+ | `auhorities` | Mapping of authority identifiers to domain names. See [Authorities](documentation/authorities.md). |
136
+ | `class` | Ingress class. |
137
+ | `annotations` | Ingress annotations. |
138
+ | `debug` | Output server errors. Default `false`. |
139
+ | `trace` | Output [server timing](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Server-Timing). Default `false`. |
137
140
 
138
141
  ### Context resources
139
142
 
140
- Exposition annotaion can contain [resource declaration](documentation/tree.md) under the `/` key.
143
+ Exposition annotation can contain [resource declaration](documentation/tree.md) under the `/` key.
141
144
 
142
145
  ```yaml
143
146
  # context.toa.yaml
144
147
 
145
148
  exposition:
146
- host: the.example.com
149
+ authorities:
150
+ example: the.example.com
147
151
  /:
148
152
  /code:
149
153
  GET:
@@ -162,8 +166,9 @@ If component resource branch conflicts with an annotation, the annotation takes
162
166
 
163
167
  ```yaml
164
168
  exposition:
165
- host: the.example.com
166
- host@staging: the.example.dev
169
+ authorities:
170
+ example: the.example.com
171
+ example@staging: the.example.dev
167
172
  class: alb
168
173
  debug@staging: true
169
174
  annotations:
@@ -1,4 +1,4 @@
1
- host: string
1
+ authorities*: <string>
2
2
  class: string
3
3
  annotations: <string>
4
4
  debug: boolean
@@ -1,4 +1,4 @@
1
- verb: /^(GET|POST|PUT|PATCH|DELETE)$/
1
+ verb: /^(GET|POST|PUT|PATCH|DELETE|LOCK|UNLOCK)$/
2
2
  mapping:
3
3
  namespace: string
4
4
  component: string
@@ -1,5 +1,6 @@
1
1
  protected: boolean
2
2
  isolated: boolean
3
+ forward: string
3
4
  routes: [ref:route]
4
5
  methods: [ref:method]
5
6
  directives: [ref:directive]
@@ -1,3 +1,25 @@
1
- accept+: string
2
- workflow+: <string>
3
- _: true
1
+ type: object
2
+ nullable: true
3
+ properties:
4
+ accept:
5
+ anyOf:
6
+ - type: string
7
+ - type: array
8
+ items:
9
+ type: string
10
+ limit:
11
+ type: string
12
+ pattern: ^(\d+(\.\d+)?)([kmgtKMBGT]i?)?[bB]?$
13
+ trust:
14
+ type: array
15
+ items:
16
+ type: string
17
+ workflow:
18
+ anyOf:
19
+ - &unit
20
+ type: object
21
+ patternProperties:
22
+ ^.+$:
23
+ type: string
24
+ - type: array
25
+ items: *unit
@@ -1,17 +1,11 @@
1
- _: true
2
1
  id?: string
3
2
  criteria?: string
4
3
  sort?: string
5
- omit:
4
+ omit?:
6
5
  $ref: range
7
- default:
8
- value: 0
9
- range: [0, 1000]
10
- limit:
6
+ limit?:
11
7
  $ref: range
12
- default:
13
- value: 10
14
- range: [1, 1000]
15
- required: [value]
16
8
  selectors?: [string]
17
9
  projection?: [string]
10
+ parameters?: [string]
11
+ _: true
@@ -1,8 +1,8 @@
1
1
  export interface Annotation {
2
- host?: string
2
+ authorities: Record<string, string>
3
3
  class?: string
4
4
  annotations?: Record<string, string>
5
- debug: boolean
6
- trace: boolean
5
+ debug?: boolean
6
+ trace?: boolean
7
7
  '/'?: object // parsed and validated by RTD.syntax.parse
8
8
  }
@@ -18,12 +18,6 @@ export class Composition extends Connector {
18
18
  await composition.connect()
19
19
 
20
20
  this.depends(composition)
21
-
22
- console.info('Composition complete.')
23
- }
24
-
25
- protected override dispose (): void {
26
- console.info('Composition shutdown complete.')
27
21
  }
28
22
  }
29
23
 
@@ -17,11 +17,8 @@ export class Directives implements RTD.Directives {
17
17
 
18
18
  const output = await set.family.preflight(set.directives, context, parameters)
19
19
 
20
- if (output !== null) {
21
- await this.settle(context, output)
22
-
20
+ if (output !== null)
23
21
  return output
24
- }
25
22
  }
26
23
 
27
24
  return null
@@ -93,5 +90,7 @@ export const shortcuts: RTD.syntax.Shortcuts = new Map([
93
90
  ['id', 'auth:id'],
94
91
  ['role', 'auth:role'],
95
92
  ['rule', 'auth:rule'],
96
- ['incept', 'auth:incept']
93
+ ['incept', 'auth:incept'],
94
+ ['input', 'io:input'],
95
+ ['output', 'io:output']
97
96
  ])
@@ -1,34 +1,41 @@
1
- import { type Component } from '@toa.io/core'
2
- import { type Remotes } from './Remotes'
1
+ import { console } from 'openspan'
3
2
  import { Mapping } from './Mapping'
4
- import { type Context } from './Context'
5
3
  import * as http from './HTTP'
4
+ import type { Introspection, Schema } from './Introspection'
5
+ import type { Remote } from '@toa.io/core'
6
+ import type { Remotes } from './Remotes'
7
+ import type { Context } from './Context'
6
8
  import type * as RTD from './RTD'
7
9
 
8
10
  export class Endpoint implements RTD.Endpoint {
9
11
  private readonly endpoint: string
10
12
  private readonly mapping: Mapping
11
- private readonly discovery: Promise<Component>
12
- private remote: Component | null = null
13
+ private readonly discovery: Promise<Remote>
14
+ private remote: Remote | null = null
13
15
 
14
- public constructor (endpoint: string, mapping: Mapping, discovery: Promise<Component>) {
16
+ public constructor (endpoint: string, mapping: Mapping, discovery: Promise<Remote>) {
15
17
  this.endpoint = endpoint
16
18
  this.mapping = mapping
17
19
  this.discovery = discovery
18
20
  }
19
21
 
20
- public async call
21
- (context: http.Context, parameters: RTD.Parameter[]): Promise<http.OutgoingMessage> {
22
+ public async call (context: http.Context, parameters: RTD.Parameter[]): Promise<http.OutgoingMessage> {
22
23
  const body = await context.body()
23
24
  const query = this.query(context)
24
25
  const request = this.mapping.fit(body, query, parameters)
25
26
 
26
27
  this.remote ??= await this.discovery
27
28
 
29
+ if (context.debug)
30
+ console.debug('Calling operation', {
31
+ endpoint: this.remote.locator.id + '.' + this.endpoint,
32
+ request
33
+ })
34
+
28
35
  const reply = await this.remote.invoke(this.endpoint, request)
29
36
 
30
37
  if (reply instanceof Error)
31
- throw new http.Conflict(reply)
38
+ throw new http.UnprocessableEntity(reply)
32
39
 
33
40
  const message: http.OutgoingMessage = {}
34
41
 
@@ -42,10 +49,8 @@ export class Endpoint implements RTD.Endpoint {
42
49
  message.headers.set('etag', etag)
43
50
 
44
51
  return message
45
- } else {
52
+ } else
46
53
  message.headers.set('etag', `"${reply._version.toString()}"`)
47
- delete reply._version
48
- }
49
54
  }
50
55
 
51
56
  message.body = reply
@@ -53,6 +58,41 @@ export class Endpoint implements RTD.Endpoint {
53
58
  return message
54
59
  }
55
60
 
61
+ public async explain (parameters: RTD.Parameter[]): Promise<Introspection> {
62
+ this.remote ??= await this.discovery
63
+
64
+ // eslint-disable-next-line @typescript-eslint/await-thenable
65
+ const operation = await this.remote.explain(this.endpoint)
66
+
67
+ let route: Record<string, Schema> | null = null
68
+
69
+ if (operation.input?.type === 'object')
70
+ for (const parameter of parameters) {
71
+ const schema = operation.input.properties[parameter.name]
72
+
73
+ // eslint-disable-next-line max-depth
74
+ if (schema !== undefined) {
75
+ route ??= {}
76
+ route[parameter.name] = schema
77
+
78
+ delete operation.input.properties[parameter.name]
79
+ }
80
+ }
81
+
82
+ const query = this.mapping.explain(operation)
83
+ const introspection: Introspection = {}
84
+
85
+ if (route !== null)
86
+ introspection.route = route
87
+
88
+ if (query !== null)
89
+ introspection.query = query
90
+
91
+ Object.assign(introspection, operation)
92
+
93
+ return introspection
94
+ }
95
+
56
96
  public async close (): Promise<void> {
57
97
  this.remote ??= await this.discovery
58
98
 
package/source/Factory.ts CHANGED
@@ -1,14 +1,17 @@
1
+ import assert from 'node:assert'
2
+ import { decode } from '@toa.io/generic'
1
3
  import { Tenant } from './Tenant'
2
4
  import { Gateway } from './Gateway'
3
5
  import { Remotes } from './Remotes'
4
- import { Tree, syntax } from './RTD'
5
- import { Server } from './HTTP'
6
+ import { Tree } from './RTD'
6
7
  import { EndpointsFactory } from './Endpoint'
7
8
  import { families, interceptors } from './directives'
8
9
  import { DirectivesFactory } from './Directive'
9
10
  import { Composition } from './Composition'
10
11
  import * as root from './root'
11
12
  import { Interception } from './Interception'
13
+ import * as http from './HTTP'
14
+ import type { syntax } from './RTD'
12
15
  import type { Broadcast } from './Gateway'
13
16
  import type { Connector, Locator, extensions } from '@toa.io/core'
14
17
 
@@ -26,16 +29,12 @@ export class Factory implements extensions.Factory {
26
29
  }
27
30
 
28
31
  public service (): Connector | null {
29
- const debug = process.env.TOA_EXPOSITION_DEBUG === '1'
30
- const trace = process.env.TOA_EXPOSITION_TRACE === '1'
31
- const broadcast: Broadcast = this.boot.bindings.broadcast(CHANNEL)
32
-
33
- const server = Server.create({
34
- methods: syntax.verbs,
35
- debug,
36
- trace
37
- })
32
+ assert.ok(process.env.TOA_EXPOSITION_PROPERTIES,
33
+ 'TOA_EXPOSITION_PROPERTIES is undefined')
38
34
 
35
+ const options = decode<http.Options>(process.env.TOA_EXPOSITION_PROPERTIES)
36
+ const broadcast: Broadcast = this.boot.bindings.broadcast(CHANNEL)
37
+ const server = http.Server.create({ ...options })
39
38
  const remotes = new Remotes(this.boot)
40
39
  const node = root.resolve()
41
40
  const methods = new EndpointsFactory(remotes)
package/source/Gateway.ts CHANGED
@@ -1,8 +1,10 @@
1
+ import assert from 'node:assert'
2
+ import { console } from 'openspan'
1
3
  import { type bindings, Connector } from '@toa.io/core'
2
4
  import * as http from './HTTP'
3
5
  import { rethrow } from './exceptions'
4
6
  import type { Interception } from './Interception'
5
- import type { Method, Parameter, Tree } from './RTD'
7
+ import type { Node, Method, Parameter, Tree, Match } from './RTD'
6
8
  import type { Label } from './discovery'
7
9
  import type { Branch } from './Branch'
8
10
 
@@ -28,15 +30,10 @@ export class Gateway extends Connector {
28
30
  if (interception !== null)
29
31
  return interception
30
32
 
31
- const match = this.tree.match(context.url.pathname)
32
-
33
- if (match === null)
34
- throw new http.NotFound()
33
+ const { node, parameters } = this.match(context)
35
34
 
36
- const {
37
- node,
38
- parameters
39
- } = match
35
+ if (context.request.method === 'OPTIONS')
36
+ return await this.explain(node, parameters)
40
37
 
41
38
  if (!(context.request.method in node.methods))
42
39
  throw new http.MethodNotAllowed()
@@ -44,12 +41,13 @@ export class Gateway extends Connector {
44
41
  const method = node.methods[context.request.method]
45
42
 
46
43
  const interruption = await context.timing.capture('preflight',
47
- method.directives.preflight(context, parameters))
44
+ method.directives.preflight(context, parameters)).catch(rethrow)
48
45
 
49
46
  const response = interruption ??
50
47
  await context.timing.capture('call', this.call(method, context, parameters))
51
48
 
52
- await context.timing.capture('settle', method.directives.settle(context, response))
49
+ await context.timing.capture('settle',
50
+ method.directives.settle(context, response)).catch(rethrow)
53
51
 
54
52
  return response
55
53
  }
@@ -57,17 +55,41 @@ export class Gateway extends Connector {
57
55
  protected override async open (): Promise<void> {
58
56
  await this.discover()
59
57
 
60
- console.info('Gateway has started and is awaiting resource branches.')
58
+ console.info('Gateway started')
61
59
  }
62
60
 
63
61
  protected override dispose (): void {
64
- console.info('Gateway is closed.')
62
+ console.info('Gateway is closed')
63
+ }
64
+
65
+ private match (context: http.Context): Match {
66
+ const match = this.tree.match(context.url.pathname)
67
+
68
+ if (match === null)
69
+ throw new http.NotFound('Route not found')
70
+
71
+ if (match.node.forward === null)
72
+ return match
73
+
74
+ const destination = match.node.forward.replace(/\/:([^/]+)/g,
75
+ (_, name) => {
76
+ const value = match.parameters.find((parameter) => parameter.name === name)?.value
77
+
78
+ assert.ok(value !== undefined, `Forwarded parameter '${name}' not found`)
79
+
80
+ return `/${value}`
81
+ })
82
+
83
+ const forward = this.tree.match(destination)
84
+
85
+ assert.ok(forward !== null, 'Forwarded route not found')
86
+
87
+ return forward
65
88
  }
66
89
 
67
- private async call (method: Method, context: http.Context, parameters: Parameter[]):
68
- Promise<http.OutgoingMessage> {
90
+ private async call (method: Method, context: http.Context, parameters: Parameter[]): Promise<http.OutgoingMessage> {
69
91
  if (context.url.pathname[context.url.pathname.length - 1] !== '/')
70
- throw new http.NotFound('Trailing slash is required.')
92
+ throw new http.NotFound('Trailing slash is required')
71
93
 
72
94
  if (context.encoder === null)
73
95
  throw new http.NotAcceptable()
@@ -80,6 +102,14 @@ export class Gateway extends Connector {
80
102
  .catch(rethrow) as http.OutgoingMessage
81
103
  }
82
104
 
105
+ private async explain (node: Node, parameters: Parameter[]): Promise<http.OutgoingMessage> {
106
+ const body = await node.explain(parameters)
107
+ const allow = [...Object.keys(node.methods)].join(', ')
108
+ const headers = new Headers({ allow })
109
+
110
+ return { body, headers }
111
+ }
112
+
83
113
  private async discover (): Promise<void> {
84
114
  await this.broadcast.receive<Branch>('expose', this.merge.bind(this))
85
115
  await this.broadcast.transmit<null>('ping', null)
@@ -89,10 +119,9 @@ export class Gateway extends Connector {
89
119
  try {
90
120
  this.tree.merge(branch.node, branch)
91
121
 
92
- console.info('Resource branch of ' +
93
- `'${branch.namespace}.${branch.component}' has been merged.`)
122
+ console.info('Branch merged', { source: branch.namespace + '.' + branch.component })
94
123
  } catch (exception) {
95
- console.error(exception)
124
+ console.error('Branch merge exception', exception as Error)
96
125
  }
97
126
  }
98
127
  }
@@ -1,4 +1,5 @@
1
1
  import Negotiator from 'negotiator'
2
+ import { console } from 'openspan'
2
3
  import { Timing } from './Timing'
3
4
  import { type Format, formats, types } from './formats'
4
5
  import { read } from './messages'
@@ -6,22 +7,29 @@ import type { OutgoingMessage } from './messages'
6
7
  import type * as http from 'node:http'
7
8
 
8
9
  export class Context {
10
+ public readonly authority: string
9
11
  public readonly request: IncomingMessage
10
12
  public readonly url: URL
11
13
  public readonly subtype: string | null = null
12
14
  public readonly encoder: Format | null = null
13
15
  public readonly timing: Timing
16
+ public readonly debug: boolean
14
17
 
15
18
  public readonly pipelines: Pipelines = {
16
19
  body: [],
17
20
  response: []
18
21
  }
19
22
 
20
- public constructor (request: IncomingMessage, trace = false) {
23
+ public constructor (authority: string, request: IncomingMessage, properties: Properties) {
24
+ this.authority = authority
21
25
  this.request = request
22
26
 
23
27
  this.url = new URL(request.url, `https://${request.headers.host}`)
24
- this.timing = new Timing(trace)
28
+ this.timing = new Timing(properties.trace)
29
+ this.debug = properties.debug
30
+
31
+ if (this.debug)
32
+ this.log(request)
25
33
 
26
34
  if (this.request.headers.accept !== undefined) {
27
35
  const match = SUBTYPE.exec(this.request.headers.accept)
@@ -52,6 +60,16 @@ export class Context {
52
60
  ? value
53
61
  : this.pipelines.body.reduce((value, transform) => transform(value), value)
54
62
  }
63
+
64
+ private log (request: IncomingMessage): void {
65
+ const headers = { ...request.headers }
66
+
67
+ if (headers.authorization !== undefined)
68
+ // only scheme
69
+ headers.authorization = headers.authorization.slice(0, headers.authorization.indexOf(' '))
70
+
71
+ console.debug('Received request', { method: request.method, url: request.url, headers })
72
+ }
55
73
  }
56
74
 
57
75
  export interface IncomingMessage extends http.IncomingMessage {
@@ -64,4 +82,9 @@ interface Pipelines {
64
82
  response: Array<(output: OutgoingMessage) => void>
65
83
  }
66
84
 
85
+ interface Properties {
86
+ debug: boolean
87
+ trace: boolean
88
+ }
89
+
67
90
  const SUBTYPE = /^(?<type>\w{1,32})\/(vnd\.toa\.(?<subtype>\S{1,32})\+)(?<suffix>\S{1,32})$/