You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
34 lines
1.0 KiB
34 lines
1.0 KiB
var AES = require('./aes');
|
|
var CBC = require('./cbc');
|
|
var Random = require('../random');
|
|
var Hash = require('../hash');
|
|
|
|
// Symmetric encryption with AES and CBC convenience class
|
|
var AESCBC = function AESCBC() {
|
|
};
|
|
|
|
AESCBC.encrypt = function(messagebuf, passwordstr) {
|
|
var cipherkeybuf = Hash.sha256(new Buffer(passwordstr));
|
|
return AESCBC.encryptCipherkey(messagebuf, cipherkeybuf);
|
|
};
|
|
|
|
AESCBC.decrypt = function(encbuf, passwordstr) {
|
|
var cipherkeybuf = Hash.sha256(new Buffer(passwordstr));
|
|
return AESCBC.decryptCipherkey(encbuf, cipherkeybuf);
|
|
};
|
|
|
|
AESCBC.encryptCipherkey = function(messagebuf, cipherkeybuf, ivbuf) {
|
|
ivbuf = ivbuf || Random.getRandomBuffer(128 / 8);
|
|
var ctbuf = CBC.encrypt(messagebuf, ivbuf, AES, cipherkeybuf);
|
|
var encbuf = Buffer.concat([ivbuf, ctbuf]);
|
|
return encbuf;
|
|
};
|
|
|
|
AESCBC.decryptCipherkey = function(encbuf, cipherkeybuf) {
|
|
var ivbuf = encbuf.slice(0, 128 / 8);
|
|
var ctbuf = encbuf.slice(128 / 8);
|
|
var messagebuf = CBC.decrypt(ctbuf, ivbuf, AES, cipherkeybuf);
|
|
return messagebuf;
|
|
};
|
|
|
|
module.exports = AESCBC;
|
|
|