@atproto/oauth-provider 0.6.6 → 0.7.1
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/CHANGELOG.md +49 -0
- package/dist/access-token/access-token-mode.d.ts +5 -0
- package/dist/access-token/access-token-mode.d.ts.map +1 -0
- package/dist/access-token/access-token-mode.js +9 -0
- package/dist/access-token/access-token-mode.js.map +1 -0
- package/dist/account/account-manager.d.ts +13 -7
- package/dist/account/account-manager.d.ts.map +1 -1
- package/dist/account/account-manager.js +69 -52
- package/dist/account/account-manager.js.map +1 -1
- package/dist/account/account-store.d.ts +88 -77
- package/dist/account/account-store.d.ts.map +1 -1
- package/dist/account/account-store.js +24 -73
- package/dist/account/account-store.js.map +1 -1
- package/dist/account/sign-in-data.d.ts +4 -13
- package/dist/account/sign-in-data.d.ts.map +1 -1
- package/dist/account/sign-in-data.js +9 -9
- package/dist/account/sign-in-data.js.map +1 -1
- package/dist/account/sign-up-input.d.ts +4 -5
- package/dist/account/sign-up-input.d.ts.map +1 -1
- package/dist/account/sign-up-input.js +13 -3
- package/dist/account/sign-up-input.js.map +1 -1
- package/dist/client/client-manager.d.ts +4 -1
- package/dist/client/client-manager.d.ts.map +1 -1
- package/dist/client/client-manager.js +13 -1
- package/dist/client/client-manager.js.map +1 -1
- package/dist/client/client-store.d.ts +1 -1
- package/dist/client/client-store.d.ts.map +1 -1
- package/dist/constants.d.ts +5 -1
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +6 -2
- package/dist/constants.js.map +1 -1
- package/dist/customization/branding.d.ts +54 -0
- package/dist/customization/branding.d.ts.map +1 -0
- package/dist/customization/branding.js +13 -0
- package/dist/customization/branding.js.map +1 -0
- package/dist/customization/build-customization-css.d.ts +3 -0
- package/dist/customization/build-customization-css.d.ts.map +1 -0
- package/dist/customization/build-customization-css.js +27 -0
- package/dist/customization/build-customization-css.js.map +1 -0
- package/dist/customization/build-customization-data.d.ts +4 -0
- package/dist/customization/build-customization-data.d.ts.map +1 -0
- package/dist/customization/build-customization-data.js +18 -0
- package/dist/customization/build-customization-data.js.map +1 -0
- package/dist/customization/colors.d.ts +7 -0
- package/dist/customization/colors.d.ts.map +1 -0
- package/dist/customization/colors.js +27 -0
- package/dist/customization/colors.js.map +1 -0
- package/dist/customization/customization.d.ts +129 -0
- package/dist/customization/customization.d.ts.map +1 -0
- package/dist/customization/customization.js +26 -0
- package/dist/customization/customization.js.map +1 -0
- package/dist/customization/links.d.ts +26 -0
- package/dist/customization/links.d.ts.map +1 -0
- package/dist/customization/links.js +12 -0
- package/dist/customization/links.js.map +1 -0
- package/dist/device/device-id.d.ts +1 -0
- package/dist/device/device-id.d.ts.map +1 -1
- package/dist/device/device-id.js +4 -0
- package/dist/device/device-id.js.map +1 -1
- package/dist/device/device-manager.d.ts +6 -36
- package/dist/device/device-manager.d.ts.map +1 -1
- package/dist/device/device-manager.js +49 -43
- package/dist/device/device-manager.js.map +1 -1
- package/dist/device/device-store.d.ts +1 -0
- package/dist/device/device-store.d.ts.map +1 -1
- package/dist/device/device-store.js.map +1 -1
- package/dist/dpop/dpop-manager.d.ts +3 -3
- package/dist/dpop/dpop-nonce.d.ts +3 -3
- package/dist/dpop/dpop-nonce.d.ts.map +1 -1
- package/dist/errors/access-denied-error.d.ts +4 -3
- package/dist/errors/access-denied-error.d.ts.map +1 -1
- package/dist/errors/access-denied-error.js +5 -6
- package/dist/errors/access-denied-error.js.map +1 -1
- package/dist/{output/build-error-payload.d.ts → errors/error-parser.d.ts} +1 -1
- package/dist/errors/error-parser.d.ts.map +1 -0
- package/dist/{output/build-error-payload.js → errors/error-parser.js} +2 -2
- package/dist/errors/error-parser.js.map +1 -0
- package/dist/errors/invalid-grant-error.d.ts +1 -0
- package/dist/errors/invalid-grant-error.d.ts.map +1 -1
- package/dist/errors/invalid-grant-error.js +5 -0
- package/dist/errors/invalid-grant-error.js.map +1 -1
- package/dist/errors/login-required-error.d.ts +1 -0
- package/dist/errors/login-required-error.d.ts.map +1 -1
- package/dist/errors/login-required-error.js +5 -0
- package/dist/errors/login-required-error.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/html/build-document.d.ts +2 -2
- package/dist/lib/html/build-document.d.ts.map +1 -1
- package/dist/lib/html/build-document.js +4 -0
- package/dist/lib/html/build-document.js.map +1 -1
- package/dist/lib/html/hydration-data.d.ts +4 -0
- package/dist/lib/html/hydration-data.d.ts.map +1 -0
- package/dist/{output/backend-data.js → lib/html/hydration-data.js} +8 -8
- package/dist/lib/html/hydration-data.js.map +1 -0
- package/dist/lib/html/tags.d.ts +1 -1
- package/dist/lib/html/tags.d.ts.map +1 -1
- package/dist/lib/html/tags.js +1 -1
- package/dist/lib/html/tags.js.map +1 -1
- package/dist/lib/http/accept.d.ts +2 -2
- package/dist/lib/http/accept.d.ts.map +1 -1
- package/dist/lib/http/accept.js +1 -1
- package/dist/lib/http/accept.js.map +1 -1
- package/dist/lib/http/context.d.ts +2 -4
- package/dist/lib/http/context.d.ts.map +1 -1
- package/dist/lib/http/context.js +29 -4
- package/dist/lib/http/context.js.map +1 -1
- package/dist/lib/http/headers.d.ts +3 -0
- package/dist/lib/http/headers.d.ts.map +1 -0
- package/dist/lib/http/headers.js +14 -0
- package/dist/lib/http/headers.js.map +1 -0
- package/dist/lib/http/index.d.ts +1 -0
- package/dist/lib/http/index.d.ts.map +1 -1
- package/dist/lib/http/index.js +1 -0
- package/dist/lib/http/index.js.map +1 -1
- package/dist/lib/http/middleware.d.ts +1 -1
- package/dist/lib/http/middleware.d.ts.map +1 -1
- package/dist/lib/http/middleware.js +8 -24
- package/dist/lib/http/middleware.js.map +1 -1
- package/dist/lib/http/parser.d.ts +3 -3
- package/dist/lib/http/parser.d.ts.map +1 -1
- package/dist/lib/http/request.d.ts +13 -9
- package/dist/lib/http/request.d.ts.map +1 -1
- package/dist/lib/http/request.js +27 -49
- package/dist/lib/http/request.js.map +1 -1
- package/dist/lib/http/response.d.ts +6 -2
- package/dist/lib/http/response.d.ts.map +1 -1
- package/dist/lib/http/response.js +31 -11
- package/dist/lib/http/response.js.map +1 -1
- package/dist/lib/http/route.d.ts +3 -3
- package/dist/lib/http/route.d.ts.map +1 -1
- package/dist/lib/http/route.js +1 -1
- package/dist/lib/http/route.js.map +1 -1
- package/dist/lib/http/router.d.ts +12 -11
- package/dist/lib/http/router.d.ts.map +1 -1
- package/dist/lib/http/router.js +26 -34
- package/dist/lib/http/router.js.map +1 -1
- package/dist/lib/http/security-headers.js +1 -1
- package/dist/lib/http/security-headers.js.map +1 -1
- package/dist/lib/http/stream.d.ts +3 -3
- package/dist/lib/http/stream.d.ts.map +1 -1
- package/dist/lib/http/types.d.ts +1 -1
- package/dist/lib/http/types.d.ts.map +1 -1
- package/dist/lib/send-web-page.d.ts +8 -0
- package/dist/lib/send-web-page.d.ts.map +1 -0
- package/dist/{output → lib}/send-web-page.js +9 -7
- package/dist/lib/send-web-page.js.map +1 -0
- package/dist/lib/util/authorization-header.d.ts.map +1 -1
- package/dist/lib/util/color.d.ts +32 -0
- package/dist/lib/util/color.d.ts.map +1 -0
- package/dist/lib/util/color.js +116 -0
- package/dist/lib/util/color.js.map +1 -0
- package/dist/lib/util/crypto.d.ts +1 -0
- package/dist/lib/util/crypto.d.ts.map +1 -1
- package/dist/lib/util/crypto.js +8 -3
- package/dist/lib/util/crypto.js.map +1 -1
- package/dist/lib/util/function.d.ts +1 -0
- package/dist/lib/util/function.d.ts.map +1 -1
- package/dist/lib/util/function.js +12 -0
- package/dist/lib/util/function.js.map +1 -1
- package/dist/lib/util/locale.d.ts +20 -0
- package/dist/lib/util/locale.d.ts.map +1 -0
- package/dist/lib/util/locale.js +14 -0
- package/dist/lib/util/locale.js.map +1 -0
- package/dist/lib/util/time.d.ts +1 -1
- package/dist/lib/util/time.d.ts.map +1 -1
- package/dist/lib/util/time.js +1 -1
- package/dist/lib/util/time.js.map +1 -1
- package/dist/lib/util/type.d.ts +22 -0
- package/dist/lib/util/type.d.ts.map +1 -1
- package/dist/lib/util/type.js.map +1 -1
- package/dist/lib/util/ui8.d.ts +4 -0
- package/dist/lib/util/ui8.d.ts.map +1 -0
- package/dist/lib/util/ui8.js +17 -0
- package/dist/lib/util/ui8.js.map +1 -0
- package/dist/lib/util/zod-error.d.ts +2 -0
- package/dist/lib/util/zod-error.d.ts.map +1 -0
- package/dist/lib/util/zod-error.js +16 -0
- package/dist/lib/util/zod-error.js.map +1 -0
- package/dist/oauth-errors.d.ts +22 -22
- package/dist/oauth-errors.d.ts.map +1 -1
- package/dist/oauth-errors.js +37 -45
- package/dist/oauth-errors.js.map +1 -1
- package/dist/oauth-hooks.d.ts +11 -23
- package/dist/oauth-hooks.d.ts.map +1 -1
- package/dist/oauth-hooks.js.map +1 -1
- package/dist/oauth-middleware.d.ts +12 -0
- package/dist/oauth-middleware.d.ts.map +1 -0
- package/dist/oauth-middleware.js +32 -0
- package/dist/oauth-middleware.js.map +1 -0
- package/dist/oauth-provider.d.ts +109 -113
- package/dist/oauth-provider.d.ts.map +1 -1
- package/dist/oauth-provider.js +124 -542
- package/dist/oauth-provider.js.map +1 -1
- package/dist/oauth-verifier.d.ts +7 -26
- package/dist/oauth-verifier.d.ts.map +1 -1
- package/dist/oauth-verifier.js +6 -16
- package/dist/oauth-verifier.js.map +1 -1
- package/dist/request/code.d.ts.map +1 -1
- package/dist/request/request-data.d.ts +2 -4
- package/dist/request/request-data.d.ts.map +1 -1
- package/dist/request/request-data.js.map +1 -1
- package/dist/request/request-manager.d.ts +4 -2
- package/dist/request/request-manager.d.ts.map +1 -1
- package/dist/request/request-manager.js +9 -8
- package/dist/request/request-manager.js.map +1 -1
- package/dist/request/request-store.d.ts +6 -0
- package/dist/request/request-store.d.ts.map +1 -1
- package/dist/request/request-store.js +3 -1
- package/dist/request/request-store.js.map +1 -1
- package/dist/result/authorization-redirect-parameters.d.ts +18 -0
- package/dist/result/authorization-redirect-parameters.d.ts.map +1 -0
- package/dist/result/authorization-redirect-parameters.js +3 -0
- package/dist/result/authorization-redirect-parameters.js.map +1 -0
- package/dist/result/authorization-result-authorize-page.d.ts +13 -0
- package/dist/result/authorization-result-authorize-page.d.ts.map +1 -0
- package/dist/result/authorization-result-authorize-page.js +3 -0
- package/dist/result/authorization-result-authorize-page.js.map +1 -0
- package/dist/result/authorization-result-redirect.d.ts +8 -0
- package/dist/result/authorization-result-redirect.d.ts.map +1 -0
- package/dist/result/authorization-result-redirect.js +3 -0
- package/dist/result/authorization-result-redirect.js.map +1 -0
- package/dist/router/assets/assets-manifest.d.ts +10 -0
- package/dist/router/assets/assets-manifest.d.ts.map +1 -0
- package/dist/router/assets/assets-manifest.js +77 -0
- package/dist/router/assets/assets-manifest.js.map +1 -0
- package/dist/router/assets/assets.d.ts +16 -0
- package/dist/router/assets/assets.d.ts.map +1 -0
- package/dist/router/assets/assets.js +43 -0
- package/dist/router/assets/assets.js.map +1 -0
- package/dist/router/assets/csrf.d.ts +4 -0
- package/dist/router/assets/csrf.d.ts.map +1 -0
- package/dist/router/assets/csrf.js +51 -0
- package/dist/router/assets/csrf.js.map +1 -0
- package/dist/router/assets/send-account-page.d.ts +7 -0
- package/dist/router/assets/send-account-page.d.ts.map +1 -0
- package/dist/router/assets/send-account-page.js +34 -0
- package/dist/router/assets/send-account-page.js.map +1 -0
- package/dist/router/assets/send-authorization-page.d.ts +5 -0
- package/dist/router/assets/send-authorization-page.d.ts.map +1 -0
- package/dist/router/assets/send-authorization-page.js +49 -0
- package/dist/router/assets/send-authorization-page.js.map +1 -0
- package/dist/router/assets/send-error-page.d.ts +4 -0
- package/dist/router/assets/send-error-page.d.ts.map +1 -0
- package/dist/router/assets/send-error-page.js +34 -0
- package/dist/router/assets/send-error-page.js.map +1 -0
- package/dist/router/create-account-page-middleware.d.ts +6 -0
- package/dist/router/create-account-page-middleware.d.ts.map +1 -0
- package/dist/router/create-account-page-middleware.js +39 -0
- package/dist/router/create-account-page-middleware.js.map +1 -0
- package/dist/router/create-api-middleware.d.ts +8 -0
- package/dist/router/create-api-middleware.d.ts.map +1 -0
- package/dist/router/create-api-middleware.js +501 -0
- package/dist/router/create-api-middleware.js.map +1 -0
- package/dist/router/create-authorization-page-middleware.d.ts +6 -0
- package/dist/router/create-authorization-page-middleware.d.ts.map +1 -0
- package/dist/router/create-authorization-page-middleware.js +104 -0
- package/dist/router/create-authorization-page-middleware.js.map +1 -0
- package/dist/router/create-oauth-middleware.d.ts +6 -0
- package/dist/router/create-oauth-middleware.d.ts.map +1 -0
- package/dist/router/create-oauth-middleware.js +142 -0
- package/dist/router/create-oauth-middleware.js.map +1 -0
- package/dist/router/error-handler.d.ts +3 -0
- package/dist/router/error-handler.d.ts.map +1 -0
- package/dist/{account/account.js → router/error-handler.js} +1 -1
- package/dist/router/error-handler.js.map +1 -0
- package/dist/router/middleware-options.d.ts +6 -0
- package/dist/router/middleware-options.d.ts.map +1 -0
- package/dist/router/middleware-options.js +3 -0
- package/dist/router/middleware-options.js.map +1 -0
- package/dist/router/send-redirect.d.ts +16 -0
- package/dist/router/send-redirect.d.ts.map +1 -0
- package/dist/{output/send-authorize-redirect.js → router/send-redirect.js} +40 -24
- package/dist/router/send-redirect.js.map +1 -0
- package/dist/{token/token-claims.d.ts → signer/api-token-payload.d.ts} +237 -232
- package/dist/signer/api-token-payload.d.ts.map +1 -0
- package/dist/signer/api-token-payload.js +17 -0
- package/dist/signer/api-token-payload.js.map +1 -0
- package/dist/signer/signed-token-payload.d.ts +164 -159
- package/dist/signer/signed-token-payload.d.ts.map +1 -1
- package/dist/signer/signed-token-payload.js +10 -16
- package/dist/signer/signed-token-payload.js.map +1 -1
- package/dist/signer/signer.d.ts +42 -11246
- package/dist/signer/signer.d.ts.map +1 -1
- package/dist/signer/signer.js +30 -15
- package/dist/signer/signer.js.map +1 -1
- package/dist/token/refresh-token.d.ts.map +1 -1
- package/dist/token/token-data.d.ts +1 -1
- package/dist/token/token-data.d.ts.map +1 -1
- package/dist/token/token-id.d.ts.map +1 -1
- package/dist/token/token-manager.d.ts +28 -26
- package/dist/token/token-manager.d.ts.map +1 -1
- package/dist/token/token-manager.js +138 -196
- package/dist/token/token-manager.js.map +1 -1
- package/dist/token/token-store.d.ts +4 -4
- package/dist/token/token-store.d.ts.map +1 -1
- package/dist/token/token-store.js +1 -0
- package/dist/token/token-store.js.map +1 -1
- package/dist/token/verify-token-claims.d.ts +3 -3
- package/dist/token/verify-token-claims.d.ts.map +1 -1
- package/dist/token/verify-token-claims.js +1 -1
- package/dist/token/verify-token-claims.js.map +1 -1
- package/dist/types/email-otp.d.ts +3 -0
- package/dist/types/email-otp.d.ts.map +1 -0
- package/dist/types/email-otp.js +6 -0
- package/dist/types/email-otp.js.map +1 -0
- package/dist/types/email.d.ts +3 -0
- package/dist/types/email.d.ts.map +1 -0
- package/dist/types/email.js +29 -0
- package/dist/types/email.js.map +1 -0
- package/dist/types/handle.d.ts +3 -0
- package/dist/types/handle.d.ts.map +1 -0
- package/dist/types/handle.js +22 -0
- package/dist/types/handle.js.map +1 -0
- package/dist/types/invite-code.d.ts +4 -0
- package/dist/types/invite-code.d.ts.map +1 -0
- package/dist/types/invite-code.js +6 -0
- package/dist/types/invite-code.js.map +1 -0
- package/dist/types/password.d.ts +4 -0
- package/dist/types/password.d.ts.map +1 -0
- package/dist/types/password.js +7 -0
- package/dist/types/password.js.map +1 -0
- package/package.json +11 -14
- package/src/access-token/access-token-mode.ts +4 -0
- package/src/account/account-manager.ts +105 -75
- package/src/account/account-store.ts +118 -114
- package/src/account/sign-in-data.ts +10 -10
- package/src/account/sign-up-input.ts +13 -4
- package/src/client/client-manager.ts +34 -2
- package/src/client/client-store.ts +1 -1
- package/src/constants.ts +6 -1
- package/src/customization/branding.ts +12 -0
- package/src/customization/build-customization-css.ts +30 -0
- package/src/customization/build-customization-data.ts +22 -0
- package/src/customization/colors.ts +30 -0
- package/src/customization/customization.ts +25 -0
- package/src/customization/links.ts +10 -0
- package/src/device/device-id.ts +5 -0
- package/src/device/device-manager.ts +76 -66
- package/src/device/device-store.ts +2 -0
- package/src/errors/access-denied-error.ts +24 -17
- package/src/{output/build-error-payload.ts → errors/error-parser.ts} +1 -1
- package/src/errors/invalid-grant-error.ts +5 -0
- package/src/errors/login-required-error.ts +10 -0
- package/src/index.ts +1 -0
- package/src/lib/html/build-document.ts +6 -4
- package/src/{output/backend-data.ts → lib/html/hydration-data.ts} +7 -5
- package/src/lib/html/tags.ts +2 -2
- package/src/lib/http/accept.ts +3 -3
- package/src/lib/http/context.ts +41 -10
- package/src/lib/http/headers.ts +15 -0
- package/src/lib/http/index.ts +1 -0
- package/src/lib/http/middleware.ts +8 -23
- package/src/lib/http/request.ts +40 -75
- package/src/lib/http/response.ts +39 -15
- package/src/lib/http/route.ts +8 -5
- package/src/lib/http/router.ts +40 -46
- package/src/lib/http/security-headers.ts +1 -1
- package/src/lib/http/types.ts +1 -6
- package/src/{output → lib}/send-web-page.ts +10 -9
- package/src/lib/util/color.ts +132 -0
- package/src/lib/util/crypto.ts +9 -4
- package/src/lib/util/function.ts +14 -0
- package/src/lib/util/locale.ts +18 -0
- package/src/lib/util/time.ts +3 -4
- package/src/lib/util/type.ts +24 -0
- package/src/lib/util/ui8.ts +14 -0
- package/src/lib/util/zod-error.ts +14 -0
- package/src/oauth-errors.ts +22 -22
- package/src/oauth-hooks.ts +11 -24
- package/src/oauth-middleware.ts +53 -0
- package/src/oauth-provider.ts +290 -1061
- package/src/oauth-verifier.ts +9 -55
- package/src/request/request-data.ts +5 -4
- package/src/request/request-manager.ts +11 -11
- package/src/request/request-store.ts +7 -0
- package/src/result/authorization-redirect-parameters.ts +24 -0
- package/src/result/authorization-result-authorize-page.ts +14 -0
- package/src/result/authorization-result-redirect.ts +8 -0
- package/src/router/assets/assets-manifest.ts +115 -0
- package/src/router/assets/assets.ts +54 -0
- package/src/router/assets/csrf.ts +63 -0
- package/src/router/assets/send-account-page.ts +43 -0
- package/src/router/assets/send-authorization-page.ts +62 -0
- package/src/router/assets/send-error-page.ts +42 -0
- package/src/router/create-account-page-middleware.ts +69 -0
- package/src/router/create-api-middleware.ts +814 -0
- package/src/router/create-authorization-page-middleware.ts +173 -0
- package/src/router/create-oauth-middleware.ts +247 -0
- package/src/router/error-handler.ts +6 -0
- package/src/router/middleware-options.ts +9 -0
- package/src/router/send-redirect.ts +142 -0
- package/src/signer/api-token-payload.ts +18 -0
- package/src/signer/signed-token-payload.ts +18 -28
- package/src/signer/signer.ts +49 -34
- package/src/token/token-data.ts +1 -1
- package/src/token/token-manager.ts +190 -239
- package/src/token/token-store.ts +6 -4
- package/src/token/verify-token-claims.ts +4 -4
- package/src/types/email-otp.ts +3 -0
- package/src/types/email.ts +26 -0
- package/src/types/handle.ts +18 -0
- package/src/types/invite-code.ts +4 -0
- package/src/types/password.ts +4 -0
- package/tsconfig.build.tsbuildinfo +1 -0
- package/tsconfig.json +1 -1
- package/dist/access-token/access-token-type.d.ts +0 -6
- package/dist/access-token/access-token-type.d.ts.map +0 -1
- package/dist/access-token/access-token-type.js +0 -10
- package/dist/access-token/access-token-type.js.map +0 -1
- package/dist/account/account.d.ts +0 -2
- package/dist/account/account.d.ts.map +0 -1
- package/dist/account/account.js.map +0 -1
- package/dist/assets/assets-middleware.d.ts +0 -5
- package/dist/assets/assets-middleware.d.ts.map +0 -1
- package/dist/assets/assets-middleware.js +0 -41
- package/dist/assets/assets-middleware.js.map +0 -1
- package/dist/lib/locale.d.ts +0 -15
- package/dist/lib/locale.d.ts.map +0 -1
- package/dist/lib/locale.js +0 -17
- package/dist/lib/locale.js.map +0 -1
- package/dist/output/backend-data.d.ts +0 -4
- package/dist/output/backend-data.d.ts.map +0 -1
- package/dist/output/backend-data.js.map +0 -1
- package/dist/output/build-authorize-data.d.ts +0 -29
- package/dist/output/build-authorize-data.d.ts.map +0 -1
- package/dist/output/build-authorize-data.js +0 -21
- package/dist/output/build-authorize-data.js.map +0 -1
- package/dist/output/build-customization-data.d.ts +0 -234
- package/dist/output/build-customization-data.d.ts.map +0 -1
- package/dist/output/build-customization-data.js +0 -174
- package/dist/output/build-customization-data.js.map +0 -1
- package/dist/output/build-error-data.d.ts +0 -3
- package/dist/output/build-error-data.d.ts.map +0 -1
- package/dist/output/build-error-data.js +0 -10
- package/dist/output/build-error-data.js.map +0 -1
- package/dist/output/build-error-payload.d.ts.map +0 -1
- package/dist/output/build-error-payload.js.map +0 -1
- package/dist/output/output-manager.d.ts +0 -28
- package/dist/output/output-manager.d.ts.map +0 -1
- package/dist/output/output-manager.js +0 -134
- package/dist/output/output-manager.js.map +0 -1
- package/dist/output/send-authorize-redirect.d.ts +0 -25
- package/dist/output/send-authorize-redirect.d.ts.map +0 -1
- package/dist/output/send-authorize-redirect.js.map +0 -1
- package/dist/output/send-web-page.d.ts +0 -8
- package/dist/output/send-web-page.d.ts.map +0 -1
- package/dist/output/send-web-page.js.map +0 -1
- package/dist/token/token-claims.d.ts.map +0 -1
- package/dist/token/token-claims.js +0 -27
- package/dist/token/token-claims.js.map +0 -1
- package/src/access-token/access-token-type.ts +0 -5
- package/src/account/account.ts +0 -1
- package/src/assets/assets-middleware.ts +0 -44
- package/src/lib/locale.ts +0 -21
- package/src/output/build-authorize-data.ts +0 -53
- package/src/output/build-customization-data.ts +0 -217
- package/src/output/build-error-data.ts +0 -8
- package/src/output/output-manager.ts +0 -188
- package/src/output/send-authorize-redirect.ts +0 -137
- package/src/token/token-claims.ts +0 -30
- package/tsconfig.backend.tsbuildinfo +0 -1
- /package/{tsconfig.backend.json → tsconfig.build.json} +0 -0
@@ -0,0 +1,77 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.parseAssetsManifest = parseAssetsManifest;
|
4
|
+
const node_fs_1 = require("node:fs");
|
5
|
+
const node_path_1 = require("node:path");
|
6
|
+
const node_stream_1 = require("node:stream");
|
7
|
+
const index_js_1 = require("../../lib/http/index.js");
|
8
|
+
const ASSETS_URL_PREFIX = '/@atproto/oauth-provider/~assets/';
|
9
|
+
function parseAssetsManifest(manifestPath) {
|
10
|
+
// Using `require` instead of `JSON.parse(readFileSync())` so that node's
|
11
|
+
// watch mode can pick up changes to the manifest file.
|
12
|
+
// eslint-disable-next-line
|
13
|
+
const manifest = require(manifestPath);
|
14
|
+
const assets = new Map(Object.entries(manifest).map(([filename, { data, ...item }]) => {
|
15
|
+
const buffer = data ? Buffer.from(data, 'base64') : null;
|
16
|
+
const filepath = (0, node_path_1.join)(manifestPath, '..', filename);
|
17
|
+
const stream = buffer
|
18
|
+
? () => node_stream_1.Readable.from(buffer)
|
19
|
+
: () => (0, node_fs_1.createReadStream)(filepath);
|
20
|
+
return [filename, { ...item, stream }];
|
21
|
+
}));
|
22
|
+
const assetsMiddleware = (req, res, next) => {
|
23
|
+
if (req.method !== 'GET' && req.method !== 'HEAD')
|
24
|
+
return next();
|
25
|
+
if (!req.url?.startsWith(ASSETS_URL_PREFIX))
|
26
|
+
return next();
|
27
|
+
const filename = decodeURIComponent(req.url.slice(ASSETS_URL_PREFIX.length));
|
28
|
+
if (!filename)
|
29
|
+
return next();
|
30
|
+
const asset = assets.get(filename);
|
31
|
+
if (!asset)
|
32
|
+
return next();
|
33
|
+
try {
|
34
|
+
// Allow "null" (ie. no header) to allow loading assets outside of a
|
35
|
+
// fetch context (not from a web page).
|
36
|
+
(0, index_js_1.validateFetchSite)(req, [null, 'none', 'cross-site', 'same-origin']);
|
37
|
+
(0, index_js_1.validateFetchDest)(req, [null, 'document', 'style', 'script']);
|
38
|
+
}
|
39
|
+
catch (err) {
|
40
|
+
return next(err);
|
41
|
+
}
|
42
|
+
if (req.headers['if-none-match'] === asset.sha256) {
|
43
|
+
return void res.writeHead(304).end();
|
44
|
+
}
|
45
|
+
res.setHeader('ETag', asset.sha256);
|
46
|
+
res.setHeader('Cache-Control', 'public, max-age=31536000, immutable');
|
47
|
+
(0, index_js_1.writeStream)(res, asset.stream(), { contentType: asset.mime });
|
48
|
+
};
|
49
|
+
return {
|
50
|
+
getAssets,
|
51
|
+
assetsMiddleware,
|
52
|
+
};
|
53
|
+
function getAssets(entryName) {
|
54
|
+
const scripts = getScripts(entryName);
|
55
|
+
if (!scripts.length)
|
56
|
+
return null;
|
57
|
+
const styles = getStyles(entryName);
|
58
|
+
return { scripts, styles };
|
59
|
+
}
|
60
|
+
function getScripts(entryName) {
|
61
|
+
return Array.from(assets)
|
62
|
+
.filter(([, asset]) => asset.type === 'chunk' && asset.isEntry && asset.name === entryName)
|
63
|
+
.map(assetEntryUrl);
|
64
|
+
}
|
65
|
+
function getStyles(_entryName) {
|
66
|
+
return Array.from(assets)
|
67
|
+
.filter(([, asset]) => asset.mime === 'text/css')
|
68
|
+
.map(assetEntryUrl);
|
69
|
+
}
|
70
|
+
}
|
71
|
+
function assetEntryUrl([filename]) {
|
72
|
+
return { url: assetUrl(filename) };
|
73
|
+
}
|
74
|
+
function assetUrl(filename) {
|
75
|
+
return `${ASSETS_URL_PREFIX}${encodeURIComponent(filename)}`;
|
76
|
+
}
|
77
|
+
//# sourceMappingURL=assets-manifest.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"assets-manifest.js","sourceRoot":"","sources":["../../../src/router/assets/assets-manifest.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import type { HydrationData as FeHydrationData } from '@atproto/oauth-provider-frontend/hydration-data';
|
2
|
+
import type { HydrationData as UiHydrationData } from '@atproto/oauth-provider-ui/hydration-data';
|
3
|
+
import { CspConfig } from '../../lib/csp/index.js';
|
4
|
+
import { Simplify } from '../../lib/util/type.js';
|
5
|
+
export type HydrationData = Simplify<UiHydrationData & FeHydrationData>;
|
6
|
+
export declare function getAssets(entryName: keyof HydrationData): {
|
7
|
+
scripts: import("../../lib/html/build-document.js").AssetRef[];
|
8
|
+
styles: import("../../lib/html/build-document.js").AssetRef[];
|
9
|
+
};
|
10
|
+
export declare const assetsMiddleware: import("../../lib/http/types.js").Middleware;
|
11
|
+
export declare const SPA_CSP: CspConfig;
|
12
|
+
/**
|
13
|
+
* @see {@link https://docs.hcaptcha.com/#content-security-policy-settings}
|
14
|
+
*/
|
15
|
+
export declare const HCAPTCHA_CSP: CspConfig;
|
16
|
+
//# sourceMappingURL=assets.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"assets.d.ts","sourceRoot":"","sources":["../../../src/router/assets/assets.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,IAAI,eAAe,EAAE,MAAM,iDAAiD,CAAA;AACvG,OAAO,KAAK,EAAE,aAAa,IAAI,eAAe,EAAE,MAAM,2CAA2C,CAAA;AACjG,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAA;AAElD,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAA;AAiBjD,MAAM,MAAM,aAAa,GAAG,QAAQ,CAAC,eAAe,GAAG,eAAe,CAAC,CAAA;AAEvE,wBAAgB,SAAS,CAAC,SAAS,EAAE,MAAM,aAAa;;;EAMvD;AAED,eAAO,MAAM,gBAAgB,8CAG3B,CAAA;AAEF,eAAO,MAAM,OAAO,EAAE,SAOrB,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,YAAY,EAAE,SAK1B,CAAA"}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.HCAPTCHA_CSP = exports.SPA_CSP = exports.assetsMiddleware = void 0;
|
4
|
+
exports.getAssets = getAssets;
|
5
|
+
const middleware_js_1 = require("../../lib/http/middleware.js");
|
6
|
+
const assets_manifest_js_1 = require("./assets-manifest.js");
|
7
|
+
// If the "ui" and "frontend" packages are ever unified, this can be replaced
|
8
|
+
// with a single expression:
|
9
|
+
//
|
10
|
+
// const { getAssets, assetsMiddleware } = parseAssetsManifest(
|
11
|
+
// require.resolve('@atproto/oauth-provider-ui/bundle-manifest.json'),
|
12
|
+
// )
|
13
|
+
const ui = (0, assets_manifest_js_1.parseAssetsManifest)(require.resolve('@atproto/oauth-provider-ui/bundle-manifest.json'));
|
14
|
+
const fe = (0, assets_manifest_js_1.parseAssetsManifest)(require.resolve('@atproto/oauth-provider-frontend/bundle-manifest.json'));
|
15
|
+
function getAssets(entryName) {
|
16
|
+
const assetRef = ui.getAssets(entryName) || fe.getAssets(entryName);
|
17
|
+
if (assetRef)
|
18
|
+
return assetRef;
|
19
|
+
// Fool-proof. Should never happen.
|
20
|
+
throw new Error(`Entry "${entryName}" not found in assets`);
|
21
|
+
}
|
22
|
+
exports.assetsMiddleware = (0, middleware_js_1.combineMiddlewares)([
|
23
|
+
ui.assetsMiddleware,
|
24
|
+
fe.assetsMiddleware,
|
25
|
+
]);
|
26
|
+
exports.SPA_CSP = {
|
27
|
+
// API calls are made to the same origin
|
28
|
+
'connect-src': ["'self'"],
|
29
|
+
// Allow loading of PDS logo & User avatars
|
30
|
+
'img-src': ['data:', 'https:'],
|
31
|
+
// Prevent embedding in iframes
|
32
|
+
'frame-ancestors': ["'none'"],
|
33
|
+
};
|
34
|
+
/**
|
35
|
+
* @see {@link https://docs.hcaptcha.com/#content-security-policy-settings}
|
36
|
+
*/
|
37
|
+
exports.HCAPTCHA_CSP = {
|
38
|
+
'script-src': ['https://hcaptcha.com', 'https://*.hcaptcha.com'],
|
39
|
+
'frame-src': ['https://hcaptcha.com', 'https://*.hcaptcha.com'],
|
40
|
+
'style-src': ['https://hcaptcha.com', 'https://*.hcaptcha.com'],
|
41
|
+
'connect-src': ['https://hcaptcha.com', 'https://*.hcaptcha.com'],
|
42
|
+
};
|
43
|
+
//# sourceMappingURL=assets.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"assets.js","sourceRoot":"","sources":["../../../src/router/assets/assets.ts"],"names":[],"mappings":";;;AAuBA,8BAMC;AA1BD,gEAAiE;AAEjE,6DAA0D;AAE1D,6EAA6E;AAC7E,4BAA4B;AAC5B,EAAE;AACF,+DAA+D;AAC/D,wEAAwE;AACxE,IAAI;AAEJ,MAAM,EAAE,GAAG,IAAA,wCAAmB,EAC5B,OAAO,CAAC,OAAO,CAAC,iDAAiD,CAAC,CACnE,CAAA;AACD,MAAM,EAAE,GAAG,IAAA,wCAAmB,EAC5B,OAAO,CAAC,OAAO,CAAC,uDAAuD,CAAC,CACzE,CAAA;AAID,SAAgB,SAAS,CAAC,SAA8B;IACtD,MAAM,QAAQ,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAA;IACnE,IAAI,QAAQ;QAAE,OAAO,QAAQ,CAAA;IAE7B,mCAAmC;IACnC,MAAM,IAAI,KAAK,CAAC,UAAU,SAAS,uBAAuB,CAAC,CAAA;AAC7D,CAAC;AAEY,QAAA,gBAAgB,GAAG,IAAA,kCAAkB,EAAC;IACjD,EAAE,CAAC,gBAAgB;IACnB,EAAE,CAAC,gBAAgB;CACpB,CAAC,CAAA;AAEW,QAAA,OAAO,GAAc;IAChC,wCAAwC;IACxC,aAAa,EAAE,CAAC,QAAQ,CAAC;IACzB,2CAA2C;IAC3C,SAAS,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC;IAC9B,+BAA+B;IAC/B,iBAAiB,EAAE,CAAC,QAAQ,CAAC;CAC9B,CAAA;AAED;;GAEG;AACU,QAAA,YAAY,GAAc;IACrC,YAAY,EAAE,CAAC,sBAAsB,EAAE,wBAAwB,CAAC;IAChE,WAAW,EAAE,CAAC,sBAAsB,EAAE,wBAAwB,CAAC;IAC/D,WAAW,EAAE,CAAC,sBAAsB,EAAE,wBAAwB,CAAC;IAC/D,aAAa,EAAE,CAAC,sBAAsB,EAAE,wBAAwB,CAAC;CAClE,CAAA"}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
2
|
+
export declare function setupCsrfToken(req: IncomingMessage, res: ServerResponse): Promise<string>;
|
3
|
+
export declare function validateCsrfToken(req: IncomingMessage, res: ServerResponse): Promise<void>;
|
4
|
+
//# sourceMappingURL=csrf.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"csrf.d.ts","sourceRoot":"","sources":["../../../src/router/assets/csrf.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAuBhE,wBAAsB,cAAc,CAClC,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,GAClB,OAAO,CAAC,MAAM,CAAC,CAOjB;AAED,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,eAAe,EACpB,GAAG,EAAE,cAAc,iBAQpB"}
|
@@ -0,0 +1,51 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.setupCsrfToken = setupCsrfToken;
|
7
|
+
exports.validateCsrfToken = validateCsrfToken;
|
8
|
+
const http_errors_1 = __importDefault(require("http-errors"));
|
9
|
+
const oauth_provider_api_1 = require("@atproto/oauth-provider-api");
|
10
|
+
const index_js_1 = require("../../lib/http/index.js");
|
11
|
+
const crypto_js_1 = require("../../lib/util/crypto.js");
|
12
|
+
const TOKEN_BYTE_LENGTH = 12;
|
13
|
+
const TOKEN_LENGTH = TOKEN_BYTE_LENGTH * 2; // 2 hex chars per byte
|
14
|
+
// @NOTE Cookie based CSRF protection is redundant with session cookies using
|
15
|
+
// `SameSite` and could probably be removed in the future.
|
16
|
+
const CSRF_COOKIE_OPTIONS = {
|
17
|
+
expires: undefined, // "session" cookie
|
18
|
+
secure: true,
|
19
|
+
httpOnly: false, // Need to be accessible from JavaScript
|
20
|
+
sameSite: 'lax',
|
21
|
+
path: `/`,
|
22
|
+
};
|
23
|
+
async function setupCsrfToken(req, res) {
|
24
|
+
const token = getCookieCsrf(req) || (await (0, crypto_js_1.randomHexId)(TOKEN_BYTE_LENGTH));
|
25
|
+
// Refresh cookie (See Chrome's "Lax+POST" behavior)
|
26
|
+
(0, index_js_1.setCookie)(res, oauth_provider_api_1.CSRF_COOKIE_NAME, token, CSRF_COOKIE_OPTIONS);
|
27
|
+
return token;
|
28
|
+
}
|
29
|
+
async function validateCsrfToken(req, res) {
|
30
|
+
const cookieValue = await setupCsrfToken(req, res);
|
31
|
+
const headerValue = getHeadersCsrf(req);
|
32
|
+
if (cookieValue !== headerValue) {
|
33
|
+
throw (0, http_errors_1.default)(400, `CSRF mismatch`);
|
34
|
+
}
|
35
|
+
}
|
36
|
+
function getCookieCsrf(req) {
|
37
|
+
const cookies = (0, index_js_1.parseHttpCookies)(req);
|
38
|
+
const cookieValue = cookies[oauth_provider_api_1.CSRF_COOKIE_NAME];
|
39
|
+
if (cookieValue?.length === TOKEN_LENGTH) {
|
40
|
+
return cookieValue;
|
41
|
+
}
|
42
|
+
return undefined;
|
43
|
+
}
|
44
|
+
function getHeadersCsrf(req) {
|
45
|
+
const headerValue = req.headers[oauth_provider_api_1.CSRF_HEADER_NAME];
|
46
|
+
if (typeof headerValue === 'string' && headerValue.length === TOKEN_LENGTH) {
|
47
|
+
return headerValue;
|
48
|
+
}
|
49
|
+
return undefined;
|
50
|
+
}
|
51
|
+
//# sourceMappingURL=csrf.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"csrf.js","sourceRoot":"","sources":["../../../src/router/assets/csrf.ts"],"names":[],"mappings":";;;;;AAuBA,wCAUC;AAED,8CAUC;AA5CD,8DAAyC;AACzC,oEAAgF;AAChF,sDAIgC;AAChC,wDAAsD;AAEtD,MAAM,iBAAiB,GAAG,EAAE,CAAA;AAC5B,MAAM,YAAY,GAAG,iBAAiB,GAAG,CAAC,CAAA,CAAC,uBAAuB;AAElE,6EAA6E;AAC7E,0DAA0D;AAC1D,MAAM,mBAAmB,GAAqC;IAC5D,OAAO,EAAE,SAAS,EAAE,mBAAmB;IACvC,MAAM,EAAE,IAAI;IACZ,QAAQ,EAAE,KAAK,EAAE,wCAAwC;IACzD,QAAQ,EAAE,KAAK;IACf,IAAI,EAAE,GAAG;CACV,CAAA;AAEM,KAAK,UAAU,cAAc,CAClC,GAAoB,EACpB,GAAmB;IAEnB,MAAM,KAAK,GAAG,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,IAAA,uBAAW,EAAC,iBAAiB,CAAC,CAAC,CAAA;IAE1E,oDAAoD;IACpD,IAAA,oBAAS,EAAC,GAAG,EAAE,qCAAgB,EAAE,KAAK,EAAE,mBAAmB,CAAC,CAAA;IAE5D,OAAO,KAAK,CAAA;AACd,CAAC;AAEM,KAAK,UAAU,iBAAiB,CACrC,GAAoB,EACpB,GAAmB;IAEnB,MAAM,WAAW,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;IAClD,MAAM,WAAW,GAAG,cAAc,CAAC,GAAG,CAAC,CAAA;IAEvC,IAAI,WAAW,KAAK,WAAW,EAAE,CAAC;QAChC,MAAM,IAAA,qBAAe,EAAC,GAAG,EAAE,eAAe,CAAC,CAAA;IAC7C,CAAC;AACH,CAAC;AAED,SAAS,aAAa,CAAC,GAAoB;IACzC,MAAM,OAAO,GAAG,IAAA,2BAAgB,EAAC,GAAG,CAAC,CAAA;IACrC,MAAM,WAAW,GAAG,OAAO,CAAC,qCAAgB,CAAC,CAAA;IAC7C,IAAI,WAAW,EAAE,MAAM,KAAK,YAAY,EAAE,CAAC;QACzC,OAAO,WAAW,CAAA;IACpB,CAAC;IACD,OAAO,SAAS,CAAA;AAClB,CAAC;AAED,SAAS,cAAc,CAAC,GAAoB;IAC1C,MAAM,WAAW,GAAG,GAAG,CAAC,OAAO,CAAC,qCAAgB,CAAC,CAAA;IACjD,IAAI,OAAO,WAAW,KAAK,QAAQ,IAAI,WAAW,CAAC,MAAM,KAAK,YAAY,EAAE,CAAC;QAC3E,OAAO,WAAW,CAAA;IACpB,CAAC;IACD,OAAO,SAAS,CAAA;AAClB,CAAC"}
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
2
|
+
import type { ActiveDeviceSession } from '@atproto/oauth-provider-api';
|
3
|
+
import { Customization } from '../../customization/customization.js';
|
4
|
+
export declare function sendAccountPageFactory(customization: Customization): (req: IncomingMessage, res: ServerResponse, data: {
|
5
|
+
deviceSessions: readonly ActiveDeviceSession[];
|
6
|
+
}) => Promise<void>;
|
7
|
+
//# sourceMappingURL=send-account-page.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"send-account-page.d.ts","sourceRoot":"","sources":["../../../src/router/assets/send-account-page.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAChE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAGtE,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAA;AASpE,wBAAgB,sBAAsB,CAAC,aAAa,EAAE,aAAa,IAO/D,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,MAAM;IACJ,cAAc,EAAE,SAAS,mBAAmB,EAAE,CAAA;CAC/C,KACA,OAAO,CAAC,IAAI,CAAC,CAiBjB"}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.sendAccountPageFactory = sendAccountPageFactory;
|
4
|
+
const build_customization_css_js_1 = require("../../customization/build-customization-css.js");
|
5
|
+
const build_customization_data_js_1 = require("../../customization/build-customization-data.js");
|
6
|
+
const hydration_data_js_1 = require("../../lib/html/hydration-data.js");
|
7
|
+
const index_js_1 = require("../../lib/html/index.js");
|
8
|
+
const tags_js_1 = require("../../lib/html/tags.js");
|
9
|
+
const security_headers_js_1 = require("../../lib/http/security-headers.js");
|
10
|
+
const send_web_page_js_1 = require("../../lib/send-web-page.js");
|
11
|
+
const assets_js_1 = require("./assets.js");
|
12
|
+
const csrf_js_1 = require("./csrf.js");
|
13
|
+
function sendAccountPageFactory(customization) {
|
14
|
+
// Pre-computed options:
|
15
|
+
const customizationData = (0, build_customization_data_js_1.buildCustomizationData)(customization);
|
16
|
+
const customizationCss = (0, index_js_1.cssCode)((0, build_customization_css_js_1.buildCustomizationCss)(customization));
|
17
|
+
const { scripts, styles } = (0, assets_js_1.getAssets)('account-page');
|
18
|
+
return async function sendAccountPage(req, res, data) {
|
19
|
+
await (0, csrf_js_1.setupCsrfToken)(req, res);
|
20
|
+
const script = (0, hydration_data_js_1.declareHydrationData)({
|
21
|
+
__customizationData: customizationData,
|
22
|
+
__deviceSessions: data.deviceSessions,
|
23
|
+
});
|
24
|
+
return (0, send_web_page_js_1.sendWebPage)(res, {
|
25
|
+
meta: [{ name: 'robots', content: 'noindex' }],
|
26
|
+
body: (0, tags_js_1.html) `<div id="root"></div>`,
|
27
|
+
csp: assets_js_1.SPA_CSP,
|
28
|
+
coep: security_headers_js_1.CrossOriginEmbedderPolicy.credentialless,
|
29
|
+
scripts: [script, ...scripts],
|
30
|
+
styles: [...styles, customizationCss],
|
31
|
+
});
|
32
|
+
};
|
33
|
+
}
|
34
|
+
//# sourceMappingURL=send-account-page.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"send-account-page.js","sourceRoot":"","sources":["../../../src/router/assets/send-account-page.ts"],"names":[],"mappings":";;AAaA,wDA6BC;AAxCD,+FAAsF;AACtF,iGAAwF;AAExF,wEAAuE;AACvE,sDAAiD;AACjD,oDAA6C;AAC7C,4EAA8E;AAC9E,iEAAwD;AACxD,2CAA+D;AAC/D,uCAA0C;AAE1C,SAAgB,sBAAsB,CAAC,aAA4B;IACjE,wBAAwB;IACxB,MAAM,iBAAiB,GAAG,IAAA,oDAAsB,EAAC,aAAa,CAAC,CAAA;IAC/D,MAAM,gBAAgB,GAAG,IAAA,kBAAO,EAAC,IAAA,kDAAqB,EAAC,aAAa,CAAC,CAAC,CAAA;IACtE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,IAAA,qBAAS,EAAC,cAAc,CAAC,CAAA;IAErD,OAAO,KAAK,UAAU,eAAe,CACnC,GAAoB,EACpB,GAAmB,EACnB,IAEC;QAED,MAAM,IAAA,wBAAc,EAAC,GAAG,EAAE,GAAG,CAAC,CAAA;QAE9B,MAAM,MAAM,GAAG,IAAA,wCAAoB,EAAgC;YACjE,mBAAmB,EAAE,iBAAiB;YACtC,gBAAgB,EAAE,IAAI,CAAC,cAAc;SACtC,CAAC,CAAA;QAEF,OAAO,IAAA,8BAAW,EAAC,GAAG,EAAE;YACtB,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;YAC9C,IAAI,EAAE,IAAA,cAAI,EAAA,uBAAuB;YACjC,GAAG,EAAE,mBAAO;YACZ,IAAI,EAAE,+CAAyB,CAAC,cAAc;YAC9C,OAAO,EAAE,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC;YAC7B,MAAM,EAAE,CAAC,GAAG,MAAM,EAAE,gBAAgB,CAAC;SACtC,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
@@ -0,0 +1,5 @@
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
2
|
+
import { Customization } from '../../customization/customization.js';
|
3
|
+
import { AuthorizationResultAuthorizePage } from '../../result/authorization-result-authorize-page.js';
|
4
|
+
export declare function sendAuthorizePageFactory(customization: Customization): (req: IncomingMessage, res: ServerResponse, data: AuthorizationResultAuthorizePage) => Promise<void>;
|
5
|
+
//# sourceMappingURL=send-authorization-page.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"send-authorization-page.d.ts","sourceRoot":"","sources":["../../../src/router/assets/send-authorization-page.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAGhE,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAA;AAMpE,OAAO,EAAE,gCAAgC,EAAE,MAAM,qDAAqD,CAAA;AAItG,wBAAgB,wBAAwB,CAAC,aAAa,EAAE,aAAa,IAgBjE,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,MAAM,gCAAgC,KACrC,OAAO,CAAC,IAAI,CAAC,CA6BjB"}
|
@@ -0,0 +1,49 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.sendAuthorizePageFactory = sendAuthorizePageFactory;
|
4
|
+
const build_customization_css_js_1 = require("../../customization/build-customization-css.js");
|
5
|
+
const build_customization_data_js_1 = require("../../customization/build-customization-data.js");
|
6
|
+
const index_js_1 = require("../../lib/csp/index.js");
|
7
|
+
const hydration_data_js_1 = require("../../lib/html/hydration-data.js");
|
8
|
+
const index_js_2 = require("../../lib/html/index.js");
|
9
|
+
const security_headers_js_1 = require("../../lib/http/security-headers.js");
|
10
|
+
const send_web_page_js_1 = require("../../lib/send-web-page.js");
|
11
|
+
const assets_js_1 = require("./assets.js");
|
12
|
+
const csrf_js_1 = require("./csrf.js");
|
13
|
+
function sendAuthorizePageFactory(customization) {
|
14
|
+
// Pre-computed options:
|
15
|
+
const customizationData = (0, build_customization_data_js_1.buildCustomizationData)(customization);
|
16
|
+
const customizationCss = (0, index_js_2.cssCode)((0, build_customization_css_js_1.buildCustomizationCss)(customization));
|
17
|
+
const { scripts, styles } = (0, assets_js_1.getAssets)('authorization-page');
|
18
|
+
const csp = (0, index_js_1.mergeCsp)(assets_js_1.SPA_CSP, customization?.hcaptcha ? assets_js_1.HCAPTCHA_CSP : undefined);
|
19
|
+
const coep = customization?.hcaptcha
|
20
|
+
? // https://github.com/hCaptcha/react-hcaptcha/issues/259
|
21
|
+
// @TODO Remove the use of `unsafeNone` once the issue above is resolved
|
22
|
+
security_headers_js_1.CrossOriginEmbedderPolicy.unsafeNone
|
23
|
+
: security_headers_js_1.CrossOriginEmbedderPolicy.credentialless;
|
24
|
+
return async function sendAuthorizePage(req, res, data) {
|
25
|
+
await (0, csrf_js_1.setupCsrfToken)(req, res);
|
26
|
+
const script = (0, hydration_data_js_1.declareHydrationData)({
|
27
|
+
__customizationData: customizationData,
|
28
|
+
__authorizeData: {
|
29
|
+
requestUri: data.uri,
|
30
|
+
clientId: data.client.id,
|
31
|
+
clientMetadata: data.client.metadata,
|
32
|
+
clientTrusted: data.client.info.isTrusted,
|
33
|
+
scopeDetails: data.scopeDetails,
|
34
|
+
uiLocales: data.parameters.ui_locales,
|
35
|
+
loginHint: data.parameters.login_hint,
|
36
|
+
},
|
37
|
+
__sessions: data.sessions,
|
38
|
+
});
|
39
|
+
return (0, send_web_page_js_1.sendWebPage)(res, {
|
40
|
+
meta: [{ name: 'robots', content: 'noindex' }],
|
41
|
+
body: (0, index_js_2.html) `<div id="root"></div>`,
|
42
|
+
csp,
|
43
|
+
coep,
|
44
|
+
scripts: [script, ...scripts],
|
45
|
+
styles: [...styles, customizationCss],
|
46
|
+
});
|
47
|
+
};
|
48
|
+
}
|
49
|
+
//# sourceMappingURL=send-authorization-page.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"send-authorization-page.js","sourceRoot":"","sources":["../../../src/router/assets/send-authorization-page.ts"],"names":[],"mappings":";;AAaA,4DAgDC;AA5DD,+FAAsF;AACtF,iGAAwF;AAExF,qDAAiD;AACjD,wEAAuE;AACvE,sDAAuD;AACvD,4EAA8E;AAC9E,iEAAwD;AAExD,2CAA6E;AAC7E,uCAA0C;AAE1C,SAAgB,wBAAwB,CAAC,aAA4B;IACnE,wBAAwB;IACxB,MAAM,iBAAiB,GAAG,IAAA,oDAAsB,EAAC,aAAa,CAAC,CAAA;IAC/D,MAAM,gBAAgB,GAAG,IAAA,kBAAO,EAAC,IAAA,kDAAqB,EAAC,aAAa,CAAC,CAAC,CAAA;IACtE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,IAAA,qBAAS,EAAC,oBAAoB,CAAC,CAAA;IAC3D,MAAM,GAAG,GAAG,IAAA,mBAAQ,EAClB,mBAAO,EACP,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAC,wBAAY,CAAC,CAAC,CAAC,SAAS,CACnD,CAAA;IACD,MAAM,IAAI,GAAG,aAAa,EAAE,QAAQ;QAClC,CAAC,CAAC,wDAAwD;YACxD,wEAAwE;YACxE,+CAAyB,CAAC,UAAU;QACtC,CAAC,CAAC,+CAAyB,CAAC,cAAc,CAAA;IAE5C,OAAO,KAAK,UAAU,iBAAiB,CACrC,GAAoB,EACpB,GAAmB,EACnB,IAAsC;QAEtC,MAAM,IAAA,wBAAc,EAAC,GAAG,EAAE,GAAG,CAAC,CAAA;QAE9B,MAAM,MAAM,GAAG,IAAA,wCAAoB,EAAsC;YACvE,mBAAmB,EAAE,iBAAiB;YACtC,eAAe,EAAE;gBACf,UAAU,EAAE,IAAI,CAAC,GAAG;gBAEpB,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE;gBACxB,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;gBACpC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS;gBAEzC,YAAY,EAAE,IAAI,CAAC,YAAY;gBAE/B,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,UAAU;gBACrC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,UAAU;aACtC;YACD,UAAU,EAAE,IAAI,CAAC,QAAQ;SAC1B,CAAC,CAAA;QAEF,OAAO,IAAA,8BAAW,EAAC,GAAG,EAAE;YACtB,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;YAC9C,IAAI,EAAE,IAAA,eAAI,EAAA,uBAAuB;YACjC,GAAG;YACH,IAAI;YACJ,OAAO,EAAE,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC;YAC7B,MAAM,EAAE,CAAC,GAAG,MAAM,EAAE,gBAAgB,CAAC;SACtC,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
2
|
+
import { Customization } from '../../customization/customization.js';
|
3
|
+
export declare function sendErrorPageFactory(customization: Customization): (req: IncomingMessage, res: ServerResponse, err: unknown) => void;
|
4
|
+
//# sourceMappingURL=send-error-page.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"send-error-page.d.ts","sourceRoot":"","sources":["../../../src/router/assets/send-error-page.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAGhE,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAA;AAYpE,wBAAgB,oBAAoB,CAAC,aAAa,EAAE,aAAa,IAO7D,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,OAAO,KACX,IAAI,CAgBR"}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.sendErrorPageFactory = sendErrorPageFactory;
|
4
|
+
const build_customization_css_js_1 = require("../../customization/build-customization-css.js");
|
5
|
+
const build_customization_data_js_1 = require("../../customization/build-customization-data.js");
|
6
|
+
const error_parser_js_1 = require("../../errors/error-parser.js");
|
7
|
+
const hydration_data_js_1 = require("../../lib/html/hydration-data.js");
|
8
|
+
const index_js_1 = require("../../lib/html/index.js");
|
9
|
+
const tags_js_1 = require("../../lib/html/tags.js");
|
10
|
+
const security_headers_js_1 = require("../../lib/http/security-headers.js");
|
11
|
+
const send_web_page_js_1 = require("../../lib/send-web-page.js");
|
12
|
+
const assets_js_1 = require("./assets.js");
|
13
|
+
function sendErrorPageFactory(customization) {
|
14
|
+
// Pre-computed options:
|
15
|
+
const customizationData = (0, build_customization_data_js_1.buildCustomizationData)(customization);
|
16
|
+
const customizationCss = (0, index_js_1.cssCode)((0, build_customization_css_js_1.buildCustomizationCss)(customization));
|
17
|
+
const { scripts, styles } = (0, assets_js_1.getAssets)('error-page');
|
18
|
+
return function sendErrorPage(req, res, err) {
|
19
|
+
const script = (0, hydration_data_js_1.declareHydrationData)({
|
20
|
+
__customizationData: customizationData,
|
21
|
+
__errorData: (0, error_parser_js_1.buildErrorPayload)(err),
|
22
|
+
});
|
23
|
+
return (0, send_web_page_js_1.sendWebPage)(res, {
|
24
|
+
status: (0, error_parser_js_1.buildErrorStatus)(err),
|
25
|
+
meta: [{ name: 'robots', content: 'noindex' }],
|
26
|
+
body: (0, tags_js_1.html) `<div id="root"></div>`,
|
27
|
+
csp: assets_js_1.SPA_CSP,
|
28
|
+
coep: security_headers_js_1.CrossOriginEmbedderPolicy.credentialless,
|
29
|
+
scripts: [script, ...scripts],
|
30
|
+
styles: [...styles, customizationCss],
|
31
|
+
});
|
32
|
+
};
|
33
|
+
}
|
34
|
+
//# sourceMappingURL=send-error-page.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"send-error-page.js","sourceRoot":"","sources":["../../../src/router/assets/send-error-page.ts"],"names":[],"mappings":";;AAeA,oDA0BC;AAxCD,+FAAsF;AACtF,iGAAwF;AAExF,kEAGqC;AACrC,wEAAuE;AACvE,sDAAiD;AACjD,oDAA6C;AAC7C,4EAA8E;AAC9E,iEAAwD;AACxD,2CAA+D;AAE/D,SAAgB,oBAAoB,CAAC,aAA4B;IAC/D,wBAAwB;IACxB,MAAM,iBAAiB,GAAG,IAAA,oDAAsB,EAAC,aAAa,CAAC,CAAA;IAC/D,MAAM,gBAAgB,GAAG,IAAA,kBAAO,EAAC,IAAA,kDAAqB,EAAC,aAAa,CAAC,CAAC,CAAA;IACtE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,IAAA,qBAAS,EAAC,YAAY,CAAC,CAAA;IAEnD,OAAO,SAAS,aAAa,CAC3B,GAAoB,EACpB,GAAmB,EACnB,GAAY;QAEZ,MAAM,MAAM,GAAG,IAAA,wCAAoB,EAA8B;YAC/D,mBAAmB,EAAE,iBAAiB;YACtC,WAAW,EAAE,IAAA,mCAAiB,EAAC,GAAG,CAAC;SACpC,CAAC,CAAA;QAEF,OAAO,IAAA,8BAAW,EAAC,GAAG,EAAE;YACtB,MAAM,EAAE,IAAA,kCAAgB,EAAC,GAAG,CAAC;YAC7B,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;YAC9C,IAAI,EAAE,IAAA,cAAI,EAAA,uBAAuB;YACjC,GAAG,EAAE,mBAAO;YACZ,IAAI,EAAE,+CAAyB,CAAC,cAAc;YAC9C,OAAO,EAAE,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC;YAC7B,MAAM,EAAE,CAAC,GAAG,MAAM,EAAE,gBAAgB,CAAC;SACtC,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
2
|
+
import { Middleware } from '../lib/http/index.js';
|
3
|
+
import type { OAuthProvider } from '../oauth-provider.js';
|
4
|
+
import type { MiddlewareOptions } from './middleware-options.js';
|
5
|
+
export declare function createAccountPageMiddleware<Ctx extends object | void = void, Req extends IncomingMessage = IncomingMessage, Res extends ServerResponse = ServerResponse>(server: OAuthProvider, { onError }: MiddlewareOptions<Req, Res>): Middleware<Ctx, Req, Res>;
|
6
|
+
//# sourceMappingURL=create-account-page-middleware.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"create-account-page-middleware.d.ts","sourceRoot":"","sources":["../../src/router/create-account-page-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAEhE,OAAO,EACL,UAAU,EAKX,MAAM,sBAAsB,CAAA;AAC7B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAGzD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAEhE,wBAAgB,2BAA2B,CACzC,GAAG,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI,EAChC,GAAG,SAAS,eAAe,GAAG,eAAe,EAC7C,GAAG,SAAS,cAAc,GAAG,cAAc,EAE3C,MAAM,EAAE,aAAa,EACrB,EAAE,OAAO,EAAE,EAAE,iBAAiB,CAAC,GAAG,EAAE,GAAG,CAAC,GACvC,UAAU,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CA+C3B"}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createAccountPageMiddleware = createAccountPageMiddleware;
|
4
|
+
const index_js_1 = require("../lib/http/index.js");
|
5
|
+
const send_account_page_js_1 = require("./assets/send-account-page.js");
|
6
|
+
const send_error_page_js_1 = require("./assets/send-error-page.js");
|
7
|
+
function createAccountPageMiddleware(server, { onError }) {
|
8
|
+
const sendAccountPage = (0, send_account_page_js_1.sendAccountPageFactory)(server.customization);
|
9
|
+
const sendErrorPage = (0, send_error_page_js_1.sendErrorPageFactory)(server.customization);
|
10
|
+
const issuerUrl = new URL(server.issuer);
|
11
|
+
const issuerOrigin = issuerUrl.origin;
|
12
|
+
const router = new index_js_1.Router(issuerUrl);
|
13
|
+
router.get(/^\/account(?:\/.*)?$/, async function (req, res) {
|
14
|
+
try {
|
15
|
+
res.setHeader('Referrer-Policy', 'same-origin');
|
16
|
+
res.setHeader('Cache-Control', 'no-store');
|
17
|
+
res.setHeader('Pragma', 'no-cache');
|
18
|
+
(0, index_js_1.validateFetchMode)(req, ['navigate']);
|
19
|
+
(0, index_js_1.validateFetchDest)(req, ['document']);
|
20
|
+
(0, index_js_1.validateOrigin)(req, issuerOrigin);
|
21
|
+
const { deviceId } = await server.deviceManager.load(req, res);
|
22
|
+
const deviceAccounts = await server.accountManager.listDeviceAccounts(deviceId);
|
23
|
+
sendAccountPage(req, res, {
|
24
|
+
deviceSessions: deviceAccounts.map((deviceAccount) => ({
|
25
|
+
account: deviceAccount.account,
|
26
|
+
loginRequired: server.checkLoginRequired(deviceAccount),
|
27
|
+
})),
|
28
|
+
});
|
29
|
+
}
|
30
|
+
catch (err) {
|
31
|
+
onError?.(req, res, err, `Failed to handle navigation request to "${req.url}"`);
|
32
|
+
if (!res.headersSent) {
|
33
|
+
sendErrorPage(req, res, err);
|
34
|
+
}
|
35
|
+
}
|
36
|
+
});
|
37
|
+
return router.buildMiddleware();
|
38
|
+
}
|
39
|
+
//# sourceMappingURL=create-account-page-middleware.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"create-account-page-middleware.js","sourceRoot":"","sources":["../../src/router/create-account-page-middleware.ts"],"names":[],"mappings":";;AAcA,kEAsDC;AAlED,mDAM6B;AAE7B,wEAAsE;AACtE,oEAAkE;AAGlE,SAAgB,2BAA2B,CAKzC,MAAqB,EACrB,EAAE,OAAO,EAA+B;IAExC,MAAM,eAAe,GAAG,IAAA,6CAAsB,EAAC,MAAM,CAAC,aAAa,CAAC,CAAA;IACpE,MAAM,aAAa,GAAG,IAAA,yCAAoB,EAAC,MAAM,CAAC,aAAa,CAAC,CAAA;IAEhE,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACxC,MAAM,YAAY,GAAG,SAAS,CAAC,MAAM,CAAA;IAErC,MAAM,MAAM,GAAG,IAAI,iBAAM,CAAgB,SAAS,CAAC,CAAA;IAEnD,MAAM,CAAC,GAAG,CAAQ,sBAAsB,EAAE,KAAK,WAAW,GAAG,EAAE,GAAG;QAChE,IAAI,CAAC;YACH,GAAG,CAAC,SAAS,CAAC,iBAAiB,EAAE,aAAa,CAAC,CAAA;YAE/C,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAA;YAC1C,GAAG,CAAC,SAAS,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAA;YAEnC,IAAA,4BAAiB,EAAC,GAAG,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;YACpC,IAAA,4BAAiB,EAAC,GAAG,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;YACpC,IAAA,yBAAc,EAAC,GAAG,EAAE,YAAY,CAAC,CAAA;YAEjC,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;YAC9D,MAAM,cAAc,GAClB,MAAM,MAAM,CAAC,cAAc,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAA;YAE1D,eAAe,CAAC,GAAG,EAAE,GAAG,EAAE;gBACxB,cAAc,EAAE,cAAc,CAAC,GAAG,CAChC,CAAC,aAAa,EAAuB,EAAE,CAAC,CAAC;oBACvC,OAAO,EAAE,aAAa,CAAC,OAAO;oBAC9B,aAAa,EAAE,MAAM,CAAC,kBAAkB,CAAC,aAAa,CAAC;iBACxD,CAAC,CACH;aACF,CAAC,CAAA;QACJ,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,EAAE,CACP,GAAG,EACH,GAAG,EACH,GAAG,EACH,2CAA2C,GAAG,CAAC,GAAG,GAAG,CACtD,CAAA;YAED,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;gBACrB,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAA;YAC9B,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,OAAO,MAAM,CAAC,eAAe,EAAE,CAAA;AACjC,CAAC"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from 'node:http';
|
2
|
+
import { Middleware } from '../lib/http/index.js';
|
3
|
+
import type { OAuthProvider } from '../oauth-provider.js';
|
4
|
+
import type { MiddlewareOptions } from './middleware-options.js';
|
5
|
+
import { OAuthRedirectOptions } from './send-redirect.js';
|
6
|
+
export declare function createApiMiddleware<Ctx extends object | void = void, Req extends IncomingMessage = IncomingMessage, Res extends ServerResponse = ServerResponse>(server: OAuthProvider, { onError }: MiddlewareOptions<Req, Res>): Middleware<Ctx, Req, Res>;
|
7
|
+
export declare function parseRedirectUrl(url: URL): OAuthRedirectOptions;
|
8
|
+
//# sourceMappingURL=create-api-middleware.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"create-api-middleware.d.ts","sourceRoot":"","sources":["../../src/router/create-api-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AA0BhE,OAAO,EACL,UAAU,EAYX,MAAM,sBAAsB,CAAA;AAK7B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAUzD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAChE,OAAO,EAEL,oBAAoB,EAMrB,MAAM,oBAAoB,CAAA;AAI3B,wBAAgB,mBAAmB,CACjC,GAAG,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI,EAChC,GAAG,SAAS,eAAe,GAAG,eAAe,EAC7C,GAAG,SAAS,cAAc,GAAG,cAAc,EAE3C,MAAM,EAAE,aAAa,EACrB,EAAE,OAAO,EAAE,EAAE,iBAAiB,CAAC,GAAG,EAAE,GAAG,CAAC,GACvC,UAAU,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAoqB3B;AAmBD,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,GAAG,GAAG,oBAAoB,CA4C/D"}
|