Docker suite for the FAST project
Includes Form.io's open-source API Server based on Alpine Linux.
FAO SURVEY TECHNOLGY (FAST) is the Food and Agriculture Organization's approach to handle corporate Data Collection and Data Management projects in a scalable and reusable fashion. Rather than just going for a single provider approach, we separated every step of the Data Collection process to allow the use of pluggable/interchangeable Open Source solutions that will work the same way whether you are using them on a Cloud or On-premise environment (No internet access)
To start using this docker container just clone the repository and build it using docker-compose
git clone https://github.com/un-fao/fast-docker-api.git # clone the repository
cd ./fast-docker-api
cp env-example ./Deploys/Compose/.env # modify and save the .env file
make deploy-compose # fire-up the docker container
To start using this docker container with Docker Swarm
git clone https://github.com/un-fao/fast-docker-api.git # clone the repository
cd ./fast-docker-api
make deploy-swarm # fire-up the docker container
The file env-example
is provided as template for setting up the environment variables. Once ready, save it as .env
to start the full stack
These are some of the environment variables available for configuring the Form.io docker container. Check env-example. For more examples check the custom-environment-variables.json to see how they map themselves into the API server configuration.
Setting | Description | Example |
---|---|---|
DATA_PATH_HOST | Storage path on your machine. For all storage systems | ../../data/compose |
NETWORKS_DRIVER | The docker network to attach the container | bridge |
VOLUMES_DRIVER | The volume to attach the containers | local |
Setting | Description | Example |
---|---|---|
FORMIO_PROTOCOL | The protocol used to connect to the formio container (default = http) | http |
FORMIO_HOST | The host used to connect to the formio container (default = localhost) | localhost |
FORMIO_PORT | The port used to connect to the formio container (listening port) | 3001 |
PROJECT_TEMPLATE | The project template to use (leave empty or use default to use default Form.io template). | default |
ROOT_EMAIL | The default root account username used when installing the Form.io API. | admin@example.com |
ROOT_PASS | The default root account password used when installing the Form.io API. | admin@example.com |
MONGO | The MongoDB connection string to connect to your remote database. | mongodb://user:user@mongo:27017/fast |
MONGO_SECRET | The database encryption secret. | FTFaVuIdSv4Hj2bjnwae |
MONGO_HIGH_AVAILABILITY | If your database is high availability (like from Mongo Cloud or Compose), then this needs to be set. | 1 |
JWT_SECRET | The secret password for JWT token encryption. | YilQ9E1wOiITdWOeaMCL |
JWT_EXPIRE_TIME | The expiration for the JWT Tokens. | 240 |
EMAIL_TYPE | The default email transport type (sendgrid or mandrill ). |
sendgrid |
EMAIL_USER | The sendgrid api_user string. | sendgrid-user |
EMAIL_PASS | The sendgrid api_key string. | sendgrid-pass |
EMAIL_KEY | The mandrill apiKey string. | mandrill-key |
EMAIL_OVERRIDE | Provides a way to point all Email traffic to a server (ignores all other email configurations). | {"transport":"smtp","settings":{"port":2525,"host":"smtp.mailtrap.io","auth":{"user":"23esdffd53ac","pass":"324csdfsdf989a"}}} |
After the default deploy you will get Form.io Community running on port 3001 (http)
And you will have full access to the Form.io API as usual
Setting | Description | Example |
---|---|---|
MONGO_PORT | Port to start the mongodb service. | 27017 |
MONGO_ROOT_USERNAME | Name of the root (admin) user | admin |
MONGO_ROOT_PASSWORD | Password of the root (admin) user | admin |
MONGO_DB_NAME | Name of the database to create | fast |
MONGO_DB_USER | Name of the main user of the created DB | user |
MONGO_DB_PASSWORD | Password of the main user of the created DB | user |
After the default deploy you will have MongoDB running on your localhost and port 27017
server: localhost
port: 27017
username: user
password: user
DB: fast
Setting | Description | Example |
---|---|---|
OPENCPU_PORT_HTTP | The OpenCpu http port | 8085 |
OPENCPU_PORT_HTTPS | The OpenCpu http port | 8086 |
After the default deploy you will have OpenCpu running on port 8085.
You will be able to access the OpenCpu test api using localhost:8085/ocpu
Or directly access the OpenCpu Rstudio implementation localhost:8085/rstudio
Remember that the default credentials for OpenCpu are:
Username: opencpu
password: opencpu
Don´t forget to change them!
If you didn't install all the packages you need while deploying the container, you can install them at any time by accessing the container
docker exec -i -t <container_id_or_name> /bin/bash
R -e 'install.packages(c("package1", "package2"))'
Or from outside
docker exec -it <container_id_or_name> echo "R -e 'install.packages(c("package1", "package2"))'"
All routes for the different services are handeled from Kong API gateway. You can use KONGA UI to manage them or to add more!
By doing this, you dont longer query directly the Form.io API server, but use the "/formio" KONG gateway instead
Setting | Description | Example |
---|---|---|
NETDATA_PORT | The NetData port | 19999 |
Want to see how your machine is performing? No problem just access Netdata on localhost:19999
Setting | Description | Example |
---|---|---|
PORTAINER_PORT | The Portainer port | 9010 |
Want to check your full docker-compose cluster status? Go to Portainer localhost:9010
To include a custom project template, save it on the templates directory using the following naming convention: project.<id>.json
(e.g.: project.basic.json
). To install a specific template, set the PROJECT_TEMPLATE
value to the templates <id>
. The default
id is reserved for Form.io's default project template. All projects templates should use Form.io's Project JSON Schema.
You may have multiple project templates in your templates
directory.
--- templates
|--- project.basic.json
|--- project.full.json
Then on your .env
file you just need to specify which template to use:
PROJECT_TEMPLATE=full
If the mongodb database defined in the mongo connection string does not exist, then a new project will be initialized using the given project template.
If you want to manually apply changes to one of the Dockerfiles dont forget to manually build the image using: docker-compose build
docker-compose build formio
- Alfredo Irarrazaval - airarrazaval
- Ignacio Cabrera - cabrerabywaters
This project is licensed under the MIT License - see the LICENSE file for details