Module src.onionrcrypto.cryptoutils.verifypow
Expand source code
from .. import hashers
import config, onionrproofs, logger
import onionrexceptions
def verify_POW(blockContent):
'''
Verifies the proof of work associated with a block
'''
retData = False
dataLen = len(blockContent)
try:
blockContent = blockContent.encode()
except AttributeError:
pass
blockHash = hashers.sha3_hash(blockContent)
try:
blockHash = blockHash.decode() # bytes on some versions for some reason
except AttributeError:
pass
difficulty = onionrproofs.getDifficultyForNewBlock(blockContent)
if difficulty < int(config.get('general.minimum_block_pow')):
difficulty = int(config.get('general.minimum_block_pow'))
mainHash = '0000000000000000000000000000000000000000000000000000000000000000'#nacl.hash.blake2b(nacl.utils.random()).decode()
puzzle = mainHash[:difficulty]
if blockHash[:difficulty] == puzzle:
# logger.debug('Validated block pow')
retData = True
else:
logger.debug("Invalid token, bad proof")
raise onionrexceptions.InvalidProof('Proof for %s needs to be %s' % (blockHash, puzzle))
return retData
Functions
def verify_POW(blockContent)
-
Verifies the proof of work associated with a block
Expand source code
def verify_POW(blockContent): ''' Verifies the proof of work associated with a block ''' retData = False dataLen = len(blockContent) try: blockContent = blockContent.encode() except AttributeError: pass blockHash = hashers.sha3_hash(blockContent) try: blockHash = blockHash.decode() # bytes on some versions for some reason except AttributeError: pass difficulty = onionrproofs.getDifficultyForNewBlock(blockContent) if difficulty < int(config.get('general.minimum_block_pow')): difficulty = int(config.get('general.minimum_block_pow')) mainHash = '0000000000000000000000000000000000000000000000000000000000000000'#nacl.hash.blake2b(nacl.utils.random()).decode() puzzle = mainHash[:difficulty] if blockHash[:difficulty] == puzzle: # logger.debug('Validated block pow') retData = True else: logger.debug("Invalid token, bad proof") raise onionrexceptions.InvalidProof('Proof for %s needs to be %s' % (blockHash, puzzle)) return retData