node-fpe
Version:
Format-preserving encryption implementation
55 lines (33 loc) • 1.94 kB
Markdown
[](https://github.com/mderazon/node-fpe/actions) [](https://badge.fury.io/js/node-fpe) [](https://opensource.org/licenses/MIT)
> Format preserving string substitution encryption
In general, [format-preserving encryption](https://en.wikipedia.org/wiki/Format-preserving_encryption) is a type of encryption such that the output (the ciphertext) is in the same format as the input (the plaintext).
This library uses a simple [substitution cipher](https://en.wikipedia.org/wiki/Substitution_cipher) algorithm. Read more about the security of this library in the dedicated section below.
cipher with default domain ([0-9])
```js
import fpe from 'node-fpe';
const cipher = fpe({ secret: 'secret!' });
cipher.encrypt('1234567');
// '7130548'
cipher.decrypt('7130548');
// '1234567'
```
cipher with a custom domain ([A-E])
```js
import fpe from 'node-fpe';
const cipher = fpe({ secret: 'secret!', domain: ['A', 'B', 'C', 'D', 'E'] });
cipher.encrypt('BEEBEE');
// 'ABBABB'
cipher.decrypt('ABBABB');
// 'BEEBEE'
```
Options to pass on to _node-fpe_ are:
- `secret`: **mandatory**. a secret used in the underlying hash function.
- `domain`: **optional**. an array of characters used as the FPE domain. **default**: 0-9 digits
This module is using the term _format-preserving encryption_, however it is **not** a proper fpe implementation. It is basically a [substitution cipher](https://en.wikipedia.org/wiki/Substitution_cipher), you can use it to scramble and de-scramble strings but it is **not recommended to use it with anything sensitive** as the encryption is weak.
For fpe, there are other libraries available:
- https://github.com/eCollect/node-fe1-fpe