JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 88
  • Score
    100M100P100Q60935F
  • License MIT

A Spritz stream-cipher implementation in JavaScript

Package Exports

  • spritzjs

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (spritzjs) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

spritzjs

A Spritz stream-cipher implementation in JavaScript

Created with reference to "Spritz - a spongy RC4-like stream cipher and hash function" by Ronald L. Rivest and Jacob C. N. Schuldt on 2014.10.27 - http://people.csail.mit.edu/rivest/pubs/RS14.pdf

Intent

Provide a literal JavaScript reference implementation from the pseudo-code provided by Rivest and Schuldt; allowing the reader to follow the Paper with this code serving as an accompaniment. To this end, variable/parameter names and their casing have been preserved, however the function names have been camel-cased for JS convention.

It is hoped this may serve as a starting point for those who wish to explore this cipher in a JS context.

This source file is deliberately unoptimized with the aim of readability, yet is relatively portable. (For example, "isArray" support is assumed rather than feature-detected, and may need replacing if you wish to run this on IE8-, or very old Firefox versions. See: http://kangax.github.io/compat-table/es5/#Array.isArray)

Tested in: Node.js (0.10.26+), Chrome (38+), Firefox (33+)

References:

Installation

Node.js

npm install spritzjs

npm install
Run tests
  npm test

Browser

  <script src="spritzjs.js"></script>

Usage

  var spritzjs = require('spritzjs');

or in the browser (though not strictly needed):

  var spritzjs = window.spritzjs;

then:

  var M = [65, 66, 67];             // "ABC" as a byte array

  var r = 32;                       // 32 byte hash required

  var hashed = spritzjs.hash(M, r); // "hashed" now contains 32 bytes of hashed "M" material

  console.log(hashed.length);       // -> 32

TODO

  • Reinstate the unit-tests - spritzjs was developed in a TDD manner using testem, jasmine and a bunch of other stuff that doesn't need to be here so the tests will be added with a lighter test-harness (probably tape)
  • Code - Complete the API with encrypt/decrypt etc
  • Usage - how to use it. NB. perfunctory hashing example now included
  • Threat Modelling - THREAT.md? "this cipher should not be used until pounded on by cryptanalysts" etc
  • Build - browserify is awesome but we want to have the smallest footprint and are not using Node.js specific functionality. Consider js(l|h)int for ensuring correctness of the clean-source version
  • Performance - measure performance before optimising
  • Optimisation - there are quick-wins available. Also, what about asm.js/SIMD can we use anything here?
  • Minification - once hand-optimised, let the uglification begin. Also, size-wise when the tests permit, we could "golf" some interesting solutions
  • Test vectors - More test-vectors would be appreciated! The paper only provided a handful (all are implemented in test/spritzjs-tests.js)
  • Cryptanalysis - should be ready to use as is, though there may be faster implementations
  • uC - port to microcontrollers, specifically 8-bit ones? tessle? IoT? Arduino/AVR/PIC? Even if ported implementation code is not useful depending on the target architecture, we should be able to share the accumulated (verified) test-vectors

For more information you can find the latest README.md, tests and minified versions at:

therealjampers - 2014.11.03