Keysafe securely backs up a gpg secret key or other short secret to the cloud.

This is not intended for storing Debian Developer keys that yield root on ten million systems. It's about making it possible for users to use gpg who currently don't, and who would find it too hard to use paperkey to back up and restore their key as they reinstall their laptop.

Not yet ready for production use! Needs security review! May run over your dog! Not suitable for bitcoin keys!

Screenshots

See screenshots. (Keysafe can also run in text mode in a terminal.)

How it works, basically

The secret key is encrypted using a password, and is split into three shards, and each is uploaded to a server run by a different entity. Any two of the shards are sufficient to recover the original key. So any one server can go down and you can still recover the key.

Keysafe checks your password strength (using the excellent but not perfect zxcvbn library), and shows an estimate of the cost to crack your password, before backing up the key.

4.png
(Above is for the password "makesad spindle stick")

Keysafe is designed so that it should take millions of dollars of computer time to crack any fairly good password. (This is accomplished using Argon2.) With a truely good password, such as four random words, the cracking cost should be many trillions of dollars.

The password is the most important line of defense, but keysafe's design also makes it hard for an attacker to even find your encrypted secret key.

For a more in-depth explanation, and some analysis of different attack vectors (and how keysafe thwarts them), see details. Also, there's a FAQ, and a video explaining keysafe.

News

keysafe 0.20200214 released with these changes

  • Updated many dependencies.
  • Support building with ghc 8.x.
  • Stackage lts-14.25.
  • Downgrade purism's keysafe server from recommended to alternate, mostly because the server is down, and AFAIK has been down for years, and I don't currently know if they plan to ever provide it again.
Posted Sat Feb 15 01:20:02 2020

keysafe 0.20180326 released with these changes

  • Updated to argon2-1.3.
Posted Mon Mar 26 12:12:36 2018

keysafe 0.20170811 released with these changes

  • Updated to http-client 0.5.3, servant 0.11, and stackage lts-9.0.
Posted Fri Aug 11 22:59:03 2017

Installation

Keysafe is now available in Debian experimental. Install it from there, or from source.

Git repository

git clone git://keysafe.branchable.com/ keysafe or git clone https://git.joeyh.name/git/keysafe.git/

All tags and commits in this repository are gpg signed, and you should verify the signature before using it.

Building from source

You should first install Haskell's stack tool, the readline and argon2 libraries, and zenity. For example, on a Debian system:

sudo apt-get install haskell-stack libreadline-dev libargon2-0-dev zenity

Then to build and install keysafe, cd into its source tree and run:

stack install

Note that there is a manpage, but stack doesn't install it yet.

Reporting bugs

Post to todo or email id@joeyh.name

Servers

See servers for information on the keysafe servers.

License

Keysafe is licensed under the terms of the AGPL 3+

Thanks

Thanks to Anthony Towns for his help with keysafe's design.