@sirketio/auth 0.0.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/dist/_virtual/_rolldown/runtime.mjs +36 -0
- package/dist/adapter/index.d.mts +4 -0
- package/dist/adapter/index.mjs +7 -0
- package/dist/api/index.d.mts +3872 -0
- package/dist/api/index.mjs +206 -0
- package/dist/api/index.mjs.map +1 -0
- package/dist/api/middlewares/index.d.mts +1 -0
- package/dist/api/middlewares/index.mjs +3 -0
- package/dist/api/middlewares/origin-check.d.mts +18 -0
- package/dist/api/middlewares/origin-check.mjs +140 -0
- package/dist/api/middlewares/origin-check.mjs.map +1 -0
- package/dist/api/rate-limiter/index.mjs +204 -0
- package/dist/api/rate-limiter/index.mjs.map +1 -0
- package/dist/api/routes/account.d.mts +410 -0
- package/dist/api/routes/account.mjs +493 -0
- package/dist/api/routes/account.mjs.map +1 -0
- package/dist/api/routes/callback.d.mts +31 -0
- package/dist/api/routes/callback.mjs +179 -0
- package/dist/api/routes/callback.mjs.map +1 -0
- package/dist/api/routes/email-verification.d.mts +161 -0
- package/dist/api/routes/email-verification.mjs +299 -0
- package/dist/api/routes/email-verification.mjs.map +1 -0
- package/dist/api/routes/error.d.mts +28 -0
- package/dist/api/routes/error.mjs +386 -0
- package/dist/api/routes/error.mjs.map +1 -0
- package/dist/api/routes/index.d.mts +11 -0
- package/dist/api/routes/index.mjs +13 -0
- package/dist/api/routes/ok.d.mts +36 -0
- package/dist/api/routes/ok.mjs +30 -0
- package/dist/api/routes/ok.mjs.map +1 -0
- package/dist/api/routes/password.d.mts +182 -0
- package/dist/api/routes/password.mjs +198 -0
- package/dist/api/routes/password.mjs.map +1 -0
- package/dist/api/routes/session.d.mts +415 -0
- package/dist/api/routes/session.mjs +483 -0
- package/dist/api/routes/session.mjs.map +1 -0
- package/dist/api/routes/sign-in.d.mts +171 -0
- package/dist/api/routes/sign-in.mjs +263 -0
- package/dist/api/routes/sign-in.mjs.map +1 -0
- package/dist/api/routes/sign-out.d.mts +36 -0
- package/dist/api/routes/sign-out.mjs +33 -0
- package/dist/api/routes/sign-out.mjs.map +1 -0
- package/dist/api/routes/sign-up.d.mts +160 -0
- package/dist/api/routes/sign-up.mjs +227 -0
- package/dist/api/routes/sign-up.mjs.map +1 -0
- package/dist/api/routes/update-user.d.mts +445 -0
- package/dist/api/routes/update-user.mjs +493 -0
- package/dist/api/routes/update-user.mjs.map +1 -0
- package/dist/api/state/oauth.d.mts +18 -0
- package/dist/api/state/oauth.mjs +8 -0
- package/dist/api/state/oauth.mjs.map +1 -0
- package/dist/api/state/should-session-refresh.d.mts +13 -0
- package/dist/api/state/should-session-refresh.mjs +16 -0
- package/dist/api/state/should-session-refresh.mjs.map +1 -0
- package/dist/api/to-auth-endpoints.mjs +197 -0
- package/dist/api/to-auth-endpoints.mjs.map +1 -0
- package/dist/auth/base.mjs +45 -0
- package/dist/auth/base.mjs.map +1 -0
- package/dist/auth/minimal.d.mts +12 -0
- package/dist/auth/minimal.mjs +14 -0
- package/dist/auth/minimal.mjs.map +1 -0
- package/dist/auth/trusted-origins.mjs +31 -0
- package/dist/auth/trusted-origins.mjs.map +1 -0
- package/dist/client/broadcast-channel.d.mts +20 -0
- package/dist/client/broadcast-channel.mjs +46 -0
- package/dist/client/broadcast-channel.mjs.map +1 -0
- package/dist/client/config.mjs +90 -0
- package/dist/client/config.mjs.map +1 -0
- package/dist/client/fetch-plugins.mjs +18 -0
- package/dist/client/fetch-plugins.mjs.map +1 -0
- package/dist/client/focus-manager.d.mts +11 -0
- package/dist/client/focus-manager.mjs +32 -0
- package/dist/client/focus-manager.mjs.map +1 -0
- package/dist/client/index.d.mts +33 -0
- package/dist/client/index.mjs +21 -0
- package/dist/client/index.mjs.map +1 -0
- package/dist/client/online-manager.d.mts +12 -0
- package/dist/client/online-manager.mjs +35 -0
- package/dist/client/online-manager.mjs.map +1 -0
- package/dist/client/parser.mjs +73 -0
- package/dist/client/parser.mjs.map +1 -0
- package/dist/client/path-to-object.d.mts +65 -0
- package/dist/client/plugins/index.d.mts +53 -0
- package/dist/client/plugins/index.mjs +30 -0
- package/dist/client/plugins/infer-plugin.d.mts +16 -0
- package/dist/client/plugins/infer-plugin.mjs +11 -0
- package/dist/client/plugins/infer-plugin.mjs.map +1 -0
- package/dist/client/proxy.mjs +79 -0
- package/dist/client/proxy.mjs.map +1 -0
- package/dist/client/query.d.mts +23 -0
- package/dist/client/query.mjs +98 -0
- package/dist/client/query.mjs.map +1 -0
- package/dist/client/react/index.d.mts +128 -0
- package/dist/client/react/index.mjs +24 -0
- package/dist/client/react/index.mjs.map +1 -0
- package/dist/client/react/react-store.d.mts +47 -0
- package/dist/client/react/react-store.mjs +47 -0
- package/dist/client/react/react-store.mjs.map +1 -0
- package/dist/client/session-atom.mjs +29 -0
- package/dist/client/session-atom.mjs.map +1 -0
- package/dist/client/session-refresh.d.mts +28 -0
- package/dist/client/session-refresh.mjs +140 -0
- package/dist/client/session-refresh.mjs.map +1 -0
- package/dist/client/types.d.mts +41 -0
- package/dist/client/vanilla.d.mts +127 -0
- package/dist/client/vanilla.mjs +20 -0
- package/dist/client/vanilla.mjs.map +1 -0
- package/dist/context/create-context.mjs +211 -0
- package/dist/context/create-context.mjs.map +1 -0
- package/dist/context/helpers.mjs +83 -0
- package/dist/context/helpers.mjs.map +1 -0
- package/dist/context/init.mjs +20 -0
- package/dist/context/init.mjs.map +1 -0
- package/dist/cookies/cookie-utils.d.mts +29 -0
- package/dist/cookies/cookie-utils.mjs +105 -0
- package/dist/cookies/cookie-utils.mjs.map +1 -0
- package/dist/cookies/index.d.mts +121 -0
- package/dist/cookies/index.mjs +261 -0
- package/dist/cookies/index.mjs.map +1 -0
- package/dist/cookies/session-store.d.mts +36 -0
- package/dist/cookies/session-store.mjs +200 -0
- package/dist/cookies/session-store.mjs.map +1 -0
- package/dist/crypto/buffer.d.mts +8 -0
- package/dist/crypto/buffer.mjs +18 -0
- package/dist/crypto/buffer.mjs.map +1 -0
- package/dist/crypto/index.d.mts +27 -0
- package/dist/crypto/index.mjs +38 -0
- package/dist/crypto/index.mjs.map +1 -0
- package/dist/crypto/jwt.d.mts +8 -0
- package/dist/crypto/jwt.mjs +95 -0
- package/dist/crypto/jwt.mjs.map +1 -0
- package/dist/crypto/password.d.mts +12 -0
- package/dist/crypto/password.mjs +36 -0
- package/dist/crypto/password.mjs.map +1 -0
- package/dist/crypto/random.d.mts +5 -0
- package/dist/crypto/random.mjs +8 -0
- package/dist/crypto/random.mjs.map +1 -0
- package/dist/db/adapter-base.d.mts +8 -0
- package/dist/db/adapter-base.mjs +19 -0
- package/dist/db/adapter-base.mjs.map +1 -0
- package/dist/db/field-converter.d.mts +8 -0
- package/dist/db/field-converter.mjs +21 -0
- package/dist/db/field-converter.mjs.map +1 -0
- package/dist/db/field.d.mts +42 -0
- package/dist/db/get-schema.d.mts +11 -0
- package/dist/db/get-schema.mjs +39 -0
- package/dist/db/get-schema.mjs.map +1 -0
- package/dist/db/index.d.mts +18 -0
- package/dist/db/index.mjs +34 -0
- package/dist/db/index.mjs.map +1 -0
- package/dist/db/internal-adapter.d.mts +14 -0
- package/dist/db/internal-adapter.mjs +616 -0
- package/dist/db/internal-adapter.mjs.map +1 -0
- package/dist/db/schema.d.mts +49 -0
- package/dist/db/schema.mjs +118 -0
- package/dist/db/schema.mjs.map +1 -0
- package/dist/db/to-zod.d.mts +36 -0
- package/dist/db/to-zod.mjs +26 -0
- package/dist/db/to-zod.mjs.map +1 -0
- package/dist/db/verification-token-storage.mjs +28 -0
- package/dist/db/verification-token-storage.mjs.map +1 -0
- package/dist/db/with-hooks.d.mts +33 -0
- package/dist/db/with-hooks.mjs +159 -0
- package/dist/db/with-hooks.mjs.map +1 -0
- package/dist/index.d.mts +53 -0
- package/dist/index.mjs +27 -0
- package/dist/integrations/next-js.d.mts +29 -0
- package/dist/integrations/next-js.mjs +85 -0
- package/dist/integrations/next-js.mjs.map +1 -0
- package/dist/oauth2/index.d.mts +5 -0
- package/dist/oauth2/index.mjs +7 -0
- package/dist/oauth2/link-account.d.mts +48 -0
- package/dist/oauth2/link-account.mjs +143 -0
- package/dist/oauth2/link-account.mjs.map +1 -0
- package/dist/oauth2/state.d.mts +26 -0
- package/dist/oauth2/state.mjs +51 -0
- package/dist/oauth2/state.mjs.map +1 -0
- package/dist/oauth2/utils.d.mts +8 -0
- package/dist/oauth2/utils.mjs +31 -0
- package/dist/oauth2/utils.mjs.map +1 -0
- package/dist/plugins/access/access.d.mts +30 -0
- package/dist/plugins/access/access.mjs +46 -0
- package/dist/plugins/access/access.mjs.map +1 -0
- package/dist/plugins/access/index.d.mts +3 -0
- package/dist/plugins/access/index.mjs +3 -0
- package/dist/plugins/access/types.d.mts +17 -0
- package/dist/plugins/additional-fields/client.d.mts +96 -0
- package/dist/plugins/additional-fields/client.mjs +11 -0
- package/dist/plugins/additional-fields/client.mjs.map +1 -0
- package/dist/plugins/admin/access/index.d.mts +2 -0
- package/dist/plugins/admin/access/index.mjs +3 -0
- package/dist/plugins/admin/access/statement.d.mts +118 -0
- package/dist/plugins/admin/access/statement.mjs +53 -0
- package/dist/plugins/admin/access/statement.mjs.map +1 -0
- package/dist/plugins/admin/admin.d.mts +911 -0
- package/dist/plugins/admin/admin.mjs +95 -0
- package/dist/plugins/admin/admin.mjs.map +1 -0
- package/dist/plugins/admin/client.d.mts +76 -0
- package/dist/plugins/admin/client.mjs +36 -0
- package/dist/plugins/admin/client.mjs.map +1 -0
- package/dist/plugins/admin/error-codes.d.mts +29 -0
- package/dist/plugins/admin/error-codes.mjs +30 -0
- package/dist/plugins/admin/error-codes.mjs.map +1 -0
- package/dist/plugins/admin/has-permission.mjs +16 -0
- package/dist/plugins/admin/has-permission.mjs.map +1 -0
- package/dist/plugins/admin/index.d.mts +3 -0
- package/dist/plugins/admin/index.mjs +3 -0
- package/dist/plugins/admin/routes.mjs +841 -0
- package/dist/plugins/admin/routes.mjs.map +1 -0
- package/dist/plugins/admin/schema.d.mts +40 -0
- package/dist/plugins/admin/schema.mjs +34 -0
- package/dist/plugins/admin/schema.mjs.map +1 -0
- package/dist/plugins/admin/types.d.mts +89 -0
- package/dist/plugins/api-key/adapter.mjs +468 -0
- package/dist/plugins/api-key/adapter.mjs.map +1 -0
- package/dist/plugins/api-key/client.d.mts +46 -0
- package/dist/plugins/api-key/client.mjs +19 -0
- package/dist/plugins/api-key/client.mjs.map +1 -0
- package/dist/plugins/api-key/error-codes.d.mts +33 -0
- package/dist/plugins/api-key/error-codes.mjs +34 -0
- package/dist/plugins/api-key/error-codes.mjs.map +1 -0
- package/dist/plugins/api-key/index.d.mts +1251 -0
- package/dist/plugins/api-key/index.mjs +134 -0
- package/dist/plugins/api-key/index.mjs.map +1 -0
- package/dist/plugins/api-key/rate-limit.mjs +74 -0
- package/dist/plugins/api-key/rate-limit.mjs.map +1 -0
- package/dist/plugins/api-key/routes/create-api-key.mjs +252 -0
- package/dist/plugins/api-key/routes/create-api-key.mjs.map +1 -0
- package/dist/plugins/api-key/routes/delete-all-expired-api-keys.mjs +24 -0
- package/dist/plugins/api-key/routes/delete-all-expired-api-keys.mjs.map +1 -0
- package/dist/plugins/api-key/routes/delete-api-key.mjs +74 -0
- package/dist/plugins/api-key/routes/delete-api-key.mjs.map +1 -0
- package/dist/plugins/api-key/routes/get-api-key.mjs +158 -0
- package/dist/plugins/api-key/routes/get-api-key.mjs.map +1 -0
- package/dist/plugins/api-key/routes/index.mjs +71 -0
- package/dist/plugins/api-key/routes/index.mjs.map +1 -0
- package/dist/plugins/api-key/routes/list-api-keys.mjs +194 -0
- package/dist/plugins/api-key/routes/list-api-keys.mjs.map +1 -0
- package/dist/plugins/api-key/routes/update-api-key.mjs +248 -0
- package/dist/plugins/api-key/routes/update-api-key.mjs.map +1 -0
- package/dist/plugins/api-key/routes/verify-api-key.mjs +224 -0
- package/dist/plugins/api-key/routes/verify-api-key.mjs.map +1 -0
- package/dist/plugins/api-key/schema.d.mts +199 -0
- package/dist/plugins/api-key/schema.mjs +130 -0
- package/dist/plugins/api-key/schema.mjs.map +1 -0
- package/dist/plugins/api-key/types.d.mts +346 -0
- package/dist/plugins/bearer/index.d.mts +45 -0
- package/dist/plugins/bearer/index.mjs +66 -0
- package/dist/plugins/bearer/index.mjs.map +1 -0
- package/dist/plugins/captcha/constants.d.mts +10 -0
- package/dist/plugins/captcha/constants.mjs +22 -0
- package/dist/plugins/captcha/constants.mjs.map +1 -0
- package/dist/plugins/captcha/error-codes.mjs +16 -0
- package/dist/plugins/captcha/error-codes.mjs.map +1 -0
- package/dist/plugins/captcha/index.d.mts +21 -0
- package/dist/plugins/captcha/index.mjs +62 -0
- package/dist/plugins/captcha/index.mjs.map +1 -0
- package/dist/plugins/captcha/types.d.mts +28 -0
- package/dist/plugins/captcha/utils.mjs +11 -0
- package/dist/plugins/captcha/utils.mjs.map +1 -0
- package/dist/plugins/captcha/verify-handlers/captchafox.mjs +28 -0
- package/dist/plugins/captcha/verify-handlers/captchafox.mjs.map +1 -0
- package/dist/plugins/captcha/verify-handlers/cloudflare-turnstile.mjs +26 -0
- package/dist/plugins/captcha/verify-handlers/cloudflare-turnstile.mjs.map +1 -0
- package/dist/plugins/captcha/verify-handlers/google-recaptcha.mjs +30 -0
- package/dist/plugins/captcha/verify-handlers/google-recaptcha.mjs.map +1 -0
- package/dist/plugins/captcha/verify-handlers/h-captcha.mjs +28 -0
- package/dist/plugins/captcha/verify-handlers/h-captcha.mjs.map +1 -0
- package/dist/plugins/captcha/verify-handlers/index.mjs +6 -0
- package/dist/plugins/custom-session/client.d.mts +17 -0
- package/dist/plugins/custom-session/client.mjs +11 -0
- package/dist/plugins/custom-session/client.mjs.map +1 -0
- package/dist/plugins/custom-session/index.d.mts +72 -0
- package/dist/plugins/custom-session/index.mjs +78 -0
- package/dist/plugins/custom-session/index.mjs.map +1 -0
- package/dist/plugins/device-authorization/client.d.mts +17 -0
- package/dist/plugins/device-authorization/client.mjs +18 -0
- package/dist/plugins/device-authorization/client.mjs.map +1 -0
- package/dist/plugins/device-authorization/error-codes.mjs +21 -0
- package/dist/plugins/device-authorization/error-codes.mjs.map +1 -0
- package/dist/plugins/device-authorization/index.d.mts +424 -0
- package/dist/plugins/device-authorization/index.mjs +50 -0
- package/dist/plugins/device-authorization/index.mjs.map +1 -0
- package/dist/plugins/device-authorization/routes.mjs +510 -0
- package/dist/plugins/device-authorization/routes.mjs.map +1 -0
- package/dist/plugins/device-authorization/schema.mjs +57 -0
- package/dist/plugins/device-authorization/schema.mjs.map +1 -0
- package/dist/plugins/email-otp/client.d.mts +21 -0
- package/dist/plugins/email-otp/client.mjs +18 -0
- package/dist/plugins/email-otp/client.mjs.map +1 -0
- package/dist/plugins/email-otp/error-codes.d.mts +11 -0
- package/dist/plugins/email-otp/error-codes.mjs +12 -0
- package/dist/plugins/email-otp/error-codes.mjs.map +1 -0
- package/dist/plugins/email-otp/index.d.mts +428 -0
- package/dist/plugins/email-otp/index.mjs +130 -0
- package/dist/plugins/email-otp/index.mjs.map +1 -0
- package/dist/plugins/email-otp/otp-token.mjs +29 -0
- package/dist/plugins/email-otp/otp-token.mjs.map +1 -0
- package/dist/plugins/email-otp/routes.mjs +631 -0
- package/dist/plugins/email-otp/routes.mjs.map +1 -0
- package/dist/plugins/email-otp/types.d.mts +86 -0
- package/dist/plugins/email-otp/utils.mjs +17 -0
- package/dist/plugins/email-otp/utils.mjs.map +1 -0
- package/dist/plugins/generic-oauth/client.d.mts +33 -0
- package/dist/plugins/generic-oauth/client.mjs +14 -0
- package/dist/plugins/generic-oauth/client.mjs.map +1 -0
- package/dist/plugins/generic-oauth/error-codes.d.mts +16 -0
- package/dist/plugins/generic-oauth/error-codes.mjs +17 -0
- package/dist/plugins/generic-oauth/error-codes.mjs.map +1 -0
- package/dist/plugins/generic-oauth/index.d.mts +201 -0
- package/dist/plugins/generic-oauth/index.mjs +145 -0
- package/dist/plugins/generic-oauth/index.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/auth0.d.mts +37 -0
- package/dist/plugins/generic-oauth/providers/auth0.mjs +62 -0
- package/dist/plugins/generic-oauth/providers/auth0.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/gumroad.d.mts +32 -0
- package/dist/plugins/generic-oauth/providers/gumroad.mjs +60 -0
- package/dist/plugins/generic-oauth/providers/gumroad.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/hubspot.d.mts +37 -0
- package/dist/plugins/generic-oauth/providers/hubspot.mjs +60 -0
- package/dist/plugins/generic-oauth/providers/hubspot.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/index.d.mts +9 -0
- package/dist/plugins/generic-oauth/providers/index.mjs +11 -0
- package/dist/plugins/generic-oauth/providers/keycloak.d.mts +37 -0
- package/dist/plugins/generic-oauth/providers/keycloak.mjs +62 -0
- package/dist/plugins/generic-oauth/providers/keycloak.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/line.d.mts +55 -0
- package/dist/plugins/generic-oauth/providers/line.mjs +91 -0
- package/dist/plugins/generic-oauth/providers/line.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/microsoft-entra-id.d.mts +37 -0
- package/dist/plugins/generic-oauth/providers/microsoft-entra-id.mjs +66 -0
- package/dist/plugins/generic-oauth/providers/microsoft-entra-id.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/okta.d.mts +37 -0
- package/dist/plugins/generic-oauth/providers/okta.mjs +62 -0
- package/dist/plugins/generic-oauth/providers/okta.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/patreon.d.mts +30 -0
- package/dist/plugins/generic-oauth/providers/patreon.mjs +59 -0
- package/dist/plugins/generic-oauth/providers/patreon.mjs.map +1 -0
- package/dist/plugins/generic-oauth/providers/slack.d.mts +30 -0
- package/dist/plugins/generic-oauth/providers/slack.mjs +61 -0
- package/dist/plugins/generic-oauth/providers/slack.mjs.map +1 -0
- package/dist/plugins/generic-oauth/routes.mjs +411 -0
- package/dist/plugins/generic-oauth/routes.mjs.map +1 -0
- package/dist/plugins/generic-oauth/types.d.mts +159 -0
- package/dist/plugins/haveibeenpwned/index.d.mts +46 -0
- package/dist/plugins/haveibeenpwned/index.mjs +57 -0
- package/dist/plugins/haveibeenpwned/index.mjs.map +1 -0
- package/dist/plugins/index.d.mts +65 -0
- package/dist/plugins/index.mjs +48 -0
- package/dist/plugins/jwt/adapter.mjs +27 -0
- package/dist/plugins/jwt/adapter.mjs.map +1 -0
- package/dist/plugins/jwt/client.d.mts +40 -0
- package/dist/plugins/jwt/client.mjs +19 -0
- package/dist/plugins/jwt/client.mjs.map +1 -0
- package/dist/plugins/jwt/index.d.mts +224 -0
- package/dist/plugins/jwt/index.mjs +202 -0
- package/dist/plugins/jwt/index.mjs.map +1 -0
- package/dist/plugins/jwt/schema.d.mts +26 -0
- package/dist/plugins/jwt/schema.mjs +23 -0
- package/dist/plugins/jwt/schema.mjs.map +1 -0
- package/dist/plugins/jwt/sign.d.mts +57 -0
- package/dist/plugins/jwt/sign.mjs +66 -0
- package/dist/plugins/jwt/sign.mjs.map +1 -0
- package/dist/plugins/jwt/types.d.mts +194 -0
- package/dist/plugins/jwt/utils.d.mts +42 -0
- package/dist/plugins/jwt/utils.mjs +64 -0
- package/dist/plugins/jwt/utils.mjs.map +1 -0
- package/dist/plugins/jwt/verify.d.mts +12 -0
- package/dist/plugins/jwt/verify.mjs +46 -0
- package/dist/plugins/jwt/verify.mjs.map +1 -0
- package/dist/plugins/last-login-method/client.d.mts +38 -0
- package/dist/plugins/last-login-method/client.mjs +32 -0
- package/dist/plugins/last-login-method/client.mjs.map +1 -0
- package/dist/plugins/last-login-method/index.d.mts +118 -0
- package/dist/plugins/last-login-method/index.mjs +76 -0
- package/dist/plugins/last-login-method/index.mjs.map +1 -0
- package/dist/plugins/magic-link/client.d.mts +10 -0
- package/dist/plugins/magic-link/client.mjs +11 -0
- package/dist/plugins/magic-link/client.mjs.map +1 -0
- package/dist/plugins/magic-link/index.d.mts +193 -0
- package/dist/plugins/magic-link/index.mjs +177 -0
- package/dist/plugins/magic-link/index.mjs.map +1 -0
- package/dist/plugins/magic-link/utils.mjs +12 -0
- package/dist/plugins/magic-link/utils.mjs.map +1 -0
- package/dist/plugins/mcp/authorize.mjs +133 -0
- package/dist/plugins/mcp/authorize.mjs.map +1 -0
- package/dist/plugins/mcp/index.d.mts +458 -0
- package/dist/plugins/mcp/index.mjs +717 -0
- package/dist/plugins/mcp/index.mjs.map +1 -0
- package/dist/plugins/multi-session/client.d.mts +19 -0
- package/dist/plugins/multi-session/client.mjs +20 -0
- package/dist/plugins/multi-session/client.mjs.map +1 -0
- package/dist/plugins/multi-session/error-codes.d.mts +9 -0
- package/dist/plugins/multi-session/error-codes.mjs +8 -0
- package/dist/plugins/multi-session/error-codes.mjs.map +1 -0
- package/dist/plugins/multi-session/index.d.mts +235 -0
- package/dist/plugins/multi-session/index.mjs +172 -0
- package/dist/plugins/multi-session/index.mjs.map +1 -0
- package/dist/plugins/oauth-proxy/index.d.mts +97 -0
- package/dist/plugins/oauth-proxy/index.mjs +305 -0
- package/dist/plugins/oauth-proxy/index.mjs.map +1 -0
- package/dist/plugins/oauth-proxy/utils.mjs +51 -0
- package/dist/plugins/oauth-proxy/utils.mjs.map +1 -0
- package/dist/plugins/oidc-provider/authorize.mjs +194 -0
- package/dist/plugins/oidc-provider/authorize.mjs.map +1 -0
- package/dist/plugins/oidc-provider/client.d.mts +12 -0
- package/dist/plugins/oidc-provider/client.mjs +11 -0
- package/dist/plugins/oidc-provider/client.mjs.map +1 -0
- package/dist/plugins/oidc-provider/error.mjs +17 -0
- package/dist/plugins/oidc-provider/error.mjs.map +1 -0
- package/dist/plugins/oidc-provider/index.d.mts +702 -0
- package/dist/plugins/oidc-provider/index.mjs +1093 -0
- package/dist/plugins/oidc-provider/index.mjs.map +1 -0
- package/dist/plugins/oidc-provider/schema.d.mts +160 -0
- package/dist/plugins/oidc-provider/schema.mjs +132 -0
- package/dist/plugins/oidc-provider/schema.mjs.map +1 -0
- package/dist/plugins/oidc-provider/types.d.mts +517 -0
- package/dist/plugins/oidc-provider/utils/prompt.mjs +19 -0
- package/dist/plugins/oidc-provider/utils/prompt.mjs.map +1 -0
- package/dist/plugins/oidc-provider/utils.mjs +15 -0
- package/dist/plugins/oidc-provider/utils.mjs.map +1 -0
- package/dist/plugins/one-tap/client.d.mts +174 -0
- package/dist/plugins/one-tap/client.mjs +188 -0
- package/dist/plugins/one-tap/client.mjs.map +1 -0
- package/dist/plugins/one-tap/index.d.mts +83 -0
- package/dist/plugins/one-tap/index.mjs +95 -0
- package/dist/plugins/one-tap/index.mjs.map +1 -0
- package/dist/plugins/one-time-token/client.d.mts +10 -0
- package/dist/plugins/one-time-token/client.mjs +11 -0
- package/dist/plugins/one-time-token/client.mjs.map +1 -0
- package/dist/plugins/one-time-token/index.d.mts +133 -0
- package/dist/plugins/one-time-token/index.mjs +82 -0
- package/dist/plugins/one-time-token/index.mjs.map +1 -0
- package/dist/plugins/one-time-token/utils.mjs +12 -0
- package/dist/plugins/one-time-token/utils.mjs.map +1 -0
- package/dist/plugins/open-api/generator.d.mts +115 -0
- package/dist/plugins/open-api/generator.mjs +315 -0
- package/dist/plugins/open-api/generator.mjs.map +1 -0
- package/dist/plugins/open-api/index.d.mts +97 -0
- package/dist/plugins/open-api/index.mjs +67 -0
- package/dist/plugins/open-api/index.mjs.map +1 -0
- package/dist/plugins/open-api/logo.mjs +15 -0
- package/dist/plugins/open-api/logo.mjs.map +1 -0
- package/dist/plugins/organization/access/index.d.mts +2 -0
- package/dist/plugins/organization/access/index.mjs +3 -0
- package/dist/plugins/organization/access/statement.d.mts +249 -0
- package/dist/plugins/organization/access/statement.mjs +81 -0
- package/dist/plugins/organization/access/statement.mjs.map +1 -0
- package/dist/plugins/organization/adapter.d.mts +792 -0
- package/dist/plugins/organization/adapter.mjs +624 -0
- package/dist/plugins/organization/adapter.mjs.map +1 -0
- package/dist/plugins/organization/call.mjs +19 -0
- package/dist/plugins/organization/call.mjs.map +1 -0
- package/dist/plugins/organization/client.d.mts +372 -0
- package/dist/plugins/organization/client.mjs +95 -0
- package/dist/plugins/organization/client.mjs.map +1 -0
- package/dist/plugins/organization/error-codes.d.mts +65 -0
- package/dist/plugins/organization/error-codes.mjs +66 -0
- package/dist/plugins/organization/error-codes.mjs.map +1 -0
- package/dist/plugins/organization/has-permission.mjs +35 -0
- package/dist/plugins/organization/has-permission.mjs.map +1 -0
- package/dist/plugins/organization/index.d.mts +5 -0
- package/dist/plugins/organization/index.mjs +4 -0
- package/dist/plugins/organization/organization.d.mts +394 -0
- package/dist/plugins/organization/organization.mjs +428 -0
- package/dist/plugins/organization/organization.mjs.map +1 -0
- package/dist/plugins/organization/permission.d.mts +17 -0
- package/dist/plugins/organization/permission.mjs +16 -0
- package/dist/plugins/organization/permission.mjs.map +1 -0
- package/dist/plugins/organization/routes/crud-access-control.d.mts +394 -0
- package/dist/plugins/organization/routes/crud-access-control.mjs +678 -0
- package/dist/plugins/organization/routes/crud-access-control.mjs.map +1 -0
- package/dist/plugins/organization/routes/crud-invites.d.mts +1031 -0
- package/dist/plugins/organization/routes/crud-invites.mjs +551 -0
- package/dist/plugins/organization/routes/crud-invites.mjs.map +1 -0
- package/dist/plugins/organization/routes/crud-members.d.mts +940 -0
- package/dist/plugins/organization/routes/crud-members.mjs +466 -0
- package/dist/plugins/organization/routes/crud-members.mjs.map +1 -0
- package/dist/plugins/organization/routes/crud-org.d.mts +708 -0
- package/dist/plugins/organization/routes/crud-org.mjs +423 -0
- package/dist/plugins/organization/routes/crud-org.mjs.map +1 -0
- package/dist/plugins/organization/routes/crud-team.d.mts +1071 -0
- package/dist/plugins/organization/routes/crud-team.mjs +676 -0
- package/dist/plugins/organization/routes/crud-team.mjs.map +1 -0
- package/dist/plugins/organization/schema.d.mts +376 -0
- package/dist/plugins/organization/schema.mjs +68 -0
- package/dist/plugins/organization/schema.mjs.map +1 -0
- package/dist/plugins/organization/types.d.mts +677 -0
- package/dist/plugins/phone-number/client.d.mts +31 -0
- package/dist/plugins/phone-number/client.mjs +20 -0
- package/dist/plugins/phone-number/client.mjs.map +1 -0
- package/dist/plugins/phone-number/error-codes.d.mts +20 -0
- package/dist/plugins/phone-number/error-codes.mjs +21 -0
- package/dist/plugins/phone-number/error-codes.mjs.map +1 -0
- package/dist/plugins/phone-number/index.d.mts +318 -0
- package/dist/plugins/phone-number/index.mjs +49 -0
- package/dist/plugins/phone-number/index.mjs.map +1 -0
- package/dist/plugins/phone-number/routes.mjs +472 -0
- package/dist/plugins/phone-number/routes.mjs.map +1 -0
- package/dist/plugins/phone-number/schema.d.mts +23 -0
- package/dist/plugins/phone-number/schema.mjs +20 -0
- package/dist/plugins/phone-number/schema.mjs.map +1 -0
- package/dist/plugins/phone-number/types.d.mts +118 -0
- package/dist/plugins/two-factor/backup-codes/index.d.mts +279 -0
- package/dist/plugins/two-factor/backup-codes/index.mjs +277 -0
- package/dist/plugins/two-factor/backup-codes/index.mjs.map +1 -0
- package/dist/plugins/two-factor/client.d.mts +55 -0
- package/dist/plugins/two-factor/client.mjs +37 -0
- package/dist/plugins/two-factor/client.mjs.map +1 -0
- package/dist/plugins/two-factor/constant.mjs +8 -0
- package/dist/plugins/two-factor/constant.mjs.map +1 -0
- package/dist/plugins/two-factor/error-code.d.mts +17 -0
- package/dist/plugins/two-factor/error-code.mjs +18 -0
- package/dist/plugins/two-factor/error-code.mjs.map +1 -0
- package/dist/plugins/two-factor/index.d.mts +670 -0
- package/dist/plugins/two-factor/index.mjs +228 -0
- package/dist/plugins/two-factor/index.mjs.map +1 -0
- package/dist/plugins/two-factor/otp/index.d.mts +216 -0
- package/dist/plugins/two-factor/otp/index.mjs +199 -0
- package/dist/plugins/two-factor/otp/index.mjs.map +1 -0
- package/dist/plugins/two-factor/schema.d.mts +41 -0
- package/dist/plugins/two-factor/schema.mjs +36 -0
- package/dist/plugins/two-factor/schema.mjs.map +1 -0
- package/dist/plugins/two-factor/totp/index.d.mts +210 -0
- package/dist/plugins/two-factor/totp/index.mjs +157 -0
- package/dist/plugins/two-factor/totp/index.mjs.map +1 -0
- package/dist/plugins/two-factor/types.d.mts +73 -0
- package/dist/plugins/two-factor/utils.mjs +12 -0
- package/dist/plugins/two-factor/utils.mjs.map +1 -0
- package/dist/plugins/two-factor/verify-two-factor.mjs +85 -0
- package/dist/plugins/two-factor/verify-two-factor.mjs.map +1 -0
- package/dist/plugins/username/client.d.mts +26 -0
- package/dist/plugins/username/client.mjs +18 -0
- package/dist/plugins/username/client.mjs.map +1 -0
- package/dist/plugins/username/error-codes.d.mts +16 -0
- package/dist/plugins/username/error-codes.mjs +17 -0
- package/dist/plugins/username/error-codes.mjs.map +1 -0
- package/dist/plugins/username/index.d.mts +251 -0
- package/dist/plugins/username/index.mjs +234 -0
- package/dist/plugins/username/index.mjs.map +1 -0
- package/dist/plugins/username/schema.d.mts +33 -0
- package/dist/plugins/username/schema.mjs +26 -0
- package/dist/plugins/username/schema.mjs.map +1 -0
- package/dist/providers/index.d.mts +1 -0
- package/dist/providers/index.mjs +3 -0
- package/dist/state.d.mts +42 -0
- package/dist/state.mjs +107 -0
- package/dist/state.mjs.map +1 -0
- package/dist/types/adapter.d.mts +2 -0
- package/dist/types/api.d.mts +29 -0
- package/dist/types/auth.d.mts +29 -0
- package/dist/types/helper.d.mts +10 -0
- package/dist/types/index.d.mts +11 -0
- package/dist/types/index.mjs +1 -0
- package/dist/types/models.d.mts +11 -0
- package/dist/types/plugins.d.mts +20 -0
- package/dist/utils/boolean.mjs +8 -0
- package/dist/utils/boolean.mjs.map +1 -0
- package/dist/utils/constants.mjs +6 -0
- package/dist/utils/constants.mjs.map +1 -0
- package/dist/utils/date.mjs +8 -0
- package/dist/utils/date.mjs.map +1 -0
- package/dist/utils/get-request-ip.d.mts +7 -0
- package/dist/utils/get-request-ip.mjs +23 -0
- package/dist/utils/get-request-ip.mjs.map +1 -0
- package/dist/utils/hide-metadata.d.mts +7 -0
- package/dist/utils/hide-metadata.mjs +6 -0
- package/dist/utils/hide-metadata.mjs.map +1 -0
- package/dist/utils/index.d.mts +4 -0
- package/dist/utils/index.mjs +6 -0
- package/dist/utils/is-api-error.d.mts +7 -0
- package/dist/utils/is-api-error.mjs +11 -0
- package/dist/utils/is-api-error.mjs.map +1 -0
- package/dist/utils/is-atom.mjs +8 -0
- package/dist/utils/is-atom.mjs.map +1 -0
- package/dist/utils/is-promise.mjs +8 -0
- package/dist/utils/is-promise.mjs.map +1 -0
- package/dist/utils/middleware-response.mjs +9 -0
- package/dist/utils/middleware-response.mjs.map +1 -0
- package/dist/utils/password.mjs +26 -0
- package/dist/utils/password.mjs.map +1 -0
- package/dist/utils/plugin-helper.mjs +17 -0
- package/dist/utils/plugin-helper.mjs.map +1 -0
- package/dist/utils/shim.mjs +24 -0
- package/dist/utils/shim.mjs.map +1 -0
- package/dist/utils/time.d.mts +49 -0
- package/dist/utils/time.mjs +100 -0
- package/dist/utils/time.mjs.map +1 -0
- package/dist/utils/url.d.mts +8 -0
- package/dist/utils/url.mjs +92 -0
- package/dist/utils/url.mjs.map +1 -0
- package/dist/utils/wildcard.mjs +108 -0
- package/dist/utils/wildcard.mjs.map +1 -0
- package/package.json +428 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { HasRequiredKeys, Prettify, PrettifyDeep, RequiredKeysOf, StripEmptyObjects, UnionToIntersection } from "../types/helper.mjs";
|
|
2
|
+
import { BetterAuthClientOptions, BetterAuthClientPlugin, ClientAtomListener, ClientStore, InferActions, InferAdditionalFromClient, InferClientAPI, InferErrorCodes, InferSessionFromClient, InferUserFromClient, IsSignal, SessionQueryParams } from "./types.mjs";
|
|
3
|
+
import { BroadcastChannel, BroadcastListener, BroadcastMessage, getGlobalBroadcastChannel, kBroadcastChannel } from "./broadcast-channel.mjs";
|
|
4
|
+
import { FocusListener, FocusManager, kFocusManager } from "./focus-manager.mjs";
|
|
5
|
+
import { OnlineListener, OnlineManager, kOnlineManager } from "./online-manager.mjs";
|
|
6
|
+
import { AuthQueryAtom, useAuthQuery } from "./query.mjs";
|
|
7
|
+
import { SessionRefreshOptions, createSessionRefreshManager } from "./session-refresh.mjs";
|
|
8
|
+
import { AuthClient, createAuthClient } from "./vanilla.mjs";
|
|
9
|
+
import { AccessControl, Role, Statements, SubArray, Subset } from "../plugins/access/types.mjs";
|
|
10
|
+
import { AuthorizeResponse, createAccessControl, role } from "../plugins/access/access.mjs";
|
|
11
|
+
import "../plugins/access/index.mjs";
|
|
12
|
+
import { OrganizationOptions } from "../plugins/organization/types.mjs";
|
|
13
|
+
import { InferInvitation, InferMember, InferOrganization, InferOrganizationRolesFromOption, InferOrganizationZodRolesFromOption, InferTeam, Invitation, InvitationInput, InvitationStatus, Member, MemberInput, Organization, OrganizationInput, OrganizationRole, OrganizationSchema, Team, TeamInput, TeamMember, TeamMemberInput, defaultRolesSchema, invitationSchema, invitationStatus, memberSchema, organizationRoleSchema, organizationSchema, roleSchema, teamMemberSchema, teamSchema } from "../plugins/organization/schema.mjs";
|
|
14
|
+
import { getOrgAdapter } from "../plugins/organization/adapter.mjs";
|
|
15
|
+
import { DefaultOrganizationPlugin, DynamicAccessControlEndpoints, OrganizationCreator, OrganizationEndpoints, OrganizationPlugin, TeamEndpoints, organization, parseRoles } from "../plugins/organization/organization.mjs";
|
|
16
|
+
import "../plugins/organization/index.mjs";
|
|
17
|
+
import { BetterAuthOptions, BetterAuthPlugin } from "@better-auth/core";
|
|
18
|
+
import { DBPrimitive } from "@better-auth/core/db";
|
|
19
|
+
export * from "@better-auth/core/db";
|
|
20
|
+
export * from "nanostores";
|
|
21
|
+
export * from "@better-fetch/fetch";
|
|
22
|
+
|
|
23
|
+
//#region src/client/index.d.ts
|
|
24
|
+
declare const InferPlugin: <T extends BetterAuthPlugin>() => {
|
|
25
|
+
id: "infer-server-plugin";
|
|
26
|
+
$InferServerPlugin: T;
|
|
27
|
+
};
|
|
28
|
+
declare function InferAuth<O extends {
|
|
29
|
+
options: BetterAuthOptions;
|
|
30
|
+
}>(): O["options"];
|
|
31
|
+
//#endregion
|
|
32
|
+
export { AccessControl, AuthClient, AuthQueryAtom, AuthorizeResponse, BetterAuthClientOptions, BetterAuthClientPlugin, BroadcastChannel, BroadcastListener, BroadcastMessage, ClientAtomListener, ClientStore, type DBPrimitive, DefaultOrganizationPlugin, DynamicAccessControlEndpoints, type FocusListener, type FocusManager, HasRequiredKeys, InferActions, InferAdditionalFromClient, InferAuth, InferClientAPI, InferErrorCodes, InferInvitation, InferMember, InferOrganization, InferOrganizationRolesFromOption, InferOrganizationZodRolesFromOption, InferPlugin, InferSessionFromClient, InferTeam, InferUserFromClient, Invitation, InvitationInput, InvitationStatus, IsSignal, Member, MemberInput, type OnlineListener, type OnlineManager, Organization, OrganizationCreator, OrganizationEndpoints, OrganizationInput, OrganizationOptions, OrganizationPlugin, OrganizationRole, OrganizationSchema, Prettify, PrettifyDeep, RequiredKeysOf, Role, SessionQueryParams, SessionRefreshOptions, Statements, StripEmptyObjects, SubArray, Subset, Team, TeamEndpoints, TeamInput, TeamMember, TeamMemberInput, type UnionToIntersection, createAccessControl, createAuthClient, createSessionRefreshManager, defaultRolesSchema, getGlobalBroadcastChannel, getOrgAdapter, invitationSchema, invitationStatus, kBroadcastChannel, kFocusManager, kOnlineManager, memberSchema, organization, organizationRoleSchema, organizationSchema, parseRoles, role, roleSchema, teamMemberSchema, teamSchema, useAuthQuery };
|
|
33
|
+
//# sourceMappingURL=index.d.mts.map
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { getGlobalBroadcastChannel, kBroadcastChannel } from "./broadcast-channel.mjs";
|
|
2
|
+
import { kFocusManager } from "./focus-manager.mjs";
|
|
3
|
+
import { kOnlineManager } from "./online-manager.mjs";
|
|
4
|
+
import { useAuthQuery } from "./query.mjs";
|
|
5
|
+
import { createSessionRefreshManager } from "./session-refresh.mjs";
|
|
6
|
+
import { createAuthClient } from "./vanilla.mjs";
|
|
7
|
+
|
|
8
|
+
//#region src/client/index.ts
|
|
9
|
+
const InferPlugin = () => {
|
|
10
|
+
return {
|
|
11
|
+
id: "infer-server-plugin",
|
|
12
|
+
$InferServerPlugin: {}
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
function InferAuth() {
|
|
16
|
+
return {};
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
//#endregion
|
|
20
|
+
export { InferAuth, InferPlugin, createAuthClient, createSessionRefreshManager, getGlobalBroadcastChannel, kBroadcastChannel, kFocusManager, kOnlineManager, useAuthQuery };
|
|
21
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","names":[],"sources":["../../src/client/index.ts"],"sourcesContent":["import type {\n\tBetterAuthClientPlugin,\n\tBetterAuthOptions,\n\tBetterAuthPlugin,\n} from \"@better-auth/core\";\n\nexport * from \"./broadcast-channel\";\nexport {\n\ttype FocusListener,\n\ttype FocusManager,\n\tkFocusManager,\n} from \"./focus-manager\";\nexport {\n\tkOnlineManager,\n\ttype OnlineListener,\n\ttype OnlineManager,\n} from \"./online-manager\";\nexport * from \"./query\";\nexport * from \"./session-refresh\";\nexport * from \"./types\";\nexport * from \"./vanilla\";\n\nexport const InferPlugin = <T extends BetterAuthPlugin>() => {\n\treturn {\n\t\tid: \"infer-server-plugin\",\n\t\t$InferServerPlugin: {} as T,\n\t} satisfies BetterAuthClientPlugin;\n};\n\nexport function InferAuth<O extends { options: BetterAuthOptions }>() {\n\treturn {} as O[\"options\"];\n}\n\n//#region Necessary re-exports\nexport type * from \"@better-auth/core/db\";\nexport type { DBPrimitive } from \"@better-auth/core/db\";\nexport type * from \"@better-fetch/fetch\";\nexport type * from \"nanostores\";\nexport type * from \"../plugins/access\";\nexport type * from \"../plugins/organization\";\nexport type * from \"../types/helper\";\nexport type { UnionToIntersection } from \"../types/helper\";\n//#endregion\n"],"mappings":";;;;;;;;AAsBA,MAAa,oBAAgD;AAC5D,QAAO;EACN,IAAI;EACJ,oBAAoB,EAAE;EACtB;;AAGF,SAAgB,YAAsD;AACrE,QAAO,EAAE"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
//#region src/client/online-manager.d.ts
|
|
2
|
+
type OnlineListener = (online: boolean) => void;
|
|
3
|
+
declare const kOnlineManager: unique symbol;
|
|
4
|
+
interface OnlineManager {
|
|
5
|
+
setOnline(online: boolean): void;
|
|
6
|
+
isOnline: boolean;
|
|
7
|
+
subscribe(listener: OnlineListener): () => void;
|
|
8
|
+
setup(): () => void;
|
|
9
|
+
}
|
|
10
|
+
//#endregion
|
|
11
|
+
export { OnlineListener, OnlineManager, kOnlineManager };
|
|
12
|
+
//# sourceMappingURL=online-manager.d.mts.map
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
//#region src/client/online-manager.ts
|
|
2
|
+
const kOnlineManager = Symbol.for("better-auth:online-manager");
|
|
3
|
+
var WindowOnlineManager = class {
|
|
4
|
+
listeners = /* @__PURE__ */ new Set();
|
|
5
|
+
isOnline = typeof navigator !== "undefined" ? navigator.onLine : true;
|
|
6
|
+
subscribe(listener) {
|
|
7
|
+
this.listeners.add(listener);
|
|
8
|
+
return () => {
|
|
9
|
+
this.listeners.delete(listener);
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
setOnline(online) {
|
|
13
|
+
this.isOnline = online;
|
|
14
|
+
this.listeners.forEach((listener) => listener(online));
|
|
15
|
+
}
|
|
16
|
+
setup() {
|
|
17
|
+
if (typeof window === "undefined" || typeof window.addEventListener === "undefined") return () => {};
|
|
18
|
+
const onOnline = () => this.setOnline(true);
|
|
19
|
+
const onOffline = () => this.setOnline(false);
|
|
20
|
+
window.addEventListener("online", onOnline, false);
|
|
21
|
+
window.addEventListener("offline", onOffline, false);
|
|
22
|
+
return () => {
|
|
23
|
+
window.removeEventListener("online", onOnline, false);
|
|
24
|
+
window.removeEventListener("offline", onOffline, false);
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
function getGlobalOnlineManager() {
|
|
29
|
+
if (!globalThis[kOnlineManager]) globalThis[kOnlineManager] = new WindowOnlineManager();
|
|
30
|
+
return globalThis[kOnlineManager];
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
//#endregion
|
|
34
|
+
export { getGlobalOnlineManager, kOnlineManager };
|
|
35
|
+
//# sourceMappingURL=online-manager.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"online-manager.mjs","names":[],"sources":["../../src/client/online-manager.ts"],"sourcesContent":["export type OnlineListener = (online: boolean) => void;\n\nexport const kOnlineManager = Symbol.for(\"better-auth:online-manager\");\n\nexport interface OnlineManager {\n\tsetOnline(online: boolean): void;\n\tisOnline: boolean;\n\n\tsubscribe(listener: OnlineListener): () => void;\n\tsetup(): () => void;\n}\n\nclass WindowOnlineManager implements OnlineManager {\n\tlisteners = new Set<OnlineListener>();\n\tisOnline = typeof navigator !== \"undefined\" ? navigator.onLine : true;\n\n\tsubscribe(listener: OnlineListener) {\n\t\tthis.listeners.add(listener);\n\t\treturn () => {\n\t\t\tthis.listeners.delete(listener);\n\t\t};\n\t}\n\n\tsetOnline(online: boolean) {\n\t\tthis.isOnline = online;\n\t\tthis.listeners.forEach((listener) => listener(online));\n\t}\n\n\tsetup() {\n\t\tif (\n\t\t\ttypeof window === \"undefined\" ||\n\t\t\ttypeof window.addEventListener === \"undefined\"\n\t\t) {\n\t\t\treturn () => {};\n\t\t}\n\n\t\tconst onOnline = () => this.setOnline(true);\n\t\tconst onOffline = () => this.setOnline(false);\n\n\t\twindow.addEventListener(\"online\", onOnline, false);\n\t\twindow.addEventListener(\"offline\", onOffline, false);\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener(\"online\", onOnline, false);\n\t\t\twindow.removeEventListener(\"offline\", onOffline, false);\n\t\t};\n\t}\n}\n\nexport function getGlobalOnlineManager() {\n\tif (!(globalThis as any)[kOnlineManager]) {\n\t\t(globalThis as any)[kOnlineManager] = new WindowOnlineManager();\n\t}\n\treturn (globalThis as any)[kOnlineManager] as OnlineManager;\n}\n"],"mappings":";AAEA,MAAa,iBAAiB,OAAO,IAAI,6BAA6B;AAUtE,IAAM,sBAAN,MAAmD;CAClD,4BAAY,IAAI,KAAqB;CACrC,WAAW,OAAO,cAAc,cAAc,UAAU,SAAS;CAEjE,UAAU,UAA0B;AACnC,OAAK,UAAU,IAAI,SAAS;AAC5B,eAAa;AACZ,QAAK,UAAU,OAAO,SAAS;;;CAIjC,UAAU,QAAiB;AAC1B,OAAK,WAAW;AAChB,OAAK,UAAU,SAAS,aAAa,SAAS,OAAO,CAAC;;CAGvD,QAAQ;AACP,MACC,OAAO,WAAW,eAClB,OAAO,OAAO,qBAAqB,YAEnC,cAAa;EAGd,MAAM,iBAAiB,KAAK,UAAU,KAAK;EAC3C,MAAM,kBAAkB,KAAK,UAAU,MAAM;AAE7C,SAAO,iBAAiB,UAAU,UAAU,MAAM;AAClD,SAAO,iBAAiB,WAAW,WAAW,MAAM;AAEpD,eAAa;AACZ,UAAO,oBAAoB,UAAU,UAAU,MAAM;AACrD,UAAO,oBAAoB,WAAW,WAAW,MAAM;;;;AAK1D,SAAgB,yBAAyB;AACxC,KAAI,CAAE,WAAmB,gBACxB,CAAC,WAAmB,kBAAkB,IAAI,qBAAqB;AAEhE,QAAQ,WAAmB"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
//#region src/client/parser.ts
|
|
2
|
+
const PROTO_POLLUTION_PATTERNS = {
|
|
3
|
+
proto: /"(?:_|\\u0{2}5[Ff]){2}(?:p|\\u0{2}70)(?:r|\\u0{2}72)(?:o|\\u0{2}6[Ff])(?:t|\\u0{2}74)(?:o|\\u0{2}6[Ff])(?:_|\\u0{2}5[Ff]){2}"\s*:/,
|
|
4
|
+
constructor: /"(?:c|\\u0063)(?:o|\\u006[Ff])(?:n|\\u006[Ee])(?:s|\\u0073)(?:t|\\u0074)(?:r|\\u0072)(?:u|\\u0075)(?:c|\\u0063)(?:t|\\u0074)(?:o|\\u006[Ff])(?:r|\\u0072)"\s*:/,
|
|
5
|
+
protoShort: /"__proto__"\s*:/,
|
|
6
|
+
constructorShort: /"constructor"\s*:/
|
|
7
|
+
};
|
|
8
|
+
const JSON_SIGNATURE = /^\s*["[{]|^\s*-?\d{1,16}(\.\d{1,17})?([Ee][+-]?\d+)?\s*$/;
|
|
9
|
+
const SPECIAL_VALUES = {
|
|
10
|
+
true: true,
|
|
11
|
+
false: false,
|
|
12
|
+
null: null,
|
|
13
|
+
undefined: void 0,
|
|
14
|
+
nan: NaN,
|
|
15
|
+
infinity: Number.POSITIVE_INFINITY,
|
|
16
|
+
"-infinity": Number.NEGATIVE_INFINITY
|
|
17
|
+
};
|
|
18
|
+
const ISO_DATE_REGEX = /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(?:\.(\d{1,7}))?(?:Z|([+-])(\d{2}):(\d{2}))$/;
|
|
19
|
+
function isValidDate(date) {
|
|
20
|
+
return date instanceof Date && !isNaN(date.getTime());
|
|
21
|
+
}
|
|
22
|
+
function parseISODate(value) {
|
|
23
|
+
const match = ISO_DATE_REGEX.exec(value);
|
|
24
|
+
if (!match) return null;
|
|
25
|
+
const [, year, month, day, hour, minute, second, ms, offsetSign, offsetHour, offsetMinute] = match;
|
|
26
|
+
const date = new Date(Date.UTC(parseInt(year, 10), parseInt(month, 10) - 1, parseInt(day, 10), parseInt(hour, 10), parseInt(minute, 10), parseInt(second, 10), ms ? parseInt(ms.padEnd(3, "0"), 10) : 0));
|
|
27
|
+
if (offsetSign) {
|
|
28
|
+
const offset = (parseInt(offsetHour, 10) * 60 + parseInt(offsetMinute, 10)) * (offsetSign === "+" ? -1 : 1);
|
|
29
|
+
date.setUTCMinutes(date.getUTCMinutes() + offset);
|
|
30
|
+
}
|
|
31
|
+
return isValidDate(date) ? date : null;
|
|
32
|
+
}
|
|
33
|
+
function betterJSONParse(value, options = {}) {
|
|
34
|
+
const { strict = false, warnings = false, reviver, parseDates = true } = options;
|
|
35
|
+
if (typeof value !== "string") return value;
|
|
36
|
+
const trimmed = value.trim();
|
|
37
|
+
if (trimmed.length > 0 && trimmed[0] === "\"" && trimmed.endsWith("\"") && !trimmed.slice(1, -1).includes("\"")) return trimmed.slice(1, -1);
|
|
38
|
+
const lowerValue = trimmed.toLowerCase();
|
|
39
|
+
if (lowerValue.length <= 9 && lowerValue in SPECIAL_VALUES) return SPECIAL_VALUES[lowerValue];
|
|
40
|
+
if (!JSON_SIGNATURE.test(trimmed)) {
|
|
41
|
+
if (strict) throw new SyntaxError("[better-json] Invalid JSON");
|
|
42
|
+
return value;
|
|
43
|
+
}
|
|
44
|
+
if (Object.entries(PROTO_POLLUTION_PATTERNS).some(([key, pattern]) => {
|
|
45
|
+
const matches = pattern.test(trimmed);
|
|
46
|
+
if (matches && warnings) console.warn(`[better-json] Detected potential prototype pollution attempt using ${key} pattern`);
|
|
47
|
+
return matches;
|
|
48
|
+
}) && strict) throw new Error("[better-json] Potential prototype pollution attempt detected");
|
|
49
|
+
try {
|
|
50
|
+
const secureReviver = (key, value) => {
|
|
51
|
+
if (key === "__proto__" || key === "constructor" && value && typeof value === "object" && "prototype" in value) {
|
|
52
|
+
if (warnings) console.warn(`[better-json] Dropping "${key}" key to prevent prototype pollution`);
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
if (parseDates && typeof value === "string") {
|
|
56
|
+
const date = parseISODate(value);
|
|
57
|
+
if (date) return date;
|
|
58
|
+
}
|
|
59
|
+
return reviver ? reviver(key, value) : value;
|
|
60
|
+
};
|
|
61
|
+
return JSON.parse(trimmed, secureReviver);
|
|
62
|
+
} catch (error) {
|
|
63
|
+
if (strict) throw error;
|
|
64
|
+
return value;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
function parseJSON(value, options = { strict: true }) {
|
|
68
|
+
return betterJSONParse(value, options);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
//#endregion
|
|
72
|
+
export { parseJSON };
|
|
73
|
+
//# sourceMappingURL=parser.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.mjs","names":[],"sources":["../../src/client/parser.ts"],"sourcesContent":["const PROTO_POLLUTION_PATTERNS = {\n\tproto:\n\t\t/\"(?:_|\\\\u0{2}5[Ff]){2}(?:p|\\\\u0{2}70)(?:r|\\\\u0{2}72)(?:o|\\\\u0{2}6[Ff])(?:t|\\\\u0{2}74)(?:o|\\\\u0{2}6[Ff])(?:_|\\\\u0{2}5[Ff]){2}\"\\s*:/,\n\tconstructor:\n\t\t/\"(?:c|\\\\u0063)(?:o|\\\\u006[Ff])(?:n|\\\\u006[Ee])(?:s|\\\\u0073)(?:t|\\\\u0074)(?:r|\\\\u0072)(?:u|\\\\u0075)(?:c|\\\\u0063)(?:t|\\\\u0074)(?:o|\\\\u006[Ff])(?:r|\\\\u0072)\"\\s*:/,\n\tprotoShort: /\"__proto__\"\\s*:/,\n\tconstructorShort: /\"constructor\"\\s*:/,\n} as const;\n\nconst JSON_SIGNATURE =\n\t/^\\s*[\"[{]|^\\s*-?\\d{1,16}(\\.\\d{1,17})?([Ee][+-]?\\d+)?\\s*$/;\n\nconst SPECIAL_VALUES = {\n\ttrue: true,\n\tfalse: false,\n\tnull: null,\n\tundefined: undefined,\n\tnan: Number.NaN,\n\tinfinity: Number.POSITIVE_INFINITY,\n\t\"-infinity\": Number.NEGATIVE_INFINITY,\n} as const;\n\nconst ISO_DATE_REGEX =\n\t/^(\\d{4})-(\\d{2})-(\\d{2})T(\\d{2}):(\\d{2}):(\\d{2})(?:\\.(\\d{1,7}))?(?:Z|([+-])(\\d{2}):(\\d{2}))$/;\n\ntype ParseOptions = {\n\t/** Throw errors instead of returning the original value */\n\tstrict?: boolean | undefined;\n\t/** Log warnings when suspicious patterns are detected */\n\twarnings?: boolean | undefined;\n\t/** Custom reviver function */\n\treviver?: ((key: string, value: any) => any) | undefined;\n\t/** Automatically convert ISO date strings to Date objects */\n\tparseDates?: boolean | undefined;\n};\n\nfunction isValidDate(date: Date): boolean {\n\treturn date instanceof Date && !isNaN(date.getTime());\n}\n\nfunction parseISODate(value: string): Date | null {\n\tconst match = ISO_DATE_REGEX.exec(value);\n\tif (!match) return null;\n\n\tconst [\n\t\t,\n\t\tyear,\n\t\tmonth,\n\t\tday,\n\t\thour,\n\t\tminute,\n\t\tsecond,\n\t\tms,\n\t\toffsetSign,\n\t\toffsetHour,\n\t\toffsetMinute,\n\t] = match;\n\n\tconst date = new Date(\n\t\tDate.UTC(\n\t\t\tparseInt(year!, 10),\n\t\t\tparseInt(month!, 10) - 1,\n\t\t\tparseInt(day!, 10),\n\t\t\tparseInt(hour!, 10),\n\t\t\tparseInt(minute!, 10),\n\t\t\tparseInt(second!, 10),\n\t\t\tms ? parseInt(ms.padEnd(3, \"0\"), 10) : 0,\n\t\t),\n\t);\n\n\tif (offsetSign) {\n\t\tconst offset =\n\t\t\t(parseInt(offsetHour!, 10) * 60 + parseInt(offsetMinute!, 10)) *\n\t\t\t(offsetSign === \"+\" ? -1 : 1);\n\t\tdate.setUTCMinutes(date.getUTCMinutes() + offset);\n\t}\n\n\treturn isValidDate(date) ? date : null;\n}\n\nfunction betterJSONParse<T = unknown>(\n\tvalue: unknown,\n\toptions: ParseOptions = {},\n): T {\n\tconst {\n\t\tstrict = false,\n\t\twarnings = false,\n\t\treviver,\n\t\tparseDates = true,\n\t} = options;\n\n\tif (typeof value !== \"string\") {\n\t\treturn value as T;\n\t}\n\n\tconst trimmed = value.trim();\n\n\tif (\n\t\ttrimmed.length > 0 &&\n\t\ttrimmed[0] === '\"' &&\n\t\ttrimmed.endsWith('\"') &&\n\t\t!trimmed.slice(1, -1).includes('\"')\n\t) {\n\t\treturn trimmed.slice(1, -1) as T;\n\t}\n\n\tconst lowerValue = trimmed.toLowerCase();\n\tif (lowerValue.length <= 9 && lowerValue in SPECIAL_VALUES) {\n\t\treturn SPECIAL_VALUES[lowerValue as keyof typeof SPECIAL_VALUES] as T;\n\t}\n\n\tif (!JSON_SIGNATURE.test(trimmed)) {\n\t\tif (strict) {\n\t\t\tthrow new SyntaxError(\"[better-json] Invalid JSON\");\n\t\t}\n\t\treturn value as T;\n\t}\n\n\tconst hasProtoPattern = Object.entries(PROTO_POLLUTION_PATTERNS).some(\n\t\t([key, pattern]) => {\n\t\t\tconst matches = pattern.test(trimmed);\n\t\t\tif (matches && warnings) {\n\t\t\t\tconsole.warn(\n\t\t\t\t\t`[better-json] Detected potential prototype pollution attempt using ${key} pattern`,\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn matches;\n\t\t},\n\t);\n\n\tif (hasProtoPattern && strict) {\n\t\tthrow new Error(\n\t\t\t\"[better-json] Potential prototype pollution attempt detected\",\n\t\t);\n\t}\n\n\ttry {\n\t\tconst secureReviver = (key: string, value: any) => {\n\t\t\tif (\n\t\t\t\tkey === \"__proto__\" ||\n\t\t\t\t(key === \"constructor\" &&\n\t\t\t\t\tvalue &&\n\t\t\t\t\ttypeof value === \"object\" &&\n\t\t\t\t\t\"prototype\" in value)\n\t\t\t) {\n\t\t\t\tif (warnings) {\n\t\t\t\t\tconsole.warn(\n\t\t\t\t\t\t`[better-json] Dropping \"${key}\" key to prevent prototype pollution`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\tif (parseDates && typeof value === \"string\") {\n\t\t\t\tconst date = parseISODate(value);\n\t\t\t\tif (date) {\n\t\t\t\t\treturn date;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn reviver ? reviver(key, value) : value;\n\t\t};\n\n\t\treturn JSON.parse(trimmed, secureReviver);\n\t} catch (error) {\n\t\tif (strict) {\n\t\t\tthrow error;\n\t\t}\n\t\treturn value as T;\n\t}\n}\n\nexport function parseJSON<T = unknown>(\n\tvalue: unknown,\n\toptions: ParseOptions = { strict: true },\n): T {\n\treturn betterJSONParse<T>(value, options);\n}\n"],"mappings":";AAAA,MAAM,2BAA2B;CAChC,OACC;CACD,aACC;CACD,YAAY;CACZ,kBAAkB;CAClB;AAED,MAAM,iBACL;AAED,MAAM,iBAAiB;CACtB,MAAM;CACN,OAAO;CACP,MAAM;CACN,WAAW;CACX,KAAK;CACL,UAAU,OAAO;CACjB,aAAa,OAAO;CACpB;AAED,MAAM,iBACL;AAaD,SAAS,YAAY,MAAqB;AACzC,QAAO,gBAAgB,QAAQ,CAAC,MAAM,KAAK,SAAS,CAAC;;AAGtD,SAAS,aAAa,OAA4B;CACjD,MAAM,QAAQ,eAAe,KAAK,MAAM;AACxC,KAAI,CAAC,MAAO,QAAO;CAEnB,MAAM,GAEL,MACA,OACA,KACA,MACA,QACA,QACA,IACA,YACA,YACA,gBACG;CAEJ,MAAM,OAAO,IAAI,KAChB,KAAK,IACJ,SAAS,MAAO,GAAG,EACnB,SAAS,OAAQ,GAAG,GAAG,GACvB,SAAS,KAAM,GAAG,EAClB,SAAS,MAAO,GAAG,EACnB,SAAS,QAAS,GAAG,EACrB,SAAS,QAAS,GAAG,EACrB,KAAK,SAAS,GAAG,OAAO,GAAG,IAAI,EAAE,GAAG,GAAG,EACvC,CACD;AAED,KAAI,YAAY;EACf,MAAM,UACJ,SAAS,YAAa,GAAG,GAAG,KAAK,SAAS,cAAe,GAAG,KAC5D,eAAe,MAAM,KAAK;AAC5B,OAAK,cAAc,KAAK,eAAe,GAAG,OAAO;;AAGlD,QAAO,YAAY,KAAK,GAAG,OAAO;;AAGnC,SAAS,gBACR,OACA,UAAwB,EAAE,EACtB;CACJ,MAAM,EACL,SAAS,OACT,WAAW,OACX,SACA,aAAa,SACV;AAEJ,KAAI,OAAO,UAAU,SACpB,QAAO;CAGR,MAAM,UAAU,MAAM,MAAM;AAE5B,KACC,QAAQ,SAAS,KACjB,QAAQ,OAAO,QACf,QAAQ,SAAS,KAAI,IACrB,CAAC,QAAQ,MAAM,GAAG,GAAG,CAAC,SAAS,KAAI,CAEnC,QAAO,QAAQ,MAAM,GAAG,GAAG;CAG5B,MAAM,aAAa,QAAQ,aAAa;AACxC,KAAI,WAAW,UAAU,KAAK,cAAc,eAC3C,QAAO,eAAe;AAGvB,KAAI,CAAC,eAAe,KAAK,QAAQ,EAAE;AAClC,MAAI,OACH,OAAM,IAAI,YAAY,6BAA6B;AAEpD,SAAO;;AAeR,KAZwB,OAAO,QAAQ,yBAAyB,CAAC,MAC/D,CAAC,KAAK,aAAa;EACnB,MAAM,UAAU,QAAQ,KAAK,QAAQ;AACrC,MAAI,WAAW,SACd,SAAQ,KACP,sEAAsE,IAAI,UAC1E;AAEF,SAAO;GAER,IAEsB,OACtB,OAAM,IAAI,MACT,+DACA;AAGF,KAAI;EACH,MAAM,iBAAiB,KAAa,UAAe;AAClD,OACC,QAAQ,eACP,QAAQ,iBACR,SACA,OAAO,UAAU,YACjB,eAAe,OACf;AACD,QAAI,SACH,SAAQ,KACP,2BAA2B,IAAI,sCAC/B;AAEF;;AAGD,OAAI,cAAc,OAAO,UAAU,UAAU;IAC5C,MAAM,OAAO,aAAa,MAAM;AAChC,QAAI,KACH,QAAO;;AAIT,UAAO,UAAU,QAAQ,KAAK,MAAM,GAAG;;AAGxC,SAAO,KAAK,MAAM,SAAS,cAAc;UACjC,OAAO;AACf,MAAI,OACH,OAAM;AAEP,SAAO;;;AAIT,SAAgB,UACf,OACA,UAAwB,EAAE,QAAQ,MAAM,EACpC;AACJ,QAAO,gBAAmB,OAAO,QAAQ"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { HasRequiredKeys, Prettify as Prettify$1, UnionToIntersection } from "../types/helper.mjs";
|
|
2
|
+
import { InferAdditionalFromClient, InferSessionFromClient, InferUserFromClient } from "./types.mjs";
|
|
3
|
+
import { BetterAuthClientOptions, ClientFetchOption } from "@better-auth/core";
|
|
4
|
+
import { Endpoint, InputContext, StandardSchemaV1 } from "better-call";
|
|
5
|
+
import { BetterFetchResponse } from "@better-fetch/fetch";
|
|
6
|
+
|
|
7
|
+
//#region src/client/path-to-object.d.ts
|
|
8
|
+
type KeepNullishFromOriginal<Original, Replaced> = Replaced | (undefined extends Original ? undefined : never) | (null extends Original ? null : never);
|
|
9
|
+
type ReplaceTopLevelField<Data, Field extends "user" | "session", Replaced> = Data extends object ? Field extends keyof Data ? Omit<Data, Field> & { [K in Field]: KeepNullishFromOriginal<Data[K], Replaced> } : Data : Data;
|
|
10
|
+
type ReplaceAuthUserAndSession<Data, ClientOpts extends BetterAuthClientOptions> = ReplaceTopLevelField<ReplaceTopLevelField<Data, "user", InferUserFromClient<ClientOpts>>, "session", InferSessionFromClient<ClientOpts>>;
|
|
11
|
+
type RefineAuthResponse<Data, ClientOpts extends BetterAuthClientOptions> = Data extends {
|
|
12
|
+
token: unknown;
|
|
13
|
+
} | {
|
|
14
|
+
redirect: unknown;
|
|
15
|
+
} ? ReplaceAuthUserAndSession<Data, ClientOpts> : Data;
|
|
16
|
+
type CamelCase<S extends string> = S extends `${infer P1}-${infer P2}${infer P3}` ? `${Lowercase<P1>}${Uppercase<P2>}${CamelCase<P3>}` : Lowercase<S>;
|
|
17
|
+
type PathToObject<T extends string, Fn extends (...args: any[]) => any> = T extends `/${infer Segment}/${infer Rest}` ? { [K in CamelCase<Segment>]: PathToObject<`/${Rest}`, Fn> } : T extends `/${infer Segment}` ? { [K in CamelCase<Segment>]: Fn } : never;
|
|
18
|
+
type InferSignUpEmailCtx<ClientOpts extends BetterAuthClientOptions, FetchOptions extends ClientFetchOption> = {
|
|
19
|
+
email: string;
|
|
20
|
+
name: string;
|
|
21
|
+
password: string;
|
|
22
|
+
image?: string | undefined;
|
|
23
|
+
callbackURL?: string | undefined;
|
|
24
|
+
fetchOptions?: FetchOptions | undefined;
|
|
25
|
+
} & UnionToIntersection<InferAdditionalFromClient<ClientOpts, "user", "input">>;
|
|
26
|
+
type InferUserUpdateCtx<ClientOpts extends BetterAuthClientOptions, FetchOptions extends ClientFetchOption> = {
|
|
27
|
+
image?: (string | null) | undefined;
|
|
28
|
+
name?: string | undefined;
|
|
29
|
+
fetchOptions?: FetchOptions | undefined;
|
|
30
|
+
} & Partial<UnionToIntersection<InferAdditionalFromClient<ClientOpts, "user", "input">>>;
|
|
31
|
+
type InferCtx<C extends InputContext<any, any>, FetchOptions extends ClientFetchOption> = C["body"] extends Record<string, any> ? C["body"] & {
|
|
32
|
+
fetchOptions?: FetchOptions | undefined;
|
|
33
|
+
} : C["query"] extends Record<string, any> ? {
|
|
34
|
+
query: C["query"];
|
|
35
|
+
fetchOptions?: FetchOptions | undefined;
|
|
36
|
+
} : C["query"] extends Record<string, any> | undefined ? {
|
|
37
|
+
query?: C["query"] | undefined;
|
|
38
|
+
fetchOptions?: FetchOptions | undefined;
|
|
39
|
+
} : {
|
|
40
|
+
fetchOptions?: FetchOptions | undefined;
|
|
41
|
+
};
|
|
42
|
+
type MergeRoutes<T> = UnionToIntersection<T>;
|
|
43
|
+
type InferRoute<API, COpts extends BetterAuthClientOptions> = API extends Record<string, infer T> ? T extends Endpoint ? T["options"]["metadata"] extends {
|
|
44
|
+
isAction: false;
|
|
45
|
+
} | {
|
|
46
|
+
SERVER_ONLY: true;
|
|
47
|
+
} | {
|
|
48
|
+
scope: "http";
|
|
49
|
+
} | {
|
|
50
|
+
scope: "server";
|
|
51
|
+
} ? {} : PathToObject<T["path"], T extends ((ctx: infer C) => infer R) ? C extends InputContext<any, any> ? <FetchOptions extends ClientFetchOption<Partial<C["body"]> & Record<string, any>, Partial<C["query"]> & Record<string, any>, C["params"]>>(...data: HasRequiredKeys<InferCtx<C, FetchOptions>> extends true ? [Prettify$1<T["path"] extends `/sign-up/email` ? InferSignUpEmailCtx<COpts, FetchOptions> : InferCtx<C, FetchOptions>>, FetchOptions?] : [Prettify$1<T["path"] extends `/update-user` ? InferUserUpdateCtx<COpts, FetchOptions> : InferCtx<C, FetchOptions>>?, FetchOptions?]) => Promise<BetterFetchResponse<T["options"]["metadata"] extends {
|
|
52
|
+
CUSTOM_SESSION: boolean;
|
|
53
|
+
} ? NonNullable<Awaited<R>> : T["path"] extends "/get-session" ? {
|
|
54
|
+
user: InferUserFromClient<COpts>;
|
|
55
|
+
session: InferSessionFromClient<COpts>;
|
|
56
|
+
} | null : RefineAuthResponse<NonNullable<Awaited<R>>, COpts>, T["options"]["error"] extends StandardSchemaV1 ? NonNullable<T["options"]["error"]["~standard"]["types"]>["output"] : {
|
|
57
|
+
code?: string | undefined;
|
|
58
|
+
message?: string | undefined;
|
|
59
|
+
}, FetchOptions["throw"] extends true ? true : COpts["fetchOptions"] extends {
|
|
60
|
+
throw: true;
|
|
61
|
+
} ? true : false>> : never : never> : {} : never;
|
|
62
|
+
type InferRoutes<API extends Record<string, Endpoint>, ClientOpts extends BetterAuthClientOptions> = MergeRoutes<InferRoute<API, ClientOpts>>;
|
|
63
|
+
//#endregion
|
|
64
|
+
export { InferRoutes };
|
|
65
|
+
//# sourceMappingURL=path-to-object.d.mts.map
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { HasRequiredKeys, Prettify, PrettifyDeep, RequiredKeysOf, StripEmptyObjects, UnionToIntersection } from "../../types/helper.mjs";
|
|
2
|
+
import { InferInvitation, InferMember, InferOrganization, InferOrganizationRolesFromOption, InferOrganizationZodRolesFromOption, InferTeam, Invitation, InvitationInput, InvitationStatus, Member, MemberInput, Organization, OrganizationInput, OrganizationRole, OrganizationSchema, Team, TeamInput, TeamMember, TeamMemberInput, defaultRolesSchema, invitationSchema, invitationStatus, memberSchema, organizationRoleSchema, organizationSchema, roleSchema, teamMemberSchema, teamSchema } from "../../plugins/organization/schema.mjs";
|
|
3
|
+
import { AdminOptions, InferAdminRolesFromOption, SessionWithImpersonatedBy, UserWithRole } from "../../plugins/admin/types.mjs";
|
|
4
|
+
import { ApiKey, ApiKeyOptions } from "../../plugins/api-key/types.mjs";
|
|
5
|
+
import { API_KEY_ERROR_CODES } from "../../plugins/api-key/error-codes.mjs";
|
|
6
|
+
import { GenericOAuthConfig, GenericOAuthOptions } from "../../plugins/generic-oauth/types.mjs";
|
|
7
|
+
import { Auth0Options, auth0 } from "../../plugins/generic-oauth/providers/auth0.mjs";
|
|
8
|
+
import { GumroadOptions, gumroad } from "../../plugins/generic-oauth/providers/gumroad.mjs";
|
|
9
|
+
import { HubSpotOptions, hubspot } from "../../plugins/generic-oauth/providers/hubspot.mjs";
|
|
10
|
+
import { KeycloakOptions, keycloak } from "../../plugins/generic-oauth/providers/keycloak.mjs";
|
|
11
|
+
import { LineOptions, line } from "../../plugins/generic-oauth/providers/line.mjs";
|
|
12
|
+
import { MicrosoftEntraIdOptions, microsoftEntraId } from "../../plugins/generic-oauth/providers/microsoft-entra-id.mjs";
|
|
13
|
+
import { OktaOptions, okta } from "../../plugins/generic-oauth/providers/okta.mjs";
|
|
14
|
+
import { PatreonOptions, patreon } from "../../plugins/generic-oauth/providers/patreon.mjs";
|
|
15
|
+
import { SlackOptions, slack } from "../../plugins/generic-oauth/providers/slack.mjs";
|
|
16
|
+
import { BaseOAuthProviderOptions } from "../../plugins/generic-oauth/index.mjs";
|
|
17
|
+
import { JWKOptions, JWSAlgorithms, Jwk, JwtOptions } from "../../plugins/jwt/types.mjs";
|
|
18
|
+
import { AuthorizationQuery, Client, CodeVerificationValue, OAuthAccessToken, OIDCMetadata, OIDCOptions, TokenBody } from "../../plugins/oidc-provider/types.mjs";
|
|
19
|
+
import { MULTI_SESSION_ERROR_CODES } from "../../plugins/multi-session/error-codes.mjs";
|
|
20
|
+
import { MultiSessionConfig } from "../../plugins/multi-session/index.mjs";
|
|
21
|
+
import { OneTimeTokenOptions } from "../../plugins/one-time-token/index.mjs";
|
|
22
|
+
import { PhoneNumberOptions, UserWithPhoneNumber } from "../../plugins/phone-number/types.mjs";
|
|
23
|
+
import { BackupCodeOptions, backupCode2fa, generateBackupCodes, getBackupCodes, verifyBackupCode } from "../../plugins/two-factor/backup-codes/index.mjs";
|
|
24
|
+
import { OTPOptions, otp2fa } from "../../plugins/two-factor/otp/index.mjs";
|
|
25
|
+
import { TOTPOptions, totp2fa } from "../../plugins/two-factor/totp/index.mjs";
|
|
26
|
+
import { TwoFactorOptions, TwoFactorProvider, TwoFactorTable, UserWithTwoFactor } from "../../plugins/two-factor/types.mjs";
|
|
27
|
+
import { TWO_FACTOR_ERROR_CODES } from "../../plugins/two-factor/error-code.mjs";
|
|
28
|
+
import { twoFactorClient } from "../../plugins/two-factor/client.mjs";
|
|
29
|
+
import { USERNAME_ERROR_CODES } from "../../plugins/username/error-codes.mjs";
|
|
30
|
+
import { ORGANIZATION_ERROR_CODES } from "../../plugins/organization/error-codes.mjs";
|
|
31
|
+
import { inferAdditionalFields } from "../../plugins/additional-fields/client.mjs";
|
|
32
|
+
import { ADMIN_ERROR_CODES } from "../../plugins/admin/error-codes.mjs";
|
|
33
|
+
import { adminClient } from "../../plugins/admin/client.mjs";
|
|
34
|
+
import { ApiKeyClientPlugin, apiKeyClient } from "../../plugins/api-key/client.mjs";
|
|
35
|
+
import { customSessionClient } from "../../plugins/custom-session/client.mjs";
|
|
36
|
+
import { deviceAuthorizationClient } from "../../plugins/device-authorization/client.mjs";
|
|
37
|
+
import { EMAIL_OTP_ERROR_CODES } from "../../plugins/email-otp/error-codes.mjs";
|
|
38
|
+
import { emailOTPClient } from "../../plugins/email-otp/client.mjs";
|
|
39
|
+
import { GENERIC_OAUTH_ERROR_CODES } from "../../plugins/generic-oauth/error-codes.mjs";
|
|
40
|
+
import { genericOAuthClient } from "../../plugins/generic-oauth/client.mjs";
|
|
41
|
+
import { jwtClient } from "../../plugins/jwt/client.mjs";
|
|
42
|
+
import { LastLoginMethodClientConfig, lastLoginMethodClient } from "../../plugins/last-login-method/client.mjs";
|
|
43
|
+
import { magicLinkClient } from "../../plugins/magic-link/client.mjs";
|
|
44
|
+
import { multiSessionClient } from "../../plugins/multi-session/client.mjs";
|
|
45
|
+
import { OidcClientPlugin, oidcClient } from "../../plugins/oidc-provider/client.mjs";
|
|
46
|
+
import { GoogleOneTapActionOptions, GoogleOneTapOptions, GsiButtonConfiguration, oneTapClient } from "../../plugins/one-tap/client.mjs";
|
|
47
|
+
import { oneTimeTokenClient } from "../../plugins/one-time-token/client.mjs";
|
|
48
|
+
import { clientSideHasPermission, inferOrgAdditionalFields, organizationClient } from "../../plugins/organization/client.mjs";
|
|
49
|
+
import { PHONE_NUMBER_ERROR_CODES } from "../../plugins/phone-number/error-codes.mjs";
|
|
50
|
+
import { phoneNumberClient } from "../../plugins/phone-number/client.mjs";
|
|
51
|
+
import { usernameClient } from "../../plugins/username/client.mjs";
|
|
52
|
+
import { InferServerPlugin } from "./infer-plugin.mjs";
|
|
53
|
+
export { ADMIN_ERROR_CODES, API_KEY_ERROR_CODES, AdminOptions, ApiKey, ApiKeyClientPlugin, ApiKeyOptions, Auth0Options, AuthorizationQuery, BackupCodeOptions, BaseOAuthProviderOptions, Client, CodeVerificationValue, EMAIL_OTP_ERROR_CODES, GENERIC_OAUTH_ERROR_CODES, GenericOAuthConfig, GenericOAuthOptions, GoogleOneTapActionOptions, GoogleOneTapOptions, GsiButtonConfiguration, GumroadOptions, HasRequiredKeys, HubSpotOptions, InferAdminRolesFromOption, InferInvitation, InferMember, InferOrganization, InferOrganizationRolesFromOption, InferOrganizationZodRolesFromOption, InferServerPlugin, InferTeam, Invitation, InvitationInput, InvitationStatus, JWKOptions, JWSAlgorithms, Jwk, JwtOptions, KeycloakOptions, LastLoginMethodClientConfig, LineOptions, MULTI_SESSION_ERROR_CODES, Member, MemberInput, MicrosoftEntraIdOptions, MultiSessionConfig, OAuthAccessToken, OIDCMetadata, OIDCOptions, ORGANIZATION_ERROR_CODES, OTPOptions, OidcClientPlugin, OktaOptions, OneTimeTokenOptions, Organization, OrganizationInput, OrganizationRole, OrganizationSchema, PHONE_NUMBER_ERROR_CODES, PatreonOptions, PhoneNumberOptions, Prettify, PrettifyDeep, RequiredKeysOf, SessionWithImpersonatedBy, SlackOptions, StripEmptyObjects, TOTPOptions, TWO_FACTOR_ERROR_CODES, Team, TeamInput, TeamMember, TeamMemberInput, TokenBody, TwoFactorOptions, TwoFactorProvider, TwoFactorTable, USERNAME_ERROR_CODES, UnionToIntersection, UserWithPhoneNumber, UserWithRole, UserWithTwoFactor, adminClient, apiKeyClient, auth0, backupCode2fa, clientSideHasPermission, customSessionClient, defaultRolesSchema, deviceAuthorizationClient, emailOTPClient, generateBackupCodes, genericOAuthClient, getBackupCodes, gumroad, hubspot, inferAdditionalFields, inferOrgAdditionalFields, invitationSchema, invitationStatus, jwtClient, keycloak, lastLoginMethodClient, line, magicLinkClient, memberSchema, microsoftEntraId, multiSessionClient, oidcClient, okta, oneTapClient, oneTimeTokenClient, organizationClient, organizationRoleSchema, organizationSchema, otp2fa, patreon, phoneNumberClient, roleSchema, slack, teamMemberSchema, teamSchema, totp2fa, twoFactorClient, usernameClient, verifyBackupCode };
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { inferAdditionalFields } from "../../plugins/additional-fields/client.mjs";
|
|
2
|
+
import { ADMIN_ERROR_CODES } from "../../plugins/admin/error-codes.mjs";
|
|
3
|
+
import { adminClient } from "../../plugins/admin/client.mjs";
|
|
4
|
+
import { API_KEY_ERROR_CODES } from "../../plugins/api-key/error-codes.mjs";
|
|
5
|
+
import { apiKeyClient } from "../../plugins/api-key/client.mjs";
|
|
6
|
+
import { customSessionClient } from "../../plugins/custom-session/client.mjs";
|
|
7
|
+
import { deviceAuthorizationClient } from "../../plugins/device-authorization/client.mjs";
|
|
8
|
+
import { EMAIL_OTP_ERROR_CODES } from "../../plugins/email-otp/error-codes.mjs";
|
|
9
|
+
import { emailOTPClient } from "../../plugins/email-otp/client.mjs";
|
|
10
|
+
import { GENERIC_OAUTH_ERROR_CODES } from "../../plugins/generic-oauth/error-codes.mjs";
|
|
11
|
+
import { genericOAuthClient } from "../../plugins/generic-oauth/client.mjs";
|
|
12
|
+
import { jwtClient } from "../../plugins/jwt/client.mjs";
|
|
13
|
+
import { lastLoginMethodClient } from "../../plugins/last-login-method/client.mjs";
|
|
14
|
+
import { magicLinkClient } from "../../plugins/magic-link/client.mjs";
|
|
15
|
+
import { MULTI_SESSION_ERROR_CODES } from "../../plugins/multi-session/error-codes.mjs";
|
|
16
|
+
import { multiSessionClient } from "../../plugins/multi-session/client.mjs";
|
|
17
|
+
import { oidcClient } from "../../plugins/oidc-provider/client.mjs";
|
|
18
|
+
import { oneTapClient } from "../../plugins/one-tap/client.mjs";
|
|
19
|
+
import { oneTimeTokenClient } from "../../plugins/one-time-token/client.mjs";
|
|
20
|
+
import { ORGANIZATION_ERROR_CODES } from "../../plugins/organization/error-codes.mjs";
|
|
21
|
+
import { clientSideHasPermission, inferOrgAdditionalFields, organizationClient } from "../../plugins/organization/client.mjs";
|
|
22
|
+
import { PHONE_NUMBER_ERROR_CODES } from "../../plugins/phone-number/error-codes.mjs";
|
|
23
|
+
import { phoneNumberClient } from "../../plugins/phone-number/client.mjs";
|
|
24
|
+
import { TWO_FACTOR_ERROR_CODES } from "../../plugins/two-factor/error-code.mjs";
|
|
25
|
+
import { twoFactorClient } from "../../plugins/two-factor/client.mjs";
|
|
26
|
+
import { USERNAME_ERROR_CODES } from "../../plugins/username/error-codes.mjs";
|
|
27
|
+
import { usernameClient } from "../../plugins/username/client.mjs";
|
|
28
|
+
import { InferServerPlugin } from "./infer-plugin.mjs";
|
|
29
|
+
|
|
30
|
+
export { ADMIN_ERROR_CODES, API_KEY_ERROR_CODES, EMAIL_OTP_ERROR_CODES, GENERIC_OAUTH_ERROR_CODES, InferServerPlugin, MULTI_SESSION_ERROR_CODES, ORGANIZATION_ERROR_CODES, PHONE_NUMBER_ERROR_CODES, TWO_FACTOR_ERROR_CODES, USERNAME_ERROR_CODES, adminClient, apiKeyClient, clientSideHasPermission, customSessionClient, deviceAuthorizationClient, emailOTPClient, genericOAuthClient, inferAdditionalFields, inferOrgAdditionalFields, jwtClient, lastLoginMethodClient, magicLinkClient, multiSessionClient, oidcClient, oneTapClient, oneTimeTokenClient, organizationClient, phoneNumberClient, twoFactorClient, usernameClient };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BetterAuthOptions } from "@better-auth/core";
|
|
2
|
+
|
|
3
|
+
//#region src/client/plugins/infer-plugin.d.ts
|
|
4
|
+
declare const InferServerPlugin: <AuthOrOption extends BetterAuthOptions | {
|
|
5
|
+
options: BetterAuthOptions;
|
|
6
|
+
}, ID extends string>() => {
|
|
7
|
+
id: "infer-server-plugin";
|
|
8
|
+
$InferServerPlugin: (AuthOrOption extends {
|
|
9
|
+
options: infer O;
|
|
10
|
+
} ? O : AuthOrOption)["plugins"] extends (infer P)[] ? P extends {
|
|
11
|
+
id: ID;
|
|
12
|
+
} ? P : never : never;
|
|
13
|
+
};
|
|
14
|
+
//#endregion
|
|
15
|
+
export { InferServerPlugin };
|
|
16
|
+
//# sourceMappingURL=infer-plugin.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"infer-plugin.mjs","names":[],"sources":["../../../src/client/plugins/infer-plugin.ts"],"sourcesContent":["import type {\n\tBetterAuthClientPlugin,\n\tBetterAuthOptions,\n} from \"@better-auth/core\";\n\nexport const InferServerPlugin = <\n\tAuthOrOption extends\n\t\t| BetterAuthOptions\n\t\t| {\n\t\t\t\toptions: BetterAuthOptions;\n\t\t },\n\tID extends string,\n>() => {\n\ttype Option = AuthOrOption extends { options: infer O } ? O : AuthOrOption;\n\ttype Plugin =\n\t\tOption[\"plugins\"] extends Array<infer P>\n\t\t\t? P extends {\n\t\t\t\t\tid: ID;\n\t\t\t\t}\n\t\t\t\t? P\n\t\t\t\t: never\n\t\t\t: never;\n\treturn {\n\t\tid: \"infer-server-plugin\",\n\t\t$InferServerPlugin: {} as Plugin,\n\t} satisfies BetterAuthClientPlugin;\n};\n"],"mappings":";AAKA,MAAa,0BAON;AAUN,QAAO;EACN,IAAI;EACJ,oBAAoB,EAAE;EACtB"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { isAtom } from "../utils/is-atom.mjs";
|
|
2
|
+
|
|
3
|
+
//#region src/client/proxy.ts
|
|
4
|
+
function getMethod(path, knownPathMethods, args) {
|
|
5
|
+
const method = knownPathMethods[path];
|
|
6
|
+
const { fetchOptions, query: _query, ...body } = args || {};
|
|
7
|
+
if (method) return method;
|
|
8
|
+
if (fetchOptions?.method) return fetchOptions.method;
|
|
9
|
+
if (body && Object.keys(body).length > 0) return "POST";
|
|
10
|
+
return "GET";
|
|
11
|
+
}
|
|
12
|
+
function createDynamicPathProxy(routes, client, knownPathMethods, atoms, atomListeners) {
|
|
13
|
+
function createProxy(path = []) {
|
|
14
|
+
return new Proxy(function() {}, {
|
|
15
|
+
get(_, prop) {
|
|
16
|
+
if (typeof prop !== "string") return;
|
|
17
|
+
if (prop === "then" || prop === "catch" || prop === "finally") return;
|
|
18
|
+
const fullPath = [...path, prop];
|
|
19
|
+
let current = routes;
|
|
20
|
+
for (const segment of fullPath) if (current && typeof current === "object" && segment in current) current = current[segment];
|
|
21
|
+
else {
|
|
22
|
+
current = void 0;
|
|
23
|
+
break;
|
|
24
|
+
}
|
|
25
|
+
if (typeof current === "function") return current;
|
|
26
|
+
if (isAtom(current)) return current;
|
|
27
|
+
return createProxy(fullPath);
|
|
28
|
+
},
|
|
29
|
+
apply: async (_, __, args) => {
|
|
30
|
+
const routePath = "/" + path.map((segment) => segment.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`)).join("/");
|
|
31
|
+
const arg = args[0] || {};
|
|
32
|
+
const fetchOptions = args[1] || {};
|
|
33
|
+
const { query, fetchOptions: argFetchOptions, ...body } = arg;
|
|
34
|
+
const options = {
|
|
35
|
+
...fetchOptions,
|
|
36
|
+
...argFetchOptions
|
|
37
|
+
};
|
|
38
|
+
const method = getMethod(routePath, knownPathMethods, arg);
|
|
39
|
+
return await client(routePath, {
|
|
40
|
+
...options,
|
|
41
|
+
body: method === "GET" ? void 0 : {
|
|
42
|
+
...body,
|
|
43
|
+
...options?.body || {}
|
|
44
|
+
},
|
|
45
|
+
query: query || options?.query,
|
|
46
|
+
method,
|
|
47
|
+
async onSuccess(context) {
|
|
48
|
+
await options?.onSuccess?.(context);
|
|
49
|
+
if (!atomListeners || options.disableSignal) return;
|
|
50
|
+
/**
|
|
51
|
+
* We trigger listeners
|
|
52
|
+
*/
|
|
53
|
+
const matches = atomListeners.filter((s) => s.matcher(routePath));
|
|
54
|
+
if (!matches.length) return;
|
|
55
|
+
const visited = /* @__PURE__ */ new Set();
|
|
56
|
+
for (const match of matches) {
|
|
57
|
+
const signal = atoms[match.signal];
|
|
58
|
+
if (!signal) return;
|
|
59
|
+
if (visited.has(match.signal)) continue;
|
|
60
|
+
visited.add(match.signal);
|
|
61
|
+
/**
|
|
62
|
+
* To avoid race conditions we set the signal in a setTimeout
|
|
63
|
+
*/
|
|
64
|
+
const val = signal.get();
|
|
65
|
+
setTimeout(() => {
|
|
66
|
+
signal.set(!val);
|
|
67
|
+
}, 10);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
return createProxy();
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
//#endregion
|
|
78
|
+
export { createDynamicPathProxy };
|
|
79
|
+
//# sourceMappingURL=proxy.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy.mjs","names":[],"sources":["../../src/client/proxy.ts"],"sourcesContent":["import type {\n\tBetterAuthClientPlugin,\n\tClientAtomListener,\n\tClientFetchOption,\n} from \"@better-auth/core\";\nimport type { BetterFetch } from \"@better-fetch/fetch\";\nimport type { Atom } from \"nanostores\";\nimport { isAtom } from \"../utils/is-atom\";\nimport type { ProxyRequest } from \"./path-to-object\";\n\nfunction getMethod(\n\tpath: string,\n\tknownPathMethods: Record<string, \"POST\" | \"GET\">,\n\targs:\n\t\t| {\n\t\t\t\tfetchOptions?: ClientFetchOption | undefined;\n\t\t\t\tquery?: Record<string, any> | undefined;\n\t\t }\n\t\t| undefined,\n) {\n\tconst method = knownPathMethods[path];\n\tconst { fetchOptions, query: _query, ...body } = args || {};\n\tif (method) {\n\t\treturn method;\n\t}\n\tif (fetchOptions?.method) {\n\t\treturn fetchOptions.method;\n\t}\n\tif (body && Object.keys(body).length > 0) {\n\t\treturn \"POST\";\n\t}\n\treturn \"GET\";\n}\n\nexport function createDynamicPathProxy<T extends Record<string, any>>(\n\troutes: T,\n\tclient: BetterFetch,\n\tknownPathMethods: Record<string, \"POST\" | \"GET\">,\n\tatoms: Record<string, Atom>,\n\tatomListeners: BetterAuthClientPlugin[\"atomListeners\"],\n): T {\n\tfunction createProxy(path: string[] = []): any {\n\t\treturn new Proxy(function () {}, {\n\t\t\tget(_, prop) {\n\t\t\t\tif (typeof prop !== \"string\") {\n\t\t\t\t\treturn undefined;\n\t\t\t\t}\n\t\t\t\tif (prop === \"then\" || prop === \"catch\" || prop === \"finally\") {\n\t\t\t\t\treturn undefined;\n\t\t\t\t}\n\t\t\t\tconst fullPath = [...path, prop];\n\t\t\t\tlet current: any = routes;\n\t\t\t\tfor (const segment of fullPath) {\n\t\t\t\t\tif (current && typeof current === \"object\" && segment in current) {\n\t\t\t\t\t\tcurrent = current[segment];\n\t\t\t\t\t} else {\n\t\t\t\t\t\tcurrent = undefined;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (typeof current === \"function\") {\n\t\t\t\t\treturn current;\n\t\t\t\t}\n\t\t\t\tif (isAtom(current)) {\n\t\t\t\t\treturn current;\n\t\t\t\t}\n\t\t\t\treturn createProxy(fullPath);\n\t\t\t},\n\t\t\tapply: async (_, __, args) => {\n\t\t\t\tconst routePath =\n\t\t\t\t\t\"/\" +\n\t\t\t\t\tpath\n\t\t\t\t\t\t.map((segment) =>\n\t\t\t\t\t\t\tsegment.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`),\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.join(\"/\");\n\t\t\t\tconst arg = (args[0] || {}) as ProxyRequest;\n\t\t\t\tconst fetchOptions = (args[1] || {}) as ClientFetchOption;\n\t\t\t\tconst { query, fetchOptions: argFetchOptions, ...body } = arg;\n\t\t\t\tconst options = {\n\t\t\t\t\t...fetchOptions,\n\t\t\t\t\t...argFetchOptions,\n\t\t\t\t} as ClientFetchOption;\n\t\t\t\tconst method = getMethod(routePath, knownPathMethods, arg);\n\t\t\t\treturn await client(routePath, {\n\t\t\t\t\t...options,\n\t\t\t\t\tbody:\n\t\t\t\t\t\tmethod === \"GET\"\n\t\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t\t: {\n\t\t\t\t\t\t\t\t\t...body,\n\t\t\t\t\t\t\t\t\t...(options?.body || {}),\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\tquery: query || options?.query,\n\t\t\t\t\tmethod,\n\t\t\t\t\tasync onSuccess(context) {\n\t\t\t\t\t\tawait options?.onSuccess?.(context);\n\t\t\t\t\t\tif (!atomListeners || options.disableSignal) return;\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * We trigger listeners\n\t\t\t\t\t\t */\n\t\t\t\t\t\tconst matches = atomListeners.filter((s) => s.matcher(routePath));\n\t\t\t\t\t\tif (!matches.length) return;\n\n\t\t\t\t\t\tconst visited = new Set<ClientAtomListener[\"signal\"]>();\n\t\t\t\t\t\tfor (const match of matches) {\n\t\t\t\t\t\t\tconst signal = atoms[match.signal as any];\n\t\t\t\t\t\t\tif (!signal) return;\n\t\t\t\t\t\t\tif (visited.has(match.signal)) {\n\t\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tvisited.add(match.signal);\n\t\t\t\t\t\t\t/**\n\t\t\t\t\t\t\t * To avoid race conditions we set the signal in a setTimeout\n\t\t\t\t\t\t\t */\n\t\t\t\t\t\t\tconst val = signal.get();\n\t\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\t\t//@ts-expect-error\n\t\t\t\t\t\t\t\tsignal.set(!val);\n\t\t\t\t\t\t\t}, 10);\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t});\n\t\t\t},\n\t\t});\n\t}\n\treturn createProxy() as T;\n}\n"],"mappings":";;;AAUA,SAAS,UACR,MACA,kBACA,MAMC;CACD,MAAM,SAAS,iBAAiB;CAChC,MAAM,EAAE,cAAc,OAAO,QAAQ,GAAG,SAAS,QAAQ,EAAE;AAC3D,KAAI,OACH,QAAO;AAER,KAAI,cAAc,OACjB,QAAO,aAAa;AAErB,KAAI,QAAQ,OAAO,KAAK,KAAK,CAAC,SAAS,EACtC,QAAO;AAER,QAAO;;AAGR,SAAgB,uBACf,QACA,QACA,kBACA,OACA,eACI;CACJ,SAAS,YAAY,OAAiB,EAAE,EAAO;AAC9C,SAAO,IAAI,MAAM,WAAY,IAAI;GAChC,IAAI,GAAG,MAAM;AACZ,QAAI,OAAO,SAAS,SACnB;AAED,QAAI,SAAS,UAAU,SAAS,WAAW,SAAS,UACnD;IAED,MAAM,WAAW,CAAC,GAAG,MAAM,KAAK;IAChC,IAAI,UAAe;AACnB,SAAK,MAAM,WAAW,SACrB,KAAI,WAAW,OAAO,YAAY,YAAY,WAAW,QACxD,WAAU,QAAQ;SACZ;AACN,eAAU;AACV;;AAGF,QAAI,OAAO,YAAY,WACtB,QAAO;AAER,QAAI,OAAO,QAAQ,CAClB,QAAO;AAER,WAAO,YAAY,SAAS;;GAE7B,OAAO,OAAO,GAAG,IAAI,SAAS;IAC7B,MAAM,YACL,MACA,KACE,KAAK,YACL,QAAQ,QAAQ,WAAW,WAAW,IAAI,OAAO,aAAa,GAAG,CACjE,CACA,KAAK,IAAI;IACZ,MAAM,MAAO,KAAK,MAAM,EAAE;IAC1B,MAAM,eAAgB,KAAK,MAAM,EAAE;IACnC,MAAM,EAAE,OAAO,cAAc,iBAAiB,GAAG,SAAS;IAC1D,MAAM,UAAU;KACf,GAAG;KACH,GAAG;KACH;IACD,MAAM,SAAS,UAAU,WAAW,kBAAkB,IAAI;AAC1D,WAAO,MAAM,OAAO,WAAW;KAC9B,GAAG;KACH,MACC,WAAW,QACR,SACA;MACA,GAAG;MACH,GAAI,SAAS,QAAQ,EAAE;MACvB;KACJ,OAAO,SAAS,SAAS;KACzB;KACA,MAAM,UAAU,SAAS;AACxB,YAAM,SAAS,YAAY,QAAQ;AACnC,UAAI,CAAC,iBAAiB,QAAQ,cAAe;;;;MAI7C,MAAM,UAAU,cAAc,QAAQ,MAAM,EAAE,QAAQ,UAAU,CAAC;AACjE,UAAI,CAAC,QAAQ,OAAQ;MAErB,MAAM,0BAAU,IAAI,KAAmC;AACvD,WAAK,MAAM,SAAS,SAAS;OAC5B,MAAM,SAAS,MAAM,MAAM;AAC3B,WAAI,CAAC,OAAQ;AACb,WAAI,QAAQ,IAAI,MAAM,OAAO,CAC5B;AAED,eAAQ,IAAI,MAAM,OAAO;;;;OAIzB,MAAM,MAAM,OAAO,KAAK;AACxB,wBAAiB;AAEhB,eAAO,IAAI,CAAC,IAAI;UACd,GAAG;;;KAGR,CAAC;;GAEH,CAAC;;AAEH,QAAO,aAAa"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { SessionQueryParams } from "./types.mjs";
|
|
2
|
+
import { ClientFetchOption } from "@better-auth/core";
|
|
3
|
+
import { PreinitializedWritableAtom } from "nanostores";
|
|
4
|
+
import { BetterFetch, BetterFetchError } from "@better-fetch/fetch";
|
|
5
|
+
|
|
6
|
+
//#region src/client/query.d.ts
|
|
7
|
+
type AuthQueryAtom<T> = PreinitializedWritableAtom<{
|
|
8
|
+
data: null | T;
|
|
9
|
+
error: null | BetterFetchError;
|
|
10
|
+
isPending: boolean;
|
|
11
|
+
isRefetching: boolean;
|
|
12
|
+
refetch: (queryParams?: {
|
|
13
|
+
query?: SessionQueryParams;
|
|
14
|
+
} | undefined) => Promise<void>;
|
|
15
|
+
}>;
|
|
16
|
+
declare const useAuthQuery: <T>(initializedAtom: PreinitializedWritableAtom<any> | PreinitializedWritableAtom<any>[], path: string, $fetch: BetterFetch, options?: (((value: {
|
|
17
|
+
data: null | T;
|
|
18
|
+
error: null | BetterFetchError;
|
|
19
|
+
isPending: boolean;
|
|
20
|
+
}) => ClientFetchOption) | ClientFetchOption) | undefined) => AuthQueryAtom<T>;
|
|
21
|
+
//#endregion
|
|
22
|
+
export { AuthQueryAtom, useAuthQuery };
|
|
23
|
+
//# sourceMappingURL=query.d.mts.map
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { atom, onMount } from "nanostores";
|
|
2
|
+
|
|
3
|
+
//#region src/client/query.ts
|
|
4
|
+
const isServer = () => typeof window === "undefined";
|
|
5
|
+
const useAuthQuery = (initializedAtom, path, $fetch, options) => {
|
|
6
|
+
const value = atom({
|
|
7
|
+
data: null,
|
|
8
|
+
error: null,
|
|
9
|
+
isPending: true,
|
|
10
|
+
isRefetching: false,
|
|
11
|
+
refetch: (queryParams) => fn(queryParams)
|
|
12
|
+
});
|
|
13
|
+
const fn = async (queryParams) => {
|
|
14
|
+
return new Promise((resolve) => {
|
|
15
|
+
const opts = typeof options === "function" ? options({
|
|
16
|
+
data: value.get().data,
|
|
17
|
+
error: value.get().error,
|
|
18
|
+
isPending: value.get().isPending
|
|
19
|
+
}) : options;
|
|
20
|
+
$fetch(path, {
|
|
21
|
+
...opts,
|
|
22
|
+
query: {
|
|
23
|
+
...opts?.query,
|
|
24
|
+
...queryParams?.query
|
|
25
|
+
},
|
|
26
|
+
async onSuccess(context) {
|
|
27
|
+
value.set({
|
|
28
|
+
data: context.data,
|
|
29
|
+
error: null,
|
|
30
|
+
isPending: false,
|
|
31
|
+
isRefetching: false,
|
|
32
|
+
refetch: value.value.refetch
|
|
33
|
+
});
|
|
34
|
+
await opts?.onSuccess?.(context);
|
|
35
|
+
},
|
|
36
|
+
async onError(context) {
|
|
37
|
+
const { request } = context;
|
|
38
|
+
const retryAttempts = typeof request.retry === "number" ? request.retry : request.retry?.attempts;
|
|
39
|
+
const retryAttempt = request.retryAttempt || 0;
|
|
40
|
+
if (retryAttempts && retryAttempt < retryAttempts) return;
|
|
41
|
+
value.set({
|
|
42
|
+
error: context.error,
|
|
43
|
+
data: null,
|
|
44
|
+
isPending: false,
|
|
45
|
+
isRefetching: false,
|
|
46
|
+
refetch: value.value.refetch
|
|
47
|
+
});
|
|
48
|
+
await opts?.onError?.(context);
|
|
49
|
+
},
|
|
50
|
+
async onRequest(context) {
|
|
51
|
+
const currentValue = value.get();
|
|
52
|
+
value.set({
|
|
53
|
+
isPending: currentValue.data === null,
|
|
54
|
+
data: currentValue.data,
|
|
55
|
+
error: null,
|
|
56
|
+
isRefetching: true,
|
|
57
|
+
refetch: value.value.refetch
|
|
58
|
+
});
|
|
59
|
+
await opts?.onRequest?.(context);
|
|
60
|
+
}
|
|
61
|
+
}).catch((error) => {
|
|
62
|
+
value.set({
|
|
63
|
+
error,
|
|
64
|
+
data: null,
|
|
65
|
+
isPending: false,
|
|
66
|
+
isRefetching: false,
|
|
67
|
+
refetch: value.value.refetch
|
|
68
|
+
});
|
|
69
|
+
}).finally(() => {
|
|
70
|
+
resolve(void 0);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
};
|
|
74
|
+
initializedAtom = Array.isArray(initializedAtom) ? initializedAtom : [initializedAtom];
|
|
75
|
+
let isMounted = false;
|
|
76
|
+
for (const initAtom of initializedAtom) initAtom.subscribe(async () => {
|
|
77
|
+
if (isServer()) return;
|
|
78
|
+
if (isMounted) await fn();
|
|
79
|
+
else onMount(value, () => {
|
|
80
|
+
const timeoutId = setTimeout(async () => {
|
|
81
|
+
if (!isMounted) {
|
|
82
|
+
await fn();
|
|
83
|
+
isMounted = true;
|
|
84
|
+
}
|
|
85
|
+
}, 0);
|
|
86
|
+
return () => {
|
|
87
|
+
value.off();
|
|
88
|
+
initAtom.off();
|
|
89
|
+
clearTimeout(timeoutId);
|
|
90
|
+
};
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
return value;
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
//#endregion
|
|
97
|
+
export { useAuthQuery };
|
|
98
|
+
//# sourceMappingURL=query.mjs.map
|