@toa.io/extensions.exposition 0.24.0-alpha.9 → 1.0.0-alpha.2

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 (291) hide show
  1. package/components/context.toa.yaml +12 -0
  2. package/components/identity.bans/manifest.toa.yaml +1 -1
  3. package/components/identity.basic/manifest.toa.yaml +1 -1
  4. package/components/identity.basic/operations/authenticate.js +1 -2
  5. package/components/identity.basic/operations/authenticate.js.map +1 -1
  6. package/components/identity.basic/operations/transit.js.map +1 -1
  7. package/components/identity.basic/operations/tsconfig.tsbuildinfo +1 -1
  8. package/components/identity.basic/source/authenticate.ts +0 -1
  9. package/components/identity.federation/events/principal.js +22 -0
  10. package/components/identity.federation/manifest.toa.yaml +88 -0
  11. package/components/identity.federation/operations/assertions-as-values.cjs +45 -0
  12. package/components/identity.federation/operations/assertions-as-values.cjs.map +1 -0
  13. package/components/identity.federation/operations/assertions-as-values.d.cts +4 -0
  14. package/components/identity.federation/operations/authenticate.d.ts +3 -0
  15. package/components/identity.federation/operations/authenticate.js +20 -0
  16. package/components/identity.federation/operations/authenticate.js.map +1 -0
  17. package/components/identity.federation/operations/create.d.ts +10 -0
  18. package/components/identity.federation/operations/create.js +15 -0
  19. package/components/identity.federation/operations/create.js.map +1 -0
  20. package/components/identity.federation/operations/jwt.cjs +112 -0
  21. package/components/identity.federation/operations/jwt.cjs.map +1 -0
  22. package/components/identity.federation/operations/jwt.d.cts +19 -0
  23. package/components/identity.federation/operations/schemas.d.ts +43 -0
  24. package/components/identity.federation/operations/schemas.js +9 -0
  25. package/components/identity.federation/operations/schemas.js.map +1 -0
  26. package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -0
  27. package/components/identity.federation/operations/types.d.ts +51 -0
  28. package/components/identity.federation/operations/types.js +3 -0
  29. package/components/identity.federation/operations/types.js.map +1 -0
  30. package/components/identity.federation/source/assertions-as-values.cts +20 -0
  31. package/components/identity.federation/source/authenticate.ts +28 -0
  32. package/components/identity.federation/source/create.ts +26 -0
  33. package/components/identity.federation/source/jwt.cts +143 -0
  34. package/components/identity.federation/source/schemas.ts +45 -0
  35. package/components/identity.federation/source/types.ts +56 -0
  36. package/components/identity.federation/tsconfig.json +9 -0
  37. package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -1
  38. package/components/identity.tokens/manifest.toa.yaml +1 -1
  39. package/components/identity.tokens/operations/authenticate.js.map +1 -1
  40. package/components/identity.tokens/operations/decrypt.js.map +1 -1
  41. package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -1
  42. package/components/octets.storage/manifest.toa.yaml +1 -0
  43. package/components/octets.storage/operations/store.js +2 -2
  44. package/cucumber.js +0 -1
  45. package/documentation/components.md +24 -1
  46. package/documentation/identity.md +7 -7
  47. package/documentation/octets.md +90 -37
  48. package/documentation/protocol.md +21 -1
  49. package/documentation/query.md +1 -1
  50. package/documentation/vary.md +69 -0
  51. package/features/cors.feature +72 -0
  52. package/features/identity.feature +19 -3
  53. package/features/identity.federation.feature +125 -0
  54. package/features/octets.entries.feature +121 -0
  55. package/features/octets.feature +2 -28
  56. package/features/octets.meta.feature +65 -0
  57. package/features/octets.workflows.feature +138 -4
  58. package/features/response.feature +65 -0
  59. package/features/routes.feature +37 -0
  60. package/features/steps/Captures.ts +6 -0
  61. package/features/steps/Components.ts +18 -6
  62. package/features/steps/Gateway.ts +1 -2
  63. package/features/steps/HTTP.ts +34 -6
  64. package/features/steps/IdP.ts +120 -0
  65. package/features/steps/Parameters.ts +8 -2
  66. package/features/steps/Workspace.ts +5 -7
  67. package/features/steps/components/echo/operations/error.js +11 -0
  68. package/features/steps/components/octets.tester/manifest.toa.yaml +3 -0
  69. package/features/steps/components/octets.tester/operations/concat.js +7 -0
  70. package/features/steps/components/octets.tester/operations/echo.js +7 -0
  71. package/features/steps/components/users/manifest.toa.yaml +3 -0
  72. package/features/steps/components/users.properties/manifest.toa.yaml +13 -0
  73. package/features/steps/tsconfig.json +1 -1
  74. package/features/vary.feature +150 -0
  75. package/package.json +17 -18
  76. package/schemas/octets/delete.cos.yaml +2 -1
  77. package/schemas/octets/list.cos.yaml +2 -1
  78. package/source/Directive.test.ts +8 -2
  79. package/source/Directive.ts +19 -16
  80. package/source/Factory.ts +8 -7
  81. package/source/Gateway.ts +22 -8
  82. package/source/HTTP/Server.fixtures.ts +0 -1
  83. package/source/HTTP/Server.test.ts +61 -134
  84. package/source/HTTP/Server.ts +68 -37
  85. package/source/HTTP/formats/msgpack.ts +9 -6
  86. package/source/HTTP/formats/text.ts +1 -1
  87. package/source/HTTP/formats/yaml.ts +1 -1
  88. package/source/HTTP/messages.ts +15 -3
  89. package/source/Interception.ts +24 -0
  90. package/source/RTD/Directives.ts +2 -2
  91. package/source/RTD/Tree.ts +3 -0
  92. package/source/RTD/syntax/parse.ts +6 -6
  93. package/source/RTD/syntax/types.ts +1 -1
  94. package/source/deployment.ts +1 -2
  95. package/source/directives/auth/{Family.ts → Authorization.ts} +29 -33
  96. package/source/directives/auth/Incept.ts +1 -1
  97. package/source/directives/auth/Rule.ts +2 -2
  98. package/source/directives/auth/index.ts +2 -2
  99. package/source/directives/auth/schemes.ts +2 -1
  100. package/source/directives/auth/types.ts +9 -6
  101. package/source/directives/cache/{Family.ts → Cache.ts} +4 -5
  102. package/source/directives/cache/index.ts +2 -2
  103. package/source/directives/cache/types.ts +1 -1
  104. package/source/directives/cors/CORS.ts +54 -0
  105. package/source/directives/cors/index.ts +3 -0
  106. package/source/directives/dev/{Family.ts → Development.ts} +3 -4
  107. package/source/directives/dev/Stub.ts +4 -4
  108. package/source/directives/dev/Throw.ts +4 -4
  109. package/source/directives/dev/index.ts +2 -2
  110. package/source/directives/dev/types.ts +1 -1
  111. package/source/directives/index.ts +10 -6
  112. package/source/directives/octets/Context.ts +1 -1
  113. package/source/directives/octets/Delete.ts +50 -9
  114. package/source/directives/octets/Fetch.ts +18 -19
  115. package/source/directives/octets/List.ts +37 -7
  116. package/source/directives/octets/{Family.ts → Octets.ts} +7 -6
  117. package/source/directives/octets/Permute.ts +3 -3
  118. package/source/directives/octets/Store.ts +43 -99
  119. package/source/directives/octets/index.ts +2 -2
  120. package/source/directives/octets/schemas.ts +11 -6
  121. package/source/directives/octets/types.ts +4 -3
  122. package/source/directives/octets/workflow/Execution.ts +78 -0
  123. package/source/directives/octets/workflow/Workflow.ts +37 -0
  124. package/source/directives/octets/workflow/index.ts +1 -0
  125. package/source/directives/vary/Directive.ts +6 -0
  126. package/source/directives/vary/Embed.ts +62 -0
  127. package/source/directives/vary/Properties.ts +17 -0
  128. package/source/directives/vary/Vary.ts +48 -0
  129. package/source/directives/vary/embeddings/Embedding.ts +6 -0
  130. package/source/directives/vary/embeddings/Header.ts +30 -0
  131. package/source/directives/vary/embeddings/Language.ts +31 -0
  132. package/source/directives/vary/embeddings/index.ts +11 -0
  133. package/source/directives/vary/index.ts +3 -0
  134. package/source/io.ts +4 -0
  135. package/source/manifest.test.ts +6 -14
  136. package/source/manifest.ts +9 -6
  137. package/source/schemas.ts +7 -3
  138. package/transpiled/Composition.js.map +1 -1
  139. package/transpiled/Directive.d.ts +6 -7
  140. package/transpiled/Directive.js +12 -10
  141. package/transpiled/Directive.js.map +1 -1
  142. package/transpiled/Factory.d.ts +0 -1
  143. package/transpiled/Factory.js +7 -6
  144. package/transpiled/Factory.js.map +1 -1
  145. package/transpiled/Gateway.d.ts +8 -5
  146. package/transpiled/Gateway.js +12 -2
  147. package/transpiled/Gateway.js.map +1 -1
  148. package/transpiled/HTTP/Server.d.ts +5 -3
  149. package/transpiled/HTTP/Server.fixtures.d.ts +0 -1
  150. package/transpiled/HTTP/Server.fixtures.js +1 -2
  151. package/transpiled/HTTP/Server.fixtures.js.map +1 -1
  152. package/transpiled/HTTP/Server.js +50 -32
  153. package/transpiled/HTTP/Server.js.map +1 -1
  154. package/transpiled/HTTP/formats/msgpack.d.ts +2 -2
  155. package/transpiled/HTTP/formats/msgpack.js +8 -29
  156. package/transpiled/HTTP/formats/msgpack.js.map +1 -1
  157. package/transpiled/HTTP/formats/text.d.ts +3 -1
  158. package/transpiled/HTTP/formats/text.js.map +1 -1
  159. package/transpiled/HTTP/formats/yaml.js +1 -1
  160. package/transpiled/HTTP/formats/yaml.js.map +1 -1
  161. package/transpiled/HTTP/messages.d.ts +5 -0
  162. package/transpiled/HTTP/messages.js +8 -3
  163. package/transpiled/HTTP/messages.js.map +1 -1
  164. package/transpiled/Interception.d.ts +9 -0
  165. package/transpiled/Interception.js +19 -0
  166. package/transpiled/Interception.js.map +1 -0
  167. package/transpiled/Query.js.map +1 -1
  168. package/transpiled/RTD/Directives.d.ts +2 -2
  169. package/transpiled/RTD/Node.js.map +1 -1
  170. package/transpiled/RTD/Route.js.map +1 -1
  171. package/transpiled/RTD/Tree.js +2 -0
  172. package/transpiled/RTD/Tree.js.map +1 -1
  173. package/transpiled/RTD/syntax/parse.js +1 -1
  174. package/transpiled/RTD/syntax/parse.js.map +1 -1
  175. package/transpiled/RTD/syntax/types.js +1 -1
  176. package/transpiled/RTD/syntax/types.js.map +1 -1
  177. package/transpiled/deployment.js +1 -2
  178. package/transpiled/deployment.js.map +1 -1
  179. package/transpiled/directives/auth/{Family.d.ts → Authorization.d.ts} +4 -4
  180. package/transpiled/directives/auth/{Family.js → Authorization.js} +15 -8
  181. package/transpiled/directives/auth/Authorization.js.map +1 -0
  182. package/transpiled/directives/auth/Incept.js.map +1 -1
  183. package/transpiled/directives/auth/Role.js.map +1 -1
  184. package/transpiled/directives/auth/Rule.d.ts +2 -2
  185. package/transpiled/directives/auth/Rule.js.map +1 -1
  186. package/transpiled/directives/auth/index.d.ts +2 -2
  187. package/transpiled/directives/auth/index.js +4 -5
  188. package/transpiled/directives/auth/index.js.map +1 -1
  189. package/transpiled/directives/auth/schemes.js +2 -1
  190. package/transpiled/directives/auth/schemes.js.map +1 -1
  191. package/transpiled/directives/auth/types.d.ts +4 -4
  192. package/transpiled/directives/cache/{Family.d.ts → Cache.d.ts} +4 -5
  193. package/transpiled/directives/cache/{Family.js → Cache.js} +4 -2
  194. package/transpiled/directives/cache/{Family.js.map → Cache.js.map} +1 -1
  195. package/transpiled/directives/cache/index.d.ts +2 -2
  196. package/transpiled/directives/cache/index.js +4 -5
  197. package/transpiled/directives/cache/index.js.map +1 -1
  198. package/transpiled/directives/cache/types.d.ts +1 -1
  199. package/transpiled/directives/cors/CORS.d.ts +11 -0
  200. package/transpiled/directives/cors/CORS.js +44 -0
  201. package/transpiled/directives/cors/CORS.js.map +1 -0
  202. package/transpiled/directives/cors/index.d.ts +2 -0
  203. package/transpiled/directives/cors/index.js +6 -0
  204. package/transpiled/directives/cors/index.js.map +1 -0
  205. package/transpiled/directives/dev/{Family.d.ts → Development.d.ts} +3 -4
  206. package/transpiled/directives/dev/{Family.js → Development.js} +4 -2
  207. package/transpiled/directives/dev/Development.js.map +1 -0
  208. package/transpiled/directives/dev/Stub.d.ts +3 -3
  209. package/transpiled/directives/dev/Stub.js.map +1 -1
  210. package/transpiled/directives/dev/Throw.d.ts +3 -3
  211. package/transpiled/directives/dev/Throw.js.map +1 -1
  212. package/transpiled/directives/dev/index.d.ts +2 -2
  213. package/transpiled/directives/dev/index.js +4 -5
  214. package/transpiled/directives/dev/index.js.map +1 -1
  215. package/transpiled/directives/dev/types.d.ts +1 -1
  216. package/transpiled/directives/index.d.ts +3 -1
  217. package/transpiled/directives/index.js +9 -9
  218. package/transpiled/directives/index.js.map +1 -1
  219. package/transpiled/directives/octets/Context.d.ts +1 -1
  220. package/transpiled/directives/octets/Delete.d.ts +12 -3
  221. package/transpiled/directives/octets/Delete.js +32 -7
  222. package/transpiled/directives/octets/Delete.js.map +1 -1
  223. package/transpiled/directives/octets/Fetch.d.ts +5 -6
  224. package/transpiled/directives/octets/Fetch.js +11 -12
  225. package/transpiled/directives/octets/Fetch.js.map +1 -1
  226. package/transpiled/directives/octets/List.d.ts +7 -2
  227. package/transpiled/directives/octets/List.js +22 -4
  228. package/transpiled/directives/octets/List.js.map +1 -1
  229. package/transpiled/directives/octets/Octets.d.ts +12 -0
  230. package/transpiled/directives/octets/{Family.js → Octets.js} +6 -4
  231. package/transpiled/directives/octets/Octets.js.map +1 -0
  232. package/transpiled/directives/octets/Permute.d.ts +1 -1
  233. package/transpiled/directives/octets/Permute.js +2 -2
  234. package/transpiled/directives/octets/Permute.js.map +1 -1
  235. package/transpiled/directives/octets/Store.d.ts +10 -21
  236. package/transpiled/directives/octets/Store.js +25 -69
  237. package/transpiled/directives/octets/Store.js.map +1 -1
  238. package/transpiled/directives/octets/index.d.ts +2 -2
  239. package/transpiled/directives/octets/index.js +4 -5
  240. package/transpiled/directives/octets/index.js.map +1 -1
  241. package/transpiled/directives/octets/schemas.d.ts +11 -6
  242. package/transpiled/directives/octets/schemas.js.map +1 -1
  243. package/transpiled/directives/octets/types.d.ts +4 -3
  244. package/transpiled/directives/octets/workflow/Execution.d.ts +25 -0
  245. package/transpiled/directives/octets/workflow/Execution.js +55 -0
  246. package/transpiled/directives/octets/workflow/Execution.js.map +1 -0
  247. package/transpiled/directives/octets/workflow/Workflow.d.ts +12 -0
  248. package/transpiled/directives/octets/workflow/Workflow.js +25 -0
  249. package/transpiled/directives/octets/workflow/Workflow.js.map +1 -0
  250. package/transpiled/directives/octets/workflow/index.d.ts +1 -0
  251. package/transpiled/directives/octets/workflow/index.js +6 -0
  252. package/transpiled/directives/octets/workflow/index.js.map +1 -0
  253. package/transpiled/directives/vary/Directive.d.ts +5 -0
  254. package/transpiled/directives/vary/Directive.js +3 -0
  255. package/transpiled/directives/vary/Directive.js.map +1 -0
  256. package/transpiled/directives/vary/Embed.d.ts +10 -0
  257. package/transpiled/directives/vary/Embed.js +49 -0
  258. package/transpiled/directives/vary/Embed.js.map +1 -0
  259. package/transpiled/directives/vary/Properties.d.ts +9 -0
  260. package/transpiled/directives/vary/Properties.js +16 -0
  261. package/transpiled/directives/vary/Properties.js.map +1 -0
  262. package/transpiled/directives/vary/Vary.d.ts +10 -0
  263. package/transpiled/directives/vary/Vary.js +36 -0
  264. package/transpiled/directives/vary/Vary.js.map +1 -0
  265. package/transpiled/directives/vary/embeddings/Embedding.d.ts +5 -0
  266. package/transpiled/directives/vary/embeddings/Embedding.js +3 -0
  267. package/transpiled/directives/vary/embeddings/Embedding.js.map +1 -0
  268. package/transpiled/directives/vary/embeddings/Header.d.ts +7 -0
  269. package/transpiled/directives/vary/embeddings/Header.js +26 -0
  270. package/transpiled/directives/vary/embeddings/Header.js.map +1 -0
  271. package/transpiled/directives/vary/embeddings/Language.d.ts +7 -0
  272. package/transpiled/directives/vary/embeddings/Language.js +28 -0
  273. package/transpiled/directives/vary/embeddings/Language.js.map +1 -0
  274. package/transpiled/directives/vary/embeddings/index.d.ts +5 -0
  275. package/transpiled/directives/vary/embeddings/index.js +10 -0
  276. package/transpiled/directives/vary/embeddings/index.js.map +1 -0
  277. package/transpiled/directives/vary/index.d.ts +2 -0
  278. package/transpiled/directives/vary/index.js +6 -0
  279. package/transpiled/directives/vary/index.js.map +1 -0
  280. package/transpiled/io.d.ts +3 -0
  281. package/transpiled/io.js +3 -0
  282. package/transpiled/io.js.map +1 -0
  283. package/transpiled/manifest.js +10 -5
  284. package/transpiled/manifest.js.map +1 -1
  285. package/transpiled/schemas.d.ts +7 -3
  286. package/transpiled/schemas.js.map +1 -1
  287. package/transpiled/tsconfig.tsbuildinfo +1 -1
  288. package/transpiled/directives/auth/Family.js.map +0 -1
  289. package/transpiled/directives/dev/Family.js.map +0 -1
  290. package/transpiled/directives/octets/Family.d.ts +0 -12
  291. package/transpiled/directives/octets/Family.js.map +0 -1
