Add node.js support
This commit is contained in:
parent
82fbc0ffa7
commit
57c98386f9
15
Gruntfile.js
15
Gruntfile.js
|
@ -9,7 +9,8 @@ module.exports = function(grunt) {
|
|||
'resources/openpgp_nodebug.js': []
|
||||
},
|
||||
options: {
|
||||
alias: './src/:openpgp'
|
||||
alias: './src/:openpgp',
|
||||
external: [ 'crypto', 'node-localstorage' ]
|
||||
}
|
||||
},
|
||||
openpgp: {
|
||||
|
@ -18,7 +19,8 @@ module.exports = function(grunt) {
|
|||
},
|
||||
options: {
|
||||
debug: true,
|
||||
alias: './src/:openpgp'
|
||||
alias: './src/:openpgp',
|
||||
external: [ 'crypto', 'node-localstorage' ]
|
||||
}
|
||||
},
|
||||
keyring_nodebug: {
|
||||
|
@ -27,7 +29,7 @@ module.exports = function(grunt) {
|
|||
},
|
||||
options: {
|
||||
alias: './src/keyring/:keyring',
|
||||
external: [ 'openpgp' ]
|
||||
external: [ 'openpgp', 'node-localstorage' ]
|
||||
}
|
||||
},
|
||||
keyring: {
|
||||
|
@ -37,7 +39,7 @@ module.exports = function(grunt) {
|
|||
options: {
|
||||
debug: true,
|
||||
alias: './src/keyring/:keyring',
|
||||
external: [ 'openpgp' ]
|
||||
external: [ 'openpgp', 'node-localstorage' ]
|
||||
}
|
||||
},
|
||||
unittests: {
|
||||
|
@ -47,7 +49,7 @@ module.exports = function(grunt) {
|
|||
options: {
|
||||
debug: true,
|
||||
alias: './test/unittests.js:unittests',
|
||||
external: [ 'openpgp', 'keyring' ]
|
||||
external: [ 'openpgp', 'keyring', 'node-localstorage' ]
|
||||
}
|
||||
}
|
||||
},
|
||||
|
@ -81,6 +83,8 @@ module.exports = function(grunt) {
|
|||
'<%= grunt.template.today("yyyy-mm-dd") %> */'
|
||||
}
|
||||
},
|
||||
prepare_install: {
|
||||
},
|
||||
jsbeautifier : {
|
||||
files : ["src/**/*.js"],
|
||||
options : {
|
||||
|
@ -120,6 +124,7 @@ module.exports = function(grunt) {
|
|||
grunt.loadNpmTasks('grunt-browserify');
|
||||
grunt.loadNpmTasks('grunt-contrib-uglify');
|
||||
grunt.loadNpmTasks('grunt-text-replace');
|
||||
grunt.loadNpmTasks('grunt-prepare-install');
|
||||
grunt.loadNpmTasks('grunt-jsbeautifier');
|
||||
grunt.loadNpmTasks('grunt-contrib-jshint');
|
||||
grunt.loadNpmTasks('grunt-jsdoc');
|
||||
|
|
|
@ -4,7 +4,11 @@
|
|||
"engines": {
|
||||
"node": ">=0.8"
|
||||
},
|
||||
"main": "./src/index.js",
|
||||
"directories": {
|
||||
"lib": "src"
|
||||
},
|
||||
"main": "src/index.js",
|
||||
"files": [ "src" ],
|
||||
"scripts": {
|
||||
"pretest": "grunt",
|
||||
"test": "grunt test"
|
||||
|
|
|
@ -23,6 +23,13 @@
|
|||
*/
|
||||
|
||||
var type_mpi = require('../type/mpi.js');
|
||||
var nodeCrypto = null;
|
||||
|
||||
if (typeof window === undefined) {}
|
||||
try {
|
||||
crypto = require('crypto');
|
||||
} catch (e) {
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
/**
|
||||
|
@ -56,7 +63,7 @@ module.exports = {
|
|||
*/
|
||||
getSecureRandom: function(from, to) {
|
||||
var buf = new Uint32Array(1);
|
||||
window.crypto.getRandomValues(buf);
|
||||
this.getRandomValues(buf);
|
||||
var bits = ((to - from)).toString(2).length;
|
||||
while ((buf[0] & (Math.pow(2, bits) - 1)) > (to - from))
|
||||
window.crypto.getRandomValues(buf);
|
||||
|
@ -65,10 +72,23 @@ module.exports = {
|
|||
|
||||
getSecureRandomOctet: function() {
|
||||
var buf = new Uint32Array(1);
|
||||
window.crypto.getRandomValues(buf);
|
||||
this.getRandomValues(buf);
|
||||
return buf[0] & 0xFF;
|
||||
},
|
||||
|
||||
/**
|
||||
* Helper routine which calls platform specific crypto random generator
|
||||
* @param {Uint32Array} buf
|
||||
*/
|
||||
getRandomValues: function(buf) {
|
||||
try {
|
||||
window.crypto.getRandomValues(buf);
|
||||
} catch (e) {
|
||||
var bytes = crypto.randomBytes(4);
|
||||
buf[0] = (bytes[0] << 24) | (bytes[1] << 16) | (bytes[2] << 8) | bytes[3];
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Create a secure random big integer of bits length
|
||||
* @param {Integer} bits Bit length of the MPI to create
|
||||
|
|
|
@ -32,7 +32,16 @@ function LocalStore() {
|
|||
* @return {Array<module:key~Key>} array of keys retrieved from localstore
|
||||
*/
|
||||
LocalStore.prototype.load = function () {
|
||||
var armoredKeys = JSON.parse(window.localStorage.getItem("armoredKeys"));
|
||||
var storage = null;
|
||||
try {
|
||||
storage = window.localStorage;
|
||||
} catch (e) {
|
||||
}
|
||||
|
||||
if (storage === null) {
|
||||
storage = new (require('node-localstorage').LocalStorage)('./keyring.store');
|
||||
}
|
||||
var armoredKeys = JSON.parse(storage.getItem("armoredKeys"));
|
||||
var keys = [];
|
||||
if (armoredKeys !== null && armoredKeys.length !== 0) {
|
||||
var key;
|
||||
|
|
11
src/keyring/package.json
Normal file
11
src/keyring/package.json
Normal file
|
@ -0,0 +1,11 @@
|
|||
{
|
||||
"name": "keyring",
|
||||
"version": "0.2.0",
|
||||
"description": "Openpgpjs Keyring",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
"test": "echo \"Error: no test specified\" && exit 1"
|
||||
},
|
||||
"author": "",
|
||||
"license": "BSD"
|
||||
}
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe('AES Rijndael cipher test with test vectors from ecb_tbl.txt', function() {
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
BFencrypt = openpgp.crypto.cipher.blowfish,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
it('Blowfish cipher test with test vectors from http://www.schneier.com/code/vectors.txt', function(done) {
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
it('CAST-128 cipher test with test vectors from RFC2144', function (done) {
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe('TripleDES (EDE) cipher test with test vectors from http://csrc.nist.gov/publications/nistpubs/800-20/800-20.pdf', function() {
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
it('Twofish with test vectors from http://www.schneier.com/code/ecb_ival.txt', function(done) {
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
var openpgp = require('openpgp');
|
||||
|
||||
'use strict';
|
||||
|
||||
var expect = chai.expect;
|
||||
var openpgp = require('openpgp'),
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe('API functional testing', function() {
|
||||
var util = openpgp.util;
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
MD5 = openpgp.crypto.hash.md5,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
it('MD5 with test vectors from RFC 1321', function(done) {
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
RMDstring = openpgp.crypto.hash.ripemd,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
it("RIPE-MD 160 bits with test vectors from http://homes.esat.kuleuven.be/~bosselae/ripemd160.html", function(done) {
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
var openpgp = require('openpgp'),
|
||||
util = openpgp.util,
|
||||
hash = openpgp.crypto.hash,
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
it('SHA* with test vectors from NIST FIPS 180-2', function(done) {
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
var openpgp = require('openpgp');
|
||||
|
||||
'use strict';
|
||||
|
||||
var expect = chai.expect;
|
||||
var openpgp = require('openpgp'),
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe('Basic', function() {
|
||||
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
var openpgp = require('openpgp');
|
||||
|
||||
'use strict';
|
||||
|
||||
var expect = chai.expect;
|
||||
var openpgp = require('openpgp'),
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe('Key', function() {
|
||||
var twoKeys =
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
var openpgp = require('openpgp'),
|
||||
keyring = new (require('keyring'))(),
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe("Keyring", function() {
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
var openpgp = require('openpgp');
|
||||
|
||||
'use strict';
|
||||
|
||||
var expect = chai.expect;
|
||||
var openpgp = require('openpgp'),
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe("Packet", function() {
|
||||
var armored_key =
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
var openpgp = require('openpgp');
|
||||
|
||||
'use strict';
|
||||
|
||||
var expect = chai.expect;
|
||||
var openpgp = require('openpgp'),
|
||||
chai = require('chai'),
|
||||
expect = chai.expect;
|
||||
|
||||
describe("Signature", function() {
|
||||
var priv_key_arm1 =
|
||||
|
|
20
test/package.json
Normal file
20
test/package.json
Normal file
|
@ -0,0 +1,20 @@
|
|||
{
|
||||
"name": "nodetests",
|
||||
"version": "0.2.0",
|
||||
"description": "Node.js server side unit tests",
|
||||
"main": "example-test.js",
|
||||
"scripts": {
|
||||
"test": "echo \"Error: no test specified\" && exit 1"
|
||||
},
|
||||
"author": "",
|
||||
"license": "BSD",
|
||||
"devDependencies": {
|
||||
"mocha": "~1.16.2",
|
||||
"chai": "~1.8.1"
|
||||
},
|
||||
"dependencies": {
|
||||
"openpgp": "~0.2.0-dev",
|
||||
"keyring": "~0.2.0",
|
||||
"node-localstorage": "~0.3.4"
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user