this repo has no description
1import logging 2 3import apsw 4 5class FirehoseManager: 6 def __init__(self, fname='db/firehose.db'): 7 self.db_cnx = apsw.Connection(fname) 8 self.db_cnx.pragma('journal_mode', 'WAL') 9 with self.db_cnx: 10 self.db_cnx.execute("create table if not exists firehose(key text unique, value text)") 11 12 self.logger = logging.getLogger('firehose.manager') 13 14 def get_sequence_number(self): 15 row = self.db_cnx.execute("select * from firehose where key = 'seq'").fetchone() 16 if row is None: 17 return None 18 (key, value) = row 19 return int(value) 20 21 def set_sequence_number(self, value): 22 self.logger.debug(f'setting sequence number = {value}') 23 24 with self.db_cnx: 25 self.db_cnx.execute( 26 "insert into firehose (key, value) values ('seq', :value) on conflict(key) do update set value = :value", 27 dict(value=value) 28 ) 29 30 self.db_cnx.pragma('wal_checkpoint(RESTART)')