| 
                        123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 | 
                        - #
 - #  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
 - import re
 - 
 - 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'))
 - 
 - 
 - @click.command('reset-email', help='Reset the account email.')
 - @click.option('--email', prompt=True, help='The old email address of the account whose email you need to reset')
 - @click.option('--new-email', prompt=True, help='the new email.')
 - @click.option('--email-confirm', prompt=True, help='the new email confirm.')
 - def reset_email(email, new_email, email_confirm):
 -     if str(new_email).strip() != str(email_confirm).strip():
 -         click.echo(click.style('Sorry, new email and confirm email do not match.', fg='red'))
 -         return
 -     if str(new_email).strip() == str(email).strip():
 -         click.echo(click.style('Sorry, new email and old email are the same.', fg='red'))
 -         return
 -     user = UserService.query(email=email)
 -     if not user:
 -         click.echo(click.style('sorry. the account: [{}] not exist .'.format(email), fg='red'))
 -         return
 -     if not re.match(r"^[\w\._-]+@([\w_-]+\.)+[\w-]{2,4}$", new_email):
 -         click.echo(click.style('sorry. {} is not a valid email. '.format(new_email), fg='red'))
 -         return
 -     new_user = UserService.query(email=new_email)
 -     if new_user:
 -         click.echo(click.style('sorry. the account: [{}] is exist .'.format(new_email), fg='red'))
 -         return
 -     user_dict = {
 -         'email': new_email
 -     }
 -     UserService.update_user(user[0].id,user_dict)
 -     click.echo(click.style('Congratulations!, email has been reset.', fg='green'))
 - 
 - def register_commands(app: Flask):
 -     app.cli.add_command(reset_password)
 -     app.cli.add_command(reset_email)
 
 
  |