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.
		
		
		
		
			
				
					43 lines
				
				917 B
			
		
		
			
		
	
	
					43 lines
				
				917 B
			| 
								 
											4 years ago
										 
									 | 
							
								var Buffer = require('safe-buffer').Buffer
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function encryptByte (self, byteParam, decrypt) {
							 | 
						||
| 
								 | 
							
								  var pad
							 | 
						||
| 
								 | 
							
								  var i = -1
							 | 
						||
| 
								 | 
							
								  var len = 8
							 | 
						||
| 
								 | 
							
								  var out = 0
							 | 
						||
| 
								 | 
							
								  var bit, value
							 | 
						||
| 
								 | 
							
								  while (++i < len) {
							 | 
						||
| 
								 | 
							
								    pad = self._cipher.encryptBlock(self._prev)
							 | 
						||
| 
								 | 
							
								    bit = (byteParam & (1 << (7 - i))) ? 0x80 : 0
							 | 
						||
| 
								 | 
							
								    value = pad[0] ^ bit
							 | 
						||
| 
								 | 
							
								    out += ((value & 0x80) >> (i % 8))
							 | 
						||
| 
								 | 
							
								    self._prev = shiftIn(self._prev, decrypt ? bit : value)
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								  return out
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function shiftIn (buffer, value) {
							 | 
						||
| 
								 | 
							
								  var len = buffer.length
							 | 
						||
| 
								 | 
							
								  var i = -1
							 | 
						||
| 
								 | 
							
								  var out = Buffer.allocUnsafe(buffer.length)
							 | 
						||
| 
								 | 
							
								  buffer = Buffer.concat([buffer, Buffer.from([value])])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  while (++i < len) {
							 | 
						||
| 
								 | 
							
								    out[i] = buffer[i] << 1 | buffer[i + 1] >> (7)
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return out
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								exports.encrypt = function (self, chunk, decrypt) {
							 | 
						||
| 
								 | 
							
								  var len = chunk.length
							 | 
						||
| 
								 | 
							
								  var out = Buffer.allocUnsafe(len)
							 | 
						||
| 
								 | 
							
								  var i = -1
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  while (++i < len) {
							 | 
						||
| 
								 | 
							
								    out[i] = encryptByte(self, chunk[i], decrypt)
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return out
							 | 
						||
| 
								 | 
							
								}
							 |