23 @ns.route('/updatePassword')
24 class UpdatePassword(Resource):
25 new_password_model = UM.update_password_model(ns)
28 @ns.doc(
'/updatePassword',
29 description=
'Updates a users password when given new password and a exact duplicate of the new password.\n\nRequires valid JWT token authentication.',
32 400:
'Invalid Argument or faulty data',
33 500:
'Internal server error'
37 @ns.expect(new_password_model, validate=True)
41 @vt.require_valid_token
45 current_user = get_jwt_identity()
46 data = request.get_json()
48 new_pass1 = data[
'password1']
49 new_pass2 = data[
'password2']
52 return {
"Error":
"No data provided"}
55 return updatePassword(current_user[
'user_id'], current_user[
'email'], new_pass1, new_pass2)
58def updatePassword(user_id, email, new_password1, new_password2):
59 if not new_password1 == new_password2:
60 return {
"Password":
"Does not match."}, 400
63 hashed_password = hash.hash(new_password1)
66 connection = SQLC.SQLConAdmin()
68 connection.execute_query(SQLQ.SQLQueries.use_users_database())
69 connection.execute_query(SQLQ.SQLQueries.update_user_login_password(user_id, hashed_password))
70 connection.execute_query(SQLQ.SQLQueries.update_sql_user_password(email, hashed_password))
71 connection.execute_query(SQLQ.SQLQueries.flush_privileges())
72 connection.cnx.commit()
76 token_handler = TH.UserTokenHandler()
79 token_handler.logout()
81 return {
"Password":
"Updated!",
"New password":
"PROTECTED"}, 200