@toa.io/extensions.exposition 1.0.0-alpha.10 → 1.0.0-alpha.100

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 (540) 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 +19 -10
  10. package/components/identity.basic/operations/authenticate.d.ts +5 -1
  11. package/components/identity.basic/operations/authenticate.js +5 -2
  12. package/components/identity.basic/operations/authenticate.js.map +1 -1
  13. package/components/identity.basic/operations/incept.d.ts +12 -0
  14. package/components/identity.basic/operations/incept.js +26 -0
  15. package/components/identity.basic/operations/incept.js.map +1 -0
  16. package/components/identity.basic/operations/transit.d.ts +4 -4
  17. package/components/identity.basic/operations/transit.js +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 +16 -5
  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 +42 -17
  26. package/components/identity.federation/operations/authenticate.d.ts +13 -2
  27. package/components/identity.federation/operations/authenticate.js +10 -10
  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/incept.js +14 -0
  31. package/components/identity.federation/operations/incept.js.map +1 -0
  32. package/components/identity.federation/operations/lib/assertions-as-values.js +4 -2
  33. package/components/identity.federation/operations/lib/assertions-as-values.js.map +1 -1
  34. package/components/identity.federation/operations/lib/get.d.ts +1 -0
  35. package/components/identity.federation/operations/lib/get.js +64 -0
  36. package/components/identity.federation/operations/lib/get.js.map +1 -0
  37. package/components/identity.federation/operations/lib/jwt.d.ts +4 -5
  38. package/components/identity.federation/operations/lib/jwt.js +20 -16
  39. package/components/identity.federation/operations/lib/jwt.js.map +1 -1
  40. package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -1
  41. package/components/identity.federation/operations/types/configuration.d.ts +15 -0
  42. package/components/identity.federation/operations/types/configuration.js +3 -0
  43. package/components/identity.federation/operations/types/configuration.js.map +1 -0
  44. package/components/identity.federation/operations/{types.d.ts → types/context.d.ts} +10 -12
  45. package/{transpiled/directives/vary/embeddings/Embedding.js → components/identity.federation/operations/types/context.js} +1 -1
  46. package/components/identity.federation/operations/types/context.js.map +1 -0
  47. package/components/identity.federation/operations/types/entity.d.ts +6 -0
  48. package/components/identity.federation/operations/types/entity.js +3 -0
  49. package/components/identity.federation/operations/types/entity.js.map +1 -0
  50. package/components/identity.federation/operations/types/index.d.ts +3 -0
  51. package/components/identity.federation/operations/types/index.js +20 -0
  52. package/components/identity.federation/operations/types/index.js.map +1 -0
  53. package/components/identity.federation/source/authenticate.ts +25 -17
  54. package/components/identity.federation/source/incept.ts +26 -0
  55. package/components/identity.federation/source/lib/assertions-as-values.ts +5 -2
  56. package/components/identity.federation/source/lib/get.ts +82 -0
  57. package/components/identity.federation/source/lib/jwt.test.ts +127 -4
  58. package/components/identity.federation/source/lib/jwt.ts +26 -19
  59. package/components/identity.federation/source/types/configuration.ts +16 -0
  60. package/components/identity.federation/source/{types.ts → types/context.ts} +11 -12
  61. package/components/identity.federation/source/types/entity.ts +6 -0
  62. package/components/identity.federation/source/types/index.ts +3 -0
  63. package/components/identity.federation/tsconfig.json +5 -4
  64. package/components/identity.roles/manifest.toa.yaml +9 -8
  65. package/components/identity.roles/operations/grant.d.ts +1 -1
  66. package/components/identity.roles/operations/grant.js +6 -5
  67. package/components/identity.roles/operations/grant.js.map +1 -1
  68. package/components/identity.roles/operations/lib/Entity.d.ts +1 -1
  69. package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -1
  70. package/components/identity.roles/source/grant.ts +7 -6
  71. package/components/identity.roles/source/lib/Entity.ts +1 -1
  72. package/components/identity.tokens/manifest.toa.yaml +18 -4
  73. package/components/identity.tokens/operations/authenticate.d.ts +2 -2
  74. package/components/identity.tokens/operations/authenticate.js +12 -5
  75. package/components/identity.tokens/operations/authenticate.js.map +1 -1
  76. package/components/identity.tokens/operations/decrypt.js +1 -0
  77. package/components/identity.tokens/operations/decrypt.js.map +1 -1
  78. package/components/identity.tokens/operations/encrypt.js +5 -1
  79. package/components/identity.tokens/operations/encrypt.js.map +1 -1
  80. package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -1
  81. package/components/identity.tokens/operations/types.d.ts +8 -2
  82. package/components/identity.tokens/receivers/identity.bans.created.js +3 -0
  83. package/components/identity.tokens/source/authenticate.test.ts +11 -4
  84. package/components/identity.tokens/source/authenticate.ts +14 -6
  85. package/components/identity.tokens/source/decrypt.test.ts +5 -3
  86. package/components/identity.tokens/source/decrypt.ts +9 -8
  87. package/components/identity.tokens/source/encrypt.test.ts +26 -2
  88. package/components/identity.tokens/source/encrypt.ts +5 -1
  89. package/components/identity.tokens/source/types.ts +9 -2
  90. package/components/octets.storage/manifest.toa.yaml +10 -11
  91. package/components/octets.storage/operations/get.js +3 -3
  92. package/components/octets.storage/operations/head.js +7 -0
  93. package/components/octets.storage/operations/put.js +132 -0
  94. package/documentation/access.md +71 -29
  95. package/documentation/authorities.md +48 -0
  96. package/documentation/cache.md +8 -1
  97. package/documentation/components.md +48 -15
  98. package/documentation/flow.md +44 -0
  99. package/documentation/identity.md +26 -22
  100. package/documentation/introspection.md +82 -0
  101. package/documentation/map.md +73 -0
  102. package/documentation/octets.md +100 -68
  103. package/documentation/protocol.md +14 -4
  104. package/documentation/query.md +29 -4
  105. package/documentation/require.md +15 -0
  106. package/documentation/tree.md +13 -0
  107. package/features/access.feature +129 -48
  108. package/features/annotation.feature +1 -0
  109. package/features/auth.claims.feature +170 -0
  110. package/features/authorities.basic.feature +141 -0
  111. package/features/authorities.feature +32 -0
  112. package/features/authorities.federation.feature +100 -0
  113. package/features/authorities.tokens.feature +117 -0
  114. package/features/body.feature +2 -0
  115. package/features/cache.feature +109 -5
  116. package/features/cors.feature +7 -1
  117. package/features/debug.feature +34 -0
  118. package/features/directives.feature +3 -0
  119. package/features/dynamic.feature +48 -0
  120. package/features/errors.feature +32 -7
  121. package/features/etag.feature +109 -1
  122. package/features/flow.feature +96 -0
  123. package/features/identity.bans.feature +137 -0
  124. package/features/identity.basic.feature +87 -30
  125. package/features/identity.feature +18 -6
  126. package/features/identity.federation.feature +129 -14
  127. package/features/identity.roles.feature +112 -19
  128. package/features/identity.tokens.feature +54 -4
  129. package/features/introspection.feature +153 -0
  130. package/features/io.feature +38 -1
  131. package/features/map.feature +241 -0
  132. package/features/methods.feature +47 -0
  133. package/features/octets.cloudinary.feature +68 -0
  134. package/features/octets.download.feature +189 -0
  135. package/features/octets.entries.feature +13 -55
  136. package/features/octets.feature +84 -108
  137. package/features/octets.head.feature +40 -0
  138. package/features/octets.meta.feature +65 -15
  139. package/features/octets.workflows.feature +242 -58
  140. package/features/probes.feature +14 -0
  141. package/features/{queries.feature → query.feature} +77 -2
  142. package/features/realtime.feature +34 -0
  143. package/features/require.feature +67 -0
  144. package/features/response.feature +38 -3
  145. package/features/routes.feature +93 -2
  146. package/features/server.feature +21 -0
  147. package/features/steps/.env.example +3 -0
  148. package/features/steps/Database.ts +16 -9
  149. package/features/steps/Gateway.ts +23 -6
  150. package/features/steps/IdP.ts +31 -25
  151. package/features/steps/Parameters.ts +44 -1
  152. package/features/steps/Realtime.ts +151 -0
  153. package/features/steps/components/echo/manifest.toa.yaml +14 -1
  154. package/features/steps/components/echo/operations/identity.js +7 -0
  155. package/features/steps/components/echo/operations/parameters.js +7 -0
  156. package/features/steps/components/echo.beacon/manifest.toa.yaml +2 -0
  157. package/features/steps/components/echo.beacon/operations/hello.js +5 -0
  158. package/features/steps/components/octets.tester/manifest.toa.yaml +22 -2
  159. package/features/steps/components/octets.tester/operations/authority.js +7 -0
  160. package/features/steps/components/octets.tester/operations/bar.js +0 -1
  161. package/features/steps/components/octets.tester/operations/baz.js +0 -2
  162. package/features/steps/components/octets.tester/operations/foo.js +1 -2
  163. package/features/steps/components/octets.tester/operations/redirect.js +12 -0
  164. package/features/steps/components/octets.tester/operations/yex.js +16 -0
  165. package/features/steps/components/octets.tester/operations/yield.js +13 -0
  166. package/features/steps/components/pots/manifest.toa.yaml +14 -3
  167. package/features/steps/components/users/manifest.toa.yaml +0 -1
  168. package/features/steps/components/users.properties/manifest.toa.yaml +1 -1
  169. package/features/streams.feature +5 -0
  170. package/features/timing.feature +4 -1
  171. package/package.json +21 -12
  172. package/readme.md +19 -14
  173. package/schemas/annotation.cos.yaml +1 -1
  174. package/schemas/method.cos.yaml +1 -1
  175. package/schemas/node.cos.yaml +2 -0
  176. package/schemas/octets/put.cos.yaml +25 -0
  177. package/schemas/query.cos.yaml +4 -10
  178. package/source/Annotation.ts +3 -3
  179. package/source/Branch.ts +1 -0
  180. package/source/Composition.ts +0 -6
  181. package/source/Context.ts +1 -0
  182. package/source/Directive.test.ts +1 -1
  183. package/source/Directive.ts +7 -6
  184. package/source/Endpoint.ts +59 -17
  185. package/source/Factory.ts +22 -13
  186. package/source/Gateway.ts +67 -18
  187. package/source/HTTP/Context.ts +26 -3
  188. package/source/HTTP/Server.ts +61 -47
  189. package/source/HTTP/exceptions.ts +13 -1
  190. package/source/HTTP/formats/index.ts +3 -3
  191. package/source/HTTP/messages.test.ts +45 -2
  192. package/source/HTTP/messages.ts +32 -8
  193. package/source/Introspection.ts +11 -0
  194. package/source/Mapping.ts +68 -21
  195. package/source/Query.test.ts +3 -3
  196. package/source/Query.ts +123 -33
  197. package/source/RTD/Context.ts +1 -1
  198. package/source/RTD/Endpoint.ts +3 -0
  199. package/source/RTD/Method.ts +16 -0
  200. package/source/RTD/Node.ts +29 -13
  201. package/source/RTD/Route.ts +5 -4
  202. package/source/RTD/Tree.ts +2 -2
  203. package/source/RTD/factory.ts +5 -2
  204. package/source/RTD/syntax/parse.test.ts +1 -1
  205. package/source/RTD/syntax/parse.ts +37 -24
  206. package/source/RTD/syntax/types.ts +6 -4
  207. package/source/Remotes.ts +7 -6
  208. package/source/Tenant.ts +6 -20
  209. package/source/deployment.ts +33 -23
  210. package/source/directives/auth/Anyone.ts +13 -0
  211. package/source/directives/auth/Authorization.ts +44 -21
  212. package/source/directives/auth/Delegate.ts +14 -4
  213. package/source/directives/auth/Echo.ts +19 -5
  214. package/source/directives/auth/Federation.ts +84 -0
  215. package/source/directives/auth/Incept.ts +4 -3
  216. package/source/directives/auth/Role.test.ts +53 -6
  217. package/source/directives/auth/Role.ts +22 -14
  218. package/source/directives/auth/Scheme.ts +1 -1
  219. package/source/directives/auth/split.ts +1 -1
  220. package/source/directives/auth/types.ts +2 -2
  221. package/source/directives/cache/Cache.ts +13 -6
  222. package/source/directives/cache/Control.ts +42 -16
  223. package/source/directives/cors/CORS.ts +2 -1
  224. package/source/directives/dev/Development.ts +1 -1
  225. package/source/directives/flow/Compose.ts +68 -0
  226. package/source/directives/flow/Fetch.ts +86 -0
  227. package/source/directives/flow/Flow.ts +42 -0
  228. package/source/directives/flow/index.ts +3 -0
  229. package/source/directives/flow/types.ts +7 -0
  230. package/source/directives/index.ts +4 -2
  231. package/source/directives/io/IO.ts +1 -1
  232. package/source/directives/io/Input.ts +4 -4
  233. package/source/directives/io/Output.ts +5 -4
  234. package/source/directives/map/Authority.ts +15 -0
  235. package/source/directives/map/Claims.ts +37 -0
  236. package/source/directives/map/Directive.ts +4 -0
  237. package/source/directives/map/Headers.ts +38 -0
  238. package/source/directives/map/Language.ts +42 -0
  239. package/source/directives/map/Languages.ts +11 -0
  240. package/source/directives/map/Map.ts +56 -0
  241. package/source/directives/map/Mapping.ts +13 -0
  242. package/source/directives/{vary → map}/Properties.ts +2 -4
  243. package/source/directives/map/Segments.ts +26 -0
  244. package/source/directives/map/index.ts +3 -0
  245. package/source/directives/octets/Context.ts +3 -2
  246. package/source/directives/octets/Delete.ts +11 -11
  247. package/source/directives/octets/Get.ts +86 -0
  248. package/source/directives/octets/Octets.ts +9 -12
  249. package/source/directives/octets/{Store.ts → Put.ts} +37 -21
  250. package/source/directives/octets/Workflow.ts +1 -1
  251. package/source/directives/octets/bytes.test.ts +30 -0
  252. package/source/directives/octets/bytes.ts +18 -0
  253. package/source/directives/octets/schemas.ts +4 -8
  254. package/source/directives/octets/workflows/Execution.ts +60 -8
  255. package/source/directives/octets/workflows/Workflow.ts +4 -4
  256. package/source/directives/require/Directive.ts +5 -0
  257. package/source/directives/require/Headers.ts +20 -0
  258. package/source/directives/require/Require.ts +28 -0
  259. package/source/directives/require/index.ts +3 -0
  260. package/source/exceptions.ts +14 -6
  261. package/source/manifest.ts +10 -11
  262. package/source/root.ts +5 -5
  263. package/source/schemas.ts +1 -1
  264. package/transpiled/Annotation.d.ts +3 -3
  265. package/transpiled/Branch.d.ts +1 -0
  266. package/transpiled/Composition.d.ts +0 -1
  267. package/transpiled/Composition.js +0 -4
  268. package/transpiled/Composition.js.map +1 -1
  269. package/transpiled/Context.d.ts +1 -0
  270. package/transpiled/Directive.js +7 -5
  271. package/transpiled/Directive.js.map +1 -1
  272. package/transpiled/Endpoint.d.ts +6 -4
  273. package/transpiled/Endpoint.js +39 -9
  274. package/transpiled/Endpoint.js.map +1 -1
  275. package/transpiled/Factory.d.ts +3 -2
  276. package/transpiled/Factory.js +18 -10
  277. package/transpiled/Factory.js.map +1 -1
  278. package/transpiled/Gateway.d.ts +3 -0
  279. package/transpiled/Gateway.js +50 -10
  280. package/transpiled/Gateway.js.map +1 -1
  281. package/transpiled/HTTP/Context.d.ts +9 -2
  282. package/transpiled/HTTP/Context.js +16 -2
  283. package/transpiled/HTTP/Context.js.map +1 -1
  284. package/transpiled/HTTP/Server.d.ts +13 -2
  285. package/transpiled/HTTP/Server.js +47 -40
  286. package/transpiled/HTTP/Server.js.map +1 -1
  287. package/transpiled/HTTP/exceptions.d.ts +7 -1
  288. package/transpiled/HTTP/exceptions.js +13 -1
  289. package/transpiled/HTTP/exceptions.js.map +1 -1
  290. package/transpiled/HTTP/formats/index.js +3 -3
  291. package/transpiled/HTTP/formats/index.js.map +1 -1
  292. package/transpiled/HTTP/messages.d.ts +2 -1
  293. package/transpiled/HTTP/messages.js +30 -7
  294. package/transpiled/HTTP/messages.js.map +1 -1
  295. package/transpiled/Introspection.d.ts +9 -0
  296. package/transpiled/Introspection.js +3 -0
  297. package/transpiled/Introspection.js.map +1 -0
  298. package/transpiled/Mapping.d.ts +11 -2
  299. package/transpiled/Mapping.js +50 -19
  300. package/transpiled/Mapping.js.map +1 -1
  301. package/transpiled/Query.d.ts +10 -1
  302. package/transpiled/Query.js +87 -30
  303. package/transpiled/Query.js.map +1 -1
  304. package/transpiled/RTD/Context.d.ts +1 -1
  305. package/transpiled/RTD/Endpoint.d.ts +1 -0
  306. package/transpiled/RTD/Method.d.ts +4 -0
  307. package/transpiled/RTD/Method.js +11 -0
  308. package/transpiled/RTD/Method.js.map +1 -1
  309. package/transpiled/RTD/Node.d.ts +4 -1
  310. package/transpiled/RTD/Node.js +23 -12
  311. package/transpiled/RTD/Node.js.map +1 -1
  312. package/transpiled/RTD/Route.d.ts +1 -1
  313. package/transpiled/RTD/Route.js +0 -1
  314. package/transpiled/RTD/Route.js.map +1 -1
  315. package/transpiled/RTD/Tree.d.ts +1 -1
  316. package/transpiled/RTD/Tree.js.map +1 -1
  317. package/transpiled/RTD/factory.js +5 -2
  318. package/transpiled/RTD/factory.js.map +1 -1
  319. package/transpiled/RTD/syntax/parse.js +34 -22
  320. package/transpiled/RTD/syntax/parse.js.map +1 -1
  321. package/transpiled/RTD/syntax/types.d.ts +5 -3
  322. package/transpiled/RTD/syntax/types.js +1 -1
  323. package/transpiled/RTD/syntax/types.js.map +1 -1
  324. package/transpiled/Remotes.d.ts +4 -4
  325. package/transpiled/Remotes.js +6 -5
  326. package/transpiled/Remotes.js.map +1 -1
  327. package/transpiled/Tenant.d.ts +5 -5
  328. package/transpiled/Tenant.js +2 -13
  329. package/transpiled/Tenant.js.map +1 -1
  330. package/transpiled/deployment.d.ts +1 -1
  331. package/transpiled/deployment.js +28 -20
  332. package/transpiled/deployment.js.map +1 -1
  333. package/transpiled/directives/auth/Anyone.d.ts +6 -0
  334. package/transpiled/directives/auth/Anyone.js +14 -0
  335. package/transpiled/directives/auth/Anyone.js.map +1 -0
  336. package/transpiled/directives/auth/Authorization.d.ts +1 -1
  337. package/transpiled/directives/auth/Authorization.js +32 -18
  338. package/transpiled/directives/auth/Authorization.js.map +1 -1
  339. package/transpiled/directives/auth/Delegate.d.ts +4 -2
  340. package/transpiled/directives/auth/Delegate.js +11 -4
  341. package/transpiled/directives/auth/Delegate.js.map +1 -1
  342. package/transpiled/directives/auth/Echo.d.ts +4 -3
  343. package/transpiled/directives/auth/Echo.js +13 -3
  344. package/transpiled/directives/auth/Echo.js.map +1 -1
  345. package/transpiled/directives/auth/Federation.d.ts +16 -0
  346. package/transpiled/directives/auth/Federation.js +57 -0
  347. package/transpiled/directives/auth/Federation.js.map +1 -0
  348. package/transpiled/directives/auth/Incept.js +4 -3
  349. package/transpiled/directives/auth/Incept.js.map +1 -1
  350. package/transpiled/directives/auth/Role.d.ts +4 -1
  351. package/transpiled/directives/auth/Role.js +20 -14
  352. package/transpiled/directives/auth/Role.js.map +1 -1
  353. package/transpiled/directives/auth/Scheme.js +1 -1
  354. package/transpiled/directives/auth/Scheme.js.map +1 -1
  355. package/transpiled/directives/auth/split.js +1 -1
  356. package/transpiled/directives/auth/split.js.map +1 -1
  357. package/transpiled/directives/auth/types.d.ts +1 -1
  358. package/transpiled/directives/cache/Cache.d.ts +3 -3
  359. package/transpiled/directives/cache/Cache.js +10 -4
  360. package/transpiled/directives/cache/Cache.js.map +1 -1
  361. package/transpiled/directives/cache/Control.d.ts +2 -1
  362. package/transpiled/directives/cache/Control.js +29 -12
  363. package/transpiled/directives/cache/Control.js.map +1 -1
  364. package/transpiled/directives/cors/CORS.js +2 -1
  365. package/transpiled/directives/cors/CORS.js.map +1 -1
  366. package/transpiled/directives/dev/Development.js +1 -1
  367. package/transpiled/directives/dev/Development.js.map +1 -1
  368. package/transpiled/directives/flow/Compose.d.ts +8 -0
  369. package/transpiled/directives/flow/Compose.js +74 -0
  370. package/transpiled/directives/flow/Compose.js.map +1 -0
  371. package/transpiled/directives/flow/Fetch.d.ts +12 -0
  372. package/transpiled/directives/flow/Fetch.js +58 -0
  373. package/transpiled/directives/flow/Fetch.js.map +1 -0
  374. package/transpiled/directives/flow/Flow.d.ts +10 -0
  375. package/transpiled/directives/flow/Flow.js +33 -0
  376. package/transpiled/directives/flow/Flow.js.map +1 -0
  377. package/transpiled/directives/flow/index.d.ts +2 -0
  378. package/transpiled/directives/flow/index.js +6 -0
  379. package/transpiled/directives/flow/index.js.map +1 -0
  380. package/transpiled/directives/flow/types.d.ts +6 -0
  381. package/transpiled/directives/flow/types.js.map +1 -0
  382. package/transpiled/directives/index.js +4 -2
  383. package/transpiled/directives/index.js.map +1 -1
  384. package/transpiled/directives/io/IO.js +1 -1
  385. package/transpiled/directives/io/IO.js.map +1 -1
  386. package/transpiled/directives/io/Input.js +2 -2
  387. package/transpiled/directives/io/Input.js.map +1 -1
  388. package/transpiled/directives/io/Output.js +2 -2
  389. package/transpiled/directives/io/Output.js.map +1 -1
  390. package/transpiled/directives/map/Authority.d.ts +6 -0
  391. package/transpiled/directives/map/Authority.js +19 -0
  392. package/transpiled/directives/map/Authority.js.map +1 -0
  393. package/transpiled/directives/map/Claims.d.ts +6 -0
  394. package/transpiled/directives/map/Claims.js +29 -0
  395. package/transpiled/directives/map/Claims.js.map +1 -0
  396. package/transpiled/directives/map/Directive.d.ts +3 -0
  397. package/transpiled/directives/map/Directive.js.map +1 -0
  398. package/transpiled/directives/map/Headers.d.ts +7 -0
  399. package/transpiled/directives/map/Headers.js +34 -0
  400. package/transpiled/directives/map/Headers.js.map +1 -0
  401. package/transpiled/directives/map/Language.d.ts +10 -0
  402. package/transpiled/directives/map/Language.js +38 -0
  403. package/transpiled/directives/map/Language.js.map +1 -0
  404. package/transpiled/directives/map/Languages.d.ts +4 -0
  405. package/transpiled/directives/map/Languages.js +17 -0
  406. package/transpiled/directives/map/Languages.js.map +1 -0
  407. package/transpiled/directives/map/Map.d.ts +11 -0
  408. package/transpiled/directives/map/Map.js +44 -0
  409. package/transpiled/directives/map/Map.js.map +1 -0
  410. package/transpiled/directives/map/Mapping.d.ts +8 -0
  411. package/transpiled/directives/map/Mapping.js +11 -0
  412. package/transpiled/directives/map/Mapping.js.map +1 -0
  413. package/transpiled/directives/{vary → map}/Properties.d.ts +2 -2
  414. package/transpiled/directives/{vary → map}/Properties.js +1 -3
  415. package/transpiled/directives/map/Properties.js.map +1 -0
  416. package/transpiled/directives/map/Segments.d.ts +6 -0
  417. package/transpiled/directives/map/Segments.js +25 -0
  418. package/transpiled/directives/map/Segments.js.map +1 -0
  419. package/transpiled/directives/map/index.d.ts +2 -0
  420. package/transpiled/directives/map/index.js +6 -0
  421. package/transpiled/directives/map/index.js.map +1 -0
  422. package/transpiled/directives/octets/Context.js +4 -24
  423. package/transpiled/directives/octets/Context.js.map +1 -1
  424. package/transpiled/directives/octets/Delete.js +8 -8
  425. package/transpiled/directives/octets/Delete.js.map +1 -1
  426. package/transpiled/directives/octets/{Fetch.d.ts → Get.d.ts} +5 -6
  427. package/transpiled/directives/octets/{Fetch.js → Get.js} +25 -29
  428. package/transpiled/directives/octets/Get.js.map +1 -0
  429. package/transpiled/directives/octets/Octets.js +9 -12
  430. package/transpiled/directives/octets/Octets.js.map +1 -1
  431. package/transpiled/directives/octets/{Store.d.ts → Put.d.ts} +7 -2
  432. package/transpiled/directives/octets/{Store.js → Put.js} +26 -19
  433. package/transpiled/directives/octets/Put.js.map +1 -0
  434. package/transpiled/directives/octets/Workflow.js +1 -1
  435. package/transpiled/directives/octets/Workflow.js.map +1 -1
  436. package/transpiled/directives/octets/bytes.d.ts +1 -0
  437. package/transpiled/directives/octets/bytes.js +21 -0
  438. package/transpiled/directives/octets/bytes.js.map +1 -0
  439. package/transpiled/directives/octets/schemas.d.ts +4 -8
  440. package/transpiled/directives/octets/schemas.js +3 -6
  441. package/transpiled/directives/octets/schemas.js.map +1 -1
  442. package/transpiled/directives/octets/workflows/Execution.d.ts +5 -1
  443. package/transpiled/directives/octets/workflows/Execution.js +44 -9
  444. package/transpiled/directives/octets/workflows/Execution.js.map +1 -1
  445. package/transpiled/directives/octets/workflows/Workflow.d.ts +1 -1
  446. package/transpiled/directives/octets/workflows/Workflow.js +2 -1
  447. package/transpiled/directives/octets/workflows/Workflow.js.map +1 -1
  448. package/transpiled/directives/require/Directive.d.ts +4 -0
  449. package/transpiled/directives/require/Directive.js +3 -0
  450. package/transpiled/directives/require/Directive.js.map +1 -0
  451. package/transpiled/directives/require/Headers.d.ts +7 -0
  452. package/transpiled/directives/require/Headers.js +19 -0
  453. package/transpiled/directives/require/Headers.js.map +1 -0
  454. package/transpiled/directives/require/Require.d.ts +9 -0
  455. package/transpiled/directives/require/Require.js +27 -0
  456. package/transpiled/directives/require/Require.js.map +1 -0
  457. package/transpiled/directives/require/index.d.ts +2 -0
  458. package/transpiled/directives/require/index.js +6 -0
  459. package/transpiled/directives/require/index.js.map +1 -0
  460. package/transpiled/exceptions.d.ts +3 -2
  461. package/transpiled/exceptions.js +8 -1
  462. package/transpiled/exceptions.js.map +1 -1
  463. package/transpiled/manifest.js +10 -11
  464. package/transpiled/manifest.js.map +1 -1
  465. package/transpiled/root.js +5 -5
  466. package/transpiled/root.js.map +1 -1
  467. package/transpiled/schemas.d.ts +1 -1
  468. package/transpiled/schemas.js +2 -2
  469. package/transpiled/schemas.js.map +1 -1
  470. package/transpiled/tsconfig.tsbuildinfo +1 -1
  471. package/components/identity.basic/operations/create.d.ts +0 -10
  472. package/components/identity.basic/operations/create.js +0 -10
  473. package/components/identity.basic/operations/create.js.map +0 -1
  474. package/components/identity.basic/source/create.ts +0 -18
  475. package/components/identity.federation/operations/create.d.ts +0 -10
  476. package/components/identity.federation/operations/create.js +0 -15
  477. package/components/identity.federation/operations/create.js.map +0 -1
  478. package/components/identity.federation/operations/schemas.d.ts +0 -59
  479. package/components/identity.federation/operations/schemas.js +0 -9
  480. package/components/identity.federation/operations/schemas.js.map +0 -1
  481. package/components/identity.federation/operations/types.js.map +0 -1
  482. package/components/identity.federation/source/create.ts +0 -26
  483. package/components/identity.federation/source/schemas.ts +0 -61
  484. package/components/octets.storage/operations/fetch.js +0 -46
  485. package/components/octets.storage/operations/list.js +0 -7
  486. package/components/octets.storage/operations/permute.js +0 -7
  487. package/components/octets.storage/operations/store.js +0 -11
  488. package/documentation/vary.md +0 -69
  489. package/features/steps/components/octets.tester/operations/diversify.js +0 -14
  490. package/features/vary.feature +0 -180
  491. package/schemas/octets/context.cos.yaml +0 -1
  492. package/schemas/octets/fetch.cos.yaml +0 -3
  493. package/schemas/octets/permute.cos.yaml +0 -1
  494. package/schemas/octets/store.cos.yaml +0 -3
  495. package/source/HTTP/Server.test.ts +0 -126
  496. package/source/directives/octets/Fetch.ts +0 -100
  497. package/source/directives/octets/List.ts +0 -72
  498. package/source/directives/octets/Permute.ts +0 -44
  499. package/source/directives/vary/Directive.ts +0 -6
  500. package/source/directives/vary/Embed.ts +0 -62
  501. package/source/directives/vary/Vary.ts +0 -48
  502. package/source/directives/vary/embeddings/Embedding.ts +0 -6
  503. package/source/directives/vary/embeddings/Header.ts +0 -32
  504. package/source/directives/vary/embeddings/Language.ts +0 -31
  505. package/source/directives/vary/embeddings/index.ts +0 -11
  506. package/source/directives/vary/index.ts +0 -3
  507. package/transpiled/directives/octets/Fetch.js.map +0 -1
  508. package/transpiled/directives/octets/List.d.ts +0 -16
  509. package/transpiled/directives/octets/List.js +0 -74
  510. package/transpiled/directives/octets/List.js.map +0 -1
  511. package/transpiled/directives/octets/Permute.d.ts +0 -11
  512. package/transpiled/directives/octets/Permute.js +0 -58
  513. package/transpiled/directives/octets/Permute.js.map +0 -1
  514. package/transpiled/directives/octets/Store.js.map +0 -1
  515. package/transpiled/directives/vary/Directive.d.ts +0 -5
  516. package/transpiled/directives/vary/Directive.js.map +0 -1
  517. package/transpiled/directives/vary/Embed.d.ts +0 -10
  518. package/transpiled/directives/vary/Embed.js +0 -49
  519. package/transpiled/directives/vary/Embed.js.map +0 -1
  520. package/transpiled/directives/vary/Properties.js.map +0 -1
  521. package/transpiled/directives/vary/Vary.d.ts +0 -10
  522. package/transpiled/directives/vary/Vary.js +0 -36
  523. package/transpiled/directives/vary/Vary.js.map +0 -1
  524. package/transpiled/directives/vary/embeddings/Embedding.d.ts +0 -5
  525. package/transpiled/directives/vary/embeddings/Embedding.js.map +0 -1
  526. package/transpiled/directives/vary/embeddings/Header.d.ts +0 -7
  527. package/transpiled/directives/vary/embeddings/Header.js +0 -28
  528. package/transpiled/directives/vary/embeddings/Header.js.map +0 -1
  529. package/transpiled/directives/vary/embeddings/Language.d.ts +0 -7
  530. package/transpiled/directives/vary/embeddings/Language.js +0 -28
  531. package/transpiled/directives/vary/embeddings/Language.js.map +0 -1
  532. package/transpiled/directives/vary/embeddings/index.d.ts +0 -5
  533. package/transpiled/directives/vary/embeddings/index.js +0 -10
  534. package/transpiled/directives/vary/embeddings/index.js.map +0 -1
  535. package/transpiled/directives/vary/index.d.ts +0 -2
  536. package/transpiled/directives/vary/index.js +0 -6
  537. package/transpiled/directives/vary/index.js.map +0 -1
  538. /package/schemas/octets/{list.cos.yaml → get.cos.yaml} +0 -0
  539. /package/{components/identity.federation/operations → transpiled/directives/flow}/types.js +0 -0
  540. /package/transpiled/directives/{vary → map}/Directive.js +0 -0
