2020-04-24 06:55:38 +00:00
|
|
|
# secret
|
|
|
|
|
2020-05-04 11:29:13 +00:00
|
|
|
A simple and tiny tool that will help you keep your little secrets.
|
2020-04-24 06:55:38 +00:00
|
|
|
|
|
|
|
## Features
|
|
|
|
|
2020-05-04 11:29:13 +00:00
|
|
|
`secret` is the simplest secret store you can think of.
|
|
|
|
But it does have some interesting features:
|
2020-04-25 11:40:13 +00:00
|
|
|
|
|
|
|
- Requires only one file `~/.secret` that you can share publicly without fear.
|
2020-05-27 08:35:09 +00:00
|
|
|
- No configuration. No directory. Get back your file and you're done.
|
2020-05-02 16:41:29 +00:00
|
|
|
- Secret names (usually hostname, mail, login, etc.) are also encrypted.
|
|
|
|
- A secret agent that only trusts subprocesses. Not all the processes of the same user!
|
2020-05-04 11:29:13 +00:00
|
|
|
- Secret names completion is available after calling the secret agent.
|
2020-05-02 16:41:29 +00:00
|
|
|
- Supports unstored secrets. Derived from some simple keys and a passphrase.
|
2020-05-06 19:34:46 +00:00
|
|
|
- Supports multiple passphrases. A confirmation is requested for each new passphrase.
|
2020-04-24 06:55:38 +00:00
|
|
|
- Depends only on the [libhydrogen](https://libhydrogen.org/) library.
|
2020-04-25 11:40:13 +00:00
|
|
|
- Small, simple and non obfuscated C code. Well, I hope so :)
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-05-27 08:35:09 +00:00
|
|
|
## Security
|
|
|
|
|
|
|
|
The main goal is to have `secret` working on all architectures and to make it very simple to audit.
|
|
|
|
|
|
|
|
Luckily, permutation-based cryptography has arrived and makes it possible to achieve this goal with very little code.
|
|
|
|
In 2020, using a bloated library full of CVEs will not have been reasonable considering the major advances in this field.
|
|
|
|
|
2020-05-27 14:09:54 +02:00
|
|
|
Only one cryptographic building block is used, the [Gimli](https://gimli.cr.yp.to/gimli-20170627.pdf) permutation.
|
2020-05-27 08:35:09 +00:00
|
|
|
All cryptographic operations are derived from this permutation and implemented in the [libhydrogen](https://libhydrogen.org/) library.
|
|
|
|
|
2020-04-24 06:55:38 +00:00
|
|
|
## Build and install
|
|
|
|
|
2020-05-04 11:29:13 +00:00
|
|
|
This should work on a wide variety of architectures and POSIX systems.
|
|
|
|
It was successfully tested on Linux, OpenBSD, FreeBSD and MacOS.
|
|
|
|
|
2020-04-25 22:19:08 +00:00
|
|
|
Clone the repository recursively:
|
|
|
|
|
2020-04-25 11:40:13 +00:00
|
|
|
$ git clone https://github.com/angt/secret --recursive
|
|
|
|
$ cd secret
|
|
|
|
|
2020-04-25 22:19:08 +00:00
|
|
|
Then, run as `root`:
|
|
|
|
|
|
|
|
# make install
|
2020-04-25 11:40:13 +00:00
|
|
|
|
2020-04-25 22:19:08 +00:00
|
|
|
As usual, you can customize the destination with `DESTDIR` and `prefix`.
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-05-08 15:05:18 +00:00
|
|
|
### Tab completion
|
2020-04-24 07:05:00 +00:00
|
|
|
|
2020-05-08 15:05:18 +00:00
|
|
|
Tab completion works with `bash` and `yash` (`zsh` is also supported if you enable `bashcompinit`).
|
|
|
|
Unfortunately, it doesn't work out of the box, you have to setup it manually.
|
|
|
|
Luckily, it's super easy!
|
2020-04-24 07:05:00 +00:00
|
|
|
|
2020-05-08 15:05:18 +00:00
|
|
|
Download the file corresponding to your shell:
|
|
|
|
- [argz.bash](https://github.com/angt/argz/blob/dev/comp/argz.bash).
|
|
|
|
- [argz.yash](https://github.com/angt/argz/blob/dev/comp/argz.yash).
|
|
|
|
|
|
|
|
Then you can add these lines in your `.bashrc` (or `.zshrc`):
|
|
|
|
|
|
|
|
. argz.bash
|
|
|
|
complete -F _argz secret
|
|
|
|
|
|
|
|
Or in your `.yashrc`:
|
|
|
|
|
|
|
|
. argz.yash
|
|
|
|
|
|
|
|
function completion/secret {
|
|
|
|
command -f completion//reexecute argz
|
|
|
|
}
|
2020-05-04 11:29:13 +00:00
|
|
|
|
2020-04-25 11:40:13 +00:00
|
|
|
Completion for secrets is only available in a trusted shell. See below.
|
|
|
|
|
2020-04-24 06:55:38 +00:00
|
|
|
## Commands
|
|
|
|
|
2020-04-27 20:58:13 +00:00
|
|
|
Available commands:
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-05-27 12:44:16 +02:00
|
|
|
init Initialize secret for the current user
|
|
|
|
list List all secrets for a given passphrase
|
|
|
|
show Print a secret
|
|
|
|
new Generate a new random secret
|
|
|
|
set Set a new secret
|
|
|
|
renew Regenerate an existing secret
|
|
|
|
update Update an existing secret
|
2020-05-27 14:09:54 +02:00
|
|
|
pass Print a deterministic secret
|
2020-05-27 12:44:16 +02:00
|
|
|
agent Run a process in a trusted zone
|
|
|
|
version Show version
|
2020-04-27 20:58:13 +00:00
|
|
|
|
|
|
|
All secrets are encrypted in the file `~/.secret`.
|
|
|
|
You can use a different file with the `SECRET_STORE` environment variable:
|
2020-04-26 08:30:22 +00:00
|
|
|
|
|
|
|
$ env SECRET_STORE=<FILE> secret ...
|
|
|
|
|
2020-04-24 06:55:38 +00:00
|
|
|
## Examples
|
|
|
|
|
2020-04-25 11:40:13 +00:00
|
|
|
Initialize secret for the current user:
|
2020-04-24 06:55:38 +00:00
|
|
|
|
|
|
|
$ secret init
|
|
|
|
|
2020-04-26 08:30:22 +00:00
|
|
|
Add a new randomly generated secret:
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-04-27 20:58:13 +00:00
|
|
|
$ secret new test
|
2020-04-26 20:44:54 +00:00
|
|
|
Passphrase:
|
2020-04-29 11:18:55 +00:00
|
|
|
^>f.8%]_zoN^jSi0CO_{(yYY5
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-04-25 11:40:13 +00:00
|
|
|
Show the secret:
|
2020-04-24 06:55:38 +00:00
|
|
|
|
|
|
|
$ secret show test
|
2020-04-26 20:44:54 +00:00
|
|
|
Passphrase:
|
2020-04-29 11:18:55 +00:00
|
|
|
^>f.8%]_zoN^jSi0CO_{(yYY5
|
|
|
|
|
|
|
|
Derive a deterministic (a.k.a. unstored) secret:
|
|
|
|
|
|
|
|
$ secret pass me@domain.com
|
|
|
|
Passphrase:
|
|
|
|
a`4$B2mJ=|"HD?b4:/y"?wOaQ
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-04-29 12:50:59 +00:00
|
|
|
Subkeys are also supported, this allows to update your secret in a clean way:
|
|
|
|
|
|
|
|
$ secret pass me@domain.com 2020
|
|
|
|
Passphrase:
|
|
|
|
F"1j;-X]t.Pi>.xf5hG,]dUMz
|
|
|
|
|
2020-04-28 16:18:33 +00:00
|
|
|
Storing binary secrets is supported:
|
|
|
|
|
2020-05-28 14:58:10 +00:00
|
|
|
$ dd if=/dev/urandom bs=1 count=32 2>/dev/null | secret set mykey
|
2020-04-28 16:18:33 +00:00
|
|
|
Passphrase:
|
|
|
|
|
|
|
|
Then, use a pipe to get it:
|
|
|
|
|
|
|
|
$ secret show mykey | xxd
|
|
|
|
Passphrase:
|
|
|
|
00000000: 0ee9 cdb3 de0a 3e71 b623 726d 5d7e eb23 ......>q.#rm]~.#
|
|
|
|
00000010: 5b43 a458 3fb7 3b96 ea9b 6e47 d302 cae7 [C.X?.;...nG....
|
|
|
|
|
2020-04-27 09:48:50 +00:00
|
|
|
Start a trusted zone:
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-04-27 09:48:50 +00:00
|
|
|
$ secret agent
|
2020-04-26 20:44:54 +00:00
|
|
|
Passphrase:
|
2020-04-24 06:55:38 +00:00
|
|
|
|
2020-04-26 08:30:22 +00:00
|
|
|
Now, the passphrase is not requested and completion fully works!
|
2020-04-25 11:40:13 +00:00
|
|
|
|
2020-04-27 09:48:50 +00:00
|
|
|
If you don't use `bash` but still want completion,
|
|
|
|
run `secret agent bash` or (much better) send a PR to add support for your shiny shell :)
|
|
|
|
|
2020-09-14 08:19:59 +00:00
|
|
|
Finally, if you want to generate TOTP tokens go check out [totp](https://github.com/angt/totp).
|
2020-09-18 18:05:53 +02:00
|
|
|
You can also use the [totp branch](https://github.com/angt/secret/tree/totp).
|
2020-09-14 08:19:59 +00:00
|
|
|
|
2020-04-25 11:40:13 +00:00
|
|
|
---
|
|
|
|
For feature requests and bug reports,
|
|
|
|
please create an [issue](https://github.com/angt/secret/issues).
|