Dan Helfman
55ebfdda39
Show full error logs at "--verbosity 0" so you can see command output without upping the verbosity level.
2019-11-19 10:09:25 -08:00
Dan Helfman
e63e2e0852
Rephrasing verbosity levels.
2019-11-17 22:52:26 -08:00
Dan Helfman
edc4b9e60e
Update the command-line help description.
2019-11-17 22:49:16 -08:00
Dan Helfman
2cc743cf47
With "borgmatic check", consider Borg warnings as errors ( #247 ).
2019-11-17 19:06:28 -08:00
Dan Helfman
d99e6d1994
Remove obnoxious log message when Healthchecks hook sends failure for check action.
2019-11-17 18:55:40 -08:00
Dan Helfman
50f62d73b7
When using the Healthchecks monitoring hook, include borgmatic logs in the payloads for completion and failure pings ( #241 ).
2019-11-17 16:54:27 -08:00
Dan Helfman
6cdc92bd0c
Fix for "borgmatic restore" showing success and incorrectly extracting archive files, even when no databases are configured to restore ( #246 ).
2019-11-13 10:41:57 -08:00
Dan Helfman
0a9f4e8708
Reopen the file given by "--log-file" flag if an external program rotates the log file while borgmatic is running.
2019-11-12 16:13:25 -08:00
Dan Helfman
781fac3266
Refactor ping monitors (Healthchecks, Cronitor, Cronhub) to share a common invocation and function signature.
2019-11-12 15:31:07 -08:00
Dan Helfman
04e5b42606
Fix repository does not exist error with "borgmatic extract" when repository is remote ( #243 ).
2019-11-12 11:47:24 -08:00
Dan Helfman
30525c43bf
Another edge case: Don't error on non-matching restore path globs ( #228 ).
2019-11-12 11:24:31 -08:00
Dan Helfman
ebeb5efe05
More accurately detecting restore of unconfigured database ( #228 ).
2019-11-12 11:10:47 -08:00
Dan Helfman
a3e939f34b
Factor out filtering of database configuration to function with tests ( #228 ).
2019-11-12 10:39:36 -08:00
Dan Helfman
2a771161e7
Finish test coverage for MySQL restore ( #228 ).
2019-11-12 09:50:26 -08:00
Dan Helfman
ded042d8cc
First crack at MySQL/MariaDB database restore ( #228 ).
2019-11-11 21:59:30 -08:00
Dan Helfman
9d29ecf304
Remove MySQL/MariaDB database dumps after backing them up ( #228 ).
2019-11-08 11:53:27 -08:00
Dan Helfman
427b57e2a9
Database dump hooks for MySQL/MariaDB ( #228 ).
2019-11-08 11:17:52 -08:00
Dan Helfman
17fda7281a
Monitor backups with Cronhub hook integration. Fix Healthchecks/Cronitor hooks to respect dry run.
2019-11-07 10:08:44 -08:00
Dan Helfman
ac777965d0
Fix regression of generate-borgmatic-config working without --source flag ( #239 ).
2019-11-06 09:52:21 -08:00
Dan Helfman
31d3bc9bd8
In documentation, clarify when Healthchecks/Cronitor hooks fire in relation to other hooks ( #238 ).
2019-11-06 09:44:46 -08:00
Dan Helfman
2115eeb6a2
Upgrade your borgmatic configuration to get new options and comments via "generate-borgmatic-config --source" ( #239 ).
2019-11-06 09:31:00 -08:00
palto42
18d3542fbc
new verbosity level "-1" for errors
2019-11-03 09:55:19 +01:00
Dan Helfman
a9104ed090
Handle log file error more consistently with other error. Add --log-file-verbosity flag. Add docs.
2019-11-02 11:23:18 -07:00
Dan Helfman
06f134cc71
Log to file instead of syslog via command-line "--log-file" flag ( #233 ).
2019-11-02 17:43:39 +00:00
palto42
6da05cbe2d
Exception handling for logfile option
2019-11-02 14:33:57 +01:00
Dan Helfman
f48f52079d
Support for Borg --keep-exclude-tags and --exclude-nodump options ( #234 ).
2019-11-01 15:50:59 -07:00
palto42
b121290c0f
Merge remote-tracking branch 'upstream/master' into logging
2019-11-01 19:44:04 +01:00
Dan Helfman
8fd46b8c70
Monitor backups with Cronitor hook integration.
2019-11-01 11:33:15 -07:00
Dan Helfman
603f525352
Clarify --archive help.
2019-11-01 10:50:20 -07:00
palto42
8c8640d0ab
file-logger replaces syslog
2019-11-01 18:42:24 +01:00
Dan Helfman
e3dd545345
Extract files to a particular directory via "borgmatic extract --destination" flag. Also rename "--restore-path" to "--path" to reduce confusion.
2019-11-01 10:00:26 -07:00
Dan Helfman
939f4d4e3d
Add additional tests for database restores.
2019-10-31 14:11:19 -07:00
Dan Helfman
3006db0cae
Restore backed up PostgreSQL databases via "borgmatic restore" sub-command ( #229 ).
2019-10-31 12:57:36 -07:00
palto42
22640a9ca0
new option for log-file
2019-10-31 10:44:22 +01:00
Dan Helfman
4dc4fe0b8d
Reordering hooks a bit so that pre-backup ordering mirrors post-backup ordering.
2019-10-27 14:47:55 -07:00
Dan Helfman
fc274b43f0
Rename "borgmatic list --pattern-from" flag to "--patterns-from" to match Borg ( #230 ).
2019-10-22 22:42:36 -07:00
Dan Helfman
458e7776c5
Database dump hooks for PostgreSQL, so you can easily dump your databases before backups run ( #225 ).
2019-10-22 16:28:42 -07:00
Dan Helfman
fa5fa1c11b
Move hooks into directory, so there can be one source file per type of hook ( #225 ).
2019-10-21 15:52:14 -07:00
Dan Helfman
f8bc67be8d
Config generation support for sequences of maps, needed for database dump hooks ( #225 ).
2019-10-21 15:17:47 -07:00
Dan Helfman
c12c47cace
Fix "borgmatic list --successful" with a slightly better heuristic for listing successful (non-checkpoint) archives.
2019-10-16 10:24:58 -07:00
Dan Helfman
128ebf04ce
Dead man's switch via healthchecks.io integration ( #223 ) + new monitoring documentation.
2019-10-15 10:49:14 -07:00
Dan Helfman
7b3b28616d
Add "borgmatic list --successful" flag to only list successful (non-checkpoint) archives ( #86 ).
2019-10-13 15:58:11 -07:00
Dan Helfman
f3910f49ca
Fix incorrect help on borg list --last flag.
2019-10-13 14:46:28 -07:00
Dan Helfman
1d37b14356
More detailed error alerting via runtime context available in "on_error" hook ( #174 ).
2019-10-01 12:23:16 -07:00
Dan Helfman
6c617eddd5
When backups to one of several repositories fails, keep backing up to the other repositories ( #144 ).
2019-09-30 22:19:31 -07:00
Dan Helfman
e14ebee4e0
User-defined hooks for global setup or cleanup that run before/after all actions. ( #192 ).
2019-09-28 16:18:10 -07:00
Dan Helfman
a897ffd514
Fix "borgmatic create --progress" output so that it updates on the console in real-time ( #221 ).
2019-09-25 12:03:10 -07:00
Dan Helfman
07222cd984
Fix visibility of "borgmatic prune --stats" output ( #219 ).
2019-09-23 13:07:51 -07:00
Dan Helfman
340bd72176
Fix regression of argument parsing for default actions ( #220 ).
2019-09-22 11:30:58 -07:00
Dan Helfman
1a1bb71af1
Fix error with "borgmatic check --only" command-line flag with "extract" consistency check ( #217 ).
2019-09-20 11:43:27 -07:00
Dan Helfman
ae45dfe63a
Clarify command-like help for check --only.
2019-09-19 15:20:05 -07:00
Dan Helfman
81739791e0
Override configured consistency checks via "borgmatic check --only" command-line flag ( #210 ).
2019-09-19 11:43:53 -07:00
Dan Helfman
4cdff74e9b
Support for Borg check --verify-data flag via borgmatic "data" consistency check ( #210 ).
2019-09-18 16:52:27 -07:00
Dan Helfman
f2198de151
Merge branch 'comments-white-space' of polyzen/borgmatic into master
2019-09-18 21:03:56 +00:00
Daniel M. Capella
0c439c0c02
Add space to separate comments from tokens
...
https://yaml.org/spec/1.2/spec.html#id2780069
2019-09-17 20:00:58 -04:00
Dan Helfman
f11a9bb4aa
Revert "Fix for spurious Borg traceback when initializing a repository in an empty directory ( #201 )."
...
This reverts commit 9585c8f908
.
2019-09-14 16:14:20 -07:00
Dan Helfman
9585c8f908
Fix for spurious Borg traceback when initializing a repository in an empty directory ( #201 ).
2019-09-13 13:08:23 -07:00
Dan Helfman
67ab2acb82
Fix for hook erroring with exit code 1 not being interpreted as an error ( #214 ).
2019-09-12 16:37:43 -07:00
Dan Helfman
c085bacccf
Reorder arguments passed to Borg to fix duplicate directories when using Borg patterns ( #213 ).
2019-09-12 15:27:04 -07:00
Dan Helfman
896401088e
Fix for traceback when the "checks" option has an empty value ( #208 ).
2019-08-26 09:52:32 -07:00
Dan Helfman
ef3dda9213
Bypass Borg error about a moved repository ( #209 ).
2019-08-26 09:39:41 -07:00
Dan Helfman
ccbd0b608b
Do not treat Borg warnings (exit code 1) as failures ( #204 ).
2019-08-03 15:13:54 -07:00
Dan Helfman
a7cc2ea803
When validating configuration files, require strings instead of allowing any scalar type.
2019-08-03 14:52:12 -07:00
Dan Helfman
9ec75ccf3f
Fit inadvertent conversion of ordered dict to dict.
2019-07-27 14:15:24 -07:00
Dan Helfman
39e5aac479
If a "prefix" option in borgmatic's configuration has an empty value (blank or ""), then disable default prefix.
2019-07-27 14:04:13 -07:00
Dan Helfman
e25f2c4e6c
Clarify documentation/schema about on_error hook running if there's an error in another hook ( #202 ).
2019-07-19 09:25:01 -07:00
Dan Helfman
90595e9c18
Only log to syslog when run from a non-interactive console (e.g. a cron job). Related to #197 .
2019-06-27 14:41:21 -07:00
Dan Helfman
032d4adee3
Remove unicode byte order mark from syslog output. (Related to #197.)
2019-06-27 10:03:49 -07:00
Dan Helfman
4444219e17
Support for Borg --noatime, --noctime, and --nobirthtime flags (mentioned in #193 ).
2019-06-25 11:30:55 -07:00
Dan Helfman
56fd78089d
Sort generated flags before passing them to Borg.
2019-06-25 11:04:10 -07:00
Dan Helfman
86dbc00cbe
Support for several more borgmatic/borg info command-line flags ( #193 ).
2019-06-25 10:46:55 -07:00
Dan Helfman
c644270599
Pass through several "borg list" flags ( #193 ).
2019-06-25 10:18:30 -07:00
Dan Helfman
1676a98c51
Fix for Borg create error output not showing up at borgmatic verbosity level zero ( #198 ).
2019-06-24 09:55:41 -07:00
Dan Helfman
c15e6c5fe5
More actions help.
2019-06-23 09:46:22 -07:00
Dan Helfman
4bf3e906a1
Break out main borgmatic arguments-parsing code into a separate file.
2019-06-22 21:32:27 -07:00
Dan Helfman
0ca43ef67a
Get tests passing.
2019-06-22 21:23:48 -07:00
Dan Helfman
75c04611dc
Refactor to support subparsed-based parsed arguments.
2019-06-22 16:10:07 -07:00
Dan Helfman
881dc9b01e
Make each subparser get a crack all all arguments.
2019-06-21 23:12:37 -07:00
Dan Helfman
8c72e909a7
Initial stab at subparsers for argument parsing. Not yet fully working.
2019-06-21 22:27:16 -07:00
Dan Helfman
74ac148747
Disable console color via "color" option in borgmatic configuration output section ( #191 ).
2019-06-19 20:48:54 -07:00
Dan Helfman
be7887c071
Demote log level of unhelpful info log ( #194 ).
2019-06-19 12:01:03 -07:00
Dan Helfman
b3aa6af859
Don't color syslog output ( #197 ).
2019-06-17 11:53:08 -07:00
Dan Helfman
de94001508
Change default syslog verbosity to show errors only.
2019-06-16 21:57:14 -07:00
Dan Helfman
6c136ebbf1
Fix for unclear error message for invalid YAML merge include ( #196 ).
2019-06-16 21:33:40 -07:00
Dan Helfman
de82919e39
Skip coverage on a particular annoying-to-trigger branch in execution code.
2019-06-13 21:38:06 -07:00
Dan Helfman
d6d66de251
Set umask used when executing hooks via "umask" option in borgmatic hooks section ( #189 ).
2019-06-13 17:05:26 -07:00
Dan Helfman
7d7308a80d
Integration tests for execute.py.
2019-06-13 10:48:21 -07:00
Dan Helfman
7f126ce127
Move hook.py file up a level.
2019-06-13 10:09:16 -07:00
Dan Helfman
a6c4debf78
Additional test coverage, and upgrade test requirements.
2019-06-13 10:01:55 -07:00
Dan Helfman
a74ad5475e
Run all Borg commands such that they log to syslog as well as console.
2019-06-12 20:56:20 -07:00
Dan Helfman
fa293828df
Run hooks such that their output goes to syslog as well as console.
2019-06-12 13:09:04 -07:00
Dan Helfman
f5582b1754
Move borgmatic.borg.execute module up a level for broader use.
2019-06-12 12:13:59 -07:00
Dan Helfman
1af95714c2
Collapse two execute_command() parameters into one output log level parameter.
2019-06-12 12:11:36 -07:00
Dan Helfman
0406d18cfd
Log Borg --stats output as warning so it shows up at any verbosity level.
2019-06-12 11:49:35 -07:00
Dan Helfman
9a5e7a3abb
Successfully convert Borg output to Python logging entries.
2019-06-11 16:42:04 -07:00
Dan Helfman
02eb6c7e09
Merge branch 'master' into logging
2019-06-10 10:27:22 -07:00
Dan Helfman
418c09398c
Fix incorrect compression default in schema comment.
2019-06-09 21:21:46 -07:00
Dan Helfman
12441331e6
Fix formatting / import ordering.
2019-05-27 15:46:38 -07:00
Dan Helfman
9ceeae2de0
Add separate syslog verbosity flag.
2019-05-27 15:44:48 -07:00
Dan Helfman
e0e493c2f1
Factor out configuring of logging into a common function.
2019-05-27 15:05:26 -07:00
Dan Helfman
0f05f7ad93
Log to syslog in addition to existing standard out logging ( #53 ).
2019-05-26 16:34:46 -07:00
Dan Helfman
fb7a6dccaa
Link to docs on skipping pruning entirely.
2019-05-21 12:32:19 -07:00
Luke Murphy
8424e443a9
Also read .yml ending configuration files
...
Closes https://projects.torsion.org/witten/borgmatic/issues/178 .
2019-05-19 13:04:42 +02:00
Dan Helfman
9417359da3
Fix for regression with missing verbose log entries ( #177 ).
2019-05-16 10:50:19 -07:00
Dan Helfman
1cf0e1bd84
Support for various Borg directory environment variables ( #153 ).
2019-05-16 10:34:52 -07:00
Luke Murphy
1c0dc3f904
Run isort over the source
2019-05-14 18:59:19 +02:00
Dan Helfman
a13cc0ab17
More tests for colored logging.
2019-05-13 21:10:26 -07:00
Dan Helfman
620f9e64d6
A few more tests for new colored logging.
2019-05-13 20:49:20 -07:00
Dan Helfman
37362150fe
Color records that are logged via logger.handle() as well.
2019-05-13 13:50:32 -07:00
Luke Murphy
1f524d6c87
Add borgmatic custom logger
2019-05-13 13:40:18 +02:00
Dan Helfman
8650a15db1
Document validate-borgmatic-config and add a few tests.
2019-05-11 14:05:16 -07:00
Robin Schneider
52e4f48eb9
Add validate-borgmatic-config command
...
Useful when generating the borgmatic configuration file with
configuration management and before moving the generated file in place
checking if it is actually valid.
2019-05-10 00:10:28 +02:00
Dan Helfman
a291477c19
Fix for hooks executing when using --dry-run ( #160 ).
2019-05-07 16:06:31 -07:00
Dan Helfman
1c88dda76a
Fix for invalid JSON output when using multiple borgmatic configuration files ( #155 ).
2019-04-02 22:30:14 -07:00
Dan Helfman
0b59c22c23
Fix for seemingly random filename ordering when running through a directory of configuration files ( #157 ).
2019-03-30 16:41:21 -07:00
Dan Helfman
6ff1867312
Configuration files includes and merging ( #148 ).
2019-03-06 12:06:27 -08:00
Dan Helfman
3cb52423d2
Support for Borg create/extract --numeric-owner flag ( #147 ).
2019-03-05 09:11:35 -08:00
Dan Helfman
4272c6b077
List the files within an archive via --list --archive option ( #140 ).
2019-02-23 23:02:17 -08:00
Dan Helfman
fe92d9e838
Fix restore paths list to tuple conversion.
2019-02-18 21:59:09 -08:00
Dan Helfman
5ea2d644a2
Fix error handling when --extract repository guard fails.
2019-02-18 21:52:56 -08:00
Dan Helfman
c35f90154f
Only guard repository when --extract is used.
2019-02-18 21:43:30 -08:00
Dan Helfman
2b3b8eab71
Add archive extract to end-to-end test.
2019-02-18 13:47:18 -08:00
Dan Helfman
aa7c7651e5
Fix config repositories consumption.
2019-02-18 13:27:35 -08:00
Dan Helfman
c41ffb5ceb
If no extract repository is given, then error if there are multiple configured repositories.
2019-02-18 13:22:14 -08:00
Dan Helfman
766a03375a
Guard that the given repository occurs in config exactly once.
2019-02-18 12:58:39 -08:00
Dan Helfman
2a4d4247e3
Tests for extract_archive().
2019-02-18 10:31:52 -08:00
Dan Helfman
9de5083a7e
Additional test coverage for extract options in borgmatic command.
2019-02-18 09:52:56 -08:00
Dan Helfman
d0557b2bcd
Initial work on #123 : Support for Borg extract.
2019-02-18 09:30:34 -08:00
Dan Helfman
1a980d6321
Organize options within command-line help into logical groups.
2019-02-12 22:27:04 -08:00
Dan Helfman
fb21d4e645
Remove dead code.
2019-02-09 21:17:55 -08:00
Dan Helfman
6096a7181c
Leave exclude_patterns glob expansion to Borg, since doing it in borgmatic leads to confusing behavior ( #132 ).
2019-01-27 13:47:26 -08:00
Dan Helfman
fa9dfb8ff7
Remove date echo from schema example, as it's not a substitute for real logging ( #127 ).
2019-01-27 12:22:22 -08:00
Dan Helfman
2dc006aab4
Allow use of --stats flag when --create or --prune flags are implied ( #139 ).
2019-01-27 12:15:47 -08:00
Dan Helfman
031b9d6faf
Handle and format validation errors raised during argument parsing ( #136 ).
2019-01-27 11:58:04 -08:00
Dan Helfman
09d521661f
Remove weasel words like "easily" and "simply".
2018-12-25 22:03:34 -08:00
Dan Helfman
fd46efb193
Add borgmatic --version command-line flag to get the current installed version number.
2018-12-25 21:01:08 -08:00
Dan Helfman
426f54c9cc
When generating sample configuration, document the defaults for each option ( #103 ).
2018-12-25 17:05:22 -08:00
Dan Helfman
45a537b6b1
When running multiple configuration files, attempt all of them even if one errors ( #116 ).
2018-12-25 15:23:54 -08:00
Dan Helfman
30b52e5523
With --init command-line flag, if a repository already exists, proceed without erroring ( #117 ).
2018-12-24 22:28:02 -08:00
Dan Helfman
14aeddc11f
Black re-formatting.
2018-12-24 14:38:57 -08:00
Dan Helfman
066399ecdb
Mention --stats command-line flag in NEWS file.
2018-12-23 16:06:08 -08:00
Felix Buehler
7516443a89
fix changes requested about stats
2018-12-22 23:46:03 +01:00
Felix Buehler
73d67e29b4
Support for Borg create & prune --stats via borgmatic command-line flag ( #100 )
2018-12-22 23:27:24 +01:00
Dan Helfman
cc9dbb1def
Support for Borg repository initialization via borgmatic --init command-line flag ( #110 ).
2018-12-10 22:20:57 -08:00
Dan Helfman
300ead65d3
Error when deprecated --excludes command-line option is used.
2018-12-09 14:57:14 -08:00
Dan Helfman
7417a3cd00
Update Borg create --filter values so a dry run lists files to back up. ( #111 ).
2018-12-02 15:03:07 -08:00
Dan Helfman
9ca80a54d8
Support for Borg create --progress via borgmatic command-line flag ( #108 ).
2018-11-21 22:03:39 -08:00
Dan Helfman
5c0b17ef39
Support for Borg --chunker-params create option via "chunker_params" in borgmatic's storage section ( #105 ).
2018-10-27 15:57:28 -07:00
Dan Helfman
695930a607
Fix for syntax error that occurred in Python 3.5 and below ( #102 ).
2018-10-15 08:47:15 -07:00
Dan Helfman
fa38de2de7
Enable consistency checks for only certain repositories via "check_repositories" ( #73 ).
2018-10-13 20:34:51 -07:00