@@ -1,12 +1,13 @@
1
+ @security
1
2
  Feature: Access authorization
2
3
 
3
4
  Background:
4
5
  Given the `identity.basic` database contains:
5
6
  # developer:secret
6
7
  # user:12345
7
- | _id | username | password |
8
- | efe3a65ebbee47ed95a73edd911ea328 | developer | $2b$10$ZRSKkgZoGnrcTNA5w5eCcu3pxDzdTduhteVYXcp56AaNcilNkwJ.O |
9
- | e8e4f9c2a68d419b861403d71fabc915 | user | $2b$10$Frszmrmsz9iwSXzBbRRMKeDVKsNxozkrLNSsN.SnVC.KPxLtQr/bK |
8
+ | _id | authority | username | password |
9
+ | efe3a65ebbee47ed95a73edd911ea328 | nex | developer | $2b$10$ZRSKkgZoGnrcTNA5w5eCcu3pxDzdTduhteVYXcp56AaNcilNkwJ.O |
10
+ | e8e4f9c2a68d419b861403d71fabc915 | nex | user | $2b$10$Frszmrmsz9iwSXzBbRRMKeDVKsNxozkrLNSsN.SnVC.KPxLtQr/bK |
10
11
  And the `identity.bans` database is empty
11
12
 
12
13
  Scenario: Deny by default
