mongocrypt
MongoCrypt is an encryption library for node.js
An example database entry without MongoCrypt:
data:image/s3,"s3://crabby-images/80071/800715c071b65e0bbae642fd0e0505ea17a8f4b9" alt="example without mongocrypt"
The same database entry with MongoCrypt:
data:image/s3,"s3://crabby-images/2dd9e/2dd9e36f3c2f3db87f1c64e29d44290c1e2ed9ea" alt="example without mongocrypt"
Introduction
MongoCrypt is a service to encrypt and decrypt your data stored in a MongoDB database. It was also designed with these principles in mind:
- Lightweight: With a 20KB index.js it's a pretty lightweight library. No unnecessary functions are included so you can care less about this encryption and concentrate more on you task.
- Easy to use: It was designed on top of the MongoDB SDK for node.js and it uses almost identical functions. The findOne function compared:
const collection = "users";
const query = {name: "eykjs"}
db.collection(collection).findOne(query, (err, res) => {
if(!err){
console.log("Email: " + res.email);
}else{
console.log("Error!");
}
});
mongocrypt.db.collection(collection).findOne(query).then(res => {
if(res){
console.log("Email: " + res.email);
}else{
console.log("Error!");
}
});
- Fast & Safe: On average mongocrypt is just 5-15ms slower than the MongoDB SDK (depending on the amount and size of your input values) but a lot safer. The data is encrypted by a modern 256-bit AES algorithm (AES-256-CBC by default)
Installation & Setup
- Install with npm - mongocrypt will install mongodb automatically after its setup
npm install mongocrypt
- Require mongocrypt & connect to your database
const mongocrypt = require('mongocrypt');
const database_url = "mongodb://yourserver:port/yourdatabase";
mongocrypt.db.connect(url).then(err => {
if(!err) {
...
}
});
Everyone
is invited to fork this project and work on it. If you create a pull request and your code is good and useful for this project, it will be merged into mongocrypt. Collaborators are also searched. For future plans have a look at Trello
Usage
The mongocrypt functions are based on the MongoDB SDK functions. The structure is always the same. You can see each equivalent in the list below.
Important before using database functions:
if(mongocrypt.db.isConnected()){
mongocrypt.encryption.set(yourKey);
}else{
}
Standard usage:
The MongoDB JS SDK function compared with the mongocrypt function
- With MongoDB's SDK:
db.collection(collection).function(parameter, callback(err, res))
- With Mongocrypt:
db.collection(collection).function(parameter).then(err)
The parameters of the mongocrypt functions are identical to the common SDK ones. You can find a list of them here. This principle works for all mongocrypt functions except find()
and findOne()
const query = {pro: true}
const options = {sort: {rank: 1}, limit: 5, filter: {email: true}
}
const canAlsoBeOptions = null;
mongocrypt.collection("users").find(query, options).then(res => {
if(res){
console.log("Email: " + res[0].email)
} else {
console.log("An error appeared");
}
})
mongocrypt.collection("users").findOne(query, {email: true}).then(res => {})
List of all Functions
mongocrypt.encryption.setKey(key)
mongocrypt.db.connect(url).then(err)
mongocrypt.db.isConnected()
returns true or falsemongocrypt.db.close()
mongocrypt.db.collection(collection).insertOne(object).then(err)
mongocrypt.db.collection(collection).insertMany(array).then(err)
mongocrypt.db.collection(collection).updateOne(query, object).then(err)
mongocrypt.db.collection(collection).updateMany(query, object).then(err)
mongocrypt.db.collection(collection).findOne(query, filter).then(res)
mongocrypt.db.collection(collection).find(query, options).then(res)
options descripted abovemongocrypt.db.collection(collection).deleteOne(query).then(err)
mongocrypt.db.collection(collection).deleteMany(query).then(err)
mongocrypt.db.collection(collection).drop(query).then(err)
Common errors / FAQ
- Error:
please connect first to a database with mongocrypt.db.connect(url)
- Solution: Look at the setup path of the README. Just fire database functions after the db.connect function has finished
- Error:
please set an encryption key first with mongocrypt.encryption.setKey(key)
- Solution: Set an encryption key first with encryption.setKey(key)
- Error:
the key has to have a length of 32 characters.
- Solution: You can only set a string as encryption key with the length of 32 characters.
Do not hesitate to open an issue or send me a message on Twitter