@toa.io/extensions.exposition 1.0.0-alpha.3 → 1.0.0-alpha.31

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 (431) hide show
  1. package/components/context.toa.yaml +2 -2
  2. package/components/identity.bans/manifest.toa.yaml +15 -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 +21 -8
  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 +20 -0
  15. package/components/identity.basic/operations/incept.js.map +1 -0
  16. package/components/identity.basic/operations/transit.d.ts +3 -3
  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 +2 -0
  21. package/components/identity.basic/source/authenticate.ts +16 -5
  22. package/components/identity.basic/source/incept.ts +32 -0
  23. package/components/identity.basic/source/transit.ts +7 -5
  24. package/components/identity.basic/source/types.ts +2 -0
  25. package/components/identity.federation/manifest.toa.yaml +28 -17
  26. package/components/identity.federation/operations/authenticate.d.ts +2 -2
  27. package/components/identity.federation/operations/authenticate.js +6 -5
  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/jwt.d.ts +4 -5
  33. package/components/identity.federation/operations/lib/jwt.js +3 -3
  34. package/components/identity.federation/operations/lib/jwt.js.map +1 -1
  35. package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -1
  36. package/components/identity.federation/operations/types/configuration.d.ts +15 -0
  37. package/components/identity.federation/operations/types/configuration.js +3 -0
  38. package/components/identity.federation/operations/types/configuration.js.map +1 -0
  39. package/components/identity.federation/operations/{types.d.ts → types/context.d.ts} +8 -3
  40. package/components/identity.federation/operations/types/context.js +3 -0
  41. package/components/identity.federation/operations/types/context.js.map +1 -0
  42. package/components/identity.federation/operations/types/entity.d.ts +6 -0
  43. package/components/identity.federation/operations/{types.js → types/entity.js} +1 -1
  44. package/components/identity.federation/operations/types/entity.js.map +1 -0
  45. package/components/identity.federation/operations/types/index.d.ts +3 -0
  46. package/components/identity.federation/operations/types/index.js +20 -0
  47. package/components/identity.federation/operations/types/index.js.map +1 -0
  48. package/components/identity.federation/source/authenticate.ts +10 -9
  49. package/components/identity.federation/source/{create.ts → incept.ts} +10 -9
  50. package/components/identity.federation/source/lib/jwt.test.ts +2 -2
  51. package/components/identity.federation/source/lib/jwt.ts +7 -8
  52. package/components/identity.federation/source/types/configuration.ts +16 -0
  53. package/components/identity.federation/source/{types.ts → types/context.ts} +9 -4
  54. package/components/identity.federation/source/types/entity.ts +6 -0
  55. package/components/identity.federation/source/types/index.ts +3 -0
  56. package/components/identity.federation/tsconfig.json +2 -2
  57. package/components/identity.roles/manifest.toa.yaml +18 -5
  58. package/components/identity.roles/operations/grant.d.ts +10 -0
  59. package/components/identity.roles/operations/grant.js +21 -0
  60. package/components/identity.roles/operations/grant.js.map +1 -0
  61. package/components/identity.roles/operations/lib/Entity.d.ts +5 -0
  62. package/components/identity.roles/operations/lib/Entity.js +3 -0
  63. package/components/identity.roles/operations/lib/Entity.js.map +1 -0
  64. package/components/identity.roles/operations/list.d.ts +1 -4
  65. package/components/identity.roles/operations/list.js.map +1 -1
  66. package/components/identity.roles/operations/principal.d.ts +4 -6
  67. package/components/identity.roles/operations/principal.js +6 -1
  68. package/components/identity.roles/operations/principal.js.map +1 -1
  69. package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -1
  70. package/components/identity.roles/source/grant.ts +32 -0
  71. package/components/identity.roles/source/lib/Entity.ts +5 -0
  72. package/components/identity.roles/source/list.ts +2 -4
  73. package/components/identity.roles/source/principal.ts +10 -8
  74. package/components/identity.tokens/manifest.toa.yaml +19 -4
  75. package/components/identity.tokens/operations/authenticate.d.ts +2 -2
  76. package/components/identity.tokens/operations/authenticate.js +10 -4
  77. package/components/identity.tokens/operations/authenticate.js.map +1 -1
  78. package/components/identity.tokens/operations/decrypt.js +1 -0
  79. package/components/identity.tokens/operations/decrypt.js.map +1 -1
  80. package/components/identity.tokens/operations/encrypt.js +5 -1
  81. package/components/identity.tokens/operations/encrypt.js.map +1 -1
  82. package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -1
  83. package/components/identity.tokens/operations/types.d.ts +8 -2
  84. package/components/identity.tokens/receivers/identity.bans.created.js +3 -0
  85. package/components/identity.tokens/source/authenticate.test.ts +11 -4
  86. package/components/identity.tokens/source/authenticate.ts +12 -5
  87. package/components/identity.tokens/source/decrypt.test.ts +5 -3
  88. package/components/identity.tokens/source/decrypt.ts +9 -8
  89. package/components/identity.tokens/source/encrypt.test.ts +26 -2
  90. package/components/identity.tokens/source/encrypt.ts +5 -1
  91. package/components/identity.tokens/source/types.ts +9 -2
  92. package/components/octets.storage/manifest.toa.yaml +0 -6
  93. package/components/octets.storage/operations/store.js +1 -1
  94. package/documentation/access.md +27 -16
  95. package/documentation/authorities.md +53 -0
  96. package/documentation/cache.md +8 -1
  97. package/documentation/components.md +52 -27
  98. package/documentation/identity.md +17 -22
  99. package/documentation/io.md +56 -0
  100. package/documentation/protocol.md +3 -0
  101. package/documentation/query.md +57 -8
  102. package/documentation/require.md +15 -0
  103. package/documentation/tree.md +22 -4
  104. package/documentation/vary.md +14 -14
  105. package/entity.json +0 -0
  106. package/features/access.feature +83 -56
  107. package/features/annotation.feature +2 -0
  108. package/features/authorities.basic.feature +141 -0
  109. package/features/authorities.feature +32 -0
  110. package/features/authorities.federation.feature +99 -0
  111. package/features/authorities.tokens.feature +118 -0
  112. package/features/body.feature +5 -1
  113. package/features/cache.feature +78 -5
  114. package/features/cors.feature +6 -2
  115. package/features/debug.feature +34 -0
  116. package/features/directives.feature +5 -0
  117. package/features/dynamic.feature +18 -7
  118. package/features/errors.feature +19 -5
  119. package/features/etag.feature +103 -0
  120. package/features/identity.bans.feature +137 -0
  121. package/features/identity.basic.feature +137 -14
  122. package/features/identity.feature +7 -2
  123. package/features/identity.federation.feature +61 -8
  124. package/features/identity.roles.feature +220 -4
  125. package/features/identity.tokens.feature +114 -4
  126. package/features/io.feature +205 -0
  127. package/features/octets.entries.feature +11 -1
  128. package/features/octets.feature +60 -64
  129. package/features/octets.meta.feature +7 -3
  130. package/features/octets.workflows.feature +14 -0
  131. package/features/probes.feature +14 -0
  132. package/features/{queries.feature → query.feature} +50 -3
  133. package/features/require.feature +67 -0
  134. package/features/response.feature +12 -3
  135. package/features/routes.feature +25 -12
  136. package/features/steps/Database.ts +17 -10
  137. package/features/steps/Gateway.ts +24 -4
  138. package/features/steps/IdP.ts +28 -23
  139. package/features/steps/components/echo/manifest.toa.yaml +5 -0
  140. package/features/steps/components/echo/operations/identity.js +7 -0
  141. package/features/steps/components/greeter/manifest.toa.yaml +1 -0
  142. package/features/steps/components/octets.tester/manifest.toa.yaml +1 -0
  143. package/features/steps/components/pots/manifest.toa.yaml +12 -3
  144. package/features/steps/components/sequences/manifest.toa.yaml +1 -0
  145. package/features/steps/components/users.properties/manifest.toa.yaml +2 -1
  146. package/features/streams.feature +1 -0
  147. package/features/timing.feature +69 -0
  148. package/features/vary.feature +105 -3
  149. package/package.json +12 -14
  150. package/readme.md +19 -13
  151. package/schemas/annotation.cos.yaml +2 -1
  152. package/schemas/io/input.cos.yaml +3 -0
  153. package/schemas/io/message.cos.yaml +5 -0
  154. package/schemas/io/output.cos.yaml +5 -0
  155. package/schemas/querystring.cos.yaml +1 -0
  156. package/source/Annotation.ts +3 -2
  157. package/source/Context.ts +6 -4
  158. package/source/Directive.test.ts +7 -7
  159. package/source/Directive.ts +19 -46
  160. package/source/Endpoint.ts +55 -6
  161. package/source/Factory.ts +17 -9
  162. package/source/Gateway.ts +38 -53
  163. package/source/HTTP/Context.ts +89 -0
  164. package/source/HTTP/Server.ts +99 -121
  165. package/source/HTTP/Timing.ts +40 -0
  166. package/source/HTTP/exceptions.ts +7 -1
  167. package/source/HTTP/index.ts +1 -0
  168. package/source/HTTP/messages.test.ts +27 -8
  169. package/source/HTTP/messages.ts +32 -48
  170. package/source/Mapping.ts +12 -8
  171. package/source/Query.test.ts +1 -1
  172. package/source/Query.ts +35 -24
  173. package/source/RTD/Context.ts +7 -10
  174. package/source/RTD/Directives.ts +28 -4
  175. package/source/RTD/Endpoint.ts +6 -4
  176. package/source/RTD/Match.ts +2 -7
  177. package/source/RTD/Method.ts +7 -13
  178. package/source/RTD/Node.ts +13 -14
  179. package/source/RTD/Tree.ts +17 -16
  180. package/source/RTD/factory.ts +3 -6
  181. package/source/Tenant.ts +0 -8
  182. package/source/deployment.ts +33 -17
  183. package/source/directives/auth/Anonymous.ts +3 -2
  184. package/source/directives/auth/Authorization.ts +34 -21
  185. package/source/directives/auth/Delegate.ts +35 -0
  186. package/source/directives/auth/Incept.ts +13 -7
  187. package/source/directives/auth/Role.test.ts +53 -6
  188. package/source/directives/auth/Role.ts +27 -17
  189. package/source/directives/auth/Scheme.ts +2 -2
  190. package/source/directives/auth/types.ts +1 -1
  191. package/source/directives/cache/Cache.ts +5 -5
  192. package/source/directives/cache/Control.ts +48 -22
  193. package/source/directives/cache/types.ts +1 -1
  194. package/source/directives/cors/CORS.ts +18 -10
  195. package/source/directives/dev/Development.ts +4 -4
  196. package/source/directives/index.ts +6 -4
  197. package/source/directives/io/Directive.ts +11 -0
  198. package/source/directives/io/IO.ts +43 -0
  199. package/source/directives/io/Input.ts +50 -0
  200. package/source/directives/io/Message.ts +1 -0
  201. package/source/directives/io/Output.ts +69 -0
  202. package/source/directives/io/index.ts +3 -0
  203. package/source/directives/io/schemas.ts +12 -0
  204. package/source/directives/octets/Context.ts +5 -4
  205. package/source/directives/octets/Delete.ts +23 -11
  206. package/source/directives/octets/Directive.ts +10 -0
  207. package/source/directives/octets/Fetch.ts +33 -17
  208. package/source/directives/octets/List.ts +18 -8
  209. package/source/directives/octets/Octets.ts +9 -9
  210. package/source/directives/octets/Store.ts +29 -19
  211. package/source/directives/octets/Workflow.ts +12 -5
  212. package/source/directives/octets/types.ts +0 -7
  213. package/source/directives/octets/workflows/Workflow.ts +2 -2
  214. package/source/directives/require/Directive.ts +5 -0
  215. package/source/directives/require/Headers.ts +20 -0
  216. package/source/directives/require/Require.ts +28 -0
  217. package/source/directives/require/index.ts +3 -0
  218. package/source/directives/vary/Directive.ts +2 -1
  219. package/source/directives/vary/Embed.ts +14 -8
  220. package/source/directives/vary/Vary.ts +8 -6
  221. package/source/directives/vary/embeddings/Authority.ts +8 -0
  222. package/source/directives/vary/embeddings/Embedding.ts +2 -1
  223. package/source/directives/vary/embeddings/Header.ts +9 -7
  224. package/source/directives/vary/embeddings/Language.ts +2 -2
  225. package/source/directives/vary/embeddings/Parameter.ts +14 -0
  226. package/source/directives/vary/embeddings/index.ts +6 -4
  227. package/source/exceptions.ts +22 -11
  228. package/source/io.ts +2 -2
  229. package/source/root.ts +5 -0
  230. package/source/schemas.ts +1 -1
  231. package/transpiled/Annotation.d.ts +3 -2
  232. package/transpiled/Context.d.ts +6 -4
  233. package/transpiled/Directive.d.ts +8 -21
  234. package/transpiled/Directive.js +11 -14
  235. package/transpiled/Directive.js.map +1 -1
  236. package/transpiled/Endpoint.d.ts +7 -5
  237. package/transpiled/Endpoint.js +60 -2
  238. package/transpiled/Endpoint.js.map +1 -1
  239. package/transpiled/Factory.js +11 -4
  240. package/transpiled/Factory.js.map +1 -1
  241. package/transpiled/Gateway.d.ts +4 -8
  242. package/transpiled/Gateway.js +25 -35
  243. package/transpiled/Gateway.js.map +1 -1
  244. package/transpiled/HTTP/Context.d.ts +31 -0
  245. package/transpiled/HTTP/Context.js +60 -0
  246. package/transpiled/HTTP/Context.js.map +1 -0
  247. package/transpiled/HTTP/Server.d.ts +21 -9
  248. package/transpiled/HTTP/Server.js +98 -100
  249. package/transpiled/HTTP/Server.js.map +1 -1
  250. package/transpiled/HTTP/Timing.d.ts +10 -0
  251. package/transpiled/HTTP/Timing.js +29 -0
  252. package/transpiled/HTTP/Timing.js.map +1 -0
  253. package/transpiled/HTTP/exceptions.d.ts +4 -1
  254. package/transpiled/HTTP/exceptions.js +7 -1
  255. package/transpiled/HTTP/exceptions.js.map +1 -1
  256. package/transpiled/HTTP/index.d.ts +1 -0
  257. package/transpiled/HTTP/index.js +1 -0
  258. package/transpiled/HTTP/index.js.map +1 -1
  259. package/transpiled/HTTP/messages.d.ts +7 -21
  260. package/transpiled/HTTP/messages.js +24 -26
  261. package/transpiled/HTTP/messages.js.map +1 -1
  262. package/transpiled/Mapping.js +11 -8
  263. package/transpiled/Mapping.js.map +1 -1
  264. package/transpiled/Query.d.ts +1 -0
  265. package/transpiled/Query.js +21 -20
  266. package/transpiled/Query.js.map +1 -1
  267. package/transpiled/RTD/Context.d.ts +7 -6
  268. package/transpiled/RTD/Directives.d.ts +19 -4
  269. package/transpiled/RTD/Endpoint.d.ts +6 -4
  270. package/transpiled/RTD/Match.d.ts +2 -4
  271. package/transpiled/RTD/Method.d.ts +7 -7
  272. package/transpiled/RTD/Method.js.map +1 -1
  273. package/transpiled/RTD/Node.d.ts +4 -6
  274. package/transpiled/RTD/Node.js +2 -1
  275. package/transpiled/RTD/Node.js.map +1 -1
  276. package/transpiled/RTD/Tree.d.ts +6 -6
  277. package/transpiled/RTD/Tree.js +4 -1
  278. package/transpiled/RTD/Tree.js.map +1 -1
  279. package/transpiled/RTD/factory.d.ts +2 -4
  280. package/transpiled/RTD/factory.js +1 -1
  281. package/transpiled/RTD/factory.js.map +1 -1
  282. package/transpiled/Tenant.d.ts +0 -1
  283. package/transpiled/Tenant.js +0 -6
  284. package/transpiled/Tenant.js.map +1 -1
  285. package/transpiled/deployment.d.ts +1 -1
  286. package/transpiled/deployment.js +28 -15
  287. package/transpiled/deployment.js.map +1 -1
  288. package/transpiled/directives/auth/Anonymous.js +3 -4
  289. package/transpiled/directives/auth/Anonymous.js.map +1 -1
  290. package/transpiled/directives/auth/Authorization.d.ts +2 -3
  291. package/transpiled/directives/auth/Authorization.js +18 -11
  292. package/transpiled/directives/auth/Authorization.js.map +1 -1
  293. package/transpiled/directives/auth/Delegate.d.ts +8 -0
  294. package/transpiled/directives/auth/Delegate.js +29 -0
  295. package/transpiled/directives/auth/Delegate.js.map +1 -0
  296. package/transpiled/directives/auth/Incept.d.ts +1 -1
  297. package/transpiled/directives/auth/Incept.js +13 -7
  298. package/transpiled/directives/auth/Incept.js.map +1 -1
  299. package/transpiled/directives/auth/Role.d.ts +4 -1
  300. package/transpiled/directives/auth/Role.js +25 -17
  301. package/transpiled/directives/auth/Role.js.map +1 -1
  302. package/transpiled/directives/auth/Scheme.js +2 -2
  303. package/transpiled/directives/auth/Scheme.js.map +1 -1
  304. package/transpiled/directives/cache/Cache.d.ts +3 -3
  305. package/transpiled/directives/cache/Cache.js +3 -3
  306. package/transpiled/directives/cache/Cache.js.map +1 -1
  307. package/transpiled/directives/cache/Control.d.ts +5 -4
  308. package/transpiled/directives/cache/Control.js +32 -15
  309. package/transpiled/directives/cache/Control.js.map +1 -1
  310. package/transpiled/directives/cache/types.d.ts +1 -1
  311. package/transpiled/directives/cors/CORS.d.ts +2 -3
  312. package/transpiled/directives/cors/CORS.js +17 -10
  313. package/transpiled/directives/cors/CORS.js.map +1 -1
  314. package/transpiled/directives/dev/Development.d.ts +3 -3
  315. package/transpiled/directives/dev/Development.js +1 -1
  316. package/transpiled/directives/dev/Development.js.map +1 -1
  317. package/transpiled/directives/index.d.ts +2 -2
  318. package/transpiled/directives/index.js +5 -3
  319. package/transpiled/directives/index.js.map +1 -1
  320. package/transpiled/directives/io/Directive.d.ts +8 -0
  321. package/transpiled/directives/io/Directive.js +3 -0
  322. package/transpiled/directives/io/Directive.js.map +1 -0
  323. package/transpiled/directives/io/IO.d.ts +9 -0
  324. package/transpiled/directives/io/IO.js +33 -0
  325. package/transpiled/directives/io/IO.js.map +1 -0
  326. package/transpiled/directives/io/Input.d.ts +11 -0
  327. package/transpiled/directives/{octets/Permute.js → io/Input.js} +33 -21
  328. package/transpiled/directives/io/Input.js.map +1 -0
  329. package/transpiled/directives/io/Message.d.ts +1 -0
  330. package/transpiled/directives/io/Message.js +3 -0
  331. package/transpiled/directives/io/Message.js.map +1 -0
  332. package/transpiled/directives/io/Output.d.ts +13 -0
  333. package/transpiled/directives/io/Output.js +76 -0
  334. package/transpiled/directives/io/Output.js.map +1 -0
  335. package/transpiled/directives/io/index.d.ts +2 -0
  336. package/transpiled/directives/io/index.js +6 -0
  337. package/transpiled/directives/io/index.js.map +1 -0
  338. package/transpiled/directives/io/schemas.d.ts +7 -0
  339. package/transpiled/directives/io/schemas.js +14 -0
  340. package/transpiled/directives/io/schemas.js.map +1 -0
  341. package/transpiled/directives/octets/Context.d.ts +4 -4
  342. package/transpiled/directives/octets/Context.js +4 -2
  343. package/transpiled/directives/octets/Context.js.map +1 -1
  344. package/transpiled/directives/octets/Delete.d.ts +4 -3
  345. package/transpiled/directives/octets/Delete.js +22 -10
  346. package/transpiled/directives/octets/Delete.js.map +1 -1
  347. package/transpiled/directives/octets/Directive.d.ts +8 -0
  348. package/transpiled/directives/octets/Directive.js +8 -0
  349. package/transpiled/directives/octets/Directive.js.map +1 -0
  350. package/transpiled/directives/octets/Fetch.d.ts +4 -3
  351. package/transpiled/directives/octets/Fetch.js +31 -15
  352. package/transpiled/directives/octets/Fetch.js.map +1 -1
  353. package/transpiled/directives/octets/List.d.ts +4 -3
  354. package/transpiled/directives/octets/List.js +16 -7
  355. package/transpiled/directives/octets/List.js.map +1 -1
  356. package/transpiled/directives/octets/Octets.d.ts +4 -4
  357. package/transpiled/directives/octets/Octets.js +5 -5
  358. package/transpiled/directives/octets/Octets.js.map +1 -1
  359. package/transpiled/directives/octets/Store.d.ts +4 -3
  360. package/transpiled/directives/octets/Store.js +20 -13
  361. package/transpiled/directives/octets/Store.js.map +1 -1
  362. package/transpiled/directives/octets/Workflow.d.ts +4 -3
  363. package/transpiled/directives/octets/Workflow.js +11 -4
  364. package/transpiled/directives/octets/Workflow.js.map +1 -1
  365. package/transpiled/directives/octets/types.d.ts +0 -5
  366. package/transpiled/directives/octets/workflows/Workflow.d.ts +1 -1
  367. package/transpiled/directives/octets/workflows/Workflow.js +2 -2
  368. package/transpiled/directives/octets/workflows/Workflow.js.map +1 -1
  369. package/transpiled/directives/require/Directive.d.ts +4 -0
  370. package/transpiled/directives/require/Directive.js +3 -0
  371. package/transpiled/directives/require/Directive.js.map +1 -0
  372. package/transpiled/directives/require/Headers.d.ts +7 -0
  373. package/transpiled/directives/require/Headers.js +19 -0
  374. package/transpiled/directives/require/Headers.js.map +1 -0
  375. package/transpiled/directives/require/Require.d.ts +9 -0
  376. package/transpiled/directives/require/Require.js +27 -0
  377. package/transpiled/directives/require/Require.js.map +1 -0
  378. package/transpiled/directives/require/index.d.ts +2 -0
  379. package/transpiled/directives/require/index.js +6 -0
  380. package/transpiled/directives/require/index.js.map +1 -0
  381. package/transpiled/directives/vary/Directive.d.ts +2 -1
  382. package/transpiled/directives/vary/Embed.d.ts +2 -1
  383. package/transpiled/directives/vary/Embed.js +8 -6
  384. package/transpiled/directives/vary/Embed.js.map +1 -1
  385. package/transpiled/directives/vary/Vary.d.ts +3 -3
  386. package/transpiled/directives/vary/Vary.js +4 -4
  387. package/transpiled/directives/vary/Vary.js.map +1 -1
  388. package/transpiled/directives/vary/embeddings/Authority.d.ts +5 -0
  389. package/transpiled/directives/vary/embeddings/Authority.js +10 -0
  390. package/transpiled/directives/vary/embeddings/Authority.js.map +1 -0
  391. package/transpiled/directives/vary/embeddings/Embedding.d.ts +2 -1
  392. package/transpiled/directives/vary/embeddings/Header.js +9 -7
  393. package/transpiled/directives/vary/embeddings/Header.js.map +1 -1
  394. package/transpiled/directives/vary/embeddings/Language.js +2 -2
  395. package/transpiled/directives/vary/embeddings/Language.js.map +1 -1
  396. package/transpiled/directives/vary/embeddings/Parameter.d.ts +7 -0
  397. package/transpiled/directives/vary/embeddings/Parameter.js +14 -0
  398. package/transpiled/directives/vary/embeddings/Parameter.js.map +1 -0
  399. package/transpiled/directives/vary/embeddings/index.d.ts +2 -2
  400. package/transpiled/directives/vary/embeddings/index.js +8 -4
  401. package/transpiled/directives/vary/embeddings/index.js.map +1 -1
  402. package/transpiled/exceptions.d.ts +3 -2
  403. package/transpiled/exceptions.js +13 -7
  404. package/transpiled/exceptions.js.map +1 -1
  405. package/transpiled/io.d.ts +2 -2
  406. package/transpiled/root.js +5 -0
  407. package/transpiled/root.js.map +1 -1
  408. package/transpiled/schemas.d.ts +1 -1
  409. package/transpiled/schemas.js +2 -2
  410. package/transpiled/schemas.js.map +1 -1
  411. package/transpiled/tsconfig.tsbuildinfo +1 -1
  412. package/components/identity.basic/operations/create.d.ts +0 -10
  413. package/components/identity.basic/operations/create.js +0 -10
  414. package/components/identity.basic/operations/create.js.map +0 -1
  415. package/components/identity.basic/source/create.ts +0 -18
  416. package/components/identity.federation/operations/create.d.ts +0 -10
  417. package/components/identity.federation/operations/create.js.map +0 -1
  418. package/components/identity.federation/operations/schemas.d.ts +0 -59
  419. package/components/identity.federation/operations/schemas.js +0 -9
  420. package/components/identity.federation/operations/schemas.js.map +0 -1
  421. package/components/identity.federation/operations/types.js.map +0 -1
  422. package/components/identity.federation/source/schemas.ts +0 -61
  423. package/components/octets.storage/operations/permute.js +0 -7
  424. package/source/HTTP/Server.fixtures.ts +0 -40
  425. package/source/HTTP/Server.test.ts +0 -126
  426. package/source/directives/octets/Permute.ts +0 -37
  427. package/transpiled/HTTP/Server.fixtures.d.ts +0 -10
  428. package/transpiled/HTTP/Server.fixtures.js +0 -31
  429. package/transpiled/HTTP/Server.fixtures.js.map +0 -1
  430. package/transpiled/directives/octets/Permute.d.ts +0 -10
  431. package/transpiled/directives/octets/Permute.js.map +0 -1
