From b709c91db8c45c547ad6824d12092b8ce2090303 Mon Sep 17 00:00:00 2001 From: shoucandanghehe Date: Tue, 22 Jul 2025 23:15:42 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=97=83=EF=B8=8F=20=E6=B7=BB=E5=8A=A0=20ve?= =?UTF-8?q?rify=20=E5=AD=97=E6=AE=B5=E5=88=B0=20Bind=20=E6=A8=A1=E5=9E=8B?= =?UTF-8?q?=EF=BC=8C=E5=B9=B6=E5=9C=A8=E5=88=9B=E5=BB=BA=E6=88=96=E6=9B=B4?= =?UTF-8?q?=E6=96=B0=E7=BB=91=E5=AE=9A=E6=97=B6=E6=94=AF=E6=8C=81=E8=AF=A5?= =?UTF-8?q?=E5=AD=97=E6=AE=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../2ff388a8c486_add_verify_field.py | 42 +++++++++++++++++++ nonebot_plugin_tetris_stats/db/__init__.py | 3 ++ nonebot_plugin_tetris_stats/db/models.py | 1 + 3 files changed, 46 insertions(+) create mode 100644 nonebot_plugin_tetris_stats/config/migrations/2ff388a8c486_add_verify_field.py diff --git a/nonebot_plugin_tetris_stats/config/migrations/2ff388a8c486_add_verify_field.py b/nonebot_plugin_tetris_stats/config/migrations/2ff388a8c486_add_verify_field.py new file mode 100644 index 0000000..3bd50bc --- /dev/null +++ b/nonebot_plugin_tetris_stats/config/migrations/2ff388a8c486_add_verify_field.py @@ -0,0 +1,42 @@ +"""add verify field + +迁移 ID: 2ff388a8c486 +父迁移: 3588702dd3a4 +创建时间: 2025-07-22 18:09:09.734164 + +""" + +from __future__ import annotations + +from typing import TYPE_CHECKING + +import sqlalchemy as sa +from alembic import op + +if TYPE_CHECKING: + from collections.abc import Sequence + +revision: str = '2ff388a8c486' +down_revision: str | Sequence[str] | None = '3588702dd3a4' +branch_labels: str | Sequence[str] | None = None +depends_on: str | Sequence[str] | None = None + + +def upgrade(name: str = '') -> None: + if name: + return + # ### commands auto generated by Alembic - please adjust! ### + with op.batch_alter_table('nb_t_bind', schema=None) as batch_op: + batch_op.add_column(sa.Column('verify', sa.Boolean(), nullable=False, server_default='false')) + + # ### end Alembic commands ### + + +def downgrade(name: str = '') -> None: + if name: + return + # ### commands auto generated by Alembic - please adjust! ### + with op.batch_alter_table('nb_t_bind', schema=None) as batch_op: + batch_op.drop_column('verify') + + # ### end Alembic commands ### diff --git a/nonebot_plugin_tetris_stats/db/__init__.py b/nonebot_plugin_tetris_stats/db/__init__.py index 2f56be9..d739b36 100644 --- a/nonebot_plugin_tetris_stats/db/__init__.py +++ b/nonebot_plugin_tetris_stats/db/__init__.py @@ -42,6 +42,8 @@ async def create_or_update_bind( user: User, game_platform: GameType, game_account: str, + *, + verify: bool = False, ) -> BindStatus: bind = await query_bind_info( session=session, @@ -53,6 +55,7 @@ async def create_or_update_bind( user_id=user.id, game_platform=game_platform, game_account=game_account, + verify=verify, ) session.add(bind) status = BindStatus.SUCCESS diff --git a/nonebot_plugin_tetris_stats/db/models.py b/nonebot_plugin_tetris_stats/db/models.py index 6e43b4c..40ff98e 100644 --- a/nonebot_plugin_tetris_stats/db/models.py +++ b/nonebot_plugin_tetris_stats/db/models.py @@ -71,6 +71,7 @@ class Bind(MappedAsDataclass, Model): user_id: Mapped[int] = mapped_column(index=True) game_platform: Mapped[GameType] = mapped_column(String(32)) game_account: Mapped[str] + verify: Mapped[bool] class TriggerHistoricalDataV2(MappedAsDataclass, Model):