Added container spec

recovery-function
Jef Roosens 2021-01-15 22:00:56 +01:00
parent 2bc4c22c5f
commit 310ac3784e
6 changed files with 78 additions and 6 deletions

View File

@ -2,7 +2,7 @@ from __future__ import annotations
import yaml
from pathlib import Path
from typing import List, Union
from specs import Spec, DirectorySpec, VolumeSpec
from specs import Spec, DirectorySpec, VolumeSpec, ContainerSpec
import skeleton
@ -10,7 +10,11 @@ def read_specs_file(path: Union[str, Path]) -> List[Spec]:
with open(path, "r") as yaml_file:
data = yaml.safe_load(yaml_file)
categories = [("directories", DirectorySpec), ("volumes", VolumeSpec)]
categories = [
("directories", DirectorySpec),
("volumes", VolumeSpec),
("containers", ContainerSpec),
]
specs = []

View File

@ -1,3 +1,4 @@
from .spec import Spec
from .directory import DirectorySpec
from .volume import VolumeSpec
from .container import ContainerSpec

View File

@ -0,0 +1,49 @@
from .spec import Spec
from typing import Union
from pathlib import Path
from datetime import datetime
import subprocess
class ContainerSpec(Spec):
"""
A spec for backing up via a container.
"""
_SKEL = {"container": None, "command": None, "mountpoint": "/from"}
def __init__(
self,
name: str,
container: str,
destination: Union[str, Path],
limit: int,
command: str,
extension: str,
mountpoint: str,
notify=None,
):
super().__init__(name, destination, limit, extension, notify)
self.container = container
self.mountpoint = mountpoint
self.command = command
def backup(self):
# Remove excess backups
self.remove_backups()
# Run actual backup command
filename = "{}.{}".format(
datetime.now().strftime("%Y-%m-%d_%H-%M-%S"), self.extension
)
process = subprocess.run(
"docker exec -t '{}' {} > '{}/{}'".format(
self.container, self.command, self.destination, filename
),
shell=True,
)
if self.notifier:
self.notifier.notify("backup", self.name, process.returncode)

View File

@ -7,7 +7,7 @@ import subprocess
class VolumeSpec(Spec):
"""
A spec for backup up a Docker volume.
A spec for backing up a Docker volume.
"""
_SKEL = {

View File

@ -27,9 +27,13 @@ specs:
limit: 7
containers:
nextcloud_app:
cmd: ''
extension: 'tar.gz'
gogs-db:
container: 'test_db_1'
destination: '/tmp/to'
limit: 7
command: 'pg_dump -U gogs gogs'
extension: 'sql'
directories:
test:
destination: "/home/jjr/test"

14
backups_test.yaml 100644
View File

@ -0,0 +1,14 @@
defaults:
directories:
notify:
title: 'yeet'
events:
- 'random'
limit: 7
specs:
directories:
test:
source: '/tmp/from'
destination: '/tmp/to'