forked from mihirs16/Project-Darwin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
252 lines (221 loc) · 8.55 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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
import threading
import database
import json
import os
import time
import smtplib
import stats
import flask
import flask_login
import pandas as pd
from ast import literal_eval
from flask_cors import CORS
from werkzeug.utils import secure_filename
from k3y5 import ADMIN_USERNAME, ADMIN_PASSWORD, ADMIN_KEY, GMAIL_PWD
app = flask.Flask(__name__)
login_manager = flask_login.LoginManager()
login_manager.init_app(app)
CORS(app, support_credentials=True)
app.config['FILE_UPLOADS'] = 'resume_uploads'
# ---- flask login setup ----------------------------------
app.secret_key = ADMIN_KEY
users = {ADMIN_USERNAME: {'password': ADMIN_PASSWORD}}
class User(flask_login.UserMixin):
pass
@login_manager.user_loader
def user_loader(email):
if email not in users:
return
user = User()
user.id = email
return user
@login_manager.request_loader
def request_loader(request):
email = request.form.get('email')
if email not in users:
return
user = User()
user.id = email
user.is_authenticated = request.form['password'] == users[email]['password']
return user
# -----------------------------------------------------
# ---- public services --------------------------------
@app.route('/', methods=['GET'])
def homepage():
return flask.render_template('homepage.html')
@app.route('/darwin/<jobid>', methods=['GET'])
def darwin(jobid):
return flask.render_template('chatbot.html', jobid = jobid)
@app.route('/data/getAllJobs', methods=['GET'])
def getAllJobs():
allJobs = database.getAllJobs()
return flask.jsonify(allJobs)
@app.route('/data/getResume/<id>', methods=['GET'])
def getResume(id):
database.resume_vault.download_item(id, os.path.join(os.path.join(app.root_path, app.config['FILE_UPLOADS']), id+str('.pdf')))
del_thread = threading.Thread(target=delay_delete, args=(5, os.path.join(os.path.join(os.path.join(app.root_path, app.config['FILE_UPLOADS']), id+str('.pdf')))))
del_thread.start()
return flask.send_from_directory(directory=os.path.join(app.root_path, app.config['FILE_UPLOADS']), filename=id+str('.pdf'))
def delay_delete (t, path):
print ("started")
time.sleep(t)
print ("trying to delete")
os.remove(path)
print ("done")
return
@app.route('/data/newCandidate', methods=['POST'])
def newCandidate():
resumeFile = flask.request.files['resumeFile']
candyInfo = json.loads(flask.request.form['jsonInput'])
path = os.path.join(app.config["FILE_UPLOADS"], resumeFile.filename)
resumeFile.save(path)
print (":adding new candidate")
print (candyInfo)
database.add_candidate({
"jobId": str(candyInfo['jobid']),
"cname": candyInfo['cname'],
"email": candyInfo['email'],
"gitId": candyInfo['gitId'],
"tweetId": candyInfo['tweetId'],
"yoe": int(candyInfo['yoe']),
"jobskills": candyInfo['jobskills'],
"self_desc": candyInfo['self_desc'],
"job_want_why": candyInfo['job_want_why'],
"job_req_what": candyInfo['job_req_what'],
"passion": candyInfo['passion'],
"date_join": candyInfo['date_join'],
"apt": candyInfo['apt']
}, path)
print (":new candidate added")
os.remove(path)
return flask.redirect(flask.url_for('homepage'))
@app.route('/data/getQuestions', methods=['GET'])
def getQues():
_qt = pd.read_csv('data_src/g4g/quants.csv', converters={"OPT": literal_eval}, dtype=str)
_lg = pd.read_csv('data_src/g4g/logix.csv', converters={"OPT": literal_eval}, dtype=str)
_vr = pd.read_csv('data_src/g4g/verbs.csv', converters={"OPT": literal_eval}, dtype=str)
qt = _qt.sample(n=5)
lg = _lg.sample(n=5)
vr = _vr.sample(n=5)
response = {
"que": list(qt['QUE'].values) + list(lg['QUE'].values) + list(vr['QUE'].values),
"opt": list(qt['OPT'].values) + list(lg['OPT'].values) + list(vr['OPT'].values),
"ans": list(qt['ANS'].values) + list(lg['ANS'].values) + list(vr['ANS'].values)
}
print (response)
return flask.jsonify(response)
# -----------------------------------------------------
# ---- admin services ---------------------------------
@app.route('/admin', methods=['GET', 'POST'])
def admin():
if flask.request.method == 'GET':
return flask.render_template('admin_login.html')
email = flask.request.form['email']
if email in list(users.keys()):
if flask.request.form['password'] == users[email]['password']:
user = User()
user.id = email
flask_login.login_user(user)
return flask.redirect(flask.url_for('billboard'))
return flask.redirect(flask.url_for('admin'))
@app.route('/admin/billboard')
@flask_login.login_required
def billboard():
return flask.render_template('job_billboard.html')
@app.route('/applicants/<jobid>')
@flask_login.login_required
def applicants(jobid):
jobDet = database.getAllJobs()
# print(jobDet)
# print(jobDet[int(jobid)-1]['role'])
jobname = jobDet[int(jobid)-1]['role']
return flask.render_template('job_applicants.html', jobid=jobid, jobname=jobname)
@app.route('/admin/jobdetails/add', methods=['GET', 'POST'])
@flask_login.login_required
def jobdetails_add():
if flask.request.method == 'POST':
jobData = flask.request.json
database.add_job(jobData)
return flask.redirect(flask.url_for('billboard'))
return flask.render_template('job_manage.html')
@app.route('/data/admin/getCandidates/<jobid>')
@flask_login.login_required
def getCandidates(jobid):
allCandidates = database.getAllCandidates(jobid)
return flask.jsonify(allCandidates)
@app.route('/data/admin/getJobStats/<jobid>')
@flask_login.login_required
def getJobStats(jobid):
allCandidates = database.getStats(jobid)
# print(allCandidates)
doj = [can["Date_Of_Joining"] for can in allCandidates]
ski = [can["Skill"] for can in allCandidates]
yoe = [can["Year_of_Experience"] for can in allCandidates]
ovr = [can["overall_score"] for can in allCandidates]
dfAllCan = pd.DataFrame(data = {'Date_Of_Joining': doj, 'Skill': ski, 'Year_of_Experience': yoe, 'overall_score': ovr})
ski_x, ski_y = stats.create_ski(dfAllCan)
plotData = {
"perc": {
"x": list(stats.create_perc(dfAllCan).index),
"y": [int(x) for x in list(stats.create_perc(dfAllCan).iloc[:, 0].values)]
},
"doj": {
"x": list(stats.create_doj(dfAllCan).index),
"y": [int(x) for x in list(stats.create_perc(dfAllCan).iloc[:, 0].values)]
},
"yoe": {
"x": [int(x) for x in list(stats.create_yoe(dfAllCan).iloc[:, 0].values)],
"y": [int(x) for x in list(stats.create_yoe(dfAllCan).iloc[:, 1].values)]
},
"ski": {
"x": [int(x) for x in ski_x],
"y": ski_y
}
}
print (plotData)
return json.dumps(plotData)
@app.route('/sendEmails', methods=['POST'])
# @flask_login.login_required
def sendEmails():
# print(flask.request.json['emails'])
try:
mailList = flask.request.json['emails']
for mail in mailList:
MAIL_USER_ID = "[email protected]"
SUBJECT = "Level Up!"
server = smtplib.SMTP('smtp.gmail.com', 587)
server.ehlo()
server.starttls()
server.login(MAIL_USER_ID, GMAIL_PWD)
TEXT = "Congratulations! You have made it to the next round of interviews. We, at Blueprint, are eagerly looking forward to meet you."
BODY = '\r\n'.join(['To: %s' % mail,
'From: %s' % MAIL_USER_ID,
'Subject: %s' % SUBJECT,
'', TEXT])
server.sendmail(MAIL_USER_ID, [mail], BODY)
print ('chat mailed')
return 'ok'
except Exception as e:
return str(e)
@app.route('/logout')
def logout():
flask_login.logout_user()
return flask.redirect(flask.url_for('admin'))
@login_manager.unauthorized_handler
def unauthorized_handler():
return flask.redirect(flask.url_for('admin'))
# -------------------------------------------------------
if __name__ == "__main__":
# # for hot reload and tracking static files and templates
# from os import path, walk
# extra_dirs = ['templates/', 'static/']
# extra_files = extra_dirs[:]
# for extra_dir in extra_dirs:
# for dirname, dirs, files in walk(extra_dir):
# for filename in files:
# filename = path.join(dirname, filename)
# if path.isfile(filename):
# extra_files.append(filename)
# # flask app run
# app.run(debug=False, extra_files=extra_files)
app.run()