101 lines
4.1 KiB
Bash
Executable File
101 lines
4.1 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# Federated installation script
|
|
|
|
PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
|
. /federated/lib/functions.sh
|
|
trap cleanup `seq 0 15`
|
|
|
|
get_config() {
|
|
# FSTACKURL="http://137.184.95.3:8000"
|
|
# [ ! -d "/federated/lib" ] && mkdir -p /federated/lib
|
|
|
|
# Download each library file
|
|
# for i in checks network dns ldap mail; do
|
|
# if [ ! -f "/federated/lib/$i.sh" ]; then
|
|
# curl $FSTACKURL/$i.sh -o /federated/lib/$i.sh -s -f &> /dev/null
|
|
# [ $? -ne 0 ] && failcheck "Couldn't download $i.sh"
|
|
# fi
|
|
# done
|
|
|
|
. /federated/lib/network.sh
|
|
. /federated/lib/dns.sh
|
|
. /federated/lib/postgresql.sh
|
|
. /federated/lib/ldap.sh
|
|
. /federated/lib/mail.sh
|
|
. /federated/lib/collabora.sh
|
|
. /federated/lib/nextcloud.sh
|
|
. /federated/lib/matrix.sh
|
|
. /federated/lib/element.sh
|
|
. /federated/lib/jitsi.sh
|
|
. /federated/lib/listmonk.sh
|
|
. /federated/lib/vaultwarden.sh
|
|
. /federated/lib/panel.sh
|
|
. /federated/lib/proxy.sh
|
|
. /federated/lib/wireguard.sh
|
|
. /federated/lib/baserow.sh
|
|
. /federated/lib/calcom.sh
|
|
. /federated/lib/gitea.sh
|
|
. /federated/lib/caddy.sh
|
|
|
|
COUNTRIES=("AF" "AL" "DZ" "AS" "AD" "AO" "AI" "AQ" "AG" "AR" "AM" "AW" "AU" "AT" "AZ" "BS" "BH" "BD" "BB" "BY" "BE" "BZ" "BJ" "BM" "BT" "BO" "BO" "BA" "BW" "BV" "BR" "IO" "BN" "BN" "BG" "BF" "BI" "KH" "CM" "CA" "CV" "KY" "CF" "TD" "CL" "CN" "CX" "CC" "CO" "KM" "CG" "CD" "CK" "CR" "CI" "CI" "HR" "CU" "CY" "CZ" "DK" "DJ" "DM" "DO" "EC" "EG" "SV" "GQ" "ER" "EE" "ET" "FK" "FO" "FJ" "FI" "FR" "GF" "PF" "TF" "GA" "GM" "GE" "DE" "GH" "GI" "GR" "GL" "GD" "GP" "GU" "GT" "GG" "GN" "GW" "GY" "HT" "HM" "VA" "HN" "HK" "HU" "IS" "IN" "ID" "IR" "IQ" "IE" "IM" "IL" "IT" "JM" "JP" "JE" "JO" "KZ" "KE" "KI" "KP" "KR" "KR" "KW" "KG" "LA" "LV" "LB" "LS" "LR" "LY" "LY" "LI" "LT" "LU" "MO" "MK" "MG" "MW" "MY" "MV" "ML" "MT" "MH" "MQ" "MR" "MU" "YT" "MX" "FM" "MD" "MC" "MN" "ME" "MS" "MA" "MZ" "MM" "MM" "NA" "NR" "NP" "NL" "AN" "NC" "NZ" "NI" "NE" "NG" "NU" "NF" "MP" "NO" "OM" "PK" "PW" "PS" "PA" "PG" "PY" "PE" "PH" "PN" "PL" "PT" "PR" "QA" "RE" "RO" "RU" "RU" "RW" "SH" "KN" "LC" "PM" "VC" "VC" "VC" "WS" "SM" "ST" "SA" "SN" "RS" "SC" "SL" "SG" "SK" "SI" "SB" "SO" "ZA" "GS" "SS" "ES" "LK" "SD" "SR" "SJ" "SZ" "SE" "CH" "SY" "TW" "TW" "TJ" "TZ" "TH" "TL" "TG" "TK" "TO" "TT" "TN" "TR" "TM" "TC" "TV" "UG" "UA" "AE" "GB" "US" "UM" "UY" "UZ" "VU" "VE" "VE" "VN" "VN" "VG" "VI" "WF" "EH" "YE" "ZM" "ZW")
|
|
|
|
if [ -f "/federated/bin/.env" ]; then
|
|
. /federated/bin/.env
|
|
[ -z "$DOMAIN" ] && failcheck "/federated/bin/.env doesn't include DOMAIN"
|
|
[ -z "$COMPANY" ] && failcheck "/federated/bin/.env doesn't include COMPANY"
|
|
[ -z "$COUNTRY" ] && failcheck "/federated/bin/.env doesn't include COUNTRY"
|
|
[ -z "$ADMINPASS" ] && failcheck "/federated/bin/.env doesn't include ADMINPASS"
|
|
exit 2;
|
|
else
|
|
echo -ne "\nFederated Stack install script\n\n"
|
|
read -p '* Enter domain name (domain.com): ' DOMAIN
|
|
read -p '* Enter company name (Domain Company): ' COMPANY
|
|
read -p '* Enter country code: ' COUNTRY
|
|
while [ true ]; do
|
|
if printf '%s\0' "${COUNTRIES[@]}" | grep -Fxqz -- "$COUNTRY"; then
|
|
break
|
|
else
|
|
read -p "* Invalid, choose a country code (US, GB, HK, etc): " COUNTRY
|
|
fi
|
|
done
|
|
read -sp '* Enter admin password to use for initial login: ' ADMINPASS
|
|
[ -z "$DOMAIN" ] && failcheck "Must enter a domain name"
|
|
[ -z "$COMPANY" ] && failcheck "Must enter a company name"
|
|
[ -z "$ADMINPASS" ] && failcheck "Must enter a admin password"
|
|
fi
|
|
}
|
|
|
|
while getopts d OPTION; do
|
|
case "$OPTION" in
|
|
d) DEBUG=ON;;
|
|
esac
|
|
done
|
|
|
|
# Download lib scripts and take in setup variables
|
|
get_config
|
|
|
|
echo -ne "\n\nStarting Federated install for $DOMAIN\n"
|
|
|
|
# Check that we have docker installed. Check that
|
|
# we have all ports available and not in use
|
|
check_docker
|
|
check_os
|
|
check_memory
|
|
check_ports
|
|
|
|
# Configure docker private network
|
|
config_network
|
|
|
|
# Configure and start each federated service
|
|
for i in dns postgresql ldap mail collabora proxy nextcloud matrix element listmonk vaultwarden panel wireguard jitsi baserow calcom gitea caddy; do
|
|
config_$i
|
|
start_$i
|
|
done
|
|
|
|
add_cron
|
|
|
|
# Print out federated environment details
|
|
print_details
|
|
echo -ne "\n\n"
|