@toa.io/extensions.exposition 1.0.0-alpha.11 → 1.0.0-alpha.111

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 (601) hide show
  1. package/components/context.toa.yaml +2 -2
  2. package/components/identity.bans/manifest.toa.yaml +14 -6
  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 +28 -10
  10. package/components/identity.basic/operations/authenticate.d.ts +5 -1
  11. package/components/identity.basic/operations/authenticate.js +7 -4
  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 +8 -6
  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 +18 -7
  22. package/components/identity.basic/source/incept.ts +38 -0
  23. package/components/identity.basic/source/transit.ts +11 -9
  24. package/components/identity.basic/source/types.ts +8 -4
  25. package/components/identity.federation/manifest.toa.yaml +61 -19
  26. package/components/identity.federation/operations/authenticate.d.ts +13 -2
  27. package/components/identity.federation/operations/authenticate.js +10 -11
  28. package/components/identity.federation/operations/authenticate.js.map +1 -1
  29. package/components/identity.federation/operations/decode.d.ts +2 -0
  30. package/{transpiled/directives/octets/Permute.js → components/identity.federation/operations/decode.js} +7 -32
  31. package/components/identity.federation/operations/decode.js.map +1 -0
  32. package/components/identity.federation/operations/incept.d.ts +11 -0
  33. package/components/identity.federation/operations/incept.js +14 -0
  34. package/components/identity.federation/operations/incept.js.map +1 -0
  35. package/components/identity.federation/operations/lib/assertions-as-values.js +4 -2
  36. package/components/identity.federation/operations/lib/assertions-as-values.js.map +1 -1
  37. package/components/identity.federation/operations/lib/get.d.ts +1 -0
  38. package/components/identity.federation/operations/lib/get.js +64 -0
  39. package/components/identity.federation/operations/lib/get.js.map +1 -0
  40. package/components/identity.federation/operations/lib/jwt.d.ts +4 -5
  41. package/components/identity.federation/operations/lib/jwt.js +20 -16
  42. package/components/identity.federation/operations/lib/jwt.js.map +1 -1
  43. package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -1
  44. package/components/identity.federation/operations/types/configuration.d.ts +15 -0
  45. package/components/identity.federation/operations/types/configuration.js +3 -0
  46. package/components/identity.federation/operations/types/configuration.js.map +1 -0
  47. package/components/identity.federation/operations/{types.d.ts → types/context.d.ts} +11 -12
  48. package/{transpiled/directives/vary/embeddings/Embedding.js → components/identity.federation/operations/types/context.js} +1 -1
  49. package/components/identity.federation/operations/types/context.js.map +1 -0
  50. package/components/identity.federation/operations/types/entity.d.ts +6 -0
  51. package/components/identity.federation/operations/types/entity.js +3 -0
  52. package/components/identity.federation/operations/types/entity.js.map +1 -0
  53. package/components/identity.federation/operations/types/index.d.ts +3 -0
  54. package/components/identity.federation/operations/types/index.js +20 -0
  55. package/components/identity.federation/operations/types/index.js.map +1 -0
  56. package/components/identity.federation/source/authenticate.ts +24 -17
  57. package/components/identity.federation/source/decode.ts +9 -0
  58. package/components/identity.federation/source/incept.ts +26 -0
  59. package/components/identity.federation/source/lib/assertions-as-values.ts +5 -2
  60. package/components/identity.federation/source/lib/get.ts +82 -0
  61. package/components/identity.federation/source/lib/jwt.test.ts +127 -4
  62. package/components/identity.federation/source/lib/jwt.ts +26 -19
  63. package/components/identity.federation/source/types/configuration.ts +16 -0
  64. package/components/identity.federation/source/{types.ts → types/context.ts} +12 -12
  65. package/components/identity.federation/source/types/entity.ts +6 -0
  66. package/components/identity.federation/source/types/index.ts +3 -0
  67. package/components/identity.federation/tsconfig.json +5 -4
  68. package/components/identity.keys/manifest.toa.yaml +54 -0
  69. package/components/identity.keys/operations/create.d.ts +22 -0
  70. package/components/identity.keys/operations/create.js +16 -0
  71. package/components/identity.keys/operations/create.js.map +1 -0
  72. package/components/identity.keys/operations/tsconfig.tsbuildinfo +1 -0
  73. package/components/identity.keys/source/create.ts +35 -0
  74. package/components/identity.keys/tsconfig.json +9 -0
  75. package/components/identity.roles/manifest.toa.yaml +9 -7
  76. package/components/identity.roles/operations/grant.d.ts +1 -1
  77. package/components/identity.roles/operations/grant.js +8 -7
  78. package/components/identity.roles/operations/grant.js.map +1 -1
  79. package/components/identity.roles/operations/lib/Entity.d.ts +1 -1
  80. package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -1
  81. package/components/identity.roles/source/grant.ts +9 -8
  82. package/components/identity.roles/source/lib/Entity.ts +1 -1
  83. package/components/identity.tokens/manifest.toa.yaml +103 -9
  84. package/components/identity.tokens/operations/authenticate.d.ts +3 -3
  85. package/components/identity.tokens/operations/authenticate.js +20 -13
  86. package/components/identity.tokens/operations/authenticate.js.map +1 -1
  87. package/components/identity.tokens/operations/decrypt.d.ts +12 -3
  88. package/components/identity.tokens/operations/decrypt.js +62 -17
  89. package/components/identity.tokens/operations/decrypt.js.map +1 -1
  90. package/components/identity.tokens/operations/encrypt.d.ts +3 -3
  91. package/components/identity.tokens/operations/encrypt.js +26 -6
  92. package/components/identity.tokens/operations/encrypt.js.map +1 -1
  93. package/components/identity.tokens/operations/issue.d.ts +24 -0
  94. package/components/identity.tokens/operations/issue.js +58 -0
  95. package/components/identity.tokens/operations/issue.js.map +1 -0
  96. package/components/identity.tokens/operations/lib/index.d.ts +2 -0
  97. package/components/identity.tokens/operations/lib/index.js +19 -0
  98. package/components/identity.tokens/operations/lib/index.js.map +1 -0
  99. package/components/identity.tokens/operations/lib/pad.d.ts +1 -0
  100. package/components/identity.tokens/operations/lib/pad.js +5 -0
  101. package/components/identity.tokens/operations/lib/pad.js.map +1 -0
  102. package/components/identity.tokens/operations/lib/types.d.ts +74 -0
  103. package/components/identity.tokens/operations/lib/types.js.map +1 -0
  104. package/components/identity.tokens/operations/revoke.d.ts +2 -2
  105. package/components/identity.tokens/operations/revoke.js.map +1 -1
  106. package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -1
  107. package/components/identity.tokens/receivers/identity.bans.created.js +3 -0
  108. package/components/identity.tokens/source/authenticate.test.ts +22 -9
  109. package/components/identity.tokens/source/authenticate.ts +23 -15
  110. package/components/identity.tokens/source/decrypt.test.ts +33 -18
  111. package/components/identity.tokens/source/decrypt.ts +91 -20
  112. package/components/identity.tokens/source/encrypt.test.ts +67 -12
  113. package/components/identity.tokens/source/encrypt.ts +37 -9
  114. package/components/identity.tokens/source/issue.ts +80 -0
  115. package/components/identity.tokens/source/lib/index.ts +2 -0
  116. package/components/identity.tokens/source/lib/pad.ts +1 -0
  117. package/components/identity.tokens/source/lib/paseto.test.ts +16 -0
  118. package/components/identity.tokens/source/lib/types.ts +85 -0
  119. package/components/identity.tokens/source/revoke.ts +2 -2
  120. package/components/octets.storage/manifest.toa.yaml +10 -11
  121. package/components/octets.storage/operations/get.js +3 -3
  122. package/components/octets.storage/operations/head.js +7 -0
  123. package/components/octets.storage/operations/put.js +132 -0
  124. package/documentation/access.md +91 -29
  125. package/documentation/authorities.md +48 -0
  126. package/documentation/cache.md +8 -1
  127. package/documentation/components.md +125 -54
  128. package/documentation/flow.md +44 -0
  129. package/documentation/identity.md +29 -22
  130. package/documentation/introspection.md +82 -0
  131. package/documentation/map.md +73 -0
  132. package/documentation/octets.md +100 -68
  133. package/documentation/protocol.md +14 -4
  134. package/documentation/query.md +29 -4
  135. package/documentation/require.md +15 -0
  136. package/documentation/tree.md +13 -0
  137. package/features/access.feature +129 -48
  138. package/features/annotation.feature +1 -0
  139. package/features/auth.claims.feature +171 -0
  140. package/features/auth.incept.feature +89 -0
  141. package/features/auth.input.feature +59 -0
  142. package/features/authorities.basic.feature +141 -0
  143. package/features/authorities.feature +32 -0
  144. package/features/authorities.federation.feature +100 -0
  145. package/features/authorities.tokens.feature +117 -0
  146. package/features/body.feature +2 -0
  147. package/features/cache.feature +109 -5
  148. package/features/cors.feature +8 -2
  149. package/features/debug.feature +34 -0
  150. package/features/directives.feature +3 -0
  151. package/features/dynamic.feature +48 -0
  152. package/features/errors.feature +32 -7
  153. package/features/etag.feature +109 -1
  154. package/features/flow.feature +96 -0
  155. package/features/identity.bans.feature +137 -0
  156. package/features/identity.basic.feature +85 -28
  157. package/features/identity.feature +18 -6
  158. package/features/identity.federation.feature +89 -18
  159. package/features/identity.roles.feature +112 -19
  160. package/features/identity.tokens.feature +13 -4
  161. package/features/identtiy.tokens.custom.feature +247 -0
  162. package/features/introspection.feature +153 -0
  163. package/features/io.feature +38 -1
  164. package/features/map.feature +305 -0
  165. package/features/methods.feature +47 -0
  166. package/features/octets.cloudinary.feature +68 -0
  167. package/features/octets.download.feature +189 -0
  168. package/features/octets.entries.feature +13 -55
  169. package/features/octets.feature +84 -108
  170. package/features/octets.head.feature +40 -0
  171. package/features/octets.meta.feature +65 -15
  172. package/features/octets.workflows.feature +242 -58
  173. package/features/probes.feature +14 -0
  174. package/features/{queries.feature → query.feature} +77 -2
  175. package/features/realtime.feature +34 -0
  176. package/features/require.feature +67 -0
  177. package/features/response.feature +38 -3
  178. package/features/routes.feature +93 -2
  179. package/features/server.feature +21 -0
  180. package/features/steps/.env.example +3 -0
  181. package/features/steps/Database.ts +16 -9
  182. package/features/steps/Gateway.ts +26 -7
  183. package/features/steps/IdP.ts +63 -25
  184. package/features/steps/Parameters.ts +44 -1
  185. package/features/steps/Realtime.ts +151 -0
  186. package/features/steps/components/echo/manifest.toa.yaml +14 -1
  187. package/features/steps/components/echo/operations/identity.js +7 -0
  188. package/features/steps/components/echo/operations/parameters.js +7 -0
  189. package/features/steps/components/echo.beacon/manifest.toa.yaml +2 -0
  190. package/features/steps/components/echo.beacon/operations/hello.js +5 -0
  191. package/features/steps/components/greeter/manifest.toa.yaml +0 -1
  192. package/features/steps/components/octets.tester/manifest.toa.yaml +22 -3
  193. package/features/steps/components/octets.tester/operations/authority.js +7 -0
  194. package/features/steps/components/octets.tester/operations/bar.js +0 -1
  195. package/features/steps/components/octets.tester/operations/baz.js +0 -2
  196. package/features/steps/components/octets.tester/operations/foo.js +1 -2
  197. package/features/steps/components/octets.tester/operations/redirect.js +12 -0
  198. package/features/steps/components/octets.tester/operations/yex.js +16 -0
  199. package/features/steps/components/octets.tester/operations/yield.js +13 -0
  200. package/features/steps/components/pots/manifest.toa.yaml +12 -4
  201. package/features/steps/components/sequences/manifest.toa.yaml +0 -1
  202. package/features/steps/components/users/manifest.toa.yaml +4 -3
  203. package/features/steps/components/users/operations/create.js +15 -0
  204. package/features/steps/components/users.properties/manifest.toa.yaml +1 -2
  205. package/features/streams.feature +5 -0
  206. package/features/timestamps.feature +41 -0
  207. package/features/timing.feature +4 -1
  208. package/package.json +25 -13
  209. package/readme.md +19 -14
  210. package/schemas/annotation.cos.yaml +1 -1
  211. package/schemas/method.cos.yaml +1 -1
  212. package/schemas/node.cos.yaml +2 -0
  213. package/schemas/octets/put.cos.yaml +25 -0
  214. package/schemas/query.cos.yaml +4 -10
  215. package/source/Annotation.ts +3 -3
  216. package/source/Branch.ts +1 -0
  217. package/source/Composition.ts +0 -6
  218. package/source/Context.ts +1 -0
  219. package/source/Directive.test.ts +1 -1
  220. package/source/Directive.ts +7 -6
  221. package/source/Endpoint.ts +69 -17
  222. package/source/Factory.ts +22 -13
  223. package/source/Gateway.ts +73 -19
  224. package/source/HTTP/Context.ts +31 -7
  225. package/source/HTTP/Server.ts +61 -47
  226. package/source/HTTP/exceptions.ts +13 -1
  227. package/source/HTTP/formats/index.ts +3 -3
  228. package/source/HTTP/messages.test.ts +45 -2
  229. package/source/HTTP/messages.ts +34 -8
  230. package/source/Introspection.ts +11 -0
  231. package/source/Mapping.ts +68 -21
  232. package/source/Query.test.ts +3 -3
  233. package/source/Query.ts +123 -33
  234. package/source/RTD/Context.ts +1 -1
  235. package/source/RTD/Endpoint.ts +3 -0
  236. package/source/RTD/Method.ts +16 -0
  237. package/source/RTD/Node.ts +29 -13
  238. package/source/RTD/Route.ts +5 -4
  239. package/source/RTD/Tree.ts +2 -2
  240. package/source/RTD/factory.ts +5 -2
  241. package/source/RTD/syntax/parse.test.ts +1 -1
  242. package/source/RTD/syntax/parse.ts +37 -24
  243. package/source/RTD/syntax/types.ts +6 -4
  244. package/source/Remotes.ts +7 -6
  245. package/source/Tenant.ts +6 -20
  246. package/source/deployment.ts +33 -23
  247. package/source/directives/auth/Anonymous.ts +3 -3
  248. package/source/directives/auth/Anyone.ts +13 -0
  249. package/source/directives/auth/Authorization.ts +65 -25
  250. package/source/directives/auth/Delegate.ts +13 -6
  251. package/source/directives/auth/Echo.ts +16 -6
  252. package/source/directives/auth/Federation.ts +84 -0
  253. package/source/directives/auth/Id.ts +1 -1
  254. package/source/directives/auth/Incept.ts +27 -12
  255. package/source/directives/auth/Input.ts +72 -0
  256. package/source/directives/auth/Role.test.ts +53 -6
  257. package/source/directives/auth/Role.ts +23 -19
  258. package/source/directives/auth/Rule.ts +3 -5
  259. package/source/directives/auth/Scheme.ts +5 -5
  260. package/source/directives/auth/create.ts +10 -0
  261. package/source/directives/auth/split.ts +1 -1
  262. package/source/directives/auth/types.ts +11 -6
  263. package/source/directives/cache/Cache.ts +13 -6
  264. package/source/directives/cache/Control.ts +42 -16
  265. package/source/directives/cors/CORS.ts +3 -2
  266. package/source/directives/dev/Development.ts +1 -1
  267. package/source/directives/flow/Compose.ts +68 -0
  268. package/source/directives/flow/Fetch.ts +86 -0
  269. package/source/directives/flow/Flow.ts +42 -0
  270. package/source/directives/flow/index.ts +3 -0
  271. package/source/directives/flow/types.ts +7 -0
  272. package/source/directives/index.ts +4 -2
  273. package/source/directives/io/IO.ts +1 -1
  274. package/source/directives/io/Input.ts +8 -5
  275. package/source/directives/io/Output.ts +5 -4
  276. package/source/directives/map/Authority.ts +15 -0
  277. package/source/directives/map/Claims.ts +58 -0
  278. package/source/directives/map/Directive.ts +4 -0
  279. package/source/directives/map/Headers.ts +38 -0
  280. package/source/directives/map/Language.ts +42 -0
  281. package/source/directives/map/Languages.ts +11 -0
  282. package/source/directives/map/Map.ts +61 -0
  283. package/source/directives/map/Mapping.ts +19 -0
  284. package/source/directives/{vary → map}/Properties.ts +2 -4
  285. package/source/directives/map/Segments.ts +26 -0
  286. package/source/directives/map/index.ts +3 -0
  287. package/source/directives/octets/Context.ts +3 -2
  288. package/source/directives/octets/Delete.ts +11 -11
  289. package/source/directives/octets/Get.ts +86 -0
  290. package/source/directives/octets/Octets.ts +9 -12
  291. package/source/directives/octets/{Store.ts → Put.ts} +36 -36
  292. package/source/directives/octets/Workflow.ts +1 -1
  293. package/source/directives/octets/bytes.test.ts +30 -0
  294. package/source/directives/octets/bytes.ts +18 -0
  295. package/source/directives/octets/schemas.ts +4 -8
  296. package/source/directives/octets/workflows/Execution.ts +60 -8
  297. package/source/directives/octets/workflows/Workflow.ts +4 -4
  298. package/source/directives/require/Directive.ts +5 -0
  299. package/source/directives/require/Headers.ts +20 -0
  300. package/source/directives/require/Require.ts +28 -0
  301. package/source/directives/require/index.ts +3 -0
  302. package/source/exceptions.ts +14 -6
  303. package/source/manifest.ts +10 -11
  304. package/source/root.ts +16 -1
  305. package/source/schemas.ts +1 -1
  306. package/transpiled/Annotation.d.ts +3 -3
  307. package/transpiled/Branch.d.ts +1 -0
  308. package/transpiled/Composition.d.ts +0 -1
  309. package/transpiled/Composition.js +0 -4
  310. package/transpiled/Composition.js.map +1 -1
  311. package/transpiled/Context.d.ts +1 -0
  312. package/transpiled/Directive.js +7 -5
  313. package/transpiled/Directive.js.map +1 -1
  314. package/transpiled/Endpoint.d.ts +6 -4
  315. package/transpiled/Endpoint.js +47 -9
  316. package/transpiled/Endpoint.js.map +1 -1
  317. package/transpiled/Factory.d.ts +3 -2
  318. package/transpiled/Factory.js +18 -10
  319. package/transpiled/Factory.js.map +1 -1
  320. package/transpiled/Gateway.d.ts +3 -0
  321. package/transpiled/Gateway.js +55 -12
  322. package/transpiled/Gateway.js.map +1 -1
  323. package/transpiled/HTTP/Context.d.ts +9 -2
  324. package/transpiled/HTTP/Context.js +20 -6
  325. package/transpiled/HTTP/Context.js.map +1 -1
  326. package/transpiled/HTTP/Server.d.ts +13 -2
  327. package/transpiled/HTTP/Server.js +47 -40
  328. package/transpiled/HTTP/Server.js.map +1 -1
  329. package/transpiled/HTTP/exceptions.d.ts +7 -1
  330. package/transpiled/HTTP/exceptions.js +13 -1
  331. package/transpiled/HTTP/exceptions.js.map +1 -1
  332. package/transpiled/HTTP/formats/index.js +3 -3
  333. package/transpiled/HTTP/formats/index.js.map +1 -1
  334. package/transpiled/HTTP/messages.d.ts +2 -1
  335. package/transpiled/HTTP/messages.js +32 -7
  336. package/transpiled/HTTP/messages.js.map +1 -1
  337. package/transpiled/Introspection.d.ts +9 -0
  338. package/transpiled/Introspection.js +3 -0
  339. package/transpiled/Introspection.js.map +1 -0
  340. package/transpiled/Mapping.d.ts +11 -2
  341. package/transpiled/Mapping.js +50 -19
  342. package/transpiled/Mapping.js.map +1 -1
  343. package/transpiled/Query.d.ts +10 -1
  344. package/transpiled/Query.js +87 -30
  345. package/transpiled/Query.js.map +1 -1
  346. package/transpiled/RTD/Context.d.ts +1 -1
  347. package/transpiled/RTD/Endpoint.d.ts +1 -0
  348. package/transpiled/RTD/Method.d.ts +4 -0
  349. package/transpiled/RTD/Method.js +11 -0
  350. package/transpiled/RTD/Method.js.map +1 -1
  351. package/transpiled/RTD/Node.d.ts +4 -1
  352. package/transpiled/RTD/Node.js +23 -12
  353. package/transpiled/RTD/Node.js.map +1 -1
  354. package/transpiled/RTD/Route.d.ts +1 -1
  355. package/transpiled/RTD/Route.js +0 -1
  356. package/transpiled/RTD/Route.js.map +1 -1
  357. package/transpiled/RTD/Tree.d.ts +1 -1
  358. package/transpiled/RTD/Tree.js.map +1 -1
  359. package/transpiled/RTD/factory.js +5 -2
  360. package/transpiled/RTD/factory.js.map +1 -1
  361. package/transpiled/RTD/syntax/parse.js +34 -22
  362. package/transpiled/RTD/syntax/parse.js.map +1 -1
  363. package/transpiled/RTD/syntax/types.d.ts +5 -3
  364. package/transpiled/RTD/syntax/types.js +1 -1
  365. package/transpiled/RTD/syntax/types.js.map +1 -1
  366. package/transpiled/Remotes.d.ts +4 -4
  367. package/transpiled/Remotes.js +6 -5
  368. package/transpiled/Remotes.js.map +1 -1
  369. package/transpiled/Tenant.d.ts +5 -5
  370. package/transpiled/Tenant.js +2 -13
  371. package/transpiled/Tenant.js.map +1 -1
  372. package/transpiled/deployment.d.ts +1 -1
  373. package/transpiled/deployment.js +28 -20
  374. package/transpiled/deployment.js.map +1 -1
  375. package/transpiled/directives/auth/Anonymous.d.ts +2 -2
  376. package/transpiled/directives/auth/Anonymous.js +2 -2
  377. package/transpiled/directives/auth/Anonymous.js.map +1 -1
  378. package/transpiled/directives/auth/Anyone.d.ts +6 -0
  379. package/transpiled/directives/auth/Anyone.js +14 -0
  380. package/transpiled/directives/auth/Anyone.js.map +1 -0
  381. package/transpiled/directives/auth/Authorization.d.ts +4 -3
  382. package/transpiled/directives/auth/Authorization.js +49 -22
  383. package/transpiled/directives/auth/Authorization.js.map +1 -1
  384. package/transpiled/directives/auth/Delegate.d.ts +5 -4
  385. package/transpiled/directives/auth/Delegate.js +10 -4
  386. package/transpiled/directives/auth/Delegate.js.map +1 -1
  387. package/transpiled/directives/auth/Echo.d.ts +4 -4
  388. package/transpiled/directives/auth/Echo.js +11 -4
  389. package/transpiled/directives/auth/Echo.js.map +1 -1
  390. package/transpiled/directives/auth/Federation.d.ts +16 -0
  391. package/transpiled/directives/auth/Federation.js +57 -0
  392. package/transpiled/directives/auth/Federation.js.map +1 -0
  393. package/transpiled/directives/auth/Id.d.ts +1 -1
  394. package/transpiled/directives/auth/Id.js.map +1 -1
  395. package/transpiled/directives/auth/Incept.d.ts +4 -3
  396. package/transpiled/directives/auth/Incept.js +23 -10
  397. package/transpiled/directives/auth/Incept.js.map +1 -1
  398. package/transpiled/directives/auth/Input.d.ts +14 -0
  399. package/transpiled/directives/auth/Input.js +49 -0
  400. package/transpiled/directives/auth/Input.js.map +1 -0
  401. package/transpiled/directives/auth/Role.d.ts +5 -2
  402. package/transpiled/directives/auth/Role.js +22 -18
  403. package/transpiled/directives/auth/Role.js.map +1 -1
  404. package/transpiled/directives/auth/Rule.d.ts +2 -4
  405. package/transpiled/directives/auth/Rule.js +2 -2
  406. package/transpiled/directives/auth/Rule.js.map +1 -1
  407. package/transpiled/directives/auth/Scheme.d.ts +2 -2
  408. package/transpiled/directives/auth/Scheme.js +4 -4
  409. package/transpiled/directives/auth/Scheme.js.map +1 -1
  410. package/transpiled/directives/auth/create.d.ts +2 -0
  411. package/transpiled/directives/auth/create.js +12 -0
  412. package/transpiled/directives/auth/create.js.map +1 -0
  413. package/transpiled/directives/auth/split.js +1 -1
  414. package/transpiled/directives/auth/split.js.map +1 -1
  415. package/transpiled/directives/auth/types.d.ts +8 -5
  416. package/transpiled/directives/cache/Cache.d.ts +3 -3
  417. package/transpiled/directives/cache/Cache.js +10 -4
  418. package/transpiled/directives/cache/Cache.js.map +1 -1
  419. package/transpiled/directives/cache/Control.d.ts +2 -1
  420. package/transpiled/directives/cache/Control.js +29 -12
  421. package/transpiled/directives/cache/Control.js.map +1 -1
  422. package/transpiled/directives/cors/CORS.js +3 -2
  423. package/transpiled/directives/cors/CORS.js.map +1 -1
  424. package/transpiled/directives/dev/Development.js +1 -1
  425. package/transpiled/directives/dev/Development.js.map +1 -1
  426. package/transpiled/directives/flow/Compose.d.ts +8 -0
  427. package/transpiled/directives/flow/Compose.js +74 -0
  428. package/transpiled/directives/flow/Compose.js.map +1 -0
  429. package/transpiled/directives/flow/Fetch.d.ts +12 -0
  430. package/transpiled/directives/flow/Fetch.js +58 -0
  431. package/transpiled/directives/flow/Fetch.js.map +1 -0
  432. package/transpiled/directives/flow/Flow.d.ts +10 -0
  433. package/transpiled/directives/flow/Flow.js +33 -0
  434. package/transpiled/directives/flow/Flow.js.map +1 -0
  435. package/transpiled/directives/flow/index.d.ts +2 -0
  436. package/transpiled/directives/flow/index.js +6 -0
  437. package/transpiled/directives/flow/index.js.map +1 -0
  438. package/transpiled/directives/flow/types.d.ts +6 -0
  439. package/transpiled/directives/flow/types.js.map +1 -0
  440. package/transpiled/directives/index.js +4 -2
  441. package/transpiled/directives/index.js.map +1 -1
  442. package/transpiled/directives/io/IO.js +1 -1
  443. package/transpiled/directives/io/IO.js.map +1 -1
  444. package/transpiled/directives/io/Input.js +4 -2
  445. package/transpiled/directives/io/Input.js.map +1 -1
  446. package/transpiled/directives/io/Output.js +2 -2
  447. package/transpiled/directives/io/Output.js.map +1 -1
  448. package/transpiled/directives/map/Authority.d.ts +6 -0
  449. package/transpiled/directives/map/Authority.js +19 -0
  450. package/transpiled/directives/map/Authority.js.map +1 -0
  451. package/transpiled/directives/map/Claims.d.ts +10 -0
  452. package/transpiled/directives/map/Claims.js +44 -0
  453. package/transpiled/directives/map/Claims.js.map +1 -0
  454. package/transpiled/directives/map/Directive.d.ts +3 -0
  455. package/transpiled/directives/map/Directive.js.map +1 -0
  456. package/transpiled/directives/map/Headers.d.ts +7 -0
  457. package/transpiled/directives/map/Headers.js +34 -0
  458. package/transpiled/directives/map/Headers.js.map +1 -0
  459. package/transpiled/directives/map/Language.d.ts +10 -0
  460. package/transpiled/directives/map/Language.js +38 -0
  461. package/transpiled/directives/map/Language.js.map +1 -0
  462. package/transpiled/directives/map/Languages.d.ts +4 -0
  463. package/transpiled/directives/map/Languages.js +17 -0
  464. package/transpiled/directives/map/Languages.js.map +1 -0
  465. package/transpiled/directives/map/Map.d.ts +13 -0
  466. package/transpiled/directives/map/Map.js +46 -0
  467. package/transpiled/directives/map/Map.js.map +1 -0
  468. package/transpiled/directives/map/Mapping.d.ts +13 -0
  469. package/transpiled/directives/map/Mapping.js +13 -0
  470. package/transpiled/directives/map/Mapping.js.map +1 -0
  471. package/transpiled/directives/{vary → map}/Properties.d.ts +2 -2
  472. package/transpiled/directives/{vary → map}/Properties.js +1 -3
  473. package/transpiled/directives/map/Properties.js.map +1 -0
  474. package/transpiled/directives/map/Segments.d.ts +6 -0
  475. package/transpiled/directives/map/Segments.js +25 -0
  476. package/transpiled/directives/map/Segments.js.map +1 -0
  477. package/transpiled/directives/map/index.d.ts +2 -0
  478. package/transpiled/directives/map/index.js +6 -0
  479. package/transpiled/directives/map/index.js.map +1 -0
  480. package/transpiled/directives/octets/Context.js +4 -24
  481. package/transpiled/directives/octets/Context.js.map +1 -1
  482. package/transpiled/directives/octets/Delete.js +8 -8
  483. package/transpiled/directives/octets/Delete.js.map +1 -1
  484. package/transpiled/directives/octets/{Fetch.d.ts → Get.d.ts} +5 -6
  485. package/transpiled/directives/octets/{Fetch.js → Get.js} +25 -29
  486. package/transpiled/directives/octets/Get.js.map +1 -0
  487. package/transpiled/directives/octets/Octets.js +9 -12
  488. package/transpiled/directives/octets/Octets.js.map +1 -1
  489. package/transpiled/directives/octets/{Store.d.ts → Put.d.ts} +6 -2
  490. package/transpiled/directives/octets/{Store.js → Put.js} +22 -26
  491. package/transpiled/directives/octets/Put.js.map +1 -0
  492. package/transpiled/directives/octets/Workflow.js +1 -1
  493. package/transpiled/directives/octets/Workflow.js.map +1 -1
  494. package/transpiled/directives/octets/bytes.d.ts +1 -0
  495. package/transpiled/directives/octets/bytes.js +21 -0
  496. package/transpiled/directives/octets/bytes.js.map +1 -0
  497. package/transpiled/directives/octets/schemas.d.ts +4 -8
  498. package/transpiled/directives/octets/schemas.js +3 -6
  499. package/transpiled/directives/octets/schemas.js.map +1 -1
  500. package/transpiled/directives/octets/workflows/Execution.d.ts +5 -1
  501. package/transpiled/directives/octets/workflows/Execution.js +44 -9
  502. package/transpiled/directives/octets/workflows/Execution.js.map +1 -1
  503. package/transpiled/directives/octets/workflows/Workflow.d.ts +1 -1
  504. package/transpiled/directives/octets/workflows/Workflow.js +2 -1
  505. package/transpiled/directives/octets/workflows/Workflow.js.map +1 -1
  506. package/transpiled/directives/require/Directive.d.ts +4 -0
  507. package/transpiled/directives/require/Directive.js +3 -0
  508. package/transpiled/directives/require/Directive.js.map +1 -0
  509. package/transpiled/directives/require/Headers.d.ts +7 -0
  510. package/transpiled/directives/require/Headers.js +19 -0
  511. package/transpiled/directives/require/Headers.js.map +1 -0
  512. package/transpiled/directives/require/Require.d.ts +9 -0
  513. package/transpiled/directives/require/Require.js +27 -0
  514. package/transpiled/directives/require/Require.js.map +1 -0
  515. package/transpiled/directives/require/index.d.ts +2 -0
  516. package/transpiled/directives/require/index.js +6 -0
  517. package/transpiled/directives/require/index.js.map +1 -0
  518. package/transpiled/exceptions.d.ts +3 -2
  519. package/transpiled/exceptions.js +8 -1
  520. package/transpiled/exceptions.js.map +1 -1
  521. package/transpiled/manifest.js +10 -11
  522. package/transpiled/manifest.js.map +1 -1
  523. package/transpiled/root.js +16 -1
  524. package/transpiled/root.js.map +1 -1
  525. package/transpiled/schemas.d.ts +1 -1
  526. package/transpiled/schemas.js +2 -2
  527. package/transpiled/schemas.js.map +1 -1
  528. package/transpiled/tsconfig.tsbuildinfo +1 -1
  529. package/components/identity.basic/operations/create.d.ts +0 -10
  530. package/components/identity.basic/operations/create.js +0 -10
  531. package/components/identity.basic/operations/create.js.map +0 -1
  532. package/components/identity.basic/source/create.ts +0 -18
  533. package/components/identity.federation/operations/create.d.ts +0 -10
  534. package/components/identity.federation/operations/create.js +0 -15
  535. package/components/identity.federation/operations/create.js.map +0 -1
  536. package/components/identity.federation/operations/schemas.d.ts +0 -59
  537. package/components/identity.federation/operations/schemas.js +0 -9
  538. package/components/identity.federation/operations/schemas.js.map +0 -1
  539. package/components/identity.federation/operations/types.js.map +0 -1
  540. package/components/identity.federation/source/create.ts +0 -26
  541. package/components/identity.federation/source/schemas.ts +0 -61
  542. package/components/identity.tokens/operations/types.d.ts +0 -40
  543. package/components/identity.tokens/operations/types.js.map +0 -1
  544. package/components/identity.tokens/source/types.ts +0 -48
  545. package/components/octets.storage/operations/fetch.js +0 -46
  546. package/components/octets.storage/operations/list.js +0 -7
  547. package/components/octets.storage/operations/permute.js +0 -7
  548. package/components/octets.storage/operations/store.js +0 -11
  549. package/documentation/vary.md +0 -69
  550. package/features/steps/components/octets.tester/operations/diversify.js +0 -14
  551. package/features/vary.feature +0 -180
  552. package/schemas/octets/context.cos.yaml +0 -1
  553. package/schemas/octets/fetch.cos.yaml +0 -3
  554. package/schemas/octets/permute.cos.yaml +0 -1
  555. package/schemas/octets/store.cos.yaml +0 -3
  556. package/source/HTTP/Server.test.ts +0 -126
  557. package/source/directives/octets/Fetch.ts +0 -100
  558. package/source/directives/octets/List.ts +0 -72
  559. package/source/directives/octets/Permute.ts +0 -44
  560. package/source/directives/vary/Directive.ts +0 -6
  561. package/source/directives/vary/Embed.ts +0 -62
  562. package/source/directives/vary/Vary.ts +0 -48
  563. package/source/directives/vary/embeddings/Embedding.ts +0 -6
  564. package/source/directives/vary/embeddings/Header.ts +0 -32
  565. package/source/directives/vary/embeddings/Language.ts +0 -31
  566. package/source/directives/vary/embeddings/index.ts +0 -11
  567. package/source/directives/vary/index.ts +0 -3
  568. package/transpiled/directives/octets/Fetch.js.map +0 -1
  569. package/transpiled/directives/octets/List.d.ts +0 -16
  570. package/transpiled/directives/octets/List.js +0 -74
  571. package/transpiled/directives/octets/List.js.map +0 -1
  572. package/transpiled/directives/octets/Permute.d.ts +0 -11
  573. package/transpiled/directives/octets/Permute.js.map +0 -1
  574. package/transpiled/directives/octets/Store.js.map +0 -1
  575. package/transpiled/directives/vary/Directive.d.ts +0 -5
  576. package/transpiled/directives/vary/Directive.js.map +0 -1
  577. package/transpiled/directives/vary/Embed.d.ts +0 -10
  578. package/transpiled/directives/vary/Embed.js +0 -49
  579. package/transpiled/directives/vary/Embed.js.map +0 -1
  580. package/transpiled/directives/vary/Properties.js.map +0 -1
  581. package/transpiled/directives/vary/Vary.d.ts +0 -10
  582. package/transpiled/directives/vary/Vary.js +0 -36
  583. package/transpiled/directives/vary/Vary.js.map +0 -1
  584. package/transpiled/directives/vary/embeddings/Embedding.d.ts +0 -5
  585. package/transpiled/directives/vary/embeddings/Embedding.js.map +0 -1
  586. package/transpiled/directives/vary/embeddings/Header.d.ts +0 -7
  587. package/transpiled/directives/vary/embeddings/Header.js +0 -28
  588. package/transpiled/directives/vary/embeddings/Header.js.map +0 -1
  589. package/transpiled/directives/vary/embeddings/Language.d.ts +0 -7
  590. package/transpiled/directives/vary/embeddings/Language.js +0 -28
  591. package/transpiled/directives/vary/embeddings/Language.js.map +0 -1
  592. package/transpiled/directives/vary/embeddings/index.d.ts +0 -5
  593. package/transpiled/directives/vary/embeddings/index.js +0 -10
  594. package/transpiled/directives/vary/embeddings/index.js.map +0 -1
  595. package/transpiled/directives/vary/index.d.ts +0 -2
  596. package/transpiled/directives/vary/index.js +0 -6
  597. package/transpiled/directives/vary/index.js.map +0 -1
  598. /package/components/{identity.federation/operations → identity.tokens/operations/lib}/types.js +0 -0
  599. /package/schemas/octets/{list.cos.yaml → get.cos.yaml} +0 -0
  600. /package/{components/identity.tokens/operations → transpiled/directives/flow}/types.js +0 -0
  601. /package/transpiled/directives/{vary → map}/Directive.js +0 -0
