A comprehensive solution for encrypted data storage.
Go to file
Andrew Lalis 0c5cd95905 Added ClusterIOTest and improved some stuff. 2021-05-31 00:17:31 +02:00
designs Added ability to edit and prepare nicer views for shards. 2021-05-29 23:09:39 +02:00
src Added ClusterIOTest and improved some stuff. 2021-05-31 00:17:31 +02:00
.gitignore Added unit test for shard io. 2021-05-29 11:18:43 +02:00
README.md Updated pom and readme. 2021-05-30 11:40:49 +02:00
pom.xml Added ClusterIOTest and improved some stuff. 2021-05-31 00:17:31 +02:00

README.md

CrystalKeep

A comprehensive solution for encrypted data storage.

Running

To get up and running, clone this repository, and open a terminal in the directory containing the pom.xml file. Run the following maven command:

mvn javafx:run

You can also use the javafx-maven-plugin to generate an executable using mvn javafx:jlink.

Design

CrystalKeep makes use of Shards as the most basic form of encrypted data storage. A shard is a single data item, like login credentials, an image, or some text. One or more shards are stored in a Cluster, which is essentially a collection of shards (and possibly nested clusters). Top-level clusters (not nested inside another) can be encrypted and saved with a secret key passphrase.

With this approach, the user minimizes the amount of data that is accessible to an attacker in the event that the attacker gets access to the system while the contents of a cluster are unencrypted in memory, since only one cluster may be actively open at a time.

Furthermore, by removing a dependency on the host filesystem for encryption of, for example, files or directories, this solution is guaranteed to be equally secure across all platforms that it can run on.