mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-09 19:37:27 -03:00
signet/miner: add Generate.gbt function
This commit is contained in:
parent
85c5c0bea9
commit
7b31332370
1 changed files with 18 additions and 11 deletions
|
@ -290,6 +290,22 @@ class Generate:
|
||||||
# can't mine a block 2h in the future; 1h55m for some safety
|
# can't mine a block 2h in the future; 1h55m for some safety
|
||||||
self.action_time = max(self.action_time, self.mine_time - 6900)
|
self.action_time = max(self.action_time, self.mine_time - 6900)
|
||||||
|
|
||||||
|
def gbt(self, bcli, bestblockhash, now):
|
||||||
|
tmpl = json.loads(bcli("getblocktemplate", '{"rules":["signet","segwit"]}'))
|
||||||
|
if tmpl["previousblockhash"] != bestblockhash:
|
||||||
|
logging.warning("GBT based off unexpected block (%s not %s), retrying", tmpl["previousblockhash"], bci["bestblockhash"])
|
||||||
|
time.sleep(1)
|
||||||
|
return None
|
||||||
|
|
||||||
|
if tmpl["mintime"] > self.mine_time:
|
||||||
|
logging.info("Updating block time from %d to %d", self.mine_time, tmpl["mintime"])
|
||||||
|
self.mine_time = tmpl["mintime"]
|
||||||
|
if self.mine_time > now:
|
||||||
|
logging.error("GBT mintime is in the future: %d is %d seconds later than %d", self.mine_time, (self.mine_time-now), now)
|
||||||
|
return None
|
||||||
|
|
||||||
|
return tmpl
|
||||||
|
|
||||||
def do_generate(args):
|
def do_generate(args):
|
||||||
if args.max_blocks is not None:
|
if args.max_blocks is not None:
|
||||||
if args.ongoing:
|
if args.ongoing:
|
||||||
|
@ -389,21 +405,12 @@ def do_generate(args):
|
||||||
continue
|
continue
|
||||||
|
|
||||||
# gbt
|
# gbt
|
||||||
tmpl = json.loads(args.bcli("getblocktemplate", '{"rules":["signet","segwit"]}'))
|
tmpl = gen.gbt(args.bcli, bci["bestblockhash"], now)
|
||||||
if tmpl["previousblockhash"] != bci["bestblockhash"]:
|
if tmpl is None:
|
||||||
logging.warning("GBT based off unexpected block (%s not %s), retrying", tmpl["previousblockhash"], bci["bestblockhash"])
|
|
||||||
time.sleep(1)
|
|
||||||
continue
|
continue
|
||||||
|
|
||||||
logging.debug("GBT template: %s", tmpl)
|
logging.debug("GBT template: %s", tmpl)
|
||||||
|
|
||||||
if tmpl["mintime"] > gen.mine_time:
|
|
||||||
logging.info("Updating block time from %d to %d", gen.mine_time, tmpl["mintime"])
|
|
||||||
gen.mine_time = tmpl["mintime"]
|
|
||||||
if gen.mine_time > now:
|
|
||||||
logging.error("GBT mintime is in the future: %d is %d seconds later than %d", gen.mine_time, (gen.mine_time-now), now)
|
|
||||||
return 1
|
|
||||||
|
|
||||||
# address for reward
|
# address for reward
|
||||||
reward_addr, reward_spk = get_reward_addr_spk(args, tmpl["height"])
|
reward_addr, reward_spk = get_reward_addr_spk(args, tmpl["height"])
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue