2024-08-19 02:21:46 +01:00
|
|
|
import ../model/config_type
|
|
|
|
import ../model/state_type
|
|
|
|
import ../notifier/notifier
|
2024-08-27 21:16:31 +01:00
|
|
|
import ../model/log_type
|
2024-08-19 02:21:46 +01:00
|
|
|
|
2024-12-30 22:47:40 +00:00
|
|
|
import exit_codes
|
2024-08-19 02:21:46 +01:00
|
|
|
import execute
|
|
|
|
import prune
|
|
|
|
|
|
|
|
import os
|
|
|
|
import times
|
|
|
|
import strformat
|
|
|
|
import nativesockets
|
|
|
|
|
|
|
|
proc genArchiveName(): string =
|
|
|
|
let hostname = getHostname()
|
|
|
|
let ts = getTime().format("yyyy-MM-dd'T'HH:mm:ss'.'ffffff")
|
|
|
|
return fmt"{hostname}-{ts}"
|
|
|
|
|
2024-12-30 19:20:02 +00:00
|
|
|
proc createArchive(nc: NorgConfig, repo: Repository, archivename: string, retry: int = 0): (EXIT_CODE,string) =
|
2024-08-27 19:27:36 +01:00
|
|
|
let further_args = nc.args.further_args
|
2024-09-03 15:20:44 +01:00
|
|
|
let res = run genCreateCommand(repo = archivename, sources = nc.source_directories, stats=nc.args.stats, exc=nc.exclusions, further_args = further_args)
|
2024-08-19 02:21:46 +01:00
|
|
|
if res != 0:
|
2024-11-25 11:14:50 +00:00
|
|
|
info "Failed to run Borg. Waiting 15 seconds and trying again"
|
2024-08-19 02:21:46 +01:00
|
|
|
sleep 15 * 1000 # 15 seconds
|
|
|
|
if retry == nc.retries:
|
2024-12-30 19:20:02 +00:00
|
|
|
return (BORG_ERROR, "Max Retries Reached")
|
2024-08-19 02:21:46 +01:00
|
|
|
else:
|
|
|
|
return createArchive(nc, repo, archivename, retry + 1)
|
2024-12-30 22:47:40 +00:00
|
|
|
return (res.toExitCode(),"Success")
|
2024-08-19 02:21:46 +01:00
|
|
|
|
2024-12-30 19:20:02 +00:00
|
|
|
proc createBackup*(nc: NorgConfig, repo: Repository): EXIT_CODE =
|
2024-08-19 02:21:46 +01:00
|
|
|
let start_time = now()
|
2024-11-25 11:20:50 +00:00
|
|
|
discard notify(nc.notifiers, state=Running)
|
2024-08-19 02:21:46 +01:00
|
|
|
let archivename = repo.path & "::" & genArchiveName()
|
2024-08-27 21:16:31 +01:00
|
|
|
debug "Creating Archive: ", archivename
|
2024-12-30 19:20:02 +00:00
|
|
|
let (res,msg) = createArchive(nc, repo, archivename)
|
2024-08-23 10:30:36 +01:00
|
|
|
let end_time = now()
|
2024-08-19 02:21:46 +01:00
|
|
|
let total = (end_time - start_time).inMilliSeconds()
|
|
|
|
case res
|
2024-12-30 19:20:02 +00:00
|
|
|
of BORG_SUCCESS:
|
2024-08-27 21:50:02 +01:00
|
|
|
if not repo.append_only:
|
|
|
|
discard pruneRepo(nc, repo)
|
2024-12-30 19:20:02 +00:00
|
|
|
discard notify(nc.notifiers, state=Success, runtime=total, msg=msg)
|
|
|
|
of BORG_WARNING:
|
|
|
|
discard notify(nc.notifiers, state=Success, runtime=total, msg="Warning")
|
|
|
|
of BORG_ERROR:
|
|
|
|
discard notify(nc.notifiers, state=Failure, runtime=total, msg=msg)
|
2024-08-19 02:21:46 +01:00
|
|
|
else:
|
2024-11-25 11:20:50 +00:00
|
|
|
discard notify(nc.notifiers, state=Failure, runtime=total, msg = $res)
|
2024-08-19 02:21:46 +01:00
|
|
|
return res
|