A comprehensive solution for encrypted data storage.
Go to file
Andrew Lalis d7f08968b3 Added better shard creation dialog, added shard-type specific icons back. 2021-06-01 08:44:05 +02:00
designs Cleaned up view models, tried to get pasting to work. 2021-05-31 13:24:32 +02:00
src Added better shard creation dialog, added shard-type specific icons back. 2021-06-01 08:44:05 +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 controlsfx dependency and toast notifications for password copying. 2021-05-31 22:59:47 +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.