EncryptedString
type for Mongoose schemas. Provides AES-256-CBC encryption-at-rest for strings.
Usage
var mongoose = require('mongoose');
const mes = require('@tsmx/mongoose-encrypted-string');
const key = 'YOUR KEY HERE';
mes.registerEncryptedString(mongoose, key);
Person = mongoose.model('Person', {
id: { type: String, required: true },
firstName: { type: mongoose.Schema.Types.EncryptedString },
lastName: { type: mongoose.Schema.Types.EncryptedString }
});
let testPerson = new Person();
testPerson.id = 'id-test';
testPerson.firstName = 'Hans';
testPerson.lastName = 'Müller';
await testPerson.save();
let queriedPerson = await Person.findOne({ id: 'id-test' });
console.log(queriedPerson.firstName);
console.log(queriedPerson.lastName);
Directly querying the MongoDB will return the encrypted data.
> db.persons.findOne({ id: 'id-test' });
{
"_id" : ObjectId("5f8576cc0a6ca01d8e5c479c"),
"id" : "id-test",
"firstName" : "66db1589b5c0de7f98f5260092e6799f|a6cb74bc05a52d1244addb125352bb0d",
"lastName" : "2b85f4ca2d98ad1234da376a6d0d9128|d5b0257d3797da7047bfea6dfa62e19c",
"__v" : 0
}
API
registerEncryptedString(mongoose, key)
Registers the new type EncryptedString
in the mongoose
instance's schema types. Encryption/decryption is done with AES-256-CBC using the given key
. After calling this funtion you can start using the new type via mongoose.Schema.Types.EncryptedString
in your schemas.
mongoose
The mongoose instance where EncryptedString
should be registered.
key
The key used for encryption/decryption. Length must be 32 bytes. See notes for details.
Use with lean() queries
For performance reasons it maybe useful to use Mongoose's lean()
queries. Doing so, the query will return the raw JSON objects from the MongoDB database where all properties of type EncryptedString
are encrypted.
To get the clear text values back you can directly use @tsmx/string-crypto which is also used internally in this package for encryption and decryption.
const key = 'YOUR KEY HERE';
const sc = require('@tsmx/string-crypto');
let person = await Person.findOne({ id: 'id-test' }).lean();
let firstName = sc.decrypt(person.firstName, { key: key });
let lastName = sc.decrypt(person.lastName, { key: key });
Notes
- Encryption/decryption is done via the package @tsmx/string-crypto.
- Key length must be 32 bytes. The key can be provided as
- a string of 32 characters length, or
- a hexadecimal value of 64 characters length (= 32 bytes)
- Don't override getters/setter for
EncryptedString
class or schema elements of this type. This would break the encryption.