/
web_server.py
69 lines (58 loc) · 1.89 KB
/
web_server.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
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash, jsonify
import api
from user import User
DATABASE = '/tmp/dev.db'
DEBUG = True
SECRET_KEY = 'dev key'
USERNAME = 'admin'
PASSWORD = 'password'
PORT = 8080
app = Flask(__name__)
app.config.from_object(__name__)
#app.config.from_object('SERVER_SETTINGS')
users = {}
@app.route('/')
def front_page():
if session.get('id'):
if session['id'] not in users:
session.pop('id',None)
return render_template('landing.html')
return render_template('chatbot.html', uid=session['id'])
return render_template('landing.html')
@app.route('/facebook-login')
def oauth_redirect():
if session.get('access_token'):
return session['access_token']['access_token']
return render_template('chatbot.html')
else:
return api.login()
@app.route('/facebook-login/<uniqueid>')
def code_process(uniqueid):
if 'code' in request.args:
code = request.args.get('code')
token = api.getToken(code, uniqueid)
if api.verifyToken(token):
users[uniqueid] = User(token, uniqueid)
session['id'] = uniqueid
return redirect(url_for('front_page'))
elif 'error' in request.args:
raise api.APIError(request.args.get('error_description'))
@app.route('/get-chat-line/<uniqueid>')
def generate_message(uniqueid):
if not 'id' in session or session['id'] != uniqueid:
abort(403)
else:
return jsonify({"message":users[uniqueid].generateMessage()})
@app.route('/about')
def about():
return render_template('about.html')
@app.route('/contact')
def contact():
return render_template('contact.html')
@app.route('/logout')
def logout():
session.pop('id', None)
flash('You were logged out')
return redirect(url_for('front_page'))
if __name__ == '__main__':
app.run(host='0.0.0.0', port=PORT)