blob: bbbc1dec522c179f25224a138ca3efbf766c6d94 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
Soledad Client
==============
The Soledad Client is a Python library aimed to provide access to a document
store that can be synchronized securelly with other deviced through the Soledad
Server. Key aspects of Soledad Client include:
* **Encrypted local storage:** All data cached locally is stored in an
encrypted database.
* **Client-side encrypted sync:** Soledad puts very little trust in the
server by encrypting all data before it is synchronized to the server and
by limiting ways in which the server can modify the user's data.
* **Document database:** An application using the Soledad client library is
presented with a document-centric database API for storage and sync.
Documents may be indexed, searched, and versioned.
* **Blobs storage:** The client and server API provide blobs storage, which
can be used both for data delivery in the server side (i.e. email) and
payload storage on the client side.
Setting-up
----------
The following information is needed in order to instantiate a soledad client:
* ``uuid``: the user's uuid.
* ``passphrase``: the user's passphrase.
* ``secrets_path``: a local path for secrets storage.
* ``local_db_path``: a local path for the documents database.
* ``server_url``: the Soledad Server's URL.
* ``cert_file``: a local path for the CA certificate.
* ``auth_token``: an authentication token obtained after logging into the
provider.
Once all pieces are in place, you can instantiate the client as following:
.. code-block:: python
from leap.soledad.client import Soledad
client = Soledad(
uuid,
passphrase,
secrets_path=secrets_path,
local_db_path=local_db_path,
server_url=server_url,
cert_file=cert_file,
auth_token=token)
Usage example
-------------
Soledad is written in the `Twisted asynchronous model
<https://twistedmatrix.com/documents/current/core/howto/defer-intro.html>`_, so
you will need to make sure a `reactor
<http://twistedmatrix.com/documents/current/core/howto/reactor-basics.html>`_
is running.
Creation of a document and synchronization is done as follows:
.. code-block:: python
yield client.create_doc({'my': 'doc'}, doc_id='some-id')
doc = yield client.get_doc('some-id')
yield client.sync()
The document can be modified and synchronized again:
.. code-block:: python
doc.content = {'new': 'content'}
yield client.put_doc(doc)
yield client.sync()
|