These instructions should help you get setup to run or develop on Medic Mobile. For latest changes and release announcements see our change log.
Medic Mobile combines messaging, data collection, and analytics for health workers and health systems in hard-to-reach areas with or without internet connectivity.
The medic-webapp
repository is the core tool of the Medic Mobile stack. When health workers submit data — using text messages (SMS), our mobile applications, or our SIM applications — the web app confirms data submission, generates unique IDs, and schedules automated reminder messages based on user-defined configurations. All information submitted by mobile users can be viewed, filtered, verified, and exported using the reports tab in the web application.
The web app is fully responsive with a mobile-first design, and supports localization using any written language. It can be installed locally, as part of a virtual machine (see medic-os), or in the cloud.
Currently, we functionally support the latest versions of Chrome, Chrome for Android and Firefox. We do not support Safari (unreliable implementations of web APIs we need) and the generic android browser (unreliable implementations in general). Our webapp code, which includes any code written as configuration, is still ES5. Our exact support matrix (including older app versions) can be found in our docs.
For more information about Medic Mobile's tools, visit http://medicmobile.org/tools. For more information about Medic Mobile's architecture and how the pieces fit together, see Architecture Overview. For more information about the format of docs in the database, see Database Schema. For more information about the SMS exchange protocol between webapp and gateway, see Message States.
If you want to get up and running with no fuss, you can use Horticulturalist.
If you want to use our standard configuration, you can use the Medic Project Configurer in the ./config/standard directory once Horticuluralist has successfully started.
If you want to develop against Medic, follow the Development Setup below.
Before getting started, read about our development workflow and the architecture overview.
The setup described below doesn't use Medic OS, the tools will be run directly on your machine.
You will need to install the following:
Node.js 8.11.x and above
yarn 1.7.0
CouchDB v2.x
NB: multiple CouchDB nodes will be more complicated, but the general pattern outlined below will be the same.
By default CouchDB runs in "admin party" mode, which means you do not need users to read or edit any data. This is great for some, but to use Medic safely we're going to disable this feature.
First, add an admin user. When prompted to create an admin during installation, use username:admin
and password:pass
. Passwords can be changed via Fauxton. For more information see the CouchDB install doc.
Now that's done, we must reconfigure CouchDB to require authentication:
curl -X PUT http://admin:pass@localhost:5986/_config/chttpd/require_valid_user \
-d '"true"' -H "Content-Type: application/json"
Then create an actual admin user:
curl -X POST http://admin:pass@localhost:5984/_users \
-H "Content-Type: application/json" \
-d '{"_id": "org.couchdb.user:admin", "name": "admin", "password":"pass", "type":"user", "roles":[]}'
After following these steps CouchDB should no longer allow unauthorised access:
curl http://admin:pass@localhost:5984 # should work
{"couchdb":"Welcome","version":"2.0.0","vendor":{"name":"The Apache Software Foundation"}}
curl http://localhost:5984 # should fail
{"error":"unauthorized","reason":"Authentication required."}
To be able to use Fauxton with authenticated users:
curl -X PUT http://admin:pass@localhost:5986/_config/httpd/WWW-Authenticate \
-d '"Basic realm=\"administrator\""' -H "Content-Type: application/json"
Our application is larger than CouchDB's default request size, so we must increase it otherwise deployments may fail:
curl -X PUT --data '"4294967296"' http://admin:pass@localhost:5986/_config/httpd/max_http_request_size
git clone https://github.com/medic/medic-webapp
cd medic-webapp
yarn install
Create a .env
file in the app directory with the following contents
COUCH_URL=http://admin:pass@localhost:5984/medic
COUCH_NODE_NAME=couchdb@localhost
COUCH_USER=username
COUCH_PASSWORD=password-for-couch
Then install webapp, admin, api and sentinel dependencies
cd webapp && yarn install && cd ..
cd admin && yarn install && cd ..
cd api && yarn install && cd ..
cd sentinel && yarn install && cd ..
Then export the contents of .env
to the shell environment
export COUCH_NODE_NAME=couchdb@localhost
export COUCH_URL=http://admin:pass@localhost:5984/medic
export COUCH_USER=admin
export COUCH_PASSWORD=pass
Then do an initial deploy of the webapp:
grunt dev-webapp
Once this is complete you can close it, and from now on you can just run to run in watch mode:
yarn dev
To run without watch:
yarn start
To run medic webapp on a docker setup use the following scripts
$ source ./setup-docker/export-env.sh [medic db name e.g. medic] [nodename e.g. couchdb-nodename] [root couchdb username] [root couchdb password]
The above script allows you to create and export the required environment variables. Here is an real use scenario:
$ source ./setup-docker/export-env.sh medic couchdb-image admin admin-1234 5984
Then run the script below to start docker-compose services
$ source ./setup-docker/boot-system.sh
The medic webapp will throw and error _design/medic - NotFound
do not be alarmed just do docker-compose restart webapp
.
If yarn start
is not to your taste for whatever reason, the apps can be deployed individually.
grunt dev-webapp
will build and deploy the webapp, then watch for changes and redeploy when necessary.
cd sentinel
yarn install
export COUCH_NODE_NAME=couchdb@localhost
export COUCH_URL=http://admin:pass@localhost:5984/medic
Then run either node ./server.js
from the sentinel directory or grunt dev-sentinel
from the repository directory (which will watch for changes).
cd api
yarn install
export COUCH_NODE_NAME=couchdb@localhost
export COUCH_URL=http://admin:pass@localhost:5984/medic
Then run either node ./server.js
from the api directory or grunt dev-api
from the repository directory (which will watch for changes).
Navigate your browser to http://localhost:5988/medic/login
.
To fill your app with generated data, you can batch-load messages from a CSV file, with the load_messages.js script.
Use curl
to submit a single message:
curl -i -u gateway:123qwe \
--data-urlencode 'message=Test One two' \
--data-urlencode 'from=+13125551212' \
--data-urlencode 'sent_timestamp=1403965605868' \
-X POST \
http://localhost:5988/api/v1/records
All text labels in the app are localized. See the translation documentation for more details on how to add new labels or modify existing ones.
Check out the Gruntfile for all the tests you can run.
They live in the tests
directories of each app. Run them with grunt: grunt unit-continuous
.
They live in tests. To run them:
- Update and start Webdriver:
yarn run webdriver
- Run tests:
grunt e2e
grunt api-e2e
Travis runs grunt ci
every time some new code is pushed to github.
Horticulturalist is an easy way to deploy Medic locally if you're not going to be developing against it.
Horti is currently in beta, and will eventually replace the Market, Gardener and Dashboard as our standard way to deploy and manage our software.
To use it locally:
- Install, configure and secure CouchDB
- Install npm
- Install Horticulturalist with
npm install -g horticulturalist
Now use the horti
tool to bootstrap Medic and launch it:
COUCH_NODE_NAME=couchdb@localhost COUCH_URL=http://admin:pass@localhost:5984/medic horti --local --bootstrap
This will download, configure and install the latest Master build of medic. If you're looking to deploy a specific version, provide it to the bootstrap
command:
COUCH_NODE_NAME=couchdb@localhost COUCH_URL=http://admin:pass@localhost:5984/medic horti --local --bootstrap=3.0.0-beta.1
To kill Horti hit CTRL+C. To start Horti (and Medic) again, run the same command as above, but this time don't bootstrap:
COUCH_NODE_NAME=couchdb@localhost COUCH_URL=http://admin:pass@localhost:5984/medic horti --local
If you wish to change the version of Medic installed, you can either bootstrap again, or use the Instance Upgrade configuration screen.'
NB: Horticulturalist doesn't wipe your database when it bootstraps, it just installs the provided version (or master) over whatever you already have. To completely start again, stop Horti and delete the medic
database, either using Futon / Fauxton, or from the command line:
curl -X DELETE $COUCH_URL
We ship with one "standard" configuration, which can be a useful basis to start with. It is located at [./config/standard[(https://github.com/medic/medic-webapp/tree/master/config/standard).
Configuration is performed using Medic Project Configurer. medic-conf
expects a particular structure (seen in the standard config above). It compiles forms and configuration into the required formats, as well as uploading that configuration and performing other tasks.
Code is automatically published via Travis CI to the staging server.
Join our Google Group or file an issue on Github. You can also post questions, and look for answers, on our AnswerHub site.
At Medic Mobile we welcome and appreciate community contributions. If you have an idea or a question we'd love to hear from you! The easiest ways to get in touch are by raising issues in the medic-webapp Github repo or by messaging our Google Group. For more info check out our contributor guidelines.
Builds brought to you courtesy of Travis CI.
Copyright 2013-2018 Medic Mobile, Inc. hello@medicmobile.org
The software is provided under AGPL-3.0. Contributions to this project are accepted under the same license.