summaryrefslogtreecommitdiff
path: root/docs/client.rst
diff options
context:
space:
mode:
Diffstat (limited to 'docs/client.rst')
-rw-r--r--docs/client.rst75
1 files changed, 70 insertions, 5 deletions
diff --git a/docs/client.rst b/docs/client.rst
index 3befd69c..bbbc1dec 100644
--- a/docs/client.rst
+++ b/docs/client.rst
@@ -1,9 +1,74 @@
Soledad Client
==============
-Current reasoning about Soledad can be found `here
-<https://leap.se/en/docs/design/soledad>`_. That will be cleaned up and
-migrated here in the future.
+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:
-You can also take a look at :ref:`client-side-code-api` and
-:ref:`client-side-attachments-api` for information on the API.
+ * **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()