diff options
author | drebs <drebs@leap.se> | 2017-11-30 19:14:47 -0200 |
---|---|---|
committer | drebs <drebs@leap.se> | 2017-11-30 20:32:01 -0200 |
commit | 33510b1f1f90ac5fdb7a473777ff5c8f0bc900c6 (patch) | |
tree | d218ae3789a40ac8115655c39c2d6c7a1afa37cb /src/leap/soledad/client | |
parent | dafd949943b06cd6478c6dc9ac2a4be2fd63db19 (diff) |
[bug] avoid overwriting priorities on sync status batch update
Diffstat (limited to 'src/leap/soledad/client')
-rw-r--r-- | src/leap/soledad/client/_db/blobs/sql.py | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/src/leap/soledad/client/_db/blobs/sql.py b/src/leap/soledad/client/_db/blobs/sql.py index a89802d8..6b92c503 100644 --- a/src/leap/soledad/client/_db/blobs/sql.py +++ b/src/leap/soledad/client/_db/blobs/sql.py @@ -149,15 +149,16 @@ class SQLiteBlobBackend(object): @defer.inlineCallbacks def update_sync_status(self, blob_id, sync_status, namespace="", priority=None): - retries = '(SELECT retries from sync_state' \ - ' WHERE blob_id="%s" and namespace="%s")' \ + retries = 'SELECT retries from sync_state' \ + ' WHERE blob_id="%s" and namespace="%s"' \ % (blob_id, namespace) if not priority: - priority = '(SELECT priority FROM sync_state' \ - ' WHERE blob_id="%s" AND namespace="%s")' \ + priority = 'SELECT priority FROM sync_state' \ + ' WHERE blob_id="%s" AND namespace="%s"' \ % (blob_id, namespace) fields = 'blob_id, namespace, sync_status, retries, priority' - markers = '?, ?, ?, %s, %s' % (retries, priority) + markers = '?, ?, ?, (%s), COALESCE((%s), %s)' \ + % (retries, priority, Priority.DEFAULT) values = [blob_id, namespace, sync_status] insert = 'INSERT or REPLACE INTO sync_state (%s) VALUES (%s)' \ % (fields, markers) @@ -188,15 +189,20 @@ class SQLiteBlobBackend(object): namespace=''): if not blob_id_list: return - insert = 'INSERT or REPLACE INTO sync_state' - first_blob_id, blob_id_list = blob_id_list[0], blob_id_list[1:] - insert += ' (blob_id, namespace, sync_status, priority)' - insert += ' VALUES (?, ?, ?, ?)' - values = (first_blob_id, namespace, sync_status, Priority.DEFAULT) + inserts = [] + values = () for blob_id in blob_id_list: - insert += ', (?, ?, ?, ?)' - values += (blob_id, namespace, sync_status, Priority.DEFAULT) - return self.dbpool.runQuery(insert, values) + priority = 'SELECT priority FROM sync_state' \ + ' WHERE blob_id="%s" AND namespace="%s"' \ + % (blob_id, namespace) + insert = '(?, ?, ?, COALESCE((%s), %s))' \ + % (priority, Priority.DEFAULT) + inserts.append(insert) + values += (blob_id, namespace, sync_status) + query = 'INSERT or REPLACE INTO sync_state' + query += ' (blob_id, namespace, sync_status, priority) VALUES ' + query += ', '.join(inserts) + return self.dbpool.runQuery(query, values) def increment_retries(self, blob_id): query = 'update sync_state set retries = retries + 1 where blob_id = ?' |