Commit Graph

58 Commits

Author SHA1 Message Date
Alex Yang
1668a33372 fix: /minimal includes unexpected deps (#7467) 2026-01-19 20:32:29 +00:00
dependabot[bot]
8f6c46d91f chore(deps): bump hono from 4.11.3 to 4.11.4 (#7343)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2026-01-13 15:25:45 -08:00
Alex Yang
47b9aa90da chore: update cloudflare fixture (#7293) 2026-01-12 09:03:52 -08:00
Alex Yang
4c897d19d2 chore: bump dev deps (#7287) 2026-01-12 03:36:24 -08:00
Paola Estefanía de Campos
e8aa51c052 feat: support form data for email sign-in/sign-up and fallback to checking fetch Metadata for first login (#6314)
Co-authored-by: Taesu <166604494+bytaesu@users.noreply.github.com>
Co-authored-by: Bereket Engida <86073083+Bekacru@users.noreply.github.com>
Co-authored-by: Jonathan Samines <jn.samines@gmail.com>
2025-12-25 11:05:23 -08:00
Dylan Vanmali
686fba4e11 feat(oauth-provider): an oauth 2.1 compliant plugin (#4163)
An upgrade to oidc-provider plugin that makes it oauth2.1 compliant and has a configuration that is secure by default.

Plans for the deprecation of oidc-provider plugin due to many inherent flaws in its design. Internally, plugin functions now share logic, providing for better future extensibility if new code_grants need to be written or user/client jwt or opaque tokens need to be written. Furthermore, as an oAuth 2.1 provider, it provides logic valid for an MCP server. When using the scope "openid" (optional, enabled by default), the server acts like an OpenId server able to issue id tokens and provides a /userinfo endpoint.

Features

OAuth 2.1 by default
Properly supports authorization_code, refresh_token, and client_credentials grants
PKCE by default (removes plain completely)
Public and confidential client registration
JWT plugin is required by default, but can be disabled using disableJWTPlugin flag
Access tokens can now be received in JWT verifiable format using the resource parameter (ie JWT aud field)
Id tokens are still verifiable by JWKS when using JWT Plugin, or clientSecret if disabled. Fixes issue to prevent public clients when disableJWTPlugin: true from obtaining id tokens directly even when they shouldn't be allowed an id token and should use /userinfo instead.
Protects /userinfo with scope check
Separates Refresh Token and Access token on database schema to allow multiple access tokens per refresh and multiple refresh tokens per login session.
oauthAccessToken strictly deals with opaque tokens
Opaque tokens are given only when resource parameter (aka audience) is not provided
Option to Encode and Decode refresh tokens
allowDynamicClientRegistration with allowUnauthenticatedClientRegistration flags
Separation of default expiration times
Proper creation of public and confidential clients
Prevents misconfiguration between .well-known/openid-configuration endpoint and plugin settings
scopeExpirations to assign scopes specific expiration
Custom claims through separated functions: customAccessTokenClaims, customIdTokenClaims, and customUserInfoClaims
Organizational support through activeOrganizationalId on a session such as through the organizational plugin. Attaches to oAuthClient via reference_id.
Rp-initiated logout
Account Selection via prompt=select_account.
Account Creation via prompt=create.
Prompt combinations prompt=select_account+consent and prompt=login+consent

Docs available at https://www.better-auth.com/docs/plugins/oauth-provider (pr: https://github.com/better-auth/better-auth/blob/main/docs/content/docs/plugins/oauth-provider.mdx)
2025-12-22 11:16:42 -08:00
Alex Yang
cbd215f6ac fix: export necessary adapter types (#6903) 2025-12-20 16:33:13 +08:00
Alex Yang
a96e907b7d test: ensure no unexpected output for cloudflare worker (#6704)
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-12-14 14:47:01 +09:00
Alex Yang
c79b6e3aae chore: bump devDependencies (#6562) 2025-12-06 18:44:23 +09:00
Maxwell
2fc58d664f fix(oidc): compatibility with exact-optional-property (#6502) 2025-12-03 20:52:26 -08:00
Jonathan Samines
fbe51c8f93 chore: add spell checker (#6319) 2025-12-01 10:33:38 -08:00
Alex Yang
2edee431cc chore(deps): update dependencies in package.json and pnpm-workspace.yaml (#6255) 2025-11-24 09:26:58 -08:00
Stephen Zhou
0c6787506d chore: fix package depends on itself (#6189) 2025-11-22 07:49:07 -08:00
Taisei Mima
c4579f4745 chore(deps): bump stripe v20 (#6162) 2025-11-21 16:48:04 +00:00
Jonathan Samines
57ee11a26f chore(lint): enforce consistent import type style (#6044) 2025-11-17 21:11:39 +00:00
Alex Yang
6c9fe209e2 chore: bump vitest (#6012) 2025-11-15 23:28:56 +00:00
Alex Yang
0f7580366c pref: infinite tsc compilation time (#5893) 2025-11-11 01:21:03 +00:00
Alex Yang
34cf292058 chore: remove e2e smoke for cloudflare 2025-11-10 16:03:45 -08:00
Alex Yang
3a2dcd4c83 chore(e2e): type fix (#5845) 2025-11-08 01:53:41 +00:00
Alex Yang
7caa2752ed feat(client): add type helper AuthClient (#5815) 2025-11-07 05:07:17 +00:00
Taesu
f327e336c8 refactor: split the passkey plugin into a separate package (#5769) 2025-11-05 17:05:39 +00:00
Alex Yang
7b65ddd02c test: add type test for organization plugin (#5581) 2025-10-29 21:41:10 +00:00
Alex Yang
15bc3c9b10 chore(organization): fix client side import server side code (#5631) 2025-10-28 01:40:19 +00:00
Alex Yang
938c2a7c31 chore: lint enable organize import (#5556) 2025-10-24 19:05:09 +00:00
Alex Yang
d958d1cf58 test: username type infer (#5434) 2025-10-20 19:42:51 +00:00
ocavue
2dfc12e61f test: check typecheck test status (#5421) 2025-10-20 16:03:56 +00:00
Alex Yang
4b5f637bf0 fix(organization): typecheck node exceeds the maximum length (#5372)
Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>
2025-10-17 03:08:55 +00:00
Alex Yang
a31bbafb34 test: add type check cases (#5367) 2025-10-16 21:47:39 +00:00
Alex Yang
5561ba75a5 chore: bump better-call (#5348) 2025-10-16 10:48:17 +00:00
Alex Yang
b4a7ea6296 fix(organization): compatibility with exactOptionalPropertyTypes (#5337) 2025-10-15 23:46:03 +00:00
Alex Yang
19f5c1409f fix(organization): compatibility with declaration on tsconfig.json (#5334)
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2025-10-15 20:08:26 +00:00
Alex Yang
af03d5fc69 fix(username): compacity with exactOptionalPropertyTypes (#5313) 2025-10-15 00:11:08 +00:00
Alex Yang
2e62296432 e2e: add coverage for additional fields (#5286) 2025-10-13 23:17:34 +00:00
KinfeMichael Tariku
f27231cf8d fix: type compatibility with exactOptionalPropertyTypes (#5236)
Co-authored-by: Alex Yang <himself65@outlook.com>
2025-10-13 21:36:38 +00:00
Alex Yang
5c878f5c83 chore: update fixture package name (#5281) 2025-10-13 19:05:39 +00:00
Alex Yang
fe01f5ef11 chore: use tsdown as bundler (#5249) 2025-10-13 17:35:33 +00:00
Alex Yang
3e013eea62 test: add bundle entry for server code (#5199) 2025-10-10 00:43:11 +00:00
Alex Yang
e6d82a83fe test: add assertions to check for unwanted imports in built output (#5123) 2025-10-06 09:32:36 -07:00
Bereket Engida
9818fb85ec chore: misc update 2025-09-29 18:02:21 -07:00
Alex Yang
f191291eac e2e: add postgres-js migration test (#4867) 2025-09-24 21:15:40 +00:00
Alex Yang
cd84ef5c8b e2e: add vite client build (#4643) 2025-09-23 23:07:50 +00:00
Alex Yang
dda554553e fix(api-key): calling client on server side (#4777) 2025-09-19 22:54:11 +00:00
Alex Yang
6ea2357653 chore: bump dev deps (#4678) 2025-09-15 19:34:59 +00:00
dependabot[bot]
7537dbb074 chore(deps): bump hono from 4.9.6 to 4.9.7 (#4619)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-12 23:13:50 +00:00
Alex Yang
22b78cfe72 Revert "feat: support cross-domain cookie (#4482)"
This reverts commit 61b6a87435.
2025-09-12 00:34:01 -07:00
Henrique Braga
61b6a87435 feat: support cross-domain cookie (#4482)
Co-authored-by: Alex Yang <himself65@outlook.com>
Co-authored-by: Rikhi Singh <114336052+rikhisingh@users.noreply.github.com>
2025-09-09 17:09:24 -07:00
Alex Yang
a22f65fdc3 chore: bump version (#4535) 2025-09-08 18:30:44 -07:00
Alex Yang
6353e3da02 e2e: integration test for solid-js (#4469)
Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>
2025-09-08 16:49:01 -07:00
Alex Yang
14ad4347c0 fix: cloudflare build warning with node:sqlite (#4415) 2025-09-03 19:15:24 -07:00
Alex Yang
efdb4ce4f0 chore: enable noFloatingPromises lint rule (#3842) 2025-09-03 15:02:45 -07:00