release_all_outputs on startup

This commit is contained in:
Lex Berezhny 2020-08-04 15:02:43 -04:00
parent bbc4113cac
commit 9f1ed6e8c3
2 changed files with 11 additions and 7 deletions

View file

@ -1254,7 +1254,10 @@ class Database(SQLiteMixin):
self.constrain_collections(constraints) self.constrain_collections(constraints)
return self.get_utxo_count(**constraints) return self.get_utxo_count(**constraints)
async def release_all_outputs(self, account): async def release_all_outputs(self, account=None):
if account is None:
await self.db.execute_fetchall("UPDATE txo SET is_reserved = 0 WHERE is_reserved = 1")
else:
await self.db.execute_fetchall( await self.db.execute_fetchall(
"UPDATE txo SET is_reserved = 0 WHERE" "UPDATE txo SET is_reserved = 0 WHERE"
" is_reserved = 1 AND txo.address IN (" " is_reserved = 1 AND txo.address IN ("

View file

@ -331,6 +331,7 @@ class Ledger(metaclass=LedgerRegistry):
async with self._header_processing_lock: async with self._header_processing_lock:
await self._update_tasks.add(self.initial_headers_sync()) await self._update_tasks.add(self.initial_headers_sync())
await fully_synced await fully_synced
await self.db.release_all_outputs()
await asyncio.gather(*(a.maybe_migrate_certificates() for a in self.accounts)) await asyncio.gather(*(a.maybe_migrate_certificates() for a in self.accounts))
await asyncio.gather(*(a.save_max_gap() for a in self.accounts)) await asyncio.gather(*(a.save_max_gap() for a in self.accounts))
if len(self.accounts) > 10: if len(self.accounts) > 10: