-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.py
85 lines (69 loc) · 2.45 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
import mysql.connector
import csv
from flask import Flask, request, jsonify, send_file
app = Flask(__name__)
host = "xxx-xxx"
user = "ingenius2018"
passwd = "Pesitbsc"
database = "ingenius2018"
@app.route("/")
def root():
return "You have hit the root route"
@app.route("/getTeams")
def get_teams():
mydb = mysql.connector.connect(host=host, user=user, passwd=passwd, database=database )
mycursor = mydb.cursor()
statement = "SELECT * FROM myTeamView"
mycursor.execute(statement)
data = mycursor.fetchall()
mycursor.close()
mydb.close()
return jsonify(data)
@app.route("/getJudges")
def get_judges():
mydb = mysql.connector.connect(host=host, user=user, passwd=passwd, database=database )
mycursor = mydb.cursor()
statement = "SELECT * FROM judge"
mycursor.execute(statement)
data = mycursor.fetchall()
mycursor.close()
mydb.close()
return jsonify(data)
@app.route("/getScores")
def get_scores():
mydb = mysql.connector.connect(host=host, user=user, passwd=passwd, database=database )
mycursor = mydb.cursor()
statement = "SELECT * FROM myScoreView"
mycursor.execute(statement)
data = mycursor.fetchall()
with open("scores.csv", "w", newline='') as f:
score_writer = csv.writer(f, delimiter=',', quotechar='"', quoting=csv.QUOTE_MINIMAL)
score_writer.writerow([i[0] for i in mycursor.description])
for row in list(data):
score_writer.writerow(row)
mycursor.close()
mydb.close()
return send_file("scores.csv", attachment_filename="scores.csv", as_attachment=True)
@app.route("/insertScore", methods=['POST'])
def insert_score():
try:
mydb = mysql.connector.connect(host=host, user=user, passwd=passwd, database=database )
mycursor = mydb.cursor()
insertion_statement = "INSERT INTO score VALUES (%s, %s, %s, %s, %s, %s)"
insertion_data = (
request.form.get("judgeID"),
request.form.get("teamID"),
request.form.get("Technical_Difficulty"),
request.form.get("Completeness"),
request.form.get("Originality"),
request.form.get("Feasibility"),
)
mycursor.execute(insertion_statement, insertion_data)
mydb.commit()
mycursor.close()
mydb.close()
return "SCORE_INSERTED"
except:
return "ALREADY_JUDGED"
if __name__ == "__main__":
app.run()