54 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined
 | |
|  * in FIPS 180-2
 | |
|  * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.
 | |
|  * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet
 | |
|  *
 | |
|  */
 | |
| 
 | |
| var inherits = require('inherits')
 | |
| var Sha256 = require('./sha256')
 | |
| var Hash = require('./hash')
 | |
| var Buffer = require('safe-buffer').Buffer
 | |
| 
 | |
| var W = new Array(64)
 | |
| 
 | |
| function Sha224 () {
 | |
|   this.init()
 | |
| 
 | |
|   this._w = W // new Array(64)
 | |
| 
 | |
|   Hash.call(this, 64, 56)
 | |
| }
 | |
| 
 | |
| inherits(Sha224, Sha256)
 | |
| 
 | |
| Sha224.prototype.init = function () {
 | |
|   this._a = 0xc1059ed8
 | |
|   this._b = 0x367cd507
 | |
|   this._c = 0x3070dd17
 | |
|   this._d = 0xf70e5939
 | |
|   this._e = 0xffc00b31
 | |
|   this._f = 0x68581511
 | |
|   this._g = 0x64f98fa7
 | |
|   this._h = 0xbefa4fa4
 | |
| 
 | |
|   return this
 | |
| }
 | |
| 
 | |
| Sha224.prototype._hash = function () {
 | |
|   var H = Buffer.allocUnsafe(28)
 | |
| 
 | |
|   H.writeInt32BE(this._a, 0)
 | |
|   H.writeInt32BE(this._b, 4)
 | |
|   H.writeInt32BE(this._c, 8)
 | |
|   H.writeInt32BE(this._d, 12)
 | |
|   H.writeInt32BE(this._e, 16)
 | |
|   H.writeInt32BE(this._f, 20)
 | |
|   H.writeInt32BE(this._g, 24)
 | |
| 
 | |
|   return H
 | |
| }
 | |
| 
 | |
| module.exports = Sha224
 |