2018-09-03 17:20:53 +00:00
|
|
|
import datetime, glob, os, shutil, time
|
|
|
|
|
|
|
|
BACKUP_INTERVAL = 60*60 # 1 hour
|
|
|
|
BACKUP_COUNT = 5
|
|
|
|
|
|
|
|
class Module(object):
|
|
|
|
def __init__(self, bot, events, exports):
|
|
|
|
self.bot = bot
|
|
|
|
now = datetime.datetime.now()
|
|
|
|
until_next_hour = 60-now.second
|
|
|
|
until_next_hour += ((60-(now.minute+1))*60)
|
|
|
|
|
2018-09-19 12:25:12 +00:00
|
|
|
events.on("timer.database-backup").hook(self.backup)
|
2018-09-03 17:20:53 +00:00
|
|
|
bot.add_timer("database-backup", BACKUP_INTERVAL, persist=False,
|
|
|
|
next_due=time.time()+until_next_hour)
|
|
|
|
|
|
|
|
def backup(self, event):
|
2018-09-24 14:26:31 +00:00
|
|
|
full_location = self.bot.database.full_location
|
|
|
|
files = glob.glob("%s.*" % full_location)
|
2018-09-03 17:20:53 +00:00
|
|
|
files = sorted(files)
|
|
|
|
|
|
|
|
if len(files) == 5:
|
|
|
|
os.remove(files[0])
|
|
|
|
|
|
|
|
suffix = datetime.datetime.now().strftime("%y-%m-%d.%H:%M:%S")
|
2018-09-24 14:26:31 +00:00
|
|
|
backup_file = "%s.%s" % (full_location, suffix)
|
2018-09-25 10:02:07 +00:00
|
|
|
shutil.copy2(full_location, backup_file)
|
2018-09-03 17:20:53 +00:00
|
|
|
|
|
|
|
event["timer"].redo()
|