strencojs
v1.0.0
Published
String encoding with modified Caesar cipher for Javascript
Downloads
3
Maintainers
Readme
strencojs
String encoding with modified Caesar cipher for Javascript.
Encoding is done using rolling cipher.
Minimal required Node version: v12.0.0
Install
npm i strencojs
Usage
Encode plaintext string
import { encode } from 'strencojs';
const plaintext = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.';
const encoded = encode(plaintext);
console.log(encoded); // %%7z;1tsk1JA!NbAFwzj j&{r(3#"+L%m*{<D%Wrh@iyB(qM!eG)>B/ox/%%
Decode encoded string
import { decode } from 'strencojs';
const encoded = '%%7z;1tsk1JA!NbAFwzj j&{r(3#"+L%m*{<D%Wrh@iyB(qM!eG)>B/ox/%%';
const decoded = decode(encoded);
console.log(decoded); // Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Other implementations
Security
This module is not secure, since its main goal is to make the original value unreadable. There are no additional keys, passphrases or secrets required, meaning that anyone can decode encoded value. It is not recommended to store sensitive data encoded with this module.
Performance
By default, this module encodes values in the main thread, meaning that it blocks JS execution. While this is not an issue if you are encoding small strings, this might become a problem when encoding big multiline strings with tens of thousands of symbols.
For the reference: encoding a string that consists of 10000 symbols takes 2 ms
, decoding the same string takes about 3 ms
.
Worker threads should be used for the encoding when dealing with big multiline strings.
Testing
Deploy project locally
git clone https://github.com/julyskies/strencojs
cd ./strencojs
nvm use 12
npm i
Run tests
npm run test
Linting
npm run lint
Using ESLint