forked from angelachan64/Storybored
/
app.py
141 lines (122 loc) · 4.23 KB
/
app.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
138
139
140
141
from flask import Flask, render_template, request, session, redirect, url_for
import database
import user
'''
Session['logged'] determines whether someone is logged in
0 means logged out
1 means logged in
'''
DATABASE = 'storybored'
SCHEMA = [
('stories', [
('title', 'text'),
('author', 'int'),
('contents', 'text'),
('link', 'int'),
('istop','int'),
]),
('users', [
('username', 'text'),
('password', 'blob'),
]),
]
def id_to_name(user):
return database.get_user_by_id(user)
app = Flask(__name__)
app.jinja_env.filters['idtoname'] = id_to_name
@app.route('/')
@app.route("/home/")
def home():
# session["logged"] = 0
if (not "logged" in session):
session["logged"] = 0
return render_template("home.html")
@app.route("/login/", methods=['GET', 'POST'])
def login():
# session["logged"] = 0
if request.method=="GET":
return render_template("login.html")
else:
if request.form["sub"]=="Cancel":
return render_template("login.html")
user = database.check_user_password(request.form["username"], request.form["password"])
if user > 0:
session["user"] = user
session["logged"] = 1
return redirect(url_for("userpage"))
else:
error = "You have entered an incorrect username or password.\n"
return render_template("login.html", error=error)
return render_template("login.html")
@app.route("/signup/", methods=['GET', 'POST'])
def signup():
if request.method=="GET":
return render_template("signup.html")
else:
session["uname"] = request.form["user"]
database.add_user(request.form["user"], request.form["pass"])
return redirect(url_for("login"))
@app.route("/userpage/")
def userpage():
if session["logged"]==0:
return redirect(url_for("login"))
else:
return render_template("userpage.html",
uname=database.get_user_by_id(session["user"]),
posts=reversed(database.get_top_posts(-1)),
yourposts=database.get_top_posts(session["user"]))
@app.route("/newpost/", methods=['GET', 'POST'])
def newpost():
if session["logged"]==0:
return redirect(url_for("login"))
elif request.method=="GET":
username = database.get_user_by_id(session["user"])
return render_template("newpost.html", uname=username)
else:
title = request.form["title"]
body = request.form["body"]
session["title"] = title
session["body"] = body
session["author"] = database.get_user_by_id(session["user"])
return redirect(url_for("story", storyid=database.add_story(title, session["user"], body, 1)))
@app.route("/edit/", methods=["GET","POST"])
def edit():
if session["logged"]==0:
return redirect(url_for("login"))
elif request.method=="GET":
username = database.get_user_by_id(session["user"])
return render_template("edit.html", uname=username)
else:
title = "<NO TITLE YET>"
database.update_story_link(database.get_lowest_child(request.args.get('storyid')), database.add_story(title, session["user"], request.form["body"], 0))
return redirect(url_for('story', storyid=request.args.get('storyid')))
@app.route("/story/")
def story():
if session["logged"]==0:
return redirect(url_for("login"))
return render_template("story.html",
title="POSTS", author="",
posts=database.get_top_posts(-1),
uname=database.get_user_by_id(session["user"]),
storyid=request.args.get('storyid'),
content=database.get_story_content(request.args.get('storyid')))
@app.route("/deletepost/")
def deletepost():
if session["logged"]==0:
return redirect(url_for("login"))
database.remove_story(request.args.get('storyid'))
return redirect(url_for("userpage"))
@app.route("/deleteline/")
def deleteline():
if session["logged"]==0:
return redirect(url_for("login"))
return redirect(url_for("userpage"))
@app.route("/logout/")
def logout():
session['logged'] = 0
session.pop('userid', None)
return redirect(url_for("home"))
if __name__ == "__main__":
app.debug = True
app.secret_key = "STORYBORED"
app.run('0.0.0.0',port=8000)