@@ -20,6 +21,7 @@ Feature: Access authorization
20
21
  When the following request is received:
21
22
  """
22
23
  GET / HTTP/1.1
24
+ host: nex.toa.io
23
25
  """
24
26
  Then the following reply is sent:
25
27
  """
@@ -39,6 +41,7 @@ Feature: Access authorization
39
41
  When the following request is received:
40
42
  """
41
43
  GET / HTTP/1.1
44
+ host: nex.toa.io
42
45
  accept: application/yaml
43
46
  """
44
47
  Then the following reply is sent:
@@ -49,6 +52,56 @@ Feature: Access authorization
49
52
  access: granted!
50
53
  """
51
54
 
55
+ Scenario: Allow access to anyone
56
+ Given the annotation:
57
+ """yaml
58
+ /:
59
+ io:output: true
60
+ auth:anyone: true
61
+ GET:
62
+ dev:stub:
63
+ access: granted!
64
+ """
65
+ When the following request is received:
66
+ """
67
+ GET / HTTP/1.1
68
+ host: nex.toa.io
69
+ authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
70
+ accept: application/yaml
71
+ """
72
+ Then the following reply is sent:
73
+ """
74
+ 200 OK
75
+ content-type: application/yaml
76
+
77
+ access: granted!
78
+ """
79
+
80
+ # request without credentials
81
+ When the following request is received:
82
+ """
83
+ GET / HTTP/1.1
84
+ host: nex.toa.io
85
+ accept: application/yaml
86
+ """
87
+ Then the following reply is sent:
88
+ """
89
+ 401 Unauthorized
90
+ """
91
+
92
+ # request with invalid credentials
93
+ When the following request is received:
94
+ """
95
+ GET / HTTP/1.1
96
+ host: nex.toa.io
97
+ authorization: Basic bm9uOmV4aXN0ZW50
98
+ accept: application/yaml
99
+ """
100
+ Then the following reply is sent:
101
+ """
102
+ 401 Unauthorized
103
+ """
104
+
52
105
  Scenario: Deny access with credentials to a resource with anonymous access
53
106
  Given the annotation:
54
107
  """yaml
@@ -61,6 +114,7 @@ Feature: Access authorization
61
114
  When the following request is received:
62
115
  """
63
116
  GET / HTTP/1.1
117
+ host: nex.toa.io
64
118
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
65
119
  """
66
120
  Then the following reply is sent:
@@ -82,6 +136,7 @@ Feature: Access authorization
82
136
  When the following request is received:
83
137
  """
84
138
  GET /efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
139
+ host: nex.toa.io
85
140
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
86
141
  accept: application/yaml
87
142
  """
@@ -95,6 +150,7 @@ Feature: Access authorization
95
150
  When the following request is received:
96
151
  """
97
152
  GET /efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
153
+ host: nex.toa.io
98
154
  authorization: Basic dXNlcjoxMjM0NQ==
99
155
  accept: application/yaml
100
156
  """
@@ -121,6 +177,7 @@ Feature: Access authorization
121
177
  # identity with `developer` and `user` roles
122
178
  """
123
179
  GET / HTTP/1.1
180
+ host: nex.toa.io
124
181
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
125
182
  accept: application/yaml
126
183
  """
@@ -135,6 +192,7 @@ Feature: Access authorization
135
192
  # identity with no roles
136
193
  """
137
194
  GET / HTTP/1.1
