-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdb_manage.py
executable file
·102 lines (81 loc) · 2.68 KB
/
db_manage.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
#!/usr/bin/env python3
# -*- mode:python; coding:utf-8; -*-
# author: Kirill Zhukov <[email protected]>
# created: 2022-10-21
"""
Database management script
"""
import sys
import getpass
from sign.db.helpers import (db_create, db_drop,
create_user,update_password,
delete_user, user_exists)
DEV_USER_EMAIL = '[email protected]'
DEV_USER_PASSWORD = 'test'
def print_and_exit(msg: str, exit_code: int = 0):
print(msg)
sys.exit(exit_code)
def user_add():
email = input("email:")
if len(email) == 0:
print_and_exit("ERROR username is not set", 1)
p1 = getpass.getpass("password:")
if len(p1) == 0:
print_and_exit("ERROR: password is not set", 1)
p2 = getpass.getpass("password (repeat):")
if p1 != p2:
print_and_exit("ERROR: passwords don`t match", 1)
uid = create_user(email, p1)
print(f"user {email} was created (uid: {uid})")
def user_reset_pass():
email = input("email:")
if len(email) == 0:
print_and_exit("ERROR username is not set", 1)
p1 = getpass.getpass("password:")
if len(p1) == 0:
print_and_exit("ERROR: password is not set", 1)
p2 = getpass.getpass("password (repeat):")
if p1 != p2:
print("ERROR: passwords don`t match")
sys.exit(0)
update_password(email, p1)
def user_delete():
email = input("email: ")
if len(email) == 0:
print_and_exit("ERROR username is not set", 1)
delete_user(email)
def dev_init():
print('initializing db for development')
db_create()
if not user_exists(DEV_USER_EMAIL):
create_user('[email protected]', 'test')
print('development user was created: login:[email protected] password:test')
cmds = {
'create': {'func': db_create, 'descr': 'creates database tables'},
'drop': {'func': db_drop, 'descr': 'drops database tables'},
'user_add': {'func': user_add, 'descr': 'creates new user'},
'user_reset_pass': {'func': user_reset_pass, 'descr': 'update user`s password'},
'user_delete': {'func': user_delete, 'descr': 'delete user'},
'dev_init': {'func': dev_init, 'descr':'creating development database with test user'}
}
def usage():
print(f'USAGE: {sys.argv[0]} <command>')
print('Supported commands:')
for k, v in cmds.items():
print(f"\t{k}\t{v['descr']}")
def run():
try:
cmd = sys.argv[1]
except IndexError:
print('ERROR: command expected')
usage()
sys.exit(1)
try:
cmds[cmd]['func']()
except KeyError:
print(f"ERROR: unsupported command {cmd}")
usage()
sys.exit(1)
print("command executed succesfully")
if __name__ == "__main__":
run()