|
1 | | -from flask import redirect, render_template, request |
| 1 | +""" |
| 2 | +Routes available to freshmen only |
| 3 | +""" |
2 | 4 |
|
3 | | -from packet import auth, app |
4 | | -from packet.packet import set_essays, get_current_packet |
| 5 | +from flask import redirect, render_template, request, url_for |
| 6 | + |
| 7 | +from packet import auth, app, db |
| 8 | +from packet.models import Packet |
5 | 9 | from packet.utils import before_request |
6 | 10 |
|
7 | 11 |
|
8 | 12 | @app.route("/") |
9 | 13 | @auth.oidc_auth |
10 | 14 | @before_request |
11 | 15 | def index(info=None): |
12 | | - return redirect("/packet/" + info['uid'], 302) |
| 16 | + most_recent_packet = Packet.query.filter_by(freshman_username=info['uid']).order_by(Packet.id.desc()).first() |
| 17 | + |
| 18 | + if most_recent_packet is not None: |
| 19 | + return redirect(url_for("freshman_packet", freshman_username=most_recent_packet.freshman_username, |
| 20 | + packet_id=most_recent_packet.id), 302) |
| 21 | + else: |
| 22 | + return redirect(url_for("packets"), 302) |
13 | 23 |
|
14 | 24 |
|
15 | | -@app.route("/essays") |
| 25 | +@app.route("/essays/<packet_id>/") |
16 | 26 | @auth.oidc_auth |
17 | 27 | @before_request |
18 | | -def essays(info=None): |
19 | | - packet = get_current_packet(info['uid']) |
20 | | - return render_template("essays.html", info=info, packet=packet) |
| 28 | +def essays(packet_id, info=None): |
| 29 | + packet = Packet.query.filter_by(freshman_username=info['uid'], id=packet_id).first() |
| 30 | + |
| 31 | + if packet is not None: |
| 32 | + return render_template("essays.html", info=info, packet=packet) |
| 33 | + else: |
| 34 | + return redirect(url_for("index"), 302) |
21 | 35 |
|
22 | 36 |
|
23 | | -@app.route("/essay", methods=["POST"]) |
| 37 | +@app.route("/essays/<packet_id>/", methods=["POST"]) |
24 | 38 | @auth.oidc_auth |
25 | 39 | @before_request |
26 | | -def submit_essay(info=None): |
27 | | - formdata = request.form |
28 | | - if set_essays(info['uid'], formdata['info_eboard'], formdata['info_events'], formdata['info_achieve']): |
29 | | - return redirect("/essays", 302) |
30 | | - return redirect("/essays", 500) |
| 40 | +def submit_essays(packet_id, info=None): |
| 41 | + packet = Packet.query.filter_by(freshman_username=info['uid'], id=packet_id).first() |
| 42 | + |
| 43 | + if packet is not None: |
| 44 | + packet.info_eboard = request.form.get("info_eboard", None) |
| 45 | + packet.info_events = request.form.get("info_events", None) |
| 46 | + packet.info_achieve = request.form.get("info_achieve", None) |
| 47 | + |
| 48 | + db.session.commit() |
| 49 | + return redirect(url_for("essays", packet_id=packet_id), 302) |
| 50 | + else: |
| 51 | + return redirect(url_for("index"), 302) |
0 commit comments