-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathacc_change.py
137 lines (102 loc) · 4.5 KB
/
acc_change.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
from tkinter import *
from tkinter import ttk
import sqlite3
from tkinter import messagebox
import sys
import bcrypt
if len(sys.argv) > 1: #Ensure username is passed correctly from the command line arguments
username = sys.argv[1]
print(f"Username received: {username}")
else:
print("Error: No username provided")
sys.exit(1)
print("Username check passed")
acc_change = Tk()
acc_change.geometry("500x650")
acc_change.configure(bg="#99FF98")
acc_change.title("Account Info Page")
#PARAMETER-----------------------------------------------------------
font_30 = ("Gill Sans MT", 30, "bold")
font_20 = ("Gill Sans MT", 20)
font_15 = ("Gill Sans MT", 15)
#FUNCTIONS-----------------------------------------------------------
def edit():
conn = sqlite3.connect("database.db") #create / fetch database
c = conn.cursor() #create cursor
c.execute("SELECT * FROM userinfo WHERE username=?", (username,))
records = c.fetchone()
print("To be edited:", records)
#WE GOING GLOBAL YALL------------------------------------------------
global username_entry
global currpw_entry
global newpw_entry
global repassword_entry
#WIDGETS-------------------------------------------------------------
cabinet=Frame(acc_change, bg="#FFFFFF", padx=20, pady=20)
cabinet.pack(side="top", expand=True)
editor_title = Label(cabinet, text="EDIT ACCOUNT\nDETAILS", font=font_30, padx=0, pady=20, bg="#FFFFFF")
editor_title.grid(row=0, column=0, columnspan=2, sticky="ew")
username_label = Label(cabinet, text="Username", font=font_15, pady=5, bg="#FFFFFF")
username_label.grid(row=1, column=0, pady=5)
username_entry = Entry(cabinet, font=font_15, bg="#FFFFFF")
username_entry.grid(row=1, column=1)
currpw_label = Label(cabinet, text="Current Password", font=font_15, pady=5, bg="#FFFFFF")
currpw_label.grid(row=2, column=0, pady=5, padx=5)
currpw_entry = Entry(cabinet, show="•", font=font_15, bg="#FFFFFF")
currpw_entry.grid(row=2, column=1)
newpw_label = Label(cabinet, text="New Password", font=font_15, pady=5, bg="#FFFFFF")
newpw_label.grid(row=3, column=0, pady=5)
newpw_entry = Entry(cabinet, show="•", font=font_15, bg="#FFFFFF")
newpw_entry.grid(row=3, column=1)
repassword_label = Label(cabinet, text="Re-enter New\nPassword", font=font_15, pady=5, bg="#FFFFFF")
repassword_label.grid(row=4, column=0, pady=5)
repassword_entry = Entry(cabinet, show="•", font=font_15, bg="#FFFFFF")
repassword_entry.grid(row=4, column=1)
savebutton = Button(cabinet, text="Save Changes", font=font_15, bg="#FFFFFF", command=save)
savebutton.grid(row=5, column=0, columnspan=2, pady=(50,0))
#FILL IN THE BLANK----------------------------------------------------
#to loop through results
#placed after widget so it works
if records:
username_entry.insert(0, records[0])
def save():
newun = username_entry.get().strip()
currpw = currpw_entry.get().strip()
newpw = newpw_entry.get().strip()
repassword = repassword_entry.get().strip()
conn = sqlite3.connect("database.db") # create / fetch database
c = conn.cursor() # create cursor
c.execute("SELECT password FROM userinfo WHERE username=?", (username,))
user = c.fetchone()
if not user:
messagebox.showerror("Error", "User not found.")
return
hashedpw = user[0]
# Verify current password
if not bcrypt.checkpw(currpw.encode(), hashedpw.encode()):
messagebox.showerror("Error", "Incorrect current password.")
return
if len(newun) < 1:
messagebox.showerror("Error", "Username must be at least 1 character long.")
return
elif len(newpw) < 8:
messagebox.showerror("Error", "New password must be at least 8 characters long.")
return False
elif newpw != repassword:
messagebox.showerror("Error", " New passwords do not match.")
return False
try:
new_hashedpw = bcrypt.hashpw(newpw.encode(), bcrypt.gensalt()).decode()
c.execute("UPDATE userinfo SET password = ? WHERE username = ?", (new_hashedpw, username))
conn.commit()
messagebox.showinfo("Success", "Account details updated successfully!")
except sqlite3.Error as e:
messagebox.showerror("Database Error", f"An error occurred: {e}")
finally:
conn.close()
# Clear entry boxes
currpw_entry.delete(0, END)
newpw_entry.delete(0, END)
repassword_entry.delete(0, END)
edit()
acc_change.mainloop()