1
0
mirror of https://github.com/moepman/bk-dss synced 2024-11-04 21:27:05 +01:00
bk-dss/index.py

122 lines
3.3 KiB
Python
Raw Normal View History

#!/usr/bin/env python
from flask import Flask, render_template, redirect, url_for, session
from flask_wtf import Form
import ldap
from redis import Redis
2015-06-17 20:22:52 +02:00
import uuid
from wtforms.fields import PasswordField, SelectField, StringField, SubmitField
from wtforms.validators import Required
app = Flask(__name__)
2015-06-17 20:22:52 +02:00
app.config.from_pyfile('config.cfg')
app.jinja_env.trim_blocks = True
app.jinja_env.lstrip_blocks = True
2015-06-17 20:22:52 +02:00
rdb = Redis(host=app.config.get('REDIS_HOST', '127.0.0.1'), password=app.config.get('REDIS_PSWD'))
class ReadonlyStringField(StringField):
def __call__(self, *args, **kwargs):
kwargs.setdefault('readonly', True)
return super(ReadonlyStringField, self).__call__(*args, **kwargs)
class EditForm(Form):
user = ReadonlyStringField('Username')
2016-01-31 16:12:35 +01:00
pwd1 = PasswordField('New Password')
pwd2 = PasswordField('New Password (repeat)')
submit = SubmitField('Submit')
class LoginForm(Form):
user = StringField('Username', validators=[Required()])
pswd = PasswordField('Password', validators=[Required()])
submit = SubmitField('Login')
2015-10-01 16:39:19 +02:00
def isLoggedin():
return 'uuid' in session and rdb.exists(session['uuid'])
@app.route('/')
def index():
nav = None
2015-10-01 16:39:19 +02:00
if isLoggedin():
nav = ['edit', 'logout']
else:
nav = ['login']
return render_template('index.html', nav=nav)
2015-06-17 20:22:52 +02:00
@app.route('/edit', methods=['GET', 'POST'])
def edit():
2015-10-01 16:39:19 +02:00
if not isLoggedin():
nav = ['login']
return render_template('error.html', message="You are not logged in. Please log in first.", nav=nav)
nav = ['edit', 'logout']
form = EditForm()
user = rdb.hget(session['uuid'], 'user')
if form.validate_on_submit():
if form.pwd1.data != form.pwd2.data:
form.pwd2.errors.append("Passwords do not match.")
else:
opwd = rdb.hget(session['uuid'], 'pswd')
npwd = form.pwd1.data
l = ldap.initialize(app.config.get('LDAP_URI', 'ldaps://127.0.0.1'))
try:
l.simple_bind_s(user, opwd)
l.passwd_s(user, opwd, npwd)
except ldap.INVALID_CREDENTIALS as e:
2016-01-31 16:12:35 +01:00
form.user.errors.append(e.message['desc'])
l.unbind_s()
2016-01-31 16:12:35 +01:00
return render_template('edit.html', form=form, nav=nav)
else:
# TODO display success message
rdb.hset(session['uuid'], 'pswd', npwd)
l.unbind_s()
2016-01-31 16:12:35 +01:00
return redirect(url_for('index'))
form.user.data = user
return render_template('edit.html', form=form, nav=nav)
@app.route('/login', methods=['GET', 'POST'])
def login():
nav = ['login']
form = LoginForm()
2015-06-17 20:22:52 +02:00
if form.validate_on_submit():
2015-06-17 20:22:52 +02:00
user = 'cn=' + form.user.data + ',' + app.config.get('LDAP_BASE','')
pswd = form.pswd.data
l = ldap.initialize(app.config.get('LDAP_URI', 'ldaps://127.0.0.1'))
try:
l.simple_bind_s(user, pswd)
except ldap.INVALID_CREDENTIALS as e:
form.pswd.errors.append(e.message['desc'])
l.unbind_s()
return render_template('login.html', form=form, nav=nav)
2015-06-17 20:22:52 +02:00
l.unbind_s()
session['uuid'] = str(uuid.uuid4())
credentials = { 'user': user, 'pswd': pswd }
rdb.hmset(session['uuid'], credentials)
# TODO refactor this and reuse
rdb.expire(session['uuid'], app.config.get('SESSION_TIMEOUT', 3600))
2015-06-17 20:22:52 +02:00
return redirect(url_for('index'))
return render_template('login.html', form=form, nav=nav)
2015-06-17 20:22:52 +02:00
@app.route('/logout')
def logout():
if 'uuid' in session:
rdb.delete(session['uuid'])
del session['uuid']
2015-06-17 20:22:52 +02:00
return redirect(url_for('index'))
if __name__ == '__main__':
app.run(host='0.0.0.0', port=5000)