Merge #10104: linearize script: Option to use RPC cookie
bd41d98 Datadir option in linearize scripts (Andrew Chow) Tree-SHA512: 0d11866b574986c087ec962a8a9fc0b6dfee8175ae20ef827f8b4a143f657c5bffc9f9696e9dabf29b68002003a5b6a7d8ac473231b5c9c81c3a4fa0318f5bd0
This commit is contained in:
parent
f471b75aec
commit
13cdff4989
@ -11,7 +11,8 @@ https://github.com/dashpay/dash_hash
|
|||||||
$ ./linearize-hashes.py linearize.cfg > hashlist.txt
|
$ ./linearize-hashes.py linearize.cfg > hashlist.txt
|
||||||
|
|
||||||
Required configuration file settings for linearize-hashes:
|
Required configuration file settings for linearize-hashes:
|
||||||
* RPC: `rpcuser`, `rpcpassword`
|
* RPC: `datadir` (Required if `rpcuser` and `rpcpassword` are not specified)
|
||||||
|
* RPC: `rpcuser`, `rpcpassword` (Required if `datadir` is not specified)
|
||||||
|
|
||||||
Optional config file setting for linearize-hashes:
|
Optional config file setting for linearize-hashes:
|
||||||
* RPC: `host` (Default: `127.0.0.1`)
|
* RPC: `host` (Default: `127.0.0.1`)
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# bitcoind RPC settings (linearize-hashes)
|
# bitcoind RPC settings (linearize-hashes)
|
||||||
rpcuser=someuser
|
rpcuser=someuser
|
||||||
rpcpassword=somepassword
|
rpcpassword=somepassword
|
||||||
|
#datadir=~/.bitcoin
|
||||||
host=127.0.0.1
|
host=127.0.0.1
|
||||||
port=9998
|
port=9998
|
||||||
|
|
||||||
|
@ -16,6 +16,8 @@ import json
|
|||||||
import re
|
import re
|
||||||
import base64
|
import base64
|
||||||
import sys
|
import sys
|
||||||
|
import os
|
||||||
|
import os.path
|
||||||
|
|
||||||
settings = {}
|
settings = {}
|
||||||
|
|
||||||
@ -93,6 +95,14 @@ def get_block_hashes(settings, max_blocks_per_call=10000):
|
|||||||
|
|
||||||
height += num_blocks
|
height += num_blocks
|
||||||
|
|
||||||
|
def get_rpc_cookie():
|
||||||
|
# Open the cookie file
|
||||||
|
with open(os.path.join(os.path.expanduser(settings['datadir']), '.cookie'), 'r') as f:
|
||||||
|
combined = f.readline()
|
||||||
|
combined_split = combined.split(":")
|
||||||
|
settings['rpcuser'] = combined_split[0]
|
||||||
|
settings['rpcpassword'] = combined_split[1]
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
if len(sys.argv) != 2:
|
if len(sys.argv) != 2:
|
||||||
print("Usage: linearize-hashes.py CONFIG-FILE")
|
print("Usage: linearize-hashes.py CONFIG-FILE")
|
||||||
@ -122,8 +132,15 @@ if __name__ == '__main__':
|
|||||||
settings['max_height'] = 313000
|
settings['max_height'] = 313000
|
||||||
if 'rev_hash_bytes' not in settings:
|
if 'rev_hash_bytes' not in settings:
|
||||||
settings['rev_hash_bytes'] = 'false'
|
settings['rev_hash_bytes'] = 'false'
|
||||||
|
|
||||||
|
use_userpass = True
|
||||||
|
use_datadir = False
|
||||||
if 'rpcuser' not in settings or 'rpcpassword' not in settings:
|
if 'rpcuser' not in settings or 'rpcpassword' not in settings:
|
||||||
print("Missing username and/or password in cfg file", file=stderr)
|
use_userpass = False
|
||||||
|
if 'datadir' in settings and not use_userpass:
|
||||||
|
use_datadir = True
|
||||||
|
if not use_userpass and not use_datadir:
|
||||||
|
print("Missing datadir or username and/or password in cfg file", file=stderr)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
settings['port'] = int(settings['port'])
|
settings['port'] = int(settings['port'])
|
||||||
@ -133,4 +150,8 @@ if __name__ == '__main__':
|
|||||||
# Force hash byte format setting to be lowercase to make comparisons easier.
|
# Force hash byte format setting to be lowercase to make comparisons easier.
|
||||||
settings['rev_hash_bytes'] = settings['rev_hash_bytes'].lower()
|
settings['rev_hash_bytes'] = settings['rev_hash_bytes'].lower()
|
||||||
|
|
||||||
|
# Get the rpc user and pass from the cookie if the datadir is set
|
||||||
|
if use_datadir:
|
||||||
|
get_rpc_cookie()
|
||||||
|
|
||||||
get_block_hashes(settings)
|
get_block_hashes(settings)
|
||||||
|
Loading…
Reference in New Issue
Block a user