123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- #!/usr/bin/env bash
- set -o errexit
- set -o nounset
- set -o pipefail
- if [[ "${TRACE-0}" == "1" ]]; then
- set -o xtrace
- fi
- source "${BASH_SOURCE%/*}/common.sh"
- ### --------------------------------
- ### General variables
- ### --------------------------------
- ROOT_FOLDER="${PWD}"
- STATE_FOLDER="${ROOT_FOLDER}/state"
- SED_ROOT_FOLDER="$(echo "$ROOT_FOLDER" | sed 's/\//\\\//g')"
- NGINX_PORT=80
- NGINX_PORT_SSL=443
- DOMAIN=tipi.localhost
- DNS_IP="9.9.9.9" # Default to Quad9 DNS
- ARCHITECTURE="$(uname -m)"
- TZ="UTC"
- JWT_SECRET=secret
- POSTGRES_PASSWORD=postgres
- TIPI_VERSION=$(get_json_field "${ROOT_FOLDER}/package.json" version)
- INTERNAL_IP=localhost
- storage_path="${ROOT_FOLDER}"
- STORAGE_PATH_ESCAPED="$(echo "${storage_path}" | sed 's/\//\\\//g')"
- if [[ "$ARCHITECTURE" == "aarch64" ]]; then
- ARCHITECTURE="arm64"
- elif [[ "$ARCHITECTURE" == "armv7l" ]]; then
- ARCHITECTURE="arm"
- elif [[ "$ARCHITECTURE" == "x86_64" ]]; then
- ARCHITECTURE="amd64"
- fi
- # If none of the above conditions are met, the architecture is not supported
- if [[ "$ARCHITECTURE" != "arm64" ]] && [[ "$ARCHITECTURE" != "arm" ]] && [[ "$ARCHITECTURE" != "amd64" ]]; then
- echo "Architecture not supported!"
- exit 1
- fi
- ### --------------------------------
- ### Apps repository configuration
- ### --------------------------------
- apps_repository="https://github.com/meienberger/runtipi-appstore"
- APPS_REPOSITORY_ESCAPED="$(echo ${apps_repository} | sed 's/\//\\\//g')"
- REPO_ID="$("${ROOT_FOLDER}"/scripts/git.sh get_hash ${apps_repository})"
- # Override configs with settings.json
- if [[ -f "${STATE_FOLDER}/settings.json" ]]; then
- if [[ "$(get_json_field "${STATE_FOLDER}/settings.json" appsRepoUrl)" != "null" ]]; then
- apps_repository=$(get_json_field "${STATE_FOLDER}/settings.json" appsRepoUrl)
- APPS_REPOSITORY_ESCAPED="$(echo "${apps_repository}" | sed 's/\//\\\//g')"
- REPO_ID="$("${ROOT_FOLDER}"/scripts/git.sh get_hash "${apps_repository}")"
- fi
- fi
- ### --------------------------------
- ### Watcher and system-info
- ### --------------------------------
- if [[ ! -f "${ROOT_FOLDER}/state/events" ]]; then
- touch "${ROOT_FOLDER}/state/events"
- fi
- if [[ ! -f "${ROOT_FOLDER}/state/system-info.json" ]]; then
- echo "{}" >"${ROOT_FOLDER}/state/system-info.json"
- fi
- chmod -R a+rwx "${ROOT_FOLDER}/state/events"
- chmod -R a+rwx "${ROOT_FOLDER}/state/system-info.json"
- kill_watcher
- "${ROOT_FOLDER}/scripts/watcher.sh" &
- ### --------------------------------
- ### env file generation
- ### --------------------------------
- ENV_FILE=$(mktemp)
- [[ -f "${ROOT_FOLDER}/.env" ]] && rm -f "${ROOT_FOLDER}/.env"
- [[ -f "$ROOT_FOLDER/templates/env-sample" ]] && cp "$ROOT_FOLDER/templates/env-sample" "$ENV_FILE"
- OS=$(uname)
- sed_args=(-i)
- # If os is macos, use gnu sed
- if [[ "$OS" == "Darwin" ]]; then
- echo "Using gnu sed"
- sed_args=(-i '')
- fi
- for template in ${ENV_FILE}; do
- sed "${sed_args[@]}" "s/<dns_ip>/${DNS_IP}/g" "${template}"
- sed "${sed_args[@]}" "s/<internal_ip>/${INTERNAL_IP}/g" "${template}"
- sed "${sed_args[@]}" "s/<tz>/${TZ}/g" "${template}"
- sed "${sed_args[@]}" "s/<jwt_secret>/${JWT_SECRET}/g" "${template}"
- sed "${sed_args[@]}" "s/<root_folder>/${SED_ROOT_FOLDER}/g" "${template}"
- sed "${sed_args[@]}" "s/<tipi_version>/${TIPI_VERSION}/g" "${template}"
- sed "${sed_args[@]}" "s/<architecture>/${ARCHITECTURE}/g" "${template}"
- sed "${sed_args[@]}" "s/<nginx_port>/${NGINX_PORT}/g" "${template}"
- sed "${sed_args[@]}" "s/<nginx_port_ssl>/${NGINX_PORT_SSL}/g" "${template}"
- sed "${sed_args[@]}" "s/<postgres_password>/${POSTGRES_PASSWORD}/g" "${template}"
- sed "${sed_args[@]}" "s/<apps_repo_id>/${REPO_ID}/g" "${template}"
- sed "${sed_args[@]}" "s/<apps_repo_url>/${APPS_REPOSITORY_ESCAPED}/g" "${template}"
- sed "${sed_args[@]}" "s/<domain>/${DOMAIN}/g" "${template}"
- sed "${sed_args[@]}" "s/<storage_path>/${STORAGE_PATH_ESCAPED}/g" "${template}"
- done
- mv -f "$ENV_FILE" "$ROOT_FOLDER/.env.dev"
- cp "$ROOT_FOLDER/.env.dev" "$ROOT_FOLDER/.env"
- chmod a+rwx "$ROOT_FOLDER/.env"
- chmod a+rwx "${ROOT_FOLDER}/.env.dev"
- ### --------------------------------
- ### Start the project
- ### --------------------------------
- docker compose -f docker-compose.dev.yml --env-file "${ROOT_FOLDER}/.env.dev" up --build
|