summaryrefslogtreecommitdiff
path: root/routes/base.py
blob: a9c0e195b7166b2cdf0304985889bf08d1e461a0 (plain)
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
from secrets import token_urlsafe
from app import app, D
from flask import render_template,session,request,redirect
from routes.tools import rows2dicts, get_alert, get_nick, csrf_check

@app.route("/")
def index():
    session["csrf"] = token_urlsafe()
    return app.send_static_file("index.html")

@app.route("/pages/info.html")
def info():
    if "id" in session:
        return render_template(
                "info.html",
                caller="info",
                alert=get_alert(),
                nick=get_nick()
            )
    return render_template(
            "info.html",
            caller="info",
            alert=get_alert()
        )
        
@app.route("/set/nick",methods=["POST"])
def new_nick():
    next = "/#"+request.form["caller"] if "caller" in request.form else "/"
    if csrf_check():
        return redirect(next)
    if "id" in session.keys():
        session["alert"]="Sinulla on jo nimimerkki. Käytä sitä."
        return redirect(next)
    if "nick" not in request.form or request.form["nick"]=="":
        session["alert"]="Nimimerkkiä ei voi asettaa ilman nimimerkkiä."
        return redirect(next)
    else:
        nick = request.form["nick"]
    if len(nick) < 4:
        session["alert"]="Nimimerkki on liian lyhyt"
        return redirect(next)
    if not nick.isalnum():
        session["alert"]="Nimimerkissä saa olla vain kirjaimia ja numeroita."
        return redirect(next)
    if D.user.exists(nick):
        session["alert"]="Nimimerkki jonka olet ottamassa on jo varattu."
        return redirect(next)
    session["id"] = int(D.user.new(nick))
    return redirect(next)