Merge pull request #509 from bitcoinjs/pow
Add Block proof-of-work validation function
This commit is contained in:
commit
f3913516ca
4 changed files with 112 additions and 10 deletions
src
24
src/block.js
24
src/block.js
|
@ -1,5 +1,6 @@
|
|||
var bufferutils = require('./bufferutils')
|
||||
var bcrypto = require('./crypto')
|
||||
var compare = require('buffer-compare')
|
||||
|
||||
var Transaction = require('./transaction')
|
||||
|
||||
|
@ -115,4 +116,27 @@ Block.prototype.toHex = function (headersOnly) {
|
|||
return this.toBuffer(headersOnly).toString('hex')
|
||||
}
|
||||
|
||||
Block.calculateTarget = function (bits) {
|
||||
var exponent = ((bits & 0xff000000) >> 24) - 3
|
||||
var mantissa = bits & 0x007fffff
|
||||
var i = 31 - exponent
|
||||
|
||||
var target = new Buffer(32)
|
||||
target.fill(0)
|
||||
|
||||
target[i] = mantissa & 0xff
|
||||
target[i - 1] = mantissa >> 8
|
||||
target[i - 2] = mantissa >> 16
|
||||
target[i - 3] = mantissa >> 24
|
||||
|
||||
return target
|
||||
}
|
||||
|
||||
Block.prototype.checkProofOfWork = function () {
|
||||
var hash = [].reverse.call(this.getHash())
|
||||
var target = Block.calculateTarget(this.bits)
|
||||
|
||||
return compare(hash, target) <= 0
|
||||
}
|
||||
|
||||
module.exports = Block
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue