From 49a9c60605177e34fba4b1274d182acd087e43cf Mon Sep 17 00:00:00 2001 From: "Pawla Abdul (Bot)" Date: Sat, 4 Apr 2026 06:17:37 +0000 Subject: [PATCH] fix(api): add server_default to users.email_inbound_token Better-Auth creates users via raw SQL INSERT (not through SQLAlchemy), so it bypasses ORM defaults and causes HTTP 500 on sign-up/sign-in. Adds PostgreSQL server_default so INSERT without email_inbound_token auto-generates a URL-safe token matching Python secrets.token_urlsafe(16). Co-Authored-By: Paperclip --- .../006_email_inbound_token_server_default.py | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 alembic/versions/006_email_inbound_token_server_default.py diff --git a/alembic/versions/006_email_inbound_token_server_default.py b/alembic/versions/006_email_inbound_token_server_default.py new file mode 100644 index 0000000..ac1c678 --- /dev/null +++ b/alembic/versions/006_email_inbound_token_server_default.py @@ -0,0 +1,32 @@ +"""Add server_default to users.email_inbound_token. + +Revision ID: 006_email_inbound_token_server_default +Revises: 005_add_email_inbound_token +Create Date: 2026-04-04 +""" + +import sqlalchemy as sa +from alembic import op + +revision = "006_email_inbound_token_server_default" +down_revision = "005_add_email_inbound_token" +branch_labels = None +depends_on = None + + +def upgrade() -> None: + op.alter_column( + "users", + "email_inbound_token", + server_default=sa.text( + "replace(replace(trim(trailing '=' from encode(gen_random_bytes(16), 'base64')), '+', '-'), '/', '_')" + ), + ) + + +def downgrade() -> None: + op.alter_column( + "users", + "email_inbound_token", + server_default=None, + )