forked from esbullington/flask-bootstrap
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.py
87 lines (73 loc) · 2.72 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
# -*- coding: utf-8 -*-
from flask import Flask, request, jsonify, make_response, render_template, flash, redirect, url_for, session, escape, g
from models.database import db_session
from flaskext.sqlalchemy import SQLAlchemy
from flaskext.auth import Auth, AuthUser, login_required, logout
from models.sa import get_user_class
app = Flask(__name__)
app.config.from_pyfile('app.cfg')
# Instantiate DB
db = SQLAlchemy(app)
## Set SQL Alchemy to automatically tear down
@app.teardown_request
def shutdown_session(exception=None):
db_session.remove()
# Instantiate authentication
auth = Auth(app, login_url_name='login')
User = get_user_class(db.Model)
def index():
return render_template('index.html')
##login methods
def login():
if request.method == 'POST':
username = request.form['username']
user = User.query.filter(User.username==username).first()
if user is not None:
# Authenticate and log in!
if user.authenticate(request.form['password']):
session['username'] = request.form['username']
return redirect(url_for('home'))
else:
flash('Incorrect password. Please try again')
return render_template('login.html')
else:
flash('Incorrect username. Please try again')
return render_template('login.html')
return render_template('login.html')
@login_required()
def home():
##Dump variables in templates
return render_template('home.html')
def user_create():
if request.method == 'POST':
username = request.form['username']
if User.query.filter(User.username==username).first():
return 'User already exists.'
password = request.form['password']
user = User(username=username, password=password)
db.session.add(user)
db.session.commit()
return redirect(url_for('index'))
return render_template('user_create.html')
def logout_view():
user_data = logout()
if user_data is None:
msg = 'No user to log out.'
return render_template('logout.html', msg=msg)
else:
msg = 'Logged out user {0}.'.format(user_data['username'])
return render_template('logout.html', msg=msg)
# URLs
app.add_url_rule('/', 'index', index)
app.add_url_rule('/login/', 'login', login, methods=['GET', 'POST'])
app.add_url_rule('/home/', 'home', home)
app.add_url_rule('/users/create/', 'user_create', user_create, methods=['GET', 'POST'])
app.add_url_rule('/logout/', 'logout', logout_view)
# Secret key needed to use sessions.
app.secret_key = 'mysecretkey'
if __name__ == "__main__":
try:
open('/tmp/app.db')
except IOError:
db.create_all()
app.run(debug=True,host='127.0.0.1')