@toa.io/extensions.exposition 1.0.0-alpha.0 → 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.
- package/components/context.toa.yaml +12 -0
- package/components/identity.bans/manifest.toa.yaml +15 -6
- package/components/identity.bans/operations/transit.d.ts +14 -0
- package/components/identity.bans/operations/transit.js +11 -0
- package/components/identity.bans/operations/transit.js.map +1 -0
- package/components/identity.bans/operations/tsconfig.tsbuildinfo +1 -0
- package/components/identity.bans/source/transit.ts +21 -0
- package/components/identity.bans/tsconfig.json +9 -0
- package/components/identity.basic/manifest.toa.yaml +21 -8
- package/components/identity.basic/operations/authenticate.d.ts +13 -0
- package/components/identity.basic/operations/authenticate.js +27 -0
- package/components/identity.basic/operations/authenticate.js.map +1 -0
- package/components/identity.basic/operations/incept.d.ts +12 -0
- package/components/identity.basic/operations/incept.js +26 -0
- package/components/identity.basic/operations/incept.js.map +1 -0
- package/components/identity.basic/operations/transit.d.ts +12 -0
- package/components/identity.basic/operations/transit.js +55 -0
- package/components/identity.basic/operations/transit.js.map +1 -0
- package/components/identity.basic/operations/tsconfig.tsbuildinfo +1 -0
- package/components/identity.basic/operations/types.d.ts +42 -0
- package/components/identity.basic/operations/types.js +3 -0
- package/components/identity.basic/operations/types.js.map +1 -0
- package/components/identity.basic/source/authenticate.ts +16 -6
- package/components/identity.basic/source/incept.ts +38 -0
- package/components/identity.basic/source/transit.ts +11 -9
- package/components/identity.basic/source/types.ts +8 -4
- package/components/identity.federation/events/principal.js +22 -0
- package/components/identity.federation/manifest.toa.yaml +119 -0
- package/components/identity.federation/operations/authenticate.d.ts +14 -0
- package/components/identity.federation/operations/authenticate.js +20 -0
- package/components/identity.federation/operations/authenticate.js.map +1 -0
- package/components/identity.federation/operations/incept.d.ts +11 -0
- package/components/identity.federation/operations/incept.js +14 -0
- package/components/identity.federation/operations/incept.js.map +1 -0
- package/components/identity.federation/operations/lib/assertions-as-values.d.ts +4 -0
- package/components/identity.federation/operations/lib/assertions-as-values.js +47 -0
- package/components/identity.federation/operations/lib/assertions-as-values.js.map +1 -0
- package/components/identity.federation/operations/lib/get.d.ts +1 -0
- package/components/identity.federation/operations/lib/get.js +64 -0
- package/components/identity.federation/operations/lib/get.js.map +1 -0
- package/components/identity.federation/operations/lib/jwt.d.ts +19 -0
- package/components/identity.federation/operations/lib/jwt.js +140 -0
- package/components/identity.federation/operations/lib/jwt.js.map +1 -0
- package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -0
- package/components/identity.federation/operations/types/configuration.d.ts +15 -0
- package/components/identity.federation/operations/types/configuration.js +3 -0
- package/components/identity.federation/operations/types/configuration.js.map +1 -0
- package/components/identity.federation/operations/types/context.d.ts +49 -0
- package/components/identity.federation/operations/types/context.js +3 -0
- package/components/identity.federation/operations/types/context.js.map +1 -0
- package/components/identity.federation/operations/types/entity.d.ts +6 -0
- package/components/identity.federation/operations/types/entity.js +3 -0
- package/components/identity.federation/operations/types/entity.js.map +1 -0
- package/components/identity.federation/operations/types/index.d.ts +3 -0
- package/components/identity.federation/operations/types/index.js +20 -0
- package/components/identity.federation/operations/types/index.js.map +1 -0
- package/components/identity.federation/source/authenticate.ts +36 -0
- package/components/identity.federation/source/incept.ts +26 -0
- package/components/identity.federation/source/lib/assertions-as-values.ts +22 -0
- package/components/identity.federation/source/lib/get.ts +82 -0
- package/components/identity.federation/source/lib/jwt.test.ts +179 -0
- package/components/identity.federation/source/lib/jwt.ts +178 -0
- package/components/identity.federation/source/types/configuration.ts +16 -0
- package/components/identity.federation/source/types/context.ts +55 -0
- package/components/identity.federation/source/types/entity.ts +6 -0
- package/components/identity.federation/source/types/index.ts +3 -0
- package/components/identity.federation/tsconfig.json +10 -0
- package/components/identity.roles/manifest.toa.yaml +18 -5
- package/components/identity.roles/operations/grant.d.ts +10 -0
- package/components/identity.roles/operations/grant.js +21 -0
- package/components/identity.roles/operations/grant.js.map +1 -0
- package/components/identity.roles/operations/lib/Entity.d.ts +5 -0
- package/components/identity.roles/operations/lib/Entity.js +3 -0
- package/components/identity.roles/operations/lib/Entity.js.map +1 -0
- package/components/identity.roles/operations/list.d.ts +2 -0
- package/components/identity.roles/operations/list.js +8 -0
- package/components/identity.roles/operations/list.js.map +1 -0
- package/components/identity.roles/operations/principal.d.ts +13 -0
- package/components/identity.roles/operations/principal.js +13 -0
- package/components/identity.roles/operations/principal.js.map +1 -0
- package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -0
- package/components/identity.roles/source/grant.ts +32 -0
- package/components/identity.roles/source/lib/Entity.ts +5 -0
- package/components/identity.roles/source/list.ts +2 -4
- package/components/identity.roles/source/principal.ts +10 -8
- package/components/identity.tokens/manifest.toa.yaml +18 -4
- package/components/identity.tokens/operations/authenticate.d.ts +9 -0
- package/components/identity.tokens/operations/authenticate.js +39 -0
- package/components/identity.tokens/operations/authenticate.js.map +1 -0
- package/components/identity.tokens/operations/decrypt.d.ts +3 -0
- package/components/identity.tokens/operations/decrypt.js +33 -0
- package/components/identity.tokens/operations/decrypt.js.map +1 -0
- package/components/identity.tokens/operations/encrypt.d.ts +8 -0
- package/components/identity.tokens/operations/encrypt.js +26 -0
- package/components/identity.tokens/operations/encrypt.js.map +1 -0
- package/components/identity.tokens/operations/revoke.d.ts +2 -0
- package/components/identity.tokens/operations/revoke.js +8 -0
- package/components/identity.tokens/operations/revoke.js.map +1 -0
- package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -0
- package/components/identity.tokens/operations/types.d.ts +46 -0
- package/components/identity.tokens/operations/types.js +3 -0
- package/components/identity.tokens/operations/types.js.map +1 -0
- package/components/identity.tokens/receivers/identity.bans.created.js +3 -0
- package/components/identity.tokens/source/authenticate.test.ts +11 -4
- package/components/identity.tokens/source/authenticate.ts +14 -6
- package/components/identity.tokens/source/decrypt.test.ts +5 -3
- package/components/identity.tokens/source/decrypt.ts +9 -8
- package/components/identity.tokens/source/encrypt.test.ts +26 -2
- package/components/identity.tokens/source/encrypt.ts +5 -1
- package/components/identity.tokens/source/types.ts +9 -2
- package/components/octets.storage/manifest.toa.yaml +10 -10
- package/components/octets.storage/operations/get.js +3 -3
- package/components/octets.storage/operations/head.js +7 -0
- package/components/octets.storage/operations/put.js +132 -0
- package/cucumber.js +0 -1
- package/documentation/access.md +80 -38
- package/documentation/authorities.md +48 -0
- package/documentation/cache.md +8 -1
- package/documentation/components.md +93 -24
- package/documentation/flow.md +44 -0
- package/documentation/identity.md +34 -23
- package/documentation/introspection.md +82 -0
- package/documentation/io.md +56 -0
- package/documentation/map.md +73 -0
- package/documentation/octets.md +162 -65
- package/documentation/protocol.md +34 -4
- package/documentation/query.md +79 -9
- package/documentation/require.md +15 -0
- package/documentation/tree.md +35 -4
- package/features/access.feature +141 -49
- package/features/annotation.feature +2 -0
- package/features/auth.claims.feature +170 -0
- package/features/authorities.basic.feature +141 -0
- package/features/authorities.feature +32 -0
- package/features/authorities.federation.feature +100 -0
- package/features/authorities.tokens.feature +117 -0
- package/features/body.feature +5 -1
- package/features/cache.feature +112 -5
- package/features/cors.feature +78 -0
- package/features/debug.feature +34 -0
- package/features/directives.feature +5 -0
- package/features/dynamic.feature +62 -7
- package/features/errors.feature +36 -10
- package/features/etag.feature +205 -0
- package/features/flow.feature +96 -0
- package/features/identity.bans.feature +137 -0
- package/features/identity.basic.feature +146 -21
- package/features/identity.feature +37 -9
- package/features/identity.federation.feature +268 -0
- package/features/identity.roles.feature +251 -7
- package/features/identity.tokens.feature +57 -4
- package/features/introspection.feature +153 -0
- package/features/io.feature +204 -0
- package/features/map.feature +241 -0
- package/features/methods.feature +47 -0
- package/features/octets.cloudinary.feature +68 -0
- package/features/octets.download.feature +189 -0
- package/features/octets.entries.feature +81 -0
- package/features/octets.feature +85 -133
- package/features/octets.head.feature +40 -0
- package/features/octets.meta.feature +116 -0
- package/features/octets.workflows.feature +391 -34
- package/features/probes.feature +14 -0
- package/features/{queries.feature → query.feature} +86 -3
- package/features/realtime.feature +34 -0
- package/features/require.feature +67 -0
- package/features/response.feature +103 -0
- package/features/routes.feature +145 -10
- package/features/server.feature +21 -0
- package/features/steps/.env.example +3 -0
- package/features/steps/Captures.ts +6 -0
- package/features/steps/Components.ts +18 -6
- package/features/steps/Database.ts +17 -10
- package/features/steps/Gateway.ts +25 -6
- package/features/steps/HTTP.ts +40 -87
- package/features/steps/IdP.ts +155 -0
- package/features/steps/Parameters.ts +51 -2
- package/features/steps/Realtime.ts +151 -0
- package/features/steps/Workspace.ts +5 -7
- package/features/steps/components/echo/manifest.toa.yaml +14 -0
- package/features/steps/components/echo/operations/error.js +11 -0
- package/features/steps/components/echo/operations/identity.js +7 -0
- package/features/steps/components/echo/operations/parameters.js +7 -0
- package/features/steps/components/echo.beacon/manifest.toa.yaml +2 -0
- package/features/steps/components/echo.beacon/operations/hello.js +5 -0
- package/features/steps/components/greeter/manifest.toa.yaml +1 -0
- package/features/steps/components/octets.tester/manifest.toa.yaml +26 -2
- package/features/steps/components/octets.tester/operations/authority.js +7 -0
- package/features/steps/components/octets.tester/operations/bar.js +0 -1
- package/features/steps/components/octets.tester/operations/baz.js +0 -2
- package/features/steps/components/octets.tester/operations/concat.js +7 -0
- package/features/steps/components/octets.tester/operations/echo.js +7 -0
- package/features/steps/components/octets.tester/operations/foo.js +1 -2
- package/features/steps/components/octets.tester/operations/redirect.js +12 -0
- package/features/steps/components/octets.tester/operations/yex.js +16 -0
- package/features/steps/components/octets.tester/operations/yield.js +13 -0
- package/features/steps/components/pots/manifest.toa.yaml +26 -6
- package/features/steps/components/sequences/manifest.toa.yaml +1 -0
- package/features/steps/components/users/manifest.toa.yaml +3 -0
- package/features/steps/components/users.properties/manifest.toa.yaml +14 -0
- package/features/steps/tsconfig.json +1 -1
- package/features/streams.feature +5 -0
- package/features/timing.feature +69 -0
- package/package.json +25 -20
- package/readme.md +19 -13
- package/schemas/annotation.cos.yaml +2 -1
- package/schemas/io/input.cos.yaml +3 -0
- package/schemas/io/message.cos.yaml +5 -0
- package/schemas/io/output.cos.yaml +5 -0
- package/schemas/method.cos.yaml +1 -1
- package/schemas/node.cos.yaml +2 -0
- package/schemas/octets/delete.cos.yaml +2 -1
- package/schemas/octets/{fetch.cos.yaml → get.cos.yaml} +0 -1
- package/schemas/octets/put.cos.yaml +25 -0
- package/schemas/octets/workflow.cos.yaml +12 -0
- package/schemas/query.cos.yaml +4 -10
- package/schemas/querystring.cos.yaml +1 -0
- package/source/Annotation.ts +3 -2
- package/source/Branch.ts +1 -0
- package/source/Composition.ts +0 -6
- package/source/Context.ts +7 -4
- package/source/Directive.test.ts +14 -8
- package/source/Directive.ts +30 -52
- package/source/Endpoint.ts +105 -16
- package/source/Factory.ts +37 -17
- package/source/Gateway.ts +94 -42
- package/source/HTTP/Context.ts +90 -0
- package/source/HTTP/Server.ts +115 -92
- package/source/HTTP/Timing.ts +40 -0
- package/source/HTTP/exceptions.ts +13 -1
- package/source/HTTP/formats/index.ts +3 -3
- package/source/HTTP/formats/msgpack.ts +9 -6
- package/source/HTTP/formats/text.ts +1 -1
- package/source/HTTP/formats/yaml.ts +1 -1
- package/source/HTTP/index.ts +1 -0
- package/source/HTTP/messages.test.ts +71 -9
- package/source/HTTP/messages.ts +66 -46
- package/source/Interception.ts +24 -0
- package/source/Introspection.ts +11 -0
- package/source/Mapping.ts +69 -23
- package/source/Query.test.ts +3 -3
- package/source/Query.ts +123 -33
- package/source/RTD/Context.ts +8 -11
- package/source/RTD/Directives.ts +28 -4
- package/source/RTD/Endpoint.ts +9 -4
- package/source/RTD/Match.ts +2 -7
- package/source/RTD/Method.ts +23 -13
- package/source/RTD/Node.ts +37 -22
- package/source/RTD/Route.ts +5 -4
- package/source/RTD/Tree.ts +20 -16
- package/source/RTD/factory.ts +7 -7
- package/source/RTD/syntax/parse.test.ts +1 -1
- package/source/RTD/syntax/parse.ts +41 -28
- package/source/RTD/syntax/types.ts +6 -4
- package/source/Remotes.ts +7 -6
- package/source/Tenant.ts +6 -20
- package/source/deployment.ts +35 -20
- package/source/directives/auth/Anonymous.ts +3 -2
- package/source/directives/auth/Anyone.ts +13 -0
- package/source/directives/auth/Authorization.ts +170 -0
- package/source/directives/auth/Delegate.ts +42 -0
- package/source/directives/auth/Echo.ts +19 -5
- package/source/directives/auth/Federation.ts +84 -0
- package/source/directives/auth/Incept.ts +14 -8
- package/source/directives/auth/Role.test.ts +53 -6
- package/source/directives/auth/Role.ts +27 -17
- package/source/directives/auth/Rule.ts +2 -2
- package/source/directives/auth/Scheme.ts +3 -3
- package/source/directives/auth/index.ts +2 -2
- package/source/directives/auth/schemes.ts +2 -1
- package/source/directives/auth/split.ts +1 -1
- package/source/directives/auth/types.ts +10 -7
- package/source/directives/cache/Cache.ts +42 -0
- package/source/directives/cache/Control.ts +47 -21
- package/source/directives/cache/index.ts +2 -2
- package/source/directives/cache/types.ts +2 -2
- package/source/directives/cors/CORS.ts +63 -0
- package/source/directives/cors/index.ts +3 -0
- package/source/directives/dev/{Family.ts → Development.ts} +5 -6
- package/source/directives/dev/Stub.ts +4 -4
- package/source/directives/dev/Throw.ts +4 -4
- package/source/directives/dev/index.ts +2 -2
- package/source/directives/dev/types.ts +1 -1
- package/source/directives/flow/Compose.ts +68 -0
- package/source/directives/flow/Fetch.ts +86 -0
- package/source/directives/flow/Flow.ts +42 -0
- package/source/directives/flow/index.ts +3 -0
- package/source/directives/flow/types.ts +7 -0
- package/source/directives/index.ts +13 -6
- package/source/directives/io/Directive.ts +11 -0
- package/source/directives/io/IO.ts +43 -0
- package/source/directives/io/Input.ts +50 -0
- package/source/directives/io/Message.ts +1 -0
- package/source/directives/io/Output.ts +70 -0
- package/source/directives/io/index.ts +3 -0
- package/source/directives/io/schemas.ts +12 -0
- package/source/directives/map/Authority.ts +15 -0
- package/source/directives/map/Claims.ts +37 -0
- package/source/directives/map/Directive.ts +4 -0
- package/source/directives/map/Headers.ts +38 -0
- package/source/directives/map/Language.ts +42 -0
- package/source/directives/map/Languages.ts +11 -0
- package/source/directives/map/Map.ts +56 -0
- package/source/directives/map/Mapping.ts +13 -0
- package/source/directives/map/Properties.ts +15 -0
- package/source/directives/map/Segments.ts +26 -0
- package/source/directives/map/index.ts +3 -0
- package/source/directives/octets/Context.ts +9 -7
- package/source/directives/octets/Delete.ts +65 -12
- package/source/directives/octets/Directive.ts +10 -0
- package/source/directives/octets/Get.ts +86 -0
- package/source/directives/octets/{Family.ts → Octets.ts} +22 -20
- package/source/directives/octets/Put.ts +142 -0
- package/source/directives/octets/Workflow.ts +48 -0
- package/source/directives/octets/bytes.test.ts +30 -0
- package/source/directives/octets/bytes.ts +18 -0
- package/source/directives/octets/index.ts +2 -2
- package/source/directives/octets/schemas.test.ts +21 -0
- package/source/directives/octets/schemas.ts +9 -6
- package/source/directives/octets/types.ts +2 -8
- package/source/directives/octets/workflows/Execution.ts +128 -0
- package/source/directives/octets/workflows/Workflow.ts +37 -0
- package/source/directives/octets/workflows/index.ts +1 -0
- package/source/directives/require/Directive.ts +5 -0
- package/source/directives/require/Headers.ts +20 -0
- package/source/directives/require/Require.ts +28 -0
- package/source/directives/require/index.ts +3 -0
- package/source/exceptions.ts +23 -11
- package/source/io.ts +4 -0
- package/source/manifest.test.ts +6 -14
- package/source/manifest.ts +18 -16
- package/source/root.ts +5 -0
- package/source/schemas.ts +7 -3
- package/transpiled/Annotation.d.ts +8 -0
- package/transpiled/Annotation.js +3 -0
- package/transpiled/Annotation.js.map +1 -0
- package/transpiled/Branch.d.ts +8 -0
- package/transpiled/Branch.js +3 -0
- package/transpiled/Branch.js.map +1 -0
- package/transpiled/Composition.d.ts +13 -0
- package/transpiled/Composition.js +39 -0
- package/transpiled/Composition.js.map +1 -0
- package/transpiled/Context.d.ts +8 -0
- package/transpiled/Context.js +3 -0
- package/transpiled/Context.js.map +1 -0
- package/transpiled/Directive.d.ts +18 -0
- package/transpiled/Directive.js +77 -0
- package/transpiled/Directive.js.map +1 -0
- package/transpiled/Endpoint.d.ts +24 -0
- package/transpiled/Endpoint.js +131 -0
- package/transpiled/Endpoint.js.map +1 -0
- package/transpiled/Factory.d.ts +10 -0
- package/transpiled/Factory.js +81 -0
- package/transpiled/Factory.js.map +1 -0
- package/transpiled/Gateway.d.ts +21 -0
- package/transpiled/Gateway.js +132 -0
- package/transpiled/Gateway.js.map +1 -0
- package/transpiled/HTTP/Context.d.ts +31 -0
- package/transpiled/HTTP/Context.js +61 -0
- package/transpiled/HTTP/Context.js.map +1 -0
- package/transpiled/HTTP/Server.d.ts +36 -0
- package/transpiled/HTTP/Server.js +148 -0
- package/transpiled/HTTP/Server.js.map +1 -0
- package/transpiled/HTTP/Timing.d.ts +10 -0
- package/transpiled/HTTP/Timing.js +29 -0
- package/transpiled/HTTP/Timing.js.map +1 -0
- package/transpiled/HTTP/exceptions.d.ts +40 -0
- package/transpiled/HTTP/exceptions.js +83 -0
- package/transpiled/HTTP/exceptions.js.map +1 -0
- package/transpiled/HTTP/formats/index.d.ts +10 -0
- package/transpiled/HTTP/formats/index.js +38 -0
- package/transpiled/HTTP/formats/index.js.map +1 -0
- package/transpiled/HTTP/formats/json.d.ts +6 -0
- package/transpiled/HTTP/formats/json.js +17 -0
- package/transpiled/HTTP/formats/json.js.map +1 -0
- package/transpiled/HTTP/formats/msgpack.d.ts +6 -0
- package/transpiled/HTTP/formats/msgpack.js +17 -0
- package/transpiled/HTTP/formats/msgpack.js.map +1 -0
- package/transpiled/HTTP/formats/text.d.ts +8 -0
- package/transpiled/HTTP/formats/text.js +15 -0
- package/transpiled/HTTP/formats/text.js.map +1 -0
- package/transpiled/HTTP/formats/yaml.d.ts +6 -0
- package/transpiled/HTTP/formats/yaml.js +41 -0
- package/transpiled/HTTP/formats/yaml.js.map +1 -0
- package/transpiled/HTTP/index.d.ts +4 -0
- package/transpiled/HTTP/index.js +21 -0
- package/transpiled/HTTP/index.js.map +1 -0
- package/transpiled/HTTP/messages.d.ts +20 -0
- package/transpiled/HTTP/messages.js +96 -0
- package/transpiled/HTTP/messages.js.map +1 -0
- package/transpiled/Interception.d.ts +9 -0
- package/transpiled/Interception.js +19 -0
- package/transpiled/Interception.js.map +1 -0
- package/transpiled/Introspection.d.ts +9 -0
- package/transpiled/Introspection.js +3 -0
- package/transpiled/Introspection.js.map +1 -0
- package/transpiled/Mapping.d.ts +17 -0
- package/transpiled/Mapping.js +69 -0
- package/transpiled/Mapping.js.map +1 -0
- package/transpiled/Query.d.ts +22 -0
- package/transpiled/Query.js +164 -0
- package/transpiled/Query.js.map +1 -0
- package/transpiled/RTD/Context.d.ts +12 -0
- package/transpiled/RTD/Context.js +3 -0
- package/transpiled/RTD/Context.js.map +1 -0
- package/transpiled/RTD/Directives.d.ts +22 -0
- package/transpiled/RTD/Directives.js +3 -0
- package/transpiled/RTD/Directives.js.map +1 -0
- package/transpiled/RTD/Endpoint.d.ts +12 -0
- package/transpiled/RTD/Endpoint.js +3 -0
- package/transpiled/RTD/Endpoint.js.map +1 -0
- package/transpiled/RTD/Match.d.ts +9 -0
- package/transpiled/RTD/Match.js +3 -0
- package/transpiled/RTD/Match.js.map +1 -0
- package/transpiled/RTD/Method.d.ts +13 -0
- package/transpiled/RTD/Method.js +27 -0
- package/transpiled/RTD/Method.js.map +1 -0
- package/transpiled/RTD/Node.d.ts +22 -0
- package/transpiled/RTD/Node.js +73 -0
- package/transpiled/RTD/Node.js.map +1 -0
- package/transpiled/RTD/Route.d.ts +14 -0
- package/transpiled/RTD/Route.js +48 -0
- package/transpiled/RTD/Route.js.map +1 -0
- package/transpiled/RTD/Tree.d.ts +14 -0
- package/transpiled/RTD/Tree.js +45 -0
- package/transpiled/RTD/Tree.js.map +1 -0
- package/transpiled/RTD/factory.d.ts +4 -0
- package/transpiled/RTD/factory.js +39 -0
- package/transpiled/RTD/factory.js.map +1 -0
- package/transpiled/RTD/index.d.ts +8 -0
- package/transpiled/RTD/index.js +38 -0
- package/transpiled/RTD/index.js.map +1 -0
- package/transpiled/RTD/segment.d.ts +8 -0
- package/transpiled/RTD/segment.js +25 -0
- package/transpiled/RTD/segment.js.map +1 -0
- package/transpiled/RTD/syntax/index.d.ts +2 -0
- package/transpiled/RTD/syntax/index.js +19 -0
- package/transpiled/RTD/syntax/index.js.map +1 -0
- package/transpiled/RTD/syntax/parse.d.ts +4 -0
- package/transpiled/RTD/syntax/parse.js +140 -0
- package/transpiled/RTD/syntax/parse.js.map +1 -0
- package/transpiled/RTD/syntax/types.d.ts +43 -0
- package/transpiled/RTD/syntax/types.js +5 -0
- package/transpiled/RTD/syntax/types.js.map +1 -0
- package/transpiled/Remotes.d.ts +9 -0
- package/transpiled/Remotes.js +26 -0
- package/transpiled/Remotes.js.map +1 -0
- package/transpiled/Tenant.d.ts +13 -0
- package/transpiled/Tenant.js +23 -0
- package/transpiled/Tenant.js.map +1 -0
- package/transpiled/deployment.d.ts +3 -0
- package/transpiled/deployment.js +79 -0
- package/transpiled/deployment.js.map +1 -0
- package/transpiled/directives/auth/Anonymous.d.ts +6 -0
- package/transpiled/directives/auth/Anonymous.js +16 -0
- package/transpiled/directives/auth/Anonymous.js.map +1 -0
- package/transpiled/directives/auth/Anyone.d.ts +6 -0
- package/transpiled/directives/auth/Anyone.js +14 -0
- package/transpiled/directives/auth/Anyone.js.map +1 -0
- package/transpiled/directives/auth/Authorization.d.ts +19 -0
- package/transpiled/directives/auth/Authorization.js +141 -0
- package/transpiled/directives/auth/Authorization.js.map +1 -0
- package/transpiled/directives/auth/Delegate.d.ts +10 -0
- package/transpiled/directives/auth/Delegate.js +34 -0
- package/transpiled/directives/auth/Delegate.js.map +1 -0
- package/transpiled/directives/auth/Echo.d.ts +7 -0
- package/transpiled/directives/auth/Echo.js +23 -0
- package/transpiled/directives/auth/Echo.js.map +1 -0
- package/transpiled/directives/auth/Federation.d.ts +16 -0
- package/transpiled/directives/auth/Federation.js +57 -0
- package/transpiled/directives/auth/Federation.js.map +1 -0
- package/transpiled/directives/auth/Id.d.ts +7 -0
- package/transpiled/directives/auth/Id.js +17 -0
- package/transpiled/directives/auth/Id.js.map +1 -0
- package/transpiled/directives/auth/Incept.d.ts +10 -0
- package/transpiled/directives/auth/Incept.js +64 -0
- package/transpiled/directives/auth/Incept.js.map +1 -0
- package/transpiled/directives/auth/Role.d.ts +14 -0
- package/transpiled/directives/auth/Role.js +52 -0
- package/transpiled/directives/auth/Role.js.map +1 -0
- package/transpiled/directives/auth/Rule.d.ts +9 -0
- package/transpiled/directives/auth/Rule.js +22 -0
- package/transpiled/directives/auth/Rule.js.map +1 -0
- package/transpiled/directives/auth/Scheme.d.ts +7 -0
- package/transpiled/directives/auth/Scheme.js +47 -0
- package/transpiled/directives/auth/Scheme.js.map +1 -0
- package/transpiled/directives/auth/index.d.ts +2 -0
- package/transpiled/directives/auth/index.js +6 -0
- package/transpiled/directives/auth/index.js.map +1 -0
- package/transpiled/directives/auth/schemes.d.ts +3 -0
- package/transpiled/directives/auth/schemes.js +10 -0
- package/transpiled/directives/auth/schemes.js.map +1 -0
- package/transpiled/directives/auth/split.d.ts +2 -0
- package/transpiled/directives/auth/split.js +38 -0
- package/transpiled/directives/auth/split.js.map +1 -0
- package/transpiled/directives/auth/types.d.ts +31 -0
- package/transpiled/directives/auth/types.js +3 -0
- package/transpiled/directives/auth/types.js.map +1 -0
- package/transpiled/directives/cache/Cache.d.ts +11 -0
- package/transpiled/directives/cache/Cache.js +34 -0
- package/transpiled/directives/cache/Cache.js.map +1 -0
- package/transpiled/directives/cache/Control.d.ts +10 -0
- package/transpiled/directives/cache/Control.js +59 -0
- package/transpiled/directives/cache/Control.js.map +1 -0
- package/transpiled/directives/cache/Exact.d.ts +4 -0
- package/transpiled/directives/cache/Exact.js +11 -0
- package/transpiled/directives/cache/Exact.js.map +1 -0
- package/transpiled/directives/cache/index.d.ts +2 -0
- package/transpiled/directives/cache/index.js +6 -0
- package/transpiled/directives/cache/index.js.map +1 -0
- package/transpiled/directives/cache/types.d.ts +7 -0
- package/transpiled/directives/cache/types.js +3 -0
- package/transpiled/directives/cache/types.js.map +1 -0
- package/transpiled/directives/cors/CORS.d.ts +10 -0
- package/transpiled/directives/cors/CORS.js +52 -0
- package/transpiled/directives/cors/CORS.js.map +1 -0
- package/transpiled/directives/cors/index.d.ts +2 -0
- package/transpiled/directives/cors/index.js +6 -0
- package/transpiled/directives/cors/index.js.map +1 -0
- package/transpiled/directives/dev/Development.d.ts +9 -0
- package/transpiled/directives/dev/Development.js +29 -0
- package/transpiled/directives/dev/Development.js.map +1 -0
- package/transpiled/directives/dev/Stub.d.ts +7 -0
- package/transpiled/directives/dev/Stub.js +14 -0
- package/transpiled/directives/dev/Stub.js.map +1 -0
- package/transpiled/directives/dev/Throw.d.ts +7 -0
- package/transpiled/directives/dev/Throw.js +14 -0
- package/transpiled/directives/dev/Throw.js.map +1 -0
- package/transpiled/directives/dev/index.d.ts +2 -0
- package/transpiled/directives/dev/index.js +6 -0
- package/transpiled/directives/dev/index.js.map +1 -0
- package/transpiled/directives/dev/types.d.ts +4 -0
- package/transpiled/directives/dev/types.js +3 -0
- package/transpiled/directives/dev/types.js.map +1 -0
- package/transpiled/directives/flow/Compose.d.ts +8 -0
- package/transpiled/directives/flow/Compose.js +74 -0
- package/transpiled/directives/flow/Compose.js.map +1 -0
- package/transpiled/directives/flow/Fetch.d.ts +12 -0
- package/transpiled/directives/flow/Fetch.js +58 -0
- package/transpiled/directives/flow/Fetch.js.map +1 -0
- package/transpiled/directives/flow/Flow.d.ts +10 -0
- package/transpiled/directives/flow/Flow.js +33 -0
- package/transpiled/directives/flow/Flow.js.map +1 -0
- package/transpiled/directives/flow/index.d.ts +2 -0
- package/transpiled/directives/flow/index.js +6 -0
- package/transpiled/directives/flow/index.js.map +1 -0
- package/transpiled/directives/flow/types.d.ts +6 -0
- package/transpiled/directives/flow/types.js +3 -0
- package/transpiled/directives/flow/types.js.map +1 -0
- package/transpiled/directives/index.d.ts +4 -0
- package/transpiled/directives/index.js +15 -0
- package/transpiled/directives/index.js.map +1 -0
- package/transpiled/directives/io/Directive.d.ts +8 -0
- package/transpiled/directives/io/Directive.js +3 -0
- package/transpiled/directives/io/Directive.js.map +1 -0
- package/transpiled/directives/io/IO.d.ts +9 -0
- package/transpiled/directives/io/IO.js +33 -0
- package/transpiled/directives/io/IO.js.map +1 -0
- package/transpiled/directives/io/Input.d.ts +11 -0
- package/transpiled/directives/io/Input.js +63 -0
- package/transpiled/directives/io/Input.js.map +1 -0
- package/transpiled/directives/io/Message.d.ts +1 -0
- package/transpiled/directives/io/Message.js +3 -0
- package/transpiled/directives/io/Message.js.map +1 -0
- package/transpiled/directives/io/Output.d.ts +13 -0
- package/transpiled/directives/io/Output.js +76 -0
- package/transpiled/directives/io/Output.js.map +1 -0
- package/transpiled/directives/io/index.d.ts +2 -0
- package/transpiled/directives/io/index.js +6 -0
- package/transpiled/directives/io/index.js.map +1 -0
- package/transpiled/directives/io/schemas.d.ts +7 -0
- package/transpiled/directives/io/schemas.js +14 -0
- package/transpiled/directives/io/schemas.js.map +1 -0
- package/transpiled/directives/map/Authority.d.ts +6 -0
- package/transpiled/directives/map/Authority.js +19 -0
- package/transpiled/directives/map/Authority.js.map +1 -0
- package/transpiled/directives/map/Claims.d.ts +6 -0
- package/transpiled/directives/map/Claims.js +29 -0
- package/transpiled/directives/map/Claims.js.map +1 -0
- package/transpiled/directives/map/Directive.d.ts +3 -0
- package/transpiled/directives/map/Directive.js +3 -0
- package/transpiled/directives/map/Directive.js.map +1 -0
- package/transpiled/directives/map/Headers.d.ts +7 -0
- package/transpiled/directives/map/Headers.js +34 -0
- package/transpiled/directives/map/Headers.js.map +1 -0
- package/transpiled/directives/map/Language.d.ts +10 -0
- package/transpiled/directives/map/Language.js +38 -0
- package/transpiled/directives/map/Language.js.map +1 -0
- package/transpiled/directives/map/Languages.d.ts +4 -0
- package/transpiled/directives/map/Languages.js +17 -0
- package/transpiled/directives/map/Languages.js.map +1 -0
- package/transpiled/directives/map/Map.d.ts +11 -0
- package/transpiled/directives/map/Map.js +44 -0
- package/transpiled/directives/map/Map.js.map +1 -0
- package/transpiled/directives/map/Mapping.d.ts +8 -0
- package/transpiled/directives/map/Mapping.js +11 -0
- package/transpiled/directives/map/Mapping.js.map +1 -0
- package/transpiled/directives/map/Properties.d.ts +9 -0
- package/transpiled/directives/map/Properties.js +14 -0
- package/transpiled/directives/map/Properties.js.map +1 -0
- package/transpiled/directives/map/Segments.d.ts +6 -0
- package/transpiled/directives/map/Segments.js +25 -0
- package/transpiled/directives/map/Segments.js.map +1 -0
- package/transpiled/directives/map/index.d.ts +2 -0
- package/transpiled/directives/map/index.js +6 -0
- package/transpiled/directives/map/index.js.map +1 -0
- package/transpiled/directives/octets/Context.d.ts +8 -0
- package/transpiled/directives/octets/Context.js +22 -0
- package/transpiled/directives/octets/Context.js.map +1 -0
- package/transpiled/directives/octets/Delete.d.ts +20 -0
- package/transpiled/directives/octets/Delete.js +84 -0
- package/transpiled/directives/octets/Delete.js.map +1 -0
- package/transpiled/directives/octets/Directive.d.ts +8 -0
- package/transpiled/directives/octets/Directive.js +8 -0
- package/transpiled/directives/octets/Directive.js.map +1 -0
- package/transpiled/directives/octets/Get.d.ts +17 -0
- package/transpiled/directives/octets/Get.js +88 -0
- package/transpiled/directives/octets/Get.js.map +1 -0
- package/transpiled/directives/octets/Octets.d.ts +12 -0
- package/transpiled/directives/octets/Octets.js +52 -0
- package/transpiled/directives/octets/Octets.js.map +1 -0
- package/transpiled/directives/octets/Put.d.ts +29 -0
- package/transpiled/directives/octets/Put.js +102 -0
- package/transpiled/directives/octets/Put.js.map +1 -0
- package/transpiled/directives/octets/Workflow.d.ts +15 -0
- package/transpiled/directives/octets/Workflow.js +59 -0
- package/transpiled/directives/octets/Workflow.js.map +1 -0
- package/transpiled/directives/octets/bytes.d.ts +1 -0
- package/transpiled/directives/octets/bytes.js +21 -0
- package/transpiled/directives/octets/bytes.js.map +1 -0
- package/transpiled/directives/octets/index.d.ts +2 -0
- package/transpiled/directives/octets/index.js +6 -0
- package/transpiled/directives/octets/index.js.map +1 -0
- package/transpiled/directives/octets/schemas.d.ts +9 -0
- package/transpiled/directives/octets/schemas.js +15 -0
- package/transpiled/directives/octets/schemas.js.map +1 -0
- package/transpiled/directives/octets/types.d.ts +5 -0
- package/transpiled/directives/octets/types.js +3 -0
- package/transpiled/directives/octets/types.js.map +1 -0
- package/transpiled/directives/octets/workflows/Execution.d.ts +29 -0
- package/transpiled/directives/octets/workflows/Execution.js +89 -0
- package/transpiled/directives/octets/workflows/Execution.js.map +1 -0
- package/transpiled/directives/octets/workflows/Workflow.d.ts +12 -0
- package/transpiled/directives/octets/workflows/Workflow.js +26 -0
- package/transpiled/directives/octets/workflows/Workflow.js.map +1 -0
- package/transpiled/directives/octets/workflows/index.d.ts +1 -0
- package/transpiled/directives/octets/workflows/index.js +6 -0
- package/transpiled/directives/octets/workflows/index.js.map +1 -0
- package/transpiled/directives/require/Directive.d.ts +4 -0
- package/transpiled/directives/require/Directive.js +3 -0
- package/transpiled/directives/require/Directive.js.map +1 -0
- package/transpiled/directives/require/Headers.d.ts +7 -0
- package/transpiled/directives/require/Headers.js +19 -0
- package/transpiled/directives/require/Headers.js.map +1 -0
- package/transpiled/directives/require/Require.d.ts +9 -0
- package/transpiled/directives/require/Require.js +27 -0
- package/transpiled/directives/require/Require.js.map +1 -0
- package/transpiled/directives/require/index.d.ts +2 -0
- package/transpiled/directives/require/index.js +6 -0
- package/transpiled/directives/require/index.js.map +1 -0
- package/transpiled/discovery.d.ts +1 -0
- package/transpiled/discovery.js +3 -0
- package/transpiled/discovery.js.map +1 -0
- package/transpiled/exceptions.d.ts +3 -0
- package/transpiled/exceptions.js +46 -0
- package/transpiled/exceptions.js.map +1 -0
- package/transpiled/index.d.ts +5 -0
- package/transpiled/index.js +12 -0
- package/transpiled/index.js.map +1 -0
- package/transpiled/io.d.ts +3 -0
- package/transpiled/io.js +3 -0
- package/transpiled/io.js.map +1 -0
- package/transpiled/manifest.d.ts +3 -0
- package/transpiled/manifest.js +65 -0
- package/transpiled/manifest.js.map +1 -0
- package/transpiled/root.d.ts +2 -0
- package/transpiled/root.js +44 -0
- package/transpiled/root.js.map +1 -0
- package/transpiled/schemas.d.ts +7 -0
- package/transpiled/schemas.js +14 -0
- package/transpiled/schemas.js.map +1 -0
- package/transpiled/tsconfig.tsbuildinfo +1 -0
- package/components/identity.basic/source/create.ts +0 -18
- package/components/octets.storage/operations/fetch.js +0 -46
- package/components/octets.storage/operations/list.js +0 -7
- package/components/octets.storage/operations/permute.js +0 -7
- package/components/octets.storage/operations/store.js +0 -11
- package/features/steps/components/octets.tester/operations/diversify.js +0 -14
- package/schemas/octets/context.cos.yaml +0 -1
- package/schemas/octets/list.cos.yaml +0 -1
- package/schemas/octets/permute.cos.yaml +0 -1
- package/schemas/octets/store.cos.yaml +0 -3
- package/source/HTTP/Server.fixtures.ts +0 -41
- package/source/HTTP/Server.test.ts +0 -199
- package/source/directives/auth/Family.ts +0 -148
- package/source/directives/cache/Family.ts +0 -36
- package/source/directives/octets/Fetch.ts +0 -85
- package/source/directives/octets/List.ts +0 -32
- package/source/directives/octets/Permute.ts +0 -37
- package/source/directives/octets/Store.ts +0 -158
package/documentation/access.md
CHANGED
|
@@ -14,8 +14,8 @@
|
|
|
14
14
|
The Authorization is implemented as a set of [RTD Directives](tree.md#directives).
|
|
15
15
|
|
|
16
16
|
Directives are executed in a predetermined order until one of them grants access to a resource.
|
|
17
|
-
If none of the directives grants access, then the Authorization interrupts request processing and
|
|
18
|
-
authorization error.
|
|
17
|
+
If none of the directives grants access, then the Authorization interrupts request processing and
|
|
18
|
+
responds with an authorization error.
|
|
19
19
|
|
|
20
20
|
> The Authorization directive provider is named `authorization`,
|
|
21
21
|
> so the full names of the directives are `authorization:{directive}`.
|
|
@@ -25,7 +25,11 @@ authorization error.
|
|
|
25
25
|
Grants access if its value is `true` and no credentials were provided[^1].
|
|
26
26
|
|
|
27
27
|
[^1]: Credentials in the request make the
|
|
28
|
-
response [non-
|
|
28
|
+
response [non-cacheable](https://datatracker.ietf.org/doc/html/rfc7234#section-3).
|
|
29
|
+
|
|
30
|
+
### `anyone`
|
|
31
|
+
|
|
32
|
+
Grants access if its value is `true` and valid credentials were provided.
|
|
29
33
|
|
|
30
34
|
### `id`
|
|
31
35
|
|
|
@@ -37,11 +41,8 @@ the directive's value.
|
|
|
37
41
|
Given the Route declaration and corresponding HTTP request:
|
|
38
42
|
|
|
39
43
|
```yaml
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
exposition:
|
|
43
|
-
/users/:user-id:
|
|
44
|
-
id: "user-id"
|
|
44
|
+
/users/:user-id:
|
|
45
|
+
id: "user-id"
|
|
45
46
|
```
|
|
46
47
|
|
|
47
48
|
```http
|
|
@@ -56,46 +57,98 @@ is `87480f2bd88048518c529d7957475ecd`.
|
|
|
56
57
|
|
|
57
58
|
Grants access if resolved Identity has a role matching the directive's value or one of its values.
|
|
58
59
|
|
|
59
|
-
#### Example
|
|
60
|
-
|
|
61
60
|
```yaml
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
exposition:
|
|
65
|
-
/code:
|
|
66
|
-
role: [developer, reviewer]
|
|
61
|
+
/code:
|
|
62
|
+
role: [developer, reviewer]
|
|
67
63
|
```
|
|
68
64
|
|
|
69
65
|
Access will be granted if the resolved Identity has a role that matches `developer` or `reviewer`.
|
|
70
66
|
|
|
71
67
|
Read [Roles](#roles) section for more details.
|
|
72
68
|
|
|
69
|
+
#### Dynamic roles
|
|
70
|
+
|
|
71
|
+
The `role` directive can be used with a placeholder in the route.
|
|
72
|
+
|
|
73
|
+
```yaml
|
|
74
|
+
/:org-id:
|
|
75
|
+
role: app:{org-id}:moderator
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
### `claims`
|
|
79
|
+
|
|
80
|
+
Grants access if `Bearer` authentication scheme is used
|
|
81
|
+
and the Token's claims matches the specified values.
|
|
82
|
+
|
|
83
|
+
```yaml
|
|
84
|
+
/:
|
|
85
|
+
auth:claims:
|
|
86
|
+
iss: https://id.example.com
|
|
87
|
+
sub: someone
|
|
88
|
+
aud: stars
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
> If OIDC token claim contains `aud`
|
|
92
|
+
> as [an array](https://openid.net/specs/openid-connect-core-1_0.html#IDTokenValidation), the
|
|
93
|
+
> directive will match if at least one value.
|
|
94
|
+
|
|
95
|
+
At least one property is required.
|
|
96
|
+
|
|
97
|
+
Values may refer to the Route parameters or the request authority:
|
|
98
|
+
|
|
99
|
+
```yaml
|
|
100
|
+
/secrets/:org-id:
|
|
101
|
+
auth:claims:
|
|
102
|
+
iss: https://id.org.com
|
|
103
|
+
sub: /:org-id
|
|
104
|
+
aud: :authority
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
An expression `:domain` will match if the domain in the value of `iss` matches the request
|
|
108
|
+
authority, excluding the most specific subdomain.
|
|
109
|
+
|
|
110
|
+
Issuer `https://accounts.example.com` matches request authorities `images.example.com`
|
|
111
|
+
and `sub.images.example.com`, but not `images.another.com`.
|
|
112
|
+
|
|
113
|
+
```yaml
|
|
114
|
+
/images/:user-id:
|
|
115
|
+
auth:claims:
|
|
116
|
+
iss: :domain
|
|
117
|
+
sub: /:org-id
|
|
118
|
+
```
|
|
119
|
+
|
|
73
120
|
### `rule`
|
|
74
121
|
|
|
75
122
|
The Rule is a collection of authorization directives. It allows access only if all the specified
|
|
76
|
-
directives grant
|
|
77
|
-
access. The value of the `rule` directive can be a single Rule or a list of Rules.
|
|
123
|
+
directives grant access. The value of the `rule` directive can be a single Rule or a list of Rules.
|
|
78
124
|
|
|
79
125
|
#### Example
|
|
80
126
|
|
|
81
127
|
```yaml
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
rule:
|
|
87
|
-
id: user-id
|
|
88
|
-
role: developer
|
|
128
|
+
/commits/:user-id:
|
|
129
|
+
rule:
|
|
130
|
+
id: user-id
|
|
131
|
+
role: developer
|
|
89
132
|
```
|
|
90
133
|
|
|
91
134
|
Access will be granted if an Identity matches a `user-id` placeholder and has a Role of `developer`.
|
|
92
135
|
|
|
136
|
+
### `delegate`
|
|
137
|
+
|
|
138
|
+
Embeds the value of the current Identity into the request body as a property named after the value
|
|
139
|
+
of the directive value, and grants access.
|
|
140
|
+
The request body must be an object.
|
|
141
|
+
|
|
142
|
+
> :warning:<br/>
|
|
143
|
+
> The intended use case for this directive is audit.
|
|
144
|
+
> **Using it to pass Identity to the application logic is strongly discouraged.**
|
|
145
|
+
|
|
93
146
|
## Roles
|
|
94
147
|
|
|
95
148
|
Role values are strings that can be assigned to an Identity and used for matching with values of
|
|
96
149
|
the [`role` directive](#role).
|
|
97
150
|
|
|
98
|
-
###
|
|
151
|
+
### Hierarchies
|
|
99
152
|
|
|
100
153
|
Role values are alphanumeric tokens separated by a colon (`:`).
|
|
101
154
|
Each token defines a Role Scope, forming a hierarchy.
|
|
@@ -105,11 +158,8 @@ directive.
|
|
|
105
158
|
#### Example
|
|
106
159
|
|
|
107
160
|
```yaml
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
/exposition:
|
|
111
|
-
/commits/:user-id:
|
|
112
|
-
role: developer:senior
|
|
161
|
+
/commits/:user-id:
|
|
162
|
+
role: developer:senior
|
|
113
163
|
```
|
|
114
164
|
|
|
115
165
|
The example above defines a `role` directive with the specified `developer:senior` Role Scope.
|
|
@@ -124,18 +174,10 @@ In other words, the Identity must have a specified or more general Role.
|
|
|
124
174
|
</picture>
|
|
125
175
|
</a>
|
|
126
176
|
|
|
127
|
-
|
|
128
177
|
> The root-level Role Scope `system` is preserved and cannot be used with the `role` directives.
|
|
129
178
|
|
|
130
179
|
See also [role management resources](components.md#roles).
|
|
131
180
|
|
|
132
|
-
#### Authorization Directives
|
|
133
|
-
|
|
134
|
-
```yaml
|
|
135
|
-
/identity/roles/:id:
|
|
136
|
-
role: system:roles
|
|
137
|
-
````
|
|
138
|
-
|
|
139
181
|
## Policies
|
|
140
182
|
|
|
141
183
|
Component Resource branches cannot have authorization directives.
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
# Authorities
|
|
2
|
+
|
|
3
|
+
Authorities are a mechanism that allows serving multiple domains from a single instance of the
|
|
4
|
+
application.
|
|
5
|
+
|
|
6
|
+
## Definition
|
|
7
|
+
|
|
8
|
+
The `authorities` definition is a map of authority identifiers to the `:authority` pseudo-header
|
|
9
|
+
values.
|
|
10
|
+
|
|
11
|
+
```yaml
|
|
12
|
+
# context.toa.yaml
|
|
13
|
+
|
|
14
|
+
exposition:
|
|
15
|
+
authorities:
|
|
16
|
+
one: the.one.com
|
|
17
|
+
two: the.two.com
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
## Mappings
|
|
21
|
+
|
|
22
|
+
To pass the requested authority to the operation call, [`map:authority` directive](map#embeddings)
|
|
23
|
+
can be used.
|
|
24
|
+
|
|
25
|
+
```yaml
|
|
26
|
+
# manifest.toa.yaml
|
|
27
|
+
|
|
28
|
+
exposition:
|
|
29
|
+
/:
|
|
30
|
+
GET:
|
|
31
|
+
map:authority: hostname
|
|
32
|
+
endpoint: observe
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
If the value of the `authority` pseudo-header is not present in the `authorities` definition,
|
|
36
|
+
then the value is embedded as is.
|
|
37
|
+
|
|
38
|
+
## Identity
|
|
39
|
+
|
|
40
|
+
Credentials stored or issued by the [authentication system](identity.md) are associated with an
|
|
41
|
+
authority.
|
|
42
|
+
Credentials in one authority are not valid in another,
|
|
43
|
+
or may be associated with a different Identity; in other words, Identity exists in the context of an
|
|
44
|
+
authority.
|
|
45
|
+
|
|
46
|
+
> :warning:<br/>
|
|
47
|
+
> Changing the authority identifier will break compatibility with existing stored or issued
|
|
48
|
+
> credentials.
|
package/documentation/cache.md
CHANGED
|
@@ -17,7 +17,7 @@ to [safe HTTP methods](https://developer.mozilla.org/en-US/docs/Glossary/Safe/HT
|
|
|
17
17
|
|
|
18
18
|
### Implicit modifications
|
|
19
19
|
|
|
20
|
-
In terms of security, the following implicit modifications are made to the `
|
|
20
|
+
In terms of security, the following implicit modifications are made to the `cache-control` header:
|
|
21
21
|
|
|
22
22
|
- If it contains the `public` directive without `no-cache` and the request is authenticated,
|
|
23
23
|
the `no-cache` directive is added.
|
|
@@ -25,6 +25,13 @@ In terms of security, the following implicit modifications are made to the `Cach
|
|
|
25
25
|
- If it does not contain the `private` directive and the request is authenticated, the `private`
|
|
26
26
|
directive is added.
|
|
27
27
|
This is to prevent the storage of private data in shared caches.
|
|
28
|
+
- If it contains `private` directive and the request is authenticated, then `vary: authorization` is
|
|
29
|
+
added.
|
|
30
|
+
This is to prevent the reuse of private data when authenticated as another identity.[^1]
|
|
31
|
+
|
|
32
|
+
[^1]: This also will invalidate the cache each time a new token is used for the same identity, thus
|
|
33
|
+
limiting the `max-age` value to the token's `refresh` time.
|
|
34
|
+
See [Issuing tokens](components.md#issuing-tokens).
|
|
28
35
|
|
|
29
36
|
## `cache:exact`
|
|
30
37
|
|
|
@@ -20,7 +20,7 @@ and pepper.
|
|
|
20
20
|
configuration:
|
|
21
21
|
identity.basic:
|
|
22
22
|
rounds: 10 # salt rounds
|
|
23
|
-
|
|
23
|
+
pepper: '' # hashing pepper
|
|
24
24
|
```
|
|
25
25
|
|
|
26
26
|
### Credentials constraints
|
|
@@ -34,7 +34,7 @@ them).
|
|
|
34
34
|
configuration:
|
|
35
35
|
identity.basic:
|
|
36
36
|
username:
|
|
37
|
-
- ^\S{1,
|
|
37
|
+
- ^\S{1,128}$
|
|
38
38
|
password:
|
|
39
39
|
- ^\S{8,32}$
|
|
40
40
|
```
|
|
@@ -89,9 +89,42 @@ password?: string
|
|
|
89
89
|
|
|
90
90
|
Access requires basic credentials of the modified Identity or `system:identity:basic` role.
|
|
91
91
|
|
|
92
|
+
## Identity federation (OpenID connect)
|
|
93
|
+
|
|
94
|
+
The `identity.federation` component manages OpenID Connect federated identities.
|
|
95
|
+
|
|
96
|
+
Both implicit identities creation and forced [identity inception](./identity.md) are supported
|
|
97
|
+
as in case with basic credentials. `principal` is also working in the same way.
|
|
98
|
+
|
|
99
|
+
The configuration schema alongside default values is described in
|
|
100
|
+
the [component manifest](../components/identity.federation/manifest.toa.yaml).
|
|
101
|
+
|
|
102
|
+
No federated tokens are accepted by default until at least one entry is added to the `trust`
|
|
103
|
+
configuration.
|
|
104
|
+
|
|
105
|
+
Toa supports either asymmetric RS256 or symmetric HS256 / HS384 / HS512 tokens with pre-shared
|
|
106
|
+
secrets.
|
|
107
|
+
|
|
108
|
+
```yaml
|
|
109
|
+
# context.toa.yaml
|
|
110
|
+
|
|
111
|
+
configuration:
|
|
112
|
+
identity.federation:
|
|
113
|
+
trust:
|
|
114
|
+
- iss: https://token.actions.githubusercontent.com
|
|
115
|
+
aud:
|
|
116
|
+
- https://github.com/tinovyatkin
|
|
117
|
+
- https://github.com/temich
|
|
118
|
+
|
|
119
|
+
- issuer: some.private.issuer
|
|
120
|
+
secrets:
|
|
121
|
+
HS256:
|
|
122
|
+
k1: <secret-to-be-used-for-hs256>
|
|
123
|
+
```
|
|
124
|
+
|
|
92
125
|
## Stateless tokens
|
|
93
126
|
|
|
94
|
-
The `identity.tokens` component manages
|
|
127
|
+
The `identity.tokens` component manages stateless authentication tokens.
|
|
95
128
|
|
|
96
129
|
These tokens carry the information required to authenticate the Identity and authorize access.
|
|
97
130
|
|
|
@@ -102,6 +135,14 @@ The new token is issued each time the request is made:
|
|
|
102
135
|
1. Using authentication scheme other than `Token`.
|
|
103
136
|
2. Using `Token` authentication scheme with an [obsolete token](#token-rotation).
|
|
104
137
|
|
|
138
|
+
When the token is issued it is sent in the `authorization` response header and the `cache-control`
|
|
139
|
+
is set to `no-store`.
|
|
140
|
+
|
|
141
|
+
```http
|
|
142
|
+
authorization: Token ...
|
|
143
|
+
cache-control: no-store
|
|
144
|
+
```
|
|
145
|
+
|
|
105
146
|
### Token encryption
|
|
106
147
|
|
|
107
148
|
Issued tokens are encrypted
|
|
@@ -112,7 +153,7 @@ using the `key0` configuration value as a secret.
|
|
|
112
153
|
# context.toa.yaml
|
|
113
154
|
|
|
114
155
|
configuration:
|
|
115
|
-
identity.
|
|
156
|
+
identity.tokens:
|
|
116
157
|
key0: $TOKEN_ENCRYPTION_KEY
|
|
117
158
|
```
|
|
118
159
|
|
|
@@ -123,25 +164,22 @@ The `key0` configuration value is required.
|
|
|
123
164
|
### Token rotation
|
|
124
165
|
|
|
125
166
|
Issued tokens are valid for a `lifetime` period defined in the configuration. After the `refresh`
|
|
126
|
-
period, the token is
|
|
127
|
-
|
|
128
|
-
provided one has
|
|
129
|
-
been [revoked](#token-revocation).
|
|
167
|
+
period, the token is considered obsolete (yet still valid), and a new token
|
|
168
|
+
is [issued](#issuing-tokens) unless the provided one has been [revoked](#token-revocation).
|
|
130
169
|
|
|
131
170
|
This essentially means that if the client uses the token at least once every `lifetime` period, it
|
|
132
|
-
will always have a
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
the `refresh` period of the currently issued tokens has expired.
|
|
171
|
+
will always have a valid token to authenticate with.
|
|
172
|
+
Also, token revocation or changing roles of an Identity will take effect once the `refresh` period
|
|
173
|
+
of the currently issued tokens has expired.
|
|
136
174
|
|
|
137
175
|
Adjusting these two values is a delicate trade-off between security, performance and client
|
|
138
|
-
|
|
176
|
+
convenience.
|
|
139
177
|
|
|
140
178
|
```yaml
|
|
141
179
|
# context.toa.yaml
|
|
142
180
|
|
|
143
181
|
configuration:
|
|
144
|
-
identity.
|
|
182
|
+
identity.tokens:
|
|
145
183
|
lifetime: 2592000 # seconds, 30 days
|
|
146
184
|
refresh: 600 # seconds, 10 minutes
|
|
147
185
|
```
|
|
@@ -169,7 +207,7 @@ the `key0` and `key1` values in order.
|
|
|
169
207
|
# context.toa.yaml
|
|
170
208
|
|
|
171
209
|
configuration:
|
|
172
|
-
identity.
|
|
210
|
+
identity.tokens:
|
|
173
211
|
key0: $TOKEN_ENCRYPTION_KEY_2023Q3
|
|
174
212
|
key1: $TOKEN_ENCRYPTION_KEY_2023Q2
|
|
175
213
|
```
|
|
@@ -201,7 +239,7 @@ The secret rotation is a 2-step process:
|
|
|
201
239
|
# context.toa.yaml
|
|
202
240
|
|
|
203
241
|
configuration:
|
|
204
|
-
identity.
|
|
242
|
+
identity.tokens:
|
|
205
243
|
key0: $TOKEN_ENCRYPTION_KEY_2023Q3
|
|
206
244
|
key1: $TOKEN_ENCRYPTION_KEY_2023Q4
|
|
207
245
|
```
|
|
@@ -214,18 +252,31 @@ configuration:
|
|
|
214
252
|
# context.toa.yaml
|
|
215
253
|
|
|
216
254
|
configuration:
|
|
217
|
-
identity.
|
|
255
|
+
identity.tokens:
|
|
218
256
|
key0: $TOKEN_ENCRYPTION_KEY_2023Q4
|
|
219
257
|
key1: $TOKEN_ENCRYPTION_KEY_2023Q3
|
|
220
258
|
```
|
|
221
259
|
|
|
222
|
-
|
|
260
|
+
### Token resources
|
|
261
|
+
|
|
262
|
+
`/identity/tokens/`
|
|
263
|
+
|
|
264
|
+
`POST` Issue a new token for the Identity. Request body is as follows:
|
|
265
|
+
|
|
266
|
+
```yaml
|
|
267
|
+
lifetime?: number # seconds
|
|
268
|
+
```
|
|
223
269
|
|
|
224
|
-
|
|
270
|
+
Providing a value of `0` will result in the token being issued with no expiration.
|
|
271
|
+
However, it will still become invalid once the encryption key used is out
|
|
272
|
+
of [rotation](#secret-rotation).
|
|
225
273
|
|
|
226
|
-
|
|
274
|
+
## Roles
|
|
227
275
|
|
|
228
|
-
|
|
276
|
+
The `identity.roles` component manages roles of an Identity used
|
|
277
|
+
by [access authorization](access.md#role).
|
|
278
|
+
|
|
279
|
+
### `/identity/roles/:id/`
|
|
229
280
|
|
|
230
281
|
`GET` Get roles of an Identity.
|
|
231
282
|
|
|
@@ -237,13 +288,16 @@ Access requires credentials of the Identity or `system:identity:roles` role.
|
|
|
237
288
|
role: string
|
|
238
289
|
```
|
|
239
290
|
|
|
240
|
-
|
|
291
|
+
To assign arbitrary roles, the `system:identity:roles` role is required.
|
|
292
|
+
|
|
293
|
+
An Identity having `system:identity:roles:delegation` role can delegate roles within its own
|
|
294
|
+
Role Scopes (see [Role Hierarchies](access.md#hierarchies)).
|
|
241
295
|
|
|
242
296
|
## Banned Identities
|
|
243
297
|
|
|
244
298
|
The `identity.bans` component manages banned identities.
|
|
245
|
-
A banned identity will fail to authenticate with any associated credentials
|
|
246
|
-
the `refresh` period).
|
|
299
|
+
A banned identity will fail to authenticate with any associated credentials
|
|
300
|
+
(except [tokens](#stateless-tokens) within the `refresh` period).
|
|
247
301
|
|
|
248
302
|
```http
|
|
249
303
|
PUT /identity/bans/:id/
|
|
@@ -251,6 +305,7 @@ authorization: Basic dXNlcm5hbWU6cGFzc3dvcmQ=
|
|
|
251
305
|
content-type: application/yaml
|
|
252
306
|
|
|
253
307
|
banned: true
|
|
308
|
+
comment: Bye bye
|
|
254
309
|
```
|
|
255
310
|
|
|
256
311
|
Access requires `system:identity:bans` role.
|
|
@@ -274,3 +329,17 @@ roles:
|
|
|
274
329
|
- developer
|
|
275
330
|
- system:identity:roles
|
|
276
331
|
```
|
|
332
|
+
|
|
333
|
+
When no credentials are provided, transient Identity is created.
|
|
334
|
+
|
|
335
|
+
```http
|
|
336
|
+
GET /identity/
|
|
337
|
+
accept: application/yaml
|
|
338
|
+
```
|
|
339
|
+
|
|
340
|
+
```
|
|
341
|
+
201 Created
|
|
342
|
+
|
|
343
|
+
id: 332017649c814649b25ee466c1fe4534
|
|
344
|
+
roles: []
|
|
345
|
+
```
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
# Request flow
|
|
2
|
+
|
|
3
|
+
## `flow:fetch`
|
|
4
|
+
|
|
5
|
+
Fetches the content from the resource returned by the specified endpoint.
|
|
6
|
+
|
|
7
|
+
The value of the directive is a `string` specifying endpoint to be called for the redirection
|
|
8
|
+
request.
|
|
9
|
+
|
|
10
|
+
Request `authority`, `path` and `parameters` are passed as input to the redirection endpoint,
|
|
11
|
+
and it must return a URL `string`, an `Error` or an object with the following properties:
|
|
12
|
+
|
|
13
|
+
```yaml
|
|
14
|
+
url: string
|
|
15
|
+
options?:
|
|
16
|
+
method?: string
|
|
17
|
+
headers?: Record<string, string>
|
|
18
|
+
body?: string
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
If it returns a URL or Request, then the response to the specified request is returned as the
|
|
22
|
+
response to the original request, along with the `content-type`, `content-length`, and `etag`
|
|
23
|
+
headers.
|
|
24
|
+
|
|
25
|
+
## `flow:compose`
|
|
26
|
+
|
|
27
|
+
Compose an object from a response stream in object mode.
|
|
28
|
+
|
|
29
|
+
The value of the directive is an object whose values are JavaScript expressions
|
|
30
|
+
accessing the response stream objects composed into an array named `$`.
|
|
31
|
+
|
|
32
|
+
```yaml
|
|
33
|
+
flow:compose:
|
|
34
|
+
one: $[0].status
|
|
35
|
+
two: $[1].data.foo
|
|
36
|
+
three: $[2].amount
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
```yaml
|
|
40
|
+
flow:compose:
|
|
41
|
+
sum: $[0].value + $[1].value
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Be careful.
|
|
@@ -1,36 +1,30 @@
|
|
|
1
1
|
# Identity
|
|
2
2
|
|
|
3
3
|
Identity is the fundamental entity within an authentication system that represents the **unique
|
|
4
|
-
identifier** of an
|
|
5
|
-
individual, organization, application or device.
|
|
4
|
+
identifier** of an individual, organization, application or device.
|
|
6
5
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
Identity.
|
|
6
|
+
To prove its Identity, the request originator must provide a valid _credentials_ that are associated
|
|
7
|
+
with that Identity.
|
|
10
8
|
|
|
11
9
|
Identity is intrinsically linked to credentials, as an Identity is established only when the first
|
|
12
|
-
set of credentials
|
|
13
|
-
for that Identity is created.
|
|
10
|
+
set of credentials for that Identity is created.
|
|
14
11
|
In other words, the creation of credentials marks the inception of an Identity.
|
|
15
12
|
Once the last credentials are removed from the Identity, it ceases to exist.
|
|
16
13
|
Without credentials, there is no basis for defining or asserting an Identity.
|
|
17
14
|
|
|
18
15
|
## Authentication
|
|
19
16
|
|
|
20
|
-
The
|
|
21
|
-
authentication
|
|
22
|
-
schemes.
|
|
17
|
+
The Authentication system resolves provided credentials to an Identity using one of the supported
|
|
18
|
+
authentication schemes.
|
|
23
19
|
|
|
24
20
|
The Authentication is request-agnostic, meaning it does not depend on the specific URL being
|
|
25
|
-
requested or the content of
|
|
26
|
-
the request body.
|
|
21
|
+
requested or the content of the request body.
|
|
27
22
|
The only information it handles is the value of the `Authorization` header.
|
|
28
23
|
|
|
29
|
-
> Except for its own [management resources](
|
|
24
|
+
> Except for its own [management resources](components.md).
|
|
30
25
|
|
|
31
26
|
If the provided credentials are not valid or not associated with an Identity, then Authentication
|
|
32
|
-
interrupts request
|
|
33
|
-
processing and responds with an authentication error.
|
|
27
|
+
interrupts request processing and responds with an authentication error.
|
|
34
28
|
|
|
35
29
|
### Basic scheme
|
|
36
30
|
|
|
@@ -52,8 +46,8 @@ Authrization: Token v4.local.eyJzdWIiOiJqb2hu...
|
|
|
52
46
|
|
|
53
47
|
The `Token` is the **primary** authentication scheme.
|
|
54
48
|
If request originators use an alternative authentication scheme, they will receive a response
|
|
55
|
-
containing `Token`
|
|
56
|
-
|
|
49
|
+
containing `Token`credentials and will be required to switch to the `Token` scheme for any
|
|
50
|
+
subsequent requests.
|
|
57
51
|
Continued use of other authentication schemes will result in temporary blocking of requests.
|
|
58
52
|
|
|
59
53
|
See [`identity.tokens` component](components.md#stateless-tokens).
|
|
@@ -69,19 +63,36 @@ to [OpenID Connect Core 1.0](https://openid.net/specs/openid-connect-core-1_0.ht
|
|
|
69
63
|
Authorization: Bearer eyJhbGciOiJIUzI1...
|
|
70
64
|
```
|
|
71
65
|
|
|
72
|
-
Trusted providers are specified using the `
|
|
66
|
+
Trusted providers are specified using the `identity.federation` configuration.
|
|
73
67
|
|
|
74
68
|
```yaml
|
|
75
69
|
# context.toa.yaml
|
|
76
70
|
|
|
77
|
-
|
|
78
|
-
identity:
|
|
71
|
+
configuration:
|
|
72
|
+
identity.federation:
|
|
79
73
|
trust:
|
|
80
|
-
- https://accounts.google.com
|
|
81
|
-
|
|
74
|
+
- iss: https://accounts.google.com
|
|
75
|
+
aud:
|
|
76
|
+
- <GOOGLE_CLIENT_ID>
|
|
77
|
+
|
|
78
|
+
- iss: https://appleid.apple.com
|
|
79
|
+
|
|
80
|
+
- iss: private.entity
|
|
81
|
+
secrets:
|
|
82
|
+
HS384:
|
|
83
|
+
key0: <THE-SECRET-STRING-FOR-HS384>
|
|
84
|
+
key1: <THE-SECRET-STRING-FOR-HS384> # selected by `kid` in the JWT header
|
|
85
|
+
principal:
|
|
86
|
+
iss: https://accounts.google.com
|
|
87
|
+
sub: 4218230498234
|
|
88
|
+
implicit: true
|
|
82
89
|
```
|
|
83
90
|
|
|
84
|
-
|
|
91
|
+
`principal` specifies the values of the `iss` and `sub` claims of an Identity that will be granted
|
|
92
|
+
with a `system` role.
|
|
93
|
+
|
|
94
|
+
`implicit` indicates whether the Identity should be implicitly created when a valid token for a
|
|
95
|
+
non-existent Identity is provided (default `false`).
|
|
85
96
|
|
|
86
97
|
## Identity inception
|
|
87
98
|
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
# Resource introspection
|
|
2
|
+
|
|
3
|
+
Any resource can be introspected by sending an `OPTIONS` request to the resource's path.
|
|
4
|
+
The response will contain the resource's input and output schemas for each supported method.
|
|
5
|
+
|
|
6
|
+
Introspection properties:
|
|
7
|
+
|
|
8
|
+
- `route` route parameters
|
|
9
|
+
- `query` query parameters
|
|
10
|
+
- `input` input schema
|
|
11
|
+
- `output` output schema
|
|
12
|
+
- `errors` error codes
|
|
13
|
+
|
|
14
|
+
```http
|
|
15
|
+
OPTIONS /pots/:id/ HTTP/1.1
|
|
16
|
+
accept: application/yaml
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
```http
|
|
20
|
+
200 OK
|
|
21
|
+
Allow: GET, POST, OPTIONS
|
|
22
|
+
|
|
23
|
+
GET:
|
|
24
|
+
route:
|
|
25
|
+
id:
|
|
26
|
+
type: string
|
|
27
|
+
pattern: ^[a-fA-F0-9]{32}$
|
|
28
|
+
output:
|
|
29
|
+
type: array
|
|
30
|
+
items:
|
|
31
|
+
type: object
|
|
32
|
+
properties:
|
|
33
|
+
title:
|
|
34
|
+
type: string
|
|
35
|
+
maxLength: 64
|
|
36
|
+
volume:
|
|
37
|
+
type: number
|
|
38
|
+
exclusiveMinimum: 0
|
|
39
|
+
maximum: 1000
|
|
40
|
+
temperature:
|
|
41
|
+
type: number
|
|
42
|
+
exclusiveMinimum: 0
|
|
43
|
+
maximum: 300
|
|
44
|
+
additionalProperties: false
|
|
45
|
+
required:
|
|
46
|
+
- id
|
|
47
|
+
- title
|
|
48
|
+
- volume
|
|
49
|
+
POST:
|
|
50
|
+
route:
|
|
51
|
+
id:
|
|
52
|
+
type: string
|
|
53
|
+
pattern: ^[a-fA-F0-9]{32}$
|
|
54
|
+
input:
|
|
55
|
+
type: object
|
|
56
|
+
properties:
|
|
57
|
+
title:
|
|
58
|
+
type: string
|
|
59
|
+
maxLength: 64
|
|
60
|
+
temperature:
|
|
61
|
+
type: number
|
|
62
|
+
exclusiveMinimum: 0
|
|
63
|
+
maximum: 300
|
|
64
|
+
volume:
|
|
65
|
+
type: number
|
|
66
|
+
exclusiveMinimum: 0
|
|
67
|
+
maximum: 1000
|
|
68
|
+
additionalProperties: false
|
|
69
|
+
required:
|
|
70
|
+
- title
|
|
71
|
+
- volume
|
|
72
|
+
output:
|
|
73
|
+
type: object
|
|
74
|
+
properties:
|
|
75
|
+
id:
|
|
76
|
+
type: string
|
|
77
|
+
pattern: ^[a-fA-F0-9]{32}$
|
|
78
|
+
additionalProperties: false
|
|
79
|
+
errors:
|
|
80
|
+
- NO_WAY
|
|
81
|
+
- WONT_CREATE
|
|
82
|
+
```
|