Prerequisites:
- One or more clients running a UNIX-like OS. Examples are given for Ubuntu 12.04 LTS, although all software components are available for other platforms as well (e.g. OS X). YMMV
- A cheap Ubuntu 12.04 VPS with storage. I recommend Backupsy, they offer 250GB storage for $5/month. Ask Google for coupon codes.
Software components used:
- 
Install Unison: $ sudo apt-get install unison 
- 
Add a user for our project and give him a decent password: $ sudo adduser encbox 
- 
Install Unison: $ sudo apt-get install unison 
- 
Enable key-based authentication for SSH (replace your.vps.comwith your VPS' hostname):$ ssh-keygen $ cat ~/.ssh/id_rsa.pub | ssh [email protected] "mkdir ~/.ssh; cat >> ~/.ssh/authorized_keys" 
- 
Create the folder holding our encrypted files: $ mkdir ~/.encbox
- 
Create a unison profile in ~/.unison/encbox.prf(replaceyour.vps.comwith your VPS' hostname):$ mkdir ~/.unison; tee ~/.unison/encbox.prf <<__EOF root = /home/$USER/.encbox root = ssh://[email protected]/encbox prefer = ssh://[email protected]/encbox backups = true times = true terse = true repeat = 2 __EOF 
- 
Create an upstart file to start synchronization automatically (in /etc/init/encbox.conf):$ sudo tee /etc/init/encbox.conf <<__EOF description "encbox" start on desktop-session-start stop on desktop-shutdown setuid $USER setgid $USER env HOME=$HOME respawn script bash -l -c "unison encbox; sleep 2" end script __EOF 
- 
Start Unison: # either run in foreground: $ unison encbox # or run it as a system service: $ sudo service encbox start # starts your Encbox $ sudo service encbox stop # stops your Encbox If unison complains about archive files on your client, run it once with the -ignorearchivesflag:$ unison -ignorearchives encbox 
- 
Install EncFS: $ sudo apt-get install encfs 
- 
Mount encrypted directory: $ encfs ~/.encbox ~/Encbox Agree to have your target directory created, then choose pto use EncFS' preconfigured paranoia mode. Give your folder a decent password.
- 
That's it! All files in ~/Encboxwill be encrypted and synced securely between your VPS and all clients.
- 
Polling: Unfortunately, Unison doesn't support file system notifications (i.e. inotify, libnotify), so it polls your file system for changes every 2 seconds (if you set repeat = 2in your profile as we did above). This isn't nice, but I did not observe any negative effects on my notebook's battery life. Feel free to set therepeatparameter to some higher value if you observe negative effects. Bandwith usage for polling is negligible as well (~0.9 kB/poll, ~3.5 kbit/s).
- 
Unison version Rumor has it you should use the same Unison version on your server as well as on all your clients, or you will run into problems. I didn't test it, though. 
- 
Android / iOS app: This setup is compatible with Boxcryptor Classic's smartphone apps. You just have to create an EncFS folder in expert mode ( x) and follow the instructions at Boxcryptor's Support Desk. Then install a WebDAV server of your choice and expose/home/encbox/encboxvia WebDAV (not in this document's scope).