#!/bin/sh SOURCE_DIR=$(realpath $(dirname "${0}"))/mifosx # Build Docker container docker build -t mifosx ${SOURCE_DIR} # Create databases export MIFOSX_PWD=$(head -c 18 /dev/urandom | base64) envsubst <${SOURCE_DIR}/createdb.sql | docker exec -i mariadb mysql # Populate database docker run --rm -h mifosx mifosx cat /tmp/mifospltaform-tenants-first-time-install.sql | docker exec -i mariadb mysql mifosplatform-tenants envsubst <${SOURCE_DIR}/schemapwd.sql | docker exec -i mariadb mysql mifosplatform-tenants # Configure Mifos X mkdir /srv/mifosx envsubst <${SOURCE_DIR}/srv/mifosx/context.xml >/srv/mifosx/context.xml # Create Mifos X service cp ${SOURCE_DIR}/etc/init.d/mifosx /etc/init.d/mifosx rc-update add mifosx boot service mifosx start # Update admin account echo `date` '- Waiting for database to be populated. This should take about a minute.' until docker logs mifosx 2>&1 | grep -q 'Migrating schema `mifostenant-default` to version 5000'; do sleep 1 done export MIFOSX_ADMIN_USER=admin export MIFOSX_ADMIN_EMAIL=admin@example.com export MIFOSX_ADMIN_PWD=$(head -c 12 /dev/urandom | base64 | tr -d "+") export MIFOSX_ADMIN_HASH=$(echo -n "${MIFOSX_ADMIN_PWD}{1}" | sha256sum | awk '{print $1}') envsubst <${SOURCE_DIR}/adminpwd.sql | docker exec -i mariadb mysql mifostenant-default # Create nginx app definition cp ${SOURCE_DIR}/etc/nginx/conf.d/mifosx.conf /etc/nginx/conf.d/mifosx.conf service nginx reload # Add portal application definition portal-app-manager mifosx "https://{host}:8412/community-app/" "${MIFOSX_ADMIN_USER}" "${MIFOSX_ADMIN_PWD}" portal-app-manager mifosx-mobile