-
Notifications
You must be signed in to change notification settings - Fork 0
/
routes.py
68 lines (52 loc) · 1.82 KB
/
routes.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
from core import app
from markupsafe import escape
from http import HTTPStatus
from flask import abort, request
from flask.wrappers import Response
from datetime import datetime
from models import db
from models import User
@app.route("/hello/<username>", methods=['GET'])
def get_username(username):
sanitized_username=escape(username)
user = User.query.filter_by(username=sanitized_username).first()
if user is None:
abort(404)
if user.days_until_birthday() == 0:
return {
"message": f"Hello, {user.username}! Happy birthday!"
}
return {
"message": f"Hello, {user.username}! Your birthday is in {user.days_until_birthday()} day(s)"
}
@app.route("/hello/<username>", methods=['PUT'])
def put_username(username):
sanitized_username=escape(username)
request_data = request.get_json()
try:
birth_date_str = request_data['dateOfBirth']
birth_date = datetime.strptime(birth_date_str, "%Y-%m-%d")
except (KeyError, ValueError):
abort(400, 'Invalid message format')
user = User.query.filter_by(username=sanitized_username).first()
try:
if user is None:
newuser = User(sanitized_username, birth_date)
db.session.add(newuser)
db.session.commit()
else:
user.birth_date = birth_date
db.session.commit()
except ValueError as e:
abort(400, f'Invalid value: {str(e)}')
return Response(status=HTTPStatus(204))
@app.route("/health", methods=['GET'])
def health():
try:
db.engine.execute('SELECT 1')
except:
abort(500, "FAILED: Database connection failed")
return Response(response="OK", status=HTTPStatus(200))
@app.route("/liveness", methods=['GET'])
def liveness():
return Response(response="OK", status=HTTPStatus(200))