|
@ -341,41 +341,40 @@ class Wallet: |
|
|
self.change_addresses.append(address) |
|
|
self.change_addresses.append(address) |
|
|
else: |
|
|
else: |
|
|
self.addresses.append(address) |
|
|
self.addresses.append(address) |
|
|
|
|
|
|
|
|
|
|
|
# updates |
|
|
|
|
|
print address |
|
|
|
|
|
self.history[address] = h = self.retrieve_history(address) |
|
|
|
|
|
self.status[address] = h[-1]['blk_hash'] if h else None |
|
|
self.save() |
|
|
self.save() |
|
|
return address |
|
|
return address |
|
|
|
|
|
|
|
|
def recover(self): |
|
|
|
|
|
# todo: recover receiving addresses from tx |
|
|
def synchronize(self): |
|
|
is_found = False |
|
|
|
|
|
while True: |
|
|
while True: |
|
|
addr = self.create_new_address2(True) |
|
|
if self.change_addresses == []: |
|
|
self.history[addr] = h = self.retrieve_history(addr) |
|
|
self.create_new_address2(True) |
|
|
self.status[addr] = h[-1]['blk_hash'] if h else None |
|
|
continue |
|
|
print "recovering", addr |
|
|
a = self.change_addresses[-1] |
|
|
if self.status[addr] is not None: |
|
|
if self.history.get(a): |
|
|
is_found = True |
|
|
self.create_new_address2(True) |
|
|
else: |
|
|
else: |
|
|
break |
|
|
break |
|
|
|
|
|
|
|
|
num_gap = 0 |
|
|
n = self.gap_limit |
|
|
while True: |
|
|
while True: |
|
|
addr = self.create_new_address2(False) |
|
|
if len(self.addresses) < n: |
|
|
self.history[addr] = h = self.retrieve_history(addr) |
|
|
self.create_new_address2(False) |
|
|
self.status[addr] = h[-1]['blk_hash'] if h else None |
|
|
continue |
|
|
print "recovering", addr |
|
|
if map( lambda a: self.history.get(a), self.addresses[-n:] ) == n*[[]]: |
|
|
if self.status[addr] is None: |
|
|
break |
|
|
num_gap += 1 |
|
|
|
|
|
if num_gap == self.gap_limit: break |
|
|
|
|
|
else: |
|
|
else: |
|
|
is_found = True |
|
|
self.create_new_address2(False) |
|
|
num_gap = 0 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
is_found = (len(self.change_addresses) > 1 ) or ( len(self.addresses) > self.gap_limit ) |
|
|
if not is_found: return False |
|
|
if not is_found: return False |
|
|
|
|
|
|
|
|
# remove limit-1 addresses. |
|
|
|
|
|
n = self.gap_limit |
|
|
|
|
|
self.addresses = self.addresses[:-n] |
|
|
|
|
|
|
|
|
|
|
|
# history and addressbook |
|
|
# history and addressbook |
|
|
self.update_tx_history() |
|
|
self.update_tx_history() |
|
|
for tx in self.tx_history.values(): |
|
|
for tx in self.tx_history.values(): |
|
@ -526,7 +525,7 @@ See the release notes for more information.""",1) |
|
|
|
|
|
|
|
|
def get_servers(self): |
|
|
def get_servers(self): |
|
|
self.servers = map( lambda x:x[1], ast.literal_eval( self.request( repr ( ('peers', '' )))) ) |
|
|
self.servers = map( lambda x:x[1], ast.literal_eval( self.request( repr ( ('peers', '' )))) ) |
|
|
|
|
|
|
|
|
def update(self): |
|
|
def update(self): |
|
|
blocks, changed_addresses = self.poll() |
|
|
blocks, changed_addresses = self.poll() |
|
|
if blocks == -1: raise BaseException("session not found") |
|
|
if blocks == -1: raise BaseException("session not found") |
|
@ -536,8 +535,10 @@ See the release notes for more information.""",1) |
|
|
print "updating history for", addr |
|
|
print "updating history for", addr |
|
|
self.history[addr] = self.retrieve_history(addr) |
|
|
self.history[addr] = self.retrieve_history(addr) |
|
|
self.status[addr] = blk_hash |
|
|
self.status[addr] = blk_hash |
|
|
self.update_tx_history() |
|
|
|
|
|
if changed_addresses: |
|
|
if changed_addresses: |
|
|
|
|
|
self.synchronize() |
|
|
|
|
|
self.save() |
|
|
return True |
|
|
return True |
|
|
else: |
|
|
else: |
|
|
return False |
|
|
return False |
|
@ -755,7 +756,7 @@ if __name__ == '__main__': |
|
|
gap = raw_input("gap limit (default 5):") |
|
|
gap = raw_input("gap limit (default 5):") |
|
|
if gap: wallet.gap_limit = int(gap) |
|
|
if gap: wallet.gap_limit = int(gap) |
|
|
print "recovering wallet..." |
|
|
print "recovering wallet..." |
|
|
r = wallet.recover() |
|
|
r = wallet.synchronize() |
|
|
if r: |
|
|
if r: |
|
|
print "recovery successful" |
|
|
print "recovery successful" |
|
|
wallet.save() |
|
|
wallet.save() |
|
|