Compare commits
193 Commits
Author | SHA1 | Date | |
---|---|---|---|
7fe07f86a9 | |||
14c81a00a7 | |||
3eced64453 | |||
c284d928fd | |||
dd9da9452b | |||
11d5121954 | |||
66d622b474 | |||
47b2aabd9f | |||
b91cf18b04 | |||
305b504ca1 | |||
7be2679b91 | |||
3c6e3ed914 | |||
02bc040e2a | |||
9f1f36215a | |||
ff75f4bbcd | |||
5f40713e98 | |||
cd5f7611a9 | |||
b542711078 | |||
52dbc353e5 | |||
6bef0c3e5b | |||
4d705d78fb | |||
62d47ecfa7 | |||
32444ff82e | |||
a5a7c05640 | |||
bfb81e11b2 | |||
fd4c83f9c0 | |||
fe27c6396a | |||
c89dde186a | |||
18a64de0de | |||
99c622b69f | |||
95e85e8b45 | |||
1a48c7bca5 | |||
5d21764ef1 | |||
c7302f0e17 | |||
fb1c8ec4fb | |||
fe9462dac0 | |||
d8453d1fb0 | |||
65c46a1e26 | |||
f859b5961f | |||
25ddd65f25 | |||
bcba6b2086 | |||
753b03861f | |||
80a45cd595 | |||
551c8ad441 | |||
3823b1bf44 | |||
f777c78aad | |||
bb693dbb97 | |||
7beda281e0 | |||
1143d2850b | |||
8900bd70a4 | |||
6db5f73bc0 | |||
a163c11129 | |||
2b4d191271 | |||
417088c32b | |||
4fa5efa5b6 | |||
a0bf51636c | |||
684edd7985 | |||
3acb20a40f | |||
0007c8696a | |||
cf2baf3601 | |||
e6b9f8e6e6 | |||
2eefc59cf7 | |||
98d8b8e8f2 | |||
1ad50ebcf8 | |||
c483a1056f | |||
3b9f569310 | |||
843be7968b | |||
d477d850ac | |||
8eb3229af7 | |||
d89a208bbd | |||
0d28d6afcf | |||
7c42a9a7cd | |||
31339fb4d8 | |||
c642e827f5 | |||
a328239021 | |||
4ee60184bf | |||
161ad31577 | |||
7c5f4a95da | |||
4981acbf9d | |||
932d5c380f | |||
f84d76badf | |||
6ee6e10621 | |||
127d38c076 | |||
0218dee76d | |||
67a1eab908 | |||
c618ca33f8 | |||
6e7d912fa2 | |||
b90d1958b2 | |||
c187fbb735 | |||
c3de4386ab | |||
e20141043c | |||
11ec1a98d8 | |||
8788d473a5 | |||
edc669b340 | |||
086835453b | |||
5d3c265ce9 | |||
8c633fd4b2 | |||
a664edaed7 | |||
e88773e289 | |||
5c2bfcc940 | |||
aee513f786 | |||
6b99cfa196 | |||
c24e8086e9 | |||
c12bbe3bee | |||
33febd662e | |||
5635c1edd0 | |||
e169778c82 | |||
c838bfe815 | |||
e81a5def47 | |||
18884c640d | |||
ee2256bfb2 | |||
82d79c520a | |||
c30ae2ac3e | |||
fc738597ff | |||
aebef21eb4 | |||
c660e97434 | |||
d35fdc890d | |||
6fe1f26c71 | |||
5b5568910d | |||
3425330890 | |||
b5f7c3fd72 | |||
01efeab13f | |||
9a663f4260 | |||
7c635c36e0 | |||
fff33849da | |||
3391ffa4e6 | |||
b7d1be495e | |||
2daf2f130d | |||
d120c2ca8f | |||
02fd04930d | |||
10b0abe707 | |||
291a954e9c | |||
e43eecf383 | |||
ea676fe0da | |||
e73bd9ff3b | |||
fd9426181f | |||
c25edc5d78 | |||
aebfbda64e | |||
5fe0629b0f | |||
7d6acd77b5 | |||
9d646297c7 | |||
bf8d261cf3 | |||
686cd0019a | |||
b7b002bd72 | |||
b8a63f39f5 | |||
feacb83274 | |||
2aeb435167 | |||
51f5084dd0 | |||
cf04e4456a | |||
25dc6225b3 | |||
a300f696d3 | |||
8161aaa0a9 | |||
a6bfabe22f | |||
a5466fc121 | |||
fbf2d9cbbc | |||
437642608b | |||
a4214b2b3f | |||
6ccb75f4fa | |||
b8a82b2836 | |||
78428a49fc | |||
42bc11bf1a | |||
44e3d534f6 | |||
1fbe3282c8 | |||
10a6342233 | |||
a35db2e05d | |||
7c4868ee4b | |||
affdd0abfd | |||
7224661c71 | |||
e353ed0225 | |||
37bd69b675 | |||
14bca64657 | |||
d9baf44199 | |||
6de94d038f | |||
a04d1db077 | |||
62942540b5 | |||
904a579994 | |||
4b382bddd9 | |||
5e7c52997c | |||
f7676e73ba | |||
2ca5f193e4 | |||
9ffa2e473e | |||
9fd60b6bf7 | |||
951bf97eb2 | |||
a2a89011fe | |||
d893a2684e | |||
ee83586072 | |||
02321870b5 | |||
3e9138e05a | |||
51f9e9a776 | |||
37c20aaafa | |||
9c202cf3e9 | |||
c3fa74e442 | |||
0f3cf0d9c4 |
9
.changes/0.2.4.md
Normal file
9
.changes/0.2.4.md
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
## 0.2.4 - 2023-02-18
|
||||||
|
### Added
|
||||||
|
* Notifications now display errors and the output of the failed command.
|
||||||
|
* CI configs for GitHub and Woodpecker
|
||||||
|
* Added `version` subcommand
|
||||||
|
### Changed
|
||||||
|
* Console logging can be disabled by setting `console-disabled` in the `logging` object
|
||||||
|
## Fixed
|
||||||
|
* If Host was not defined for an incomplete `hosts` object, any commands would fail as they could not look up the values in the SSH config files.
|
6
.changes/header.tpl.md
Normal file
6
.changes/header.tpl.md
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
# Changelog
|
||||||
|
All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||||
|
adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html),
|
||||||
|
and is generated by [Changie](https://github.com/miniscruff/changie).
|
1
.changes/unreleased/.gitkeep
Normal file
1
.changes/unreleased/.gitkeep
Normal file
@ -0,0 +1 @@
|
|||||||
|
*.yaml
|
3
.changes/unreleased/Added-20250409-174528.yaml
Normal file
3
.changes/unreleased/Added-20250409-174528.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Added
|
||||||
|
body: 'feat: Package operation `versionCheck` supports regular expressions (see [regexp](https://pkg.go.dev/regexp) package for docs)'
|
||||||
|
time: 2025-04-09T17:45:28.836497149-05:00
|
3
.changes/unreleased/Added-20250501-110745.yaml
Normal file
3
.changes/unreleased/Added-20250501-110745.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Added
|
||||||
|
body: 'Command lists: added `cmdLists.[name].notify` object'
|
||||||
|
time: 2025-05-01T11:07:45.96164753-05:00
|
3
.changes/unreleased/Added-20250704-085917.yaml
Normal file
3
.changes/unreleased/Added-20250704-085917.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Added
|
||||||
|
body: Testing setup with Docker
|
||||||
|
time: 2025-07-04T08:59:17.430373451-05:00
|
3
.changes/unreleased/Added-20250704-102126.yaml
Normal file
3
.changes/unreleased/Added-20250704-102126.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Added
|
||||||
|
body: 'CLI: add global flag --hostsConfig that allows hosts to be dynamic in relation to the main config'
|
||||||
|
time: 2025-07-04T10:21:26.864635558-05:00
|
3
.changes/unreleased/Added-20250715-202303.yaml
Normal file
3
.changes/unreleased/Added-20250715-202303.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Added
|
||||||
|
body: 'CLI: Exec subcommand `hosts`. See documentation for more details.'
|
||||||
|
time: 2025-07-15T20:23:03.647128713-05:00
|
3
.changes/unreleased/Added-20250723-220340.yaml
Normal file
3
.changes/unreleased/Added-20250723-220340.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Added
|
||||||
|
body: 'CLI: added `exec hosts` subcommand `list`'
|
||||||
|
time: 2025-07-23T22:03:40.24191927-05:00
|
3
.changes/unreleased/Changed-20250321-090849.yaml
Normal file
3
.changes/unreleased/Changed-20250321-090849.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: 'Commands: `host` can now be `localhost` or `127.0.0.1` to run commands locally'
|
||||||
|
time: 2025-03-21T09:08:49.871021144-05:00
|
3
.changes/unreleased/Changed-20250325-003357.yaml
Normal file
3
.changes/unreleased/Changed-20250325-003357.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: lists loaded from external files only if no list config present in current file
|
||||||
|
time: 2025-03-25T00:33:57.039431409-05:00
|
3
.changes/unreleased/Changed-20250407-223020.yaml
Normal file
3
.changes/unreleased/Changed-20250407-223020.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: "`PackageManager.Parse` renamed to `ParseRemotePackageManagerVersionOutput`. This now returns arrays of PackageManagerCommon.Package and errors."
|
||||||
|
time: 2025-04-07T22:30:20.342177323-05:00
|
3
.changes/unreleased/Changed-20250418-133440.yaml
Normal file
3
.changes/unreleased/Changed-20250418-133440.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: 'Internal: refactoring and renaming functions'
|
||||||
|
time: 2025-04-18T13:34:40.842541658-05:00
|
3
.changes/unreleased/Changed-20250501-110534.yaml
Normal file
3
.changes/unreleased/Changed-20250501-110534.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: 'Commands: moved output-prefixed keys to the `commands.[name].output` object'
|
||||||
|
time: 2025-05-01T11:05:34.90130087-05:00
|
3
.changes/unreleased/Changed-20250609-072601.yaml
Normal file
3
.changes/unreleased/Changed-20250609-072601.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: Change internal method name for better understanding
|
||||||
|
time: 2025-06-09T07:26:01.819927627-05:00
|
3
.changes/unreleased/Changed-20250709-231919.yaml
Normal file
3
.changes/unreleased/Changed-20250709-231919.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Changed
|
||||||
|
body: Improved error message for remote version package output
|
||||||
|
time: 2025-07-09T23:19:19.431960446-05:00
|
3
.changes/unreleased/Fixed-20250418-095747.yaml
Normal file
3
.changes/unreleased/Fixed-20250418-095747.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Fixed
|
||||||
|
body: 'Command Lists: hooks now run correctly when commands finish'
|
||||||
|
time: 2025-04-18T09:57:47.39035092-05:00
|
3
.changes/unreleased/Fixed-20250424-225711.yaml
Normal file
3
.changes/unreleased/Fixed-20250424-225711.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
kind: Fixed
|
||||||
|
body: Log file passed using `--log-file` correctly used
|
||||||
|
time: 2025-04-24T22:57:11.592829277-05:00
|
16
.changes/v0.10.0.md
Normal file
16
.changes/v0.10.0.md
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
## v0.10.0 - 2025-03-08
|
||||||
|
### Added
|
||||||
|
* Hooks: improved logging when executing
|
||||||
|
* User commands: adding SSH keys using config key `userSshPubKeys`
|
||||||
|
* directives: added support for fetching values using directive `%{externalSource:key}%`
|
||||||
|
### Changed
|
||||||
|
* Commands: if dir is not specified, run in config dir
|
||||||
|
* FileDirective: use the config directory if path is not absolute
|
||||||
|
* Host: changes to case of some keys
|
||||||
|
* Notifications: added external directive to sensitive keys
|
||||||
|
### Fixed
|
||||||
|
* LocalFetcher: return fetch error
|
||||||
|
* Lists: load file key before attempting to load from current file
|
||||||
|
* fix: host not in config file, but in ssh config, properly added to hosts struct
|
||||||
|
* SSH: password authentication bugs
|
||||||
|
* User commands: change user password works
|
8
.changes/v0.10.1.md
Normal file
8
.changes/v0.10.1.md
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
## v0.10.1 - 2025-03-11
|
||||||
|
### Added
|
||||||
|
* UserCommands: add ssh public keys when running locally
|
||||||
|
* UserCommands: add field CreateUserHome
|
||||||
|
### Changed
|
||||||
|
* UserCommands: create temp file when modifing password over SSH
|
||||||
|
* UserCommands: change field name
|
||||||
|
* Vault: keys are now referenced by `name`, and the actual data by `data`
|
6
.changes/v0.10.2.md
Normal file
6
.changes/v0.10.2.md
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
## v0.10.2 - 2025-03-19
|
||||||
|
### Added
|
||||||
|
* Notifications: http service added
|
||||||
|
* Variable support. Can be referenced with `%{var:nameOfVar}%` in select string fields.
|
||||||
|
### Changed
|
||||||
|
* vault: initialize vault before validating config
|
8
.changes/v0.3.0.md
Normal file
8
.changes/v0.3.0.md
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
## v0.3.0 - 2023-01-07
|
||||||
|
### Added
|
||||||
|
* Getting environment variables and passwords from Vault (not tested yet)
|
||||||
|
* Vault configuration to config (not tested yet)
|
||||||
|
* Ability to run scripts from file on local machine on the remote host
|
||||||
|
* Ability to get ouput in the notification of a list for individual commands or all commands
|
||||||
|
### Changed
|
||||||
|
* Make SSH connections close after all commands have been run; reuse previous connections if needed
|
3
.changes/v0.3.1.md
Normal file
3
.changes/v0.3.1.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
## v0.3.1 - 2023-07-20
|
||||||
|
### Changed
|
||||||
|
* If an SSH session failed to be created, the command would fail. This would be caused when restarting the SSH host. The SSH connection is attempted to be created again. If successful, the command is executed normally.
|
13
.changes/v0.4.0.md
Normal file
13
.changes/v0.4.0.md
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
## v0.4.0 - 2023-09-08
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
* Added `scriptEnvFile` to command object that allows one to specify an environment file (or any file really) when a `scriptFile` is run. Inspired by the practice of keeping environment variables and scripts or commands seperate.
|
||||||
|
* Basis for listing commands
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
* BREAKING: Notifications object now takes the form of service.id, where service can be "mail" or "matrix" and id is a unique id for the service.
|
||||||
|
* BREAKING: Since the change to the notifications object, cmd-lists' inner map key 'notifications' must be of the form service.id. id must be defined for that service. See notifications docs for aviliable services.
|
||||||
|
* Config parser is now the simpler Koanf - Keys are now case-sensitive
|
||||||
|
* Log size limited to 50 Mb
|
9
.changes/v0.5.0.md
Normal file
9
.changes/v0.5.0.md
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
## v0.5.0 - 2024-11-19
|
||||||
|
### Added
|
||||||
|
* Lists can now go in a file. See docs for more information.
|
||||||
|
* commands.[name].type: script now opens `scriptEnvFile`.
|
||||||
|
* Hooks for Commands.[name]. Error, success, and final. [#12]
|
||||||
|
### Changed
|
||||||
|
* GetKnownHosts is now a method of Host
|
||||||
|
### Fixed
|
||||||
|
* make command logger be used for errors, not just when running the command
|
4
.changes/v0.6.0.md
Normal file
4
.changes/v0.6.0.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
## v0.6.0 - 2025-01-04
|
||||||
|
### Added
|
||||||
|
* Command Type Package - allows one to perform package operations [docs](https://backy.cybershell.xyz/config/packages/)
|
||||||
|
* Exec subcommand `host` allows for parallel execution of commands on hosts. [See docs](https://backy.cybershell.xyz/cli/exec)
|
3
.changes/v0.6.1.md
Normal file
3
.changes/v0.6.1.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
## v0.6.1 - 2025-01-04
|
||||||
|
### Fixed
|
||||||
|
* When running a list, hooks now run explicitly after the command executes. Fixed panic due to improper logic.
|
16
.changes/v0.7.0.md
Normal file
16
.changes/v0.7.0.md
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
## v0.7.0 - 2025-02-11
|
||||||
|
### Added
|
||||||
|
* [feat]: package `packageOperation` option `checkVersion` implemented
|
||||||
|
* user management added - see docs
|
||||||
|
* Support for remote config sources. Only config file and list can be used for now.
|
||||||
|
* Cache functionality - still a WIP
|
||||||
|
* Flag `--s3-endpoint` for config file fetching from S3
|
||||||
|
### Changed
|
||||||
|
* Internal refactoring of config setup
|
||||||
|
* Formatting and sending for notifications
|
||||||
|
* name of `configfetcher` to `remotefetcher`
|
||||||
|
* Flags that took comma-separated lists now have to be passed multiple times for each argument.
|
||||||
|
* Hosts passed to `exec host` now checked against default SSH config files
|
||||||
|
### Fixed
|
||||||
|
* Parsing of remote URLs when determining list config file path
|
||||||
|
* Incorrect error notification template value
|
3
.changes/v0.7.1.md
Normal file
3
.changes/v0.7.1.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
## v0.7.1 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* Incorrect local config file loading logic caused files to not be detected
|
3
.changes/v0.7.2.md
Normal file
3
.changes/v0.7.2.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
## v0.7.2 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* CI configs
|
3
.changes/v0.7.3.md
Normal file
3
.changes/v0.7.3.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
## v0.7.3 - 2025-02-14
|
||||||
|
### Changed
|
||||||
|
* GoReleaser configs
|
5
.changes/v0.7.4.md
Normal file
5
.changes/v0.7.4.md
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
## v0.7.4 - 2025-02-14
|
||||||
|
### Changed
|
||||||
|
* CI configs
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
5
.changes/v0.7.5.md
Normal file
5
.changes/v0.7.5.md
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
## v0.7.5 - 2025-02-14
|
||||||
|
### Changed
|
||||||
|
* CI configs
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
4
.changes/v0.7.6.md
Normal file
4
.changes/v0.7.6.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
## v0.7.6 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
* CI configs
|
4
.changes/v0.7.7.md
Normal file
4
.changes/v0.7.7.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
## v0.7.7 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
* CI configs
|
4
.changes/v0.7.8.md
Normal file
4
.changes/v0.7.8.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
## v0.7.8 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* Github CI config
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
6
.changes/v0.8.0.md
Normal file
6
.changes/v0.8.0.md
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
## v0.8.0 - 2025-02-15
|
||||||
|
### Changed
|
||||||
|
* Breaking: `cmd-lists` key changed to `cmdLists`
|
||||||
|
* Properly load list config
|
||||||
|
* Config file loading properly errors
|
||||||
|
* CI Configs
|
12
.changes/v0.9.0.md
Normal file
12
.changes/v0.9.0.md
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
## v0.9.0 - 2025-02-28
|
||||||
|
### Added
|
||||||
|
* `list` command with subcommands `cmds` and `lists`
|
||||||
|
* Deprecation and unsupported warnings for old config keys
|
||||||
|
* CLI flag `--cmdStdOut` to output command's stdout/stderr to stdout
|
||||||
|
* Command type `remoteScript`. See docs for more info.
|
||||||
|
### Changed
|
||||||
|
* change to enums for Command type
|
||||||
|
* Cache now stores resources by URL hash for ease-of-lookup
|
||||||
|
* Changed PackageOperation to enums
|
||||||
|
### Fixed
|
||||||
|
* Local command's `dir` full path is now found with home directory
|
3
.changes/v0.9.1.md
Normal file
3
.changes/v0.9.1.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
## v0.9.1 - 2025-03-01
|
||||||
|
### Changed
|
||||||
|
* Use EnvVar AWS_PROFILE to get S3 profile
|
26
.changie.yaml
Normal file
26
.changie.yaml
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
changesDir: .changes
|
||||||
|
unreleasedDir: unreleased
|
||||||
|
headerPath: header.tpl.md
|
||||||
|
changelogPath: CHANGELOG.md
|
||||||
|
versionExt: md
|
||||||
|
versionFormat: '## {{.Version}} - {{.Time.Format "2006-01-02"}}'
|
||||||
|
kindFormat: '### {{.Kind}}'
|
||||||
|
changeFormat: '* {{.Body}}'
|
||||||
|
kinds:
|
||||||
|
- label: Added
|
||||||
|
auto: minor
|
||||||
|
- label: Changed
|
||||||
|
auto: major
|
||||||
|
- label: Deprecated
|
||||||
|
auto: minor
|
||||||
|
- label: Removed
|
||||||
|
auto: major
|
||||||
|
- label: Fixed
|
||||||
|
auto: patch
|
||||||
|
- label: Security
|
||||||
|
auto: patch
|
||||||
|
newlines:
|
||||||
|
afterChangelogHeader: 1
|
||||||
|
beforeChangelogVersion: 1
|
||||||
|
endOfVersion: 1
|
||||||
|
envPrefix: CHANGIE_
|
1
.frontmatter/database/mediaDb.json
Normal file
1
.frontmatter/database/mediaDb.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
1
.frontmatter/database/taxonomyDb.json
Normal file
1
.frontmatter/database/taxonomyDb.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
40
.github/workflows/release.yml
vendored
Normal file
40
.github/workflows/release.yml
vendored
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
name: goreleaser
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
# run only against tags
|
||||||
|
tags:
|
||||||
|
- '*'
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
packages: write
|
||||||
|
# issues: write
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
goreleaser:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
- run: git fetch --force --tags
|
||||||
|
- uses: actions/setup-go@v5
|
||||||
|
with:
|
||||||
|
go-version: '1.23'
|
||||||
|
cache: true
|
||||||
|
# More assembly might be required: Docker logins, GPG, etc. It all depends
|
||||||
|
# on your needs.
|
||||||
|
- uses: olegtarasov/get-tag@v2.1.4
|
||||||
|
id: tagName
|
||||||
|
with:
|
||||||
|
# tagRegex: "foobar-(.*)" # Optional. Returns specified group text as tag name. Full tag string is returned if regex is not defined.
|
||||||
|
tagRegexGroup: 1 # Optional. Default is 1.
|
||||||
|
- uses: goreleaser/goreleaser-action@v6
|
||||||
|
with:
|
||||||
|
distribution: goreleaser
|
||||||
|
version: 2.7.0
|
||||||
|
args: release --release-notes=".changes/${{ env.GIT_TAG_NAME }}.md" -f .goreleaser/github.yml --clean
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GORELEASER_TOKEN }}
|
||||||
|
GIT_TAG_NAME: ${{ steps.tagName.outputs.tag }}
|
8
.gitignore
vendored
8
.gitignore
vendored
@ -1,2 +1,10 @@
|
|||||||
|
!.changie.yaml
|
||||||
|
!.changes/**
|
||||||
|
|
||||||
dist/
|
dist/
|
||||||
|
.codegpt
|
||||||
|
|
||||||
|
*.log
|
||||||
|
/*.sh
|
||||||
|
/*.yaml
|
||||||
|
/*.yml
|
||||||
|
7
.gitmodules
vendored
Normal file
7
.gitmodules
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
[submodule "docs/themes/hugo-theme-relearn"]
|
||||||
|
path = docs/themes/hugo-theme-relearn
|
||||||
|
url = https://github.com/McShelby/hugo-theme-relearn.git
|
||||||
|
|
||||||
|
[submodule "docs/themes/plausible-hugo"]
|
||||||
|
path = docs/themes/plausible-hugo
|
||||||
|
url = https://github.com/divinerites/plausible-hugo.git
|
43
.goreleaser/gitea.yml
Normal file
43
.goreleaser/gitea.yml
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
version: 2
|
||||||
|
before:
|
||||||
|
hooks:
|
||||||
|
# You may remove this if you don't use go modules.
|
||||||
|
- go mod tidy
|
||||||
|
builds:
|
||||||
|
- env:
|
||||||
|
- CGO_ENABLED=0
|
||||||
|
goos:
|
||||||
|
- freebsd
|
||||||
|
- linux
|
||||||
|
goarch:
|
||||||
|
- "386"
|
||||||
|
- amd64
|
||||||
|
- arm64
|
||||||
|
|
||||||
|
archives:
|
||||||
|
- formats: tar.gz
|
||||||
|
# this name template makes the OS and Arch compatible with the results of uname.
|
||||||
|
name_template: >-
|
||||||
|
{{ .ProjectName }}_{{ .Version }}_
|
||||||
|
{{- title .Os }}_
|
||||||
|
{{- if eq .Arch "amd64" }}x86_64
|
||||||
|
{{- else if eq .Arch "386" }}i386
|
||||||
|
{{- else }}{{ .Arch }}{{ end }}
|
||||||
|
{{- if .Arm }}v{{ .Arm }}{{ end }}
|
||||||
|
# use zip for windows archives
|
||||||
|
format_overrides:
|
||||||
|
- goos: windows
|
||||||
|
formats: [zip]
|
||||||
|
checksum:
|
||||||
|
name_template: 'checksums.txt'
|
||||||
|
snapshot:
|
||||||
|
version_template: "{{ incpatch .Version }}-next"
|
||||||
|
changelog:
|
||||||
|
disable: false
|
||||||
|
|
||||||
|
gitea_urls:
|
||||||
|
api: https://git.andrewnw.xyz/api/v1
|
||||||
|
download: https://git.andrewnw.xyz
|
||||||
|
# The lines beneath this are called `modelines`. See `:help modeline`
|
||||||
|
# Feel free to remove those if you don't want/use them.
|
||||||
|
# yaml-language-server: $schema=https://goreleaser.com/static/schema.json
|
41
.goreleaser/github.yml
Normal file
41
.goreleaser/github.yml
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
# Make sure to check the documentation at https://goreleaser.com
|
||||||
|
version: 2
|
||||||
|
before:
|
||||||
|
hooks:
|
||||||
|
# You may remove this if you don't use go modules.
|
||||||
|
- go mod tidy
|
||||||
|
builds:
|
||||||
|
- env:
|
||||||
|
- CGO_ENABLED=0
|
||||||
|
goos:
|
||||||
|
- freebsd
|
||||||
|
- linux
|
||||||
|
goarch:
|
||||||
|
- "386"
|
||||||
|
- amd64
|
||||||
|
- arm64
|
||||||
|
|
||||||
|
archives:
|
||||||
|
- formats: tar.gz
|
||||||
|
# this name template makes the OS and Arch compatible with the results of uname.
|
||||||
|
name_template: >-
|
||||||
|
{{ .ProjectName }}_{{ .Version }}_
|
||||||
|
{{- title .Os }}_
|
||||||
|
{{- if eq .Arch "amd64" }}x86_64
|
||||||
|
{{- else if eq .Arch "386" }}i386
|
||||||
|
{{- else }}{{ .Arch }}{{ end }}
|
||||||
|
{{- if .Arm }}v{{ .Arm }}{{ end }}
|
||||||
|
# use zip for windows archives
|
||||||
|
format_overrides:
|
||||||
|
- goos: windows
|
||||||
|
formats: [zip]
|
||||||
|
checksum:
|
||||||
|
name_template: 'checksums.txt'
|
||||||
|
snapshot:
|
||||||
|
version_template: "{{ incpatch .Version }}-next"
|
||||||
|
changelog:
|
||||||
|
sort: asc
|
||||||
|
filters:
|
||||||
|
exclude:
|
||||||
|
- '^docs:'
|
||||||
|
- '^test:'
|
@ -1,5 +1,3 @@
|
|||||||
# This is an example .goreleaser.yml file with some sensible defaults.
|
|
||||||
# Make sure to check the documentation at https://goreleaser.com
|
|
||||||
before:
|
before:
|
||||||
hooks:
|
hooks:
|
||||||
# You may remove this if you don't use go modules.
|
# You may remove this if you don't use go modules.
|
||||||
@ -8,10 +6,15 @@ builds:
|
|||||||
- env:
|
- env:
|
||||||
- CGO_ENABLED=0
|
- CGO_ENABLED=0
|
||||||
goos:
|
goos:
|
||||||
|
- freebsd
|
||||||
- linux
|
- linux
|
||||||
|
goarch:
|
||||||
|
- "386"
|
||||||
|
- amd64
|
||||||
|
- arm64
|
||||||
|
|
||||||
archives:
|
archives:
|
||||||
- format: tar.gz
|
- format: binary
|
||||||
# this name template makes the OS and Arch compatible with the results of uname.
|
# this name template makes the OS and Arch compatible with the results of uname.
|
||||||
name_template: >-
|
name_template: >-
|
||||||
{{ .ProjectName }}_{{ .Version }}_
|
{{ .ProjectName }}_{{ .Version }}_
|
||||||
@ -36,8 +39,8 @@ changelog:
|
|||||||
- '^test:'
|
- '^test:'
|
||||||
|
|
||||||
gitea_urls:
|
gitea_urls:
|
||||||
api: https://git.andrewnw.xyz/api/v1
|
api: https://git.vern.cc/api/v1
|
||||||
download: https://git.andrewnw.xyz
|
download: https://git.vern.cc
|
||||||
# The lines beneath this are called `modelines`. See `:help modeline`
|
# The lines beneath this are called `modelines`. See `:help modeline`
|
||||||
# Feel free to remove those if you don't want/use them.
|
# Feel free to remove those if you don't want/use them.
|
||||||
# yaml-language-server: $schema=https://goreleaser.com/static/schema.json
|
# yaml-language-server: $schema=https://goreleaser.com/static/schema.json
|
13
.vscode/settings.json
vendored
13
.vscode/settings.json
vendored
@ -1,5 +1,14 @@
|
|||||||
{
|
{
|
||||||
"cSpell.words": [
|
"cSpell.words": [
|
||||||
"Cmds"
|
"Cmds",
|
||||||
]
|
"remotefetcher",
|
||||||
|
"knadh",
|
||||||
|
"koanf",
|
||||||
|
"mattn",
|
||||||
|
"maunium",
|
||||||
|
"mautrix",
|
||||||
|
"nikoksr",
|
||||||
|
"Strs"
|
||||||
|
],
|
||||||
|
"CodeGPT.apiKey": "CodeGPT Plus Beta"
|
||||||
}
|
}
|
19
.woodpecker/gitea.yml
Normal file
19
.woodpecker/gitea.yml
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
steps:
|
||||||
|
golang:
|
||||||
|
image: golang:1.23
|
||||||
|
commands:
|
||||||
|
- go install github.com/goreleaser/goreleaser/v2@v2.7.0
|
||||||
|
- goreleaser release -f .goreleaser/gitea.yml --release-notes=".changes/$(go run backy.go version -V).md"
|
||||||
|
environment:
|
||||||
|
GITEA_TOKEN:
|
||||||
|
from_secret: gitea_token
|
||||||
|
|
||||||
|
when:
|
||||||
|
event: tag
|
||||||
|
# release:
|
||||||
|
# image: goreleaser/goreleaser
|
||||||
|
# commands:
|
||||||
|
|
||||||
|
when:
|
||||||
|
- event: tag
|
||||||
|
branch: master
|
14
.woodpecker/go-lint.yml
Normal file
14
.woodpecker/go-lint.yml
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
steps:
|
||||||
|
build:
|
||||||
|
image: golang
|
||||||
|
commands:
|
||||||
|
- go build
|
||||||
|
- go test
|
||||||
|
release:
|
||||||
|
image: golangci/golangci-lint:v1.64.7
|
||||||
|
commands:
|
||||||
|
- golangci-lint run -v --timeout 5m
|
||||||
|
|
||||||
|
when:
|
||||||
|
- event: push
|
||||||
|
branch: develop
|
36
.woodpecker/publish-docs.yml
Normal file
36
.woodpecker/publish-docs.yml
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
steps:
|
||||||
|
build:
|
||||||
|
image: hugomods/hugo:ci
|
||||||
|
commands:
|
||||||
|
- git submodule foreach 'git fetch origin; git checkout $(git describe --tags `git rev-list --tags --max-count=1`);'
|
||||||
|
- cd docs
|
||||||
|
- hugo mod get -u github.com/divinerites/plausible-hugo
|
||||||
|
- hugo mod get -u github.com/McShelby/hugo-theme-relearn@7.3.1
|
||||||
|
- hugo
|
||||||
|
|
||||||
|
deploy:
|
||||||
|
image: codingkoopa/git-rsync-openssh
|
||||||
|
commands:
|
||||||
|
- cd docs
|
||||||
|
- echo "nameserver 1.1.1.1" > /etc/resolv.conf
|
||||||
|
- mkdir ~/.ssh && chmod -R 700 ~/.ssh
|
||||||
|
# - apt update -y && apt install openssh-client rsync -y
|
||||||
|
- echo "$SSH_HOST_KEY" > ~/.ssh/known_hosts
|
||||||
|
- echo -e '#!/bin/sh\necho "$SSH_PASSPHRASE"' | tr -d '\r' > ~/.ssh/.print_ssh_password
|
||||||
|
# - cat ~/.ssh/.print_ssh_password
|
||||||
|
- chmod 700 ~/.ssh/.print_ssh_password
|
||||||
|
- eval $(ssh-agent -s)
|
||||||
|
- echo "$SSH_DEPLOY_KEY" | tr -d '\r' | DISPLAY=":0.0" SSH_ASKPASS=~/.ssh/.print_ssh_password setsid ssh-add -
|
||||||
|
- rsync -atv --delete --progress public/ backy@backy.cybershell.xyz:docs
|
||||||
|
- rsync -atv --delete --progress vangen/ backy@backy.cybershell.xyz:vangen-go
|
||||||
|
environment:
|
||||||
|
SSH_HOST_KEY:
|
||||||
|
from_secret: ssh_host_key
|
||||||
|
SSH_DEPLOY_KEY:
|
||||||
|
from_secret: ssh_deploy_key
|
||||||
|
SSH_PASSPHRASE:
|
||||||
|
from_secret: ssh_passphrase
|
||||||
|
|
||||||
|
when:
|
||||||
|
- branch: master
|
||||||
|
- path: 'docs/**'
|
175
CHANGELOG.md
Normal file
175
CHANGELOG.md
Normal file
@ -0,0 +1,175 @@
|
|||||||
|
# Changelog
|
||||||
|
All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||||
|
adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html),
|
||||||
|
and is generated by [Changie](https://github.com/miniscruff/changie).
|
||||||
|
|
||||||
|
|
||||||
|
## v0.10.2 - 2025-03-19
|
||||||
|
### Added
|
||||||
|
* Notifications: http service added
|
||||||
|
* Variable support. Can be referenced with `%{var:nameOfVar}%` in select string fields.
|
||||||
|
### Changed
|
||||||
|
* vault: initialize vault before validating config
|
||||||
|
|
||||||
|
## v0.10.1 - 2025-03-11
|
||||||
|
### Added
|
||||||
|
* UserCommands: add ssh public keys when running locally
|
||||||
|
* UserCommands: add field CreateUserHome
|
||||||
|
### Changed
|
||||||
|
* UserCommands: create temp file when modifing password over SSH
|
||||||
|
* UserCommands: change field name
|
||||||
|
* Vault: keys are now referenced by `name`, and the actual data by `data`
|
||||||
|
|
||||||
|
## v0.10.0 - 2025-03-08
|
||||||
|
### Added
|
||||||
|
* Hooks: improved logging when executing
|
||||||
|
* User commands: adding SSH keys using config key `userSshPubKeys`
|
||||||
|
* directives: added support for fetching values using directive `%{externalSource:key}%`
|
||||||
|
### Changed
|
||||||
|
* Commands: if dir is not specified, run in config dir
|
||||||
|
* FileDirective: use the config directory if path is not absolute
|
||||||
|
* Host: changes to case of some keys
|
||||||
|
* Notifications: added external directive to sensitive keys
|
||||||
|
### Fixed
|
||||||
|
* LocalFetcher: return fetch error
|
||||||
|
* Lists: load file key before attempting to load from current file
|
||||||
|
* fix: host not in config file, but in ssh config, properly added to hosts struct
|
||||||
|
* SSH: password authentication bugs
|
||||||
|
* User commands: change user password works
|
||||||
|
|
||||||
|
## v0.9.1 - 2025-03-01
|
||||||
|
### Changed
|
||||||
|
* Use EnvVar AWS_PROFILE to get S3 profile
|
||||||
|
|
||||||
|
## v0.9.0 - 2025-02-28
|
||||||
|
### Added
|
||||||
|
* `list` command with subcommands `cmds` and `lists`
|
||||||
|
* Deprecation and unsupported warnings for old config keys
|
||||||
|
* CLI flag `--cmdStdOut` to output command's stdout/stderr to stdout
|
||||||
|
* Command type `remoteScript`. See docs for more info.
|
||||||
|
### Changed
|
||||||
|
* change to enums for Command type
|
||||||
|
* Cache now stores resources by URL hash for ease-of-lookup
|
||||||
|
* Changed PackageOperation to enums
|
||||||
|
### Fixed
|
||||||
|
* Local command's `dir` full path is now found with home directory
|
||||||
|
|
||||||
|
## v0.8.0 - 2025-02-15
|
||||||
|
### Changed
|
||||||
|
* Breaking: `cmd-lists` key changed to `cmdLists`
|
||||||
|
* Properly load list config
|
||||||
|
* Config file loading properly errors
|
||||||
|
* CI Configs
|
||||||
|
|
||||||
|
## v0.7.8 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* Github CI config
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
|
||||||
|
## v0.7.7 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
* CI configs
|
||||||
|
|
||||||
|
## v0.7.6 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
* CI configs
|
||||||
|
|
||||||
|
## v0.7.5 - 2025-02-14
|
||||||
|
### Changed
|
||||||
|
* CI configs
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
|
||||||
|
## v0.7.4 - 2025-02-14
|
||||||
|
### Changed
|
||||||
|
* CI configs
|
||||||
|
### Fixed
|
||||||
|
* v0.7.1: Incorrect local config file loading logic caused files to not be detected
|
||||||
|
|
||||||
|
## v0.7.3 - 2025-02-14
|
||||||
|
### Changed
|
||||||
|
* GoReleaser configs
|
||||||
|
|
||||||
|
## v0.7.2 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* CI configs
|
||||||
|
|
||||||
|
## v0.7.1 - 2025-02-14
|
||||||
|
### Fixed
|
||||||
|
* Incorrect local config file loading logic caused files to not be detected
|
||||||
|
|
||||||
|
## v0.7.0 - 2025-02-11
|
||||||
|
### Added
|
||||||
|
* [feat]: package `packageOperation` option `checkVersion` implemented
|
||||||
|
* user management added - see docs
|
||||||
|
* Support for remote config sources. Only config file and list can be used for now.
|
||||||
|
* Cache functionality - still a WIP
|
||||||
|
* Flag `--s3-endpoint` for config file fetching from S3
|
||||||
|
### Changed
|
||||||
|
* Internal refactoring of config setup
|
||||||
|
* Formatting and sending for notifications
|
||||||
|
* name of `configfetcher` to `remotefetcher`
|
||||||
|
* Flags that took comma-separated lists now have to be passed multiple times for each argument.
|
||||||
|
* Hosts passed to `exec host` now checked against default SSH config files
|
||||||
|
### Fixed
|
||||||
|
* Parsing of remote URLs when determining list config file path
|
||||||
|
* Incorrect error notification template value
|
||||||
|
|
||||||
|
## v0.6.1 - 2025-01-04
|
||||||
|
### Fixed
|
||||||
|
* When running a list, hooks now run explicitly after the command executes. Fixed panic due to improper logic.
|
||||||
|
## v0.6.0 - 2025-01-04
|
||||||
|
### Added
|
||||||
|
* Command Type Package - allows one to perform package operations [docs](https://backy.cybershell.xyz/config/packages/)
|
||||||
|
* Exec subcommand `host` allows for parallel execution of commands on hosts. [See docs](https://backy.cybershell.xyz/cli/exec)
|
||||||
|
|
||||||
|
## v0.5.0 - 2024-11-19
|
||||||
|
### Added
|
||||||
|
* Lists can now go in a file. See docs for more information.
|
||||||
|
* commands.[name].type: script now opens `scriptEnvFile`.
|
||||||
|
* Hooks for Commands.[name]. Error, success, and final. [#12]
|
||||||
|
### Changed
|
||||||
|
* GetKnownHosts is now a method of Host
|
||||||
|
### Fixed
|
||||||
|
* make command logger be used for errors, not just when running the command
|
||||||
|
|
||||||
|
## v0.4.0 - 2023-09-08
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
* Added `scriptEnvFile` to command object that allows one to specify an environment file (or any file really) when a `scriptFile` is run. Inspired by the practice of keeping environment variables and scripts or commands seperate.
|
||||||
|
* Basis for listing commands
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
* BREAKING: Notifications object now takes the form of service.id, where service can be "mail" or "matrix" and id is a unique id for the service.
|
||||||
|
* BREAKING: Since the change to the notifications object, cmd-lists' inner map key 'notifications' must be of the form service.id. id must be defined for that service. See notifications docs for aviliable services.
|
||||||
|
* Config parser is now the simpler Koanf - Keys are now case-sensitive
|
||||||
|
* Log size limited to 50 Mb
|
||||||
|
|
||||||
|
## v0.3.1 - 2023-07-20
|
||||||
|
### Changed
|
||||||
|
* If an SSH session failed to be created, the command would fail. This would be caused when restarting the SSH host. The SSH connection is attempted to be created again. If successful, the command is executed normally.
|
||||||
|
|
||||||
|
## v0.3.0 - 2023-01-07
|
||||||
|
### Added
|
||||||
|
* Getting environment variables and passwords from Vault (not tested yet)
|
||||||
|
* Vault configuration to config (not tested yet)
|
||||||
|
* Ability to run scripts from file on local machine on the remote host
|
||||||
|
* Ability to get ouput in the notification of a list for individual commands or all commands
|
||||||
|
### Changed
|
||||||
|
* Make SSH connections close after all commands have been run; reuse previous connections if needed
|
||||||
|
|
||||||
|
## 0.2.4 - 2023-02-18
|
||||||
|
### Added
|
||||||
|
* Notifications now display errors and the output of the failed command.
|
||||||
|
* CI configs for GitHub and Woodpecker
|
||||||
|
* Added `version` subcommand
|
||||||
|
### Changed
|
||||||
|
* Console logging can be disabled by setting `console-disabled` in the `logging` object
|
||||||
|
## Fixed
|
||||||
|
* If Host was not defined for an incomplete `hosts` object, any commands would fail as they could not look up the values in the SSH config files.
|
5
Makefile
5
Makefile
@ -1,5 +0,0 @@
|
|||||||
build:
|
|
||||||
go build
|
|
||||||
|
|
||||||
gorealeaser-build:
|
|
||||||
goreleaser release --snapshot --rm-dist
|
|
110
README.md
110
README.md
@ -1,112 +1,22 @@
|
|||||||
|
|
||||||
# Backy - an application to manage backups
|
# Backy - an application to manage backups
|
||||||
|
|
||||||
This app is in development, and is currently not stable. Expect core functionality to possiblly break.
|
See the [install documentation](https://backy.cybershell.xyz/getting-started/install/index.html)
|
||||||
|
|
||||||
## Installing
|
## Security
|
||||||
|
|
||||||
To install:
|
The latest version is currently the only supported version.
|
||||||
|
|
||||||
`go install git.andrewnw.xyz/CyberShell/backy@master`
|
|
||||||
|
|
||||||
This assumes you already have a working Go environment, if not please see [this page](https://golang.org/doc/install) first.
|
|
||||||
|
|
||||||
You can also download binaries [here](https://git.andrewnw.xyz/CyberShell/backy/releases) and [here](https://github.com/CybersShell/backy/releases).
|
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
- Define lists of commands and run them
|
- Allows easy configuration of executable commands
|
||||||
|
|
||||||
- Execute commands over SSH
|
- Allows for commands to be run on many hosts over SSH
|
||||||
|
|
||||||
- More to come.
|
- Commands can be grouped in list to run in specific order
|
||||||
|
|
||||||
To run a config:
|
- Notifications on completion and failure
|
||||||
|
|
||||||
`backy backup`
|
- Run in cron mode
|
||||||
|
|
||||||
Or to use a specific file:
|
- For any command, especially backup commands
|
||||||
```backy backup -f /path/to/file```
|
|
||||||
|
|
||||||
If you leave the config path blank, the following paths will be searched in order:
|
|
||||||
|
|
||||||
- `./backy.yaml`
|
|
||||||
- `~/.config/backy.yaml`
|
|
||||||
|
|
||||||
Create a file at `~/.config/backy.yaml`:
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
commands:
|
|
||||||
stop-docker-container:
|
|
||||||
cmd: docker
|
|
||||||
Args:
|
|
||||||
- compose
|
|
||||||
- -f /some/path/to/docker-compose.yaml
|
|
||||||
- down
|
|
||||||
# if host is not defined, cmd will be run locally
|
|
||||||
host: some-host
|
|
||||||
backup-docker-container-script:
|
|
||||||
cmd: /path/to/script
|
|
||||||
# The host has to be defined in the config file
|
|
||||||
host: some-host
|
|
||||||
shell-cmd:
|
|
||||||
cmd: rsync
|
|
||||||
shell: bash
|
|
||||||
Args:
|
|
||||||
- -av some-host:/path/to/data ~/Docker/Backups/docker-data
|
|
||||||
hostname:
|
|
||||||
cmd: hostname
|
|
||||||
|
|
||||||
cmd-configs:
|
|
||||||
cmds-to-run: # this can be any name you want
|
|
||||||
# all commands have to be defined
|
|
||||||
order:
|
|
||||||
- stop-docker-container
|
|
||||||
- backup-docker-container-script
|
|
||||||
- shell-cmd
|
|
||||||
- hostname
|
|
||||||
notifications:
|
|
||||||
- matrix
|
|
||||||
name: backup-some-server
|
|
||||||
hostname:
|
|
||||||
name: hostname
|
|
||||||
order:
|
|
||||||
- hostname
|
|
||||||
notifications:
|
|
||||||
- prod-email
|
|
||||||
|
|
||||||
hosts:
|
|
||||||
some-host:
|
|
||||||
hostname: some-hostname
|
|
||||||
config: ~/.ssh/config
|
|
||||||
user: user
|
|
||||||
privatekeypath: /path/to/private/key
|
|
||||||
port: 22
|
|
||||||
password:
|
|
||||||
|
|
||||||
|
|
||||||
logging:
|
|
||||||
verbose: true
|
|
||||||
file: /path/to/logs/commands.log
|
|
||||||
console: false
|
|
||||||
cmd-std-out: false
|
|
||||||
|
|
||||||
|
|
||||||
notifications:
|
|
||||||
prod-email:
|
|
||||||
id: prod-email
|
|
||||||
type: mail
|
|
||||||
host: yourhost.tld:port
|
|
||||||
senderAddress: email@domain.tld
|
|
||||||
to:
|
|
||||||
- admin@domain.tld
|
|
||||||
username: smtp-username@domain.tld
|
|
||||||
password: your-password-here
|
|
||||||
matrix:
|
|
||||||
id: matrix
|
|
||||||
type: matrix
|
|
||||||
home-server: your-home-server.tld
|
|
||||||
room-id: room-id
|
|
||||||
access-token: your-access-token
|
|
||||||
user-id: your-user-id
|
|
||||||
|
|
||||||
```
|
|
||||||
|
27
backy.code-workspace
Normal file
27
backy.code-workspace
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
{
|
||||||
|
"folders": [
|
||||||
|
{
|
||||||
|
"name": "backy",
|
||||||
|
"path": "."
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cSpell.words": [
|
||||||
|
"Autorestic",
|
||||||
|
"changie",
|
||||||
|
"Cmds",
|
||||||
|
"CMDSTDOUT",
|
||||||
|
"goreleaser",
|
||||||
|
"knadh",
|
||||||
|
"koanf",
|
||||||
|
"mattn",
|
||||||
|
"maunium",
|
||||||
|
"mautrix",
|
||||||
|
"nikoksr",
|
||||||
|
"packagemanagercommon",
|
||||||
|
"rawbytes",
|
||||||
|
"remotefetcher",
|
||||||
|
"Strs"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
1
cmd/.gitignore
vendored
1
cmd/.gitignore
vendored
@ -1 +1,2 @@
|
|||||||
*.yaml
|
*.yaml
|
||||||
|
*.yml
|
@ -12,11 +12,10 @@ import (
|
|||||||
|
|
||||||
var (
|
var (
|
||||||
backupCmd = &cobra.Command{
|
backupCmd = &cobra.Command{
|
||||||
Use: "backup [--lists==list1,list2]",
|
Use: "backup [--lists=list1 --lists list2 ... | -l list1 -l list2 ...]",
|
||||||
Short: "Runs commands defined in config file.",
|
Short: "Runs commands defined in config file. Use -l flag multiple times to run multiple lists.",
|
||||||
Long: `Backup executes commands defined in config file.
|
Long: "Backup executes commands defined in config file.\nUse the --lists or -l flag to execute the specified lists. If not flag is not given, all lists will be executed.",
|
||||||
Use the --lists flag to execute the specified commands.`,
|
Run: Backup,
|
||||||
Run: Backup,
|
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -24,14 +23,26 @@ var (
|
|||||||
var cmdLists []string
|
var cmdLists []string
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
backupCmd.Flags().StringSliceVarP(&cmdLists, "lists", "l", nil, "Accepts a comma-separated names of command lists to execute.")
|
backupCmd.Flags().StringArrayVarP(&cmdLists, "lists", "l", nil, "Accepts comma-separated names of command lists to execute.")
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func Backup(cmd *cobra.Command, args []string) {
|
func Backup(cmd *cobra.Command, args []string) {
|
||||||
backyConfOpts := backy.NewOpts(cfgFile, backy.AddCommandLists(cmdLists))
|
backyConfOpts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.AddCommandLists(cmdLists),
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.EnableCommandStdOut(cmdStdOut),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
|
||||||
backyConfOpts.InitConfig()
|
backyConfOpts.InitConfig()
|
||||||
config := backy.ReadConfig(backyConfOpts)
|
backyConfOpts.ParseConfigurationFile()
|
||||||
config.RunBackyConfig("")
|
|
||||||
|
backyConfOpts.RunListConfig("")
|
||||||
|
for _, host := range backyConfOpts.Hosts {
|
||||||
|
if host.SshClient != nil {
|
||||||
|
host.SshClient.Close()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
54
cmd/backup_test.go
Normal file
54
cmd/backup_test.go
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
package cmd
|
||||||
|
|
||||||
|
// import (
|
||||||
|
// "bufio"
|
||||||
|
// "encoding/json"
|
||||||
|
// "os"
|
||||||
|
// "os/exec"
|
||||||
|
// "strings"
|
||||||
|
// "testing"
|
||||||
|
|
||||||
|
// "github.com/stretchr/testify/assert"
|
||||||
|
// )
|
||||||
|
|
||||||
|
// // TestConfigOptions tests the configuration options for the backy package.
|
||||||
|
// func Test_ErrorHook(t *testing.T) {
|
||||||
|
// configFile := "-f ../../tests/ErrorHook.yml"
|
||||||
|
// logFile := "--log-file=ErrorHook.log"
|
||||||
|
// backyCommand := exec.Command("go", "run", "../../backy.go", configFile, logFile, "backup")
|
||||||
|
// backyCommand.Stderr = os.Stdout
|
||||||
|
// backyCommand.Stdout = os.Stdout
|
||||||
|
// err := backyCommand.Run()
|
||||||
|
// assert.Nil(t, err)
|
||||||
|
// os.Remove("ErrorHook.log")
|
||||||
|
// logFileData, logFileErr := os.ReadFile("ErrorHook.log")
|
||||||
|
// if logFileErr != nil {
|
||||||
|
// assert.FailNow(t, logFileErr.Error())
|
||||||
|
|
||||||
|
// }
|
||||||
|
// var JsonData []map[string]interface{}
|
||||||
|
// jsonScanner := bufio.NewScanner(strings.NewReader(string(logFileData)))
|
||||||
|
|
||||||
|
// for jsonScanner.Scan() {
|
||||||
|
// var jsonDataLine map[string]interface{}
|
||||||
|
// err = json.Unmarshal(jsonScanner.Bytes(), &jsonDataLine)
|
||||||
|
// assert.Nil(t, err)
|
||||||
|
// JsonData = append(JsonData, jsonDataLine)
|
||||||
|
// }
|
||||||
|
// for _, v := range JsonData {
|
||||||
|
// _, ok := v["error"]
|
||||||
|
// if !ok {
|
||||||
|
// assert.FailNow(t, "error does not exist\n")
|
||||||
|
// // return
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// // t.Logf("%s", logFileData)
|
||||||
|
// // t.Logf("%v", JsonData)
|
||||||
|
// }
|
||||||
|
|
||||||
|
// func TestBackupErrorHook(t *testing.T) {
|
||||||
|
// logFile = "ErrorHook.log"
|
||||||
|
|
||||||
|
// configFile = "../tests/ErrorHook.yml"
|
||||||
|
|
||||||
|
// }
|
31
cmd/config.go
Normal file
31
cmd/config.go
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
package cmd
|
||||||
|
|
||||||
|
// import (
|
||||||
|
// "git.andrewnw.xyz/CyberShell/backy/pkg/backy"
|
||||||
|
|
||||||
|
// "github.com/spf13/cobra"
|
||||||
|
// )
|
||||||
|
|
||||||
|
// var (
|
||||||
|
// configCmd = &cobra.Command{
|
||||||
|
// Use: "config list ...",
|
||||||
|
// Short: "Runs commands defined in config file.",
|
||||||
|
// Long: `Cron executes commands at the time defined in config file.`,
|
||||||
|
// Run: config,
|
||||||
|
// }
|
||||||
|
|
||||||
|
// cmds []string
|
||||||
|
// lists []string
|
||||||
|
// )
|
||||||
|
|
||||||
|
// func config(cmd *cobra.Command, args []string) {
|
||||||
|
|
||||||
|
// opts := backy.NewConfigOptions(configFile, backy.cronEnabled())
|
||||||
|
// opts.InitConfig()
|
||||||
|
|
||||||
|
// }
|
||||||
|
|
||||||
|
// func init() {
|
||||||
|
|
||||||
|
// configCmd.PersistentFlags().StringArrayVarP(&cmds, "cmds", "c", nil, "Accepts comma-seperated list of commands to list")
|
||||||
|
// }
|
17
cmd/cron.go
17
cmd/cron.go
@ -8,17 +8,24 @@ import (
|
|||||||
|
|
||||||
var (
|
var (
|
||||||
cronCmd = &cobra.Command{
|
cronCmd = &cobra.Command{
|
||||||
Use: "cron command ...",
|
Use: "cron [flags]",
|
||||||
Short: "Runs commands defined in config file.",
|
Short: "Starts a scheduler that runs lists defined in config file.",
|
||||||
Long: `Cron executes commands at the time defined in config file.`,
|
Long: `Cron starts a scheduler that executes command lists at the time defined in config file.`,
|
||||||
Run: cron,
|
Run: cron,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
func cron(cmd *cobra.Command, args []string) {
|
func cron(cmd *cobra.Command, args []string) {
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
|
opts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.EnableCron(),
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.EnableCommandStdOut(cmdStdOut),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
|
||||||
opts := backy.NewOpts(cfgFile, backy.UseCron())
|
|
||||||
opts.InitConfig()
|
opts.InitConfig()
|
||||||
|
opts.ParseConfigurationFile()
|
||||||
|
|
||||||
backy.ReadConfig(opts).Cron()
|
opts.Cron()
|
||||||
}
|
}
|
||||||
|
33
cmd/exec.go
33
cmd/exec.go
@ -14,21 +14,30 @@ import (
|
|||||||
var (
|
var (
|
||||||
execCmd = &cobra.Command{
|
execCmd = &cobra.Command{
|
||||||
Use: "exec command ...",
|
Use: "exec command ...",
|
||||||
Short: "Runs commands defined in config file.",
|
Short: "Runs commands defined in config file in order given.",
|
||||||
Long: `Exec executes commands defined in config file.`,
|
Long: `Exec executes commands defined in config file in order given.`,
|
||||||
Run: execute,
|
Run: execute,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
func execute(cmd *cobra.Command, args []string) {
|
func init() {
|
||||||
|
execCmd.AddCommand(hostExecCommand, hostsExecCommand)
|
||||||
if len(args) < 1 {
|
|
||||||
logging.ExitWithMSG("Please provide a command to run. Pass --help to see options.", 0, nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
opts := backy.NewOpts(cfgFile, backy.AddCommands(args))
|
|
||||||
opts.InitConfig()
|
|
||||||
// opts.InitMongo()
|
|
||||||
backy.ReadConfig(opts).ExecuteCmds()
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func execute(cmd *cobra.Command, args []string) {
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
|
if len(args) < 1 {
|
||||||
|
logging.ExitWithMSG("Please provide a command to run. Pass --help to see options.", 1, nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
opts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.AddCommands(args),
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.EnableCommandStdOut(cmdStdOut),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
opts.InitConfig()
|
||||||
|
opts.ParseConfigurationFile()
|
||||||
|
opts.ExecuteCmds()
|
||||||
|
}
|
||||||
|
81
cmd/host.go
Normal file
81
cmd/host.go
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
package cmd
|
||||||
|
|
||||||
|
import (
|
||||||
|
"git.andrewnw.xyz/CyberShell/backy/pkg/backy"
|
||||||
|
"git.andrewnw.xyz/CyberShell/backy/pkg/logging"
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
hostExecCommand = &cobra.Command{
|
||||||
|
Use: "host [--command=command1 --command=command2 ... | -c command1 -c command2 ...] [--hosts=host1 --hosts=hosts2 ... | -m host1 -m host2 ...] ",
|
||||||
|
Short: "Runs command defined in config file on the hosts in order specified.",
|
||||||
|
Long: "Host executes specified commands on the hosts defined in config file.\nUse the --commands or -c flag to choose the commands.",
|
||||||
|
Run: Host,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
// Holds list of hosts to run commands on
|
||||||
|
var hostsList []string
|
||||||
|
|
||||||
|
// Holds command list to run
|
||||||
|
var cmdList []string
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
|
||||||
|
hostExecCommand.Flags().StringArrayVarP(&hostsList, "hosts", "m", nil, "Accepts space-separated names of hosts. Specify multiple times for multiple hosts.")
|
||||||
|
hostExecCommand.Flags().StringArrayVarP(&cmdList, "command", "c", nil, "Accepts space-separated names of commands. Specify multiple times for multiple commands.")
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// cli input should be hosts and commands. Hosts are defined in config files.
|
||||||
|
// commands can be passed by the following mutually exclusive options:
|
||||||
|
// 1. as a list of commands defined in the config file
|
||||||
|
// 2. stdin (on command line) (TODO)
|
||||||
|
|
||||||
|
func Host(cmd *cobra.Command, args []string) {
|
||||||
|
backyConfOpts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.EnableCommandStdOut(cmdStdOut),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
backyConfOpts.InitConfig()
|
||||||
|
|
||||||
|
backyConfOpts.ParseConfigurationFile()
|
||||||
|
|
||||||
|
// check CLI input
|
||||||
|
if hostsList == nil {
|
||||||
|
logging.ExitWithMSG("error: hosts must be specified", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, h := range hostsList {
|
||||||
|
if backy.IsHostLocal(h) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
// check if h exists in the config file
|
||||||
|
_, hostFound := backyConfOpts.Hosts[h]
|
||||||
|
if !hostFound {
|
||||||
|
// check if h exists in the SSH config file
|
||||||
|
hostFoundInConfig, s := backy.DoesHostHaveHostName(h)
|
||||||
|
if !hostFoundInConfig {
|
||||||
|
logging.ExitWithMSG("host "+h+" not found", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
if backyConfOpts.Hosts == nil {
|
||||||
|
backyConfOpts.Hosts = make(map[string]*backy.Host)
|
||||||
|
}
|
||||||
|
// create host with hostname and host
|
||||||
|
backyConfOpts.Hosts[h] = &backy.Host{Host: h, HostName: s}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if cmdList == nil {
|
||||||
|
logging.ExitWithMSG("error: commands must be specified", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
for _, c := range cmdList {
|
||||||
|
_, cmdFound := backyConfOpts.Cmds[c]
|
||||||
|
if !cmdFound {
|
||||||
|
logging.ExitWithMSG("cmd "+c+" not found", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
backyConfOpts.ExecCmdsOnHosts(cmdList, hostsList)
|
||||||
|
}
|
91
cmd/hosts.go
Normal file
91
cmd/hosts.go
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
package cmd
|
||||||
|
|
||||||
|
import (
|
||||||
|
"maps"
|
||||||
|
"slices"
|
||||||
|
|
||||||
|
"git.andrewnw.xyz/CyberShell/backy/pkg/backy"
|
||||||
|
"git.andrewnw.xyz/CyberShell/backy/pkg/logging"
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
hostsExecCommand = &cobra.Command{
|
||||||
|
Use: "hosts [--command=command1 --command=command2 ... | -c command1 -c command2 ...]",
|
||||||
|
Short: "Runs command defined in config file on the hosts in order specified.",
|
||||||
|
Long: "Hosts executes specified commands on all the hosts defined in config file.\nUse the --commands or -c flag to choose the commands.",
|
||||||
|
Run: Hosts,
|
||||||
|
}
|
||||||
|
|
||||||
|
hostsListExecCommand = &cobra.Command{
|
||||||
|
Use: "list list1 list2 ...",
|
||||||
|
Short: "Runs lists in order specified defined in config file on all hosts.",
|
||||||
|
Long: "Lists executes specified lists on all the hosts defined in hosts config.\nPass the names of lists as arguments after command.",
|
||||||
|
Run: HostsList,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
hostsExecCommand.AddCommand(hostsListExecCommand)
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// cli input should be hosts and commands. Hosts are defined in config files.
|
||||||
|
// commands can be passed by the following mutually exclusive options:
|
||||||
|
// 1. as a list of commands defined in the config file
|
||||||
|
// 2. stdin (on command line) (TODO)
|
||||||
|
|
||||||
|
func Hosts(cmd *cobra.Command, args []string) {
|
||||||
|
backyConfOpts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.EnableCommandStdOut(cmdStdOut),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
backyConfOpts.InitConfig()
|
||||||
|
|
||||||
|
backyConfOpts.ParseConfigurationFile()
|
||||||
|
|
||||||
|
for _, h := range backyConfOpts.Hosts {
|
||||||
|
|
||||||
|
hostsList = append(hostsList, h.Host)
|
||||||
|
}
|
||||||
|
|
||||||
|
if cmdList == nil {
|
||||||
|
logging.ExitWithMSG("error: commands must be specified", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
for _, c := range cmdList {
|
||||||
|
_, cmdFound := backyConfOpts.Cmds[c]
|
||||||
|
if !cmdFound {
|
||||||
|
logging.ExitWithMSG("cmd "+c+" not found", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
backyConfOpts.ExecCmdsOnHosts(cmdList, hostsList)
|
||||||
|
}
|
||||||
|
|
||||||
|
func HostsList(cmd *cobra.Command, args []string) {
|
||||||
|
backyConfOpts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.EnableCommandStdOut(cmdStdOut),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
backyConfOpts.InitConfig()
|
||||||
|
|
||||||
|
backyConfOpts.ParseConfigurationFile()
|
||||||
|
|
||||||
|
if len(args) == 0 {
|
||||||
|
logging.ExitWithMSG("error: no lists specified", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, l := range args {
|
||||||
|
_, listFound := backyConfOpts.CmdConfigLists[l]
|
||||||
|
if !listFound {
|
||||||
|
logging.ExitWithMSG("list "+l+" not found", 1, &backyConfOpts.Logger)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
maps.DeleteFunc(backyConfOpts.CmdConfigLists, func(k string, v *backy.CmdList) bool {
|
||||||
|
return !slices.Contains(args, k)
|
||||||
|
})
|
||||||
|
|
||||||
|
backyConfOpts.ExecuteListOnHosts(args)
|
||||||
|
}
|
90
cmd/list.go
Normal file
90
cmd/list.go
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
// backup.go
|
||||||
|
// Copyright (C) Andrew Woodlee 2023
|
||||||
|
// License: Apache-2.0
|
||||||
|
|
||||||
|
package cmd
|
||||||
|
|
||||||
|
import (
|
||||||
|
"git.andrewnw.xyz/CyberShell/backy/pkg/backy"
|
||||||
|
"git.andrewnw.xyz/CyberShell/backy/pkg/logging"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
listCmd = &cobra.Command{
|
||||||
|
Use: "list [command]",
|
||||||
|
Short: "List commands, lists, or hosts defined in config file.",
|
||||||
|
Long: "List commands, lists, or hosts defined in config file",
|
||||||
|
}
|
||||||
|
|
||||||
|
listCmds = &cobra.Command{
|
||||||
|
Use: "cmds [cmd1 cmd2 cmd3...]",
|
||||||
|
Short: "List commands defined in config file.",
|
||||||
|
Long: "List commands defined in config file",
|
||||||
|
Run: ListCommands,
|
||||||
|
}
|
||||||
|
listCmdLists = &cobra.Command{
|
||||||
|
Use: "lists [list1 list2 ...]",
|
||||||
|
Short: "List lists defined in config file.",
|
||||||
|
Long: "List lists defined in config file",
|
||||||
|
Run: ListCommandLists,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
var listsToList []string
|
||||||
|
var cmdsToList []string
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
listCmd.AddCommand(listCmds, listCmdLists)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func ListCommands(cmd *cobra.Command, args []string) {
|
||||||
|
|
||||||
|
// setup based on whats passed in:
|
||||||
|
// - cmds
|
||||||
|
// - lists
|
||||||
|
// - if none, list all commands
|
||||||
|
if len(args) > 0 {
|
||||||
|
cmdsToList = args
|
||||||
|
} else {
|
||||||
|
logging.ExitWithMSG("Error: list cmds subcommand needs commands to list", 1, nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
|
opts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
|
||||||
|
opts.InitConfig()
|
||||||
|
opts.ParseConfigurationFile()
|
||||||
|
|
||||||
|
for _, v := range cmdsToList {
|
||||||
|
opts.ListCommand(v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func ListCommandLists(cmd *cobra.Command, args []string) {
|
||||||
|
|
||||||
|
parseS3Config()
|
||||||
|
|
||||||
|
if len(args) > 0 {
|
||||||
|
listsToList = args
|
||||||
|
} else {
|
||||||
|
logging.ExitWithMSG("Error: lists subcommand needs lists", 1, nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
opts := backy.NewConfigOptions(configFile,
|
||||||
|
backy.SetLogFile(logFile),
|
||||||
|
backy.SetHostsConfigFile(hostsConfigFile))
|
||||||
|
|
||||||
|
opts.InitConfig()
|
||||||
|
opts.ParseConfigurationFile()
|
||||||
|
|
||||||
|
for _, v := range listsToList {
|
||||||
|
opts.ListCommandList(v)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
23
cmd/root.go
23
cmd/root.go
@ -13,8 +13,12 @@ import (
|
|||||||
|
|
||||||
var (
|
var (
|
||||||
// Used for flags.
|
// Used for flags.
|
||||||
cfgFile string
|
configFile string
|
||||||
verbose bool
|
hostsConfigFile string
|
||||||
|
verbose bool
|
||||||
|
cmdStdOut bool
|
||||||
|
logFile string
|
||||||
|
s3Endpoint string
|
||||||
|
|
||||||
rootCmd = &cobra.Command{
|
rootCmd = &cobra.Command{
|
||||||
Use: "backy",
|
Use: "backy",
|
||||||
@ -32,9 +36,18 @@ func Execute() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
rootCmd.PersistentFlags().StringVar(&logFile, "logFile", "", "log file to write to")
|
||||||
|
rootCmd.PersistentFlags().BoolVar(&cmdStdOut, "cmdStdOut", false, "Pass to print command output to stdout")
|
||||||
|
|
||||||
rootCmd.PersistentFlags().StringVarP(&cfgFile, "config", "f", "", "config file to read from")
|
rootCmd.PersistentFlags().StringVarP(&configFile, "config", "f", "", "config file to read from")
|
||||||
|
rootCmd.PersistentFlags().StringVar(&hostsConfigFile, "hostsConfig", "", "yaml hosts file to read from")
|
||||||
rootCmd.PersistentFlags().BoolVarP(&verbose, "verbose", "v", false, "Sets verbose level")
|
rootCmd.PersistentFlags().BoolVarP(&verbose, "verbose", "v", false, "Sets verbose level")
|
||||||
|
rootCmd.PersistentFlags().StringVar(&s3Endpoint, "s3Endpoint", "", "Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.")
|
||||||
rootCmd.AddCommand(backupCmd, execCmd, cronCmd)
|
rootCmd.AddCommand(backupCmd, execCmd, cronCmd, versionCmd, listCmd)
|
||||||
|
}
|
||||||
|
|
||||||
|
func parseS3Config() {
|
||||||
|
if s3Endpoint != "" {
|
||||||
|
os.Setenv("S3_ENDPOINT", s3Endpoint)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
39
cmd/version.go
Normal file
39
cmd/version.go
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
package cmd
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
|
||||||
|
"github.com/spf13/cobra"
|
||||||
|
)
|
||||||
|
|
||||||
|
const versionStr = "0.10.2"
|
||||||
|
|
||||||
|
var (
|
||||||
|
versionCmd = &cobra.Command{
|
||||||
|
Use: "version [flags]",
|
||||||
|
Short: "Prints the version and exits",
|
||||||
|
Long: "Prints the version and exits. No arguments just prints the version number only.",
|
||||||
|
Run: version,
|
||||||
|
}
|
||||||
|
numOnly bool
|
||||||
|
vPre bool
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
versionCmd.PersistentFlags().BoolVarP(&numOnly, "num", "n", false, "Output the version number only.")
|
||||||
|
versionCmd.PersistentFlags().BoolVarP(&vPre, "vpre", "V", false, "Output the version with v prefixed.")
|
||||||
|
}
|
||||||
|
|
||||||
|
func version(cmd *cobra.Command, args []string) {
|
||||||
|
|
||||||
|
if numOnly && !vPre {
|
||||||
|
fmt.Printf("%s\n", versionStr)
|
||||||
|
} else if vPre && !numOnly {
|
||||||
|
fmt.Printf("v%s\n", versionStr)
|
||||||
|
} else {
|
||||||
|
fmt.Printf("Backy version: %s\n", versionStr)
|
||||||
|
}
|
||||||
|
|
||||||
|
os.Exit(0)
|
||||||
|
}
|
2
docs/.gitignore
vendored
Normal file
2
docs/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
public/
|
||||||
|
resources/_gen
|
0
docs/.hugo_build.lock
Normal file
0
docs/.hugo_build.lock
Normal file
6
docs/archetypes/default.md
Normal file
6
docs/archetypes/default.md
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
title: "{{ replace .Name "-" " " | title }}"
|
||||||
|
date: {{ .Date }}
|
||||||
|
draft: true
|
||||||
|
---
|
||||||
|
|
78
docs/config.yaml
Normal file
78
docs/config.yaml
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
baseURL: https://backy.cybershell.xyz/
|
||||||
|
languageCode: en-us
|
||||||
|
title: A tool for commands
|
||||||
|
theme:
|
||||||
|
- hugo-theme-relearn
|
||||||
|
- plausible-hugo
|
||||||
|
outputs:
|
||||||
|
home:
|
||||||
|
- HTML
|
||||||
|
- RSS
|
||||||
|
- PRINT
|
||||||
|
module:
|
||||||
|
imports:
|
||||||
|
- path: github.com/divinerites/plausible-hugo
|
||||||
|
- path: github.com/McShelby/hugo-theme-relearn
|
||||||
|
params:
|
||||||
|
themeVariant:
|
||||||
|
- auto: []
|
||||||
|
identifier: relearn-auto
|
||||||
|
name: Relearn Light/Dark
|
||||||
|
- identifier: relearn-light
|
||||||
|
- identifier: relearn-dark
|
||||||
|
- identifier: relearn-bright
|
||||||
|
- auto:
|
||||||
|
- zen-light
|
||||||
|
- zen-dark
|
||||||
|
identifier: zen-auto
|
||||||
|
name: Zen Light/Dark
|
||||||
|
- identifier: zen-light
|
||||||
|
- identifier: zen-dark
|
||||||
|
- auto:
|
||||||
|
- learn
|
||||||
|
- neon
|
||||||
|
identifier: retro-auto
|
||||||
|
name: Retro Learn/Neon
|
||||||
|
- identifier: neon
|
||||||
|
- identifier: learn
|
||||||
|
plausible:
|
||||||
|
enable: true
|
||||||
|
domain: backy.cybershell.xyz
|
||||||
|
outbound_link: true
|
||||||
|
gitstar: false
|
||||||
|
selfhosted_domain: stats.andrewnw.com
|
||||||
|
author:
|
||||||
|
name: Andrew Woodlee
|
||||||
|
alwaysopen: false
|
||||||
|
editURL: ""
|
||||||
|
description: ""
|
||||||
|
showVisitedLinks: false
|
||||||
|
disableSearch: false
|
||||||
|
disableSearchHiddenPages: false
|
||||||
|
disableSeoHiddenPages: false
|
||||||
|
disableTagHiddenPages: false
|
||||||
|
disableAssetsBusting: false
|
||||||
|
disableGeneratorVersion: false
|
||||||
|
disableInlineCopyToClipBoard: false
|
||||||
|
disableShortcutsTitle: false
|
||||||
|
disableLandingPageButton: true
|
||||||
|
disableLanguageSwitchingButton: false
|
||||||
|
disableBreadcrumb: true
|
||||||
|
disableToc: false
|
||||||
|
math: true
|
||||||
|
customMathJaxURL: https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js
|
||||||
|
mathJaxInitialize: "{}"
|
||||||
|
mermaid: true
|
||||||
|
customMermaidURL: https://unpkg.com/mermaid/dist/mermaid.min.js
|
||||||
|
mermaidInitialize: '{ "theme": "default" }'
|
||||||
|
disableSwagger: false
|
||||||
|
customSwaggerURL: https://unpkg.com/rapidoc/dist/rapidoc-min.js
|
||||||
|
swaggerInitialize: '{ "theme": "light" }'
|
||||||
|
disableNextPrev: true
|
||||||
|
ordersectionsby: weight
|
||||||
|
titleSeparator: "-"
|
||||||
|
collapsibleMenu: true
|
||||||
|
additionalContentLanguage:
|
||||||
|
- en
|
||||||
|
disableExplicitIndexURLs: false
|
||||||
|
externalLinkTarget: _blank
|
32
docs/content/_index.md
Normal file
32
docs/content/_index.md
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
+++
|
||||||
|
archetype = "home"
|
||||||
|
title = "Backy"
|
||||||
|
+++
|
||||||
|
|
||||||
|
Backy is a tool for automating data backup and remote command execution. It can work over SSH, and provides completion and failure notifications, error reporting, and more.
|
||||||
|
|
||||||
|
Why the name Backy? Because I wanted an app for backups.
|
||||||
|
|
||||||
|
View the [changelog here](https://git.andrewnw.xyz/CyberShell/backy/src/branch/master/CHANGELOG.md).
|
||||||
|
|
||||||
|
{{% notice tip %}}
|
||||||
|
Feel free to open a [PR](https://git.andrewnw.xyz/CyberShell/backy/pulls), raise an [issue](https://git.andrewnw.xyz/CyberShell/backy/issues "Open a Gitea Issue")(s), or request new feature(s).
|
||||||
|
{{% /notice %}}
|
||||||
|
|
||||||
|
## Features
|
||||||
|
|
||||||
|
- Allows easy configuration of executable commands
|
||||||
|
|
||||||
|
- Allows for running package operations
|
||||||
|
|
||||||
|
- Allows configuring failure, success, and final hooks
|
||||||
|
|
||||||
|
- Allows for commands to be run on many hosts over SSH
|
||||||
|
|
||||||
|
- Commands can be grouped in list to run in specific order
|
||||||
|
|
||||||
|
- Notifications on completion and failure
|
||||||
|
|
||||||
|
- Run in cron mode
|
||||||
|
|
||||||
|
- For any command, especially backup commands
|
215
docs/content/cli/_index.md
Normal file
215
docs/content/cli/_index.md
Normal file
@ -0,0 +1,215 @@
|
|||||||
|
---
|
||||||
|
title: CLI
|
||||||
|
weight: 4
|
||||||
|
---
|
||||||
|
|
||||||
|
This page lists documentation for the CLI.
|
||||||
|
|
||||||
|
## Backy
|
||||||
|
|
||||||
|
```
|
||||||
|
Backy is a command-line application useful for configuring backups, or any commands run in sequence.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy [command]
|
||||||
|
|
||||||
|
Available Commands:
|
||||||
|
backup Runs commands defined in config file. Use -l flag multiple times to run multiple lists.
|
||||||
|
completion Generate the autocompletion script for the specified shell
|
||||||
|
cron Starts a scheduler that runs lists defined in config file.
|
||||||
|
exec Runs commands defined in config file in order given.
|
||||||
|
help Help about any command
|
||||||
|
list List commands, lists, or hosts defined in config file.
|
||||||
|
version Prints the version and exits
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
-h, --help help for backy
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
|
||||||
|
Use "backy [command] --help" for more information about a command.
|
||||||
|
```
|
||||||
|
|
||||||
|
# Subcommands
|
||||||
|
|
||||||
|
## backup
|
||||||
|
|
||||||
|
```
|
||||||
|
Backup executes commands defined in config file.
|
||||||
|
Use the --lists or -l flag to execute the specified lists. If not flag is not given, all lists will be executed.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy backup [--lists=list1 --lists list2 ... | -l list1 -l list2 ...] [flags]
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for backup
|
||||||
|
-l, --lists stringArray Accepts comma-separated names of command lists to execute.
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
||||||
|
|
||||||
|
## cron
|
||||||
|
|
||||||
|
```
|
||||||
|
Cron starts a scheduler that executes command lists at the time defined in config file.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy cron [flags]
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for cron
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
||||||
|
|
||||||
|
## exec
|
||||||
|
|
||||||
|
```
|
||||||
|
Exec executes commands defined in config file in order given.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy exec command ... [flags]
|
||||||
|
backy exec [command]
|
||||||
|
|
||||||
|
Available Commands:
|
||||||
|
host Runs command defined in config file on the hosts in order specified.
|
||||||
|
hosts Runs command defined in config file on the hosts in order specified.
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for exec
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
|
||||||
|
Use "backy exec [command] --help" for more information about a command.
|
||||||
|
```
|
||||||
|
|
||||||
|
### exec host
|
||||||
|
|
||||||
|
```
|
||||||
|
Host executes specified commands on the hosts defined in config file.
|
||||||
|
Use the --commands or -c flag to choose the commands.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy exec host [--command=command1 --command=command2 ... | -c command1 -c command2 ...] [--hosts=host1 --hosts=hosts2 ... | -m host1 -m host2 ...] [flags]
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-c, --command stringArray Accepts space-separated names of commands. Specify multiple times for multiple commands.
|
||||||
|
-h, --help help for host
|
||||||
|
-m, --hosts stringArray Accepts space-separated names of hosts. Specify multiple times for multiple hosts.
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
||||||
|
|
||||||
|
## version
|
||||||
|
|
||||||
|
```
|
||||||
|
Prints the version and exits. No arguments just prints the version number only.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy version [flags]
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for version
|
||||||
|
-n, --num Output the version number only.
|
||||||
|
-V, --vpre Output the version with v prefixed.
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
||||||
|
|
||||||
|
## list
|
||||||
|
|
||||||
|
```
|
||||||
|
List commands, lists, or hosts defined in config file
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy list [command]
|
||||||
|
|
||||||
|
Available Commands:
|
||||||
|
cmds List commands defined in config file.
|
||||||
|
lists List lists defined in config file.
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for list
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
|
||||||
|
Use "backy list [command] --help" for more information about a command.
|
||||||
|
```
|
||||||
|
## list cmds
|
||||||
|
|
||||||
|
```
|
||||||
|
List commands defined in config file
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy list cmds [cmd1 cmd2 cmd3...] [flags]
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for cmds
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
||||||
|
## list lists
|
||||||
|
|
||||||
|
```
|
||||||
|
List lists defined in config file
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
backy list lists [list1 list2 ...] [flags]
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
-h, --help help for lists
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--hostsConfig string yaml hosts file to read from
|
||||||
|
--logFile string log file to write to
|
||||||
|
--s3Endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
19
docs/content/cli/exec.md
Normal file
19
docs/content/cli/exec.md
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
---
|
||||||
|
title: Exec
|
||||||
|
---
|
||||||
|
|
||||||
|
The `exec` subcommand can do some things that the configuration file can't do yet. The command `exec host` can execute commands on many hosts.
|
||||||
|
|
||||||
|
`exec host` takes the following arguments:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
-c, --commands strings Accepts space-separated names of commands.
|
||||||
|
-h, --help help for host
|
||||||
|
-m, --hosts strings Accepts space-separated names of hosts.
|
||||||
|
```
|
||||||
|
|
||||||
|
The commands have to be defined in the config file. The hosts need to at least be in the ssh_config(5) file.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
backy exec host [--commands=command1 -commands=command2 ... | -c command1 -c command2 ...] [--hosts=host1 --hosts=hosts2 ... | -m host1 -m host2 ...] [flags]
|
||||||
|
```
|
29
docs/content/cli/list.md
Normal file
29
docs/content/cli/list.md
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
---
|
||||||
|
title: List
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
List commands, lists, or hosts defined in config file
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
```
|
||||||
|
backy list [command]
|
||||||
|
```
|
||||||
|
|
||||||
|
Available Commands:
|
||||||
|
cmds List commands defined in config file.
|
||||||
|
lists List lists defined in config file.
|
||||||
|
|
||||||
|
Flags:
|
||||||
|
```
|
||||||
|
-h, --help help for list
|
||||||
|
```
|
||||||
|
|
||||||
|
Global Flags:
|
||||||
|
```
|
||||||
|
--cmdStdOut Pass to print command output to stdout
|
||||||
|
-f, --config string config file to read from
|
||||||
|
--log-file string log file to write to
|
||||||
|
--s3-endpoint string Sets the S3 endpoint used for config file fetching. Overrides S3_ENDPOINT env variable.
|
||||||
|
-v, --verbose Sets verbose level
|
||||||
|
```
|
40
docs/content/config/_index.md
Normal file
40
docs/content/config/_index.md
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
---
|
||||||
|
title: "Configuring Backy"
|
||||||
|
weight: 3
|
||||||
|
description: >
|
||||||
|
This page tells you how to configure Backy.
|
||||||
|
---
|
||||||
|
|
||||||
|
This is the section on the config file.
|
||||||
|
|
||||||
|
To use a specific file:
|
||||||
|
```backy [command] -f /path/to/file```
|
||||||
|
|
||||||
|
You can also use a remote file:
|
||||||
|
```
|
||||||
|
backy [command] -f `s3/http source`
|
||||||
|
```
|
||||||
|
|
||||||
|
See remote resources docs for specific info.
|
||||||
|
|
||||||
|
If you leave the config path blank, the following paths will be searched in order:
|
||||||
|
|
||||||
|
1. `./backy.yml`
|
||||||
|
2. `./backy.yaml`
|
||||||
|
3. The same two files above contained in a `backy` subdirectory under in what is returned by Go's `os` package function `UserConfigDir()`.
|
||||||
|
|
||||||
|
{{% expand title="`UserConfigDir()` documentation:" %}}
|
||||||
|
|
||||||
|
Up-to date documentation for this function may be found on [GoDoc](https://pkg.go.dev/os#UserConfigDir).
|
||||||
|
|
||||||
|
>UserConfigDir returns the default root directory to use for user-specific configuration data. Users should create their own application-specific subdirectory within this one and use that.
|
||||||
|
|
||||||
|
>On Unix systems, it returns $XDG_CONFIG_HOME as specified by https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html if non-empty, else $HOME/.config. On Darwin, it returns $HOME/Library/Application Support. On Windows, it returns %AppData%. On Plan 9, it returns $home/lib.
|
||||||
|
|
||||||
|
>If the location cannot be determined (for example, $HOME is not defined), then it will return an error.
|
||||||
|
|
||||||
|
{{% /expand %}}
|
||||||
|
|
||||||
|
See the rest of the documentation, titles included below, in this section to configure it.
|
||||||
|
|
||||||
|
{{% children description="true" %}}
|
99
docs/content/config/command-lists.md
Normal file
99
docs/content/config/command-lists.md
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
---
|
||||||
|
title: "Command Lists"
|
||||||
|
weight: 2
|
||||||
|
description: >
|
||||||
|
This page tells you how to use command lists.
|
||||||
|
---
|
||||||
|
|
||||||
|
Command lists are for executing commands in sequence and getting notifications from them.
|
||||||
|
|
||||||
|
The top-level object key can be anything you want but not the same as another.
|
||||||
|
|
||||||
|
Lists can go in a separate file. Command lists should be in a separate file if:
|
||||||
|
|
||||||
|
1. key 'cmdLists.file' is specified
|
||||||
|
2. lists.yml or lists.yaml is found in the same directory as the backy config file (this includes remote config files as of v0.7.0)
|
||||||
|
|
||||||
|
{{% notice info %}}
|
||||||
|
The lists file is also checked in remote resources.
|
||||||
|
|
||||||
|
The lists file is ignored under the following condition:
|
||||||
|
|
||||||
|
If a remote config file is specified (on the command-line using `-f`) and the lists file is not found in the same directory, the lists file is assumed to not exist.
|
||||||
|
{{% /notice %}}
|
||||||
|
|
||||||
|
```yaml {lineNos="true" wrap="true" title="yaml"}
|
||||||
|
test2:
|
||||||
|
name: test2
|
||||||
|
order:
|
||||||
|
- test
|
||||||
|
- test2
|
||||||
|
notifications:
|
||||||
|
- mail.prod-email
|
||||||
|
- matrix.sysadmin
|
||||||
|
cron: "0 * * * * *"
|
||||||
|
```
|
||||||
|
|
||||||
|
| key | description | type | required
|
||||||
|
| --- | --- | --- | ---
|
||||||
|
| `order` | Defines the sequence of commands to execute | `[]string` | yes
|
||||||
|
| `sendNotificationOnSuccess` | Whether to send notification on list success with the commands' output | `bool` | no
|
||||||
|
| `notifications` | The notification service(s) and ID(s) to use on success and failure. Must be *`service.id`*. See the [notifications documentation page](/config/notifications/) for more | `[]string` | no
|
||||||
|
| `name` | Optional name of the list | `string` | no
|
||||||
|
| `cron` | Time at which to schedule the list. Only has affect when cron subcommand is run. | `string` | no
|
||||||
|
|
||||||
|
### Order
|
||||||
|
|
||||||
|
The order is an array of commands to execute in order. Each command must be defined.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
order:
|
||||||
|
- cmd-1
|
||||||
|
- cmd-2
|
||||||
|
```
|
||||||
|
|
||||||
|
### getOutput
|
||||||
|
|
||||||
|
Get command output when a notification is sent.
|
||||||
|
|
||||||
|
Is not required. Can be `true` or `false`. Default is `false`.
|
||||||
|
|
||||||
|
### Notifications
|
||||||
|
|
||||||
|
An array of notification IDs to use on success and failure. Must match any of the `notifications` object map keys.
|
||||||
|
|
||||||
|
### Name
|
||||||
|
|
||||||
|
Name is optional. If name is not defined, name will be the object's map key.
|
||||||
|
|
||||||
|
### Cron mode
|
||||||
|
|
||||||
|
Backy also has a cron mode, so one can run `backy cron` and start a process that schedules jobs to run at times defined in the configuration file.
|
||||||
|
|
||||||
|
Adding `cron: 0 0 1 * * *` to a `cmdLists` object will schedule the list at 1 in the morning. See [https://crontab.guru/](https://crontab.guru/) for reference.
|
||||||
|
|
||||||
|
{{% notice tip %}}
|
||||||
|
Note: Backy uses the second field of cron, so add anything except `*` to the beginning of a regular cron expression.
|
||||||
|
{{% /notice %}}
|
||||||
|
|
||||||
|
```yaml {lineNos="true" wrap="true" title="yaml"}
|
||||||
|
cmdLists:
|
||||||
|
docker-container-backup: # this can be any name you want
|
||||||
|
# all commands have to be defined
|
||||||
|
order:
|
||||||
|
- stop-docker-container
|
||||||
|
- backup-docker-container-script
|
||||||
|
- shell-cmd
|
||||||
|
- hostname
|
||||||
|
- start-docker-container
|
||||||
|
notifications:
|
||||||
|
- matrix.id
|
||||||
|
name: backup-some-container
|
||||||
|
cron: "0 0 1 * * *"
|
||||||
|
hostname:
|
||||||
|
name: hostname
|
||||||
|
order:
|
||||||
|
- hostname
|
||||||
|
notifications:
|
||||||
|
- mail.prod-email
|
||||||
|
```
|
128
docs/content/config/commands/_index.md
Normal file
128
docs/content/config/commands/_index.md
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
---
|
||||||
|
title: "Commands"
|
||||||
|
description: Commands are just that, commands
|
||||||
|
weight: 1
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
### Example Config
|
||||||
|
|
||||||
|
{{% code file="/examples/example.yml" language="yaml" %}}
|
||||||
|
|
||||||
|
Values available for this section **(case-sensitive)**:
|
||||||
|
|
||||||
|
| name | notes | type | required | External directive support |
|
||||||
|
| ----------------| ------------------------------------------------------------------------------------------------------- | --------------------- | -------- |----------------------------|
|
||||||
|
| `cmd` | Defines the command to execute | `string` | yes | No |
|
||||||
|
| `Args` | Defines the arguments to the command | `[]string` | no | No |
|
||||||
|
| `environment` | Defines environment variables for the command | `[]string` | no | Partial |
|
||||||
|
| `type` | See documentation further down the page. Additional fields may be required. | `string` | no | No |
|
||||||
|
| `getOutput` | Command(s) output is in the notification(s) | `bool` | no | No |
|
||||||
|
| `host` | If not specified, the command will execute locally. | `string` | no | No |
|
||||||
|
| `scriptEnvFile` | When type is `scriptFile` or `script`, this file is prepended to the input. | `string` | no | No |
|
||||||
|
| `shell` | Run the command in the shell | `string` | no | No |
|
||||||
|
| `hooks` | Hooks are used at the end of the individual command. Must have at least `error`, `success`, or `final`. | `map[string][]string` | no | No |
|
||||||
|
|
||||||
|
#### cmd
|
||||||
|
|
||||||
|
cmd must be a valid command or script to execute.
|
||||||
|
|
||||||
|
#### Args
|
||||||
|
|
||||||
|
args must be arguments to cmd as they would be passed on the command-line:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
cmd [arg1 arg2 ...]
|
||||||
|
```
|
||||||
|
|
||||||
|
Define them in an array:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
Args:
|
||||||
|
- arg1
|
||||||
|
- arg2
|
||||||
|
- arg3
|
||||||
|
```
|
||||||
|
|
||||||
|
### getOutput
|
||||||
|
|
||||||
|
Get command output when a notification is sent.
|
||||||
|
|
||||||
|
Is not required. Can be `true` or `false`.
|
||||||
|
|
||||||
|
#### host
|
||||||
|
|
||||||
|
{{% notice info %}}
|
||||||
|
If any `host` is not defined or left blank, the command will run on the local machine.
|
||||||
|
{{% /notice %}}
|
||||||
|
|
||||||
|
Host may or may not be defined in the `hosts` section.
|
||||||
|
|
||||||
|
{{% notice info %}}
|
||||||
|
If any `host` from the commands section does not match any object in the `hosts` section, the `Host` is assumed to be this value. This value will be used to search in the default SSH config files.
|
||||||
|
|
||||||
|
For example, say that I have a host defined in my SSH config with the `Host` defined as `web-prod`.
|
||||||
|
If I assign a value to host as `host: web-prod` and don't specify this value in the `hosts` object, web-prod will be used as the `Host` in searching the SSH config files.
|
||||||
|
{{% /notice %}}
|
||||||
|
|
||||||
|
### shell
|
||||||
|
|
||||||
|
If shell is defined, the command will run in the specified shell.
|
||||||
|
Make sure to escape any shell input.
|
||||||
|
|
||||||
|
### scriptEnvFile
|
||||||
|
|
||||||
|
Path to a file.
|
||||||
|
|
||||||
|
When type is `script` or `scriptFile` , the script is appended to this file.
|
||||||
|
|
||||||
|
This is useful for specifying environment variables or other things so they don't have to be included in the script.
|
||||||
|
|
||||||
|
### type
|
||||||
|
|
||||||
|
The following options are available:
|
||||||
|
|
||||||
|
| name | description |
|
||||||
|
| --- | --- |
|
||||||
|
| script | `cmd` is used as the script |
|
||||||
|
| scriptFile | Can only be run on a host. `cmd` is read and used as the script, and `scriptEnvFile` can be used to add env variables |
|
||||||
|
| package | Run package operations. See [dedicated page](/config/packages) for configuring package commands |
|
||||||
|
| user | Run user operations. See [dedicated page](/config/user-commands) for configuring package commands |
|
||||||
|
|
||||||
|
### environment
|
||||||
|
|
||||||
|
The environment variables support expansion:
|
||||||
|
|
||||||
|
- using escaped values `$VAR` or `${VAR}`
|
||||||
|
- using any external directive, and if using the env directive, the variable will be read from a `.env` file
|
||||||
|
|
||||||
|
<!-- For now, the variables expanded have to be defined in an `.env` file in the same directory that the program is run from. -->
|
||||||
|
|
||||||
|
If using it with host specified, the SSH server has to be configured to accept those env variables.
|
||||||
|
|
||||||
|
If the command is run locally, the OS's environment is added.
|
||||||
|
|
||||||
|
### hooks
|
||||||
|
|
||||||
|
Hooks are run after the command is run.
|
||||||
|
|
||||||
|
Errors are run if the command errors, success if it returns no error. Final hooks are run regardless of error condition.
|
||||||
|
|
||||||
|
Values for hooks are as follows:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
command:
|
||||||
|
hook:
|
||||||
|
# these commands are defined elsewhere in the file
|
||||||
|
error:
|
||||||
|
- errcommand
|
||||||
|
success:
|
||||||
|
- successcommand
|
||||||
|
final:
|
||||||
|
- donecommand
|
||||||
|
```
|
||||||
|
|
||||||
|
### packages
|
||||||
|
|
||||||
|
See the [dedicated page](/config/packages) for package configuration.
|
79
docs/content/config/commands/packages.md
Normal file
79
docs/content/config/commands/packages.md
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
---
|
||||||
|
title: "Packages"
|
||||||
|
weight: 2
|
||||||
|
description: This is dedicated to package commands.
|
||||||
|
---
|
||||||
|
|
||||||
|
This is dedicated to `package` commands. The command `type` field must be `package`. Package is a type that allows one to perform package operations. There are several additional options available when `type` is `package`:
|
||||||
|
|
||||||
|
| name | notes | type | required |
|
||||||
|
| --- | --- | --- | --- |
|
||||||
|
| `packageName` | The name of a package to be modified. | `string` | yes |
|
||||||
|
| `packageManager` | The name of the package manger to be used. | `string` | yes |
|
||||||
|
| `packageOperation` | The type of operation to perform. | `string` | yes |
|
||||||
|
| `packageVersion` | The version of a package. | `string` | no |
|
||||||
|
|
||||||
|
|
||||||
|
#### example
|
||||||
|
|
||||||
|
The following is an example of a package command:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
update-docker:
|
||||||
|
type: package
|
||||||
|
shell: zsh
|
||||||
|
packageName: docker-ce
|
||||||
|
packageManager: apt
|
||||||
|
packageOperation: install
|
||||||
|
host: debian-based-host
|
||||||
|
```
|
||||||
|
|
||||||
|
#### packageOperation
|
||||||
|
|
||||||
|
The following package operations are supported:
|
||||||
|
|
||||||
|
- `install`
|
||||||
|
- `remove`
|
||||||
|
- `upgrade`
|
||||||
|
- `checkVersion`
|
||||||
|
|
||||||
|
#### packageManager
|
||||||
|
|
||||||
|
The following package managers are recognized:
|
||||||
|
|
||||||
|
- `apt`
|
||||||
|
- `yum`
|
||||||
|
- `dnf`
|
||||||
|
|
||||||
|
#### package command args
|
||||||
|
|
||||||
|
You can add additional arguments using the standard `Args` key. This is useful for adding more packages, yet it does not work with `checkVersion`.
|
||||||
|
|
||||||
|
### Development
|
||||||
|
|
||||||
|
The PackageManager interface provides an easy way to enforce functions and options. There are two interfaces, `PackageManager` and `ConfigurablePackageManager` in the directory `pkg/pkgman`. Go's import-cycle "feature" caused me to implement functional options using a third interface. `PackageManagerOption`is a function that takes an interface.
|
||||||
|
|
||||||
|
#### PackageManager
|
||||||
|
|
||||||
|
```go
|
||||||
|
// PackageManager is an interface used to define common package commands. This shall be implemented by every package.
|
||||||
|
type PackageManager interface {
|
||||||
|
Install(pkg, version string, args []string) (string, []string)
|
||||||
|
Remove(pkg string, args []string) (string, []string)
|
||||||
|
Upgrade(pkg, version string) (string, []string) // Upgrade a specific package
|
||||||
|
UpgradeAll() (string, []string)
|
||||||
|
|
||||||
|
// Configure applies functional options to customize the package manager.
|
||||||
|
Configure(options ...pkgcommon.PackageManagerOption)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
There are a few functional options that should be implemented using the `ConfigurablePackageManager` interface:
|
||||||
|
|
||||||
|
```go
|
||||||
|
// ConfigurablePackageManager defines methods for setting configuration options.
|
||||||
|
type ConfigurablePackageManager interface {
|
||||||
|
SetUseAuth(useAuth bool)
|
||||||
|
SetAuthCommand(authCommand string)
|
||||||
|
}
|
||||||
|
```
|
66
docs/content/config/commands/user-commands.md
Normal file
66
docs/content/config/commands/user-commands.md
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
---
|
||||||
|
title: "User commands"
|
||||||
|
weight: 2
|
||||||
|
description: This is dedicated to user commands.
|
||||||
|
---
|
||||||
|
|
||||||
|
This is dedicated to `user` commands. The command `type` field must be `user`. User is a type that allows one to perform user operations. There are several additional options available when `type` is `user`:
|
||||||
|
|
||||||
|
| name | notes | type | required | External directive support
|
||||||
|
| ----------------| -------------------------------------------------------------| ---------- | ---------| --------------------------|
|
||||||
|
| `userName` | The name of a user to be configured. | `string` | yes | no |
|
||||||
|
| `userOperation` | The type of operation to perform. | `string` | yes | no |
|
||||||
|
| `userID` | The user ID to use. | `string` | no | no |
|
||||||
|
| `userGroups` | The groups the user should be added to. | `[]string` | no | no |
|
||||||
|
| `systemUser` | Create a system user. | `bool` | no | no |
|
||||||
|
| `userCreateHome`| Create the home directory. | `bool` | no | no |
|
||||||
|
| `userSshPubKeys`| The keys to add to the user's authorized keys. | `[]string` | no | yes |
|
||||||
|
| `userShell` | The shell for the user. | `string` | no | no |
|
||||||
|
| `userHome` | The user's home directory. | `string` | no | no |
|
||||||
|
| `userPassword` | The new password value when using the `password` operation. | `string` | no | yes |
|
||||||
|
|
||||||
|
|
||||||
|
#### example
|
||||||
|
|
||||||
|
The following is an example of a package command:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
addUser:
|
||||||
|
name: add user backy with custom home dir
|
||||||
|
type: user
|
||||||
|
userName: backy
|
||||||
|
userHome: /opt/backy
|
||||||
|
userOperation: add
|
||||||
|
host: some-host
|
||||||
|
```
|
||||||
|
|
||||||
|
#### userOperation
|
||||||
|
|
||||||
|
The following package operations are supported:
|
||||||
|
|
||||||
|
- `add`
|
||||||
|
- `remove`
|
||||||
|
- `modify`
|
||||||
|
- `password`
|
||||||
|
- `checkIfExists`
|
||||||
|
|
||||||
|
### Development
|
||||||
|
|
||||||
|
The UserManager interface provides an way easy to add new commands. There is one interface `Usermanager` in directory `pkg/usermanager`.
|
||||||
|
|
||||||
|
#### UserManager
|
||||||
|
|
||||||
|
```go
|
||||||
|
// UserManager defines the interface for user management operations.
|
||||||
|
// All functions but one return a string for the command and any args.
|
||||||
|
type UserManager interface {
|
||||||
|
AddUser(username, homeDir, shell string, isSystem bool, groups, args []string) (string, []string)
|
||||||
|
RemoveUser(username string) (string, []string)
|
||||||
|
ModifyUser(username, homeDir, shell string, groups []string) (string, []string)
|
||||||
|
// Modify password uses chpasswd for Linux systems to build the command to change the password
|
||||||
|
// Should return a password as the last argument
|
||||||
|
// TODO: refactor when adding more systems instead of Linux
|
||||||
|
ModifyPassword(username, password string) (string, *strings.Reader, string)
|
||||||
|
UserExists(username string) (string, []string)
|
||||||
|
}
|
||||||
|
```
|
15
docs/content/config/directives.md
Normal file
15
docs/content/config/directives.md
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
---
|
||||||
|
title: "External Directives"
|
||||||
|
weight: 2
|
||||||
|
description: How to set up external directives.
|
||||||
|
---
|
||||||
|
|
||||||
|
External directives are for including data that should not be in the config file. The following directives are supported:
|
||||||
|
|
||||||
|
- `%{file:path/to/file}%`
|
||||||
|
- `%{env:ENV_VAR}%`
|
||||||
|
- `%{vault:vault-key}%`
|
||||||
|
|
||||||
|
See the docs of each command if the field is supported.
|
||||||
|
|
||||||
|
If the file path does not begin with a `/`, the config file's directory will be used as the starting point.
|
24
docs/content/config/hosts.md
Normal file
24
docs/content/config/hosts.md
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
---
|
||||||
|
title: "Hosts"
|
||||||
|
weight: 2
|
||||||
|
description: >
|
||||||
|
This page tells you how to use hosts.
|
||||||
|
---
|
||||||
|
|
||||||
|
| Key | Description | Type | Required | External directive support |
|
||||||
|
|----------------------|---------------------------------------------------------------|----------|----------|----------------------------|
|
||||||
|
| `OS` | Operating system of the host (used for package commands) | `string` | no | No |
|
||||||
|
| `config` | Path to the SSH config file | `string` | no | No |
|
||||||
|
| `host` | Specifies the `Host` ssh_config(5) directive | `string` | yes | No |
|
||||||
|
| `hostname` | Hostname of the host | `string` | no | No |
|
||||||
|
| `knownHostsFile` | Path to the known hosts file | `string` | no | No |
|
||||||
|
| `port` | Port number to connect to | `uint16` | no | No |
|
||||||
|
| `proxyjump` | Proxy jump hosts, comma-separated | `string` | no | No |
|
||||||
|
| `password` | Password for SSH authentication | `string` | no | No |
|
||||||
|
| `privateKeyPath` | Path to the private key file | `string` | no | No |
|
||||||
|
| `privateKeyPassword` | Password for the private key file | `string` | no | Yes |
|
||||||
|
| `user` | Username for SSH authentication | `string` | no | No |
|
||||||
|
|
||||||
|
## exec host subcommand
|
||||||
|
|
||||||
|
Backy has a subcommand `exec host`. This subcommand takes the flags of `-m host1 -m host2`. The commands can also be specified by `-c command1 -c command2`.
|
75
docs/content/config/notifications.md
Normal file
75
docs/content/config/notifications.md
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
---
|
||||||
|
title: "Notifications"
|
||||||
|
weight: 3
|
||||||
|
description: >
|
||||||
|
This page tells you how to get set up Backy notifications.
|
||||||
|
---
|
||||||
|
|
||||||
|
Notifications are only configurable for command lists, as of right now.
|
||||||
|
|
||||||
|
Notifications can be sent on command list completion and failure.
|
||||||
|
|
||||||
|
The supported platforms for notifications are email (SMTP) and [Matrix](https://matrix.org/).
|
||||||
|
|
||||||
|
Notifications are defined by service, with the current form following below. Ids must come after the service.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
notifications:
|
||||||
|
mail:
|
||||||
|
prod-email:
|
||||||
|
host: yourhost.tld
|
||||||
|
port: 587
|
||||||
|
senderaddress: email@domain.tld
|
||||||
|
to:
|
||||||
|
- admin@domain.tld
|
||||||
|
username: smtp-username@domain.tld
|
||||||
|
password: your-password-here
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
matrix:
|
||||||
|
home-server: your-home-server.tld
|
||||||
|
room-id: room-id
|
||||||
|
access-token: your-access-token
|
||||||
|
user-id: your-user-id
|
||||||
|
```
|
||||||
|
|
||||||
|
Sections recognized are `mail` and `matrix`
|
||||||
|
|
||||||
|
There must be a section with an id (eg. `mail.test-svr`) following one of these sections.
|
||||||
|
|
||||||
|
### mail
|
||||||
|
|
||||||
|
| key | description | type | External directive support |
|
||||||
|
| --- | --- | --- | --- |
|
||||||
|
| `host` | Specifies the SMTP host to connect to | `string` | no
|
||||||
|
| `port` | Specifies the SMTP port | `uint16` | no
|
||||||
|
| `senderaddress` | Address from which to send mail | `string` | no
|
||||||
|
| `to` | Recipients to send emails to | `[]string` | no
|
||||||
|
| `username` | SMTP username | `string` | no
|
||||||
|
| `password` | SMTP password | `string` | yes
|
||||||
|
|
||||||
|
### matrix
|
||||||
|
|
||||||
|
| key | description | type | External directive support |
|
||||||
|
| --- | --- | ---| ---- |
|
||||||
|
| `home-server` | Specifies the Matrix server connect to | `string` | no
|
||||||
|
| `room-id` | Specifies the room ID of the room to send messages to | `string` | no
|
||||||
|
| `access-token` | Matrix access token | `string` | yes
|
||||||
|
| `user-id` | Matrix user ID | `string` | no
|
||||||
|
|
||||||
|
To get your access token (assumes you are using [Element](https://element.io/)) :
|
||||||
|
|
||||||
|
1. Log in to the account you want to get the access token for. Click on the name in the top left corner, then "Settings".
|
||||||
|
2. Click the "Help & About" tab (left side of the dialog).
|
||||||
|
3. Scroll to the bottom and click on `<click to reveal>` part of Access Token.
|
||||||
|
4. Copy your access token to a safe place.
|
||||||
|
|
||||||
|
To get the room ID:
|
||||||
|
|
||||||
|
1. On Element or a similar client, navigate to the room.
|
||||||
|
2. Navigate to the settings from the top menu.
|
||||||
|
3. Click on Advanced, the room ID is there.
|
||||||
|
|
||||||
|
{{% notice info %}}
|
||||||
|
Make sure to quote the room ID, as [YAML spec defines tags using `!`](https://yaml.org/spec/1.2.2/#3212-tags).
|
||||||
|
{{% /notice %}}
|
21
docs/content/config/remote-resources.md
Normal file
21
docs/content/config/remote-resources.md
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
---
|
||||||
|
title: "Remote resources"
|
||||||
|
weight: 2
|
||||||
|
description: This is dedicated to configuring remote resources.
|
||||||
|
---
|
||||||
|
|
||||||
|
Remote resources can be used for a lot of things, including config files and scripts.
|
||||||
|
|
||||||
|
## Config file
|
||||||
|
|
||||||
|
For the main config file to be fetched remotely, pass the URL using `-f [url]`.
|
||||||
|
|
||||||
|
If using S3, you should use the s3 protocol URI: `s3://bucketName/key/path`. You will also need to set the env variable `S3_ENDPOINT` to the appropriate value. The flag `--s3-endpoint` can be used to override this value or to set this value, if not already set.
|
||||||
|
|
||||||
|
## Authentication
|
||||||
|
|
||||||
|
Currently, only the AWS authentication credentials file `~/.aws/credentials` is supported. For now, the environment variable `AWS_PROFILE` is used to lookup the profile.
|
||||||
|
|
||||||
|
## Scripts
|
||||||
|
|
||||||
|
Remote script support is currently limited to http/https endpoints.
|
29
docs/content/config/vault.md
Normal file
29
docs/content/config/vault.md
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
---
|
||||||
|
title: "Vault"
|
||||||
|
weight: 4
|
||||||
|
description: Set up and configure vault.
|
||||||
|
---
|
||||||
|
|
||||||
|
[Vault](https://www.vaultproject.io/) is a tool for storing secrets and other data securely.
|
||||||
|
|
||||||
|
A Vault key can be used by prefixing `%{vault:vault.keys.name}%` in a field that supports external directives.
|
||||||
|
|
||||||
|
This is the object in the config file:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
vault:
|
||||||
|
token: hvs.tXqcASvTP8wg92f7riyvGyuf
|
||||||
|
address: http://127.0.0.1:8200
|
||||||
|
enabled: false
|
||||||
|
keys:
|
||||||
|
- name: mongourl
|
||||||
|
mountpath: secret
|
||||||
|
key: data
|
||||||
|
path: mongo/url
|
||||||
|
type: KVv2 # KVv1 or KVv2
|
||||||
|
- name: someKeyName
|
||||||
|
mountpath: secret
|
||||||
|
key: keyData
|
||||||
|
type: KVv2
|
||||||
|
path: some/path
|
||||||
|
```
|
108
docs/content/examples/backy.yaml
Normal file
108
docs/content/examples/backy.yaml
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
commands:
|
||||||
|
stop-docker-container:
|
||||||
|
cmd: docker
|
||||||
|
Args:
|
||||||
|
- compose
|
||||||
|
- -f /some/path/to/docker-compose.yaml
|
||||||
|
- down
|
||||||
|
# if host is not defined, cmd will be run locally
|
||||||
|
host: some-host
|
||||||
|
hooks:
|
||||||
|
final:
|
||||||
|
- hostname
|
||||||
|
error:
|
||||||
|
- hostname
|
||||||
|
backup-docker-container-script:
|
||||||
|
cmd: /path/to/script
|
||||||
|
# The host has to be defined in the config file
|
||||||
|
host: some-host
|
||||||
|
environment:
|
||||||
|
- FOO=BAR
|
||||||
|
- APP=$VAR
|
||||||
|
shell-cmd:
|
||||||
|
cmd: rsync
|
||||||
|
shell: bash
|
||||||
|
Args:
|
||||||
|
- -av some-host:/path/to/data ~/Docker/Backups/docker-data
|
||||||
|
hostname:
|
||||||
|
cmd: hostname
|
||||||
|
update-docker:
|
||||||
|
type: package
|
||||||
|
shell: zsh # best to run package commands in a shell
|
||||||
|
packageName: docker-ce
|
||||||
|
Args:
|
||||||
|
- docker-ce-cli
|
||||||
|
packageManager: apt
|
||||||
|
packageOperation: install
|
||||||
|
update-dockerApt:
|
||||||
|
# type: package
|
||||||
|
shell: zsh
|
||||||
|
cmd: apt
|
||||||
|
Args:
|
||||||
|
- update
|
||||||
|
- "&&"
|
||||||
|
- apt install -y docker-ce
|
||||||
|
- docker-ce-cli
|
||||||
|
packageManager: apt
|
||||||
|
packageOperation: install
|
||||||
|
|
||||||
|
cmd-lists:
|
||||||
|
cmds-to-run: # this can be any name you want
|
||||||
|
# all commands have to be defined
|
||||||
|
order:
|
||||||
|
- stop-docker-container
|
||||||
|
- backup-docker-container-script
|
||||||
|
- shell-cmd
|
||||||
|
- hostname
|
||||||
|
notifications:
|
||||||
|
- matrix.matrix
|
||||||
|
name: backup-some-server
|
||||||
|
cron: "0 0 1 * * *"
|
||||||
|
hostname:
|
||||||
|
name: hostname
|
||||||
|
order:
|
||||||
|
- hostname
|
||||||
|
notifications:
|
||||||
|
- mail.prod-email
|
||||||
|
|
||||||
|
hosts:
|
||||||
|
# any ssh_config(5) keys/values not listed here will be looked up in the config file or the default config file
|
||||||
|
some-host:
|
||||||
|
hostname: some-hostname
|
||||||
|
config: ~/.ssh/config
|
||||||
|
user: user
|
||||||
|
privateKeyPath: /path/to/private/key
|
||||||
|
port: 22
|
||||||
|
# can also be env:VAR
|
||||||
|
password: file:/path/to/file
|
||||||
|
# only one is supported for now
|
||||||
|
proxyjump: some-proxy-host
|
||||||
|
|
||||||
|
# optional
|
||||||
|
logging:
|
||||||
|
verbose: true
|
||||||
|
file: ./backy.log
|
||||||
|
console: false
|
||||||
|
cmd-std-out: false
|
||||||
|
|
||||||
|
|
||||||
|
notifications:
|
||||||
|
mail:
|
||||||
|
prod-email:
|
||||||
|
id: prod-email
|
||||||
|
type: mail
|
||||||
|
host: yourhost.tld
|
||||||
|
port: 587
|
||||||
|
senderAddress: email@domain.tld
|
||||||
|
to:
|
||||||
|
- admin@domain.tld
|
||||||
|
username: smtp-username@domain.tld
|
||||||
|
password: your-password-here
|
||||||
|
matrix:
|
||||||
|
matrix:
|
||||||
|
id: matrix
|
||||||
|
type: matrix
|
||||||
|
home-server: your-home-server.tld
|
||||||
|
room-id: room-id
|
||||||
|
access-token: your-access-token
|
||||||
|
user-id: your-user-id
|
24
docs/content/examples/example.yml
Normal file
24
docs/content/examples/example.yml
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
commands:
|
||||||
|
stop-docker-container:
|
||||||
|
cmd: docker
|
||||||
|
Args:
|
||||||
|
- compose
|
||||||
|
- -f /some/path/to/docker-compose.yaml
|
||||||
|
- down
|
||||||
|
# if host is not defined, command will be run locally
|
||||||
|
# The host has to be defined in either the config file or the SSH Config files
|
||||||
|
host: some-host
|
||||||
|
hooks:
|
||||||
|
error:
|
||||||
|
- some-other-command-when-failing
|
||||||
|
success:
|
||||||
|
- success-command
|
||||||
|
final:
|
||||||
|
- final-command
|
||||||
|
backup-docker-container-script:
|
||||||
|
cmd: /path/to/local/script
|
||||||
|
# script file is input as stdin to SSH
|
||||||
|
type: scriptFile # also can be script
|
||||||
|
environment:
|
||||||
|
- FOO=BAR
|
||||||
|
- APP=$VAR
|
10
docs/content/getting-started/_index.md
Normal file
10
docs/content/getting-started/_index.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
---
|
||||||
|
title: "Getting started"
|
||||||
|
weight: 2
|
||||||
|
description: >
|
||||||
|
This page tells you how to get started with Backy.
|
||||||
|
---
|
||||||
|
|
||||||
|
If you have not installed Backy, [see the install documentation](install).
|
||||||
|
|
||||||
|
If you need to configure it, [see the config page](config).
|
161
docs/content/getting-started/config.md
Normal file
161
docs/content/getting-started/config.md
Normal file
@ -0,0 +1,161 @@
|
|||||||
|
---
|
||||||
|
title: "Config File Definitions"
|
||||||
|
description: >
|
||||||
|
This page tells you how to configure Backy.
|
||||||
|
---
|
||||||
|
|
||||||
|
### Commands
|
||||||
|
|
||||||
|
The commands section is for defining commands. These can be run with or without a shell and on a host or locally.
|
||||||
|
|
||||||
|
See the [commands documentation](/config/commands) for further information.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
commands:
|
||||||
|
stop-docker-container:
|
||||||
|
output: true # Optional and only when run in list and notifications are sent
|
||||||
|
cmd: docker
|
||||||
|
args:
|
||||||
|
- compose
|
||||||
|
- -f /some/path/to/docker-compose.yaml
|
||||||
|
- down
|
||||||
|
# if host is not defined, cmd will be run locally
|
||||||
|
host: some-host
|
||||||
|
backup-docker-container-script:
|
||||||
|
cmd: /path/to/script
|
||||||
|
# The host has to be defined in the config file
|
||||||
|
host: some-host
|
||||||
|
environment:
|
||||||
|
- FOO=BAR
|
||||||
|
- APP=$VAR # defined in .env file in config directory
|
||||||
|
shell-cmd:
|
||||||
|
cmd: rsync
|
||||||
|
shell: bash
|
||||||
|
args:
|
||||||
|
- -av
|
||||||
|
- some-host:/path/to/data
|
||||||
|
- ~/Docker/Backups/docker-data
|
||||||
|
script:
|
||||||
|
type: scriptFile # run a local script on a remote host
|
||||||
|
cmd: path/to/your/script.sh
|
||||||
|
host: some-host
|
||||||
|
hostname:
|
||||||
|
cmd: hostname
|
||||||
|
```
|
||||||
|
|
||||||
|
### Lists
|
||||||
|
|
||||||
|
To execute groups of commands in sequence, use a list configuration.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
cmdLists:
|
||||||
|
cmds-to-run: # this can be any name you want
|
||||||
|
# all commands have to be defined in the commands section
|
||||||
|
order:
|
||||||
|
- stop-docker-container
|
||||||
|
- backup-docker-container-script
|
||||||
|
- shell-cmd
|
||||||
|
- hostname
|
||||||
|
getOutput: true # Optional and only for when notifications are sent
|
||||||
|
notifications:
|
||||||
|
- matrix
|
||||||
|
name: backup-some-server
|
||||||
|
hostname:
|
||||||
|
name: hostname
|
||||||
|
order:
|
||||||
|
- hostname
|
||||||
|
notifications:
|
||||||
|
- prod-email
|
||||||
|
```
|
||||||
|
|
||||||
|
### Hosts
|
||||||
|
|
||||||
|
The hosts object may or may not be defined.
|
||||||
|
|
||||||
|
{{% notice info %}}
|
||||||
|
If any `host` from a commands object does not match any `host` object, the needed values will be checked in the default SSH config files.
|
||||||
|
{{% /notice %}}
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
hosts:
|
||||||
|
# any needed ssh_config(5) keys/values not listed here will be looked up in the config file or the default config file
|
||||||
|
some-host:
|
||||||
|
hostname: some-hostname
|
||||||
|
config: ~/.ssh/config
|
||||||
|
user: user
|
||||||
|
privatekeypath: /path/to/private/key
|
||||||
|
port: 22
|
||||||
|
# can also be env:VAR or the password itself
|
||||||
|
password: file:/path/to/file
|
||||||
|
# can also be env:VAR or the password itself
|
||||||
|
privatekeypassword: file:/path/to/file
|
||||||
|
# only one is supported for now
|
||||||
|
proxyjump: some-proxy-host
|
||||||
|
```
|
||||||
|
|
||||||
|
### Notifications
|
||||||
|
|
||||||
|
The notifications object can have two forms.
|
||||||
|
|
||||||
|
For more, [see the notification object documentation](/config/notifications). The top-level map key is id that has to be referenced by the `cmdLists` key `notifications`.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
notifications:
|
||||||
|
mail:
|
||||||
|
prod-email:
|
||||||
|
id: prod-email
|
||||||
|
type: mail
|
||||||
|
host: yourhost.tld
|
||||||
|
port: 587
|
||||||
|
senderAddress: email@domain.tld
|
||||||
|
to:
|
||||||
|
- admin@domain.tld
|
||||||
|
username: smtp-username@domain.tld
|
||||||
|
password: your-password-here
|
||||||
|
matrix:
|
||||||
|
matrix:
|
||||||
|
id: matrix
|
||||||
|
type: matrix
|
||||||
|
home-server: your-home-server.tld
|
||||||
|
room-id: room-id
|
||||||
|
access-token: your-access-token
|
||||||
|
user-id: your-user-id
|
||||||
|
```
|
||||||
|
|
||||||
|
### Logging
|
||||||
|
|
||||||
|
`cmd-std-out` controls whether commands output is echoed to StdOut.
|
||||||
|
|
||||||
|
If `logfile` is not defined, the log file will be written to the config directory in the file `backy.log`.
|
||||||
|
|
||||||
|
`console-disabled` controls whether the logging messages are echoed to StdOut. Default is false.
|
||||||
|
|
||||||
|
`verbose` prints out debugging messages.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
logging:
|
||||||
|
verbose: false
|
||||||
|
file: path/to/log/file.log
|
||||||
|
console-disabled: false
|
||||||
|
cmd-std-out: false
|
||||||
|
```
|
||||||
|
|
||||||
|
### Vault
|
||||||
|
|
||||||
|
[Vault](https://www.vaultproject.io/) can be used to get some configuration values and ENV variables securely.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
vault:
|
||||||
|
token: hvs.tXqcASvTP8wg92f7riyvGyuf
|
||||||
|
address: http://127.0.0.1:8200
|
||||||
|
enabled: false
|
||||||
|
keys:
|
||||||
|
- name: mongourl
|
||||||
|
mountpath: secret
|
||||||
|
path: mongo/url
|
||||||
|
type: # KVv1 or KVv2
|
||||||
|
- name:
|
||||||
|
path:
|
||||||
|
type:
|
||||||
|
mountpath:
|
||||||
|
```
|
21
docs/content/getting-started/install.md
Normal file
21
docs/content/getting-started/install.md
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
---
|
||||||
|
title: "Install Backy"
|
||||||
|
weight: 1
|
||||||
|
description: >
|
||||||
|
This page tells you how to install Backy.
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
Binaries are available from the [release page](https://git.andrewnw.xyz/CyberShell/backy/releases). Make sure to get the correct version for your system, which supports x86_64, ARM64, and i386.
|
||||||
|
|
||||||
|
### Source Install
|
||||||
|
|
||||||
|
You can install from source. You will need [Go installed](https://go.dev/doc/install).
|
||||||
|
|
||||||
|
Then run:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
go install git.andrewnw.xyz/CyberShell/backy@master
|
||||||
|
```
|
||||||
|
|
||||||
|
Once set, jump over to the [config docs](/getting-started/config) and start configuring your file.
|
9
docs/content/repositories/_index.md
Normal file
9
docs/content/repositories/_index.md
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
title: "Repositories"
|
||||||
|
weight: 5
|
||||||
|
---
|
||||||
|
|
||||||
|
The repo mirrors are:
|
||||||
|
|
||||||
|
* [https://git.andrewnw.xyz/CyberShell/backy](https://git.andrewnw.xyz/CyberShell/backy)
|
||||||
|
* [https://github.com/CybersShell/backy](https://github.com/CybersShell/backy)
|
8
docs/go.mod
Normal file
8
docs/go.mod
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
module git.andrewnw.xyz/CyberShell/backy/docs
|
||||||
|
|
||||||
|
go 1.19
|
||||||
|
|
||||||
|
require (
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20250103114405-80e448e5bdaa // indirect
|
||||||
|
github.com/divinerites/plausible-hugo v1.21.1 // indirect
|
||||||
|
)
|
10
docs/go.sum
Normal file
10
docs/go.sum
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20230209073138-890d12ea922d h1:weq1mrQ/qNAvGrNgvZVL1K8adbT3bswZf2ABLr/LCIA=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20230209073138-890d12ea922d/go.mod h1:mKQQdxZNIlLvAj8X3tMq+RzntIJSr9z7XdzuMomt0IM=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20241210183303-16d4de84becf h1:bMx4kwM7Q+dAzvSOWs3XWZ25o+n4mI0GPHqzbzeWb3M=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20241210183303-16d4de84becf/go.mod h1:mKQQdxZNIlLvAj8X3tMq+RzntIJSr9z7XdzuMomt0IM=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20250102210630-dd0597ffa4b2 h1:sWaC1/dL65v3iRvblEAaBLpKC5TIT0R9JASk1hZNET8=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20250102210630-dd0597ffa4b2/go.mod h1:mKQQdxZNIlLvAj8X3tMq+RzntIJSr9z7XdzuMomt0IM=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20250103114405-80e448e5bdaa h1:G+OnMEzK4XOzbbcf1SmaGyOYJ0h5idp/IJdguWs8ioU=
|
||||||
|
github.com/McShelby/hugo-theme-relearn v0.0.0-20250103114405-80e448e5bdaa/go.mod h1:mKQQdxZNIlLvAj8X3tMq+RzntIJSr9z7XdzuMomt0IM=
|
||||||
|
github.com/divinerites/plausible-hugo v1.21.1 h1:ZTWwjhZ0PmLMacCVGlcGiYFEZW7VaYE767tchDskOug=
|
||||||
|
github.com/divinerites/plausible-hugo v1.21.1/go.mod h1:cxr+YB3FUwbLon8KCs4pV4Ankbkq6lJxTQUpNb5KqPo=
|
84
docs/layouts/_default/baseof.html
Normal file
84
docs/layouts/_default/baseof.html
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
{{- block "storeOutputFormat" . }}{{ end }}
|
||||||
|
{{- if .IsHome }}
|
||||||
|
{{- $hugoVersion := "0.126.0" }}
|
||||||
|
{{- if lt hugo.Version $hugoVersion }}
|
||||||
|
{{- errorf "The Relearn theme requires Hugo %s or later" $hugoVersion }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Site.Params.description }}
|
||||||
|
{{- warnf "UNSUPPORTED usage of 'params.description' config parameter found, move it to the front matter of your home page; see https://mcshelby.github.io/hugo-theme-relearn/introduction/releasenotes/6/#6-0-0" }}
|
||||||
|
{{- end }}
|
||||||
|
<html lang="{{ .Page.Language.LanguageCode }}" dir="{{ .Page.Language.LanguageDirection | default (T "Reading-direction") | default "ltr" }}" itemscope itemtype="http://schema.org/Article" data-r-output-format="{{ with .Store.Get "relearnOutputFormat" }}{{ . }}{{ else }}html{{ end }}">
|
||||||
|
<head>
|
||||||
|
{{ partial "plausible_head.html" . }}
|
||||||
|
{{- partial "meta.html" . }}
|
||||||
|
{{- $title := partial "title.gotmpl" (dict "page" . "fullyQualified" true "reverse" true) }}
|
||||||
|
<title>{{ $title }}</title>
|
||||||
|
|
||||||
|
{{- /* multilingual stuff */}}
|
||||||
|
{{- if .IsTranslated -}}
|
||||||
|
{{- range $index, $trans := .AllTranslations }}
|
||||||
|
{{- if eq $index 0 }}
|
||||||
|
<link href="{{ partial "permalink.gotmpl" (dict "to" . "abs" true) }}" rel="alternate" hreflang="x-default">
|
||||||
|
{{- end }}
|
||||||
|
<link href="{{ partial "permalink.gotmpl" (dict "to" . "abs" true) }}" rel="alternate" hreflang="{{ .Language.LanguageCode }}">
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
|
{{- /* output formats */}}
|
||||||
|
{{- $page := . }}
|
||||||
|
{{- $link := "<link href=\"%s\" rel=\"%s\" type=\"%s\" title=\"%s\">" }}
|
||||||
|
{{- range .AlternativeOutputFormats }}
|
||||||
|
{{- if eq .Rel "canonical" }}
|
||||||
|
{{ (printf $link (partial "permalink.gotmpl" (dict "to" . "abs" true)) .Rel .MediaType.Type ($title | htmlEscape)) | safeHTML }}
|
||||||
|
{{- else if not (partial "_relearn/pageIsSpecial.gotmpl" $page) }}
|
||||||
|
{{ (printf $link (partial "permalink.gotmpl" (dict "to" .)) .Rel .MediaType.Type ($title | htmlEscape)) | safeHTML }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- partialCached "favicon.html" . }}
|
||||||
|
{{- partial "stylesheet.html" . }}
|
||||||
|
{{- partial "dependencies.gotmpl" (dict "page" . "location" "header") }}
|
||||||
|
{{- partial "custom-header.html" . }}
|
||||||
|
</head>
|
||||||
|
<body class="mobile-support {{ with .Store.Get "relearnOutputFormat" }}{{ . }}{{ else }}html{{ end }}{{- if .Site.Params.disableInlineCopyToClipBoard }} disableInlineCopyToClipboard{{ end }}{{- if .Site.Params.disableHoverBlockCopyToClipBoard }} disableHoverBlockCopyToClipBoard{{ end }}" data-url="{{ partial "permalink.gotmpl" (dict "to" .) }}">
|
||||||
|
<div id="R-body" class="default-animation">
|
||||||
|
<div id="R-body-overlay"></div>
|
||||||
|
<nav id="R-topbar">
|
||||||
|
<div class="topbar-wrapper">
|
||||||
|
<div class="topbar-sidebar-divider"></div>
|
||||||
|
<div class="topbar-area topbar-area-start" data-area="start">
|
||||||
|
{{- partial "topbar/area/start.html" . }}
|
||||||
|
</div>
|
||||||
|
{{- $showBreadcrumb := (and (not .Params.disableBreadcrumb) (not .Site.Params.disableBreadcrumb)) }}
|
||||||
|
{{- if $showBreadcrumb }}
|
||||||
|
<ol class="topbar-breadcrumbs breadcrumbs highlightable" itemscope itemtype="http://schema.org/BreadcrumbList">
|
||||||
|
{{- partial "breadcrumbs.html" (dict "page" .) }}
|
||||||
|
</ol>
|
||||||
|
{{- else }}
|
||||||
|
<span class="topbar-breadcrumbs highlightable">
|
||||||
|
{{ partial "title.gotmpl" (dict "page" . "linkTitle" true) }}
|
||||||
|
</span>
|
||||||
|
{{- end }}
|
||||||
|
<div class="topbar-area topbar-area-end" data-area="end">
|
||||||
|
{{- partial "topbar/area/end.html" . }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
|
<div id="R-main-overlay"></div>
|
||||||
|
<main id="R-body-inner" class="highlightable{{ with or .Type "default" }} {{ . }}{{ end }}" tabindex="-1">
|
||||||
|
<div class="flex-block-wrapper">
|
||||||
|
{{- block "body" . }}{{ end }}
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
{{- partial "custom-comments.html" . }}
|
||||||
|
</div>
|
||||||
|
{{- block "menu" . }}{{ end }}
|
||||||
|
{{- $assetBusting := partialCached "assetbusting.gotmpl" . }}
|
||||||
|
<script src="{{"js/clipboard.min.js" | relURL}}{{ $assetBusting }}" defer></script>
|
||||||
|
<script src="{{"js/perfect-scrollbar.min.js" | relURL}}{{ $assetBusting }}" defer></script>
|
||||||
|
{{- partial "dependencies.gotmpl" (dict "page" . "location" "footer") }}
|
||||||
|
<script src="{{"js/theme.js" | relURL}}{{ $assetBusting }}" defer></script>
|
||||||
|
{{- partial "custom-footer.html" . }}
|
||||||
|
</body>
|
||||||
|
</html>
|
46
docs/layouts/partials/logo.html
Normal file
46
docs/layouts/partials/logo.html
Normal file
File diff suppressed because one or more lines are too long
3
docs/layouts/shortcodes/code.html
Normal file
3
docs/layouts/shortcodes/code.html
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{{ $file := .Get "file" | readFile }}
|
||||||
|
{{ $lang := .Get "language" }}
|
||||||
|
{{ (print "```" $lang "\n" $file "\n```") }}
|
1
docs/themes/hugo-theme-relearn
vendored
Submodule
1
docs/themes/hugo-theme-relearn
vendored
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 80e448e5bdaa92c87ee0d0d86f1125c8606ebf5f
|
1
docs/themes/plausible-hugo
vendored
Submodule
1
docs/themes/plausible-hugo
vendored
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 25d00b53c8ba5bac67329d4ed552b11322093811
|
20
docs/vangen.json
Normal file
20
docs/vangen.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"domain": "go.cybershell.xyz",
|
||||||
|
"docsDomain": "pkg.go.dev",
|
||||||
|
"repositories": [
|
||||||
|
{
|
||||||
|
"prefix": "backy",
|
||||||
|
"type": "git",
|
||||||
|
"hidden": false,
|
||||||
|
"url": "https://git.andrewnw.xyz/CyberShell/backy",
|
||||||
|
"source": {
|
||||||
|
"home": "https://git.andrewnw.xyz/CyberShell/backy",
|
||||||
|
"dir": "https://git.andrewnw.xyz/CyberShell/backy/src/branch/master/{/dir}",
|
||||||
|
"file": "https://git.andrewnw.xyz/CyberShell/backy/src/branch/master/{/dir}/{file}#L{line}"
|
||||||
|
},
|
||||||
|
"website": {
|
||||||
|
"url": "https://backy.cybershell.xyz/"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user