@@ -3,26 +3,32 @@ import type { Interceptor } from '../../Interception'
3
3
 
4
4
  export class CORS implements Interceptor {
5
5
  public readonly name = 'cors'
6
- public readonly mandatory = true
7
6
 
8
- private readonly allowedHeaders = new Set<string>(['accept', 'authorization', 'content-type'])
7
+ private readonly requestHeaders = new Set<string>([
8
+ 'accept',
9
+ 'authorization',
10
+ 'content-type',
11
+ 'etag',
12
+ 'if-match',
13
+ 'if-none-match'
14
+ ])
9
15
 
10
16
  private readonly headers = new Headers({
11
17
  'access-control-allow-methods': 'GET, POST, PUT, PATCH, DELETE',
12
18
  'access-control-allow-credentials': 'true',
13
- 'access-control-allow-headers': Array.from(this.allowedHeaders).join(', '),
19
+ 'access-control-allow-headers': Array.from(this.requestHeaders).join(', '),
14
20
  'access-control-max-age': '3600',
15
- 'cache-control': 'public, max-age=3600',
21
+ 'cache-control': 'max-age=3600',
16
22
  vary: 'origin'
17
23
  })
18
24
 
19
25
  public intercept (input: Input): Output {
20
- const origin = input.headers.origin
26
+ const origin = input.request.headers.origin
21
27
 
22
28
  if (origin === undefined)
23
29
  return null
24
30
 
25
- if (input.method === 'OPTIONS')
31
+ if (input.request.method === 'OPTIONS')
26
32
  return this.preflightResponse(origin)
27
33
 
28
34
  input.pipelines.response.push((output) => {
@@ -31,16 +37,18 @@ export class CORS implements Interceptor {
31
37
  output.headers.set('access-control-expose-headers',
32
38
  'authorization, content-type, content-length, etag')
33
39
 
34
- if (input.method === 'GET' || input.method === 'HEAD' || input.method === 'OPTIONS')
40
+ const method = input.request.method
41
+
42
+ if (method === 'GET' || method === 'HEAD' || method === 'OPTIONS')
35
43
  output.headers.append('vary', 'origin')
36
44
  })
37
45
 
38
46
  return null
39
47
  }
40
48
 
41
- public allowHeader (header: string): void {
42
- this.allowedHeaders.add(header.toLowerCase())
43
- this.headers.set('access-control-allow-headers', Array.from(this.allowedHeaders).join(', '))
49
+ public allow (header: string): void {
50
+ this.requestHeaders.add(header.toLowerCase())
51
+ this.headers.set('access-control-allow-headers', Array.from(this.requestHeaders).join(', '))
44
52
  }
45
53
 
46
54
  private preflightResponse (origin: string): Output {
@@ -2,17 +2,17 @@ import { Stub } from './Stub'
2
2
  import { Throw } from './Throw'
3
3
  import { type Directive } from './types'
4
4
  import type { Input, Output } from '../../io'
5
- import type { Family } from '../../Directive'
5
+ import type { DirectiveFamily } from '../../RTD'
6
6
 
7
- export class Development implements Family<Directive> {
7
+ export class Development implements DirectiveFamily<Directive> {
8
8
  public readonly name: string = 'dev'
9
9
  public readonly mandatory: boolean = false
10
10
 
11
- public create (name: string, value: any): Directive {
11
+ public create (name: string, value: unknown): Directive {
12
12
  const Class = constructors[name]
13
13
 
14
14
  if (Class === undefined)
15
- throw new Error(`Directive '${name}' is not provided by the '${this.name}' family.`)
15
+ throw new Error(`Directive 'dev:${name}' is not implemented.`)
16
16
 
17
17
  return new Class(value)
18
18
  }
@@ -1,11 +1,13 @@
1
- import { dev } from './dev'
2
1
  import { authorization } from './auth'
3
2
  import { cache } from './cache'
4
- import { octets } from './octets'
5
3
  import { cors } from './cors'
4
+ import { dev } from './dev'
5
+ import { octets } from './octets'
6
+ import { io } from './io'
6
7
  import { vary } from './vary'
7
- import type { Family } from '../Directive'
8
+ import { req } from './require'
9
+ import type { DirectiveFamily } from '../RTD'
8
10
  import type { Interceptor } from '../Interception'
9
11
 
10
- export const families: Family[] = [authorization, cache, octets, vary, dev]
12
+ export const families: DirectiveFamily[] = [authorization, io, cache, vary, req, octets, dev]
11
13
  export const interceptors: Interceptor[] = [cors]
@@ -0,0 +1,11 @@
1
+ import type { Input } from '../../io'
2
+
3
+ export interface Directive {
4
+ attach: (context: Input) => void
5
+ }
6
+
7
+ export interface Constructor {
8
+ validate: (value: unknown) => void
9
+
10
+ new (value: any): Directive
11
+ }
@@ -0,0 +1,43 @@
1
+ import { Output } from './Output'
2
+ import { Input } from './Input'
3
+ import type { Constructor, Directive } from './Directive'
4
+ import type { Input as Context } from '../../io'
5
+ import type { DirectiveFamily } from '../../RTD'
6
+
7
+ export class IO implements DirectiveFamily<Directive> {
8
+ public readonly name = 'io'
9
+ public readonly mandatory = true
10
+
11
+ public create (name: string, value: unknown): Directive {
12
+ if (!(name in constructors))
13
+ throw new Error(`Directive 'io:${name}' is not implemented.`)
14
+
15
+ const Directive = constructors[name]
16
+
17
+ Directive.validate(value)
18
+
19
+ return new Directive(value)
20
+ }
21
+
22
+ public preflight (directives: Directive[], context: Context): null {
23
+ let restricted = false
24
+
25
+ for (const directive of directives) {
26
+ restricted ||= directive instanceof Output
27
+
28
+ directive.attach(context)
29
+ }
30
+
31
+ if (!restricted)
32
+ DENIAL.attach(context)
33
+
34
+ return null
35
+ }
36
+ }
37
+
38
+ const constructors: Record<string, Constructor> = {
39
+ output: Output,
40
+ input: Input
41
+ }
42
+
43
+ const DENIAL: Output = new Output([])
@@ -0,0 +1,50 @@
1
+ import { BadRequest } from '../../HTTP'
2
+ import * as schemas from './schemas'
3
+ import type { Message } from './Message'
4
+ import type { Directive } from './Directive'
5
+ import type { Input as Context } from '../../io'
6
+
7
+ export class Input implements Directive {
8
+ private readonly permissions: Permissions
9
+
10
+ public constructor (permissions: Permissions) {
11
+ this.permissions = permissions
12
+ }
13
+
14
+ public static validate (permissions: unknown): asserts permissions is Permissions {
15
+ schemas.input.validate(permissions, 'Incorrect \'io:input\' format')
16
+ }
17
+
18
+ public attach (context: Context): void {
19
+ context.pipelines.body.push((body) => this.check(body))
20
+ }
21
+
22
+ private check (body: unknown): unknown {
23
+ try {
24
+ schemas.message.validate(body)
25
+ } catch {
26
+ throw new BadRequest('Invalid request body.')
27
+ }
28
+
29
+ const property = this.violation(body)
30
+
31
+ if (property !== undefined)
32
+ throw new BadRequest(`Unexpected input: ${property}.`)
33
+
34
+ return body
35
+ }
36
+
37
+ private violation (value: Message | Message[]): string | undefined {
38
+ if (!Array.isArray(value))
39
+ return Object.keys(value).find((key) => !this.permissions.includes(key))
40
+
41
+ for (const item of value) {
42
+ const property = this.violation(item)
43
+
44
+ if (property !== undefined)
45
+ return property
46
+ }
47
+ }
48
+ }
49
+
50
+ export type Permissions = string[]
@@ -0,0 +1 @@
1
+ export type Message = Record<string, unknown>
@@ -0,0 +1,69 @@
1
+ import { Stream } from 'node:stream'
2
+ import * as schemas from './schemas'
3
+ import type { Message } from './Message'
4
+ import type { Directive } from './Directive'
5
+ import type { Input as Context } from '../../io'
6
+ import type { OutgoingMessage } from '../../HTTP'
7
+
8
+ export class Output implements Directive {
9
+ private readonly disabled: boolean = false
10
+ private readonly omitted: boolean = true
11
+ private readonly permissions: string[] = []
12
+
13
+ public constructor (permissions: Permissions) {
14
+ if (typeof permissions === 'boolean')
15
+ if (permissions)
16
+ this.disabled = true
17
+ else
18
+ this.omitted = false
19
+
20
+ else
21
+ this.permissions = permissions
22
+ }
23
+
24
+ public static validate (permissions: unknown): asserts permissions is Permissions {
25
+ schemas.output.validate(permissions, 'Incorrect \'io:output\' format')
26
+ }
27
+
28
+ public attach (context: Context): void {
29
+ context.pipelines.response.push(this.restriction(context))
30
+ }
31
+
32
+ private restriction (context: Context) {
33
+ return (message: OutgoingMessage): void => {
34
+ const error = message.status !== undefined && message.status >= 300
35
+ const stream = message.body instanceof Stream
36
+ const none = message.body === undefined || message.body === null
37
+
38
+ if (this.disabled || error || stream || none)
39
+ return
40
+
41
+ if (typeof message.body !== 'object' || this.permissions.length === 0) {
42
+ if (this.omitted)
43
+ console.warn('Permissions for \'io:output\' are not specified properly ' +
44
+ `(${context.request.url}). Response omitted.`)
45
+
46
+ delete message.body
47
+
48
+ return
49
+ }
50
+
51
+ schemas.message.validate(message.body,
52
+ '\'io:output\' expects response to be an object or array of objects')
53
+
54
+ if (Array.isArray(message.body))
55
+ message.body = message.body.map((entity) => this.fit(entity))
56
+ else
57
+ message.body = this.fit(message.body)
58
+ }
59
+ }
60
+
61
+ private fit (message: Message): Message | undefined {
62
+ const entries = Object.entries(message)
63
+ .filter(([key]) => this.permissions.includes(key))
64
+
65
+ return Object.fromEntries(entries)
66
+ }
67
+ }
68
+
69
+ export type Permissions = string[] | boolean
@@ -0,0 +1,3 @@
1
+ import { IO } from './IO'
2
+
3
+ export const io = new IO()
@@ -0,0 +1,12 @@
1
+ import { resolve } from 'node:path'
2
+ import schemas, { type Schema } from '@toa.io/schemas'
3
+ import type { Permissions as InputPermissions } from './Input'
4
+ import type { Permissions as OutputPermissions } from './Output'
5
+ import type { Message } from './Message'
6
+
7
+ const path = resolve(__dirname, '../../../schemas/io')
8
+ const namespace = schemas.namespace(path)
9
+
10
+ export const message: Schema<Message | Message[]> = namespace.schema('message')
11
+ export const input: Schema<InputPermissions> = namespace.schema('input')
12
+ export const output: Schema<OutputPermissions> = namespace.schema('output')
@@ -1,18 +1,19 @@
1
1
  import * as schemas from './schemas'
2
+ import { Directive } from './Directive'
2
3
  import type { Output } from '../../io'
3
- import type { Directive } from './types'
4
4
 
5
- export class Context implements Directive {
5
+ export class Context extends Directive {
6
6
  public readonly targeted = false
7
7
  public readonly storage: string
8
8
 
9
- public constructor (value: any) {
9
+ public constructor (value: unknown) {
10
+ super()
10
11
  schemas.context.validate(value)
11
12
 
12
13
  this.storage = value
13
14
  }
14
15
 
15
- public apply (): Output {
16
+ public async apply (): Promise<Output> {
16
17
  return null
17
18
  }
18
19
  }
@@ -2,16 +2,17 @@ import { Readable } from 'stream'
2
2
  import { NotFound } from '../../HTTP'
3
3
  import * as schemas from './schemas'
4
4
  import { Workflow } from './workflows'
5
+ import { Directive } from './Directive'
5
6
  import type { Parameter } from '../../RTD'
6
7
  import type { Unit } from './workflows'
7
8
  import type { Maybe } from '@toa.io/types'
8
9
  import type { Component } from '@toa.io/core'
9
10
  import type { Output } from '../../io'
10
- import type { Directive, Input } from './types'
11
+ import type { Input } from './types'
11
12
  import type { Remotes } from '../../Remotes'
12
13
  import type { Entry } from '@toa.io/extensions.storages'
13
14
 
14
- export class Delete implements Directive {
15
+ export class Delete extends Directive {
15
16
  public readonly targeted = true
16
17
 
17
18
  private readonly workflow?: Workflow
@@ -19,6 +20,7 @@ export class Delete implements Directive {
19
20
  private storage: Component | null = null
20
21
 
21
22
  public constructor (options: Options | null, discovery: Promise<Component>, remotes: Remotes) {
23
+ super()
22
24
  schemas.remove.validate(options)
23
25
 
24
26
  if (options?.workflow !== undefined)
@@ -27,11 +29,16 @@ export class Delete implements Directive {
27
29
  this.discovery = discovery
28
30
  }
29
31
 
30
- public async apply (storage: string, request: Input, parameters: Parameter[]): Promise<Output> {
32
+ public async apply (storage: string, input: Input, parameters: Parameter[]): Promise<Output> {
31
33
  this.storage ??= await this.discovery
32
34
 
33
35
  const entry = await this.storage.invoke<Maybe<Entry>>('get',
34
- { input: { storage, path: request.url } })
36
+ {
37
+ input: {
38
+ storage,
39
+ path: input.request.url
40
+ }
41
+ })
35
42
 
36
43
  if (entry instanceof Error)
37
44
  throw new NotFound()
@@ -40,31 +47,36 @@ export class Delete implements Directive {
40
47
 
41
48
  if (this.workflow !== undefined) {
42
49
  output.status = 202
43
- output.body = Readable.from(this.execute(request, storage, entry, parameters))
50
+ output.body = Readable.from(this.execute(input, storage, entry, parameters))
44
51
  } else
45
- await this.delete(storage, request)
52
+ await this.delete(storage, input)
46
53
 
47
54
  return output
48
55
  }
49
56
 
50
- private async delete (storage: string, request: Input): Promise<void> {
57
+ private async delete (storage: string, input: Input): Promise<void> {
51
58
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
52
59
  await this.storage!.invoke('delete',
53
- { input: { storage, path: request.url } })
60
+ {
61
+ input: {
62
+ storage,
63
+ path: input.request.url
64
+ }
65
+ })
54
66
  }
55
67
 
56
68
  // eslint-disable-next-line max-params
57
69
  private async * execute
58
- (request: Input, storage: string, entry: Entry, parameters: Parameter[]): AsyncGenerator {
70
+ (input: Input, storage: string, entry: Entry, parameters: Parameter[]): AsyncGenerator {
59
71
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
60
- for await (const chunk of this.workflow!.execute(request, storage, entry, parameters)) {
72
+ for await (const chunk of this.workflow!.execute(input, storage, entry, parameters)) {
61
73
  yield chunk
62
74
 
63
75
  if (typeof chunk === 'object' && chunk !== null && 'error' in chunk)
64
76
  return
65
77
  }
66
78
 
67
- await this.delete(storage, request)
79
+ await this.delete(storage, input)
68
80
  }
69
81
  }
70
82
 
@@ -0,0 +1,10 @@
1
+ import type { Input } from './types'
2
+ import type { Parameter } from '../../RTD'
3
+ import type * as io from '../../io'
4
+
5
+ export abstract class Directive {
6
+ public readonly name = 'octets.' + this.constructor.name.toLowerCase()
7
+ public abstract readonly targeted: boolean
8
+
9
+ public abstract apply (storage: string, input: Input, parameters: Parameter[]): Promise<io.Output>
10
+ }
@@ -1,52 +1,61 @@
1
1
  import { posix } from 'node:path'
2
2
  import { Forbidden, NotFound } from '../../HTTP'
3
3
  import * as schemas from './schemas'
4
+ import { Directive } from './Directive'
4
5
  import type { Maybe } from '@toa.io/types'
5
6
  import type { Entry } from '@toa.io/extensions.storages'
6
7
  import type { Readable } from 'node:stream'
7
8
  import type { Component } from '@toa.io/core'
8
9
  import type { Output } from '../../io'
10
+ import type { Input } from './types'
9
11
 
10
- import type { Directive, Input } from './types'
11
-
12
- export class Fetch implements Directive {
12
+ export class Fetch extends Directive {
13
13
  public readonly targeted = true
14
14
 
15
- private readonly permissions: Required<Permissions> = { blob: true, meta: false }
15
+ private readonly permissions: Required<Permissions> = {
16
+ blob: true,
17
+ meta: false
18
+ }
19
+
16
20
  private readonly discovery: Promise<Component>
17
21
  private storage: Component = null as unknown as Component
18
22
 
19
23
  public constructor (permissions: Permissions | null, discovery: Promise<Component>) {
24
+ super()
20
25
  schemas.fetch.validate(permissions)
21
26
 
22
27
  Object.assign(this.permissions, permissions)
23
28
  this.discovery = discovery
24
29
  }
25
30
 
26
- public async apply (storage: string, request: Input): Promise<Output> {
31
+ public async apply (storage: string, input: Input): Promise<Output> {
27
32
  this.storage ??= await this.discovery
28
33
 
29
- const variant = posix.basename(request.url).includes('.')
30
- const metadata = request.subtype === 'octets.entry'
34
+ const variant = posix.basename(input.request.url).includes('.')
35
+ const metadata = input.subtype === 'octets.entry'
31
36
 
32
37
  if (!variant && metadata)
33
38
  if (this.permissions.meta)
34
- return this.get(storage, request)
39
+ return this.get(storage, input)
35
40
  else
36
41
  throw new Forbidden('Metadata is not accessible.')
37
42
 
38
43
  if (!variant && !this.permissions.blob)
39
44
  throw new Forbidden('BLOB variant must be specified.')
40
45
 
41
- return await this.fetch(storage, request)
46
+ return await this.fetch(storage, input)
42
47
  }
43
48
 
44
- private async fetch (storage: string, request: Input): Promise<Output> {
45
- if ('if-none-match' in request.headers)
49
+ private async fetch (storage: string, input: Input): Promise<Output> {
50
+ if ('if-none-match' in input.request.headers)
46
51
  return { status: 304 }
47
52
 
48
- const input = { storage, path: request.url }
49
- const result = await this.storage.invoke<Maybe<FetchResult>>('fetch', { input })
53
+ const result = await this.storage.invoke<Maybe<FetchResult>>('fetch', {
54
+ input: {
55
+ storage,
56
+ path: input.request.url
57
+ }
58
+ })
50
59
 
51
60
  if (result instanceof Error)
52
61
  throw new NotFound()
@@ -57,12 +66,19 @@ export class Fetch implements Directive {
57
66
  etag: result.checksum
58
67
  })
59
68
 
60
- return { headers, body: result.stream }
69
+ return {
70
+ headers,
71
+ body: result.stream
72
+ }
61
73
  }
62
74
 
63
- private async get (storage: string, request: Input): Promise<Output> {
64
- const input = { storage, path: request.url }
65
- const entry = await this.storage.invoke<Maybe<Entry>>('get', { input })
75
+ private async get (storage: string, input: Input): Promise<Output> {
76
+ const entry = await this.storage.invoke<Maybe<Entry>>('get', {
77
+ input: {
78
+ storage,
79
+ path: input.request.url
80
+ }
81
+ })
66
82
 
67
83
  if (entry instanceof Error)
68
84
  throw new NotFound()
@@ -1,14 +1,15 @@
1
1
  import { posix } from 'node:path'
2
2
  import { Forbidden, NotFound } from '../../HTTP'
3
3
  import * as schemas from './schemas'
4
+ import { Directive } from './Directive'
4
5
  import type { Entry } from '@toa.io/extensions.storages'
5
6
  import type { Maybe } from '@toa.io/types'
6
7
  import type { Component } from '@toa.io/core'
7
8
  import type { Output } from '../../io'
8
9
 
9
- import type { Directive, Input } from './types'
10
+ import type { Input } from './types'
10
11
 
11
- export class List implements Directive {
12
+ export class List extends Directive {
12
13
  public readonly targeted = false
13
14
 
14
15
  private readonly permissions: Required<Permissions> = { meta: false }
@@ -16,28 +17,33 @@ export class List implements Directive {
16
17
  private storage: Component | null = null
17
18
 
18
19
  public constructor (permissions: Permissions | null, discovery: Promise<Component>) {
20
+ super()
19
21
  schemas.list.validate(permissions)
20
22
 
21
23
  Object.assign(this.permissions, permissions)
22
24
  this.discovery = discovery
23
25
  }
24
26
 
25
- public async apply (storage: string, request: Input): Promise<Output> {
27
+ public async apply (storage: string, input: Input): Promise<Output> {
26
28
  this.storage ??= await this.discovery
27
29
 
28
- const metadata = request.subtype === 'octets.entries'
30
+ const metadata = input.subtype === 'octets.entries'
29
31
 
30
32
  if (metadata && !this.permissions.meta)
31
33
  throw new Forbidden('Metadata is not accessible.')
32
34
 
33
- const input = { storage, path: request.url }
34
- const list = await this.storage.invoke<Maybe<string[]>>('list', { input })
35
+ const list = await this.storage.invoke<Maybe<string[]>>('list', {
36
+ input: {
37
+ storage,
38
+ path: input.request.url
39
+ }
40
+ })
35
41
 
36
42
  if (list instanceof Error)
37
43
  throw new NotFound()
38
44
 
39
45
  const body = metadata
40
- ? await this.expand(storage, request.url, list)
46
+ ? await this.expand(storage, input.request.url, list)
41
47
  : list
42
48
 
43
49
  return { body }
@@ -47,7 +53,11 @@ export class List implements Directive {
47
53
  Promise<Array<Maybe<Entry>>> {
48
54
  const promises = list.map(async (id) => {
49
55
  const path = posix.join(prefix, id)
50
- const input = { storage, path }
56
+
57
+ const input = {
58
+ storage,
59
+ path
60
+ }
51
61
 
52
62
  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- ensured in `apply`
53
63
  return this.storage!.invoke<Maybe<Entry>>('get', { input })
@@ -4,16 +4,15 @@ import { Store } from './Store'
4
4
  import { Fetch } from './Fetch'
5
5
  import { List } from './List'
6
6
  import { Delete } from './Delete'
7
- import { Permute } from './Permute'
8
7
  import { WorkflowDirective } from './Workflow'
8
+ import type { Directive } from './Directive'
9
9
  import type { Output } from '../../io'
10
10
  import type { Component } from '@toa.io/core'
11
11
  import type { Remotes } from '../../Remotes'
12
- import type { Family } from '../../Directive'
13
- import type { Directive, Input } from './types'
14
- import type { Parameter } from '../../RTD'
12
+ import type { Parameter, DirectiveFamily } from '../../RTD'
13
+ import type { Input } from './types'
15
14
 
16
- export class Octets implements Family<Directive> {
15
+ export class Octets implements DirectiveFamily<Directive> {
17
16
  public readonly name: string = 'octets'
18
17
  public readonly mandatory: boolean = false
19
18
 
@@ -23,7 +22,7 @@ export class Octets implements Family<Directive> {
23
22
  const Class = DIRECTIVES[name]
24
23
 
25
24
  if (Class === undefined)
26
- throw new Error(`Directive '${name}' is not provided by the '${this.name}' family.`)
25
+ throw new Error(`Directive 'octets:${name}' is not implemented.`)
27
26
 
28
27
  this.discovery ??= remotes.discover('octets', 'storage')
29
28
 
@@ -46,15 +45,17 @@ export class Octets implements Family<Directive> {
46
45
  if (action === null)
47
46
  return null
48
47
 
48
+ // noinspection PointlessBooleanExpressionJS
49
49
  if (context === null)
50
50
  throw new Error('Octets context is not defined.')
51
51
 
52
- const targeted = input.path[input.path.length - 1] !== '/'
52
+ const targeted = input.request.url[input.request.url.length - 1] !== '/'
53
53
 
54
54
  if (targeted !== action.targeted)
55
55
  throw new NotFound(`Trailing slash is ${action.targeted ? 'redundant' : 'required'}.`)
56
56
 
57
- return await action.apply(context.storage, input, parameters)
57
+ // noinspection JSObjectNullOrUndefined
58
+ return await input.timing.capture(action.name, action.apply(context.storage, input, parameters))
58
59
  }
59
60
  }
60
61
 
@@ -64,7 +65,6 @@ const DIRECTIVES: Record<string, Constructor> = {
64
65
  fetch: Fetch,
65
66
  list: List,
66
67
  delete: Delete,
67
- permute: Permute,
68
68
  workflow: WorkflowDirective
69
69
  }
70
70