@@ -1,6 +1,7 @@
1
1
  export interface Node {
2
2
  protected?: boolean
3
3
  isolated?: boolean
4
+ forward?: string
4
5
  routes: Route[]
5
6
  methods: Method[]
6
7
  directives: Directive[]
@@ -27,17 +28,18 @@ export interface Mapping {
27
28
  namespace?: string
28
29
  component?: string
29
30
  endpoint: string
30
- query?: Query
31
+ query?: Query | null
31
32
  }
32
33
 
33
34
  export interface Query {
34
35
  id?: string
35
36
  criteria?: string
36
37
  sort?: string
37
- omit: Range
38
- limit: Range
38
+ omit?: Range
39
+ limit?: Range
39
40
  selectors?: string[]
40
41
  projection?: string[]
42
+ parameters?: string[]
41
43
  }
42
44
 
43
45
  export interface Range {
@@ -45,4 +47,4 @@ export interface Range {
45
47
  range: [number, number]
46
48
  }
47
49
 
48
- export const verbs = new Set<string>(['GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'OPTIONS'])
50
+ export const verbs = new Set<string>(['GET', 'HEAD', 'POST', 'PUT', 'PATCH', 'DELETE', 'LOCK', 'UNLOCK'])
package/source/Remotes.ts CHANGED
@@ -1,24 +1,25 @@
1
- import { Locator, Connector, type Component } from '@toa.io/core'
1
+ import { Locator, Connector, type Remote } from '@toa.io/core'
2
2
  import { type Bootloader } from './Factory'
3
3
 
4
4
  export class Remotes extends Connector {
5
5
  private readonly boot: Bootloader
6
- private readonly remotes: Record<string, Promise<Component>> = {}
6
+ private readonly cache: Record<string, Promise<Remote>> = {}
7
7
 
8
8
  public constructor (boot: Bootloader) {
9
9
  super()
10
10
  this.boot = boot
11
11
  }
12
12
 
13
- public async discover (namespace: string, name: string): Promise<Component> {
13
+ public async discover (namespace: string, name: string, version: string = 'local'): Promise<Remote> {
14
14
  const locator = new Locator(name, namespace)
15
+ const key = locator.id + ':' + version
15
16
 
16
- this.remotes[locator.id] ??= this.create(locator)
17
+ this.cache[key] ??= this.locate(locator)
17
18
 
18
- return await this.remotes[locator.id]
19
+ return this.cache[key]
19
20
  }
20
21
 
21
- private async create (locator: Locator): Promise<Component> {
22
+ private async locate (locator: Locator): Promise<Remote> {
22
23
  const remote = await this.boot.remote(locator)
23
24
 
24
25
  this.depends(remote)
package/source/Tenant.ts CHANGED
@@ -1,23 +1,17 @@
1
- import { Connector, type Locator, type bindings } from '@toa.io/core'
2
- import { type Label } from './discovery'
3
- import { type Branch } from './Branch'
4
- import type * as RTD from './RTD/syntax'
1
+ import { Connector } from '@toa.io/core'
2
+ import type { bindings } from '@toa.io/core'
3
+ import type { Label } from './discovery'
4
+ import type { Branch } from './Branch'
5
5
 
6
6
  export class Tenant extends Connector {
7
7
  private readonly broadcast: Broadcast
8
8
  private readonly branch: Branch
9
9
 
10
- public constructor (broadcast: Broadcast, locator: Locator, node: RTD.Node) {
10
+ public constructor (broadcast: Broadcast, branch: Branch) {
11
11
  super()
12
12
 
13
13
  this.broadcast = broadcast
14
-
15
- this.branch = {
16
- namespace: locator.namespace,
17
- component: locator.name,
18
- isolated: locator.namespace === 'identity',
19
- node
20
- }
14
+ this.branch = branch
21
15
 
22
16
  this.depends(broadcast)
23
17
  }
@@ -25,14 +19,6 @@ export class Tenant extends Connector {
25
19
  public override async open (): Promise<void> {
26
20
  await this.expose()
27
21
  await this.broadcast.receive('ping', this.expose.bind(this))
28
-
29
- console.info('Exposition Tenant for ' +
30
- `'${this.branch.namespace}.${this.branch.component}' has started.`)
31
- }
32
-
33
- public override async dispose (): Promise<void> {
34
- console.info('Exposition Tenant for ' +
35
- `'${this.branch.namespace}.${this.branch.component}' has been stopped.`)
36
22
  }
37
23
 
38
24
  private async expose (): Promise<void> {
@@ -1,3 +1,4 @@
1
+ import assert from 'node:assert'
1
2
  import { type Dependency, type Service } from '@toa.io/operations'
2
3
  import { encode } from '@toa.io/generic'
3
4
  import { type Annotation } from './Annotation'
@@ -5,50 +6,59 @@ import * as schemas from './schemas'
5
6
  import { shortcuts } from './Directive'
6
7
  import { components } from './Composition'
7
8
  import { parse } from './RTD/syntax'
9
+ import { DELAY, PORT } from './HTTP'
10
+
11
+ export function deployment (_: unknown, annotation?: Annotation): Dependency {
12
+ assert.ok(annotation !== undefined, 'Exposition context annotation is required')
13
+ schemas.annotation.validate(annotation)
8
14
 
9
- export function deployment (_: unknown, annotation: Annotation | undefined): Dependency {
10
15
  const labels = components().labels
11
16
 
12
17
  const service: Service = {
13
18
  group: 'exposition',
14
19
  name: 'gateway',
15
- port: 8000,
20
+ port: PORT,
16
21
  // eslint-disable-next-line @typescript-eslint/no-var-requires
17
22
  version: require('../package.json').version,
18
23
  variables: [],
19
- components: labels
20
- }
21
-
22
- if (annotation?.host !== undefined)
23
- service.ingress = {
24
- host: annotation.host,
25
- class: annotation.class,
26
- annotations: annotation.annotations
24
+ components: labels,
25
+ ingress: { default: true, hosts: [] },
26
+ probe: {
27
+ path: '/.ready',
28
+ port: PORT,
29
+ delay: DELAY
27
30
  }
31
+ }
28
32
 
29
33
  if (annotation?.['/'] !== undefined) {
30
34
  const tree = parse(annotation['/'], shortcuts)
31
35
 
32
- service.variables.push({
36
+ service.variables!.push({
33
37
  name: 'TOA_EXPOSITION',
34
38
  value: encode(tree)
35
39
  })
36
40
  }
37
41
 
38
- if (annotation?.debug === true)
39
- service.variables.push({
40
- name: 'TOA_EXPOSITION_DEBUG',
41
- value: '1'
42
- })
42
+ const { debug, trace, authorities } = annotation
43
43
 
44
- if (annotation?.trace === true)
45
- service.variables.push({
46
- name: 'TOA_EXPOSITION_TRACE',
47
- value: '1'
48
- })
44
+ service.ingress!.hosts = Object.values(authorities)
45
+ service.ingress!.class = annotation.class
46
+ service.ingress!.annotations = annotation.annotations
47
+
48
+ const properties: Properties = { authorities }
49
+
50
+ if (debug === true)
51
+ properties.debug = true
49
52
 
50
- if (annotation !== undefined)
51
- schemas.annotaion.validate(annotation)
53
+ if (trace === true)
54
+ properties.trace = true
55
+
56
+ service.variables!.push({
57
+ name: 'TOA_EXPOSITION_PROPERTIES',
58
+ value: encode(properties)
59
+ })
52
60
 
53
61
  return { services: [service] }
54
62
  }
63
+
64
+ type Properties = Pick<Annotation, 'authorities' | 'debug' | 'trace'>
@@ -1,4 +1,4 @@
1
- import { type Directive, type Input } from './types'
1
+ import { type Directive, type Context } from './types'
2
2
 
3
3
  export class Anonymous implements Directive {
4
4
  private readonly allow: boolean
@@ -7,8 +7,8 @@ export class Anonymous implements Directive {
7
7
  this.allow = allow
8
8
  }
9
9
 
10
- public authorize (_: any, input: Input): boolean {
11
- return 'authorization' in input.request.headers
10
+ public authorize (_: any, context: Context): boolean {
11
+ return 'authorization' in context.request.headers
12
12
  ? false
13
13
  : this.allow
14
14
  }
@@ -0,0 +1,13 @@
1
+ import { type Directive, type Context } from './types'
2
+
3
+ export class Anyone implements Directive {
4
+ private readonly allow: boolean
5
+
6
+ public constructor (allow: boolean) {
7
+ this.allow = allow
8
+ }
9
+
10
+ public authorize (_: any, context: Context): boolean {
11
+ return context.identity !== null && this.allow
12
+ }
13
+ }
@@ -1,5 +1,7 @@
1
1
  import assert from 'node:assert'
2
2
  import { match } from 'matchacho'
3
+ import { console } from 'openspan'
4
+ import { minimatch } from 'minimatch'
3
5
  import * as http from '../../HTTP'
4
6
  import { Anonymous } from './Anonymous'
5
7
  import { Id } from './Id'
@@ -9,6 +11,9 @@ import { Incept } from './Incept'
9
11
  import { Echo } from './Echo'
10
12
  import { Scheme } from './Scheme'
11
13
  import { Delegate } from './Delegate'
14
+ import { Federation } from './Federation'
15
+ import { Anyone } from './Anyone'
16
+ import { Input } from './Input'
12
17
  import { split } from './split'
13
18
  import { PRIMARY, PROVIDERS } from './schemes'
14
19
  import type { Output } from '../../io'
@@ -22,7 +27,7 @@ import type {
22
27
  Discovery,
23
28
  Extension,
24
29
  Identity,
25
- Input,
30
+ Context,
26
31
  Remote,
27
32
  Schemes
28
33
  } from './types'
@@ -39,7 +44,7 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
39
44
 
40
45
  public create (name: string, value: any, remotes: Remotes): Directive {
41
46
  assert.ok(name in constructors,
42
- `Directive '${name}' is not provided by the '${this.name}' family.`)
47
+ `Directive 'auth:${name}' is not implemented`)
43
48
 
44
49
  const Class = constructors[name]
45
50
 
@@ -49,70 +54,90 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
49
54
  return match(Class,
50
55
  Role, () => new Role(value as string | string[], this.discovery.roles),
51
56
  Rule, () => new Rule(value as Record<string, string>, this.create.bind(this)),
57
+ Input, () => new Input(value, this.create.bind(this)),
52
58
  Incept, () => new Incept(value as string, this.discovery),
59
+ Delegate, () => new Delegate(value as string, this.discovery.roles),
53
60
  () => new Class(value))
54
61
  }
55
62
 
56
63
  public async preflight (directives: Directive[],
57
- input: Input,
64
+ context: Context,
58
65
  parameters: Parameter[]): Promise<Output> {
59
- const identity = await this.resolve(input.request.headers.authorization)
60
-
61
- input.identity = identity
66
+ context.identity = await this.resolve(context.authority, context.request.headers.authorization)
67
+ directives.sort((a, b) => (a.priority ?? 1) - (b.priority ?? 1))
62
68
 
63
69
  for (const directive of directives) {
64
- const allow = await directive.authorize(identity, input, parameters)
70
+ const allow = await directive.authorize(context.identity, context, parameters)
65
71
 
66
72
  if (allow)
67
- return directive.reply?.(identity) ?? null
73
+ if (this.permitted(context))
74
+ return directive.reply?.(context) ?? null
75
+ else
76
+ throw new http.Forbidden()
68
77
  }
69
78
 
70
- if (identity === null)
79
+ if (context.identity === null)
71
80
  throw new http.Unauthorized()
72
81
  else
73
82
  throw new http.Forbidden()
74
83
  }
75
84
 
76
85
  public async settle (directives: Directive[],
77
- request: Input,
86
+ context: Context,
78
87
  response: http.OutgoingMessage): Promise<void> {
79
- for (const directive of directives) await directive.settle?.(request, response)
88
+ await Promise.all(directives.map(async (directive) =>
89
+ directive.settle?.(context, response)))
80
90
 
81
- const identity = request.identity
91
+ const identity = context.identity
82
92
 
83
- if (identity === null) return
93
+ if (identity === null)
94
+ return
84
95
 
85
- if (identity.scheme === PRIMARY && !identity.refresh) return
96
+ if (identity.scheme === PRIMARY && !identity.refresh)
97
+ return
86
98
 
87
99
  // Role directive may have already set the value
88
- if (identity.roles === undefined) await Role.set(identity, this.discovery.roles)
89
-
100
+ identity.roles ??= await Role.get(identity, this.discovery.roles)
90
101
  this.tokens ??= await this.discovery.tokens
91
102
 
92
- const token = await this.tokens.invoke<string>('encrypt', { input: { identity } })
93
- const authorization = `Token ${token}`
103
+ const token = await this.tokens.invoke<string>('encrypt', {
104
+ input: { authority: context.authority, identity }
105
+ })
94
106
 
95
- if (response.headers === undefined) response.headers = new Headers()
107
+ const authorization = `Token ${token}`
96
108
 
109
+ response.headers ??= new Headers()
97
110
  response.headers.set('authorization', authorization)
111
+ response.headers.set('cache-control', 'no-store')
98
112
  }
99
113
 
100
- private async resolve (authorization: string | undefined): Promise<Identity | null> {
101
- if (authorization === undefined) return null
114
+ private async resolve (authority: string, authorization: string | undefined): Promise<Identity | null> {
115
+ if (authorization === undefined)
116
+ return null
102
117
 
103
118
  const [scheme, credentials] = split(authorization)
104
119
  const provider = PROVIDERS[scheme]
105
120
 
106
121
  if (!(provider in this.discovery))
107
- throw new http.Unauthorized(`Unknown authentication scheme '${scheme}'.`)
122
+ throw new http.Unauthorized(`Unknown authentication scheme '${scheme}'`)
108
123
 
109
124
  this.schemes[scheme] ??= await this.discovery[provider]
110
125
 
111
126
  const result = await this.schemes[scheme].invoke<AuthenticationResult>('authenticate', {
112
- input: credentials
127
+ input: {
128
+ authority,
129
+ credentials
130
+ }
113
131
  })
114
132
 
115
- if (result instanceof Error) return null
133
+ if (result instanceof Error) {
134
+ const code: string | unknown = (result as unknown as { code: string }).code
135
+
136
+ if (typeof code === 'string')
137
+ console.info('Authentication failed', { code })
138
+
139
+ return null
140
+ }
116
141
 
117
142
  const identity = result.identity
118
143
 
@@ -124,6 +149,18 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
124
149
  return identity
125
150
  }
126
151
 
152
+ private permitted (context: Context): boolean {
153
+ const permissions = context.identity?.permissions
154
+
155
+ if (permissions === undefined)
156
+ return true
157
+
158
+ return Object.entries(permissions).some(([pattern, methods]) => {
159
+ return methods.some((method) => method === '*' || method === context.request.method) &&
160
+ minimatch(context.request.url, pattern)
161
+ })
162
+ }
163
+
127
164
  private async banned (identity: Identity): Promise<boolean> {
128
165
  this.bans ??= await this.discovery.bans
129
166
 
@@ -135,13 +172,16 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
135
172
 
136
173
  const constructors: Record<string, new (value: any, argument?: any) => Directive> = {
137
174
  anonymous: Anonymous,
175
+ anyone: Anyone,
138
176
  id: Id,
139
177
  role: Role,
140
178
  rule: Rule,
141
179
  incept: Incept,
142
180
  scheme: Scheme,
143
181
  echo: Echo,
144
- delegate: Delegate
182
+ delegate: Delegate,
183
+ claims: Federation,
184
+ input: Input
145
185
  }
146
186
 
147
187
  const REMOTES: Remote[] = ['basic', 'federation', 'tokens', 'roles', 'bans']
@@ -1,26 +1,33 @@
1
1
  import { BadRequest } from '../../HTTP'
2
- import { type Directive, type Identity } from './types'
3
- import type { Input } from '../../io'
2
+ import { Role } from './Role'
3
+ import type { Context, Directive, Identity } from './types'
4
+ import type { Component } from '@toa.io/core'
4
5
 
5
6
  export class Delegate implements Directive {
6
7
  private readonly property: string
8
+ private readonly discovery: Promise<Component>
7
9
 
8
- public constructor (property: string) {
10
+ public constructor (property: string, discovery: Promise<Component>) {
9
11
  this.property = property
12
+ this.discovery = discovery
10
13
  }
11
14
 
12
- public authorize (identity: Identity | null, context: Input): boolean {
15
+ public async authorize (identity: Identity | null, context: Context): Promise<boolean> {
13
16
  if (identity === null)
14
17
  return false
15
18
 
19
+ identity.roles ??= await Role.get(identity, this.discovery)
16
20
  context.pipelines.body.push((body) => this.embed(body, identity))
17
21
 
18
22
  return true
19
23
  }
20
24
 
21
25
  private embed (body: unknown, identity: Identity): Record<string, unknown> {
26
+ if (body === undefined)
27
+ body = {}
28
+
22
29
  check(body)
23
- body[this.property] = identity
30
+ body[this.property] = structuredClone(identity)
24
31
 
25
32
  return body
26
33
  }
@@ -28,5 +35,5 @@ export class Delegate implements Directive {
28
35
 
29
36
  function check (body: unknown): asserts body is Record<string, unknown> {
30
37
  if (typeof body !== 'object' || body === null)
31
- throw new BadRequest('Invalid request body.')
38
+ throw new BadRequest('Invalid request body')
32
39
  }
@@ -1,12 +1,22 @@
1
- import { type OutgoingMessage } from '../../HTTP'
2
- import { type Directive, type Identity } from './types'
1
+ import { create } from './create'
2
+ import type { OutgoingMessage } from '../../HTTP'
3
+ import type { Directive, Identity, Context } from './types'
3
4
 
4
5
  export class Echo implements Directive {
5
- public authorize (identity: Identity | null): boolean {
6
- return identity !== null
6
+ public authorize (identity: Identity | null, context: Context): boolean {
7
+ if (identity === null && 'authorization' in context.request.headers)
8
+ return false
9
+
10
+ context.identity ??= create()
11
+
12
+ return true
7
13
  }
8
14
 
9
- public reply (identity: Identity | null): OutgoingMessage {
10
- return { body: identity }
15
+ public reply (context: Context): OutgoingMessage {
16
+ const body = context.identity!
17
+
18
+ return body.scheme === null
19
+ ? { status: 201, body }
20
+ : { body }
11
21
  }
12
22
  }
@@ -0,0 +1,84 @@
1
+ import assert from 'node:assert'
2
+ import type { Directive, Identity, Context } from './types'
3
+ import type { Parameter } from '../../RTD'
4
+
5
+ export class Federation implements Directive {
6
+ private readonly matchers: Array<[keyof Claims, Matcher]>
7
+
8
+ public constructor (options: Options) {
9
+ this.matchers = (Object.entries(options) as Array<[keyof Claims, string]>)
10
+ .map(([key, value]) => [key, toMatcher(value)])
11
+
12
+ assert.ok(this.matchers.length > 0, '`auth:claims` requires at least one property defined')
13
+ }
14
+
15
+ public authorize (identity: Identity | null, context: Context, parameters: Parameter[]): boolean {
16
+ if (identity === null || !('claims' in identity))
17
+ return false
18
+
19
+ const claims = (identity as FederatedIdentity).claims
20
+
21
+ for (const [key, match] of this.matchers)
22
+ if (!match(claims[key], context, parameters))
23
+ return false
24
+
25
+ return true
26
+ }
27
+ }
28
+
29
+ function toMatcher (expression: string): Matcher {
30
+ if (expression.startsWith(':')) {
31
+ const key = expression.slice(1) as 'authority'
32
+
33
+ if (key === 'authority')
34
+ return (value, context) => matches(value, context[key])
35
+
36
+ if (key === 'domain')
37
+ return (value, context) => {
38
+ return Array.isArray(value)
39
+ ? value.some((iss) => codomain(iss, context))
40
+ : codomain(value, context)
41
+ }
42
+
43
+ throw new Error('Unknown `auth:claims` syntax: ' + expression)
44
+ }
45
+
46
+ if (expression.startsWith('/:')) {
47
+ const name = expression.slice(2)
48
+
49
+ return (value, _, parameters) => parameters
50
+ .some((parameter) => parameter.name === name && matches(value, parameter.value))
51
+ }
52
+
53
+ return (value) => matches(value, expression)
54
+ }
55
+
56
+ function matches (value: string | string[], reference: string): boolean {
57
+ return Array.isArray(value)
58
+ ? value.includes(reference)
59
+ : value === reference
60
+ }
61
+
62
+ function codomain (iss: string, context: Context): boolean {
63
+ const hostname = new URL(iss).hostname
64
+ const dot = hostname.indexOf('.')
65
+ const basename = dot === -1 ? hostname : hostname.slice(dot)
66
+
67
+ return context.authority.slice(-basename.length) === basename
68
+ }
69
+
70
+ type Matcher = (value: string | string[], context: Context, parameters: Parameter[]) => boolean
71
+
72
+ interface Claims {
73
+ iss: string
74
+ sub: string
75
+ aud: string | string[]
76
+ }
77
+
78
+ interface Options extends Partial<Claims> {
79
+ iss: string
80
+ }
81
+
82
+ interface FederatedIdentity extends Identity {
83
+ claims: Claims
84
+ }
@@ -8,7 +8,7 @@ export class Id implements Directive {
8
8
  this.parameter = parameter
9
9
  }
10
10
 
11
- public authorize (identity: Identity | null, _: any, parameters: Parameter[]): boolean {
11
+ public authorize (identity: Identity | null, _: unknown, parameters: Parameter[]): boolean {
12
12
  if (identity === null)
13
13
  return false
14
14
 
@@ -1,47 +1,62 @@
1
+ import assert from 'node:assert'
1
2
  import { type Maybe } from '@toa.io/types'
2
3
  import * as http from '../../HTTP'
3
- import { type Directive, type Discovery, type Identity, type Input, type Schemes } from './types'
4
+ import { type Directive, type Discovery, type Identity, type Context, type Schemes } from './types'
4
5
  import { split } from './split'
6
+ import { create } from './create'
5
7
  import { PROVIDERS } from './schemes'
6
8
 
7
9
  export class Incept implements Directive {
8
- private readonly property: string
10
+ private readonly property: string | null
9
11
  private readonly discovery: Discovery
10
12
  private readonly schemes: Schemes = {} as unknown as Schemes
11
13
 
12
14
  public constructor (property: string, discovery: Discovery) {
15
+ assert.ok(property === null || typeof property === 'string',
16
+ '`auth:incept` value must be a string or null')
17
+
13
18
  this.property = property
14
19
  this.discovery = discovery
15
20
  }
16
21
 
17
- public authorize (identity: Identity | null, input: Input): boolean {
18
- return identity === null && 'authorization' in input.request.headers
22
+ public authorize (identity: Identity | null, context: Context): boolean {
23
+ return identity === null && 'authorization' in context.request.headers
24
+ }
25
+
26
+ public reply (context: Context): http.OutgoingMessage | null {
27
+ if (this.property !== null)
28
+ return null
29
+
30
+ const body = create(context.request.headers.authorization)
31
+
32
+ return { body }
19
33
  }
20
34
 
21
- public async settle (input: Input, response: http.OutgoingMessage): Promise<void> {
22
- const id = response.body?.[this.property]
35
+ public async settle (context: Context, response: http.OutgoingMessage): Promise<void> {
36
+ const id = response.body?.[this.property ?? 'id']
23
37
 
24
38
  if (id === undefined)
25
39
  throw new http.Conflict('Identity inception has failed as the response body ' +
26
- ` does not contain the '${this.property}' property.`)
40
+ `does not contain the '${this.property}' property`)
27
41
 
28
- const [scheme, credentials] = split(input.request.headers.authorization!)
42
+ const [scheme, credentials] = split(context.request.headers.authorization!)
29
43
  const provider = PROVIDERS[scheme]
30
44
 
31
45
  this.schemes[scheme] ??= await this.discovery[provider]
32
46
 
33
47
  const identity = await this.schemes[scheme]
34
- .invoke<Maybe<Identity>>('create', {
48
+ .invoke<Maybe<Identity>>('incept', {
35
49
  input: {
50
+ authority: context.authority,
36
51
  id,
37
52
  credentials
38
53
  }
39
54
  })
40
55
 
41
56
  if (identity instanceof Error)
42
- throw new http.Conflict(identity)
57
+ throw new http.UnprocessableEntity(identity)
43
58
 
44
- input.identity = identity
45
- input.identity.scheme = scheme
59
+ context.identity = identity
60
+ context.identity.scheme = scheme
46
61
  }
47
62
  }