A comprehensive solution for encrypted data storage.
Go to file
Andrew Lalis e88c51c152 Removed debug statement. 2021-06-01 09:53:52 +02:00
designs Cleaned up view models, tried to get pasting to work. 2021-05-31 13:24:32 +02:00
src Removed debug statement. 2021-06-01 09:53:52 +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
cluster_format.md Added version number to file format. 2021-06-01 09:50:12 +02:00
pom.xml Removed jnativehook. 2021-06-01 08:45:03 +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.