195
+ host: nex.toa.io
138
196
  authorization: Basic dXNlcjoxMjM0NQ==
139
197
  """
140
198
  Then the following reply is sent:
@@ -163,6 +221,7 @@ Feature: Access authorization
163
221
  When the following request is received:
164
222
  """
165
223
  GET /nested/ HTTP/1.1
224
+ host: nex.toa.io
166
225
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
167
226
  accept: text/plain
168
227
  """
@@ -176,6 +235,7 @@ Feature: Access authorization
176
235
  When the following request is received:
177
236
  """
178
237
  GET /javascript/ HTTP/1.1
238
+ host: nex.toa.io
179
239
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
180
240
  """
181
241
  Then the following reply is sent:
@@ -202,6 +262,7 @@ Feature: Access authorization
202
262
  # identity with `developer` and `user` roles
203
263
  """
204
264
  GET / HTTP/1.1
265
+ host: nex.toa.io
205
266
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
206
267
  accept: application/yaml
207
268
  """
@@ -239,6 +300,7 @@ Feature: Access authorization
239
300
  When the following request is received:
240
301
  """
241
302
  GET /rust/efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
303
+ host: nex.toa.io
242
304
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
243
305
  accept: application/yaml
244
306
  """
@@ -252,6 +314,7 @@ Feature: Access authorization
252
314
  When the following request is received:
253
315
  """
