|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- #
- # Copyright 2024 The InfiniFlow Authors. All Rights Reserved.
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- #
-
- import base64
- import click
-
- from flask import Flask
- from werkzeug.security import generate_password_hash
-
- from api.db.services import UserService
-
-
- @click.command('reset-password', help='Reset the account password.')
- @click.option('--email', prompt=True, help='The email address of the account whose password you need to reset')
- @click.option('--new-password', prompt=True, help='the new password.')
- @click.option('--password-confirm', prompt=True, help='the new password confirm.')
- def reset_password(email, new_password, password_confirm):
- if str(new_password).strip() != str(password_confirm).strip():
- click.echo(click.style('sorry. The two passwords do not match.', fg='red'))
- return
- user = UserService.query(email=email)
- if not user:
- click.echo(click.style('sorry. The Email is not registered!.', fg='red'))
- return
- encode_password = base64.b64encode(new_password.encode('utf-8')).decode('utf-8')
- password_hash = generate_password_hash(encode_password)
- user_dict = {
- 'password': password_hash
- }
- UserService.update_user(user[0].id,user_dict)
- click.echo(click.style('Congratulations! Password has been reset.', fg='green'))
-
-
- def register_commands(app: Flask):
- app.cli.add_command(reset_password)
|