norgbackup/norg/restic/backup.nim

38 lines
1.1 KiB
Nim
Raw Normal View History

2024-08-23 10:12:00 +01:00
import ../model/config_type
2024-08-23 10:30:36 +01:00
import ../model/state_type
import ../notifier/notifier
import execute
import prune
2024-08-23 10:12:00 +01:00
2024-08-23 10:30:36 +01:00
import nativesockets
import times
import os
proc createArchive(nc: NorgConfig, repo: Repository, retry: int = 0): int =
let further_args = nc.args.further_args
let res = run genBackupCommand(repo = repo.path, sources = nc.source_directories, exc= nc.exclusions, further_args = further_args)
2024-08-23 10:30:36 +01:00
if res != 0:
sleep 15 * 1000 # 15 seconds
if retry == nc.retries:
return 1
else:
return createArchive(nc, repo, retry + 1)
return res
2024-08-23 10:12:00 +01:00
2024-08-23 10:30:36 +01:00
proc createBackup*(nc: NorgConfig, repo: Repository): int =
let start_time = now()
2024-11-25 11:20:50 +00:00
discard notify(nc.notifiers, state=Running)
2024-08-23 10:30:36 +01:00
let res = createArchive(nc, repo)
let end_time = now()
let total = (end_time - start_time).inMilliSeconds()
case res
of 0:
if not repo.append_only:
discard pruneRepo(nc, repo)
2024-11-25 11:20:50 +00:00
discard notify(nc.notifiers, state=Success, runtime=total)
2024-08-23 10:30:36 +01:00
of 1:
2024-11-25 11:20:50 +00:00
discard notify(nc.notifiers, state=Failure, runtime=total)
2024-08-23 10:30:36 +01:00
else:
2024-11-25 11:20:50 +00:00
discard notify(nc.notifiers, state=Failure, runtime=total, msg = $res)
2024-08-23 10:30:36 +01:00
return res