#!/usr/bin/env python3 # # Copyright (c) 2016, Neil Booth # # All rights reserved. # # See the file "LICENCE" for information about the copyright # and warranty status of this software. '''Script to query the database for debugging purposes. Not currently documented; might become easier to use in future. ''' import sys from server.env import Env from server.db import DB from lib.hash import hash_to_str def count_entries(db): utxos = 0 for key in db.iterator(prefix=b'u', include_value=False): utxos += 1 print("UTXO count:", utxos) hash168 = 0 for key in db.iterator(prefix=b'h', include_value=False): hash168 += 1 print("Hash168 count:", hash168) hist = 0 for key in db.iterator(prefix=b'H', include_value=False): hist += 1 print("History rows:", hist) def main(): env = Env() bp = DB(env) coin = env.coin if len(sys.argv) == 1: count_entries(bp.db) return argc = 1 try: limit = int(sys.argv[argc]) argc += 1 except: limit = 10 for addr in sys.argv[argc:]: print('Address: ', addr) hash168 = coin.address_to_hash168(addr) hist = 0 hist_len = 0 for key, value in bp.db.iterator(prefix=b'H'+hash168): hist += 1 hist_len += len(value) // 4 print("History: {:,d} rows with {:,d} entries".format(hist, hist_len)) n = None for n, (tx_hash, height) in enumerate(bp.get_history(hash168, limit)): print('History #{:d}: hash: {} height: {:d}' .format(n + 1, hash_to_str(tx_hash), height)) n = None for n, utxo in enumerate(bp.get_utxos(hash168, limit)): print('UTXOs #{:d}: hash: {} pos: {:d} height: {:d} value: {:d}' .format(n + 1, hash_to_str(utxo.tx_hash), utxo.tx_pos, utxo.height, utxo.value)) if n is None: print('No UTXOs') balance = bp.get_balance(hash168) print('Balance: {} {}'.format(coin.decimal_value(balance), coin.SHORTNAME)) if __name__ == '__main__': main()