forked from uwidcit/INFO2602L2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwsgi.py
132 lines (117 loc) · 3.67 KB
/
wsgi.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
import click, sys
from models import db, User, Todo
from app import app
from sqlalchemy.exc import IntegrityError
@app.cli.command("init", help="Creates and initializes the database")
def initialize():
db.drop_all()
db.init_app(app)
db.create_all()
bob = User('bob', 'bob@mail.com', 'bobpass')
bob.todos.append(Todo('wash car'))
db.session.add(bob)
db.session.commit()
print(bob)
print('database intialized')
@app.cli.command("get-user", help = "Retrives a user")
@click.argument('username', default = 'bob')
def get_user(username):
bob = User.query.filter_by(username = username).first()
if not bob:
print(f'User {username} not found')
return
print(bob)
@app.cli.command('get-users')
def get_users():
users = User.query.all()
if not users:
print('No users found')
return
for user in users:
print(user)
@app.cli.command('change-email')
@click.argument('username', default = 'bob')
@click.argument('email', default = 'bob@mail.com')
def change_email(username, email):
user = User.query.filter_by(username = username).first()
if not user:
print(f'User {username} not found')
return
user.email = email
db.session.add(user)
db.session.commit()
print(user)
@app.cli.command('create-user')
@click.argument('username', default = 'babaoolal')
@click.argument('email', default = 'babaoolal@gmail.com')
@click.argument('password', default = 'babaoolalpass')
def create_user(username, email, password):
newuser = User(username, email, password)
try:
db.session.add(newuser)
db.session.commit()
except IntegrityError as e:
db.session.rollback()
print(f'Error creating user: User already exists')
else:
print(f'User {newuser} created successfully')
@app.cli.command('delete-user')
@click.argument('username', default = 'bob')
def delete_user(username):
user = User.query.filter_by(username = username).first()
if not user:
print(f'User {username} not found')
return
db.session.delete(user)
db.session.commit()
print(f'User {user} deleted successfully')
@app.cli.command('get-todos')
@click.argument('username', default='bob')
def get_user_todos(username):
user = User.query.filter_by(username=username).first()
if not user:
print(f'{username} not found!')
return
for todo in user.todos:
print(todo)
@app.cli.command('add-todo')
@click.argument('username', default = 'bob')
@click.argument('text', default = 'wash car')
def add_task(username, text):
user = User.query.filter_by(username = username).first()
if not user:
print(f'User {username} not found')
return
new_todo = Todo(text)
user.todos.append(new_todo)
db.session.add(new_todo)
db.session.commit()
print(f'Task {new_todo} added to {user}')
@app.cli.command('toggle-todo')
@click.argument('username', default = 'bob')
@click.argument('id', default = 1)
def toggle_todo(id, username):
user = User.query.filter_by(username = username).first()
if not user:
print(f'User {username} not found')
return
todo = Todo.query.filter_by(id = id, user_id = user.id).first()
if not todo:
print(f'{username} has no todo id {id}')
return
todo.toggle()
print(f'{todo.text} is done')
@click.argument('username', default='bob')
@click.argument('todo_id', default=1)
@click.argument('category', default='chores')
@app.cli.command('add-category', help="Adds a category to a todo")
def add_todo_category_command(username, todo_id, category):
user = User.query.filter_by(username=username).first()
if not user:
print(f'{username} not found!')
return
res = user.add_todo_category(todo_id, category)
if not res:
print(f'{username} has no todo id {todo_id}')
return
print('Category added!')