Data protection SDK for Node.js — format-preserving encryption (FF1/FF3), AES-GCM, data masking, and hashing.
npm install cyphera
const { Cyphera } = require("cyphera");
// Auto-discover: checks CYPHERA_CONFIG_FILE env, ./cyphera.json, /etc/cyphera/cyphera.json
const c = Cyphera.load();
// Or load from a specific file
const c = Cyphera.fromFile("./config/cyphera.json");
// Or inline config
const c = new Cyphera({
configurations: {
ssn: { engine: "ff1", key_ref: "my-key", header: "T01" },
},
keys: {
"my-key": { material: "2B7E151628AED2A6ABF7158809CF4F3C" },
},
});
// Protect
const encrypted = c.protect("123-45-6789", "ssn");
// → "T01i6J-xF-07pX" (DPH-prefixed, dashes preserved)
// Access (header-based, no configuration name needed)
const decrypted = c.access(encrypted);
// → "123-45-6789"{
"configurations": {
"ssn": { "engine": "ff1", "key_ref": "my-key", "header": "T01" },
"cc": { "engine": "ff1", "key_ref": "my-key", "header": "T02" },
"ssn_mask": { "engine": "mask", "pattern": "last4", "header_enabled": false }
},
"keys": {
"my-key": { "material": "2B7E151628AED2A6ABF7158809CF4F3C" }
}
}The header (Data Protection Header, DPH) is a short prefix prepended to
protected output that identifies the configuration used. It lets access()
reverse a value without the caller naming the configuration.
All six SDKs produce identical output for the same inputs:
Input: 123-45-6789
Java: T01i6J-xF-07pX
Rust: T01i6J-xF-07pX
Node: T01i6J-xF-07pX
Python: T01i6J-xF-07pX
Go: T01i6J-xF-07pX
.NET: T01i6J-xF-07pX
Alpha. API is unstable. Cross-language test vectors validated against Java, Rust, Python, Go, and .NET implementations.
Apache 2.0 — Copyright 2026 Horizon Digital Engineering LLC