68 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| var DES = require('browserify-des')
 | |
| var aes = require('browserify-aes/browser')
 | |
| var aesModes = require('browserify-aes/modes')
 | |
| var desModes = require('browserify-des/modes')
 | |
| var ebtk = require('evp_bytestokey')
 | |
| 
 | |
| function createCipher (suite, password) {
 | |
|   suite = suite.toLowerCase()
 | |
| 
 | |
|   var keyLen, ivLen
 | |
|   if (aesModes[suite]) {
 | |
|     keyLen = aesModes[suite].key
 | |
|     ivLen = aesModes[suite].iv
 | |
|   } else if (desModes[suite]) {
 | |
|     keyLen = desModes[suite].key * 8
 | |
|     ivLen = desModes[suite].iv
 | |
|   } else {
 | |
|     throw new TypeError('invalid suite type')
 | |
|   }
 | |
| 
 | |
|   var keys = ebtk(password, false, keyLen, ivLen)
 | |
|   return createCipheriv(suite, keys.key, keys.iv)
 | |
| }
 | |
| 
 | |
| function createDecipher (suite, password) {
 | |
|   suite = suite.toLowerCase()
 | |
| 
 | |
|   var keyLen, ivLen
 | |
|   if (aesModes[suite]) {
 | |
|     keyLen = aesModes[suite].key
 | |
|     ivLen = aesModes[suite].iv
 | |
|   } else if (desModes[suite]) {
 | |
|     keyLen = desModes[suite].key * 8
 | |
|     ivLen = desModes[suite].iv
 | |
|   } else {
 | |
|     throw new TypeError('invalid suite type')
 | |
|   }
 | |
| 
 | |
|   var keys = ebtk(password, false, keyLen, ivLen)
 | |
|   return createDecipheriv(suite, keys.key, keys.iv)
 | |
| }
 | |
| 
 | |
| function createCipheriv (suite, key, iv) {
 | |
|   suite = suite.toLowerCase()
 | |
|   if (aesModes[suite]) return aes.createCipheriv(suite, key, iv)
 | |
|   if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite })
 | |
| 
 | |
|   throw new TypeError('invalid suite type')
 | |
| }
 | |
| 
 | |
| function createDecipheriv (suite, key, iv) {
 | |
|   suite = suite.toLowerCase()
 | |
|   if (aesModes[suite]) return aes.createDecipheriv(suite, key, iv)
 | |
|   if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite, decrypt: true })
 | |
| 
 | |
|   throw new TypeError('invalid suite type')
 | |
| }
 | |
| 
 | |
| function getCiphers () {
 | |
|   return Object.keys(desModes).concat(aes.getCiphers())
 | |
| }
 | |
| 
 | |
| exports.createCipher = exports.Cipher = createCipher
 | |
| exports.createCipheriv = exports.Cipheriv = createCipheriv
 | |
| exports.createDecipher = exports.Decipher = createDecipher
 | |
| exports.createDecipheriv = exports.Decipheriv = createDecipheriv
 | |
| exports.listCiphers = exports.getCiphers = getCiphers
 |