Guardedbox : Online Client-Side Manager For Secure Storage & Secrets Sharing

GuardedBox is an open-source online client-side manager for secure storage and secrets sharing.

It allows users to upload secrets to a centralized server and retrieve them at anytime and from anywhere. It also allows users to share their secrets with other users, individually or via groups.

Secrets are stored encrypted server-side. The encryption is performed client-side by JavaScript code. It is based on ECC-Curve25519 asymmetric encryption and AES256-GCM symmetric encryption. The ECC key pair is generated from the user login credentials during the registration and login processes, by means of PBKDF2.

The server knows the public key of every user. Any user can retrieve the public key of any other user and encrypt a secret for her, in a way that only that user will be able to decrypt it, using his own private key generated from his credentials. This is all done client-side by JavaScript code, minimizing the trust on the server, and using End to End (E2E) encryption between users.

The server does not receive the user password during the login process. Instead, a crypto-challenge is involved using digital signatures based on ECC-EDDSA with ED25519. When a user wants to perform a login, the server sends him a challenge. The user must sign it with his private key and send it back to the server. Again, this is all done client-side by JavaScript code.

Also Read – Saycheese : Grab Target’s Webcam Shots By Link

Online Service

GuardedBox is deployed online. The official details, notification and communication channels, version information (and changelog) and documentation, as well as the reference to the online service, are available at:

It is a free service for anyone: individuals, companies and organizations!

Technical Documentation & Local Deployment

It is a JavaScript and Java/Spring-Boot project:

  • The back-end is based on Java/Spring-Boot. See the “pom.xml” file and the “java” folder (inside “src/main”).
  • The front-end is based on JavaScript using ReactJS. See the “front” folder (inside “src/main”).
  • The database is MySQL. See the “sql” folder (inside “src/main”).

The project can be built via Maven with the following command from its root directory:

mvn clean install

A JAR file (.jar) will be generated in the “target” folder.

The project can be run with the following command from the project root directory:

java -jar target/guardedbox-1.0.0.jar –spring.config.location=file:./config-example/application.properties

It requires a MySQL database instance with the schema described in the file “sql/guardedbox.sql” (inside “src/main”).

It also requires an external properties file (the “application.properties” reference in the previous command). An example of a properties file can be found in the “config-example” folder, plus a server digital certificate for HTTPS.

The project is also dockerized. The image is built during the Maven life cycle. The container can be run locally with the following command from the project root directory:

docker-compose up

Make sure the secrets paths (which point to the properties file) are right in the “docker-compose.yml” file.

The image is available at Docker Hub:

It still requires, as detailed above, a MySQL database instance and a properties file, plus a server digital certificate for HTTPS.

R K

Recent Posts

Vermilion : Mastering Linux Post-Exploitation For Red Team Success

Vermilion is a simple and lightweight CLI tool designed for rapid collection, and optional exfiltration…

1 day ago

AD-CS-Forest-Exploiter : Mastering Security Through PowerShell For AD CS Misconfiguration

ADCFFS is a PowerShell script that can be used to exploit the AD CS container…

1 day ago

Usage Of Tartufo – A Comprehensive Guide To Securing Your Git Repositories

Tartufo will, by default, scan the entire history of a git repository for any text…

1 day ago

Loco : A Rails-Inspired Framework For Rust Developers

Loco is strongly inspired by Rails. If you know Rails and Rust, you'll feel at…

2 days ago

Monolith : The Ultimate Tool For Storing Entire Web Pages As Single HTML Files

A data hoarder’s dream come true: bundle any web page into a single HTML file.…

2 days ago