@revealui/auth 0.0.1-pre.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/LICENSE +202 -0
- package/dist/better-auth/adapter/__tests__/transform.test.js +213 -0
- package/dist/better-auth/adapter/__tests__/transform.test.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/biome.d.js +2 -0
- package/dist/better-auth/adapter/generate-schema/biome.d.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/generate-schema-builder.d.ts +5 -0
- package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js +482 -0
- package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/get-payload-schema.d.ts +1 -0
- package/dist/better-auth/adapter/generate-schema/get-payload-schema.js +42 -0
- package/dist/better-auth/adapter/generate-schema/get-payload-schema.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/index.d.ts +4 -0
- package/dist/better-auth/adapter/generate-schema/index.js +19 -0
- package/dist/better-auth/adapter/generate-schema/index.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/utils.d.ts +2 -0
- package/dist/better-auth/adapter/generate-schema/utils.js +20 -0
- package/dist/better-auth/adapter/generate-schema/utils.js.map +1 -0
- package/dist/better-auth/adapter/index.d.ts +15 -0
- package/dist/better-auth/adapter/index.js +731 -0
- package/dist/better-auth/adapter/index.js.map +1 -0
- package/dist/better-auth/adapter/tests/adapter.test.js +174 -0
- package/dist/better-auth/adapter/tests/adapter.test.js.map +1 -0
- package/dist/better-auth/adapter/tests/base-collections-tests.js +575 -0
- package/dist/better-auth/adapter/tests/base-collections-tests.js.map +1 -0
- package/dist/better-auth/adapter/tests/dev/index.js +117 -0
- package/dist/better-auth/adapter/tests/dev/index.js.map +1 -0
- package/dist/better-auth/adapter/tests/dev/migrate.js +26 -0
- package/dist/better-auth/adapter/tests/dev/migrate.js.map +1 -0
- package/dist/better-auth/adapter/tests/dev/migrations/20250423_232936_init.js +218 -0
- package/dist/better-auth/adapter/tests/dev/migrations/20250423_232936_init.js.map +1 -0
- package/dist/better-auth/adapter/tests/dev/schema.js +160 -0
- package/dist/better-auth/adapter/tests/dev/schema.js.map +1 -0
- package/dist/better-auth/adapter/tests/plugins-tests.js +2 -0
- package/dist/better-auth/adapter/tests/plugins-tests.js.map +1 -0
- package/dist/better-auth/adapter/transform/index.d.ts +27 -0
- package/dist/better-auth/adapter/transform/index.js +664 -0
- package/dist/better-auth/adapter/transform/index.js.map +1 -0
- package/dist/better-auth/adapter/types.d.ts +10 -0
- package/dist/better-auth/adapter/types.js +3 -0
- package/dist/better-auth/adapter/types.js.map +1 -0
- package/dist/better-auth/generated-types.d.ts +285 -0
- package/dist/better-auth/index.d.ts +3 -0
- package/dist/better-auth/index.js +5 -0
- package/dist/better-auth/index.js.map +1 -0
- package/dist/better-auth/plugin/__tests__/plugin.test.js +162 -0
- package/dist/better-auth/plugin/__tests__/plugin.test.js.map +1 -0
- package/dist/better-auth/plugin/constants.d.ts +220 -0
- package/dist/better-auth/plugin/constants.js +249 -0
- package/dist/better-auth/plugin/constants.js.map +1 -0
- package/dist/better-auth/plugin/helpers/check-plugin-exists.d.ts +12 -0
- package/dist/better-auth/plugin/helpers/check-plugin-exists.js +14 -0
- package/dist/better-auth/plugin/helpers/check-plugin-exists.js.map +1 -0
- package/dist/better-auth/plugin/helpers/generate-verify-email-url.d.ts +29 -0
- package/dist/better-auth/plugin/helpers/generate-verify-email-url.js +46 -0
- package/dist/better-auth/plugin/helpers/generate-verify-email-url.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-admin-access.d.ts +7 -0
- package/dist/better-auth/plugin/helpers/get-admin-access.js +22 -0
- package/dist/better-auth/plugin/helpers/get-admin-access.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-all-roles.d.ts +5 -0
- package/dist/better-auth/plugin/helpers/get-all-roles.js +20 -0
- package/dist/better-auth/plugin/helpers/get-all-roles.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts +18 -0
- package/dist/better-auth/plugin/helpers/get-better-auth-schema.js +70 -0
- package/dist/better-auth/plugin/helpers/get-better-auth-schema.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-collection-slug.d.ts +5 -0
- package/dist/better-auth/plugin/helpers/get-collection-slug.js +20 -0
- package/dist/better-auth/plugin/helpers/get-collection-slug.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-collection.d.ts +15 -0
- package/dist/better-auth/plugin/helpers/get-collection.js +29 -0
- package/dist/better-auth/plugin/helpers/get-collection.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-ip.d.ts +2 -0
- package/dist/better-auth/plugin/helpers/get-ip.js +31 -0
- package/dist/better-auth/plugin/helpers/get-ip.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-signed-cookie.d.ts +2 -0
- package/dist/better-auth/plugin/helpers/get-signed-cookie.js +65 -0
- package/dist/better-auth/plugin/helpers/get-signed-cookie.js.map +1 -0
- package/dist/better-auth/plugin/helpers/index.d.ts +1 -0
- package/dist/better-auth/plugin/helpers/index.js +3 -0
- package/dist/better-auth/plugin/helpers/index.js.map +1 -0
- package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +59 -0
- package/dist/better-auth/plugin/helpers/prepare-session-data.js +49 -0
- package/dist/better-auth/plugin/helpers/prepare-session-data.js.map +1 -0
- package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.d.ts +20 -0
- package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.js +67 -0
- package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.js.map +1 -0
- package/dist/better-auth/plugin/index.d.ts +11 -0
- package/dist/better-auth/plugin/index.js +125 -0
- package/dist/better-auth/plugin/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.d.ts +12 -0
- package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.js +87 -0
- package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js +60 -0
- package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/accounts/index.js +154 -0
- package/dist/better-auth/plugin/lib/build-collections/accounts/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.d.ts +5 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.js +11 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.d.ts +2 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.js +8 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.d.ts +6 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.js +119 -0
- package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/api-keys.js +177 -0
- package/dist/better-auth/plugin/lib/build-collections/api-keys.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/device-code.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/device-code.js +50 -0
- package/dist/better-auth/plugin/lib/build-collections/device-code.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/index.d.ts +10 -0
- package/dist/better-auth/plugin/lib/build-collections/index.js +73 -0
- package/dist/better-auth/plugin/lib/build-collections/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/invitations.js +94 -0
- package/dist/better-auth/plugin/lib/build-collections/invitations.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/jwks.js +59 -0
- package/dist/better-auth/plugin/lib/build-collections/jwks.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/members.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/members.js +73 -0
- package/dist/better-auth/plugin/lib/build-collections/members.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js +107 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js +118 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js +89 -0
- package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/organizations.js +70 -0
- package/dist/better-auth/plugin/lib/build-collections/organizations.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/passkeys.js +115 -0
- package/dist/better-auth/plugin/lib/build-collections/passkeys.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/sessions.js +170 -0
- package/dist/better-auth/plugin/lib/build-collections/sessions.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/sso-providers.js +81 -0
- package/dist/better-auth/plugin/lib/build-collections/sso-providers.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/subscriptions.js +111 -0
- package/dist/better-auth/plugin/lib/build-collections/subscriptions.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/team-members.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/team-members.js +57 -0
- package/dist/better-auth/plugin/lib/build-collections/team-members.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/teams.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/teams.js +76 -0
- package/dist/better-auth/plugin/lib/build-collections/teams.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/two-factors.js +67 -0
- package/dist/better-auth/plugin/lib/build-collections/two-factors.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts +7 -0
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +53 -0
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.d.ts +11 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.js +75 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts +4 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js +6 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.d.ts +2 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.js +115 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.js +64 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js +80 -0
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts +6 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +79 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts +2 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js +82 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts +2 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js +54 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.d.ts +6 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.js +15 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.d.ts +6 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.js +8 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.d.ts +2 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.js +17 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts +2 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js +91 -0
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/users/index.js +341 -0
- package/dist/better-auth/plugin/lib/build-collections/users/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts +15 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js +24 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-duplicate-fields.d.ts +10 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-duplicate-fields.js +67 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-duplicate-fields.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.d.ts +9 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.js +94 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.d.ts +7 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.js +35 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts +12 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js +25 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.d.ts +14 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.js +67 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts +20 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js +98 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts +3 -0
- package/dist/better-auth/plugin/lib/build-collections/verifications.js +87 -0
- package/dist/better-auth/plugin/lib/build-collections/verifications.js.map +1 -0
- package/dist/better-auth/plugin/lib/get-payload-auth.d.ts +5 -0
- package/dist/better-auth/plugin/lib/get-payload-auth.js +9 -0
- package/dist/better-auth/plugin/lib/get-payload-auth.js.map +1 -0
- package/dist/better-auth/plugin/lib/init-better-auth.d.ts +7 -0
- package/dist/better-auth/plugin/lib/init-better-auth.js +46 -0
- package/dist/better-auth/plugin/lib/init-better-auth.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js +9 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js +10 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.js +8 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts +10 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +156 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js +18 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js +34 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js +11 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js +10 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts +2 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js +11 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.d.ts +7 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.js +23 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.d.ts +25 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.js +62 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts +9 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js +47 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +15 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +42 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.d.ts +9 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.js +63 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.js.map +1 -0
- package/dist/better-auth/plugin/lib/set-login-methods.d.ts +4 -0
- package/dist/better-auth/plugin/lib/set-login-methods.js +14 -0
- package/dist/better-auth/plugin/lib/set-login-methods.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons/index.d.ts +9 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons/index.js +143 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.d.ts +10 -0
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.js +219 -0
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/logout-button.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/logout-button.js +24 -0
- package/dist/better-auth/plugin/payload/components/logout-button.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts +8 -0
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +117 -0
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts +3 -0
- package/dist/better-auth/plugin/payload/components/passkeys/client.js +66 -0
- package/dist/better-auth/plugin/payload/components/passkeys/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.js +52 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts +8 -0
- package/dist/better-auth/plugin/payload/components/passkeys/list.js +57 -0
- package/dist/better-auth/plugin/payload/components/passkeys/list.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts +22 -0
- package/dist/better-auth/plugin/payload/components/passkeys/types.js +3 -0
- package/dist/better-auth/plugin/payload/components/passkeys/types.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/rsc-redirect.d.ts +6 -0
- package/dist/better-auth/plugin/payload/components/rsc-redirect.js +7 -0
- package/dist/better-auth/plugin/payload/components/rsc-redirect.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.d.ts +15 -0
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.js +157 -0
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/token-field.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/token-field.js +31 -0
- package/dist/better-auth/plugin/payload/components/token-field.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts +8 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js +300 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/exports/client.d.ts +6 -0
- package/dist/better-auth/plugin/payload/exports/client.js +8 -0
- package/dist/better-auth/plugin/payload/exports/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/exports/rsc.d.ts +8 -0
- package/dist/better-auth/plugin/payload/exports/rsc.js +10 -0
- package/dist/better-auth/plugin/payload/exports/rsc.js.map +1 -0
- package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.d.ts +2 -0
- package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.js +9 -0
- package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.js.map +1 -0
- package/dist/better-auth/plugin/payload/utils/get-safe-redirect.d.ts +1 -0
- package/dist/better-auth/plugin/payload/utils/get-safe-redirect.js +22 -0
- package/dist/better-auth/plugin/payload/utils/get-safe-redirect.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +19 -0
- package/dist/better-auth/plugin/payload/views/admin-login/client.js +226 -0
- package/dist/better-auth/plugin/payload/views/admin-login/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts +10 -0
- package/dist/better-auth/plugin/payload/views/admin-login/index.js +150 -0
- package/dist/better-auth/plugin/payload/views/admin-login/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts +16 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/client.js +299 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts +9 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/index.js +104 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/forgot-password/client.d.ts +7 -0
- package/dist/better-auth/plugin/payload/views/forgot-password/client.js +119 -0
- package/dist/better-auth/plugin/payload/views/forgot-password/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/forgot-password/index.d.ts +8 -0
- package/dist/better-auth/plugin/payload/views/forgot-password/index.js +78 -0
- package/dist/better-auth/plugin/payload/views/forgot-password/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/reset-password/client.d.ts +10 -0
- package/dist/better-auth/plugin/payload/views/reset-password/client.js +144 -0
- package/dist/better-auth/plugin/payload/views/reset-password/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/reset-password/index.d.ts +8 -0
- package/dist/better-auth/plugin/payload/views/reset-password/index.js +96 -0
- package/dist/better-auth/plugin/payload/views/reset-password/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts +6 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js +96 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +9 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +56 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js.map +1 -0
- package/dist/better-auth/plugin/types.d.ts +429 -0
- package/dist/better-auth/plugin/types.js +3 -0
- package/dist/better-auth/plugin/types.js.map +1 -0
- package/dist/better-auth/plugin/utils/set.d.ts +39 -0
- package/dist/better-auth/plugin/utils/set.js +103 -0
- package/dist/better-auth/plugin/utils/set.js.map +1 -0
- package/dist/better-auth/scripts/generate-types.d.ts +1 -0
- package/dist/better-auth/scripts/generate-types.js +234 -0
- package/dist/better-auth/scripts/generate-types.js.map +1 -0
- package/dist/better-auth/types.d.ts +2 -0
- package/dist/better-auth/types.js +4 -0
- package/dist/better-auth/types.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/shared/components/icons.d.ts +7 -0
- package/dist/shared/components/icons.js +442 -0
- package/dist/shared/components/icons.js.map +1 -0
- package/dist/shared/components/logo.d.ts +3 -0
- package/dist/shared/components/logo.js +24 -0
- package/dist/shared/components/logo.js.map +1 -0
- package/dist/shared/form/components/submit.d.ts +7 -0
- package/dist/shared/form/components/submit.js +16 -0
- package/dist/shared/form/components/submit.js.map +1 -0
- package/dist/shared/form/fields/text-field.d.ts +8 -0
- package/dist/shared/form/fields/text-field.js +37 -0
- package/dist/shared/form/fields/text-field.js.map +1 -0
- package/dist/shared/form/index.d.ts +4 -0
- package/dist/shared/form/index.js +8 -0
- package/dist/shared/form/index.js.map +1 -0
- package/dist/shared/form/ui/header/index.d.ts +8 -0
- package/dist/shared/form/ui/header/index.js +24 -0
- package/dist/shared/form/ui/header/index.js.map +1 -0
- package/dist/shared/form/ui/index.d.ts +31 -0
- package/dist/shared/form/ui/index.js +57 -0
- package/dist/shared/form/ui/index.js.map +1 -0
- package/dist/shared/form/validation.d.ts +51 -0
- package/dist/shared/form/validation.js +127 -0
- package/dist/shared/form/validation.js.map +1 -0
- package/dist/shared/index.d.ts +2 -0
- package/dist/shared/index.js +4 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/payload/fields/field-copy-button/index.d.ts +3 -0
- package/dist/shared/payload/fields/field-copy-button/index.js +38 -0
- package/dist/shared/payload/fields/field-copy-button/index.js.map +1 -0
- package/dist/shared/payload/fields/generate-uuid-button/index.d.ts +3 -0
- package/dist/shared/payload/fields/generate-uuid-button/index.js +26 -0
- package/dist/shared/payload/fields/generate-uuid-button/index.js.map +1 -0
- package/dist/shared/payload/fields/index.d.ts +2 -0
- package/dist/shared/payload/fields/index.js +4 -0
- package/dist/shared/payload/fields/index.js.map +1 -0
- package/dist/shared/utils/regex.d.ts +2 -0
- package/dist/shared/utils/regex.js +4 -0
- package/dist/shared/utils/regex.js.map +1 -0
- package/dist/shared/utils/try-catch.d.ts +11 -0
- package/dist/shared/utils/try-catch.js +17 -0
- package/dist/shared/utils/try-catch.js.map +1 -0
- package/dist/shared/utils/value-or-default.d.ts +9 -0
- package/dist/shared/utils/value-or-default.js +12 -0
- package/dist/shared/utils/value-or-default.js.map +1 -0
- package/package.json +122 -0
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
import fs from "node:fs/promises";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { fileURLToPath } from "node:url";
|
|
4
|
+
// import { emailHarmony, phoneHarmony } from 'better-auth-harmony'
|
|
5
|
+
import { sso } from "@better-auth/sso";
|
|
6
|
+
import { stripe } from "@better-auth/stripe";
|
|
7
|
+
import { checkout, polar } from "@polar-sh/better-auth";
|
|
8
|
+
import { Polar } from "@polar-sh/sdk";
|
|
9
|
+
import { getSchema } from "better-auth/db";
|
|
10
|
+
import { nextCookies } from "better-auth/next-js";
|
|
11
|
+
import { admin, anonymous, apiKey, bearer, customSession, deviceAuthorization, emailOTP, genericOAuth, jwt, lastLoginMethod, magicLink, mcp, multiSession, oidcProvider, oneTap, oneTimeToken, openAPI, organization, phoneNumber, twoFactor, username } from "better-auth/plugins";
|
|
12
|
+
import Stripe from "stripe";
|
|
13
|
+
// Note: passkey may not be available in all better-auth versions
|
|
14
|
+
// Create a no-op function as fallback
|
|
15
|
+
const passkey = ()=>({
|
|
16
|
+
id: 'passkey'
|
|
17
|
+
});
|
|
18
|
+
const client = new Polar({
|
|
19
|
+
accessToken: 'pk_test_1234567890',
|
|
20
|
+
server: 'sandbox'
|
|
21
|
+
});
|
|
22
|
+
const plugins = [
|
|
23
|
+
username(),
|
|
24
|
+
admin(),
|
|
25
|
+
apiKey(),
|
|
26
|
+
passkey(),
|
|
27
|
+
// emailHarmony(),
|
|
28
|
+
// phoneHarmony(),
|
|
29
|
+
bearer(),
|
|
30
|
+
emailOTP({
|
|
31
|
+
sendVerificationOTP: async ()=>{}
|
|
32
|
+
}),
|
|
33
|
+
magicLink({
|
|
34
|
+
sendMagicLink: async ()=>{}
|
|
35
|
+
}),
|
|
36
|
+
phoneNumber({
|
|
37
|
+
sendOTP: async ()=>{}
|
|
38
|
+
}),
|
|
39
|
+
oneTap(),
|
|
40
|
+
anonymous(),
|
|
41
|
+
multiSession(),
|
|
42
|
+
oneTimeToken(),
|
|
43
|
+
oidcProvider({
|
|
44
|
+
loginPage: ''
|
|
45
|
+
}),
|
|
46
|
+
sso(),
|
|
47
|
+
genericOAuth({
|
|
48
|
+
config: [
|
|
49
|
+
{
|
|
50
|
+
providerId: 'typescript',
|
|
51
|
+
clientId: 'typescript',
|
|
52
|
+
clientSecret: 'typescript'
|
|
53
|
+
}
|
|
54
|
+
]
|
|
55
|
+
}),
|
|
56
|
+
openAPI(),
|
|
57
|
+
organization({
|
|
58
|
+
teams: {
|
|
59
|
+
enabled: true
|
|
60
|
+
}
|
|
61
|
+
}),
|
|
62
|
+
jwt(),
|
|
63
|
+
twoFactor(),
|
|
64
|
+
phoneNumber(),
|
|
65
|
+
nextCookies(),
|
|
66
|
+
customSession(async ()=>({})),
|
|
67
|
+
mcp({
|
|
68
|
+
loginPage: ''
|
|
69
|
+
}),
|
|
70
|
+
deviceAuthorization(),
|
|
71
|
+
lastLoginMethod({
|
|
72
|
+
storeInDatabase: true
|
|
73
|
+
}),
|
|
74
|
+
stripe({
|
|
75
|
+
stripeClient: new Stripe('typescript'),
|
|
76
|
+
stripeWebhookSecret: 'typescript',
|
|
77
|
+
subscription: {
|
|
78
|
+
enabled: true,
|
|
79
|
+
plans: [
|
|
80
|
+
{
|
|
81
|
+
name: 'Basic',
|
|
82
|
+
priceId: 'basic'
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
name: 'Pro',
|
|
86
|
+
priceId: 'pro'
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
name: 'Enterprise',
|
|
90
|
+
priceId: 'enterprise'
|
|
91
|
+
}
|
|
92
|
+
]
|
|
93
|
+
}
|
|
94
|
+
}),
|
|
95
|
+
// As of writing this, Polar don't create schema fields, but just in case in the future we leave this here.
|
|
96
|
+
polar({
|
|
97
|
+
client,
|
|
98
|
+
use: [
|
|
99
|
+
checkout({
|
|
100
|
+
products: [
|
|
101
|
+
{
|
|
102
|
+
productId: '123-456-789',
|
|
103
|
+
slug: 'pro'
|
|
104
|
+
}
|
|
105
|
+
],
|
|
106
|
+
successUrl: '/success?checkout_id={CHECKOUT_ID}',
|
|
107
|
+
authenticatedUsersOnly: true
|
|
108
|
+
})
|
|
109
|
+
]
|
|
110
|
+
})
|
|
111
|
+
];
|
|
112
|
+
// Using Record<string, unknown> because BetterAuth config structure varies by plugin configuration and cannot be strictly typed
|
|
113
|
+
const betterAuthConfig = {
|
|
114
|
+
emailAndPassword: {
|
|
115
|
+
enabled: true
|
|
116
|
+
},
|
|
117
|
+
user: {
|
|
118
|
+
additionalFields: {
|
|
119
|
+
role: {
|
|
120
|
+
type: 'string',
|
|
121
|
+
defaultValue: 'user',
|
|
122
|
+
input: false
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
},
|
|
126
|
+
plugins
|
|
127
|
+
};
|
|
128
|
+
const baseSchema = getSchema({
|
|
129
|
+
...betterAuthConfig,
|
|
130
|
+
plugins: []
|
|
131
|
+
});
|
|
132
|
+
const map = (t)=>{
|
|
133
|
+
if (t === 'boolean') return 'boolean';
|
|
134
|
+
if (t === 'date') return 'Date';
|
|
135
|
+
if (t === 'number') return 'number';
|
|
136
|
+
if (t === 'string') return 'string';
|
|
137
|
+
if (t === 'number[]') return 'number[]';
|
|
138
|
+
if (t === 'string[]') return 'string[]';
|
|
139
|
+
return 'unknown';
|
|
140
|
+
};
|
|
141
|
+
const pascal = (s)=>s.split(/[-_]/g).map((p)=>p.charAt(0).toUpperCase() + p.slice(1)).join('');
|
|
142
|
+
const diff = (base, target)=>{
|
|
143
|
+
const d = {};
|
|
144
|
+
for (const [m, { fields }] of Object.entries(target)){
|
|
145
|
+
const added = Object.entries(fields).filter(([k])=>!(k in (base[m]?.fields ?? {})));
|
|
146
|
+
if (added.length) d[m] = Object.fromEntries(added);
|
|
147
|
+
}
|
|
148
|
+
return d;
|
|
149
|
+
};
|
|
150
|
+
const gen = ()=>{
|
|
151
|
+
let out = '// Auto-generated types. Do not edit.\n\n';
|
|
152
|
+
const pluginAdds = {};
|
|
153
|
+
const seen = new Set();
|
|
154
|
+
for (const pl of plugins){
|
|
155
|
+
const id = pl.id;
|
|
156
|
+
if (!id || seen.has(id)) continue;
|
|
157
|
+
seen.add(id);
|
|
158
|
+
const adds = diff(baseSchema, getSchema({
|
|
159
|
+
...betterAuthConfig,
|
|
160
|
+
plugins: [
|
|
161
|
+
pl
|
|
162
|
+
]
|
|
163
|
+
}));
|
|
164
|
+
for (const [m, f] of Object.entries(adds)){
|
|
165
|
+
pluginAdds[m] ??= {};
|
|
166
|
+
pluginAdds[m][id] = f;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
const models = new Set([
|
|
170
|
+
...Object.keys(baseSchema),
|
|
171
|
+
...Object.keys(pluginAdds)
|
|
172
|
+
]);
|
|
173
|
+
for (const model of models){
|
|
174
|
+
const P = pascal(model);
|
|
175
|
+
const base = baseSchema[model]?.fields ?? {};
|
|
176
|
+
const pluginsForModel = pluginAdds[model] ?? {};
|
|
177
|
+
const pluginIds = Object.keys(pluginsForModel);
|
|
178
|
+
if (Object.keys(base).length) {
|
|
179
|
+
out += `export type Base${P}Fields = {\n`;
|
|
180
|
+
for (const [k, f] of Object.entries(base))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
|
|
181
|
+
out += '}\n\n';
|
|
182
|
+
}
|
|
183
|
+
const needPluginMap = pluginIds.length > 1 || Object.keys(base).length;
|
|
184
|
+
if (needPluginMap && pluginIds.length) {
|
|
185
|
+
out += `export type ${P}PluginFields = {\n`;
|
|
186
|
+
for (const [pid, flds] of Object.entries(pluginsForModel)){
|
|
187
|
+
out += ` ${JSON.stringify(pid)}: {\n`;
|
|
188
|
+
for (const [k, f] of Object.entries(flds))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
|
|
189
|
+
out += ' }\n';
|
|
190
|
+
}
|
|
191
|
+
out += '}\n\n';
|
|
192
|
+
}
|
|
193
|
+
if (!Object.keys(base).length && pluginIds.length === 1) {
|
|
194
|
+
const only = pluginIds[0];
|
|
195
|
+
if (!only) continue;
|
|
196
|
+
out += `export type ${P}Fields = {\n`;
|
|
197
|
+
for (const [k, f] of Object.entries(pluginsForModel[only] ?? {}))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
|
|
198
|
+
out += '}\n\n';
|
|
199
|
+
out += `export type ${P} = ${P}Fields\n\n`;
|
|
200
|
+
continue;
|
|
201
|
+
}
|
|
202
|
+
const parts = [];
|
|
203
|
+
if (Object.keys(base).length) parts.push(`Base${P}Fields`);
|
|
204
|
+
if (pluginIds.length) {
|
|
205
|
+
const mapName = needPluginMap ? `${P}PluginFields` : undefined;
|
|
206
|
+
parts.push(...pluginIds.map((id)=>mapName ? `${mapName}[${JSON.stringify(id)}]` : 'never'));
|
|
207
|
+
}
|
|
208
|
+
out += `export type ${P} = ${parts.join(' & ')}\n\n`;
|
|
209
|
+
}
|
|
210
|
+
// Generate union type of plugin identifiers
|
|
211
|
+
const pluginIdUnion = [
|
|
212
|
+
...seen
|
|
213
|
+
].map((id)=>JSON.stringify(id)).join(' | ');
|
|
214
|
+
out += `export type PluginId = ${pluginIdUnion}\n\n`;
|
|
215
|
+
// Generate full schema mapping
|
|
216
|
+
out += 'export type BetterAuthFullSchema = {\n';
|
|
217
|
+
for (const model of models){
|
|
218
|
+
const P = pascal(model);
|
|
219
|
+
out += ` ${JSON.stringify(model)}: ${P}\n`;
|
|
220
|
+
}
|
|
221
|
+
out += '}\n\n';
|
|
222
|
+
// Generate union type of all model names
|
|
223
|
+
out += 'export type ModelKey = keyof BetterAuthFullSchema';
|
|
224
|
+
return out;
|
|
225
|
+
};
|
|
226
|
+
const generated = gen();
|
|
227
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
228
|
+
(async ()=>{
|
|
229
|
+
const file = path.resolve(__dirname, '../generated-types.ts');
|
|
230
|
+
await fs.writeFile(file, generated, 'utf8');
|
|
231
|
+
console.log(`Generated types written to ${file}`);
|
|
232
|
+
})();
|
|
233
|
+
|
|
234
|
+
//# sourceMappingURL=generate-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/better-auth/scripts/generate-types.ts"],"sourcesContent":["import fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\n// import { emailHarmony, phoneHarmony } from 'better-auth-harmony'\nimport { sso } from '@better-auth/sso';\nimport { stripe } from '@better-auth/stripe';\nimport { checkout, polar } from '@polar-sh/better-auth';\nimport { Polar } from '@polar-sh/sdk';\nimport type { DBFieldAttribute } from 'better-auth/db';\nimport { getSchema } from 'better-auth/db';\nimport { nextCookies } from 'better-auth/next-js';\nimport {\n admin,\n anonymous,\n apiKey,\n bearer,\n customSession,\n deviceAuthorization,\n emailOTP,\n genericOAuth,\n jwt,\n lastLoginMethod,\n magicLink,\n mcp,\n multiSession,\n oidcProvider,\n oneTap,\n oneTimeToken,\n openAPI,\n organization,\n phoneNumber,\n twoFactor,\n username,\n} from 'better-auth/plugins';\nimport Stripe from 'stripe';\n\n// Note: passkey may not be available in all better-auth versions\n// Create a no-op function as fallback\nconst passkey = () => ({ id: 'passkey' });\n\nconst client = new Polar({\n accessToken: 'pk_test_1234567890',\n server: 'sandbox',\n});\n\nconst plugins = [\n username(),\n admin(),\n apiKey(),\n passkey(),\n // emailHarmony(),\n // phoneHarmony(),\n bearer(),\n emailOTP({ sendVerificationOTP: async () => {} }),\n magicLink({ sendMagicLink: async () => {} }),\n phoneNumber({ sendOTP: async () => {} }),\n oneTap(),\n anonymous(),\n multiSession(),\n oneTimeToken(),\n oidcProvider({ loginPage: '' }),\n sso(),\n genericOAuth({\n config: [{ providerId: 'typescript', clientId: 'typescript', clientSecret: 'typescript' }],\n }),\n openAPI(),\n organization({ teams: { enabled: true } }),\n jwt(),\n twoFactor(),\n phoneNumber(),\n nextCookies(),\n customSession(async () => ({})),\n mcp({ loginPage: '' }),\n deviceAuthorization(),\n lastLoginMethod({ storeInDatabase: true }),\n stripe({\n stripeClient: new Stripe('typescript'),\n stripeWebhookSecret: 'typescript',\n subscription: {\n enabled: true,\n plans: [\n {\n name: 'Basic',\n priceId: 'basic',\n },\n {\n name: 'Pro',\n priceId: 'pro',\n },\n {\n name: 'Enterprise',\n priceId: 'enterprise',\n },\n ],\n },\n }),\n // As of writing this, Polar don't create schema fields, but just in case in the future we leave this here.\n polar({\n client,\n use: [\n checkout({\n products: [\n {\n productId: '123-456-789', // ID of Product from Polar Dashboard\n slug: 'pro', // Custom slug for easy reference in Checkout URL, e.g. /checkout/pro\n },\n ],\n successUrl: '/success?checkout_id={CHECKOUT_ID}',\n authenticatedUsersOnly: true,\n }),\n ],\n }),\n];\n\n// Using Record<string, unknown> because BetterAuth config structure varies by plugin configuration and cannot be strictly typed\nconst betterAuthConfig: /* Using Record<string, unknown> because BetterAuth config structure varies by plugin configuration and cannot be strictly typed */ Record<\n string,\n unknown\n> = {\n emailAndPassword: { enabled: true },\n user: { additionalFields: { role: { type: 'string', defaultValue: 'user', input: false } } },\n plugins,\n};\n\nconst baseSchema = getSchema({ ...betterAuthConfig, plugins: [] });\n\ntype Schema = Record<string, { fields: Record<string, DBFieldAttribute> }>;\n\nconst map = (t: string): string => {\n if (t === 'boolean') return 'boolean';\n if (t === 'date') return 'Date';\n if (t === 'number') return 'number';\n if (t === 'string') return 'string';\n if (t === 'number[]') return 'number[]';\n if (t === 'string[]') return 'string[]';\n return 'unknown';\n};\n\nconst pascal = (s: string): string =>\n s\n .split(/[-_]/g)\n .map(p => p.charAt(0).toUpperCase() + p.slice(1))\n .join('');\n\nconst diff = (base: Schema, target: Schema): Record<string, Record<string, DBFieldAttribute>> => {\n const d: Record<string, Record<string, DBFieldAttribute>> = {};\n for (const [m, { fields }] of Object.entries(target)) {\n const added = Object.entries(fields).filter(([k]) => !(k in (base[m]?.fields ?? {})));\n if (added.length) d[m] = Object.fromEntries(added);\n }\n return d;\n};\n\nconst gen = (): string => {\n let out = '// Auto-generated types. Do not edit.\\n\\n';\n\n const pluginAdds: Record<string, Record<string, Record<string, DBFieldAttribute>>> = {};\n const seen = new Set<string>();\n\n for (const pl of plugins) {\n const id = (pl as { id?: string }).id;\n if (!id || seen.has(id)) continue;\n seen.add(id);\n const adds = diff(baseSchema, getSchema({ ...betterAuthConfig, plugins: [pl] }));\n for (const [m, f] of Object.entries(adds)) {\n pluginAdds[m] ??= {};\n pluginAdds[m][id] = f;\n }\n }\n\n const models = new Set<string>([...Object.keys(baseSchema), ...Object.keys(pluginAdds)]);\n\n for (const model of models) {\n const P = pascal(model);\n const base = baseSchema[model]?.fields ?? {};\n const pluginsForModel = pluginAdds[model] ?? {};\n const pluginIds = Object.keys(pluginsForModel);\n\n if (Object.keys(base).length) {\n out += `export type Base${P}Fields = {\\n`;\n for (const [k, f] of Object.entries(base))\n out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type as string)}\\n`;\n out += '}\\n\\n';\n }\n\n const needPluginMap = pluginIds.length > 1 || Object.keys(base).length;\n if (needPluginMap && pluginIds.length) {\n out += `export type ${P}PluginFields = {\\n`;\n for (const [pid, flds] of Object.entries(pluginsForModel)) {\n out += ` ${JSON.stringify(pid)}: {\\n`;\n for (const [k, f] of Object.entries(flds))\n out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type as string)}\\n`;\n out += ' }\\n';\n }\n out += '}\\n\\n';\n }\n\n if (!Object.keys(base).length && pluginIds.length === 1) {\n const only = pluginIds[0];\n if (!only) continue;\n out += `export type ${P}Fields = {\\n`;\n for (const [k, f] of Object.entries(pluginsForModel[only] ?? {}))\n out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type as string)}\\n`;\n out += '}\\n\\n';\n out += `export type ${P} = ${P}Fields\\n\\n`;\n continue;\n }\n\n const parts: string[] = [];\n if (Object.keys(base).length) parts.push(`Base${P}Fields`);\n if (pluginIds.length) {\n const mapName = needPluginMap ? `${P}PluginFields` : undefined;\n parts.push(\n ...pluginIds.map(\n id => (mapName ? `${mapName}[${JSON.stringify(id)}]` : 'never') /* not reachable */\n )\n );\n }\n out += `export type ${P} = ${parts.join(' & ')}\\n\\n`;\n }\n\n // Generate union type of plugin identifiers\n const pluginIdUnion = [...seen].map(id => JSON.stringify(id)).join(' | ');\n out += `export type PluginId = ${pluginIdUnion}\\n\\n`;\n\n // Generate full schema mapping\n out += 'export type BetterAuthFullSchema = {\\n';\n for (const model of models) {\n const P = pascal(model);\n out += ` ${JSON.stringify(model)}: ${P}\\n`;\n }\n out += '}\\n\\n';\n\n // Generate union type of all model names\n out += 'export type ModelKey = keyof BetterAuthFullSchema';\n\n return out;\n};\n\nconst generated = gen();\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n(async () => {\n const file = path.resolve(__dirname, '../generated-types.ts');\n await fs.writeFile(file, generated, 'utf8');\n\n console.log(`Generated types written to ${file}`);\n})();\n"],"names":["fs","path","fileURLToPath","sso","stripe","checkout","polar","Polar","getSchema","nextCookies","admin","anonymous","apiKey","bearer","customSession","deviceAuthorization","emailOTP","genericOAuth","jwt","lastLoginMethod","magicLink","mcp","multiSession","oidcProvider","oneTap","oneTimeToken","openAPI","organization","phoneNumber","twoFactor","username","Stripe","passkey","id","client","accessToken","server","plugins","sendVerificationOTP","sendMagicLink","sendOTP","loginPage","config","providerId","clientId","clientSecret","teams","enabled","storeInDatabase","stripeClient","stripeWebhookSecret","subscription","plans","name","priceId","use","products","productId","slug","successUrl","authenticatedUsersOnly","betterAuthConfig","emailAndPassword","user","additionalFields","role","type","defaultValue","input","baseSchema","map","t","pascal","s","split","p","charAt","toUpperCase","slice","join","diff","base","target","d","m","fields","Object","entries","added","filter","k","length","fromEntries","gen","out","pluginAdds","seen","Set","pl","has","add","adds","f","models","keys","model","P","pluginsForModel","pluginIds","fieldName","required","needPluginMap","pid","flds","JSON","stringify","only","parts","push","mapName","undefined","pluginIdUnion","generated","__dirname","dirname","url","file","resolve","writeFile","console","log"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/better-auth/types.ts"],"sourcesContent":["export * from './adapter/types';\nexport * from './plugin/types';\n"],"names":[],"mappings":"AAAA,cAAc,kBAAkB;AAChC,cAAc,iBAAiB"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './better-auth';
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["// These re-exports will be used by consumers of the library\nexport * from './better-auth';\n"],"names":[],"mappings":"AAAA,4DAA4D;AAC5D,cAAc,gBAAgB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type ComponentType, type SVGProps } from 'react';
|
|
2
|
+
export interface ProviderIconProps extends SVGProps<SVGSVGElement> {
|
|
3
|
+
className?: string;
|
|
4
|
+
variant?: 'default' | 'color';
|
|
5
|
+
}
|
|
6
|
+
export type ProviderIcon = ComponentType<ProviderIconProps>;
|
|
7
|
+
export declare const Icons: Record<string, ProviderIcon>;
|