254
316
  GET /javascript/efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
317
+ host: nex.toa.io
255
318
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
256
319
  """
257
320
  Then the following reply is sent:
@@ -272,8 +335,37 @@ Feature: Access authorization
272
335
  """
273
336
  When the following request is received:
274
337
  """
275
- GET /efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
276
- authorization: Token v3.local.9oEtVJkfRw4cOJ8M4DxuVuAN29dGT26XMYyPAoXtwrkdkiJVSVj46sMNAOdlxwKGszJZV_ReOL26dxDVlsQ7QAIuRhRPlvsHYNOhcD-LApoAXV0S3IK16EMoEv7tE9z70FCLC3WoIW9RIQ8PR3uZhAdhSgBilsVOpWrk4XtnfCIlVwhYMKu79a66oZZhV2Q7Kl3nfYsf84-6rAL_1H0MsqCDUHVXuIg
338
+ GET /identity/ HTTP/1.1
339
+ host: nex.toa.io
340
+ authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
341
+ accept: application/yaml
342
+ """
343
+ Then the following reply is sent:
344
+ """
345
+ 200 OK
346
+ authorization: Token ${{ developer.token }}
347
+
348
+ id: ${{ developer.id }}
349
+ """
350
+ When the following request is received:
351
+ """
352
+ GET /identity/ HTTP/1.1
353
+ host: nex.toa.io
354
+ authorization: Basic dXNlcjoxMjM0NQ==
355
+ accept: application/yaml
356
+ """
357
+ Then the following reply is sent:
358
+ """
359
+ 200 OK
360
+ authorization: Token ${{ user.token }}
361
+
362
+ id: ${{ user.id }}
363
+ """
364
+ When the following request is received:
365
+ """
366
+ GET /${{ developer.id }}/ HTTP/1.1
367
+ host: nex.toa.io
368
+ authorization: Token ${{ developer.token }}
277
369
  accept: application/yaml
278
370
  """
279
371
  Then the following reply is sent:
@@ -289,8 +381,9 @@ Feature: Access authorization
289
381
  """
290
382
  When the following request is received:
291
383
  """
292
- GET /efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
293
- authorization: Token v3.local.cjlxn4IJ9hI92KuksguzDx7_kYxgDFFGFnfNchf0cWnmos34dqX2XpTAUBd-LqgqfuH-lVGfNvjBUkw5JtHRBiIAVaPHF3Ncc0eafwgH2DPme9pndZL92fWryGnJ-sMHA28Q6UcXsIfhgd2JZ0n-585SBhwlosC3gKTcVHK7XNljeaTen4jZPw8uY-pdbsm6dDq3aKMzl8K78_BTTfiNPG2cI_aNuHw
384
+ GET /${{ user.id }}/ HTTP/1.1
385
+ host: nex.toa.io
386
+ authorization: Token ${{ developer.token }}
294
387
  accept: application/yaml
295
388
  """
296
389
  Then the following reply is sent:
@@ -314,6 +407,7 @@ Feature: Access authorization
314
407
  When the following request is received:
315
408
  """
316
409
  GET / HTTP/1.1
410
+ host: nex.toa.io
317
411
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
318
412
  accept: application/yaml
319
413
  """
@@ -328,6 +422,7 @@ Feature: Access authorization
328
422
  When the following request is received:
329
423
  """
330
424
  GET / HTTP/1.1
425
+ host: nex.toa.io
331
426
  authorization: Token ${{ token }}
332
427
  accept: application/yaml
333
428
  """
@@ -354,6 +449,7 @@ Feature: Access authorization
354
449
  When the following request is received:
355
450
  """
356
451
  GET /efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
452
+ host: nex.toa.io
357
453
  authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
358
454
  accept: application/yaml