@@ -0,0 +1,69 @@
1
+ # HTTP request details
2
+
3
+ The `vary` directives family provides the capability to include HTTP request details as input for an
4
+ operation call.
5
+
6
+ ## TL;DR
7
+
8
+ ```yaml
9
+ exposition:
10
+ realms:
11
+ toa: the.toa.io
12
+ /:
13
+ vary:languages: [en, fr]
14
+ GET:
15
+ vary:embed:
16
+ lang: language # predefined embeddings
17
+ realm: realm
18
+ token: :x-access-token # raw header value
19
+ endpoint: dummies.get
20
+ ```
21
+
22
+ ## Embeddings
23
+
24
+ Request parts are embedded into the operation call according to the mapping
25
+ defined by the `vary:embed` directive.
26
+ The keys in the embedding map are the names of the input properties details to be embedded to,
27
+ and the values are the names of the embedding functions.
28
+ If the value is an array, the first non-empty embedding function's result is used.
29
+
30
+ > If a property is already present in the input, the embedded value will overwrite its current
31
+ > value.
32
+
33
+ ### Realm
34
+
35
+ Realm is an identifier of a domain used to access the Exposition.
36
+ The list of domains is defined by the `vary:realms` directive,
37
+ which is a map of realm names to their domain names.
38
+
39
+ The `realm` embedding substitutes the realm identified based on the `host` request header.
40
+
41
+ ### Language
42
+
43
+ The `language` embedding substitutes the most matching language code based on the `accept-language`
44
+ request header and a list of supported languages defined by the `vary:languages` directive, and also
45
+ adds `accept-language` to the `vary` HTTP response header value.
46
+ If neither of the supported languages matches, the first supported language is used.
47
+
48
+ ### Raw header values
49
+
50
+ Keys in the embedding map starting with a semicolon (:) are the names of HTTP request headers whose
51
+ values to be embedded into an operation call.
52
+ The names of these headers are then included in the `vary` HTTP response header
53
+ and [Access-Control-Allow-Headers](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Allow-Headers)
54
+ of the [CORS](protocol.md#cors).
55
+
56
+ [Multiple header fields](https://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.2) are embedded
57
+ as a comma-separated list.
58
+
59
+ ### Fallbacks
60
+
61
+ If the embedding function is an array, the first non-empty resolved value is used.
62
+
63
+ ```yaml
64
+ vary:embed:
65
+ ip: # fallbacks
66
+ - :CloudFront-Viewer-Address
67
+ - :CF-Connecting-IP
68
+ - :X-Appengine-User-IP
69
+ ```
@@ -0,0 +1,72 @@
1
+ Feature: CORS Support
2
+
3
+ Scenario: Using CORS
4
+ Given the annotation:
5
+ """yaml
6
+ /:
7
+ anonymous: true
8
+ /foo:
9
+ GET:
10
+ dev:stub: Hello
11
+ """
12
+ When the following request is received:
13
+ """
14
+ OPTIONS / HTTP/1.1
15
+ origin: https://hello.world
16
+ """
17
+ Then the following reply is sent:
18
+ """
19
+ 204 No Content
20
+ access-control-allow-origin: https://hello.world
21
+ access-control-allow-methods: GET, POST, PUT, PATCH, DELETE
22
+ access-control-allow-headers: accept, authorization, content-type
23
+ access-control-allow-credentials: true
24
+ access-control-max-age: 3600
25
+ cache-control: public, max-age=3600
26
+ vary: origin
27
+ """
28
+ When the following request is received:
29
+ """
30
+ GET /foo/ HTTP/1.1
31
+ origin: https://hello.world
32
+ """
33
+ Then the following reply is sent:
34
+ """
35
+ 200 OK
36
+ access-control-allow-origin: https://hello.world
37
+ access-control-expose-headers: authorization, content-type, content-length, etag
38
+ vary: origin
39
+ """
40
+
41
+ Scenario: Errors contain CORS headers
42
+ Given the annotation:
43
+ """yaml
44
+ /:
45
+ /foo:
46
+ GET:
47
+ dev:stub: Hello
48
+ """
49
+ When the following request is received:
50
+ """
51
+ GET /bar/ HTTP/1.1
52
+ origin: https://hello.world
53
+ """
54
+ Then the following reply is sent:
55
+ """
56
+ 404 Not Found
57
+ access-control-allow-origin: https://hello.world
58
+ access-control-expose-headers: authorization, content-type, content-length, etag
59
+ vary: origin
60
+ """
61
+ When the following request is received:
62
+ """
63
+ GET /foo/ HTTP/1.1
64
+ origin: https://hello.world
65
+ """
66
+ Then the following reply is sent:
67
+ """
68
+ 401 Unauthorized
69
+ access-control-allow-origin: https://hello.world
70
+ access-control-expose-headers: authorization, content-type, content-length, etag
71
+ vary: origin
72
+ """
@@ -17,7 +17,7 @@ Feature: Identity resource
17
17
  Then the following reply is sent:
18
18
  """
19
19
  200 OK
20
- authorization: Token ${{ token }}
20
+ authorization: Token ${{ User.token }}
21
21
 
22
22
  id: efe3a65ebbee47ed95a73edd911ea328
23
23
  roles:
@@ -27,14 +27,30 @@ Feature: Identity resource
27
27
  When the following request is received:
28
28
  """
29
29
  GET /identity/ HTTP/1.1
30
- authorization: Token ${{ token }}
30
+ authorization: Token ${{ User.token }}
31
31
  accept: application/yaml
32
32
  """
33
33
  Then the following reply is sent:
34
34
  """
35
35
  200 OK
36
36
 
37
- id: efe3a65ebbee47ed95a73edd911ea328
37
+ id: ${{ User.id }}
38
+ roles:
39
+ - developer
40
+ - system:identity
41
+ """
42
+ # checking that it returns the same id for given token
43
+ When the following request is received:
44
+ """
45
+ GET /identity/ HTTP/1.1
46
+ authorization: Token ${{ User.token }}
47
+ accept: application/yaml
48
+ """
49
+ Then the following reply is sent:
50
+ """
51
+ 200 OK
52
+
53
+ id: ${{ User.id }}
38
54
  roles:
39
55
  - developer
40
56
  - system:identity
@@ -0,0 +1,125 @@
1
+ Feature: Identity Federation
2
+
3
+ Background:
4
+ Given the `identity.federation` database is empty
5
+ Given local IDP is running
6
+
7
+
8
+ Scenario: Getting identity for a new user
9
+ Given the `identity.federation` configuration:
10
+ """yaml
11
+ explicit_identity_creation: false
12
+ trust:
13
+ - issuer: http://localhost:44444
14
+ """
15
+ And the IDP token for User is issued
16
+ When the following request is received:
17
+ """
18
+ GET /identity/ HTTP/1.1
19
+ authorization: Bearer ${{ User.id_token }}
20
+ accept: application/yaml
21
+ content-type: application/yaml
22
+ """
23
+ Then the following reply is sent:
24
+ """
25
+ 200 OK
26
+ authorization: Token ${{ User.token }}
27
+
28
+ id: ${{ User.id }}
29
+ roles: []
30
+ scheme: bearer
31
+ """
32
+ # validate token
33
+ When the following request is received:
34
+ """
35
+ GET /identity/ HTTP/1.1
36
+ accept: application/yaml
37
+ authorization: Token ${{ User.token }}
38
+ """
39
+ Then the following reply is sent:
40
+ """
41
+ 200 OK
42
+ id: ${{ User.id }}
43
+ """
44
+ # ensuring identity idemptotency
45
+ When the following request is received:
46
+ """
47
+ GET /identity/ HTTP/1.1
48
+ authorization: Bearer ${{ User.id_token }}
49
+ accept: application/yaml
50
+ """
51
+ Then the following reply is sent:
52
+ """
53
+ 200 OK
54
+ id: ${{ User.id }}
55
+ """
56
+
57
+ Scenario: Creating an Identity using inception with existing credentials
58
+ Given the `identity.federation` configuration:
59
+ """yaml
60
+ trust:
61
+ - issuer: http://localhost:44444
62
+ """
63
+ Given the `users` is running with the following manifest:
64
+ """yaml
65
+ exposition:
66
+ /:
67
+ anonymous: true
68
+ POST:
69
+ incept: id
70
+ endpoint: transit
71
+ """
72
+ And the IDP token for Bill is issued
73
+ When the following request is received:
74
+ # identity inception
75
+ """
76
+ POST /users/ HTTP/1.1
77
+ authorization: Bearer ${{ Bill.id_token }}
78
+ accept: application/yaml
79
+ content-type: application/yaml
80
+
81
+ name: Bill Smith
82
+ """
83
+ Then the following reply is sent:
84
+ """
85
+ 201 Created
86
+ authorization: Token ${{ Bill.token }}
87
+
88
+ id: ${{ Bill.id }}
89
+ """
90
+ # check that both tokens corresponds to the same id
91
+ When the following request is received:
92
+ """
93
+ GET /identity/ HTTP/1.1
94
+ authorization: Token ${{ Bill.token }}
95
+ accept: application/yaml
96
+ """
97
+ Then the following reply is sent:
98
+ """
99
+ 200 OK
100
+ id: ${{ Bill.id }}
101
+ """
102
+ When the following request is received:
103
+ """
104
+ GET /identity/ HTTP/1.1
105
+ authorization: Bearer ${{ Bill.id_token }}
106
+ accept: application/yaml
107
+ """
108
+ Then the following reply is sent:
109
+ """
110
+ 200 OK
111
+ id: ${{ Bill.id }}
112
+ """
113
+ And the following request is received:
114
+ # same credentials
115
+ """
116
+ POST /users/ HTTP/1.1
117
+ authorization: Bearer ${{ Bill.id_token }}
118
+ content-type: text/plain
119
+
120
+ name: Mary Louis
121
+ """
122
+ Then the following reply is sent:
123
+ """
124
+ 403 Forbidden
125
+ """
@@ -0,0 +1,121 @@
1
+ Feature: Accessing entires
2
+
3
+ Scenario: Entries are not accessible by default
4
+ Given the annotation:
5
+ """yaml
6
+ /:
7
+ auth:anonymous: true
8
+ octets:context: octets
9
+ POST:
10
+ octets:store: ~
11
+ GET:
12
+ octets:list: ~
13
+ /*:
14
+ GET:
15
+ octets:fetch: ~
16
+ """
17
+ When the stream of `lenna.ascii` is received with the following headers:
18
+ """
19
+ POST / HTTP/1.1
20
+ content-type: application/octet-stream
21
+ """
22
+ Then the following reply is sent:
23
+ """
24
+ 201 Created
25
+ """
26
+ When the following request is received:
27
+ """
28
+ GET / HTTP/1.1
29
+ accept: application/vnd.toa.octets.entries+yaml
30
+ """
31
+ Then the following reply is sent:
32
+ """
33
+ 403 Forbidden
34
+
35
+ Metadata is not accessible.
36
+ """
37
+ When the following request is received:
38
+ """
39
+ GET /10cf16b458f759e0d617f2f3d83599ff HTTP/1.1
40
+ accept: text/vnd.toa.octets.entry+plain
41
+ """
42
+ Then the following reply is sent:
43
+ """
44
+ 403 Forbidden
45
+
46
+ Metadata is not accessible.
47
+ """
48
+
49
+ Scenario: Accessing entries
50
+ Given the annotation:
51
+ """yaml
52
+ /:
53
+ auth:anonymous: true
54
+ octets:context: octets
55
+ POST:
56
+ octets:store: ~
57
+ GET:
58
+ octets:list:
59
+ meta: true
60
+ /*:
61
+ GET:
62
+ octets:fetch:
63
+ meta: true
64
+ """
65
+ When the stream of `lenna.ascii` is received with the following headers:
66
+ """
67
+ POST / HTTP/1.1
68
+ accept: application/yaml
69
+ content-type: application/octet-stream
70
+ """
71
+ And the stream of `lenna.png` is received with the following headers:
72
+ """
73
+ POST / HTTP/1.1
74
+ accept: application/yaml
75
+ content-type: application/octet-stream
76
+ """
77
+ When the following request is received:
78
+ """
79
+ GET / HTTP/1.1
80
+ accept: application/yaml
81
+ """
82
+ Then the following reply is sent:
83
+ """
84
+ 200 OK
85
+ content-type: application/yaml
86
+
87
+ - 10cf16b458f759e0d617f2f3d83599ff
88
+ - 814a0034f5549e957ee61360d87457e5
89
+ """
90
+ When the following request is received:
91
+ """
92
+ GET / HTTP/1.1
93
+ accept: application/vnd.toa.octets.entries+yaml
94
+ """
95
+ Then the following reply is sent:
96
+ """
97
+ 200 OK
98
+ content-type: application/yaml
99
+
100
+ - id: 10cf16b458f759e0d617f2f3d83599ff
101
+ size: 8169
102
+ type: application/octet-stream
103
+ - id: 814a0034f5549e957ee61360d87457e5
104
+ size: 473831
105
+ type: image/png
106
+ """
107
+ When the following request is received:
108
+ """
109
+ GET /10cf16b458f759e0d617f2f3d83599ff HTTP/1.1
110
+ accept: application/vnd.toa.octets.entry+yaml
111
+ """
112
+ Then the following reply is sent:
113
+ """
114
+ 200 OK
115
+ content-type: application/yaml
116
+ content-length: 124
117
+
118
+ id: 10cf16b458f759e0d617f2f3d83599ff
119
+ type: application/octet-stream
120
+ size: 8169
121
+ """
@@ -70,17 +70,6 @@ Feature: Octets directive family
70
70
  """
71
71
  304 Not Modified
72
72
  """
73
- When the following request is received:
74
- """
75
- GET /10cf16b458f759e0d617f2f3d83599ff:meta HTTP/1.1
76
- accept: text/plain
77
- """
78
- Then the following reply is sent:
79
- """
80
- 403 Forbidden
81
-
82
- Metadata is not accessible.
83
- """
84
73
  When the following request is received:
85
74
  """
86
75
  GET / HTTP/1.1
@@ -245,10 +234,9 @@ Feature: Octets directive family
245
234
  Trailing slash is redundant.
246
235
  """
247
236
 
248
- Scenario: Accessing an Entry and the original BLOLB
237
+ Scenario: Original BLOLB is not accessible
249
238
  Given the annotation:
250
239
  """yaml
251
- debug: true
252
240
  /:
253
241
  auth:anonymous: true
254
242
  octets:context: octets
@@ -268,24 +256,10 @@ Feature: Octets directive family
268
256
  """
269
257
  201 Created
270
258
  """
271
- When the following request is received:
272
- """
273
- GET /10cf16b458f759e0d617f2f3d83599ff:meta HTTP/1.1
274
- accept: application/yaml
275
- """
276
- Then the following reply is sent:
277
- """
278
- 200 OK
279
- content-type: application/yaml
280
- content-length: 124
281
-
282
- id: 10cf16b458f759e0d617f2f3d83599ff
283
- type: application/octet-stream
284
- size: 8169
285
- """
286
259
  When the following request is received:
287
260
  """
288
261
  GET /10cf16b458f759e0d617f2f3d83599ff HTTP/1.1
262
+ accept: text/plain
289
263
  """
290
264
  Then the following reply is sent:
291
265
  """
@@ -0,0 +1,65 @@
1
+ Feature: Octets `content-meta` header
2
+
3
+ Scenario: Sending `content-meta` header
4
+ Given the `octets.tester` is running
5
+ And the annotation:
6
+ """yaml
7
+ /:
8
+ auth:anonymous: true
9
+ octets:context: octets
10
+ /*:
11
+ POST:
12
+ octets:store: ~
13
+ /*:
14
+ GET:
15
+ octets:fetch:
16
+ meta: true
17
+ """
18
+ When the stream of `lenna.ascii` is received with the following headers:
19
+ """
20
+ POST /meta-header/ HTTP/1.1
21
+ content-type: application/octet-stream
22
+ content-meta: foo, bar=baz=1
23
+ content-meta: baz=1
24
+ """
25
+ Then the following reply is sent:
26
+ """
27
+ 201 Created
28
+ """
29
+ When the following request is received:
30
+ """
31
+ GET /meta-header/10cf16b458f759e0d617f2f3d83599ff HTTP/1.1
32
+ accept: application/vnd.toa.octets.entry+yaml
33
+ """
34
+ Then the following reply is sent:
35
+ """
36
+ 200 OK
37
+
38
+ id: 10cf16b458f759e0d617f2f3d83599ff
39
+ type: application/octet-stream
40
+ size: 8169
41
+ meta:
42
+ foo: 'true'
43
+ bar: baz=1
44
+ baz: '1'
45
+ """
46
+
47
+ Scenario: CORS allows `content-meta` header
48
+ Given the annotation:
49
+ """yaml
50
+ /:
51
+ octets:context: octets
52
+ POST:
53
+ octets:store: ~
54
+ """
55
+ When the following request is received:
56
+ """
57
+ OPTIONS / HTTP/1.1
58
+ origin: http://example.com
59
+ """
60
+ Then the following reply is sent:
61
+ """
62
+ 204 No Content
63
+ access-control-allow-origin: http://example.com
64
+ access-control-allow-headers: accept, authorization, content-type, content-meta
65
+ """