diff --git a/coffeebuddy/__init__.py b/coffeebuddy/__init__.py index 5b49a49..aff5894 100644 --- a/coffeebuddy/__init__.py +++ b/coffeebuddy/__init__.py @@ -4,6 +4,9 @@ import os import random import socket +import subprocess +from pathlib import Path +from tempfile import TemporaryDirectory import flask import flask_login @@ -13,7 +16,7 @@ from flask_sqlalchemy import SQLAlchemy from sqlalchemy.exc import OperationalError -__version__ = "1.4.0" +__version__ = "1.5.0" db = SQLAlchemy() login_manager = flask_login.LoginManager() @@ -136,7 +139,10 @@ def init_app_context(app): coffeebuddy.pir.init() - if "REMINDER_MESSAGE" in flask.current_app.config: + if ( + "WEBEX_DATABASE_BACKUP" in flask.current_app.config + or "REMINDER_MESSAGE" in flask.current_app.config + ): start_scheduler(app) @@ -205,16 +211,53 @@ def prefill(): def start_scheduler(app): - from coffeebuddy.reminder import remind - scheduler = BackgroundScheduler() scheduler.start() - scheduler.add_job( - func=remind, - args=(app,), - trigger="interval", - minutes=60, - id="webex dept reminder", - name="webex dept reminder", - replace_existing=True, - ) + + if flask.current_app.config.get("REMINDER_MESSAGE"): + from coffeebuddy.reminder import remind + + scheduler.add_job( + func=remind, + args=(app,), + trigger="interval", + minutes=60, + id="webex dept reminder", + name="webex dept reminder", + replace_existing=True, + ) + + if flask.current_app.config.get("WEBEX_DATABASE_BACKUP"): + import webexteamssdk + + @scheduler.scheduled_job("cron", hour="*") + def backup_database(): + with TemporaryDirectory() as tmpdir, app.app_context(): + backupfile = Path(tmpdir) / "coffeebuddydb-backup-{}".format( + datetime.now().strftime("%Y-%m-%dT%H-%M-%S") + ) + backupfile.write_text( + subprocess.check_output( + [ + "sudo", + "docker-compose", + "exec", + "coffeebuddydb", + "pg_dump", + "-U", + "coffeebuddydb", + "-d", + "coffeebuddy", + ], + cwd="database", + universal_newlines=True, + ) + ) + + api = webexteamssdk.WebexTeamsAPI( + access_token=flask.current_app.config["WEBEX_ACCESS_TOKEN"] + ) + api.messages.create( + roomId=flask.current_app.config["WEBEX_DATABASE_BACKUP"], + files=[str(backupfile)], + ) diff --git a/config.py b/config.py index 575273a..083d01e 100644 --- a/config.py +++ b/config.py @@ -56,6 +56,9 @@ NAME ROOM is looking forward to seeing you(r money)! """ +# If not False, the webex roomid where to post database backup files +WEBEX_DATABASE_BACKUP = False + # List of peoples' emails who are notified when someone pays PAYMENT_NOTIFICATION_EMAILS = []