-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathapp.py
64 lines (52 loc) · 2.64 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
from flask import Flask, render_template, redirect, url_for, request, session
from flask_sqlalchemy import SQLAlchemy
# import our model from folder
from face_recognition_and_liveness.face_liveness_detection.face_recognition_liveness_app import recognition_liveness
app = Flask(__name__)
app.secret_key = 'web_app_for_face_recognition_and_liveness' # something super secret
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///database.sqlite'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)
class Users(db.Model):
username = db.Column(db.String(100), primary_key=True)
name = db.Column(db.String(100))
password = db.Column(db.String(100))
@app.route('/')
def index():
return redirect(url_for('login'))
@app.route('/login', methods=['GET','POST'])
def login():
if request.method == 'POST':
session.pop('name', None)
username = request.form['username']
password = request.form['password']
user = Users.query.filter_by(username=username).first()
print(user)
if user is not None and user.password == password:
session['name'] = user.name # store variable in session
detected_name, label_name = recognition_liveness('face_recognition_and_liveness/face_liveness_detection/liveness.model',
'face_recognition_and_liveness/face_liveness_detection/label_encoder.pickle',
'face_recognition_and_liveness/face_liveness_detection/face_detector',
'face_recognition_and_liveness/face_recognition/encoded_faces.pickle',
confidence=0.5)
if user.name == detected_name and label_name == 'real':
return redirect(url_for('main'))
else:
return render_template('login_page.html', invalid_user=True, username=username)
else:
return render_template('login_page.html', incorrect=True)
return render_template('login_page.html')
@app.route('/main', methods=['GET'])
def main():
name = session['name']
return render_template('main_page.html', name=name)
if __name__ == '__main__':
db.create_all()
# add users to database
# new_user = Users(username='jom_ariya', password='123456789', name='Ariya')
# db.session.add(new_user)
# new_user_2 = Users(username='earth_ekaphat', password='123456789', name='Ekaphat')
# new_user_3 = Users(username='bonus_ekkawit', password='123456789', name='Ekkawit')
# db.session.add(new_user_2)
# db.session.add(new_user_3)
app.run(debug=True)