-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
95 lines (73 loc) · 2.97 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
88
89
90
91
92
93
94
95
import os
from dotenv import load_dotenv
from flask import Flask, render_template, send_from_directory, request, redirect, url_for, make_response
from routes.lowongan_kerja import lowongan_kerja_blueprint
from routes.informasi_karier import informasi_karier_blueprint
from routes.personalisasi_karier import personalisasi_karier_blueprint
import requests
from routes.cerita_alumni import cerita_alumni_blueprint
from routes.informasi_karier import informasi_karier_blueprint
load_dotenv()
app = Flask(__name__)
app.config['SECRET_KEY'] = os.urandom(32).hex()
app.register_blueprint(lowongan_kerja_blueprint)
app.register_blueprint(informasi_karier_blueprint)
app.register_blueprint(personalisasi_karier_blueprint)
app.register_blueprint(cerita_alumni_blueprint)
@app.context_processor
def inject_cookies():
access_token = request.cookies.get('access_token')
refresh_token = request.cookies.get('refresh_token')
return dict(access_token=access_token, refresh_token=refresh_token)
@app.route('/public/<path:path>/', methods=['GET'])
def static_files(path):
return send_from_directory('public', path)
@app.route('/')
def home():
return render_template('index.html')
@app.route('/login', methods=['GET', 'POST'])
def login():
error = None
if request.method == 'POST':
if request.form['username'] != 'admin' or request.form['password'] != 'secret':
error = 'Invalid Credentials. Please try again.'
else:
return redirect(url_for('home'))
return render_template('login.html', error=error)
@app.route('/register', methods=['GET'])
def register():
return render_template('register.html')
@app.route('/profile')
def profile():
access_token = request.cookies.get('access_token')
if access_token:
headers = {'Authorization': f'Bearer {access_token}'}
response = requests.get('https://karirku-backend.meervix.com/user/', headers=headers)
if response.status_code == 200:
user_info = response.json()
return render_template('profile.html', user=user_info)
else:
return redirect('/logout')
else:
return "Access token not found", 401
@app.route('/edit-profile')
def edit_profile():
access_token = request.cookies.get('access_token')
if access_token:
headers = {'Authorization': f'Bearer {access_token}'}
response = requests.get('https://karirku-backend.meervix.com/user/', headers=headers)
if response.status_code == 200:
user_info = response.json()
return render_template('edit-profile.html', user=user_info)
else:
return redirect('/logout')
else:
return "Access token not found", 401
@app.route('/logout')
def logout():
response = make_response(redirect('/'))
response.set_cookie('access_token', '', expires=0)
response.set_cookie('refresh_token', '', expires=0)
return response
if __name__ == '__main__':
app.run(host='localhost', port=3000, debug=True)