diff options
| author | Kali Kaneko <kali@leap.se> | 2014-02-19 23:34:49 -0400 | 
|---|---|---|
| committer | Kali Kaneko <kali@leap.se> | 2014-02-20 00:20:27 -0400 | 
| commit | 057e7c28f9fc790fa449cef5361fba9dcd5009d1 (patch) | |
| tree | 652ad489f38ad2119a074802875929f998526eac | |
| parent | dfa01cb0518eade316abb12c10bf2dc808745cea (diff) | |
add locks for create_doc and update_indexes. Closes: #5139
This solves a InterfaceError (sqlite error code 21)
we were having with massive concurrent creation/puts.
| -rw-r--r-- | client/src/leap/soledad/client/sqlcipher.py | 31 | 
1 files changed, 25 insertions, 6 deletions
| diff --git a/client/src/leap/soledad/client/sqlcipher.py b/client/src/leap/soledad/client/sqlcipher.py index ef059e9b..d8ba0b79 100644 --- a/client/src/leap/soledad/client/sqlcipher.py +++ b/client/src/leap/soledad/client/sqlcipher.py @@ -147,6 +147,8 @@ class SQLCipherDatabase(sqlite_backend.SQLitePartialExpandDatabase):      _index_storage_value = 'expand referenced encrypted'      k_lock = threading.Lock() +    create_doc_lock = threading.Lock() +    update_indexes_lock = threading.Lock()      _syncer = None      def __init__(self, sqlcipher_file, password, document_factory=None, @@ -400,6 +402,22 @@ class SQLCipherDatabase(sqlite_backend.SQLitePartialExpandDatabase):              'ALTER TABLE document '              'ADD COLUMN syncable BOOL NOT NULL DEFAULT TRUE') +    def create_doc(self, content, doc_id=None): +        """ +        Create a new document in the local encrypted database. + +        :param content: the contents of the new document +        :type content: dict +        :param doc_id: an optional identifier specifying the document id +        :type doc_id: str + +        :return: the new document +        :rtype: SoledadDocument +        """ +        with self.create_doc_lock: +            return sqlite_backend.SQLitePartialExpandDatabase.create_doc( +                self, content, doc_id=doc_id) +      def _put_and_update_indexes(self, old_doc, doc):          """          Update a document and all indexes related to it. @@ -409,12 +427,13 @@ class SQLCipherDatabase(sqlite_backend.SQLitePartialExpandDatabase):          :param doc: The new version of the document.          :type doc: u1db.Document          """ -        sqlite_backend.SQLitePartialExpandDatabase._put_and_update_indexes( -            self, old_doc, doc) -        c = self._db_handle.cursor() -        c.execute('UPDATE document SET syncable=? ' -                  'WHERE doc_id=?', -                  (doc.syncable, doc.doc_id)) +        with self.update_indexes_lock: +            sqlite_backend.SQLitePartialExpandDatabase._put_and_update_indexes( +                self, old_doc, doc) +            c = self._db_handle.cursor() +            c.execute('UPDATE document SET syncable=? ' +                      'WHERE doc_id=?', +                      (doc.syncable, doc.doc_id))      def _get_doc(self, doc_id, check_for_conflicts=False):          """ | 
