@toa.io/extensions.exposition 1.0.0-alpha.7 → 1.0.0-alpha.71
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 +2 -2
- package/components/identity.bans/manifest.toa.yaml +15 -7
- 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 -10
- package/components/identity.basic/operations/authenticate.d.ts +5 -1
- package/components/identity.basic/operations/authenticate.js +5 -2
- package/components/identity.basic/operations/authenticate.js.map +1 -1
- 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 +4 -4
- package/components/identity.basic/operations/transit.js +5 -3
- package/components/identity.basic/operations/transit.js.map +1 -1
- package/components/identity.basic/operations/tsconfig.tsbuildinfo +1 -1
- package/components/identity.basic/operations/types.d.ts +8 -4
- package/components/identity.basic/source/authenticate.ts +16 -5
- package/components/identity.basic/source/incept.ts +38 -0
- package/components/identity.basic/source/transit.ts +8 -6
- package/components/identity.basic/source/types.ts +8 -4
- package/components/identity.federation/manifest.toa.yaml +32 -16
- package/components/identity.federation/operations/authenticate.d.ts +2 -2
- package/components/identity.federation/operations/authenticate.js +4 -11
- package/components/identity.federation/operations/authenticate.js.map +1 -1
- package/components/identity.federation/operations/incept.d.ts +11 -0
- package/components/identity.federation/operations/{create.js → incept.js} +6 -7
- package/components/identity.federation/operations/incept.js.map +1 -0
- package/components/identity.federation/operations/lib/assertions-as-values.js +2 -1
- package/components/identity.federation/operations/lib/assertions-as-values.js.map +1 -1
- package/components/identity.federation/operations/lib/jwt.d.ts +5 -5
- package/components/identity.federation/operations/lib/jwt.js +25 -12
- package/components/identity.federation/operations/lib/jwt.js.map +1 -1
- package/components/identity.federation/operations/tsconfig.tsbuildinfo +1 -1
- package/components/identity.federation/operations/types/configuration.d.ts +14 -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.d.ts → types/context.d.ts} +15 -7
- 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 +6 -19
- package/components/identity.federation/source/{create.ts → incept.ts} +10 -9
- package/components/identity.federation/source/lib/assertions-as-values.ts +4 -2
- package/components/identity.federation/source/lib/jwt.test.ts +123 -4
- package/components/identity.federation/source/lib/jwt.ts +36 -16
- package/components/identity.federation/source/types/configuration.ts +15 -0
- package/components/identity.federation/source/{types.ts → types/context.ts} +17 -6
- 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 +5 -4
- package/components/identity.roles/manifest.toa.yaml +18 -7
- 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 +1 -4
- package/components/identity.roles/operations/list.js.map +1 -1
- package/components/identity.roles/operations/principal.d.ts +4 -6
- package/components/identity.roles/operations/principal.js +6 -1
- package/components/identity.roles/operations/principal.js.map +1 -1
- package/components/identity.roles/operations/tsconfig.tsbuildinfo +1 -1
- 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 +19 -5
- package/components/identity.tokens/operations/authenticate.d.ts +2 -2
- package/components/identity.tokens/operations/authenticate.js +12 -5
- package/components/identity.tokens/operations/authenticate.js.map +1 -1
- package/components/identity.tokens/operations/decrypt.js +1 -0
- package/components/identity.tokens/operations/decrypt.js.map +1 -1
- package/components/identity.tokens/operations/encrypt.js +5 -1
- package/components/identity.tokens/operations/encrypt.js.map +1 -1
- package/components/identity.tokens/operations/tsconfig.tsbuildinfo +1 -1
- package/components/identity.tokens/operations/types.d.ts +8 -2
- 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 +6 -7
- package/components/octets.storage/operations/get.js +2 -2
- package/components/octets.storage/operations/store.js +113 -3
- package/documentation/access.md +75 -38
- package/documentation/authorities.md +49 -0
- package/documentation/cache.md +8 -1
- package/documentation/components.md +47 -22
- package/documentation/flow.md +31 -0
- package/documentation/identity.md +17 -22
- package/documentation/introspection.md +82 -0
- package/documentation/octets.md +81 -23
- package/documentation/protocol.md +13 -3
- package/documentation/query.md +29 -4
- package/documentation/require.md +15 -0
- package/documentation/tree.md +13 -0
- package/documentation/vary.md +14 -14
- package/features/access.feature +78 -46
- package/features/annotation.feature +1 -0
- package/features/auth.claim.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 +3 -0
- package/features/cache.feature +109 -5
- package/features/cors.feature +6 -1
- package/features/debug.feature +34 -0
- package/features/directives.feature +3 -0
- package/features/dynamic.feature +4 -0
- package/features/errors.feature +20 -7
- package/features/etag.feature +31 -0
- package/features/flow.feature +45 -0
- package/features/identity.bans.feature +137 -0
- package/features/identity.basic.feature +125 -23
- package/features/identity.feature +7 -2
- package/features/identity.federation.feature +66 -11
- package/features/identity.roles.feature +250 -7
- package/features/identity.tokens.feature +54 -4
- package/features/introspection.feature +153 -0
- package/features/io.feature +38 -1
- package/features/methods.feature +47 -0
- package/features/octets.download.feature +189 -0
- package/features/octets.entries.feature +8 -1
- package/features/octets.feature +82 -54
- package/features/octets.meta.feature +3 -0
- package/features/octets.workflows.feature +239 -19
- package/features/probes.feature +14 -0
- package/features/{queries.feature → query.feature} +65 -2
- package/features/realtime.feature +34 -0
- package/features/require.feature +67 -0
- package/features/response.feature +38 -3
- package/features/routes.feature +93 -2
- package/features/steps/Database.ts +17 -10
- package/features/steps/Gateway.ts +23 -6
- package/features/steps/IdP.ts +30 -25
- package/features/steps/Parameters.ts +4 -1
- package/features/steps/Realtime.ts +151 -0
- package/features/steps/components/echo/manifest.toa.yaml +14 -1
- 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/octets.tester/manifest.toa.yaml +22 -1
- package/features/steps/components/octets.tester/operations/authority.js +7 -0
- package/features/steps/components/octets.tester/operations/baz.js +1 -2
- package/features/steps/components/octets.tester/operations/diversify.js +3 -1
- package/features/steps/components/octets.tester/operations/foo.js +2 -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 +14 -3
- package/features/steps/components/users/manifest.toa.yaml +0 -1
- package/features/steps/components/users.properties/manifest.toa.yaml +1 -1
- package/features/streams.feature +5 -0
- package/features/timing.feature +4 -1
- package/features/vary.feature +71 -0
- package/package.json +23 -14
- package/readme.md +19 -14
- package/schemas/annotation.cos.yaml +1 -1
- package/schemas/method.cos.yaml +1 -1
- package/schemas/node.cos.yaml +1 -0
- package/schemas/octets/store.cos.yaml +25 -3
- package/schemas/query.cos.yaml +4 -10
- package/source/Annotation.ts +3 -3
- package/source/Composition.ts +0 -6
- package/source/Directive.ts +4 -5
- package/source/Endpoint.ts +52 -12
- package/source/Factory.ts +10 -11
- package/source/Gateway.ts +48 -19
- package/source/HTTP/Context.ts +25 -2
- package/source/HTTP/Server.ts +52 -44
- package/source/HTTP/exceptions.ts +13 -1
- package/source/HTTP/formats/index.ts +3 -3
- package/source/HTTP/messages.test.ts +45 -2
- package/source/HTTP/messages.ts +23 -5
- package/source/Introspection.ts +11 -0
- package/source/Mapping.ts +63 -21
- package/source/Query.test.ts +3 -3
- package/source/Query.ts +117 -33
- package/source/RTD/Endpoint.ts +3 -0
- package/source/RTD/Method.ts +16 -0
- package/source/RTD/Node.ts +29 -13
- package/source/RTD/Route.ts +5 -4
- package/source/RTD/factory.ts +5 -2
- package/source/RTD/syntax/parse.ts +37 -24
- package/source/RTD/syntax/types.ts +6 -4
- package/source/Remotes.ts +2 -9
- package/source/Tenant.ts +0 -8
- package/source/deployment.ts +33 -23
- package/source/directives/auth/Authorization.ts +37 -14
- package/source/directives/auth/Delegate.ts +42 -0
- package/source/directives/auth/Federation.ts +84 -0
- package/source/directives/auth/Incept.ts +4 -3
- package/source/directives/auth/Role.test.ts +53 -6
- package/source/directives/auth/Role.ts +22 -14
- package/source/directives/auth/split.ts +1 -1
- package/source/directives/auth/types.ts +1 -1
- package/source/directives/cache/Cache.ts +13 -6
- package/source/directives/cache/Control.ts +42 -16
- package/source/directives/cors/CORS.ts +1 -1
- package/source/directives/dev/Development.ts +1 -1
- package/source/directives/flow/Fetch.ts +88 -0
- package/source/directives/flow/Flow.ts +34 -0
- package/source/directives/flow/index.ts +3 -0
- package/source/directives/flow/types.ts +6 -0
- package/source/directives/index.ts +3 -1
- package/source/directives/io/Input.ts +4 -4
- package/source/directives/io/Output.ts +4 -3
- package/source/directives/octets/Context.ts +3 -2
- package/source/directives/octets/Fetch.ts +11 -10
- package/source/directives/octets/List.ts +5 -5
- package/source/directives/octets/Octets.ts +1 -3
- package/source/directives/octets/Store.ts +30 -10
- package/source/directives/octets/bytes.test.ts +30 -0
- package/source/directives/octets/bytes.ts +18 -0
- package/source/directives/octets/schemas.ts +4 -6
- package/source/directives/octets/workflows/Execution.ts +60 -8
- package/source/directives/octets/workflows/Workflow.ts +2 -1
- 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/directives/vary/Directive.ts +2 -1
- package/source/directives/vary/Embed.ts +14 -8
- package/source/directives/vary/Vary.ts +6 -4
- package/source/directives/vary/embeddings/Authority.ts +8 -0
- package/source/directives/vary/embeddings/Embedding.ts +2 -1
- package/source/directives/vary/embeddings/Parameter.ts +14 -0
- package/source/directives/vary/embeddings/index.ts +6 -4
- package/source/exceptions.ts +23 -11
- package/source/manifest.ts +10 -11
- package/source/schemas.ts +1 -1
- package/transpiled/Annotation.d.ts +3 -3
- package/transpiled/Composition.d.ts +0 -1
- package/transpiled/Composition.js +0 -4
- package/transpiled/Composition.js.map +1 -1
- package/transpiled/Directive.js +4 -4
- package/transpiled/Directive.js.map +1 -1
- package/transpiled/Endpoint.d.ts +6 -4
- package/transpiled/Endpoint.js +32 -4
- package/transpiled/Endpoint.js.map +1 -1
- package/transpiled/Factory.d.ts +1 -1
- package/transpiled/Factory.js +9 -8
- package/transpiled/Factory.js.map +1 -1
- package/transpiled/Gateway.d.ts +2 -0
- package/transpiled/Gateway.js +36 -12
- package/transpiled/Gateway.js.map +1 -1
- package/transpiled/HTTP/Context.d.ts +8 -1
- package/transpiled/HTTP/Context.js +16 -2
- package/transpiled/HTTP/Context.js.map +1 -1
- package/transpiled/HTTP/Server.d.ts +13 -2
- package/transpiled/HTTP/Server.js +39 -36
- package/transpiled/HTTP/Server.js.map +1 -1
- package/transpiled/HTTP/exceptions.d.ts +7 -1
- package/transpiled/HTTP/exceptions.js +13 -1
- package/transpiled/HTTP/exceptions.js.map +1 -1
- package/transpiled/HTTP/formats/index.js +3 -3
- package/transpiled/HTTP/formats/index.js.map +1 -1
- package/transpiled/HTTP/messages.d.ts +1 -0
- package/transpiled/HTTP/messages.js +24 -5
- package/transpiled/HTTP/messages.js.map +1 -1
- 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 +10 -2
- package/transpiled/Mapping.js +48 -19
- package/transpiled/Mapping.js.map +1 -1
- package/transpiled/Query.d.ts +10 -1
- package/transpiled/Query.js +83 -30
- package/transpiled/Query.js.map +1 -1
- package/transpiled/RTD/Endpoint.d.ts +1 -0
- package/transpiled/RTD/Method.d.ts +4 -0
- package/transpiled/RTD/Method.js +11 -0
- package/transpiled/RTD/Method.js.map +1 -1
- package/transpiled/RTD/Node.d.ts +4 -1
- package/transpiled/RTD/Node.js +23 -12
- package/transpiled/RTD/Node.js.map +1 -1
- package/transpiled/RTD/Route.d.ts +1 -1
- package/transpiled/RTD/Route.js +0 -1
- package/transpiled/RTD/Route.js.map +1 -1
- package/transpiled/RTD/factory.js +5 -2
- package/transpiled/RTD/factory.js.map +1 -1
- package/transpiled/RTD/syntax/parse.js +34 -22
- package/transpiled/RTD/syntax/parse.js.map +1 -1
- package/transpiled/RTD/syntax/types.d.ts +5 -3
- package/transpiled/RTD/syntax/types.js +1 -1
- package/transpiled/RTD/syntax/types.js.map +1 -1
- package/transpiled/Remotes.d.ts +2 -4
- package/transpiled/Remotes.js +0 -5
- package/transpiled/Remotes.js.map +1 -1
- package/transpiled/Tenant.d.ts +0 -1
- package/transpiled/Tenant.js +0 -6
- package/transpiled/Tenant.js.map +1 -1
- package/transpiled/deployment.d.ts +1 -1
- package/transpiled/deployment.js +28 -20
- package/transpiled/deployment.js.map +1 -1
- package/transpiled/directives/auth/Authorization.js +26 -10
- package/transpiled/directives/auth/Authorization.js.map +1 -1
- 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/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/Incept.js +4 -3
- package/transpiled/directives/auth/Incept.js.map +1 -1
- package/transpiled/directives/auth/Role.d.ts +4 -1
- package/transpiled/directives/auth/Role.js +20 -14
- package/transpiled/directives/auth/Role.js.map +1 -1
- package/transpiled/directives/auth/split.js +1 -1
- package/transpiled/directives/auth/split.js.map +1 -1
- package/transpiled/directives/cache/Cache.d.ts +3 -3
- package/transpiled/directives/cache/Cache.js +10 -4
- package/transpiled/directives/cache/Cache.js.map +1 -1
- package/transpiled/directives/cache/Control.d.ts +2 -1
- package/transpiled/directives/cache/Control.js +29 -12
- package/transpiled/directives/cache/Control.js.map +1 -1
- package/transpiled/directives/cors/CORS.js +1 -1
- package/transpiled/directives/cors/CORS.js.map +1 -1
- package/transpiled/directives/dev/Development.js +1 -1
- package/transpiled/directives/dev/Development.js.map +1 -1
- package/transpiled/directives/flow/Fetch.d.ts +13 -0
- package/transpiled/directives/flow/Fetch.js +59 -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 +27 -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 +5 -0
- package/transpiled/directives/flow/types.js.map +1 -0
- package/transpiled/directives/index.js +3 -1
- package/transpiled/directives/index.js.map +1 -1
- package/transpiled/directives/io/Input.js +2 -2
- package/transpiled/directives/io/Input.js.map +1 -1
- package/transpiled/directives/io/Output.js +2 -2
- package/transpiled/directives/io/Output.js.map +1 -1
- package/transpiled/directives/octets/Context.js +4 -24
- package/transpiled/directives/octets/Context.js.map +1 -1
- package/transpiled/directives/octets/Fetch.d.ts +3 -3
- package/transpiled/directives/octets/Fetch.js +8 -8
- package/transpiled/directives/octets/Fetch.js.map +1 -1
- package/transpiled/directives/octets/List.d.ts +3 -3
- package/transpiled/directives/octets/List.js +3 -3
- package/transpiled/directives/octets/List.js.map +1 -1
- package/transpiled/directives/octets/Octets.js +1 -3
- package/transpiled/directives/octets/Octets.js.map +1 -1
- package/transpiled/directives/octets/Store.d.ts +6 -1
- package/transpiled/directives/octets/Store.js +17 -7
- package/transpiled/directives/octets/Store.js.map +1 -1
- 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/schemas.d.ts +4 -6
- package/transpiled/directives/octets/schemas.js +1 -3
- package/transpiled/directives/octets/schemas.js.map +1 -1
- package/transpiled/directives/octets/workflows/Execution.d.ts +5 -1
- package/transpiled/directives/octets/workflows/Execution.js +44 -9
- package/transpiled/directives/octets/workflows/Execution.js.map +1 -1
- package/transpiled/directives/octets/workflows/Workflow.js +2 -1
- package/transpiled/directives/octets/workflows/Workflow.js.map +1 -1
- 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/directives/vary/Directive.d.ts +2 -1
- package/transpiled/directives/vary/Embed.d.ts +2 -1
- package/transpiled/directives/vary/Embed.js +8 -6
- package/transpiled/directives/vary/Embed.js.map +1 -1
- package/transpiled/directives/vary/Vary.d.ts +2 -2
- package/transpiled/directives/vary/Vary.js +3 -3
- package/transpiled/directives/vary/Vary.js.map +1 -1
- package/transpiled/directives/vary/embeddings/Authority.d.ts +5 -0
- package/transpiled/directives/vary/embeddings/Authority.js +10 -0
- package/transpiled/directives/vary/embeddings/Authority.js.map +1 -0
- package/transpiled/directives/vary/embeddings/Embedding.d.ts +2 -1
- package/transpiled/directives/vary/embeddings/Parameter.d.ts +7 -0
- package/transpiled/directives/vary/embeddings/Parameter.js +14 -0
- package/transpiled/directives/vary/embeddings/Parameter.js.map +1 -0
- package/transpiled/directives/vary/embeddings/index.d.ts +2 -2
- package/transpiled/directives/vary/embeddings/index.js +8 -4
- package/transpiled/directives/vary/embeddings/index.js.map +1 -1
- package/transpiled/exceptions.d.ts +3 -2
- package/transpiled/exceptions.js +14 -7
- package/transpiled/exceptions.js.map +1 -1
- package/transpiled/manifest.js +10 -11
- package/transpiled/manifest.js.map +1 -1
- package/transpiled/schemas.d.ts +1 -1
- package/transpiled/schemas.js +2 -2
- package/transpiled/schemas.js.map +1 -1
- package/transpiled/tsconfig.tsbuildinfo +1 -1
- package/tsconfig.json +9 -7
- package/components/identity.basic/operations/create.d.ts +0 -10
- package/components/identity.basic/operations/create.js +0 -10
- package/components/identity.basic/operations/create.js.map +0 -1
- package/components/identity.basic/source/create.ts +0 -18
- package/components/identity.federation/operations/create.d.ts +0 -10
- package/components/identity.federation/operations/create.js.map +0 -1
- package/components/identity.federation/operations/schemas.d.ts +0 -59
- package/components/identity.federation/operations/schemas.js +0 -9
- package/components/identity.federation/operations/schemas.js.map +0 -1
- package/components/identity.federation/operations/types.js.map +0 -1
- package/components/identity.federation/source/schemas.ts +0 -61
- package/components/octets.storage/operations/permute.js +0 -7
- package/schemas/octets/context.cos.yaml +0 -1
- package/source/HTTP/Server.test.ts +0 -126
- package/source/directives/octets/Permute.ts +0 -44
- package/transpiled/directives/octets/Permute.d.ts +0 -11
- package/transpiled/directives/octets/Permute.js +0 -58
- package/transpiled/directives/octets/Permute.js.map +0 -1
- /package/{components/identity.federation/operations → transpiled/directives/flow}/types.js +0 -0
package/source/RTD/Endpoint.ts
CHANGED
|
@@ -5,6 +5,9 @@ import type * as RTD from './index'
|
|
|
5
5
|
|
|
6
6
|
export interface Endpoint {
|
|
7
7
|
call: (context: http.Context, parameters: RTD.Parameter[]) => Promise<http.OutgoingMessage>
|
|
8
|
+
|
|
9
|
+
explain: (parameters: RTD.Parameter[]) => Promise<unknown>
|
|
10
|
+
|
|
8
11
|
close: () => Promise<void>
|
|
9
12
|
}
|
|
10
13
|
|
package/source/RTD/Method.ts
CHANGED
|
@@ -1,15 +1,31 @@
|
|
|
1
|
+
import type { Parameter } from './Match'
|
|
1
2
|
import type { Endpoint } from './Endpoint'
|
|
2
3
|
import type { Directives } from './Directives'
|
|
3
4
|
|
|
4
5
|
export class Method {
|
|
5
6
|
public readonly endpoint: Endpoint | null
|
|
6
7
|
public readonly directives: Directives
|
|
8
|
+
private introspection: unknown | null = null
|
|
9
|
+
private introspecting: Promise<unknown> | null = null
|
|
7
10
|
|
|
8
11
|
public constructor (endpoint: Endpoint | null, directives: Directives) {
|
|
9
12
|
this.endpoint = endpoint
|
|
10
13
|
this.directives = directives
|
|
11
14
|
}
|
|
12
15
|
|
|
16
|
+
public async explain (parameters: Parameter[]): Promise<unknown> {
|
|
17
|
+
if (this.introspection !== null)
|
|
18
|
+
return this.introspection
|
|
19
|
+
|
|
20
|
+
if (this.introspecting === null)
|
|
21
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-asserted-optional-chain
|
|
22
|
+
this.introspecting = this.endpoint?.explain(parameters)!
|
|
23
|
+
|
|
24
|
+
this.introspection = await this.introspecting
|
|
25
|
+
|
|
26
|
+
return this.introspection
|
|
27
|
+
}
|
|
28
|
+
|
|
13
29
|
public async close (): Promise<void> {
|
|
14
30
|
await this.endpoint?.close()
|
|
15
31
|
}
|
package/source/RTD/Node.ts
CHANGED
|
@@ -4,6 +4,7 @@ import { type Match, type Parameter } from './Match'
|
|
|
4
4
|
|
|
5
5
|
export class Node {
|
|
6
6
|
public intermediate: boolean
|
|
7
|
+
public forward: string | null
|
|
7
8
|
public methods: Methods
|
|
8
9
|
private readonly protected: boolean
|
|
9
10
|
private routes: Route[]
|
|
@@ -13,6 +14,7 @@ export class Node {
|
|
|
13
14
|
this.routes = routes
|
|
14
15
|
this.methods = methods
|
|
15
16
|
this.protected = properties.protected
|
|
17
|
+
this.forward = properties.forward ?? null
|
|
16
18
|
this.intermediate = this.routes.findIndex((route) => route.root) !== -1
|
|
17
19
|
|
|
18
20
|
this.sort()
|
|
@@ -20,7 +22,8 @@ export class Node {
|
|
|
20
22
|
|
|
21
23
|
public match (fragments: string[], parameters: Parameter[] = []): Match | null {
|
|
22
24
|
for (const route of this.routes) {
|
|
23
|
-
const
|
|
25
|
+
const params = parameters.slice()
|
|
26
|
+
const match = route.match(fragments, params)
|
|
24
27
|
|
|
25
28
|
if (match !== null)
|
|
26
29
|
return match
|
|
@@ -32,38 +35,46 @@ export class Node {
|
|
|
32
35
|
public merge (node: Node): void {
|
|
33
36
|
this.intermediate = node.intermediate
|
|
34
37
|
|
|
35
|
-
if (
|
|
36
|
-
this.replace(node)
|
|
37
|
-
else
|
|
38
|
+
if (this.protected)
|
|
38
39
|
this.append(node)
|
|
40
|
+
else
|
|
41
|
+
this.replace(node)
|
|
39
42
|
|
|
40
43
|
this.sort()
|
|
41
44
|
}
|
|
42
45
|
|
|
46
|
+
public async explain (parameters: Parameter[]): Promise<Record<string, unknown>> {
|
|
47
|
+
const methods: Record<string, unknown> = {}
|
|
48
|
+
|
|
49
|
+
const explained = Object.entries(this.methods)
|
|
50
|
+
.map(async ([verb, method]) =>
|
|
51
|
+
(methods[verb] = await method.explain(parameters)))
|
|
52
|
+
|
|
53
|
+
await Promise.all(explained)
|
|
54
|
+
|
|
55
|
+
return methods
|
|
56
|
+
}
|
|
57
|
+
|
|
43
58
|
private replace (node: Node): void {
|
|
44
59
|
const methods = Object.values(this.methods)
|
|
45
60
|
|
|
46
61
|
this.routes = node.routes
|
|
47
62
|
this.methods = node.methods
|
|
48
63
|
|
|
64
|
+
// race condition is really unlikely
|
|
49
65
|
for (const method of methods)
|
|
50
66
|
void method.close()
|
|
51
|
-
|
|
52
|
-
// race condition is really unlikely
|
|
53
67
|
}
|
|
54
68
|
|
|
55
69
|
private append (node: Node): void {
|
|
56
70
|
for (const route of node.routes)
|
|
57
|
-
this.
|
|
71
|
+
this.route(route)
|
|
58
72
|
|
|
59
73
|
for (const [verb, method] of Object.entries(node.methods))
|
|
60
|
-
|
|
61
|
-
console.warn(`Overriding of the protected method ${verb} is not permitted.`)
|
|
62
|
-
else
|
|
63
|
-
this.methods[verb] = method
|
|
74
|
+
this.methods[verb] = method
|
|
64
75
|
}
|
|
65
76
|
|
|
66
|
-
private
|
|
77
|
+
private route (candidate: Route): void {
|
|
67
78
|
for (const route of this.routes)
|
|
68
79
|
if (candidate.equals(route)) {
|
|
69
80
|
route.merge(candidate)
|
|
@@ -75,10 +86,15 @@ export class Node {
|
|
|
75
86
|
}
|
|
76
87
|
|
|
77
88
|
private sort (): void {
|
|
78
|
-
this.routes.sort((a, b) =>
|
|
89
|
+
this.routes.sort((a, b) => {
|
|
90
|
+
return a.variables === b.variables
|
|
91
|
+
? b.segments.length - a.segments.length // routes with more segments should be matched first
|
|
92
|
+
: a.variables - b.variables // routes with more variables should be matched last
|
|
93
|
+
})
|
|
79
94
|
}
|
|
80
95
|
}
|
|
81
96
|
|
|
82
97
|
export interface Properties {
|
|
83
98
|
protected: boolean
|
|
99
|
+
forward?: string
|
|
84
100
|
}
|
package/source/RTD/Route.ts
CHANGED
|
@@ -5,7 +5,7 @@ import { type Match, type Parameter } from './Match'
|
|
|
5
5
|
export class Route {
|
|
6
6
|
public readonly root: boolean
|
|
7
7
|
public readonly variables: number = 0
|
|
8
|
-
|
|
8
|
+
public readonly segments: Segment[]
|
|
9
9
|
private readonly node: Node
|
|
10
10
|
|
|
11
11
|
public constructor (segments: Segment[], node: Node) {
|
|
@@ -31,8 +31,10 @@ export class Route {
|
|
|
31
31
|
|
|
32
32
|
const exact = this.segments.length === fragments.length
|
|
33
33
|
|
|
34
|
-
if (exact && !this.node.intermediate)
|
|
35
|
-
|
|
34
|
+
if (exact && !this.node.intermediate)
|
|
35
|
+
return { node: this.node, parameters }
|
|
36
|
+
else
|
|
37
|
+
return this.matchNested(fragments, parameters)
|
|
36
38
|
}
|
|
37
39
|
|
|
38
40
|
public equals (route: Route): boolean {
|
|
@@ -52,7 +54,6 @@ export class Route {
|
|
|
52
54
|
|
|
53
55
|
private matchNested (fragments: string[], parameters: Parameter[]): Match | null {
|
|
54
56
|
fragments = fragments.slice(this.segments.length)
|
|
55
|
-
parameters = parameters.slice()
|
|
56
57
|
|
|
57
58
|
return this.node.match(fragments, parameters)
|
|
58
59
|
}
|
package/source/RTD/factory.ts
CHANGED
|
@@ -17,7 +17,10 @@ export function createNode (node: syntax.Node, context: Context): Node {
|
|
|
17
17
|
for (const method of node.methods)
|
|
18
18
|
methods[method.verb] = createMethod(method, context)
|
|
19
19
|
|
|
20
|
-
const properties: Properties = {
|
|
20
|
+
const properties: Properties = {
|
|
21
|
+
protected: node.protected ?? context.protected,
|
|
22
|
+
forward: node.forward
|
|
23
|
+
}
|
|
21
24
|
|
|
22
25
|
return new Node(routes, methods, properties)
|
|
23
26
|
}
|
|
@@ -33,7 +36,7 @@ function createRoute (route: syntax.Route, context: Context): Route {
|
|
|
33
36
|
}
|
|
34
37
|
|
|
35
38
|
function createMethod (method: syntax.Method, context: Context): Method {
|
|
36
|
-
const stack =
|
|
39
|
+
const stack = method.directives.concat(context.directives.stack)
|
|
37
40
|
const directives = context.directives.factory.create(stack)
|
|
38
41
|
|
|
39
42
|
const endpoint = method.mapping?.endpoint === undefined
|
|
@@ -17,42 +17,56 @@ export function parse (input: object, shortcuts?: Shortcuts): Node {
|
|
|
17
17
|
return node
|
|
18
18
|
}
|
|
19
19
|
|
|
20
|
-
function parseNode (input: object, shortcuts?: Shortcuts): Node {
|
|
20
|
+
function parseNode (input: object | string, shortcuts?: Shortcuts): Node {
|
|
21
21
|
const node = createNode()
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
node[key as keyof Node] = value
|
|
23
|
+
if (typeof input === 'string') {
|
|
24
|
+
node.forward = input
|
|
26
25
|
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
return node
|
|
27
|
+
}
|
|
29
28
|
|
|
30
|
-
|
|
31
|
-
|
|
29
|
+
for (const [key, value] of Object.entries(input) as Array<[keyof Node, unknown]>)
|
|
30
|
+
switch (key) {
|
|
31
|
+
case 'protected':
|
|
32
|
+
case 'isolated':
|
|
33
|
+
node[key] = value as boolean
|
|
34
|
+
break
|
|
35
|
+
case 'forward':
|
|
36
|
+
node[key] = value as string
|
|
37
|
+
break
|
|
32
38
|
|
|
33
|
-
|
|
39
|
+
default:
|
|
40
|
+
// eslint-disable-next-line max-depth
|
|
41
|
+
if (key[0] === '/') {
|
|
42
|
+
const route = parseRoute(key, value as Node, shortcuts)
|
|
34
43
|
|
|
35
|
-
|
|
36
|
-
}
|
|
44
|
+
node.routes.push(route)
|
|
37
45
|
|
|
38
|
-
|
|
39
|
-
|
|
46
|
+
continue
|
|
47
|
+
}
|
|
40
48
|
|
|
41
|
-
|
|
49
|
+
// eslint-disable-next-line max-depth
|
|
50
|
+
if (verbs.has(key)) {
|
|
51
|
+
const method = parseMethod(key, value as Mapping, shortcuts)
|
|
42
52
|
|
|
43
|
-
|
|
44
|
-
}
|
|
53
|
+
node.methods.push(method)
|
|
45
54
|
|
|
46
|
-
|
|
55
|
+
continue
|
|
56
|
+
}
|
|
47
57
|
|
|
48
|
-
|
|
49
|
-
|
|
58
|
+
// eslint-disable-next-line no-case-declarations
|
|
59
|
+
const directive = parseDirective(key, value, shortcuts)
|
|
50
60
|
|
|
51
|
-
|
|
52
|
-
|
|
61
|
+
// eslint-disable-next-line max-depth
|
|
62
|
+
if (directive !== null) {
|
|
63
|
+
node.directives.push(directive)
|
|
53
64
|
|
|
54
|
-
|
|
55
|
-
|
|
65
|
+
continue
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
throw new Error(`RTD parse error: unknown key '${key}'.`)
|
|
69
|
+
}
|
|
56
70
|
|
|
57
71
|
return node
|
|
58
72
|
}
|
|
@@ -149,6 +163,5 @@ function expandRange (range: number): Range {
|
|
|
149
163
|
}
|
|
150
164
|
|
|
151
165
|
const DIRECTIVE_RX = /^(?<family>\w{1,32}):(?<name>\w{1,32})$/
|
|
152
|
-
const PROPERTIES: Array<keyof Node> = ['protected', 'isolated']
|
|
153
166
|
|
|
154
167
|
export type Shortcuts = Map<string, string>
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export interface Node {
|
|
2
2
|
protected?: boolean
|
|
3
3
|
isolated?: boolean
|
|
4
|
+
forward?: string
|
|
4
5
|
routes: Route[]
|
|
5
6
|
methods: Method[]
|
|
6
7
|
directives: Directive[]
|
|
@@ -27,17 +28,18 @@ export interface Mapping {
|
|
|
27
28
|
namespace?: string
|
|
28
29
|
component?: string
|
|
29
30
|
endpoint: string
|
|
30
|
-
query?: Query
|
|
31
|
+
query?: Query | null
|
|
31
32
|
}
|
|
32
33
|
|
|
33
34
|
export interface Query {
|
|
34
35
|
id?: string
|
|
35
36
|
criteria?: string
|
|
36
37
|
sort?: string
|
|
37
|
-
omit
|
|
38
|
-
limit
|
|
38
|
+
omit?: Range
|
|
39
|
+
limit?: Range
|
|
39
40
|
selectors?: string[]
|
|
40
41
|
projection?: string[]
|
|
42
|
+
parameters?: string[]
|
|
41
43
|
}
|
|
42
44
|
|
|
43
45
|
export interface Range {
|
|
@@ -45,4 +47,4 @@ export interface Range {
|
|
|
45
47
|
range: [number, number]
|
|
46
48
|
}
|
|
47
49
|
|
|
48
|
-
export const verbs = new Set<string>(['GET', 'POST', 'PUT', 'PATCH', 'DELETE', '
|
|
50
|
+
export const verbs = new Set<string>(['GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'LOCK', 'UNLOCK'])
|
package/source/Remotes.ts
CHANGED
|
@@ -1,24 +1,17 @@
|
|
|
1
|
-
import { Locator, Connector, type
|
|
1
|
+
import { Locator, Connector, type Remote } from '@toa.io/core'
|
|
2
2
|
import { type Bootloader } from './Factory'
|
|
3
3
|
|
|
4
4
|
export class Remotes extends Connector {
|
|
5
5
|
private readonly boot: Bootloader
|
|
6
|
-
private readonly remotes: Record<string, Promise<Component>> = {}
|
|
7
6
|
|
|
8
7
|
public constructor (boot: Bootloader) {
|
|
9
8
|
super()
|
|
10
9
|
this.boot = boot
|
|
11
10
|
}
|
|
12
11
|
|
|
13
|
-
public async discover (namespace: string, name: string): Promise<
|
|
12
|
+
public async discover (namespace: string, name: string): Promise<Remote> {
|
|
14
13
|
const locator = new Locator(name, namespace)
|
|
15
14
|
|
|
16
|
-
this.remotes[locator.id] ??= this.create(locator)
|
|
17
|
-
|
|
18
|
-
return await this.remotes[locator.id]
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
private async create (locator: Locator): Promise<Component> {
|
|
22
15
|
const remote = await this.boot.remote(locator)
|
|
23
16
|
|
|
24
17
|
this.depends(remote)
|
package/source/Tenant.ts
CHANGED
|
@@ -25,14 +25,6 @@ export class Tenant extends Connector {
|
|
|
25
25
|
public override async open (): Promise<void> {
|
|
26
26
|
await this.expose()
|
|
27
27
|
await this.broadcast.receive('ping', this.expose.bind(this))
|
|
28
|
-
|
|
29
|
-
console.info('Exposition Tenant for ' +
|
|
30
|
-
`'${this.branch.namespace}.${this.branch.component}' has started.`)
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
public override async dispose (): Promise<void> {
|
|
34
|
-
console.info('Exposition Tenant for ' +
|
|
35
|
-
`'${this.branch.namespace}.${this.branch.component}' has been stopped.`)
|
|
36
28
|
}
|
|
37
29
|
|
|
38
30
|
private async expose (): Promise<void> {
|
package/source/deployment.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import assert from 'node:assert'
|
|
1
2
|
import { type Dependency, type Service } from '@toa.io/operations'
|
|
2
3
|
import { encode } from '@toa.io/generic'
|
|
3
4
|
import { type Annotation } from './Annotation'
|
|
@@ -5,50 +6,59 @@ import * as schemas from './schemas'
|
|
|
5
6
|
import { shortcuts } from './Directive'
|
|
6
7
|
import { components } from './Composition'
|
|
7
8
|
import { parse } from './RTD/syntax'
|
|
9
|
+
import { DELAY, PORT } from './HTTP'
|
|
10
|
+
|
|
11
|
+
export function deployment (_: unknown, annotation?: Annotation): Dependency {
|
|
12
|
+
assert.ok(annotation !== undefined, 'Exposition context annotation is required')
|
|
13
|
+
schemas.annotation.validate(annotation)
|
|
8
14
|
|
|
9
|
-
export function deployment (_: unknown, annotation: Annotation | undefined): Dependency {
|
|
10
15
|
const labels = components().labels
|
|
11
16
|
|
|
12
17
|
const service: Service = {
|
|
13
18
|
group: 'exposition',
|
|
14
19
|
name: 'gateway',
|
|
15
|
-
port:
|
|
20
|
+
port: PORT,
|
|
16
21
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
17
22
|
version: require('../package.json').version,
|
|
18
23
|
variables: [],
|
|
19
|
-
components: labels
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
class: annotation.class,
|
|
26
|
-
annotations: annotation.annotations
|
|
24
|
+
components: labels,
|
|
25
|
+
ingress: { hosts: [] },
|
|
26
|
+
probe: {
|
|
27
|
+
path: '/.ready',
|
|
28
|
+
port: PORT,
|
|
29
|
+
delay: DELAY
|
|
27
30
|
}
|
|
31
|
+
}
|
|
28
32
|
|
|
29
33
|
if (annotation?.['/'] !== undefined) {
|
|
30
34
|
const tree = parse(annotation['/'], shortcuts)
|
|
31
35
|
|
|
32
|
-
service.variables
|
|
36
|
+
service.variables!.push({
|
|
33
37
|
name: 'TOA_EXPOSITION',
|
|
34
38
|
value: encode(tree)
|
|
35
39
|
})
|
|
36
40
|
}
|
|
37
41
|
|
|
38
|
-
|
|
39
|
-
service.variables.push({
|
|
40
|
-
name: 'TOA_EXPOSITION_DEBUG',
|
|
41
|
-
value: '1'
|
|
42
|
-
})
|
|
42
|
+
const { debug, trace, authorities } = annotation
|
|
43
43
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
44
|
+
service.ingress!.hosts = Object.values(authorities)
|
|
45
|
+
service.ingress!.class = annotation.class
|
|
46
|
+
service.ingress!.annotations = annotation.annotations
|
|
47
|
+
|
|
48
|
+
const properties: Properties = { authorities }
|
|
49
|
+
|
|
50
|
+
if (debug === true)
|
|
51
|
+
properties.debug = true
|
|
49
52
|
|
|
50
|
-
if (
|
|
51
|
-
|
|
53
|
+
if (trace === true)
|
|
54
|
+
properties.trace = true
|
|
55
|
+
|
|
56
|
+
service.variables!.push({
|
|
57
|
+
name: 'TOA_EXPOSITION_PROPERTIES',
|
|
58
|
+
value: encode(properties)
|
|
59
|
+
})
|
|
52
60
|
|
|
53
61
|
return { services: [service] }
|
|
54
62
|
}
|
|
63
|
+
|
|
64
|
+
type Properties = Pick<Annotation, 'authorities' | 'debug' | 'trace'>
|
|
@@ -7,8 +7,10 @@ import { Role } from './Role'
|
|
|
7
7
|
import { Rule } from './Rule'
|
|
8
8
|
import { Incept } from './Incept'
|
|
9
9
|
import { Echo } from './Echo'
|
|
10
|
-
import { split } from './split'
|
|
11
10
|
import { Scheme } from './Scheme'
|
|
11
|
+
import { Delegate } from './Delegate'
|
|
12
|
+
import { Federation } from './Federation'
|
|
13
|
+
import { split } from './split'
|
|
12
14
|
import { PRIMARY, PROVIDERS } from './schemes'
|
|
13
15
|
import type { Output } from '../../io'
|
|
14
16
|
import type { Component } from '@toa.io/core'
|
|
@@ -38,7 +40,7 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
|
|
|
38
40
|
|
|
39
41
|
public create (name: string, value: any, remotes: Remotes): Directive {
|
|
40
42
|
assert.ok(name in constructors,
|
|
41
|
-
`Directive '
|
|
43
|
+
`Directive 'auth:${name}' is not implemented.`)
|
|
42
44
|
|
|
43
45
|
const Class = constructors[name]
|
|
44
46
|
|
|
@@ -49,13 +51,22 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
|
|
|
49
51
|
Role, () => new Role(value as string | string[], this.discovery.roles),
|
|
50
52
|
Rule, () => new Rule(value as Record<string, string>, this.create.bind(this)),
|
|
51
53
|
Incept, () => new Incept(value as string, this.discovery),
|
|
54
|
+
Delegate, () => new Delegate(value as string, this.discovery.roles),
|
|
52
55
|
() => new Class(value))
|
|
53
56
|
}
|
|
54
57
|
|
|
55
58
|
public async preflight (directives: Directive[],
|
|
56
59
|
input: Input,
|
|
57
60
|
parameters: Parameter[]): Promise<Output> {
|
|
58
|
-
|
|
61
|
+
/**
|
|
62
|
+
* Some authentication scheme providers may create identity during authentication;
|
|
63
|
+
* therefore, we need to skip the authentication process if the Incept directive is present.
|
|
64
|
+
*
|
|
65
|
+
* If the provided credentials already exist,
|
|
66
|
+
* the inception will cause a unique constraint violation on the settle stage.
|
|
67
|
+
*/
|
|
68
|
+
const inception = directives.reduce((yes, directive) => yes || directive instanceof Incept, false)
|
|
69
|
+
const identity = inception ? null : await this.resolve(input.authority, input.request.headers.authorization)
|
|
59
70
|
|
|
60
71
|
input.identity = identity
|
|
61
72
|
|
|
@@ -79,25 +90,31 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
|
|
|
79
90
|
|
|
80
91
|
const identity = request.identity
|
|
81
92
|
|
|
82
|
-
if (identity === null)
|
|
93
|
+
if (identity === null)
|
|
94
|
+
return
|
|
83
95
|
|
|
84
|
-
if (identity.scheme === PRIMARY && !identity.refresh)
|
|
96
|
+
if (identity.scheme === PRIMARY && !identity.refresh)
|
|
97
|
+
return
|
|
85
98
|
|
|
86
99
|
// Role directive may have already set the value
|
|
87
|
-
if (identity.roles === undefined)
|
|
100
|
+
if (identity.roles === undefined)
|
|
101
|
+
await Role.set(identity, this.discovery.roles)
|
|
88
102
|
|
|
89
103
|
this.tokens ??= await this.discovery.tokens
|
|
90
104
|
|
|
91
|
-
const token = await this.tokens.invoke<string>('encrypt', {
|
|
92
|
-
|
|
105
|
+
const token = await this.tokens.invoke<string>('encrypt', {
|
|
106
|
+
input: { authority: request.authority, identity }
|
|
107
|
+
})
|
|
93
108
|
|
|
94
|
-
|
|
109
|
+
const authorization = `Token ${token}`
|
|
95
110
|
|
|
111
|
+
response.headers ??= new Headers()
|
|
96
112
|
response.headers.set('authorization', authorization)
|
|
97
113
|
}
|
|
98
114
|
|
|
99
|
-
private async resolve (authorization: string | undefined): Promise<Identity | null> {
|
|
100
|
-
if (authorization === undefined)
|
|
115
|
+
private async resolve (authority: string, authorization: string | undefined): Promise<Identity | null> {
|
|
116
|
+
if (authorization === undefined)
|
|
117
|
+
return null
|
|
101
118
|
|
|
102
119
|
const [scheme, credentials] = split(authorization)
|
|
103
120
|
const provider = PROVIDERS[scheme]
|
|
@@ -108,10 +125,14 @@ export class Authorization implements DirectiveFamily<Directive, Extension> {
|
|
|
108
125
|
this.schemes[scheme] ??= await this.discovery[provider]
|
|
109
126
|
|
|
110
127
|
const result = await this.schemes[scheme].invoke<AuthenticationResult>('authenticate', {
|
|
111
|
-
input:
|
|
128
|
+
input: {
|
|
129
|
+
authority,
|
|
130
|
+
credentials
|
|
131
|
+
}
|
|
112
132
|
})
|
|
113
133
|
|
|
114
|
-
if (result instanceof Error)
|
|
134
|
+
if (result instanceof Error)
|
|
135
|
+
return null
|
|
115
136
|
|
|
116
137
|
const identity = result.identity
|
|
117
138
|
|
|
@@ -139,7 +160,9 @@ const constructors: Record<string, new (value: any, argument?: any) => Directive
|
|
|
139
160
|
rule: Rule,
|
|
140
161
|
incept: Incept,
|
|
141
162
|
scheme: Scheme,
|
|
142
|
-
echo: Echo
|
|
163
|
+
echo: Echo,
|
|
164
|
+
delegate: Delegate,
|
|
165
|
+
claim: Federation
|
|
143
166
|
}
|
|
144
167
|
|
|
145
168
|
const REMOTES: Remote[] = ['basic', 'federation', 'tokens', 'roles', 'bans']
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { BadRequest } from '../../HTTP'
|
|
2
|
+
import { type Directive, type Identity } from './types'
|
|
3
|
+
import { Role } from './Role'
|
|
4
|
+
import type { Component } from '@toa.io/core'
|
|
5
|
+
import type { Input } from '../../io'
|
|
6
|
+
|
|
7
|
+
export class Delegate implements Directive {
|
|
8
|
+
private readonly property: string
|
|
9
|
+
private readonly discovery: Promise<Component>
|
|
10
|
+
|
|
11
|
+
public constructor (property: string, discovery: Promise<Component>) {
|
|
12
|
+
this.property = property
|
|
13
|
+
this.discovery = discovery
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
public async authorize (identity: Identity | null, context: Input): Promise<boolean> {
|
|
17
|
+
if (identity === null)
|
|
18
|
+
return false
|
|
19
|
+
|
|
20
|
+
if (identity.roles === undefined)
|
|
21
|
+
await Role.set(identity, this.discovery)
|
|
22
|
+
|
|
23
|
+
context.pipelines.body.push((body) => this.embed(body, identity))
|
|
24
|
+
|
|
25
|
+
return true
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
private embed (body: unknown, identity: Identity): Record<string, unknown> {
|
|
29
|
+
if (body === undefined)
|
|
30
|
+
body = {}
|
|
31
|
+
|
|
32
|
+
check(body)
|
|
33
|
+
body[this.property] = structuredClone(identity)
|
|
34
|
+
|
|
35
|
+
return body
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function check (body: unknown): asserts body is Record<string, unknown> {
|
|
40
|
+
if (typeof body !== 'object' || body === null)
|
|
41
|
+
throw new BadRequest('Invalid request body')
|
|
42
|
+
}
|