Skip to content
Chris George edited this page Jan 27, 2016 · 111 revisions

RapidPro

  1. Create a RapidPro account and get the API key for that account (you will need this key for the below provisioning steps).
  2. Clone the appropriate flows from an existing RapidPro account and import them into your new account.
  3. Within each flow, make sure to point the Webhooks to the appropriate EUMS hostname (which is specified below in the provisioning steps).
  4. Make sure to apply the following labels to the corresponding flows (it is important to specify these correctly in order for the EUMS application to work):
Flow Label Name
IP Flow IMPLEMENTING_PARTNER
Middle Man / Sub-consignee Flow SUB_CONSIGNEES
End User Flow END_USER

EUMS

Environment Variables

The following environment variables need to be set in order for a successful deployment. Note that for deploying from the CI server, the 'Secure Variable?' column refers to whether the variable needs to be set in the Secure Variable section of the 'Environment Variables' tab in the top level section for the pipeline. If you are not deploying EUMS from the CI server, disregard that column.

Variable Name Secure Variable? Explanation
DEPLOY_USER No this is the deploy user you will set up in step 1 below
DEPLOY_HOST No this is the IP or hostname of the production server
EUMS_HOST No this will be the hostname of the production server
DJANGO_SECRET_KEY Yes this should be set to a unique, unpredictable value
RAPIDPRO_API_TOKEN Yes this is the token that corresponds to the appropriate RapidPro account that the production server will be talking to
EMAIL_PASSWORD Yes we are unsure if this is necessary so can put a random placeholder here for now
VISION_USER Yes this is the user name you will use to sync the vision data
VISION_PASSWORD Yes this is the password you will use to sync the vision data
VISION_BUSINESS_AREA_CODE No this is the business area code you will use to sync the vision data
TIME_ZONE No the time zone for your instance; you can find time zones here
MAP_LATITUDE No the latitude that represents the center latitude of your respective map; use this tool to find the center latitude
MAP_LONGITUDE No the longitude that represents the center longitude of your respective map; use this tool to find the center longitude
MAP_LEVEL No this is the zoom level for your respective map; use this tool to find the zoom level
ADMIN_PASSWORD Yes this is the password for the EUMS super user for logging into the EUMS system after a deploy

Prerequisites

  1. Make sure the system requirements of the new production server match the specs given here.

  2. Also, the expectation is that outside of the normal libraries that come installed with the OS, nothing else has been installed. For example, the initial deploy depends on PostgreSQL not having been set up yet (PostgreSQL is set up during the automated deployment).

Deployment Steps

Deployment is currently done using the Go Release Management system. Below are the steps for deploying EUMS to production. Note that the steps for the production server only need to be done once, as well as a few of the initial steps for the Go Release Management server.

On the new production server ...

  1. Create a deploy user with a home directory (no password necessary). This user should be the same one referenced in the environment variable section above.
  2. Allow remote access via public / private keys.
    • Create or retrieve the public key for the user on the machine being deploying from.
    • Copy this public key to a 'authorized_keys' file within the the /home/<name-of-deploy-user>/.ssh/ directory on the production server.
  3. Allow this user to run sudo on any command without a password.
    • Run 'sudo visudo'
    • Add this line to the bottom of the file: 'deployuser ALL=(ALL) NOPASSWD:ALL' (without quotes)

On the Go Release Management server ...

  1. Clone a previous production-like pipeline. Make sure the name reflects your new production deploy (e.g. 'eums-prod-uganda').
  2. Update the environment variables in the pipeline's top level 'Environment Variables' tab. Refer to the above environment variables table. Save the new pipeline.
  3. Place the new pipeline within the 'eums-prod' environment. You can do this via the 'Environments' menu item at the top of the page. (This allows a dedicated agent to pick and execute production deploys.)
  4. Un-pause the pipeline.
  5. Kick off the first stage of the pipeline, 'fetch-artifacts'. Wait for this stage and the 'packaging' stage to complete.
  6. Once the 'packaging' stage is complete, place the map in the appropriate directory.
    • ssh into the CI server. Switch to the go user (sudo su - go)
    • cd to the /var/lib/go-agent2/pipelines/<name of your new pipeline>/
    • Create a 'map' directory in this directory.
    • Within the 'map' directory, place your map GeoJSON file. This map GeoJSON file must be named 'districts.json'.
    • Reminder: Ensure your map environment variables are set correctly. This tool provides a way to find the appropriate latitude, longitude, and zoom level of your map for EUMS.
  7. Kick off the 'deploy' stage. This should take roughly 20-30 minutes.

For doing subsequent upgrades to the production server, repeat steps 5) through 7).

Clone this wiki locally