removed risk of restic failing is --stats flag is passed

This commit is contained in:
Paul Wilde 2024-08-23 15:46:35 +01:00
parent 948639b9d5
commit 59dead5ea5
4 changed files with 12 additions and 1 deletions

View file

@ -18,7 +18,7 @@ proc genArchiveName(): string =
proc createArchive(nc: NorgConfig, repo: Repository, archivename: string, retry: int = 0): int = proc createArchive(nc: NorgConfig, repo: Repository, archivename: string, retry: int = 0): int =
let further_args = concat(nc.source_directories, nc.args.further_args) let further_args = concat(nc.source_directories, nc.args.further_args)
let res = run genCommand(cmd = "create", repo = archivename, further_args = further_args) let res = run genCreateCommand(cmd = "create", repo = archivename, stats=nc.args.stats, further_args = further_args)
if res != 0: if res != 0:
sleep 15 * 1000 # 15 seconds sleep 15 * 1000 # 15 seconds
if retry == nc.retries: if retry == nc.retries:

View file

@ -10,6 +10,13 @@ proc genCommand*(cmd: string, repo: string, further_args: seq[string]): string =
let cmd = fmt"{BORG_BIN} {cmd} {repo} {args}" let cmd = fmt"{BORG_BIN} {cmd} {repo} {args}"
return cmd return cmd
proc genCreateCommand*(cmd: string, repo: string, stats: bool, further_args: seq[string]): string =
let args = further_args.join(" ")
var stats_flag = "--stats"
if not stats: stats_flag = ""
let cmd = fmt"{BORG_BIN} {cmd} {stats_flag} {repo} {args}"
return cmd
proc genDeleteCommand*(cmd: string, repo: string, archive: string, further_args: seq[string]): string = proc genDeleteCommand*(cmd: string, repo: string, archive: string, further_args: seq[string]): string =
let args = further_args.join(" ") let args = further_args.join(" ")
let cmd = fmt"{BORG_BIN} {cmd} {repo} {archive} {args}" let cmd = fmt"{BORG_BIN} {cmd} {repo} {archive} {args}"

View file

@ -8,6 +8,7 @@ type
command*: Command command*: Command
repository*: string repository*: string
archive*: string archive*: string
stats*: bool
further_args*: seq[string] further_args*: seq[string]
var norg_args*: NorgArgs = NorgArgs() var norg_args*: NorgArgs = NorgArgs()
@ -19,6 +20,7 @@ proc parseArgs*() =
option("-d", "--destination", help="Destination when extracting backup", required = false) option("-d", "--destination", help="Destination when extracting backup", required = false)
option("-r", "--repository", help="Define an explicit repository to work on by either label or path.", required = false) option("-r", "--repository", help="Define an explicit repository to work on by either label or path.", required = false)
option("-a", "--archive", help="The archive or snapshot to operate on", required = false) option("-a", "--archive", help="The archive or snapshot to operate on", required = false)
flag("-s","--stats",help="Provides statistics at the end of a backup (Borg only)")
arg("command", help="The command to run, defaults to 'create' which will perform a backup.", default=some("create")) arg("command", help="The command to run, defaults to 'create' which will perform a backup.", default=some("create"))
arg("further_args", nargs = -1, help="Any further arguments to send onto borg or restic.") arg("further_args", nargs = -1, help="Any further arguments to send onto borg or restic.")
try: try:
@ -28,6 +30,7 @@ proc parseArgs*() =
norg_args.command = opts.command.toCommand() norg_args.command = opts.command.toCommand()
norg_args.repository = opts.repository norg_args.repository = opts.repository
norg_args.archive = opts.archive norg_args.archive = opts.archive
norg_args.stats = opts.stats
norg_args.further_args = opts.further_args norg_args.further_args = opts.further_args
except ShortCircuit as err: except ShortCircuit as err:
if err.flag == "argparse_help": if err.flag == "argparse_help":

View file

@ -8,4 +8,5 @@
- [x] Allow to specify direct repository so mount/extract doesn't fail if multiple are available - [x] Allow to specify direct repository so mount/extract doesn't fail if multiple are available
- [ ] Better workflow of using borg flags and options as it seems a little sketchy just passing them through to the command string - [ ] Better workflow of using borg flags and options as it seems a little sketchy just passing them through to the command string
- [ ] Add Windows support (Restic Only) - [ ] Add Windows support (Restic Only)
- [ ] Include/Exclude files functionality
- [ ] ... and loads more - [ ] ... and loads more