view prod/install-itcm-app.sh @ 539:5d5525414c8d production tip

update exec-all-projects-docker.sh to search for ./env/*-shared.properties in place of ./env/ssdt-*-shared.properties. ESS doesn't follow the same pattern for property file names.
author Marc Davis <marc.davis@mcoecn.org>
date Mon, 13 May 2024 13:28:30 -0400
parents edf477197f1b
children
line wrap: on
line source
#!/bin/bash
#
# read required env variables
BASEDIR="$PWD"
source $BASEDIR/.env/itcm-shared.properties
source $BASEDIR/.env/itcm-app.properties
# docker login
echo "Attempting to login to $artifactUrl"
docker login $artifactUrl -u $artifactUser -p $artifactPassword
# docker pull db image
echo "Attempting to pull $artifactUrl/itcm-app:$appVersion"
docker pull $artifactUrl/itcm-app:$appVersion
#
# Builder docker run command based on settings in env files
echo "Building docker run command"
dockerRunCommand="docker run --name $entityId-itcm-app
  --restart=unless-stopped
  --network $entityId-itcm-net
  -e SPRING_DATASOURCE_URL=jdbc:postgresql://$entityId-itcm-db:5432/itcmdb
  -e SPRING_DATASOURCE_DRIVER_CLASS_NAME=org.postgresql.Driver
  -e SPRING_DATASOURCE_USERNAME=postgres
  -e SPRING_DATASOURCE_PASSWORD=$dbPassword
  -e SPRING_PROFILES_ACTIVE=prod 
  -e APPLICATION_ADMIN_PASSWORD=$adminPassword
  -e APPLICATION_ADMIN_RESET=$resetAdminPassword
  -e JAVA_OPTS=$java_opts"
#
if [ ! -z "$virtualHost" ]; then
    dockerRunCommand="$dockerRunCommand -e VIRTUAL_HOST=$virtualHost"
fi
#
if [ ! -z "$virtualPort" ]; then
    dockerRunCommand="$dockerRunCommand -e VIRTUAL_PORT=$virtualPort"
fi
#
if [ ! -z "$letsencryptHost" ]; then
    dockerRunCommand="$dockerRunCommand -e LETSENCRYPT_HOST=$letsencryptHost"
fi
#
if [ ! -z "$letsencryptEmail" ]; then
    dockerRunCommand="$dockerRunCommand -e LETSENCRYPT_EMAIL=$letsencryptEmail"
fi
#
if [ ! -z "$hostPort" ]; then
    dockerRunCommand="$dockerRunCommand -p $hostPort"
fi
#
#
if [ ! -z "$duoEnabled" ]; then
    echo "Adding Duo Configuration"
    dockerRunCommand="$dockerRunCommand 
        -e DUO_ENABLED=$duoEnabled
        -e DUO_CLIENT_ID=$duoClientId
        -e DUO_CLIENT_SECRET=$duoClientSecret
        -e DUO_API_HOSTNAME=$duoApiHostname
        -e DUO_FAIL_OPEN=$duoFailOpen
        -e DUO_ITCM_HOST=$duoItcmHost
        -e DUO_ITCM_PORT=$duoItcmPort
        -e DUO_ITCM_CONTEXT=$duoItcmContext
        -e DUO_MINUTES_UNTIL_EXPIRATION=$duoMinutesUntilExpiration"
fi
#
#
if [ ! -z "$ads_config1_enabled" ]; then
    echo "Add Window Active Director Configuration 1"
    dockerRunCommand="$dockerRunCommand 
    -e SSDT_ADS_CONFIG1_ENABLED=$ads_config1_enabled 
    -e SSDT_ADS_CONFIG1_DOMAIN=$ads_config1_domain 
    -e SSDT_ADS_CONFIG1_LDAP_URL=$ads_config1_ldap_url 
    -e SSDT_ADS_CONFIG1_ROOT_DN=$ads_config1_root_dn 
    -e SSDT_ADS_CONFIG1_SEARCH_FILTER=$ads_config1_search_filter"
fi
#
#
if [ ! -z "$ads_config2_enabled" ]; then
    echo "Add Window Active Director Configuration 2"
    dockerRunCommand="$dockerRunCommand 
    -e SSDT_ADS_CONFIG2_ENABLED=$ads_config2_enabled 
    -e SSDT_ADS_CONFIG2_DOMAIN=$ads_config2_domain 
    -e SSDT_ADS_CONFIG2_LDAP_URL=$ads_config2_ldap_url 
    -e SSDT_ADS_CONFIG2_ROOT_DN=$ads_config2_root_dn 
    -e SSDT_ADS_CONFIG2_SEARCH_FILTER=$ads_config2_search_filter"
fi
#
#
if [ ! -z "$ads_config3_enabled" ]; then
    echo "Add Window Active Director Configuration 3"
    dockerRunCommand="$dockerRunCommand 
    -e SSDT_ADS_CONFIG3_ENABLED=$ads_config3_enabled 
    -e SSDT_ADS_CONFIG3_DOMAIN=$ads_config3_domain 
    -e SSDT_ADS_CONFIG3_LDAP_URL=$ads_config3_ldap_url 
    -e SSDT_ADS_CONFIG3_ROOT_DN=$ads_config3_root_dn 
    -e SSDT_ADS_CONFIG3_SEARCH_FILTER=$ads_config3_search_filter"
fi
#
#
dockerRunCommand="$dockerRunCommand -d $artifactUrl/itcm-app:$appVersion"
#
# Execute constructed docker run command to create $entityId-itcm-app container connected to db and docker network
echo "Executing docker run command"
$dockerRunCommand