359
455
  """
@@ -367,6 +463,7 @@ Feature: Access authorization
367
463
  When the following request is received:
368
464
  """
369
465
  GET /efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
466
+ host: nex.toa.io
370
467
  authorization: Token v3.local.9oEtVJkfRw4cOJ8M4DxuVuAN29dGT26XMYyPAoXtwrkdkiJVSVj46sMNAOdlxwKGszJZV_ReOL26dxDVlsQ7QAIuRhRPlvsHYNOhcD-LApoAXV0S3IK16EMoEv7tE9z70FCLC3WoIW9RIQ8PR3uZhAdhSgBilsVOpWrk4XtnfCIlVwhYMKu79a66oZZhV2Q7Kl3nfYsf84-6rAL_1H0MsqCDUHVXuIg
371
468
  accept: text/plain
372
469
  """
@@ -374,12 +471,12 @@ Feature: Access authorization
374
471
  """
375
472
  403 Forbidden
376
473
 
377
- Basic authentication scheme is required to access this resource.
474
+ Basic authentication scheme is required to access this resource
378
475
  """
379
476
 
380
477
  Scenario: Adding a role without required permissions
381
478
 
382
- Trunk directives should not be applied to the Identity management resources.
479
+ Trunk directives should not be applied to the Identity management resources
383
480
 
384
481
  Given the annotation:
385
482
  """yaml
@@ -389,6 +486,7 @@ Feature: Access authorization
389
486
  When the following request is received:
390
487
  """
391
488
  POST /identity/roles/efe3a65ebbee47ed95a73edd911ea328/ HTTP/1.1
489
+ host: nex.toa.io
392
490
  content-type: application/yaml
393
491
 
394
492
  role: developer
@@ -398,63 +496,46 @@ Feature: Access authorization
398
496
  401 Unauthorized
399
497
  """
400
498
 
401
- Scenario: Banning an Identity
499
+ Scenario: Authorization delegation
402
500
  Given the `identity.roles` database contains:
403
- | _id | identity | role |
404
- | 775a648d054e4ce1a65f8f17e5b51803 | efe3a65ebbee47ed95a73edd911ea328 | system |
405
- And the annotation:
501
+ | _id | identity | role |
502
+ | 775a648d054e4ce1a65f8f17e5b51803 | efe3a65ebbee47ed95a73edd911ea328 | developer |
503
+ And the `echo` is running with the following manifest:
406
504
  """yaml
407
- /:
408
- /:id:
505
+ exposition:
506
+ /:
409
507
  io:output: true
410
- auth:id: id
411
- GET:
412
- dev:stub:
413
- access: granted!
414
- """
415
- And the `identity.tokens` configuration:
416
- """yaml
417
- refresh: 1
508
+ auth:delegate: identity
509
+ GET: identity
418
510
  """
419
511
  When the following request is received:
420
512
  """
421
- GET /e8e4f9c2a68d419b861403d71fabc915/ HTTP/1.1
422
- authorization: Basic dXNlcjoxMjM0NQ==
513
+ GET /echo/ HTTP/1.1
514
+ host: nex.toa.io
515
+ authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
516
+ accept: application/yaml
423
517
  """
424
518
  Then the following reply is sent:
425
519
  """
426
520
  200 OK
427
521
  authorization: Token ${{ token }}
428
- """
429
- When the following request is received:
430
- """
431
- PUT /identity/bans/e8e4f9c2a68d419b861403d71fabc915/ HTTP/1.1
432
- authorization: Basic ZGV2ZWxvcGVyOnNlY3JldA==
433
- content-type: application/yaml
434
522
 
435
- banned: true
436
- """
437
- Then the following reply is sent:
438
- """
439
- 200 OK
523
+ identity:
524
+ id: efe3a65ebbee47ed95a73edd911ea328
525
+ roles:
526
+ - developer
440
527
  """
441
- # accessing a resource with a banned Identity
442
528
  When the following request is received:
443
529
  """
444
- GET /e8e4f9c2a68d419b861403d71fabc915/ HTTP/1.1
445
- authorization: Basic dXNlcjoxMjM0NQ==
530
+ GET /echo/ HTTP/1.1
531
+ host: nex.toa.io
532
+ authorization: Token ${{ token }}
446
533
  """
447
534
  Then the following reply is sent:
448
535
  """
449
- 401 Unauthorized
450
- """
451
- Then after 1 second
452
- When the following request is received:
453
- """
454
- GET /e8e4f9c2a68d419b861403d71fabc915/ HTTP/1.1
455
- authorization: Token ${{ token }}
536
+ 200 OK
456
537
  """
457
- Then the following reply is sent:
538
+ And the reply does not contain:
458
539
  """
459
- 401 Unauthorized
540
+ authorization: Token
460
541
  """
@@ -18,6 +18,7 @@ Feature: Annotation
18
18
  When the following request is received:
19
19
  """
20
20
  GET /foo/ HTTP/1.1
21
+ host: nex.toa.io
21
22
  accept: application/yaml
22
23
  """
23
24
  Then the following reply is sent:
