-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathroutes.py
87 lines (79 loc) · 3.24 KB
/
routes.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
from flask import render_template, request, redirect, flash, url_for
from flask_login import login_user, logout_user, current_user, login_required
from markdown import markdown
from models import User, Story
from ai import generate_story
from sqlalchemy.exc import IntegrityError
def register_routes(app, db, bcrypt):
@app.route("/")
def index():
return render_template("index.html", user=current_user)
@app.route("/login", methods=["GET", "POST"])
def login():
if request.method == "POST":
username = request.form["username"]
password = request.form["password"]
user = User.query.filter_by(username=username).first()
if user and bcrypt.check_password_hash(user.password, password):
login_user(user)
return redirect(url_for("stories"))
flash("Invalid username or password")
return render_template("login.html")
@app.route("/signup", methods=["GET", "POST"])
def signup():
if request.method == "POST":
username = request.form["username"]
name = request.form["name"]
password = request.form["password"]
email = request.form["email"]
hashed_password = bcrypt.generate_password_hash(password).decode("utf-8")
new_user = User(
name=name, username=username, email=email, password=hashed_password
)
try:
db.session.add(new_user)
db.session.commit()
return redirect(url_for("login"))
except IntegrityError:
db.session.rollback()
flash("Username or email already exists")
return render_template("signup.html")
@app.route("/logout")
@login_required
def logout():
logout_user()
return redirect(url_for("index"))
@app.route("/stories")
@login_required
def stories():
user_stories = Story.query.filter_by(user_id=current_user.id).all()
for story in user_stories:
story.story = markdown(story.story)
return render_template("stories.html", stories=user_stories)
@app.route("/create_story", methods=["GET", "POST"])
@login_required
def create_story():
if request.method == "POST":
title = request.form["title"]
theme = request.form["theme"]
place = request.form["place"]
prompt = request.form["prompt"]
story_prompt, story_text = generate_story(theme, place, prompt)
new_story = Story(
title=title,
user_id=current_user.id,
prompt=story_prompt,
story=story_text,
)
db.session.add(new_story)
db.session.commit()
return redirect(url_for("stories"))
return render_template("create_story.html")
@app.route("/delete_story/<int:story_id>", methods=["DELETE"])
@login_required
def delete_story(story_id):
story = Story.query.get_or_404(story_id)
db.session.delete(story)
db.session.commit()
flash("Story deleted successfully.")
return "", 204