eCryptfs (enterprise cryptographic filesystem) is a package of disk encryption software for Linux. Its implementation is a POSIX-compliant[1] filesystem-level encryption layer, aiming to offer functionality similar to that of GnuPG at the operating system level,[2] and has been part of the Linux kernel since version 2.6.19.

eCryptfs
Original author(s)Michael Halcrow, IBM Linux Technology Center, Erez Zadok
Initial releaseNovember 30, 2006; 17 years ago (2006-11-30)
Stable release
111 / May 2, 2016; 8 years ago (2016-05-02)
Written inC
Operating systemLinux
PlatformLinux kernel
Typefilesystem, encryption
LicenseGPL v2+
Websiteecryptfs.org

Details

edit

The eCryptfs package has been included in Ubuntu since version 9.04 to implement Ubuntu's encrypted home directory feature,[3] but is now deprecated[4]

eCryptfs is derived from Erez Zadok's Cryptfs.[5] It uses a variant of the OpenPGP file format for encrypted data, extended to allow random access, storing cryptographic metadata (including a per-file randomly generated session key) with each individual file.[2]

It also encrypts file and directory names which makes them internally longer (average one third). The reason is it needs to uuencode the encrypted names to eliminate unwanted characters in the resulting name. This lowers the maximum usable byte name length of the original file system entry depending on the used file system (this can lead to four times fewer characters for example for Asian utf-8 file names).

See also

edit

References

edit
  1. ^ "About the project". 2012. Retrieved 2018-11-15.
  2. ^ a b Halcrow, Michael Austin (2005). eCryptfs: An Enterprise-class Encrypted Filesystem for Linux (PDF). Proc. Linux Symposium. Vol. 1. Archived from the original (PDF) on 2008-09-16. Retrieved 2020-04-10.
  3. ^ Ian Nicholson (2014-11-24). "Ubuntu CommunityHelpWiki: EncryptedHome". Retrieved 2018-11-15.
  4. ^ Ian Nicholson (2014-11-24). "Ubuntu CommunityHelpWiki: EncryptedHome". Retrieved 2018-11-15.
  5. ^ "eCryptfs – Enterprise Cryptographic Filesystem".
edit