2016-01-05 21:18:04 +01:00
|
|
|
[![gocryptfs](https://nuetzlich.net/gocryptfs/img/gocryptfs-logo.paths-black.svg)](https://nuetzlich.net/gocryptfs/) [![Build Status](https://travis-ci.org/rfjakob/gocryptfs.svg?branch=master)](https://travis-ci.org/rfjakob/gocryptfs) ![MIT License](https://img.shields.io/badge/license-MIT-blue.svg)
|
2015-10-11 23:57:51 +02:00
|
|
|
==============
|
2015-11-01 12:14:59 +01:00
|
|
|
An encrypted overlay filesystem written in Go.
|
2015-12-20 18:25:10 +01:00
|
|
|
Official website: https://nuetzlich.net/gocryptfs
|
2015-09-06 12:12:14 +02:00
|
|
|
|
2015-10-06 00:31:53 +02:00
|
|
|
gocryptfs is built on top the excellent
|
|
|
|
[go-fuse](https://github.com/hanwen/go-fuse) FUSE library and its
|
|
|
|
LoopbackFileSystem API.
|
2015-09-06 12:12:14 +02:00
|
|
|
|
2015-12-08 16:41:45 +01:00
|
|
|
This project was inspired by EncFS and strives to fix its security
|
|
|
|
issues while providing good performance.
|
2015-11-01 12:14:59 +01:00
|
|
|
For details on the security of gocryptfs see the
|
2015-12-20 18:25:10 +01:00
|
|
|
[Security](https://nuetzlich.net/gocryptfs/security/) design document.
|
2015-09-08 23:09:28 +02:00
|
|
|
|
2015-12-20 21:15:49 +01:00
|
|
|
All tags from v0.4 onward are signed by the *gocryptfs signing key*.
|
2016-01-09 15:31:58 +01:00
|
|
|
Please check [Signed Releases](https://nuetzlich.net/gocryptfs/releases/) for
|
2015-12-20 21:15:49 +01:00
|
|
|
details.
|
|
|
|
|
2015-10-06 23:08:04 +02:00
|
|
|
Current Status
|
|
|
|
--------------
|
2015-11-14 19:10:52 +01:00
|
|
|
|
2016-01-09 15:31:58 +01:00
|
|
|
gocryptfs is a young project. While bugs in any software can cause issues,
|
|
|
|
bugs in encryption software can cause catastrophic data loss. Keep a backup
|
|
|
|
of your gocryptfs filesystem *and* store a copy of your master key (printed
|
|
|
|
on mount) in a safe place.
|
2015-11-14 19:10:52 +01:00
|
|
|
|
2016-01-04 10:24:00 +01:00
|
|
|
Only Linux is supported at the moment. [Help wanted for a Mac OS X port.](https://github.com/rfjakob/gocryptfs/issues/15)
|
2015-11-14 19:10:52 +01:00
|
|
|
|
|
|
|
Testing
|
|
|
|
-------
|
|
|
|
|
2015-11-15 16:06:19 +01:00
|
|
|
gocryptfs comes with is own test suite that is constantly expanded as features are
|
2016-01-09 15:31:58 +01:00
|
|
|
added. Run it using `./test.bash`. It takes about 1 minute and requires FUSE
|
2015-11-15 16:06:19 +01:00
|
|
|
as it mounts several test filesystems.
|
2015-11-14 19:10:52 +01:00
|
|
|
|
2015-11-15 16:06:19 +01:00
|
|
|
In addition, I have ported `xfstests` to FUSE, the result is the
|
2015-11-14 19:10:52 +01:00
|
|
|
[fuse-xfstests](https://github.com/rfjakob/fuse-xfstests) project. gocryptfs
|
2015-12-01 18:19:24 +01:00
|
|
|
passes the "generic" tests with one exception, results: [XFSTESTS.md](Documentation/XFSTESTS.md)
|
2015-11-14 19:10:52 +01:00
|
|
|
|
|
|
|
A lot of work has gone into this. The testing has found bugs in gocryptfs
|
|
|
|
as well as in go-fuse.
|
|
|
|
|
|
|
|
The one exception is generic/035, see [go-fuse issue 55](https://github.com/hanwen/go-fuse/issues/55)
|
|
|
|
for details. While this is a POSIX violation, I do not see any real-world impact.
|
2015-10-06 23:08:04 +02:00
|
|
|
|
2016-01-09 15:31:58 +01:00
|
|
|
Compile
|
2015-10-06 23:08:04 +02:00
|
|
|
-------
|
|
|
|
|
2015-10-11 19:45:03 +02:00
|
|
|
$ go get github.com/rfjakob/gocryptfs
|
2015-10-07 23:30:45 +02:00
|
|
|
|
|
|
|
Use
|
|
|
|
---
|
|
|
|
|
|
|
|
$ mkdir cipher plain
|
2016-01-09 15:31:58 +01:00
|
|
|
$ $GOPATH/bin/gocryptfs -init cipher
|
2015-10-11 19:45:03 +02:00
|
|
|
$ $GOPATH/bin/gocryptfs cipher plain
|
2016-01-09 15:31:58 +01:00
|
|
|
|
|
|
|
See the [Quickstart](https://nuetzlich.net/gocryptfs/quickstart/) page for more info.
|
|
|
|
|
|
|
|
The [MANPAGE.md](Documentation/MANPAGE.md) containes a description of available command-line options.
|
|
|
|
If you already have gocryptfs installed, run `./MANPAGE-render.bash` to bring up the rendered manpage in
|
|
|
|
your man pager (requires pandoc).
|
2015-11-11 09:19:53 +01:00
|
|
|
|
2015-11-01 12:14:59 +01:00
|
|
|
Storage Overhead
|
|
|
|
----------------
|
|
|
|
|
|
|
|
* Empty files take 0 bytes on disk
|
|
|
|
* 18 byte file header for non-empty files (2 bytes version, 16 bytes random file id)
|
|
|
|
* 28 bytes of storage overhead per 4kB block (12 byte nonce, 16 bytes auth tag)
|
|
|
|
|
2016-01-09 15:31:58 +01:00
|
|
|
[file-format.md](Documentation/file-format.md) contains a more detailed description.
|
|
|
|
|
2015-10-06 23:08:04 +02:00
|
|
|
Performance
|
|
|
|
-----------
|
|
|
|
|
2016-05-04 19:55:20 +02:00
|
|
|
Since version 0.7.2, gocryptfs is as fast as EncFS in the default mode,
|
|
|
|
and significantly faster than EncFS' "paranoia" mode that provides
|
|
|
|
a security level comparable to gocryptfs.
|
2015-09-06 12:16:34 +02:00
|
|
|
|
2016-05-04 19:55:20 +02:00
|
|
|
gocryptfs uses OpenSSL through a thin wrapper called `stupidgcm`.
|
|
|
|
This provides a 4x speedup compared to Go's builtin AES-GCM
|
|
|
|
implementation - see [openssl-gcm.md](Documentation/openssl-gcm.md)
|
|
|
|
for details. The use of openssl can disabled on the command-line.
|
2015-09-06 12:12:14 +02:00
|
|
|
|
2016-05-04 19:55:20 +02:00
|
|
|
Run `./benchmark.bash` to run gocryptfs' canonical set of
|
|
|
|
benchmarks that include streaming write, extracting a linux kernel
|
|
|
|
tarball, recursively listing and finally deleting it. The output will
|
|
|
|
look like this:
|
2015-09-06 12:12:14 +02:00
|
|
|
|
2016-01-23 20:17:34 +01:00
|
|
|
```
|
|
|
|
$ ./benchmark.bash
|
2016-05-04 19:55:20 +02:00
|
|
|
linux-3.0.tar.gz 100%[==========================>] 92,20M 2,96MB/s in 35s
|
|
|
|
2016-05-04 19:29:20 URL:https://www.kernel.org/pub/linux/kernel/v3.0/linux-3.0.tar.gz
|
|
|
|
WRITE: 131072000 bytes (131 MB) copied, 1,43137 s, 91,6 MB/s
|
|
|
|
UNTAR: 23.25
|
|
|
|
LS: 1.75
|
|
|
|
RM: 4.42
|
2016-01-23 20:17:34 +01:00
|
|
|
```
|
2015-10-06 00:31:53 +02:00
|
|
|
|
2015-11-01 01:32:33 +01:00
|
|
|
Changelog
|
|
|
|
---------
|
|
|
|
|
2016-05-04 19:55:20 +02:00
|
|
|
v0.10-rc1
|
|
|
|
* **Drop dependency to `spacemonkeygo/openssl`**
|
2016-05-04 20:04:10 +02:00
|
|
|
* gocryptfs now has its own thin wrapper to OpenSSL's GCM implementation
|
2016-05-04 19:55:20 +02:00
|
|
|
called `stupidgcm`.
|
|
|
|
* This should fix the [compile issues](https://github.com/rfjakob/gocryptfs/issues/21)
|
|
|
|
people are seeing with `spacemonkeygo/openssl` and it also gets us
|
|
|
|
a 20% performance boost for streaming writes.
|
|
|
|
|
2016-04-10 23:01:00 +02:00
|
|
|
v0.9
|
|
|
|
* **Long file name support**
|
2016-04-03 23:11:46 +02:00
|
|
|
* gocryptfs now supports file names up to 255 characters.
|
|
|
|
* This is a forwards-compatible change. gocryptfs v0.9 can mount filesystems
|
|
|
|
created by earlier versions but not the other way round.
|
|
|
|
* Refactor gocryptfs into multiple "internal" packages
|
|
|
|
* New command-line options:
|
|
|
|
* `-longnames`: Enable long file name support (default true)
|
|
|
|
* `-nosyslog`: Print messages to stdout and stderr instead of syslog (default false)
|
|
|
|
* `-wpanic`: Make warning messages fatal (used for testing)
|
|
|
|
* `-d`: Alias for `-debug`
|
|
|
|
* `-q`: Alias for `-quiet`
|
|
|
|
|
2016-01-23 19:35:51 +01:00
|
|
|
v0.8
|
|
|
|
* Redirect output to syslog when running in the background
|
|
|
|
* New command-line option:
|
|
|
|
* `-memprofile`: Write a memory allocation debugging profile the specified
|
|
|
|
file
|
|
|
|
|
2016-01-19 22:56:33 +01:00
|
|
|
v0.7.2
|
2016-01-19 23:08:10 +01:00
|
|
|
* **Fix performance issue in small file creation**
|
2016-01-19 22:56:33 +01:00
|
|
|
* This brings performance on-par with EncFS paranoia mode, with streaming writes
|
|
|
|
significantly faster
|
|
|
|
* The actual [fix](https://github.com/hanwen/go-fuse/commit/c4b6b7949716d13eec856baffc7b7941ae21778c)
|
|
|
|
is in the go-fuse library. There are no code changes in gocryptfs.
|
|
|
|
|
2016-01-09 15:31:58 +01:00
|
|
|
v0.7.1
|
|
|
|
* Make the `build.bash` script compatible with Go 1.3
|
|
|
|
* Disable fallocate on OSX (system call not availabe)
|
|
|
|
* Introduce pre-built binaries for Fedora 23 and Debian 8
|
|
|
|
|
2015-12-20 15:42:52 +01:00
|
|
|
v0.7
|
|
|
|
* **Extend GCM IV size to 128 bit from Go's default of 96 bit**
|
|
|
|
* This pushes back the birthday bound to make IV collisions virtually
|
|
|
|
impossible
|
|
|
|
* This is a forwards-compatible change. gocryptfs v0.7 can mount filesystems
|
|
|
|
created by earlier versions but not the other way round.
|
|
|
|
* New command-line option:
|
|
|
|
* `-gcmiv128`: Use 128-bit GCM IVs (default true)
|
|
|
|
|
2015-12-08 16:41:45 +01:00
|
|
|
v0.6
|
|
|
|
* **Wide-block filename encryption using EME + DirIV**
|
|
|
|
* EME (ECB-Mix-ECB) provides even better security than CBC as it fixes
|
|
|
|
the prefix leak. The used Go EME implementation is
|
|
|
|
https://github.com/rfjakob/eme which is, as far as I know, the first
|
|
|
|
implementation of EME in Go.
|
2015-12-08 16:44:39 +01:00
|
|
|
* This is a forwards-compatible change. gocryptfs v0.6 can mount filesystems
|
2015-12-20 15:42:52 +01:00
|
|
|
created by earlier versions but not the other way round.
|
2015-12-08 16:41:45 +01:00
|
|
|
* New command-line option:
|
|
|
|
* `-emenames`: Enable EME filename encryption (default true)
|
|
|
|
|
2016-01-09 15:31:58 +01:00
|
|
|
v0.5.1
|
|
|
|
* Fix a rename regression caused by DirIV and add test case
|
|
|
|
* Use fallocate to guard against out-of-space errors
|
|
|
|
|
2015-12-06 15:13:06 +01:00
|
|
|
v0.5
|
2015-11-29 22:36:25 +01:00
|
|
|
* **Stronger filename encryption: DirIV**
|
|
|
|
* Each directory gets a random 128 bit file name IV on creation,
|
|
|
|
stored in `gocryptfs.diriv`
|
|
|
|
* This makes it impossible to identify identically-named files across
|
|
|
|
directories
|
|
|
|
* A single-entry IV cache brings the performance cost of DirIV close to
|
|
|
|
zero for common operations (see performance.txt)
|
|
|
|
* This is a forwards-compatible change. gocryptfs v0.5 can mount filesystems
|
2015-12-20 15:42:52 +01:00
|
|
|
created by earlier versions but not the other way round.
|
2015-11-29 22:36:25 +01:00
|
|
|
* New command-line option:
|
|
|
|
* `-diriv`: Use the new per-directory IV file name encryption (default true)
|
|
|
|
* `-scryptn`: allows to set the scrypt cost parameter N. This option
|
|
|
|
can be used for faster mounting at the cost of lower brute-force
|
|
|
|
resistance. It was mainly added to speed up the automated tests.
|
|
|
|
|
2015-11-15 16:06:19 +01:00
|
|
|
v0.4
|
|
|
|
* New command-line options:
|
|
|
|
* `-plaintextnames`: disables filename encryption, added on user request
|
|
|
|
* `-extpass`: calls an external program for prompting for the password
|
|
|
|
* `-config`: allows to specify a custom gocryptfs.conf path
|
|
|
|
* Add `FeatureFlags` gocryptfs.conf paramter
|
2015-11-03 22:34:03 +01:00
|
|
|
* This is a config format change, hence the on-disk format is incremented
|
|
|
|
* Used for ext4-style filesystem feature flags. This should help avoid future
|
2015-11-15 16:06:19 +01:00
|
|
|
format changes. The first user is `-plaintextnames`.
|
2015-11-03 00:08:31 +01:00
|
|
|
* On-disk format 2
|
|
|
|
|
2015-11-01 14:07:42 +01:00
|
|
|
v0.3
|
2015-11-29 22:36:25 +01:00
|
|
|
* **Add a random 128 bit file header to authenticate file->block ownership**
|
2015-11-01 01:32:33 +01:00
|
|
|
* This is an on-disk-format change
|
2015-11-01 14:07:42 +01:00
|
|
|
* On-disk format 1
|
2015-11-01 01:32:33 +01:00
|
|
|
|
|
|
|
v0.2
|
|
|
|
* Replace bash daemonization wrapper with native Go implementation
|
|
|
|
* Better user feedback on mount failures
|
|
|
|
|
|
|
|
v0.1
|
|
|
|
* First release
|
2015-11-01 14:07:42 +01:00
|
|
|
* On-disk format 0
|
2015-11-01 01:32:33 +01:00
|
|
|
|
2015-11-15 16:10:45 +01:00
|
|
|
See https://github.com/rfjakob/gocryptfs/tags for the release dates and associated
|
|
|
|
git tags.
|