Commit 81188c8
committed
Fix OAuth token exchange 500 error for MCP clients
The token endpoint handler consumed the request body via request.text()
to check for the `resource` parameter, but only reconstructed the
Request when `resource` was missing. When MCP clients (e.g. Claude Code)
sent `resource` in the token exchange, the body was consumed but never
rebuilt, causing Better Auth to receive an empty body and return 500.
Always reconstruct the request after reading the body. Also adds
consent page redirect URL fallback and DB migration for new OAuth
columns (require_pkce, auth_time).1 parent 2b5a106 commit 81188c8
6 files changed
Lines changed: 7185 additions & 2 deletions
File tree
- apps/web/src/routes
- api/auth
- oauth
- packages/db
- drizzle
- meta
- src/schema
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
43 | 43 | | |
44 | 44 | | |
45 | 45 | | |
46 | | - | |
47 | 46 | | |
| 47 | + | |
| 48 | + | |
48 | 49 | | |
49 | 50 | | |
50 | 51 | | |
| |||
54 | 55 | | |
55 | 56 | | |
56 | 57 | | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
57 | 80 | | |
58 | 81 | | |
59 | 82 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
121 | 121 | | |
122 | 122 | | |
123 | 123 | | |
124 | | - | |
| 124 | + | |
125 | 125 | | |
126 | 126 | | |
127 | 127 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
0 commit comments