Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
C
CS123-Canteeneo
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Willard Torres
CS123-Canteeneo
Commits
bee55882
Commit
bee55882
authored
Nov 08, 2016
by
Willard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use decorators for stall and dish validation
parent
8695734d
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
33 deletions
+38
-33
views.py
canteeneo/views.py
+38
-33
No files found.
canteeneo/views.py
View file @
bee55882
import
os.path
from
functools
import
wraps
from
canteeneo
import
app
,
login_manager
,
db
from
flask
import
flash
,
redirect
,
render_template
,
request
,
url_for
from
flask_login
import
login_required
,
login_user
,
logout_user
,
current_user
...
...
@@ -51,6 +52,30 @@ def register():
return
render_template
(
'register.html'
,
form
=
form
)
def
stall_validate
(
f
):
@
wraps
(
f
)
def
wrapper
(
*
args
,
**
kwargs
):
stall_id
=
int
(
kwargs
.
get
(
'stall_id'
))
stall
=
Stall
.
query
.
get
(
stall_id
)
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
return
f
(
*
args
,
**
kwargs
)
return
wrapper
def
dish_validate
(
f
):
@
wraps
(
f
)
def
wrapper
(
*
args
,
**
kwargs
):
stall_id
=
int
(
kwargs
.
get
(
'stall_id'
))
dish_id
=
int
(
kwargs
.
get
(
'dish_id'
))
stall
=
Stall
.
query
.
get
(
stall_id
)
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
dish
=
Dish
.
query
.
get
(
dish_id
)
if
dish
is
None
or
dish
.
stall
!=
stall
:
return
redirect
(
url_for
(
'stall'
,
stall_id
=
stall_id
))
return
f
(
*
args
,
**
kwargs
)
return
wrapper
@
app
.
route
(
'/stalls'
)
@
login_required
def
stalls
():
...
...
@@ -58,11 +83,9 @@ def stalls():
@
app
.
route
(
'/stalls/<int:stall_id>'
)
@
login_required
@
stall_validate
def
stall
(
stall_id
):
stall
=
Stall
.
query
.
filter_by
(
id
=
int
(
stall_id
))
.
first
()
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
stall
=
Stall
.
query
.
get
(
stall_id
)
dishes
=
stall
.
dishes
.
all
()
return
render_template
(
'stall.html'
,
stall
=
stall
,
dishes
=
dishes
,
upload_folder
=
app
.
config
[
'UPLOAD_FOLDER'
])
...
...
@@ -85,11 +108,9 @@ def new_stall():
@
app
.
route
(
'/stalls/<int:stall_id>/edit'
,
methods
=
[
'GET'
,
'POST'
])
@
login_required
@
stall_validate
def
edit_stall
(
stall_id
):
stall
=
Stall
.
query
.
filter_by
(
id
=
int
(
stall_id
))
.
first
()
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_to
(
'stalls'
))
stall
=
Stall
.
query
.
get
(
stall_id
)
form
=
StallRegisterForm
()
form
.
location
.
choices
=
[(
loc
.
id
,
loc
.
name
)
for
loc
in
Location
.
query
.
all
()]
...
...
@@ -112,12 +133,9 @@ def edit_stall(stall_id):
@
app
.
route
(
'/stalls/<int:stall_id>/delete'
,
methods
=
[
'POST'
])
@
login_required
@
stall_validate
def
delete_stall
(
stall_id
):
stall
=
Stall
.
query
.
filter_by
(
id
=
int
(
stall_id
))
.
first
()
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
stall
=
Stall
.
query
.
get
(
stall_id
)
db
.
session
.
delete
(
stall
)
db
.
session
.
commit
()
...
...
@@ -125,11 +143,9 @@ def delete_stall(stall_id):
@
app
.
route
(
'/stalls/<int:stall_id>/dish/new'
,
methods
=
[
'GET'
,
'POST'
])
@
login_required
@
stall_validate
def
new_dish
(
stall_id
):
stall
=
Stall
.
query
.
filter_by
(
id
=
int
(
stall_id
))
.
first
()
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
stall
=
Stall
.
query
.
get
(
stall_id
)
form
=
DishRegisterForm
()
if
request
.
method
==
'POST'
:
if
form
.
validate
():
...
...
@@ -147,15 +163,10 @@ def new_dish(stall_id):
@
app
.
route
(
'/stalls/<int:stall_id>/dish/<int:dish_id>/edit'
,
methods
=
[
'GET'
,
'POST'
])
@
login_required
@
dish_validate
def
edit_dish
(
stall_id
,
dish_id
):
stall
=
Stall
.
query
.
filter_by
(
id
=
int
(
stall_id
))
.
first
()
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
dish
=
Dish
.
query
.
filter_by
(
id
=
dish_id
)
.
first
()
if
dish
is
None
or
dish
.
stall
!=
stall
:
return
redirect
(
url_for
(
'stall'
,
stall_id
=
stall_id
))
stall
=
Stall
.
query
.
get
(
stall_id
)
dish
=
Dish
.
query
.
get
(
dish_id
)
form
=
DishRegisterForm
()
if
request
.
method
==
'POST'
:
if
form
.
validate
(
editing
=
True
):
...
...
@@ -179,15 +190,9 @@ def edit_dish(stall_id, dish_id):
@
app
.
route
(
'/stalls/<int:stall_id>/dish/<int:dish_id>/delete'
,
methods
=
[
'POST'
])
@
login_required
@
dish_validate
def
delete_dish
(
stall_id
,
dish_id
):
stall
=
Stall
.
query
.
filter_by
(
id
=
int
(
stall_id
))
.
first
()
if
stall
is
None
or
stall
.
owner
!=
current_user
:
return
redirect
(
url_for
(
'stalls'
))
dish
=
Dish
.
query
.
filter_by
(
id
=
dish_id
)
.
first
()
if
dish
is
None
or
dish
.
stall
!=
stall
:
return
redirect
(
url_for
(
'stall'
,
stall_id
=
stall_id
))
dish
=
Dish
.
query
.
get
(
dish_id
)
db
.
session
.
delete
(
dish
)
db
.
session
.
commit
()
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment