2024-08-16 16:40:24 +01:00
|
|
|
import parsetoml
|
2024-11-25 11:15:15 +00:00
|
|
|
import streams
|
|
|
|
import os
|
2024-08-16 16:40:24 +01:00
|
|
|
|
|
|
|
import ../model/config_type
|
2024-08-24 22:32:10 +01:00
|
|
|
import ../model/command_type
|
2024-08-19 02:21:46 +01:00
|
|
|
import ../model/encryption_type
|
2024-08-27 19:58:50 +01:00
|
|
|
import ../model/args_type
|
2024-08-17 18:00:30 +01:00
|
|
|
import notifier_config
|
2024-08-19 02:21:46 +01:00
|
|
|
import actions_config
|
|
|
|
import maintenance_config
|
2024-08-27 19:58:50 +01:00
|
|
|
export args_type
|
2024-08-24 22:32:10 +01:00
|
|
|
|
2024-08-16 16:40:24 +01:00
|
|
|
export config_type
|
|
|
|
|
2024-08-27 19:58:50 +01:00
|
|
|
|
2024-08-18 18:45:37 +01:00
|
|
|
proc parseSourceDirectories*(in_conf: TomlValueRef): seq[string] =
|
|
|
|
var src_dirs: seq[string] = @[]
|
|
|
|
for dir in in_conf{"source_directories"}.getElems():
|
|
|
|
src_dirs.add(dir.getStr())
|
|
|
|
# this is here for backwards compatibiliy
|
2024-08-16 16:40:24 +01:00
|
|
|
for dir in in_conf{"source_dirs"}.getElems():
|
2024-08-18 18:45:37 +01:00
|
|
|
norg_config.source_directories.add(dir.getStr())
|
|
|
|
return src_dirs
|
|
|
|
|
|
|
|
proc parseRepositories*(rep_conf: TomlValueRef): seq[Repository] =
|
|
|
|
var repos: seq[Repository] = @[]
|
|
|
|
for r in rep_conf.getElems():
|
2024-08-16 16:40:24 +01:00
|
|
|
let rtable = r.getTable()
|
|
|
|
var repo = Repository()
|
|
|
|
repo.path = rtable["path"].getStr()
|
|
|
|
repo.label = rtable["label"].getStr()
|
2024-08-27 21:50:02 +01:00
|
|
|
if rtable.hasKey("append_only"):
|
|
|
|
repo.append_only = rtable["append_only"].getBool()
|
2024-08-23 10:12:00 +01:00
|
|
|
if rtable.hasKey("tool"):
|
|
|
|
repo.tool = rtable["tool"].getStr("borg").toBackupTool()
|
2024-08-18 18:45:37 +01:00
|
|
|
repos.add(repo)
|
|
|
|
return repos
|
|
|
|
|
2024-08-23 10:12:00 +01:00
|
|
|
proc parseEncryption*(enc_conf: TomlValueRef) =
|
|
|
|
setEncryptionPassphrase(enc_conf{"encryption_passphrase"}.getStr(""))
|
|
|
|
setEncryptionPassphraseFD(enc_conf{"encryption_passphrase_fd"}.getStr(""))
|
|
|
|
setEncryptionPassphraseFile(enc_conf{"encryption_passphrase_file"}.getStr(""))
|
|
|
|
setEncryptionPassCommand(enc_conf{"encryption_passcommand"}.getStr(""))
|
|
|
|
|
2024-08-27 21:16:31 +01:00
|
|
|
proc parseLogging(nc: var NorgConfig, log_conf: TomlValueRef) =
|
|
|
|
let ll = log_conf{"log_level"}.getStr()
|
|
|
|
if ll != "":
|
|
|
|
nc.log_info.level = ll.toLogLevel()
|
|
|
|
nc.log_info.file = log_conf{"log_file"}.getStr()
|
|
|
|
discard
|
|
|
|
|
2024-08-24 22:32:10 +01:00
|
|
|
proc addConfigBinaries*(current: var Binaries, bin_conf: TomlValueRef) =
|
|
|
|
let
|
|
|
|
borg = bin_conf{"borg_bin"}.getStr()
|
|
|
|
restic = bin_conf{"restic_bin"}.getStr()
|
|
|
|
if borg != "":
|
|
|
|
current.borg.insert(borg,0)
|
|
|
|
if restic != "":
|
|
|
|
current.restic.insert(restic,0)
|
|
|
|
|
2024-09-03 15:20:44 +01:00
|
|
|
proc addExclusions*(current: var Exclusions, exc_conf: TomlValueRef) =
|
|
|
|
current.exclude_file = exc_conf{"exclude_file"}.getStr()
|
|
|
|
current.excludes = @[]
|
|
|
|
current.patterns_file = exc_conf{"patterns_file"}.getStr()
|
|
|
|
current.patterns = @[]
|
|
|
|
for e in exc_conf{"excludes"}.getElems():
|
|
|
|
current.excludes.add(e.getStr())
|
|
|
|
for p in exc_conf{"patterns"}.getElems():
|
|
|
|
current.patterns.add(p.getStr())
|
|
|
|
|
2024-08-18 18:45:37 +01:00
|
|
|
proc parseConfigFile*(file: string): NorgConfig =
|
2024-11-25 11:56:01 +00:00
|
|
|
if not fileExists(file):
|
|
|
|
echo "No Config File provided or file does not exist."
|
|
|
|
return NorgConfig()
|
2024-08-18 18:45:37 +01:00
|
|
|
let in_conf = parsetoml.parseFile(file)
|
|
|
|
norg_config.source_directories = parseSourceDirectories(in_conf)
|
2024-09-03 15:20:44 +01:00
|
|
|
# Add config file to backup
|
|
|
|
norg_config.source_directories.add(file)
|
2024-08-18 18:45:37 +01:00
|
|
|
norg_config.repositories = parseRepositories(in_conf{"repositories"})
|
2024-08-23 12:31:43 +01:00
|
|
|
if norg_config.args.repository != "":
|
|
|
|
echo "Filtering repo list to selected: ", norg_config.args.repository
|
|
|
|
norg_config.repositories = norg_config.repositories.findRepository(norg_config.args.repository)
|
2024-08-23 10:12:00 +01:00
|
|
|
parseEncryption(in_conf{"encryption"})
|
2024-08-17 18:00:30 +01:00
|
|
|
norg_config.notifiers = parseNotifiers(in_conf)
|
2024-08-19 02:21:46 +01:00
|
|
|
norg_config.actions = parseActions(in_conf{"actions"})
|
|
|
|
norg_config.maintenance = parseMaintenance(in_conf{"maintenance"})
|
2024-08-24 22:32:10 +01:00
|
|
|
norg_config.bins.addConfigBinaries(in_conf{"binaries"})
|
|
|
|
norg_config.bins.setBinaryLocations()
|
2024-09-03 15:20:44 +01:00
|
|
|
norg_config.exclusions.addExclusions(in_conf{"exclusions"})
|
2024-08-27 21:16:31 +01:00
|
|
|
norg_config.parseLogging(in_conf{"logging"})
|
2024-08-16 16:40:24 +01:00
|
|
|
return norg_config
|
|
|
|
|
2024-11-25 11:15:15 +00:00
|
|
|
const SAMPLE_CONFIG = staticRead("../../docs/static/downloads/norg.toml.sample")
|
|
|
|
proc generateConfigFile*(file: string) =
|
|
|
|
if fileExists(file):
|
|
|
|
echo "Sensibly not overwriting existing file: " & file
|
|
|
|
echo "Exiting"
|
|
|
|
return
|
|
|
|
echo "Generating Configuration to " & file
|
|
|
|
var r_strm = newStringStream(SAMPLE_CONFIG)
|
|
|
|
var w_strm = newFileStream(file, fmWrite)
|
|
|
|
var line = ""
|
|
|
|
if r_strm != nil and w_strm != nil:
|
|
|
|
while r_strm.readLine(line):
|
|
|
|
w_strm.writeLine("#" & line)
|
|
|
|
r_strm.close()
|
|
|
|
w_strm.close()
|
|
|
|
echo "Done. Now edit " & file & " to your requirements and run:"
|
|
|
|
echo "norg -c " & file & " init"
|
|
|
|
else:
|
|
|
|
echo "Error writing sample config file"
|
|
|
|
|