Skip to content
Open
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,6 @@ __pycache__
.vscode
uploads
node_modules
schemas.json
.mypy_cache
*.db
opengeodeweb_back_schemas.json
16 changes: 14 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

41 changes: 9 additions & 32 deletions requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,55 +2,39 @@
# This file is autogenerated by pip-compile with Python 3.12
# by the following command:
#
# pip-compile --output-file=./requirements.txt --pre ./requirements-internal.in ./requirements.in
# pip-compile --output-file=./requirements.txt --pre ./requirements.in
#
asgiref~=3.0
# via flask
blinker~=1.0
# via
# flask
# opengeodeweb-microservice
# via flask
click~=8.0
# via
# flask
# opengeodeweb-microservice
fastjsonschema~=2.0
# via opengeodeweb-microservice
# via flask
flask[async]~=3.0
# via
# -r requirements.in
# flask
# flask-cors
# flask-sqlalchemy
# opengeodeweb-microservice
flask-cors~=6.0
# via -r requirements.in
flask-sqlalchemy~=3.0
# via
# -r requirements.in
# opengeodeweb-microservice
# via -r requirements.in
geode-common==33.11.0
# via
# -r requirements.in
# geode-viewables
geode-viewables==3.3.0
# via -r requirements.in
greenlet~=3.0
# via
# opengeodeweb-microservice
# sqlalchemy
# via sqlalchemy
itsdangerous~=2.0
# via
# flask
# opengeodeweb-microservice
# via flask
jinja2~=3.0
# via
# flask
# opengeodeweb-microservice
# via flask
markupsafe~=3.0
# via
# jinja2
# opengeodeweb-microservice
# werkzeug
opengeode-core==15.27.4
# via
Expand All @@ -75,19 +59,12 @@ opengeode-io==7.4.0
# -r requirements.in
# geode-viewables
# opengeode-geosciencesio
opengeodeweb-microservice~=1.0
# via -r requirements-internal.in
sqlalchemy~=2.0
# via
# flask-sqlalchemy
# opengeodeweb-microservice
# via flask-sqlalchemy
typing-extensions~=4.0
# via
# opengeodeweb-microservice
# sqlalchemy
# via sqlalchemy
werkzeug==3.0.3
# via
# -r requirements.in
# flask
# flask-cors
# opengeodeweb-microservice
14 changes: 14 additions & 0 deletions src/opengeodeweb_back/routes/blueprint_routes.py
Original file line number Diff line number Diff line change
Expand Up @@ -381,3 +381,17 @@ def ping():
utils_functions.validate_request(flask.request, ping_json)
flask.current_app.config.update(LAST_PING_TIME=time.time())
return flask.make_response({"message": "Flask server is running"}, 200)


with open(
os.path.join(schemas, "kill.json"),
"r",
) as file:
kill_json = json.load(file)


@routes.route(kill_json["route"], methods=kill_json["methods"])
def kill() -> flask.Response:
print("Manual server kill, shutting down...", flush=True)
os._exit(0)
return flask.make_response({"message": "Flask server is dead"}, 200)
10 changes: 10 additions & 0 deletions src/opengeodeweb_back/routes/schemas/kill.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"route": "/kill",
"methods": [
"POST"
],
"type": "object",
"properties": {},
"required": [],
"additionalProperties": false
}