CHT Applications > Quick Guides > Performance > Replication
Settings for downloading copies of data onto a user’s device.
Sometimes there will be a production problem that you need to dig into locally to solve. This guide explains how to:
Production data is medical data. It’s HIV statuses and pregnancies. It’s important, and it’s not yours. If you’re downloading it, do so on an encrypted drive and delete it once you’re done with it.
First thing is to get the data onto your local CouchDB. It’s advisable to create a new DB for this, so that you have a fresh untouched collection of data that isn’t mixed in with anything you have locally.
If there isn’t much data you can replicate the entire DB locally. You can initiate this either from your local Fauxton, or from the command line. You must use an administrator username and password for this at both the source and destination.
For Fauxton, navigate to http://localhost:5984/_utils/#/replication/_create For command line, see: https://docs.couchdb.org/en/stable/api/server/common.html#replicate
Note that replication may stall on one document, and you may end up with your local DB having one less document than the source. This is due to how our URLs are setup: the replicator gets confused and considers login
(ie https://url/login
) to be a document. You can safely ignore this difference - you’re good to go once your destination database has one less document than the source.
If the instance is too large to replicate locally (or you are too impatient), you can replicate the data accessible to a single user. This process downloads a user’s data into a browser and then copies that data into a CouchDB database.
about:config
. Set security.csp.enable
to false
to disable Content Security Policies.https
. One way is to run ngrok http PORT
. The PORT
(5984
by default) can be found in database configuration using fauxton under the chttpd
section. This will make your CouchDB accessible via a url like https://abcd1234.ngrok.io
.await PouchDB.replicate('medic-user-XXX', 'https://your:admin@abcd1234.ngrok.io/YYY');
. Here XXX
is the name you logged in as, and YYY
is the name of a database in which to store the data.5984
and 5986
to localhost.about:config
. Set security.csp.enable
to true
to re-enable Content Security Policies.To log in as a specific prod user you need to also copy them from the prod _users
database into your own local _users
database. The simplest way to do this is to just open the DB in Fauxton, find the document and copy it on your clipboard, then create a new document in your local _users
DB and paste it in, deleting the _rev
property.
You could also use this opportunity to change the password to something easier to work with locally. To do this, add a password
property into the document with the password you want in plain text. CouchDB will convert this to a properly hashed password on save.
First you need to decide if you need a local development environment (unless you already have one, in which case you might as well use it), or are happy to just use Horticulturalist.
A local development environment will be useful to you if:
2.14.0
, as they are not available in Horticulturalist’s repos.If you don’t already have a local dev env, follow the instructions on the development setup instructions.
Then you need to:
COUCH_URL=http://your:admin@localhost:5984/YYY npm run build-dev
.COUCH_URL=http://your:admin@localhost:5984/YYY node api/server
.Once you’ve done all of that you should be able to log in with your user.
Follow the instructions on the horticulturalist repo to get it installed. Then:
medic
DB doesn’t exist, so that you have a fresh database.medic
database using the Fauxton console.horti --local --bootstrap=XXX
, where XXX
is the version you want to use (maybe the same one as production?)You should now be able to log in as that user locally!
Settings for downloading copies of data onto a user’s device.
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.