-
Notifications
You must be signed in to change notification settings - Fork 176
/
Copy pathapp.py
58 lines (40 loc) · 1.29 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
import logging
import os
import time
from flask import Flask, request
APP_PORT = os.getenv("APP_PORT", "3004")
app = Flask(__name__)
is_deactivated = False
@app.route("/shipping/ship", methods=["POST"])
def ship():
if is_deactivated:
return "The shipping service is currently deactivated for routine maintenance.", 503
logging.info(f"Shipping order: {request.json}")
# Simulate work
time.sleep(1)
return '', 200
@app.route("/shipping/deactivate", methods=["POST"])
def deactivate():
global is_deactivated
is_deactivated = True
logging.warning("The shipping service has been deactivated for routine maintenance.")
return '', 200
@app.route("/shipping/activate", methods=["POST"])
def activate():
global is_deactivated
is_deactivated = False
logging.info("The shipping service has been (re)activated.")
return '', 200
@app.route("/", methods=["GET"])
@app.route("/healthz", methods=["GET"])
def hello():
return f"Hello from {__name__}", 200
def main():
# Start the Flask app server
app.run(port=APP_PORT, debug=True, use_reloader=False)
if __name__ == "__main__":
logging.basicConfig(
format='%(asctime)s.%(msecs)03d %(levelname)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S',
level=logging.INFO)
main()