项目作者: Gavin-Song

项目描述 :
A node.js implementation of the ElsieFour (LC4) cipher
高级语言: JavaScript
项目地址: git://github.com/Gavin-Song/elsie-four-cipher.git
创建时间: 2018-05-17T01:11:19Z
项目社区:https://github.com/Gavin-Song/elsie-four-cipher

开源协议:MIT License

下载


elsie-four-cipher

npm version
Codacy Badge
Build Status

A node.js implementation of the ElsieFour (LC4) cipher (https://eprint.iacr.org/2017/339.pdf). Currently supports encryption and decryption, but not the nonce or signature auth.

Install

npm install elsie-four-cipher --save

Example

  1. const cipher = require('elsie-four-cipher');
  2. // encrypt(key, message). This example returns tk5j23tq94_gw9c#lhzs
  3. cipher.encrypt('s2ferw_nx346ty5odiupq#lmz8ajhgcvk79b', 'aaaaaaaaaaaaaaaaaaaa');
  4. // decrypt (key, message). This example returns aaaaaaaaaaaaaaaaaaaa
  5. cipher.decrypt('s2ferw_nx346ty5odiupq#lmz8ajhgcvk79b', 'tk5j23tq94_gw9c#lhzs');

What is ElsieFour?

ElsieFour (LC4) is a low-tech cipher that can be computed by hand;
but unlike many historical ciphers, LC4 is designed to be hard to break. LC4 is in
tended for encrypted communication between humans only, and therefore it encrypts
and decrypts plaintexts and ciphertexts consisting only of the English letters
A through Z plus a few other characters

In other words, it’s a cipher that can be easily computed by hand. It uses a grid of the following alphabet:
#_23456789abcdefghijklmnopqrstuvwxyz
In some combination (a key). This grid is operated on depending on the value of the square and the location of a marker that starts in the top right corner. (See the paper for a detailed explaination. There is a tutorial with images near the end of the paper)

Test

npm test

License

This project is under the MIT License (See LICENSE)