@atproto/oauth-provider 0.3.1 → 0.5.0
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/.linguirc +57 -0
- package/CHANGELOG.md +29 -0
- package/LICENSE.txt +1 -1
- package/dist/account/account-manager.d.ts +17 -3
- package/dist/account/account-manager.d.ts.map +1 -1
- package/dist/account/account-manager.js +102 -8
- package/dist/account/account-manager.js.map +1 -1
- package/dist/account/account-store.d.ts +81 -15
- package/dist/account/account-store.d.ts.map +1 -1
- package/dist/account/account-store.js +70 -19
- package/dist/account/account-store.js.map +1 -1
- package/dist/account/sign-in-data.d.ts +28 -0
- package/dist/account/sign-in-data.d.ts.map +1 -0
- package/dist/account/sign-in-data.js +16 -0
- package/dist/account/sign-in-data.js.map +1 -0
- package/dist/account/sign-up-data.d.ts +26 -0
- package/dist/account/sign-up-data.d.ts.map +1 -0
- package/dist/account/sign-up-data.js +11 -0
- package/dist/account/sign-up-data.js.map +1 -0
- package/dist/assets/app/bundle-manifest.json +598 -6
- package/dist/assets/app/index-ItwwtJ8r.js +36 -0
- package/dist/assets/app/index-ItwwtJ8r.js.map +1 -0
- package/dist/assets/app/main-B_dNxQo_.js +4 -0
- package/dist/assets/app/main-B_dNxQo_.js.map +1 -0
- package/dist/assets/app/main-CSatvmRR.css +3 -0
- package/dist/assets/app/main-CSatvmRR.js +306 -0
- package/dist/assets/app/main-CSatvmRR.js.map +1 -0
- package/dist/assets/app/messages-BQeltXSF.js +4 -0
- package/dist/assets/app/messages-BQeltXSF.js.map +1 -0
- package/dist/assets/app/messages-BQkEhfjg.js +4 -0
- package/dist/assets/app/messages-BQkEhfjg.js.map +1 -0
- package/dist/assets/app/messages-BUjKj_UJ.js +4 -0
- package/dist/assets/app/messages-BUjKj_UJ.js.map +1 -0
- package/dist/assets/app/messages-BWIQa8fO.js +4 -0
- package/dist/assets/app/messages-BWIQa8fO.js.map +1 -0
- package/dist/assets/app/messages-BaNVb0bp.js +4 -0
- package/dist/assets/app/messages-BaNVb0bp.js.map +1 -0
- package/dist/assets/app/messages-BaizVXcF.js +4 -0
- package/dist/assets/app/messages-BaizVXcF.js.map +1 -0
- package/dist/assets/app/messages-BfoClA1Y.js +4 -0
- package/dist/assets/app/messages-BfoClA1Y.js.map +1 -0
- package/dist/assets/app/messages-BsKGDZnC.js +4 -0
- package/dist/assets/app/messages-BsKGDZnC.js.map +1 -0
- package/dist/assets/app/messages-Bu-TJhml.js +4 -0
- package/dist/assets/app/messages-Bu-TJhml.js.map +1 -0
- package/dist/assets/app/messages-BvOKnBQk.js +4 -0
- package/dist/assets/app/messages-BvOKnBQk.js.map +1 -0
- package/dist/assets/app/messages-BxDzCiWz.js +4 -0
- package/dist/assets/app/messages-BxDzCiWz.js.map +1 -0
- package/dist/assets/app/messages-CDgFOy4S.js +4 -0
- package/dist/assets/app/messages-CDgFOy4S.js.map +1 -0
- package/dist/assets/app/messages-CLbTz0o9.js +4 -0
- package/dist/assets/app/messages-CLbTz0o9.js.map +1 -0
- package/dist/assets/app/messages-CNwSh0t7.js +4 -0
- package/dist/assets/app/messages-CNwSh0t7.js.map +1 -0
- package/dist/assets/app/messages-CSMNJ6P8.js +4 -0
- package/dist/assets/app/messages-CSMNJ6P8.js.map +1 -0
- package/dist/assets/app/messages-CZQUw3mp.js +4 -0
- package/dist/assets/app/messages-CZQUw3mp.js.map +1 -0
- package/dist/assets/app/messages-CZT41oVp.js +4 -0
- package/dist/assets/app/messages-CZT41oVp.js.map +1 -0
- package/dist/assets/app/messages-C_b-d3t8.js +4 -0
- package/dist/assets/app/messages-C_b-d3t8.js.map +1 -0
- package/dist/assets/app/messages-C_u3MTc2.js +4 -0
- package/dist/assets/app/messages-C_u3MTc2.js.map +1 -0
- package/dist/assets/app/messages-Cn8nHZic.js +4 -0
- package/dist/assets/app/messages-Cn8nHZic.js.map +1 -0
- package/dist/assets/app/messages-CtDywJUm.js +4 -0
- package/dist/assets/app/messages-CtDywJUm.js.map +1 -0
- package/dist/assets/app/messages-CurtIjBF.js +4 -0
- package/dist/assets/app/messages-CurtIjBF.js.map +1 -0
- package/dist/assets/app/messages-Cv6zIbaP.js +4 -0
- package/dist/assets/app/messages-Cv6zIbaP.js.map +1 -0
- package/dist/assets/app/messages-D1eLQuPE.js +4 -0
- package/dist/assets/app/messages-D1eLQuPE.js.map +1 -0
- package/dist/assets/app/messages-D8vHEaYW.js +4 -0
- package/dist/assets/app/messages-D8vHEaYW.js.map +1 -0
- package/dist/assets/app/messages-DJ1Q4GeC.js +4 -0
- package/dist/assets/app/messages-DJ1Q4GeC.js.map +1 -0
- package/dist/assets/app/messages-DRL3exqd.js +4 -0
- package/dist/assets/app/messages-DRL3exqd.js.map +1 -0
- package/dist/assets/app/messages-DWLPQRTp.js +4 -0
- package/dist/assets/app/messages-DWLPQRTp.js.map +1 -0
- package/dist/assets/app/messages-DjVaE9YE.js +4 -0
- package/dist/assets/app/messages-DjVaE9YE.js.map +1 -0
- package/dist/assets/app/messages-DqpMfFJR.js +4 -0
- package/dist/assets/app/messages-DqpMfFJR.js.map +1 -0
- package/dist/assets/app/messages-ETjhJBEN.js +4 -0
- package/dist/assets/app/messages-ETjhJBEN.js.map +1 -0
- package/dist/assets/app/messages-EUKrgrGn.js +4 -0
- package/dist/assets/app/messages-EUKrgrGn.js.map +1 -0
- package/dist/assets/app/messages-QQrOUcPW.js +4 -0
- package/dist/assets/app/messages-QQrOUcPW.js.map +1 -0
- package/dist/assets/app/messages-e2QGqFL6.js +4 -0
- package/dist/assets/app/messages-e2QGqFL6.js.map +1 -0
- package/dist/assets/app/messages-p61py7gD.js +4 -0
- package/dist/assets/app/messages-p61py7gD.js.map +1 -0
- package/dist/assets/asset.d.ts +1 -0
- package/dist/assets/asset.d.ts.map +1 -1
- package/dist/assets/assets-middleware.d.ts.map +1 -1
- package/dist/assets/assets-middleware.js +12 -7
- package/dist/assets/assets-middleware.js.map +1 -1
- package/dist/assets/index.d.ts +3 -2
- package/dist/assets/index.d.ts.map +1 -1
- package/dist/assets/index.js +13 -1
- package/dist/assets/index.js.map +1 -1
- package/dist/client/client-store.d.ts +3 -3
- package/dist/client/client-store.d.ts.map +1 -1
- package/dist/client/client-store.js +6 -5
- package/dist/client/client-store.js.map +1 -1
- package/dist/device/device-manager.d.ts +12 -13
- package/dist/device/device-manager.d.ts.map +1 -1
- package/dist/device/device-manager.js +5 -3
- package/dist/device/device-manager.js.map +1 -1
- package/dist/device/device-store.d.ts +3 -3
- package/dist/device/device-store.d.ts.map +1 -1
- package/dist/device/device-store.js +10 -9
- package/dist/device/device-store.js.map +1 -1
- package/dist/dpop/dpop-manager.d.ts +15 -7
- package/dist/dpop/dpop-manager.d.ts.map +1 -1
- package/dist/dpop/dpop-manager.js +17 -3
- package/dist/dpop/dpop-manager.js.map +1 -1
- package/dist/dpop/dpop-nonce.d.ts +11 -5
- package/dist/dpop/dpop-nonce.d.ts.map +1 -1
- package/dist/dpop/dpop-nonce.js +47 -38
- package/dist/dpop/dpop-nonce.js.map +1 -1
- package/dist/errors/handle-unavailable-error.d.ts +11 -0
- package/dist/errors/handle-unavailable-error.d.ts.map +1 -0
- package/dist/errors/handle-unavailable-error.js +19 -0
- package/dist/errors/handle-unavailable-error.js.map +1 -0
- package/dist/errors/invalid-request-error.d.ts +6 -8
- package/dist/errors/invalid-request-error.d.ts.map +1 -1
- package/dist/errors/invalid-request-error.js +10 -8
- package/dist/errors/invalid-request-error.js.map +1 -1
- package/dist/lib/csp/index.d.ts +18 -0
- package/dist/lib/csp/index.d.ts.map +1 -0
- package/dist/lib/csp/index.js +72 -0
- package/dist/lib/csp/index.js.map +1 -0
- package/dist/lib/hcaptcha.d.ts +177 -0
- package/dist/lib/hcaptcha.d.ts.map +1 -0
- package/dist/lib/hcaptcha.js +155 -0
- package/dist/lib/hcaptcha.js.map +1 -0
- package/dist/lib/html/build-document.d.ts +11 -3
- package/dist/lib/html/build-document.d.ts.map +1 -1
- package/dist/lib/html/build-document.js +51 -15
- package/dist/lib/html/build-document.js.map +1 -1
- package/dist/lib/http/middleware.d.ts.map +1 -1
- package/dist/lib/http/middleware.js +4 -1
- package/dist/lib/http/middleware.js.map +1 -1
- package/dist/lib/http/request.d.ts +18 -3
- package/dist/lib/http/request.d.ts.map +1 -1
- package/dist/lib/http/request.js +56 -23
- package/dist/lib/http/request.js.map +1 -1
- package/dist/lib/http/response.d.ts +4 -2
- package/dist/lib/http/response.d.ts.map +1 -1
- package/dist/lib/http/response.js +23 -5
- package/dist/lib/http/response.js.map +1 -1
- package/dist/lib/locale.d.ts +15 -0
- package/dist/lib/locale.d.ts.map +1 -0
- package/dist/lib/locale.js +17 -0
- package/dist/lib/locale.js.map +1 -0
- package/dist/lib/util/function.d.ts +2 -2
- package/dist/lib/util/function.d.ts.map +1 -1
- package/dist/lib/util/function.js.map +1 -1
- package/dist/lib/util/type.d.ts +88 -1
- package/dist/lib/util/type.d.ts.map +1 -1
- package/dist/lib/util/type.js +41 -0
- package/dist/lib/util/type.js.map +1 -1
- package/dist/metadata/build-metadata.d.ts +2 -2
- package/dist/metadata/build-metadata.d.ts.map +1 -1
- package/dist/metadata/build-metadata.js.map +1 -1
- package/dist/oauth-errors.d.ts +1 -0
- package/dist/oauth-errors.d.ts.map +1 -1
- package/dist/oauth-errors.js +3 -1
- package/dist/oauth-errors.js.map +1 -1
- package/dist/oauth-hooks.d.ts +60 -3
- package/dist/oauth-hooks.d.ts.map +1 -1
- package/dist/oauth-hooks.js +3 -3
- package/dist/oauth-hooks.js.map +1 -1
- package/dist/oauth-provider.d.ts +28 -22
- package/dist/oauth-provider.d.ts.map +1 -1
- package/dist/oauth-provider.js +212 -211
- package/dist/oauth-provider.js.map +1 -1
- package/dist/oauth-verifier.d.ts +1 -1
- package/dist/oauth-verifier.d.ts.map +1 -1
- package/dist/oauth-verifier.js +2 -1
- package/dist/oauth-verifier.js.map +1 -1
- package/dist/output/build-authorize-data.d.ts +0 -1
- package/dist/output/build-authorize-data.d.ts.map +1 -1
- package/dist/output/build-authorize-data.js +0 -1
- package/dist/output/build-authorize-data.js.map +1 -1
- package/dist/output/build-customization-data.d.ts +232 -0
- package/dist/output/build-customization-data.d.ts.map +1 -0
- package/dist/output/build-customization-data.js +145 -0
- package/dist/output/build-customization-data.js.map +1 -0
- package/dist/output/output-manager.d.ts +16 -9
- package/dist/output/output-manager.d.ts.map +1 -1
- package/dist/output/output-manager.js +78 -42
- package/dist/output/output-manager.js.map +1 -1
- package/dist/output/send-authorize-redirect.d.ts +9 -6
- package/dist/output/send-authorize-redirect.d.ts.map +1 -1
- package/dist/output/send-authorize-redirect.js +20 -14
- package/dist/output/send-authorize-redirect.js.map +1 -1
- package/dist/output/send-web-page.d.ts +7 -2
- package/dist/output/send-web-page.d.ts.map +1 -1
- package/dist/output/send-web-page.js +37 -21
- package/dist/output/send-web-page.js.map +1 -1
- package/dist/request/request-manager.d.ts +1 -1
- package/dist/request/request-manager.d.ts.map +1 -1
- package/dist/request/request-manager.js +4 -4
- package/dist/request/request-manager.js.map +1 -1
- package/dist/request/request-store.d.ts +3 -3
- package/dist/request/request-store.d.ts.map +1 -1
- package/dist/request/request-store.js +11 -10
- package/dist/request/request-store.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 +13 -12
- package/dist/token/token-store.js.map +1 -1
- package/package.json +46 -21
- package/rollup.config.js +61 -17
- package/src/account/account-manager.ts +159 -8
- package/src/account/account-store.ts +127 -32
- package/src/account/sign-in-data.ts +15 -0
- package/src/account/sign-up-data.ts +11 -0
- package/src/assets/app/app.tsx +31 -16
- package/src/assets/app/backend-data.ts +15 -60
- package/src/assets/app/backend-types.ts +66 -0
- package/src/assets/app/components/forms/button-toggle-visibility.tsx +43 -0
- package/src/assets/app/components/forms/button.tsx +60 -0
- package/src/assets/app/components/forms/fieldset.tsx +55 -0
- package/src/assets/app/components/forms/form-card-async.tsx +103 -0
- package/src/assets/app/components/forms/form-card.tsx +49 -0
- package/src/assets/app/components/forms/input-checkbox.tsx +73 -0
- package/src/assets/app/components/forms/input-container.tsx +107 -0
- package/src/assets/app/components/forms/input-email-address.tsx +66 -0
- package/src/assets/app/components/forms/input-new-password.tsx +62 -0
- package/src/assets/app/components/forms/input-password.tsx +88 -0
- package/src/assets/app/components/forms/input-text.tsx +76 -0
- package/src/assets/app/components/forms/input-token.tsx +94 -0
- package/src/assets/app/components/forms/wizard-card.tsx +116 -0
- package/src/assets/app/components/layouts/layout-title-page.tsx +77 -0
- package/src/assets/app/components/layouts/layout-welcome.tsx +73 -0
- package/src/assets/app/components/utils/account-identifier.tsx +23 -0
- package/src/assets/app/components/utils/account-image.tsx +33 -0
- package/src/assets/app/components/utils/admonition.tsx +52 -0
- package/src/assets/app/components/utils/client-name.tsx +45 -0
- package/src/assets/app/components/utils/error-card.tsx +93 -0
- package/src/assets/app/components/utils/error-message.tsx +62 -0
- package/src/assets/app/components/utils/help-card.tsx +46 -0
- package/src/assets/app/components/utils/icons.tsx +88 -0
- package/src/assets/app/components/utils/link-anchor.tsx +28 -0
- package/src/assets/app/components/utils/link-title.tsx +26 -0
- package/src/assets/app/components/utils/multi-lang-string.tsx +56 -0
- package/src/assets/app/components/utils/password-strength-label.tsx +37 -0
- package/src/assets/app/components/utils/password-strength-meter.tsx +58 -0
- package/src/assets/app/components/{url-viewer.tsx → utils/url-viewer.tsx} +9 -6
- package/src/assets/app/hooks/use-api.ts +128 -55
- package/src/assets/app/hooks/use-async-action.ts +120 -0
- package/src/assets/app/hooks/use-browser-color-scheme.ts +31 -0
- package/src/assets/app/hooks/use-csrf-token.ts +1 -1
- package/src/assets/app/hooks/use-random-string.ts +37 -0
- package/src/assets/app/hooks/use-stepper.ts +87 -0
- package/src/assets/app/index.html +182 -0
- package/src/assets/app/lib/api.ts +248 -79
- package/src/assets/app/lib/clsx.ts +5 -8
- package/src/assets/app/lib/json-client.ts +94 -0
- package/src/assets/app/lib/password.ts +98 -0
- package/src/assets/app/lib/ref.ts +17 -0
- package/src/assets/app/locales/an/messages.po +492 -0
- package/src/assets/app/locales/ast/messages.po +492 -0
- package/src/assets/app/locales/ca/messages.po +492 -0
- package/src/assets/app/locales/da/messages.po +492 -0
- package/src/assets/app/locales/de/messages.po +492 -0
- package/src/assets/app/locales/el/messages.po +492 -0
- package/src/assets/app/locales/en/messages.po +492 -0
- package/src/assets/app/locales/en-GB/messages.po +492 -0
- package/src/assets/app/locales/es/messages.po +492 -0
- package/src/assets/app/locales/eu/messages.po +492 -0
- package/src/assets/app/locales/fi/messages.po +492 -0
- package/src/assets/app/locales/fr/messages.po +492 -0
- package/src/assets/app/locales/ga/messages.po +492 -0
- package/src/assets/app/locales/gl/messages.po +492 -0
- package/src/assets/app/locales/hi/messages.po +492 -0
- package/src/assets/app/locales/hu/messages.po +492 -0
- package/src/assets/app/locales/ia/messages.po +492 -0
- package/src/assets/app/locales/id/messages.po +492 -0
- package/src/assets/app/locales/it/messages.po +492 -0
- package/src/assets/app/locales/ja/messages.po +492 -0
- package/src/assets/app/locales/km/messages.po +492 -0
- package/src/assets/app/locales/ko/messages.po +492 -0
- package/src/assets/app/locales/load.ts +8 -0
- package/src/assets/app/locales/locale-context.ts +19 -0
- package/src/assets/app/locales/locale-provider.tsx +112 -0
- package/src/assets/app/locales/locale-selector.tsx +58 -0
- package/src/assets/app/locales/locales.ts +168 -0
- package/src/assets/app/locales/ne/messages.po +492 -0
- package/src/assets/app/locales/nl/messages.po +492 -0
- package/src/assets/app/locales/pl/messages.po +492 -0
- package/src/assets/app/locales/pt-BR/messages.po +492 -0
- package/src/assets/app/locales/ro/messages.po +492 -0
- package/src/assets/app/locales/ru/messages.po +492 -0
- package/src/assets/app/locales/sv/messages.po +492 -0
- package/src/assets/app/locales/th/messages.po +492 -0
- package/src/assets/app/locales/tr/messages.po +492 -0
- package/src/assets/app/locales/uk/messages.po +492 -0
- package/src/assets/app/locales/vi/messages.po +492 -0
- package/src/assets/app/locales/zh-CN/messages.po +492 -0
- package/src/assets/app/locales/zh-HK/messages.po +492 -0
- package/src/assets/app/locales/zh-TW/messages.po +492 -0
- package/src/assets/app/main.css +23 -2
- package/src/assets/app/main.tsx +24 -8
- package/src/assets/app/views/authorize/accept/accept-form.tsx +150 -0
- package/src/assets/app/views/authorize/accept/accept-view.tsx +70 -0
- package/src/assets/app/views/authorize/authorize-view.tsx +180 -0
- package/src/assets/app/views/authorize/reset-password/reset-password-confirm-form.tsx +88 -0
- package/src/assets/app/views/authorize/reset-password/reset-password-request-form.tsx +80 -0
- package/src/assets/app/views/authorize/reset-password/reset-password-view.tsx +127 -0
- package/src/assets/app/views/authorize/sign-in/sign-in-form.tsx +244 -0
- package/src/assets/app/views/authorize/sign-in/sign-in-picker.tsx +116 -0
- package/src/assets/app/views/authorize/sign-in/sign-in-view.tsx +145 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-account-form.tsx +140 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-disclaimer.tsx +51 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-handle-form.tsx +289 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-hcaptcha-form.tsx +108 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-view.tsx +158 -0
- package/src/assets/app/views/authorize/welcome/welcome-view.tsx +56 -0
- package/src/assets/app/views/error/error-view.tsx +31 -0
- package/src/assets/asset.ts +1 -0
- package/src/assets/assets-middleware.ts +13 -8
- package/src/assets/index.ts +15 -2
- package/src/client/client-store.ts +10 -12
- package/src/device/device-manager.ts +14 -15
- package/src/device/device-store.ts +9 -15
- package/src/dpop/dpop-manager.ts +20 -8
- package/src/dpop/dpop-nonce.ts +58 -40
- package/src/errors/handle-unavailable-error.ts +18 -0
- package/src/errors/invalid-request-error.ts +10 -8
- package/src/lib/csp/index.ts +98 -0
- package/src/lib/hcaptcha.ts +182 -0
- package/src/lib/html/build-document.ts +60 -16
- package/src/lib/http/middleware.ts +4 -3
- package/src/lib/http/request.ts +81 -28
- package/src/lib/http/response.ts +22 -9
- package/src/lib/locale.ts +21 -0
- package/src/lib/util/function.ts +0 -3
- package/src/lib/util/type.ts +130 -1
- package/src/metadata/build-metadata.ts +2 -1
- package/src/oauth-errors.ts +1 -0
- package/src/oauth-hooks.ts +69 -3
- package/src/oauth-provider.ts +410 -315
- package/src/oauth-verifier.ts +3 -1
- package/src/output/build-authorize-data.ts +1 -3
- package/src/output/build-customization-data.ts +189 -0
- package/src/output/output-manager.ts +111 -48
- package/src/output/send-authorize-redirect.ts +43 -36
- package/src/output/send-web-page.ts +40 -26
- package/src/request/request-manager.ts +4 -4
- package/src/request/request-store.ts +12 -16
- package/src/token/token-store.ts +14 -18
- package/tailwind.config.js +5 -0
- package/tsconfig.backend.tsbuildinfo +1 -1
- package/tsconfig.frontend.tsbuildinfo +1 -1
- package/tsconfig.tools.tsbuildinfo +1 -1
- package/vite.config.mjs +16 -0
- package/.postcssrc.yml +0 -3
- package/dist/assets/app/main.css +0 -3
- package/dist/assets/app/main.js +0 -20
- package/dist/assets/app/main.js.map +0 -1
- package/dist/output/customization.d.ts +0 -27
- package/dist/output/customization.d.ts.map +0 -1
- package/dist/output/customization.js +0 -88
- package/dist/output/customization.js.map +0 -1
- package/src/assets/app/components/accept-form.tsx +0 -137
- package/src/assets/app/components/account-identifier.tsx +0 -18
- package/src/assets/app/components/account-picker.tsx +0 -127
- package/src/assets/app/components/button.tsx +0 -34
- package/src/assets/app/components/client-name.tsx +0 -37
- package/src/assets/app/components/fieldset.tsx +0 -26
- package/src/assets/app/components/form-card.tsx +0 -47
- package/src/assets/app/components/help-card.tsx +0 -42
- package/src/assets/app/components/icons/alert-icon.tsx +0 -5
- package/src/assets/app/components/icons/at-symbol-icon.tsx +0 -5
- package/src/assets/app/components/icons/caret-right-icon.tsx +0 -5
- package/src/assets/app/components/icons/lock-icon.tsx +0 -5
- package/src/assets/app/components/icons/token-icon.tsx +0 -5
- package/src/assets/app/components/icons/util.tsx +0 -17
- package/src/assets/app/components/info-card.tsx +0 -45
- package/src/assets/app/components/input-checkbox.tsx +0 -47
- package/src/assets/app/components/input-container.tsx +0 -37
- package/src/assets/app/components/input-layout.tsx +0 -47
- package/src/assets/app/components/input-text.tsx +0 -69
- package/src/assets/app/components/layout-title-page.tsx +0 -60
- package/src/assets/app/components/layout-welcome.tsx +0 -74
- package/src/assets/app/components/sign-in-form.tsx +0 -337
- package/src/assets/app/components/sign-up-account-form.tsx +0 -194
- package/src/assets/app/components/sign-up-disclaimer.tsx +0 -44
- package/src/assets/app/views/accept-view.tsx +0 -55
- package/src/assets/app/views/authorize-view.tsx +0 -106
- package/src/assets/app/views/error-view.tsx +0 -36
- package/src/assets/app/views/sign-in-view.tsx +0 -111
- package/src/assets/app/views/sign-up-view.tsx +0 -86
- package/src/assets/app/views/welcome-view.tsx +0 -54
- package/src/output/customization.ts +0 -118
@@ -14,21 +14,22 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
-
exports.isRequestStore =
|
17
|
+
exports.isRequestStore = void 0;
|
18
18
|
exports.ifRequestStore = ifRequestStore;
|
19
|
+
const type_js_1 = require("../lib/util/type.js");
|
19
20
|
// Export all types needed to implement the RequestStore interface
|
20
21
|
__exportStar(require("./code.js"), exports);
|
21
|
-
__exportStar(require("./request-id.js"), exports);
|
22
22
|
__exportStar(require("./request-data.js"), exports);
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
23
|
+
__exportStar(require("./request-id.js"), exports);
|
24
|
+
exports.isRequestStore = (0, type_js_1.buildInterfaceChecker)([
|
25
|
+
'createRequest',
|
26
|
+
'readRequest',
|
27
|
+
'updateRequest',
|
28
|
+
'deleteRequest',
|
29
|
+
'findRequestByCode',
|
30
|
+
]);
|
30
31
|
function ifRequestStore(implementation) {
|
31
|
-
if (implementation && isRequestStore(implementation)) {
|
32
|
+
if (implementation && (0, exports.isRequestStore)(implementation)) {
|
32
33
|
return implementation;
|
33
34
|
}
|
34
35
|
return undefined;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"request-store.js","sourceRoot":"","sources":["../../src/request/request-store.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"request-store.js","sourceRoot":"","sources":["../../src/request/request-store.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAyCA,wCAQC;AAjDD,iDAAsE;AAKtE,kEAAkE;AAClE,4CAAyB;AACzB,oDAAiC;AACjC,kDAA+B;AAyBlB,QAAA,cAAc,GAAG,IAAA,+BAAqB,EAAe;IAChE,eAAe;IACf,aAAa;IACb,eAAe;IACf,eAAe;IACf,mBAAmB;CACpB,CAAC,CAAA;AAEF,SAAgB,cAAc,CAC5B,cAAkB;IAElB,IAAI,cAAc,IAAI,IAAA,sBAAc,EAAC,cAAc,CAAC,EAAE,CAAC;QACrD,OAAO,cAAc,CAAA;IACvB,CAAC;IAED,OAAO,SAAS,CAAA;AAClB,CAAC"}
|
@@ -5,9 +5,9 @@ import { Code } from '../request/code.js';
|
|
5
5
|
import { RefreshToken } from './refresh-token.js';
|
6
6
|
import { TokenData } from './token-data.js';
|
7
7
|
import { TokenId } from './token-id.js';
|
8
|
-
export * from './token-id.js';
|
9
|
-
export * from './token-data.js';
|
10
8
|
export * from './refresh-token.js';
|
9
|
+
export * from './token-data.js';
|
10
|
+
export * from './token-id.js';
|
11
11
|
export type { Awaitable };
|
12
12
|
export type TokenInfo = {
|
13
13
|
id: TokenId;
|
@@ -30,6 +30,6 @@ export interface TokenStore {
|
|
30
30
|
findTokenByRefreshToken(refreshToken: RefreshToken): Awaitable<null | TokenInfo>;
|
31
31
|
findTokenByCode(code: Code): Awaitable<null | TokenInfo>;
|
32
32
|
}
|
33
|
-
export declare
|
34
|
-
export declare function asTokenStore
|
33
|
+
export declare const isTokenStore: <V extends Partial<TokenStore>>(value: V) => value is V & import("../lib/util/type.js").RequiredDefined<TokenStore>;
|
34
|
+
export declare function asTokenStore<V extends Partial<TokenStore>>(implementation?: V): V & TokenStore;
|
35
35
|
//# sourceMappingURL=token-store.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"token-store.d.ts","sourceRoot":"","sources":["../../src/token/token-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAA;AAC/C,OAAO,EAAE,SAAS,
|
1
|
+
{"version":3,"file":"token-store.d.ts","sourceRoot":"","sources":["../../src/token/token-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAA;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAA;AAC/C,OAAO,EAAE,SAAS,EAAyB,MAAM,qBAAqB,CAAA;AACtE,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAA;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAGvC,cAAc,oBAAoB,CAAA;AAClC,cAAc,iBAAiB,CAAA;AAC/B,cAAc,eAAe,CAAA;AAC7B,YAAY,EAAE,SAAS,EAAE,CAAA;AAEzB,MAAM,MAAM,SAAS,GAAG;IACtB,EAAE,EAAE,OAAO,CAAA;IACX,IAAI,EAAE,SAAS,CAAA;IACf,OAAO,EAAE,OAAO,CAAA;IAChB,IAAI,CAAC,EAAE,iBAAiB,CAAA;IACxB,mBAAmB,EAAE,IAAI,GAAG,YAAY,CAAA;CACzC,CAAA;AAED,MAAM,MAAM,YAAY,GAAG,IAAI,CAC7B,SAAS,EACT,YAAY,GAAG,WAAW,GAAG,WAAW,CACzC,CAAA;AAED,MAAM,WAAW,UAAU;IACzB,WAAW,CACT,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,SAAS,EACf,YAAY,CAAC,EAAE,YAAY,GAC1B,SAAS,CAAC,IAAI,CAAC,CAAA;IAElB,SAAS,CAAC,OAAO,EAAE,OAAO,GAAG,SAAS,CAAC,IAAI,GAAG,SAAS,CAAC,CAAA;IAExD,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,CAAA;IAE9C,WAAW,CACT,OAAO,EAAE,OAAO,EAChB,UAAU,EAAE,OAAO,EACnB,eAAe,EAAE,YAAY,EAC7B,OAAO,EAAE,YAAY,GACpB,SAAS,CAAC,IAAI,CAAC,CAAA;IAElB;;;;OAIG;IACH,uBAAuB,CACrB,YAAY,EAAE,YAAY,GACzB,SAAS,CAAC,IAAI,GAAG,SAAS,CAAC,CAAA;IAE9B,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,SAAS,CAAC,IAAI,GAAG,SAAS,CAAC,CAAA;CACzD;AAED,eAAO,MAAM,YAAY,qHAOvB,CAAA;AAEF,wBAAgB,YAAY,CAAC,CAAC,SAAS,OAAO,CAAC,UAAU,CAAC,EACxD,cAAc,CAAC,EAAE,CAAC,GACjB,CAAC,GAAG,UAAU,CAKhB"}
|
@@ -14,22 +14,23 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
-
exports.isTokenStore =
|
17
|
+
exports.isTokenStore = void 0;
|
18
18
|
exports.asTokenStore = asTokenStore;
|
19
|
+
const type_js_1 = require("../lib/util/type.js");
|
19
20
|
// Export all types needed to implement the TokenStore interface
|
20
|
-
__exportStar(require("./token-id.js"), exports);
|
21
|
-
__exportStar(require("./token-data.js"), exports);
|
22
21
|
__exportStar(require("./refresh-token.js"), exports);
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
22
|
+
__exportStar(require("./token-data.js"), exports);
|
23
|
+
__exportStar(require("./token-id.js"), exports);
|
24
|
+
exports.isTokenStore = (0, type_js_1.buildInterfaceChecker)([
|
25
|
+
'createToken',
|
26
|
+
'readToken',
|
27
|
+
'deleteToken',
|
28
|
+
'rotateToken',
|
29
|
+
'findTokenByRefreshToken',
|
30
|
+
'findTokenByCode',
|
31
|
+
]);
|
31
32
|
function asTokenStore(implementation) {
|
32
|
-
if (!implementation || !isTokenStore(implementation)) {
|
33
|
+
if (!implementation || !(0, exports.isTokenStore)(implementation)) {
|
33
34
|
throw new Error('Invalid TokenStore implementation');
|
34
35
|
}
|
35
36
|
return implementation;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"token-store.js","sourceRoot":"","sources":["../../src/token/token-store.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"token-store.js","sourceRoot":"","sources":["../../src/token/token-store.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAkEA,oCAOC;AAvED,iDAAsE;AAMtE,gEAAgE;AAChE,qDAAkC;AAClC,kDAA+B;AAC/B,gDAA6B;AA8ChB,QAAA,YAAY,GAAG,IAAA,+BAAqB,EAAa;IAC5D,aAAa;IACb,WAAW;IACX,aAAa;IACb,aAAa;IACb,yBAAyB;IACzB,iBAAiB;CAClB,CAAC,CAAA;AAEF,SAAgB,YAAY,CAC1B,cAAkB;IAElB,IAAI,CAAC,cAAc,IAAI,CAAC,IAAA,oBAAY,EAAC,cAAc,CAAC,EAAE,CAAC;QACrD,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;IACtD,CAAC;IACD,OAAO,cAAc,CAAA;AACvB,CAAC"}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@atproto/oauth-provider",
|
3
|
-
"version": "0.
|
3
|
+
"version": "0.5.0",
|
4
4
|
"license": "MIT",
|
5
5
|
"description": "Generic OAuth2 and OpenID Connect provider for Node.js. Currently only supports features needed for Atproto.",
|
6
6
|
"keywords": [
|
@@ -32,50 +32,75 @@
|
|
32
32
|
},
|
33
33
|
"dependencies": {
|
34
34
|
"@hapi/accept": "^6.0.3",
|
35
|
+
"@hapi/address": "^5.1.1",
|
35
36
|
"@hapi/bourne": "^3.0.0",
|
36
37
|
"@hapi/content": "^6.0.0",
|
37
38
|
"cookie": "^0.6.0",
|
39
|
+
"disposable-email-domains-js": "^1.5.0",
|
40
|
+
"forwarded": "^0.2.0",
|
38
41
|
"http-errors": "^2.0.0",
|
39
42
|
"ioredis": "^5.3.2",
|
40
43
|
"jose": "^5.2.0",
|
41
44
|
"psl": "^1.9.0",
|
42
45
|
"zod": "^3.23.8",
|
43
|
-
"@atproto-labs/fetch": "0.2.
|
44
|
-
"@atproto-labs/fetch-node": "0.1.
|
46
|
+
"@atproto-labs/fetch": "0.2.2",
|
47
|
+
"@atproto-labs/fetch-node": "0.1.8",
|
48
|
+
"@atproto-labs/pipe": "0.1.0",
|
45
49
|
"@atproto-labs/simple-store": "0.1.2",
|
46
50
|
"@atproto-labs/simple-store-memory": "0.1.2",
|
47
|
-
"@atproto-labs/pipe": "0.1.0",
|
48
51
|
"@atproto/common": "^0.4.8",
|
49
|
-
"@atproto/jwk": "0.1.
|
50
|
-
"@atproto/jwk-jose": "0.1.
|
51
|
-
"@atproto/oauth-types": "0.2.
|
52
|
+
"@atproto/jwk": "0.1.4",
|
53
|
+
"@atproto/jwk-jose": "0.1.5",
|
54
|
+
"@atproto/oauth-types": "0.2.4"
|
52
55
|
},
|
53
56
|
"devDependencies": {
|
54
|
-
"@
|
55
|
-
"@
|
56
|
-
"@
|
57
|
-
"@
|
58
|
-
"@
|
57
|
+
"@hcaptcha/react-hcaptcha": "^1.11.2",
|
58
|
+
"@lingui/cli": "^5.2.0",
|
59
|
+
"@lingui/core": "^5.2.0",
|
60
|
+
"@lingui/react": "^5.2.0",
|
61
|
+
"@lingui/swc-plugin": "^5.4.0",
|
62
|
+
"@lingui/vite-plugin": "^5.2.0",
|
63
|
+
"@rollup/plugin-commonjs": "^28.0.2",
|
64
|
+
"@rollup/plugin-dynamic-import-vars": "^2.1.5",
|
65
|
+
"@rollup/plugin-node-resolve": "^16.0.0",
|
66
|
+
"@rollup/plugin-swc": "^0.4.0",
|
67
|
+
"@swc/core": "^1.10.18",
|
68
|
+
"@swc/helpers": "^0.5.15",
|
59
69
|
"@types/cookie": "^0.6.0",
|
70
|
+
"@types/forwarded": "0.1.3",
|
60
71
|
"@types/psl": "1.1.3",
|
61
|
-
"@types/react": "^
|
62
|
-
"@types/react-dom": "^
|
72
|
+
"@types/react": "^19.0.10",
|
73
|
+
"@types/react-dom": "^19.0.4",
|
63
74
|
"@types/send": "^0.17.4",
|
75
|
+
"@vitejs/plugin-react-swc": "^3.8.0",
|
64
76
|
"@web/rollup-plugin-import-meta-assets": "^2.2.1",
|
65
77
|
"autoprefixer": "^10.4.17",
|
66
|
-
"postcss": "^8.4.
|
67
|
-
"react": "^
|
68
|
-
"react-dom": "^
|
78
|
+
"postcss": "^8.4.38",
|
79
|
+
"react": "^19.0.0",
|
80
|
+
"react-dom": "^19.0.0",
|
81
|
+
"react-error-boundary": "^5.0.0",
|
69
82
|
"rollup": "^4.13.0",
|
70
83
|
"rollup-plugin-postcss": "^4.0.2",
|
71
|
-
"tailwindcss": "^3.4.
|
84
|
+
"tailwindcss": "^3.4.3",
|
72
85
|
"typescript": "^5.6.3",
|
73
|
-
"
|
86
|
+
"vite": "^6.2.0",
|
87
|
+
"@atproto-labs/rollup-plugin-bundle-manifest": "0.1.2"
|
88
|
+
},
|
89
|
+
"postcss": {
|
90
|
+
"plugins": {
|
91
|
+
"tailwindcss": {},
|
92
|
+
"autoprefixer": {}
|
93
|
+
}
|
74
94
|
},
|
75
95
|
"scripts": {
|
96
|
+
"po:extract": "lingui extract --clean",
|
97
|
+
"po:compile": "lingui compile --typescript",
|
98
|
+
"prebuild:frontend": "pnpm po:compile",
|
76
99
|
"build:frontend": "rollup --config rollup.config.js",
|
77
100
|
"build:backend": "tsc --build --force tsconfig.backend.json",
|
78
|
-
"
|
79
|
-
"dev": "
|
101
|
+
"start:ui": "vite",
|
102
|
+
"dev:frontend": "pnpm run build:frontend --watch",
|
103
|
+
"dev:catalogs": "pnpm run po:extract --debounce 250 --watch > /dev/null",
|
104
|
+
"dev:messages": "pnpm run po:compile --debounce 500 --watch"
|
80
105
|
}
|
81
106
|
}
|
package/rollup.config.js
CHANGED
@@ -1,10 +1,11 @@
|
|
1
1
|
/* eslint-env node */
|
2
2
|
|
3
3
|
const { default: commonjs } = require('@rollup/plugin-commonjs')
|
4
|
+
const {
|
5
|
+
default: dynamicImportVars,
|
6
|
+
} = require('@rollup/plugin-dynamic-import-vars')
|
4
7
|
const { default: nodeResolve } = require('@rollup/plugin-node-resolve')
|
5
|
-
const { default:
|
6
|
-
const { default: terser } = require('@rollup/plugin-terser')
|
7
|
-
const { default: typescript } = require('@rollup/plugin-typescript')
|
8
|
+
const { default: swc } = require('@rollup/plugin-swc')
|
8
9
|
const { defineConfig } = require('rollup')
|
9
10
|
const {
|
10
11
|
default: manifest,
|
@@ -16,34 +17,77 @@ module.exports = defineConfig((commandLineArguments) => {
|
|
16
17
|
process.env['NODE_ENV'] ??
|
17
18
|
(commandLineArguments.watch ? 'development' : 'production')
|
18
19
|
|
19
|
-
const
|
20
|
+
const devMode = NODE_ENV === 'development'
|
20
21
|
|
21
22
|
return {
|
22
|
-
input: 'src/assets/app/main.tsx',
|
23
|
+
input: ['src/assets/app/main.tsx', 'src/assets/app/main.css'],
|
23
24
|
output: {
|
24
25
|
manualChunks: undefined,
|
25
26
|
sourcemap: true,
|
26
|
-
|
27
|
-
format: '
|
27
|
+
dir: 'dist/assets/app',
|
28
|
+
format: 'module',
|
29
|
+
entryFileNames: 'main-[hash].js',
|
28
30
|
},
|
29
31
|
plugins: [
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
32
|
+
{
|
33
|
+
name: 'resolve-swc-helpers',
|
34
|
+
resolveId(src) {
|
35
|
+
// For some reason, "nodeResolve" doesn't resolve these:
|
36
|
+
if (src.startsWith('@swc/helpers/')) return require.resolve(src)
|
37
|
+
},
|
38
|
+
},
|
39
|
+
nodeResolve({
|
40
|
+
preferBuiltins: false,
|
41
|
+
browser: true,
|
42
|
+
exportConditions: ['browser', 'module', 'import', 'default'],
|
36
43
|
}),
|
37
|
-
|
38
|
-
|
39
|
-
|
44
|
+
commonjs(),
|
45
|
+
postcss({ config: true, extract: true, minimize: !devMode }),
|
46
|
+
swc({
|
47
|
+
swc: {
|
48
|
+
swcrc: false,
|
49
|
+
configFile: false,
|
50
|
+
sourceMaps: true,
|
51
|
+
minify: !devMode,
|
52
|
+
jsc: {
|
53
|
+
experimental: {
|
54
|
+
// @NOTE Because of the experimental nature of SWC plugins, A
|
55
|
+
// very particular version of @swc/core needs to be used. The
|
56
|
+
// link below allows to determine with version of @swc/core is
|
57
|
+
// compatible based on the version of @lingui/swc-plugin used
|
58
|
+
// (click on the swc_core version in the right column to see
|
59
|
+
// which version of the @swc/core is compatible)
|
60
|
+
//
|
61
|
+
// https://github.com/lingui/swc-plugin?tab=readme-ov-file#compatibility
|
62
|
+
plugins: [['@lingui/swc-plugin', {}]],
|
63
|
+
},
|
64
|
+
minify: {
|
65
|
+
compress: true,
|
66
|
+
mangle: true,
|
67
|
+
},
|
68
|
+
externalHelpers: true,
|
69
|
+
target: 'es2020',
|
70
|
+
parser: { syntax: 'typescript', tsx: true },
|
71
|
+
transform: {
|
72
|
+
useDefineForClassFields: true,
|
73
|
+
react: { runtime: 'automatic' },
|
74
|
+
optimizer: {
|
75
|
+
simplify: true,
|
76
|
+
globals: {
|
77
|
+
vars: { 'process.env.NODE_ENV': JSON.stringify(NODE_ENV) },
|
78
|
+
},
|
79
|
+
},
|
80
|
+
},
|
81
|
+
},
|
82
|
+
},
|
40
83
|
}),
|
84
|
+
dynamicImportVars({ errorWhenNoFilesFound: true }),
|
85
|
+
|
41
86
|
// Change `data` to `true` to include assets data in the manifest,
|
42
87
|
// allowing for easier bundling of the backend code (eg. using esbuild) as
|
43
88
|
// bundlers know how to bundle JSON files but not how to bundle assets
|
44
89
|
// referenced at runtime.
|
45
90
|
manifest({ data: false }),
|
46
|
-
minify && terser({}),
|
47
91
|
],
|
48
92
|
onwarn(warning, warn) {
|
49
93
|
// 'use client' directives are fine
|
@@ -1,31 +1,164 @@
|
|
1
|
-
import {
|
1
|
+
import {
|
2
|
+
OAuthIssuerIdentifier,
|
3
|
+
isOAuthClientIdLoopback,
|
4
|
+
} from '@atproto/oauth-types'
|
2
5
|
import { Client } from '../client/client.js'
|
3
6
|
import { DeviceId } from '../device/device-id.js'
|
7
|
+
import { InvalidRequestError } from '../errors/invalid-request-error.js'
|
8
|
+
import { HCaptchaClient, HcaptchaVerifyResult } from '../lib/hcaptcha.js'
|
9
|
+
import { callAsync } from '../lib/util/function.js'
|
4
10
|
import { constantTime } from '../lib/util/time.js'
|
5
|
-
import {
|
11
|
+
import { OAuthHooks, RequestMetadata } from '../oauth-hooks.js'
|
12
|
+
import { Customization } from '../oauth-provider.js'
|
6
13
|
import { Sub } from '../oidc/sub.js'
|
7
14
|
import { ClientAuth } from '../token/token-store.js'
|
8
15
|
import {
|
9
16
|
Account,
|
10
17
|
AccountInfo,
|
11
18
|
AccountStore,
|
12
|
-
|
19
|
+
ResetPasswordConfirmData,
|
20
|
+
ResetPasswordRequestData,
|
13
21
|
} from './account-store.js'
|
22
|
+
import { SignInData } from './sign-in-data.js'
|
23
|
+
import { SignUpData } from './sign-up-data.js'
|
14
24
|
|
15
25
|
const TIMING_ATTACK_MITIGATION_DELAY = 400
|
26
|
+
const BRUTE_FORCE_MITIGATION_DELAY = 300
|
16
27
|
|
17
28
|
export class AccountManager {
|
18
|
-
|
29
|
+
protected readonly inviteCodeRequired: boolean
|
30
|
+
protected readonly hcaptchaClient?: HCaptchaClient
|
31
|
+
|
32
|
+
constructor(
|
33
|
+
issuer: OAuthIssuerIdentifier,
|
34
|
+
protected readonly store: AccountStore,
|
35
|
+
protected readonly hooks: OAuthHooks,
|
36
|
+
customization: Customization,
|
37
|
+
) {
|
38
|
+
this.inviteCodeRequired = customization.inviteCodeRequired !== false
|
39
|
+
this.hcaptchaClient = customization.hcaptcha
|
40
|
+
? new HCaptchaClient(new URL(issuer).hostname, customization.hcaptcha)
|
41
|
+
: undefined
|
42
|
+
}
|
43
|
+
|
44
|
+
protected async verifySignupData(
|
45
|
+
data: SignUpData,
|
46
|
+
deviceId: DeviceId,
|
47
|
+
deviceMetadata: RequestMetadata,
|
48
|
+
): Promise<void> {
|
49
|
+
let hcaptchaResult: undefined | HcaptchaVerifyResult
|
50
|
+
|
51
|
+
if (this.inviteCodeRequired && !data.inviteCode) {
|
52
|
+
throw new InvalidRequestError('Invite code is required')
|
53
|
+
}
|
54
|
+
|
55
|
+
if (this.hcaptchaClient) {
|
56
|
+
if (!data.hcaptchaToken) {
|
57
|
+
throw new InvalidRequestError('hCaptcha token is required')
|
58
|
+
}
|
59
|
+
|
60
|
+
const { allowed, result } = await this.hcaptchaClient.verify(
|
61
|
+
'signup',
|
62
|
+
data.hcaptchaToken,
|
63
|
+
deviceMetadata.ipAddress,
|
64
|
+
data.handle,
|
65
|
+
deviceMetadata.userAgent,
|
66
|
+
)
|
67
|
+
|
68
|
+
await callAsync(this.hooks.onSignupHcaptchaResult, {
|
69
|
+
data,
|
70
|
+
allowed,
|
71
|
+
result,
|
72
|
+
deviceId,
|
73
|
+
deviceMetadata,
|
74
|
+
})
|
75
|
+
|
76
|
+
if (!allowed) {
|
77
|
+
throw new InvalidRequestError('hCaptcha verification failed')
|
78
|
+
}
|
79
|
+
|
80
|
+
hcaptchaResult = result
|
81
|
+
}
|
82
|
+
|
83
|
+
await callAsync(this.hooks.onSignupAttempt, {
|
84
|
+
data,
|
85
|
+
deviceId,
|
86
|
+
deviceMetadata,
|
87
|
+
hcaptchaResult,
|
88
|
+
})
|
89
|
+
}
|
90
|
+
|
91
|
+
public async signUp(
|
92
|
+
data: SignUpData,
|
93
|
+
deviceId: DeviceId,
|
94
|
+
deviceMetadata: RequestMetadata,
|
95
|
+
): Promise<AccountInfo> {
|
96
|
+
await this.verifySignupData(data, deviceId, deviceMetadata)
|
97
|
+
|
98
|
+
// Mitigation against brute forcing email of users.
|
99
|
+
// @TODO Add rate limit to all the OAuth routes.
|
100
|
+
return constantTime(BRUTE_FORCE_MITIGATION_DELAY, async () => {
|
101
|
+
let account: Account
|
102
|
+
try {
|
103
|
+
account = await this.store.createAccount(data)
|
104
|
+
} catch (err) {
|
105
|
+
throw InvalidRequestError.from(err, 'Account creation failed')
|
106
|
+
}
|
107
|
+
|
108
|
+
try {
|
109
|
+
const info = await this.store.addDeviceAccount(
|
110
|
+
deviceId,
|
111
|
+
account.sub,
|
112
|
+
false,
|
113
|
+
)
|
114
|
+
|
115
|
+
await callAsync(this.hooks.onSignedUp, {
|
116
|
+
data,
|
117
|
+
info,
|
118
|
+
account,
|
119
|
+
deviceId,
|
120
|
+
deviceMetadata,
|
121
|
+
})
|
122
|
+
|
123
|
+
return { account, info }
|
124
|
+
} catch (err) {
|
125
|
+
throw InvalidRequestError.from(
|
126
|
+
err,
|
127
|
+
'Something went wrong, try singing-in',
|
128
|
+
)
|
129
|
+
}
|
130
|
+
})
|
131
|
+
}
|
19
132
|
|
20
133
|
public async signIn(
|
21
|
-
|
134
|
+
data: SignInData,
|
22
135
|
deviceId: DeviceId,
|
136
|
+
deviceMetadata: RequestMetadata,
|
23
137
|
): Promise<AccountInfo> {
|
24
138
|
return constantTime(TIMING_ATTACK_MITIGATION_DELAY, async () => {
|
25
|
-
|
26
|
-
|
139
|
+
try {
|
140
|
+
const account = await this.store.authenticateAccount(data)
|
141
|
+
const info = await this.store.addDeviceAccount(
|
142
|
+
deviceId,
|
143
|
+
account.sub,
|
144
|
+
data.remember,
|
145
|
+
)
|
27
146
|
|
28
|
-
|
147
|
+
await callAsync(this.hooks.onSignedIn, {
|
148
|
+
data,
|
149
|
+
info,
|
150
|
+
account,
|
151
|
+
deviceId,
|
152
|
+
deviceMetadata,
|
153
|
+
})
|
154
|
+
|
155
|
+
return { account, info }
|
156
|
+
} catch (err) {
|
157
|
+
throw InvalidRequestError.from(
|
158
|
+
err,
|
159
|
+
'Unable to sign-in due to an unexpected server error',
|
160
|
+
)
|
161
|
+
}
|
29
162
|
})
|
30
163
|
}
|
31
164
|
|
@@ -52,4 +185,22 @@ export class AccountManager {
|
|
52
185
|
const results = await this.store.listDeviceAccounts(deviceId)
|
53
186
|
return results.filter((result) => result.info.remembered)
|
54
187
|
}
|
188
|
+
|
189
|
+
public async resetPasswordRequest(data: ResetPasswordRequestData) {
|
190
|
+
return constantTime(TIMING_ATTACK_MITIGATION_DELAY, async () => {
|
191
|
+
await this.store.resetPasswordRequest(data)
|
192
|
+
})
|
193
|
+
}
|
194
|
+
|
195
|
+
public async resetPasswordConfirm(data: ResetPasswordConfirmData) {
|
196
|
+
return constantTime(TIMING_ATTACK_MITIGATION_DELAY, async () => {
|
197
|
+
await this.store.resetPasswordConfirm(data)
|
198
|
+
})
|
199
|
+
}
|
200
|
+
|
201
|
+
public async verifyHandleAvailability(handle: string): Promise<void> {
|
202
|
+
return constantTime(TIMING_ATTACK_MITIGATION_DELAY, async () => {
|
203
|
+
return this.store.verifyHandleAvailability(handle)
|
204
|
+
})
|
205
|
+
}
|
55
206
|
}
|