|
@ -260,6 +260,7 @@ class Wallet: |
|
|
self.aliases = {} # aliases for addresses |
|
|
self.aliases = {} # aliases for addresses |
|
|
self.authorities = {} # trusted addresses |
|
|
self.authorities = {} # trusted addresses |
|
|
self.frozen_addresses = [] |
|
|
self.frozen_addresses = [] |
|
|
|
|
|
self.prioritized_addresses = [] |
|
|
|
|
|
|
|
|
self.receipts = {} # signed URIs |
|
|
self.receipts = {} # signed URIs |
|
|
self.receipt = None # next receipt |
|
|
self.receipt = None # next receipt |
|
@ -569,6 +570,7 @@ class Wallet: |
|
|
'receipts':self.receipts, |
|
|
'receipts':self.receipts, |
|
|
'num_zeros':self.num_zeros, |
|
|
'num_zeros':self.num_zeros, |
|
|
'frozen_addresses':self.frozen_addresses, |
|
|
'frozen_addresses':self.frozen_addresses, |
|
|
|
|
|
'prioritized_addresses':self.prioritized_addresses, |
|
|
} |
|
|
} |
|
|
f = open(self.path,"w") |
|
|
f = open(self.path,"w") |
|
|
f.write( repr(s) ) |
|
|
f.write( repr(s) ) |
|
@ -606,6 +608,7 @@ class Wallet: |
|
|
self.receipts = d.get('receipts',{}) |
|
|
self.receipts = d.get('receipts',{}) |
|
|
self.num_zeros = d.get('num_zeros',0) |
|
|
self.num_zeros = d.get('num_zeros',0) |
|
|
self.frozen_addresses = d.get('frozen_addresses',[]) |
|
|
self.frozen_addresses = d.get('frozen_addresses',[]) |
|
|
|
|
|
self.prioritized_addresses = d.get('prioritized_addresses',[]) |
|
|
except: |
|
|
except: |
|
|
raise BaseException("cannot read wallet file") |
|
|
raise BaseException("cannot read wallet file") |
|
|
|
|
|
|
|
@ -648,10 +651,14 @@ class Wallet: |
|
|
fee = self.fee if fixed_fee is None else fixed_fee |
|
|
fee = self.fee if fixed_fee is None else fixed_fee |
|
|
|
|
|
|
|
|
coins = [] |
|
|
coins = [] |
|
|
|
|
|
prioritized_coins = [] |
|
|
domain = [from_addr] if from_addr else self.all_addresses() |
|
|
domain = [from_addr] if from_addr else self.all_addresses() |
|
|
for i in self.frozen_addresses: |
|
|
for i in self.frozen_addresses: |
|
|
if i in domain: domain.remove(i) |
|
|
if i in domain: domain.remove(i) |
|
|
|
|
|
|
|
|
|
|
|
for i in self.prioritized_addresses: |
|
|
|
|
|
if i in domain: domain.remove(i) |
|
|
|
|
|
|
|
|
for addr in domain: |
|
|
for addr in domain: |
|
|
h = self.history.get(addr) |
|
|
h = self.history.get(addr) |
|
|
if h is None: continue |
|
|
if h is None: continue |
|
@ -660,7 +667,19 @@ class Wallet: |
|
|
coins.append( (addr,item)) |
|
|
coins.append( (addr,item)) |
|
|
|
|
|
|
|
|
coins = sorted( coins, key = lambda x: x[1]['timestamp'] ) |
|
|
coins = sorted( coins, key = lambda x: x[1]['timestamp'] ) |
|
|
|
|
|
|
|
|
|
|
|
for addr in prioritized_addresses: |
|
|
|
|
|
h = self.history.get(addr) |
|
|
|
|
|
if h is None: continue |
|
|
|
|
|
for item in h: |
|
|
|
|
|
if item.get('raw_output_script'): |
|
|
|
|
|
prioritized_coins.append( (addr,item)) |
|
|
|
|
|
|
|
|
|
|
|
prioritized_coins = sorted( prioritized_coins, key = lambda x: x[1]['timestamp'] ) |
|
|
|
|
|
|
|
|
inputs = [] |
|
|
inputs = [] |
|
|
|
|
|
coins = prioritized_coins + coins |
|
|
|
|
|
|
|
|
for c in coins: |
|
|
for c in coins: |
|
|
addr, item = c |
|
|
addr, item = c |
|
|
v = item.get('value') |
|
|
v = item.get('value') |
|
|