[Pkg-javascript-commits] [node-browserify-des] 01/08: first
Bastien Roucariès
rouca at moszumanska.debian.org
Thu May 4 10:16:16 UTC 2017
This is an automated email from the git hooks/post-receive script.
rouca pushed a commit to branch master
in repository node-browserify-des.
commit ec4fc6ad180ab43efe687bdb6e84100d048c9c53
Author: Calvin Metcalf <calvin.metcalf at gmail.com>
Date: Sun Sep 27 13:30:17 2015 -0400
first
---
index.js | 43 +++++++++++++++++++++++++++++++++++++++++++
modes.js | 24 ++++++++++++++++++++++++
package.json | 29 +++++++++++++++++++++++++++++
readme.md | 4 ++++
test.js | 48 ++++++++++++++++++++++++++++++++++++++++++++++++
5 files changed, 148 insertions(+)
diff --git a/index.js b/index.js
new file mode 100644
index 0000000..2889bb7
--- /dev/null
+++ b/index.js
@@ -0,0 +1,43 @@
+var CipherBase = require('cipher-base')
+var des = require('des.js')
+var inherits = require('inherits')
+
+var modes = {
+ 'des-ede3-cbc': des.CBC.instantiate(des.EDE),
+ 'des-ede3': des.EDE,
+ 'des-ede-cbc': des.CBC.instantiate(des.EDE),
+ 'des-ede': des.EDE,
+ 'des-cbc': des.CBC.instantiate(des.DES),
+ 'des-ecb': des.DES
+}
+modes.des = modes['des-cbc']
+modes.des3 = modes['des-ede3-cbc']
+module.exports = DES
+inherits(DES, CipherBase)
+function DES (opts) {
+ CipherBase.call(this)
+ var modeName = opts.mode.toLowerCase()
+ var mode = modes[modeName]
+ var type
+ if (opts.decrypt) {
+ type = 'decrypt'
+ } else {
+ type = 'encrypt'
+ }
+ var key = opts.key
+ if (modeName === 'des-ede' || modeName === 'des-ede-cbc') {
+ key = Buffer.concat([key, key.slice(0, 8)])
+ }
+ var iv = opts.iv
+ this._des = mode.create({
+ key: key,
+ iv: iv,
+ type: type
+ })
+}
+DES.prototype._update = function (data) {
+ return new Buffer(this._des.update(data))
+}
+DES.prototype._final = function () {
+ return new Buffer(this._des.final())
+}
diff --git a/modes.js b/modes.js
new file mode 100644
index 0000000..72f308d
--- /dev/null
+++ b/modes.js
@@ -0,0 +1,24 @@
+exports['des-ecb'] = {
+ key: 8,
+ iv: 0
+}
+exports['des-cbc'] = exports.des = {
+ key: 8,
+ iv: 8
+}
+exports['des-ede3-cbc'] = exports.des3 = {
+ key: 24,
+ iv: 8
+}
+exports['des-ede3'] = {
+ key: 24,
+ iv: 0
+}
+exports['des-ede-cbc'] = {
+ key: 16,
+ iv: 8
+}
+exports['des-ede'] = {
+ key: 16,
+ iv: 0
+}
diff --git a/package.json b/package.json
new file mode 100644
index 0000000..fdc9a8f
--- /dev/null
+++ b/package.json
@@ -0,0 +1,29 @@
+{
+ "name": "browserify-des",
+ "version": "1.0.0",
+ "description": "",
+ "main": "index.js",
+ "scripts": {
+ "test": "standard && node test.js | tspec"
+ },
+ "repository": {
+ "type": "git",
+ "url": "git+https://github.com/crypto-browserify/browserify-des.git"
+ },
+ "author": "Calvin Metcalf <calvin.metcalf at gmail.com>",
+ "license": "MIT",
+ "bugs": {
+ "url": "https://github.com/crypto-browserify/browserify-des/issues"
+ },
+ "homepage": "https://github.com/crypto-browserify/browserify-des#readme",
+ "dependencies": {
+ "cipher-base": "^1.0.1",
+ "des.js": "^1.0.0",
+ "inherits": "^2.0.1"
+ },
+ "devDependencies": {
+ "standard": "^5.3.1",
+ "tap-spec": "^4.1.0",
+ "tape": "^4.2.0"
+ }
+}
diff --git a/readme.md b/readme.md
new file mode 100644
index 0000000..c29c1b2
--- /dev/null
+++ b/readme.md
@@ -0,0 +1,4 @@
+browserify-des
+===
+
+DES for browserify
diff --git a/test.js b/test.js
new file mode 100644
index 0000000..6324f43
--- /dev/null
+++ b/test.js
@@ -0,0 +1,48 @@
+var test = require('tape')
+var DES = require('./')
+var modes = require('./modes')
+var crypto = require('crypto')
+
+Object.keys(modes).forEach(function (mode) {
+ test(mode, function (t) {
+ var i = 0
+ while (++i < 10) {
+ runOnce(i)
+ }
+ function runOnce (i) {
+ t.test('run: ' + i, function (t) {
+ t.plan(2)
+ var key = crypto.randomBytes(modes[mode].key)
+ var iv = crypto.randomBytes(modes[mode].iv)
+ var text = crypto.randomBytes(200)
+ var ourEncrypt
+ try {
+ ourEncrypt = new DES({
+ mode: mode,
+ key: key,
+ iv: iv
+ })
+ } catch (e) {
+ t.notOk(e, e.stack)
+ }
+ var nodeEncrypt
+ try {
+ nodeEncrypt = crypto.createCipheriv(mode, key, iv)
+ } catch (e) {
+ t.notOk(e, e.stack)
+ }
+ var ourCipherText = Buffer.concat([ourEncrypt.update(text), ourEncrypt.final()])
+ var nodeCipherText = Buffer.concat([nodeEncrypt.update(text), nodeEncrypt.final()])
+ t.equals(nodeCipherText.toString('hex'), ourCipherText.toString('hex'))
+ var ourDecrypt = new DES({
+ mode: mode,
+ key: key,
+ iv: iv,
+ decrypt: true
+ })
+ var plainText = Buffer.concat([ourDecrypt.update(ourCipherText), ourDecrypt.final()])
+ t.equals(text.toString('hex'), plainText.toString('hex'))
+ })
+ }
+ })
+})
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-javascript/node-browserify-des.git
More information about the Pkg-javascript-commits
mailing list