@@ -0,0 +1,170 @@
1
+ @security
2
+ Feature: Federated identity authentication
3
+
4
+ Background:
5
+ Given the `identity.federation` database is empty
6
+ And local IDP is running
7
+ And the IDP token for Bob is issued
8
+ And the `identity.federation` configuration:
9
+ """yaml
10
+ trust:
11
+ - iss: http://localhost:44444
12
+ """
13
+
14
+ Scenario: Full claim
15
+ Given the annotation:
16
+ """yaml
17
+ /:
18
+ GET:
19
+ auth:claims:
20
+ iss: http://localhost:44444
21
+ aud: test
22
+ sub: Bob
23
+ dev:stub: ok
24
+ """
25
+
26
+ When the following request is received:
27
+ """
28
+ GET / HTTP/1.1
29
+ host: nex.toa.io
30
+ authorization: Bearer ${{ Bob.id_token }}
31
+ """
32
+ Then the following reply is sent:
33
+ """
34
+ 200 OK
35
+ """
36
+
37
+ Scenario: Only `sub`
38
+ Given the annotation:
39
+ """yaml
40
+ /:
41
+ GET:
42
+ auth:claims:
43
+ sub: Bob
44
+ dev:stub: ok
45
+ """
46
+
47
+ When the following request is received:
48
+ """
49
+ GET / HTTP/1.1
50
+ host: nex.toa.io
51
+ authorization: Bearer ${{ Bob.id_token }}
52
+ """
53
+ Then the following reply is sent:
54
+ """
55
+ 200 OK
56
+ """
57
+
58
+ Scenario: No `sub`
59
+ Given the annotation:
60
+ """yaml
61
+ /:
62
+ GET:
63
+ auth:claims:
64
+ iss: http://localhost:44444
65
+ aud: test
66
+ dev:stub: ok
67
+ """
68
+
69
+ When the following request is received:
70
+ """
71
+ GET / HTTP/1.1
72
+ host: nex.toa.io
73
+ authorization: Bearer ${{ Bob.id_token }}
74
+ """
75
+ Then the following reply is sent:
76
+ """
77
+ 200 OK
78
+ """
79
+
80
+ Scenario: `sub` mismatch
81
+ Given the annotation:
82
+ """yaml
83
+ /:
84
+ GET:
85
+ auth:claims:
86
+ iss: http://localhost:44444
87
+ sub: Alice
88
+ dev:stub: ok
89
+ """
90
+
91
+ When the following request is received:
92
+ """
93
+ GET / HTTP/1.1
94
+ host: nex.toa.io
95
+ authorization: Bearer ${{ Bob.id_token }}
96
+ """
97
+ Then the following reply is sent:
98
+ """
99
+ 403 Forbidden
100
+ """
101
+
102
+ Scenario: `aud` mismatch
103
+ Given the annotation:
104
+ """yaml
105
+ /:
106
+ GET:
107
+ auth:claims:
108
+ iss: http://localhost:44444
109
+ aud: goalkeepers
110
+ dev:stub: ok
111
+ """
112
+
113
+ When the following request is received:
114
+ """
115
+ GET / HTTP/1.1
116
+ host: nex.toa.io
117
+ authorization: Bearer ${{ Bob.id_token }}
118
+ """
119
+ Then the following reply is sent:
120
+ """
121
+ 403 Forbidden
122
+ """
123
+
124
+ Scenario: Matching authority and Route parameter
125
+ Given the annotation:
126
+ """yaml
127
+ authorities:
128
+ test: the.test.local
129
+ /:
130
+ /:id:
131
+ GET:
132
+ auth:claims:
133
+ aud: :authority
134
+ sub: /:id
135
+ dev:stub: ok
136
+ """
137
+
138
+ When the following request is received:
139
+ """
140
+ GET /Bob/ HTTP/1.1
141
+ host: the.test.local
142
+ authorization: Bearer ${{ Bob.id_token }}
143
+ """
144
+ Then the following reply is sent:
145
+ """
146
+ 200 OK
147
+ """
148
+
149
+ Scenario: `iss` matching authority common domain
150
+ Given the annotation:
151
+ """yaml
152
+ /:
153
+ /:id:
154
+ GET:
155
+ auth:claims:
156
+ iss: :domain
157
+ sub: /:id
158
+ dev:stub: ok
159
+ """
160
+
161
+ When the following request is received:
162
+ """
163
+ GET /Bob/ HTTP/1.1
164
+ host: localhost
165
+ authorization: Bearer ${{ Bob.id_token }}
166
+ """
167
+ Then the following reply is sent:
168
+ """
169
+ 200 OK
170
+ """
@@ -0,0 +1,141 @@
1
+ Feature: Basic credentials with authorities
2
+
3
+ Scenario: Basic credentials are scoped to authorities
4
+ Given the annotation:
5
+ """yaml
6
+ authorities:
7
+ one: the.one.com
8
+ two: the.two.com
9
+ /:
10
+ /:id:
11
+ auth:id: id
12
+ io:output: true
13
+ GET:
14
+ dev:stub: Hello
15
+ """
16
+
17
+ # create basic credentials within the `one` authority
18
+ When the following request is received:
19
+ """
20
+ POST /identity/basic/ HTTP/1.1
21
+ host: the.one.com
22
+ content-type: application/yaml
23
+ accept: application/yaml
24
+
25
+ username: #{{ id | set one.username }}
26
+ password: #{{ password 8 | set one.password }}
27
+ """
28
+ Then the following reply is sent:
29
+ """
30
+ 201 Created
31
+
32
+ id: ${{ one.id }}
33
+ """
34
+
35
+ # create basic credentials within the `two` authority
36
+ When the following request is received:
37
+ """
38
+ POST /identity/basic/ HTTP/1.1
39
+ host: the.two.com
40
+ content-type: application/yaml
41
+ accept: application/yaml
42
+
43
+ username: #{{ id | set two.username }}
44
+ password: #{{ password 8 | set two.password }}
45
+ """
46
+ Then the following reply is sent:
47
+ """
48
+ 201 Created
49
+
50
+ id: ${{ two.id }}
51
+ """
52
+
53
+ # access the resource with the `one` authority
54
+ When the following request is received:
55
+ """
56
+ GET /${{ one.id }}/ HTTP/1.1
57
+ host: the.one.com
58
+ authorization: Basic #{{ basic one }}
59
+ """
60
+ Then the following reply is sent:
61
+ """
62
+ 200 OK
63
+ """
64
+ When the following request is received:
65
+ """
66
+ GET /${{ two.id }}/ HTTP/1.1
67
+ host: the.one.com
68
+ authorization: Basic #{{ basic two }}
69
+ """
70
+ Then the following reply is sent:
71
+ """
72
+ 401 Unauthorized
73
+ """
74
+
75
+ # access the resource with the `two` authority
76
+ When the following request is received:
77
+ """
78
+ GET /${{ one.id }}/ HTTP/1.1
79
+ host: the.two.com
80
+ authorization: Basic #{{ basic one }}
81
+ """
82
+ Then the following reply is sent:
83
+ """
84
+ 401 Unauthorized
85
+ """
86
+ When the following request is received:
87
+ """
88
+ GET /${{ two.id }}/ HTTP/1.1
89
+ host: the.two.com
90
+ authorization: Basic #{{ basic two }}
91
+ """
92
+ Then the following reply is sent:
93
+ """
94
+ 200 OK
95
+ """
96
+
97
+ # create `one` credentials in the `two` authority
98
+ When the following request is received:
99
+ """
100
+ POST /identity/basic/ HTTP/1.1
101
+ host: the.one.com
102
+ content-type: application/yaml
103
+ accept: application/yaml
104
+
105
+ username: ${{ one.username }}
106
+ password: ${{ one.password }}
107
+ """
108
+ Then the following reply is sent:
109
+ """
110
+ 409 Conflict
111
+ """
112
+ When the following request is received:
113
+ """
114
+ POST /identity/basic/ HTTP/1.1
115
+ host: the.two.com
116
+ content-type: application/yaml
117
+ accept: application/yaml
118
+
119
+ username: ${{ one.username }}
120
+ password: ${{ one.password }}
121
+ """
122
+ Then the following reply is sent:
123
+ """
124
+ 201 Created
125
+ """
126
+
127
+ # create `two` credentials in the `one` authority
128
+ When the following request is received:
129
+ """
130
+ POST /identity/basic/ HTTP/1.1
131
+ host: the.one.com
132
+ content-type: application/yaml
133
+ accept: application/yaml
134
+
135
+ username: ${{ two.username }}
136
+ password: ${{ two.password }}
137
+ """
138
+ Then the following reply is sent:
139
+ """
140
+ 201 Created
141
+ """
@@ -0,0 +1,32 @@
1
+ Feature: Authorities
2
+
3
+ Scenario: Accessing an authority
4
+ Given the annotation:
5
+ """yaml
6
+ authorities:
7
+ example: the.example.com
8
+ /:
9
+ anonymous: true
10
+ GET:
11
+ dev:stub: Hello
12
+ """
13
+ When the following request is received:
14
+ """
15
+ GET / HTTP/1.1
16
+ host: the.example.com
17
+ """
18
+ Then the following reply is sent:
19
+ """
20
+ 200 OK
21
+ """
22
+
23
+ # arbitrary authorities are also allowed
24
+ When the following request is received:
25
+ """
26
+ GET / HTTP/1.1
27
+ host: the.other.com
28
+ """
29
+ Then the following reply is sent:
30
+ """
31
+ 200 OK
32
+ """