diff options
| author | Tomás Touceda <chiiph@leap.se> | 2013-12-06 15:43:23 -0300 | 
|---|---|---|
| committer | Tomás Touceda <chiiph@leap.se> | 2013-12-06 15:43:23 -0300 | 
| commit | deb78a5f3502ece98ec3e0b70f93025c4a1b3da5 (patch) | |
| tree | abb188c846482e60a1961864b70c17cbf760f6a8 /scripts | |
| parent | 0ade4a7e3a323df631c9772e4db5173a20979d46 (diff) | |
| parent | 5f2a29120ba2d22d7d2406628ce2f6735b60d09c (diff) | |
Merge branch 'release-0.4.4'0.4.4
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/README.rst | 17 | ||||
| -rw-r--r-- | scripts/client-side-db.py | 36 | ||||
| -rwxr-xr-x | scripts/develop_mode.sh | 7 | ||||
| -rw-r--r-- | scripts/server-side-db.py | 38 | 
4 files changed, 98 insertions, 0 deletions
| diff --git a/scripts/README.rst b/scripts/README.rst new file mode 100644 index 00000000..fdd1d642 --- /dev/null +++ b/scripts/README.rst @@ -0,0 +1,17 @@ +Soledad Scripts +=============== + +The scripts in this directory are meant to be used for development purposes. + +Currently, the scripts are: + +  * server-side-db.py: Gives access to server-side soledad user database, +    based on the configuration in /etc/leap/soledad-server.conf. One should +    use it as: + +      python -i server-side-db.py <uuid> + +  * client-side-db.py: Gives access to client-side soledad user database, +    based on data stored in ~/.config/leap/soledad. One should use it as: + +      python -i client-side-db.py <uuid> <passphrase> diff --git a/scripts/client-side-db.py b/scripts/client-side-db.py new file mode 100644 index 00000000..0c3df7a4 --- /dev/null +++ b/scripts/client-side-db.py @@ -0,0 +1,36 @@ +#!/usr/bin/python + +# This script gives client-side access to one Soledad user database by using +# the data stored in ~/.config/leap/soledad/ + +import sys +import os + +from leap.common.config import get_path_prefix +from leap.soledad.client import Soledad + +if len(sys.argv) != 3: +    print 'Usage: %s <uuid> <passphrase>' % sys.argv[0] +    exit(1) + +uuid = sys.argv[1] +passphrase = unicode(sys.argv[2]) + +secrets_path = os.path.join(get_path_prefix(), 'leap', 'soledad', +                            '%s.secret' % uuid) +local_db_path = os.path.join(get_path_prefix(), 'leap', 'soledad', +                             '%s.db' % uuid) +server_url = 'http://dummy-url' +cert_file = 'cert' + +sol = Soledad(uuid, passphrase, secrets_path, local_db_path, server_url, +             cert_file) +db = sol._db + +# get replica info +replica_uid = db._replica_uid +gen, docs = db.get_all_docs() +print "replica_uid: %s" % replica_uid +print "generation:  %d" % gen +gen, trans_id = db._get_generation_info() +print "transaction_id: %s" % trans_id diff --git a/scripts/develop_mode.sh b/scripts/develop_mode.sh new file mode 100755 index 00000000..8d2ebaa8 --- /dev/null +++ b/scripts/develop_mode.sh @@ -0,0 +1,7 @@ +#!/bin/sh +cd common +python setup.py develop +cd ../client +python setup.py develop +cd ../server +python setup.py develop diff --git a/scripts/server-side-db.py b/scripts/server-side-db.py new file mode 100644 index 00000000..01a9aaac --- /dev/null +++ b/scripts/server-side-db.py @@ -0,0 +1,38 @@ +#!/usr/bin/python + +# This script gives server-side access to one Soledad user database by using +# the configuration stored in /etc/leap/soledad-server.conf. + +import sys +from ConfigParser import ConfigParser + +from leap.soledad.common.couch import CouchDatabase + +if len(sys.argv) != 2: +    print 'Usage: %s <uuid>' % sys.argv[0] +    exit(1) + +uuid = sys.argv[1] + +# get couch url +cp = ConfigParser() +cp.read('/etc/leap/soledad-server.conf') +url = cp.get('soledad-server', 'couch_url') + +# access user db +dbname = 'user-%s' % uuid +db = CouchDatabase(url, dbname) + +# get replica info +replica_uid = db._replica_uid +gen, docs = db.get_all_docs() +print "dbname:      %s" % dbname +print "replica_uid: %s" % replica_uid +print "generation:  %d" % gen + +# get relevant docs +schemes = map(lambda d: d.content['_enc_scheme'], docs) +pubenc = filter(lambda d: d.content['_enc_scheme'] == 'pubkey', docs) + +print "total number of docs:  %d" % len(docs) +print "pubkey encrypted docs: %d" % len(pubenc) | 
