1
0
Fork 0
mirror of synced 2025-01-08 22:21:06 -05:00
yadm/_docs/080_encryption.md

55 lines
2 KiB
Markdown
Raw Normal View History

2016-09-06 23:19:16 -04:00
---
title: "Encryption"
permalink: /docs/encryption
---
It can be useful to manage confidential files, like SSH keys, across multiple
systems. However, doing so would put plain text data into a Git repository,
2019-10-19 14:59:03 -04:00
which often resides on a public system. yadm implements a feature which can
2016-09-06 23:19:16 -04:00
make it easy to encrypt and decrypt a set of files so the encrypted version can
be maintained in the Git repository. This feature will only work if the gpg
command is available.
_It is recommended that you use a private repository when keeping confidential
files, even though they are encrypted._
To use this feature, a list of patterns must be created and saved as
2019-10-20 16:07:13 -04:00
`$HOME/.config/yadm/encrypt`. For example:
2016-09-06 23:19:16 -04:00
.ssh/*.key
The `yadm encrypt` command will find all files matching the patterns, and
prompt for a password. Once a password has confirmed, the matching files will be
2019-10-20 16:07:13 -04:00
encrypted and saved as `$HOME/.config/yadm/files.gpg`. The patterns and files.gpg
2019-10-19 14:59:03 -04:00
should be added to the yadm repository so they are available across multiple
2016-09-06 23:19:16 -04:00
systems.
2019-10-20 16:07:13 -04:00
yadm add .config/yadm/encrypt
yadm add .config/yadm/files.gpg
2016-09-06 23:19:16 -04:00
To decrypt these files later, or on another system run `yadm decrypt` and
provide the correct password.
_By default, any decrypted files will have their "group" and "others"
permissions removed._
### Asymmetric Encryption
Symmetric encryption is used by default, but asymmetric encryption may
be enabled using the `yadm.gpg-recipient` configuration. To do so, run:
yadm config yadm.gpg-recipient <recipient-address>
For this to work, `<recipient-address>` must exist in your gpg keyrings.
2019-12-16 23:44:04 -05:00
2020-08-08 22:09:13 -04:00
## transcrypt & git-crypt
2019-12-16 23:44:04 -05:00
2020-08-08 22:09:13 -04:00
transcrypt & git-crypt are tools that enable transparent encryption and
decryption of files in a Git repository. If installed, you can use either of
these tools with your yadm repository.
2019-12-16 23:44:04 -05:00
2020-08-08 22:09:13 -04:00
Simply use it normally, prefacing the `transcrypt` or `git-crypt` commands with
`yadm`.
2019-12-16 23:44:04 -05:00
2020-08-08 22:09:13 -04:00
Learn more about these tools here:
* [transcrypt](https://github.com/elasticdog/transcrypt)
* [git-crypt](https://github.com/AGWA/git-crypt)