@ -11,18 +11,18 @@ var crypto = require('crypto');
crypto . DEFAULT_ENCODING = 'buffer' ;
crypto . DEFAULT_ENCODING = 'buffer' ;
function aes256 ( decipherFinal ) {
function aes256 ( decipherFinal ) {
var iv = Buffer . from ( '00000000000000000000000000000000' , 'hex' ) ;
const iv = Buffer . from ( '00000000000000000000000000000000' , 'hex' ) ;
var key = Buffer . from ( '0123456789abcdef0123456789abcdef' +
const key = Buffer . from ( '0123456789abcdef0123456789abcdef' +
'0123456789abcdef0123456789abcdef' , 'hex' ) ;
'0123456789abcdef0123456789abcdef' , 'hex' ) ;
function encrypt ( val , pad ) {
function encrypt ( val , pad ) {
var c = crypto . createCipheriv ( 'aes256' , key , iv ) ;
const c = crypto . createCipheriv ( 'aes256' , key , iv ) ;
c . setAutoPadding ( pad ) ;
c . setAutoPadding ( pad ) ;
return c . update ( val , 'utf8' , 'latin1' ) + c . final ( 'latin1' ) ;
return c . update ( val , 'utf8' , 'latin1' ) + c . final ( 'latin1' ) ;
}
}
function decrypt ( val , pad ) {
function decrypt ( val , pad ) {
var c = crypto . createDecipheriv ( 'aes256' , key , iv ) ;
const c = crypto . createDecipheriv ( 'aes256' , key , iv ) ;
c . setAutoPadding ( pad ) ;
c . setAutoPadding ( pad ) ;
return c . update ( val , 'latin1' , 'utf8' ) + c [ decipherFinal ] ( 'utf8' ) ;
return c . update ( val , 'latin1' , 'utf8' ) + c [ decipherFinal ] ( 'utf8' ) ;
}
}
@ -30,10 +30,10 @@ function aes256(decipherFinal) {
// echo 0123456789abcdef0123456789abcdef \
// echo 0123456789abcdef0123456789abcdef \
// | openssl enc -e -aes256 -nopad -K <key> -iv <iv> \
// | openssl enc -e -aes256 -nopad -K <key> -iv <iv> \
// | openssl enc -d -aes256 -nopad -K <key> -iv <iv>
// | openssl enc -d -aes256 -nopad -K <key> -iv <iv>
var plaintext = '0123456789abcdef0123456789abcdef' ; // multiple of block size
let plaintext = '0123456789abcdef0123456789abcdef' ; // multiple of block size
var encrypted = encrypt ( plaintext , false ) ;
let encrypted = encrypt ( plaintext , false ) ;
var decrypted = decrypt ( encrypted , false ) ;
let decrypted = decrypt ( encrypted , false ) ;
assert . e qual( decrypted , plaintext ) ;
assert . strictE qual( decrypted , plaintext ) ;
// echo 0123456789abcdef0123456789abcde \
// echo 0123456789abcdef0123456789abcde \
// | openssl enc -e -aes256 -K <key> -iv <iv> \
// | openssl enc -e -aes256 -K <key> -iv <iv> \
@ -41,7 +41,7 @@ function aes256(decipherFinal) {
plaintext = '0123456789abcdef0123456789abcde' ; // not a multiple
plaintext = '0123456789abcdef0123456789abcde' ; // not a multiple
encrypted = encrypt ( plaintext , true ) ;
encrypted = encrypt ( plaintext , true ) ;
decrypted = decrypt ( encrypted , true ) ;
decrypted = decrypt ( encrypted , true ) ;
assert . e qual( decrypted , plaintext ) ;
assert . strictE qual( decrypted , plaintext ) ;
}
}
aes256 ( 'final' ) ;
aes256 ( 'final' ) ;