README
                    
                  The High Security EnCrypting File System.
 HSENCFS is a user space encrypting file system. Simple to set up, seamless
to use, fast, safe, secure and maintenance free. It will encrypt
data on the fly written to it, decrypt data read from it. HSENCFS uses only 
storage space for actual data stored, no pre-allocation needed. It is fast 
enough for real time Video Encryption. HSENCFS is classified as a variable 
key length encryption.
                
 An additional (and useful) feature is auditing. HSENCFS reports file access 
by time and user ID. The report is sent to syslog. The log is sent to facility
'daemon' with level 'DEBUG'. See: the -l log option.)
 To use it (as a simple example):
      hsencfs  -l 2 ~/.secretdata ~/secrets
 Will ask for password, and password creation confirmation if started on 
a new mount. The above command exposes the ~/secrets directory with the 
backing data directory in ~/.secretdata. 
For added convenience, use a dotted (hidden) file for mountdata. 
(example: ~/.my_secret_data or ~/.data or ~/.secrets) (note the leading dot)
  
 You may un-mount your secret directory with the normal umount(8) utility
or the fusermount -u option. After un-mounting, the mounted data is not 
accessible, and the encrypted data is not legible until it is mounted again.
(example: fusermount ~/secrets) The tilde '~' expands to the user's home dir.
# -----------------------------------------------------------------------
Password / Key management.
 HSENCFS does not manage passwords. The password becomes the encryption key, 
and the key is used to encrypt the file system access. If the password / key 
is lost, the data cannot be recovered.
 As the password becomes the key, it is possible to achieve long key lengths
by entering a long password. Short key lengths are replicated to standard 
legal length.
# -----------------------------------------------------------------------
On Demand Password entry:
 HSENCFS mount can be mounted (started) with the on-demand (-o) password 
option. This allows the encryption to ask for a password when any
encrypted file is first accessed. 
 The on-demand option requires the use of an ask-pass program. The 
hsaskpass.py is supplied for GUI deployment. HSENCFS will start the ask-pass 
program when a password is needed. This only truly makes sense on GUI 
deployment, but the console program (hsaskpass) can also be specified.
An example of on-demand command line: 
        hsencfs -o -a 'which hsaskpass.py` .mydata mysecret
        
Note the 'which' utility, HSENCF needs absolute path.
# -----------------------------------------------------------------------
Safety, Security, Feeding and Care
 HSENCFS uses BluePoint2 encryption. Bluepoint(2) has been thoroughly tested,
and withstood the test of time. The backing files in the data directory 
preserve their original names, size, and access times. The only dependence 
they need is the original password. This means they can be safely copied from 
the backing directory for transport (like email) or backup. Please note
that HSENCFS relies on the file system having block size 4096. This is 
the case with most modern systems, so it does not present an issue. If the 
block size is not 4096, HSENCFS will operate fine, but the data may not be 
portable across systems with different block sizes. The internal block size
of HSENCFS is 1024, which makes it operate across a large number of systems.
# -----------------------------------------------------------------------
The data directory:
Files can be extracted from the backing data directory with the 'bpdec2' 
utility. To extract a single encrypted file by hand:
     bpdec2 ~/secretdata/filename > newname
     
(Will ask for password.)
 Also, files can be copied to the backing data directory with 
the 'bpenc2' utility. To add a single file into the data directory by hand:
     bpdec2 filename > ~/.secretdata/newname
     
(Will ask for password.)
 Both bp(enc/dec) utilities need the correct password to create data 
accessible from the HSENCFS subsystem. The utilities do not check the 
encryption key, so the wrong password will produce false cipher-text /
false clear-text. You may reverse false encryption by entering the same 
password on decrypt. These utilities are provided as recovery tools only.
  The wrong password creates garbled data. ** You have been warned. **
# -----------------------------------------------------------------------
The cypher text.
 Files can be copied out from the backing data directory. They stay encrypted
when copied directly out of the data directory. This is useful for backup /
replication / archiving / transport etc ...
# -----------------------------------------------------------------------
Go to the Cloud.
 The backing data directory can reside on any valid file system, including
a cloud drive. HSENCFS will encrypt data automatically before it sees
the transport layer, and decrypt data after the transport layer delivered it.
This allows secure remote storage.
# -----------------------------------------------------------------------
The Mountpoint directory:
 When the mountpoint is mounted, data is encrypted / decrypted on the fly.
FUSE will warn you if the mount directory is not empty on mount. It is 
usually undesirable to mount over data. You may force the mount, see FUSE 
options for details.
Configuring Shared Mountpoint(s):
 By default FUSE will not allow anyone (except the user) to see the mount. To
create a mount that is visible by others (on the same system) use the fuse
'allow_other' option. To append FUSE options, use '--' at the end of HSENCFS 
command line. Fuse will not allow the allow_other option unless configured in 
/etc/fuse.conf (add a line: 'user_allow_other')
 Example: 
        hsencfs .mydata mymount -- -o allow_other
# -----------------------------------------------------------------------
Technical Description:
 HSENCFS makes use of the API offered by the fuse subsystem to intercept file 
operations. The interception is done from mountdata to mountpoint. Copying
data to mountpoint ends up encrypted in mountdata. Because of HSENCFS intercept
concept, encryption / decryption is fast. It is plausible to use it to encrypt
video streams.
# -----------------------------------------------------------------------
The GNOME Panel Applet:
HSENCFS can be controlled from the GNOME Panl (System Tray) with the 
hstray.py utility. New mounts can be added, mounted or unmounted. The mounts 
are relative to the user's home directory unless an absolute path is specified.
 The 'comments' field can be used as a password hint. See PASSHINTS.
 Removing mounts from the hstray's list does not effect the data behind it.
The mounts created from the system tray are visible from the command line, 
but the mounts created on the command line are not visible in the system 
tray. (added protection)
 Upon install, the System Panel needs to rescan for the list of Applets for
the HSENCFS applet to show up. This can be achieved by adding an arbitrary
Applet to the panel, and then removing it. After the panel add / remove cycle,  
the HSENCFS applet will show up. 
 Naturally, one can force a rescan by restarting the gnome-panel or X-windows 
or the whole system.
Additional Versions:
 The industrial version of this project is available upon request. 
Please send a message to the author. (see Sourceforge page)