1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2025-02-22 22:22:27 +00:00

also delete security dir when deleting a repo, fixes #3427

This commit is contained in:
Thomas Waldmann 2017-12-16 22:59:47 +01:00
parent e203b8739b
commit 8f772437f2
2 changed files with 9 additions and 1 deletions

View file

@ -38,7 +38,7 @@
from .archive import Archive, ArchiveChecker, ArchiveRecreater, Statistics, is_special
from .archive import BackupOSError, backup_io
from .archive import FilesystemObjectProcessors, MetadataCollector, ChunksProcessor
from .cache import Cache, assert_secure
from .cache import Cache, assert_secure, SecurityManager
from .constants import * # NOQA
from .compress import CompressionSpec
from .crypto.key import key_creator, key_argument_names, tam_required_file, tam_required, RepoKey, PassphraseKey
@ -1108,6 +1108,7 @@ def _delete_repository(self, args, repository):
return self.exit_code
repository.destroy()
logger.info("Repository deleted.")
SecurityManager.destroy(repository)
Cache.destroy(repository)
logger.info("Cache deleted.")
return self.exit_code

View file

@ -66,6 +66,13 @@ def __init__(self, repository):
self.location_file = os.path.join(self.dir, 'location')
self.manifest_ts_file = os.path.join(self.dir, 'manifest-timestamp')
@staticmethod
def destroy(repository, path=None):
"""destroy the security dir for ``repository`` or at ``path``"""
path = path or get_security_dir(repository.id_str)
if os.path.exists(path):
shutil.rmtree(path)
def known(self):
return os.path.exists(self.key_type_file)