add confirmation_option when downgrade

This commit is contained in:
long2ice
2020-10-30 16:39:14 +08:00
parent 4e76f12ccf
commit 1bac33cd33
3 changed files with 14 additions and 2 deletions

BIN
.DS_Store vendored Normal file

Binary file not shown.

4
.vscode/settings.json vendored Normal file
View File

@@ -0,0 +1,4 @@
{
"python.pythonPath": "venv/bin/python",
"python.formatting.provider": "black"
}

View File

@@ -117,6 +117,11 @@ async def upgrade(ctx: Context):
click.secho("No migrate items", fg=Color.yellow) click.secho("No migrate items", fg=Color.yellow)
def abort_if_false(ctx, param, value):
if not value:
ctx.abort()
@cli.command(help="Downgrade to specified version.") @cli.command(help="Downgrade to specified version.")
@click.option( @click.option(
"-v", "-v",
@@ -127,6 +132,9 @@ async def upgrade(ctx: Context):
help="Specified version, default to last.", help="Specified version, default to last.",
) )
@click.pass_context @click.pass_context
@click.confirmation_option(
prompt="Downgrade is dangerous, which maybe lose your data, are you sure?",
)
@coro @coro
async def downgrade(ctx: Context, version: int): async def downgrade(ctx: Context, version: int):
app = ctx.obj["app"] app = ctx.obj["app"]
@@ -191,7 +199,7 @@ async def history(ctx: Context):
help="Tortoise-ORM config module dict variable, like settings.TORTOISE_ORM.", help="Tortoise-ORM config module dict variable, like settings.TORTOISE_ORM.",
) )
@click.option( @click.option(
"--location", default="./migrations", show_default=True, help="Migrate store location." "--location", default="./migrations", show_default=True, help="Migrate store location.",
) )
@click.pass_context @click.pass_context
@coro @coro
@@ -247,7 +255,7 @@ async def init_db(ctx: Context, safe):
version = await Migrate.generate_version() version = await Migrate.generate_version()
await Aerich.create( await Aerich.create(
version=version, app=app, content=Migrate.get_models_content(config, app, location) version=version, app=app, content=Migrate.get_models_content(config, app, location),
) )
with open(os.path.join(dirname, version), "w", encoding="utf-8") as f: with open(os.path.join(dirname, version), "w", encoding="utf-8") as f:
content = { content = {