Added helpers to commit in logger.py

Trying to ignore line for #3865
This commit is contained in:
Jean-Marie Traissard 2008-04-16 13:46:44 +00:00
parent 3aefee4700
commit df257baef5
1 changed files with 24 additions and 35 deletions

View File

@ -135,6 +135,14 @@ class Logger:
self.open_db() self.open_db()
self.get_jids_already_in_db() self.get_jids_already_in_db()
def simple_commit(self, sql_to_commit):
'''helper to commit'''
self.cur.execute(sql_to_commit)
try:
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)
def get_jids_already_in_db(self): def get_jids_already_in_db(self):
try: try:
self.cur.execute('SELECT jid FROM jids') self.cur.execute('SELECT jid FROM jids')
@ -144,6 +152,10 @@ class Logger:
self.jids_already_in = [] self.jids_already_in = []
for row in rows: for row in rows:
# row[0] is first item of row (the only result here, the jid) # row[0] is first item of row (the only result here, the jid)
if row[0] == '':
# malformed jid, ignore line
pass
else:
self.jids_already_in.append(row[0]) self.jids_already_in.append(row[0])
def get_jids_in_db(self): def get_jids_in_db(self):
@ -331,21 +343,13 @@ class Logger:
def insert_unread_events(self, message_id, jid_id): def insert_unread_events(self, message_id, jid_id):
''' add unread message with id: message_id''' ''' add unread message with id: message_id'''
sql = 'INSERT INTO unread_messages VALUES (%d, %d)' % (message_id, jid_id) sql = 'INSERT INTO unread_messages VALUES (%d, %d)' % (message_id, jid_id)
self.cur.execute(sql) self.simple_commit(sql)
try:
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)
def set_read_messages(self, message_ids): def set_read_messages(self, message_ids):
''' mark all messages with ids in message_ids as read''' ''' mark all messages with ids in message_ids as read'''
ids = ','.join([str(i) for i in message_ids]) ids = ','.join([str(i) for i in message_ids])
sql = 'DELETE FROM unread_messages WHERE message_id IN (%s)' % ids sql = 'DELETE FROM unread_messages WHERE message_id IN (%s)' % ids
self.cur.execute(sql) self.simple_commit(sql)
try:
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)
def get_unread_msgs(self): def get_unread_msgs(self):
''' get all unread messages ''' ''' get all unread messages '''
@ -625,11 +629,7 @@ class Logger:
# jid_id is unique in this table, create or update : # jid_id is unique in this table, create or update :
sql = 'REPLACE INTO rooms_last_message_time VALUES (%d, %d)' % \ sql = 'REPLACE INTO rooms_last_message_time VALUES (%d, %d)' % \
(jid_id, time) (jid_id, time)
self.cur.execute(sql) self.simple_commit(sql)
try:
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)
def _build_contact_where(self, account, jid): def _build_contact_where(self, account, jid):
'''build the where clause for a jid, including metacontacts '''build the where clause for a jid, including metacontacts
@ -662,20 +662,12 @@ class Logger:
result = results[0][0] result = results[0][0]
if result == type_id: if result == type_id:
return return
self.cur.execute( sql = 'UPDATE transports_cache SET type = %d WHERE transport = "%s"' %\
'UPDATE transports_cache SET type = %d WHERE transport = "%s"' % ( (type_id, jid)
type_id, jid)) self.simple_commit(sql)
try:
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)
return return
self.cur.execute( sql = 'INSERT INTO transports_cache VALUES ("%s", %d)' % (jid, type_id)
'INSERT INTO transports_cache VALUES ("%s", %d)' % (jid, type_id)) self.simple_commit(sql)
try:
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)
def get_transports_type(self): def get_transports_type(self):
'''return all the type of the transports in DB''' '''return all the type of the transports in DB'''
@ -756,11 +748,8 @@ class Logger:
gzip.write(data) gzip.write(data)
gzip.close() gzip.close()
data = string.getvalue() data = string.getvalue()
self.cur.execute(''' sql = '''
INSERT INTO caps_cache ( node, ver, ext, data ) INSERT INTO caps_cache ( node, ver, ext, data )
VALUES (?, ?, ?, ?); VALUES (?, ?, ?, ?);
''', (node, ver, ext, buffer(data))) # (1) -- note above ''', (node, ver, ext, buffer(data)) # (1) -- note above
try: self.simple_commit(sql)
self.con.commit()
except sqlite.OperationalError, e:
print >> sys.stderr, str(e)