1 Commits

Author SHA1 Message Date
f371768681 #v1.3 - versão 1.3 da tela 2026-04-22 15:45:46 -03:00
4 changed files with 132 additions and 15 deletions

View File

@@ -5,7 +5,7 @@ ENV_FILE = .env.$(ENV)
PROJECT_NAME = attendancesystem-$(ENV) PROJECT_NAME = attendancesystem-$(ENV)
NETWORK_NAME = attendancesystem-network NETWORK_NAME = attendancesystem-network
.PHONY: app install update reset-network nuke nuke-project .PHONY: infra app install update reset-network nuke nuke-project
# =============================== # ===============================
# 🧹 Reset Network # 🧹 Reset Network
@@ -14,6 +14,25 @@ reset-network:
@echo "🧹 Removendo rede antiga (se existir)..." @echo "🧹 Removendo rede antiga (se existir)..."
-docker network rm $(NETWORK_NAME) 2>/dev/null || true -docker network rm $(NETWORK_NAME) 2>/dev/null || true
# ===============================
# 🏗 Subir apenas INFRA
# ===============================
infra: reset-network
@echo "📥 Baixando imagens de INFRA ($(PROJECT_NAME))..."
docker compose \
--project-name $(PROJECT_NAME) \
--env-file $(ENV_FILE) \
--profile infra \
-f $(COMPOSE_FILE) \
pull
@echo "🚀 Subindo apenas INFRA ($(PROJECT_NAME))..."
docker compose \
--project-name $(PROJECT_NAME) \
--env-file $(ENV_FILE) \
--profile infra \
-f $(COMPOSE_FILE) \
up -d --pull never
# =============================== # ===============================
# 🧩 Subir apenas APP # 🧩 Subir apenas APP
# =============================== # ===============================
@@ -41,6 +60,7 @@ install:
docker compose \ docker compose \
--project-name $(PROJECT_NAME) \ --project-name $(PROJECT_NAME) \
--env-file $(ENV_FILE) \ --env-file $(ENV_FILE) \
--profile infra \
--profile app \ --profile app \
-f $(COMPOSE_FILE) \ -f $(COMPOSE_FILE) \
pull pull
@@ -48,6 +68,7 @@ install:
docker compose \ docker compose \
--project-name $(PROJECT_NAME) \ --project-name $(PROJECT_NAME) \
--env-file $(ENV_FILE) \ --env-file $(ENV_FILE) \
--profile infra \
--profile app \ --profile app \
-f $(COMPOSE_FILE) \ -f $(COMPOSE_FILE) \
up -d --pull never up -d --pull never
@@ -90,6 +111,7 @@ nuke-project:
docker compose \ docker compose \
--project-name $(PROJECT_NAME) \ --project-name $(PROJECT_NAME) \
--env-file $(ENV_FILE) \ --env-file $(ENV_FILE) \
--profile infra \
--profile app \ --profile app \
-f $(COMPOSE_FILE) \ -f $(COMPOSE_FILE) \
down --volumes --remove-orphans down --volumes --remove-orphans
@@ -98,3 +120,4 @@ nuke-project:
- docker images --format '{{.Repository}}:{{.Tag}}' | grep '^seventhltda/' | xargs -r docker rmi -f 2>/dev/null || true - docker images --format '{{.Repository}}:{{.Tag}}' | grep '^seventhltda/' | xargs -r docker rmi -f 2>/dev/null || true
@echo "✅ Projeto $(PROJECT_NAME) limpo (containers, volumes, rede e imagens)." @echo "✅ Projeto $(PROJECT_NAME) limpo (containers, volumes, rede e imagens)."
@echo " Imagens de infraestrutura preservadas."

View File

@@ -7,15 +7,15 @@
}, },
"urlLgpd": "https://lgpd.seventh.com.br/feedback?product=situator", "urlLgpd": "https://lgpd.seventh.com.br/feedback?product=situator",
"modules": { "modules": {
"suite": "", "suite": "${FRONTEND_SUITE_URL}",
"attendance": "${FRONTEND_ATTENDANCE_URL}", "attendance": "${FRONTEND_ATTENDANCE_URL}",
"account": "", "account": "${FRONTEND_ACCOUNT_URL}",
"people": "" "people": "${FRONTEND_PEOPLE_URL}"
}, },
"api": { "api": {
"suite": "", "suite": "${BACKEND_SUITE_API_URL}",
"people": "", "people": "${BACKEND_PEOPLE_API_URL}",
"account": "", "account": "${BACKEND_ACCOUNT_API_URL}",
"attendance": "${BACKEND_ATTENDANCE_API_URL}" "attendance": "${BACKEND_ATTENDANCE_API_URL}"
} }
} }

View File

@@ -1,6 +1,38 @@
services: services:
# ================= INFRA =================
mongodb:
image: mongo:${IMAGEM_LATEST}
profiles: ["infra"]
ports:
- "${MONGO_PORT}:27017"
volumes:
- mongodb_data:/data/db
networks:
- app-network
healthcheck:
test: echo 'db.runCommand("ping").ok' | mongosh localhost:27017/test --quiet
interval: 10s
timeout: 5s
retries: 5
# ================= BACKEND ================= # ================= BACKEND =================
suite-api:
image: ${DOCKER_REPO}/suite-api:${IMAGEM_UNSTABLE_LATEST}
profiles: ["app"]
ports:
- "${BACKEND_SUITE_API_INTERNAL_PORT}:${BACKEND_SUITE_API_INTERNAL_PORT}"
environment:
- ASPNETCORE_ENVIRONMENT=${ASPNETCORE_ENVIRONMENT}
- MONGODB_CONNECTION_STRING=${MONGODB_CONNECTION_STRING}
- MONGODB_DATABASE=${MONGODB_DATABASE}
- SYSTEM_BASE_CONN=${SYSTEM_BASE_CONN}
- FRONTEND_CONN=${INTERNAL_HOST}:${FRONTEND_SUITE_APP_INTERNAL_PORT}
- KEEPALIVE_ATTENDANCE_SYSTEM_BACKEND_HOST=${KEEPALIVE_ATTENDANCE_SYSTEM_BACKEND_HOST}
- KEEPALIVE_ATTENDANCE_SYSTEM_FRONTEND_HOST=${KEEPALIVE_ATTENDANCE_SYSTEM_FRONTEND_HOST}
networks:
- app-network
attendancesystem-api: attendancesystem-api:
image: ${DOCKER_REPO}/backend-attendance-system-api:${IMAGEM_RELEASE_1_3} image: ${DOCKER_REPO}/backend-attendance-system-api:${IMAGEM_RELEASE_1_3}
profiles: ["app"] profiles: ["app"]
@@ -59,4 +91,5 @@ networks:
name: attendancesystem-network name: attendancesystem-network
volumes: volumes:
mongodb_data:
config-volume: config-volume:

View File

@@ -4,7 +4,7 @@
# 🚀 Instalador - AttendanceSystem # 🚀 Instalador - AttendanceSystem
# Uso: # Uso:
# bash <(curl -fsSL \ # bash <(curl -fsSL \
# "https://git.seventh.com.br/seventh.p7/attendance-system.install/raw/branch/exposec/install.sh") # "https://git.seventh.com.br/seventh.p7/attendance-system.install/raw/branch/main/install.sh")
# ============================================================== # ==============================================================
# ── Redireciona stdin para o terminal quando rodado via curl | bash ── # ── Redireciona stdin para o terminal quando rodado via curl | bash ──
@@ -28,7 +28,7 @@ NC='\033[0m'
# ─── Repositório Git ────────────────────────────────────────── # ─── Repositório Git ──────────────────────────────────────────
INSTALL_DIR="attendancesystem" INSTALL_DIR="attendancesystem"
BRANCH="${BRANCH:-exposec}" BRANCH="${BRANCH:-main}"
ENV_FILE="" ENV_FILE=""
GIT_REPO="https://git.seventh.com.br/seventh.p7/attendance-system.install.git" GIT_REPO="https://git.seventh.com.br/seventh.p7/attendance-system.install.git"
@@ -221,16 +221,33 @@ collect_system_base() {
collect_internal_ports() { collect_internal_ports() {
print_section "3. Portas Internas (rede local)" print_section "3. Portas Internas (rede local)"
ask BACKEND_SUITE_API_INTERNAL_PORT "Backend Suite API" "${BACKEND_SUITE_API_INTERNAL_PORT:-10101}"
ask BACKEND_PEOPLE_API_INTERNAL_PORT "Backend People API" "${BACKEND_PEOPLE_API_INTERNAL_PORT:-10100}"
ask BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT "Backend AttendanceSystem API" "${BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT:-10102}" ask BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT "Backend AttendanceSystem API" "${BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT:-10102}"
ask BACKEND_ACCOUNT_API_INTERNAL_PORT "Backend Account API" "${BACKEND_ACCOUNT_API_INTERNAL_PORT:-10103}"
ask FRONTEND_SUITE_APP_INTERNAL_PORT "Frontend Suite" "${FRONTEND_SUITE_APP_INTERNAL_PORT:-4200}"
ask FRONTEND_PEOPLE_APP_INTERNAL_PORT "Frontend People" "${FRONTEND_PEOPLE_APP_INTERNAL_PORT:-4201}"
ask FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT "Frontend AttendanceSystem" "${FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT:-4202}" ask FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT "Frontend AttendanceSystem" "${FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT:-4202}"
ask FRONTEND_ACCOUNT_APP_INTERNAL_PORT "Frontend Account" "${FRONTEND_ACCOUNT_APP_INTERNAL_PORT:-4203}"
} }
collect_external_ports() { collect_external_ports() {
print_section "4. Portas Externas (NAT/acesso remoto)" print_section "4. Portas Externas (NAT/acesso remoto)"
echo -e " ${DIM}Pressione ENTER para usar a mesma porta interna.${NC}\n" echo -e " ${DIM}Pressione ENTER para usar a mesma porta interna.${NC}\n"
ask BACKEND_SUITE_API_EXTERNAL_PORT "Backend Suite API" "${BACKEND_SUITE_API_EXTERNAL_PORT:-$BACKEND_SUITE_API_INTERNAL_PORT}"
ask BACKEND_PEOPLE_API_EXTERNAL_PORT "Backend People API" "${BACKEND_PEOPLE_API_EXTERNAL_PORT:-$BACKEND_PEOPLE_API_INTERNAL_PORT}"
ask BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT "Backend AttendanceSystem API" "${BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT:-$BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT}" ask BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT "Backend AttendanceSystem API" "${BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT:-$BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT}"
ask BACKEND_ACCOUNT_API_EXTERNAL_PORT "Backend Account API" "${BACKEND_ACCOUNT_API_EXTERNAL_PORT:-$BACKEND_ACCOUNT_API_INTERNAL_PORT}"
ask FRONTEND_SUITE_APP_EXTERNAL_PORT "Frontend Suite" "${FRONTEND_SUITE_APP_EXTERNAL_PORT:-$FRONTEND_SUITE_APP_INTERNAL_PORT}"
ask FRONTEND_PEOPLE_APP_EXTERNAL_PORT "Frontend People" "${FRONTEND_PEOPLE_APP_EXTERNAL_PORT:-$FRONTEND_PEOPLE_APP_INTERNAL_PORT}"
ask FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT "Frontend AttendanceSystem" "${FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT:-$FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT}" ask FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT "Frontend AttendanceSystem" "${FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT:-$FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT}"
ask FRONTEND_ACCOUNT_APP_EXTERNAL_PORT "Frontend Account" "${FRONTEND_ACCOUNT_APP_EXTERNAL_PORT:-$FRONTEND_ACCOUNT_APP_INTERNAL_PORT}"
}
collect_database() {
print_section "5. Banco de Dados"
ask MONGO_PORT "MongoDB (porta interna)" "${MONGO_PORT:-27017}"
} }
# ══════════════════════════════════════════════════════════════ # ══════════════════════════════════════════════════════════════
@@ -252,10 +269,18 @@ collect_config() {
else else
collect_internal_ports collect_internal_ports
# Copia internas → externas automaticamente # Copia internas → externas automaticamente
BACKEND_SUITE_API_EXTERNAL_PORT="$BACKEND_SUITE_API_INTERNAL_PORT"
BACKEND_PEOPLE_API_EXTERNAL_PORT="$BACKEND_PEOPLE_API_INTERNAL_PORT"
BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT="$BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT" BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT="$BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT"
BACKEND_ACCOUNT_API_EXTERNAL_PORT="$BACKEND_ACCOUNT_API_INTERNAL_PORT"
FRONTEND_SUITE_APP_EXTERNAL_PORT="$FRONTEND_SUITE_APP_INTERNAL_PORT"
FRONTEND_PEOPLE_APP_EXTERNAL_PORT="$FRONTEND_PEOPLE_APP_INTERNAL_PORT"
FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT="$FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT" FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT="$FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT"
FRONTEND_ACCOUNT_APP_EXTERNAL_PORT="$FRONTEND_ACCOUNT_APP_INTERNAL_PORT"
print_ok "Portas externas definidas iguais às internas." print_ok "Portas externas definidas iguais às internas."
fi fi
collect_database
} }
# ══════════════════════════════════════════════════════════════ # ══════════════════════════════════════════════════════════════
@@ -278,12 +303,15 @@ show_summary() {
echo -e " Porta : ${BOLD}${SYSTEM_BASE_PORT}${NC}" echo -e " Porta : ${BOLD}${SYSTEM_BASE_PORT}${NC}"
echo "" echo ""
echo -e " ${BOLD}[3] Portas Internas${NC}" echo -e " ${BOLD}[3] Portas Internas${NC}"
echo -e " Backend Attendance : ${BOLD}${BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT}${NC}" echo -e " Backend Suite/People/Attendance/Account : ${BOLD}${BACKEND_SUITE_API_INTERNAL_PORT}${NC} / ${BOLD}${BACKEND_PEOPLE_API_INTERNAL_PORT}${NC} / ${BOLD}${BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT}${NC} / ${BOLD}${BACKEND_ACCOUNT_API_INTERNAL_PORT}${NC}"
echo -e " Frontend Attendance : ${BOLD}${FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT}${NC}" echo -e " Frontend Suite/People/Attendance/Account : ${BOLD}${FRONTEND_SUITE_APP_INTERNAL_PORT}${NC} / ${BOLD}${FRONTEND_PEOPLE_APP_INTERNAL_PORT}${NC} / ${BOLD}${FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT}${NC} / ${BOLD}${FRONTEND_ACCOUNT_APP_INTERNAL_PORT}${NC}"
echo "" echo ""
echo -e " ${BOLD}[4] Portas Externas${NC}" echo -e " ${BOLD}[4] Portas Externas${NC}"
echo -e " Backend Attendance : ${BOLD}${BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT}${NC}" echo -e " Backend Suite/People/Attendance/Account : ${BOLD}${BACKEND_SUITE_API_EXTERNAL_PORT}${NC} / ${BOLD}${BACKEND_PEOPLE_API_EXTERNAL_PORT}${NC} / ${BOLD}${BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT}${NC} / ${BOLD}${BACKEND_ACCOUNT_API_EXTERNAL_PORT}${NC}"
echo -e " Frontend Attendance : ${BOLD}${FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT}${NC}" echo -e " Frontend Suite/People/Attendance/Account : ${BOLD}${FRONTEND_SUITE_APP_EXTERNAL_PORT}${NC} / ${BOLD}${FRONTEND_PEOPLE_APP_EXTERNAL_PORT}${NC} / ${BOLD}${FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT}${NC} / ${BOLD}${FRONTEND_ACCOUNT_APP_EXTERNAL_PORT}${NC}"
echo ""
echo -e " ${BOLD}[5] Banco de Dados${NC}"
echo -e " MongoDB : ${BOLD}${MONGO_PORT}${NC}"
echo "" echo ""
echo -e " ──────────────────────────────────────────────────────────────" echo -e " ──────────────────────────────────────────────────────────────"
echo -e " ${GREEN}${BOLD}[C]${NC} Confirmar e continuar ${RED}${BOLD}[X]${NC} Cancelar instalação" echo -e " ${GREEN}${BOLD}[C]${NC} Confirmar e continuar ${RED}${BOLD}[X]${NC} Cancelar instalação"
@@ -297,6 +325,7 @@ show_summary() {
2) collect_system_base ;; 2) collect_system_base ;;
3) collect_internal_ports ;; 3) collect_internal_ports ;;
4) collect_external_ports ;; 4) collect_external_ports ;;
5) collect_database ;;
C) break ;; C) break ;;
X) X)
echo "" echo ""
@@ -304,7 +333,7 @@ show_summary() {
exit 0 exit 0
;; ;;
*) *)
print_warn "Opção inválida. Digite 1-4, C ou X." print_warn "Opção inválida. Digite 1-5, C ou X."
;; ;;
esac esac
done done
@@ -327,9 +356,20 @@ ASPNETCORE_ENVIRONMENT=Production
DOCKER_REPO=seventhltda DOCKER_REPO=seventhltda
IMAGEM_LATEST=latest IMAGEM_LATEST=latest
IMAGEM_UNSTABLE_LATEST=unstable-latest IMAGEM_UNSTABLE_LATEST=unstable-latest
IMAGEM_RELEASE_1_1=1.1
IMAGEM_RELEASE_1_2=1.2
IMAGEM_RELEASE_1_3=1.3 IMAGEM_RELEASE_1_3=1.3
IMAGEM_RELEASE_1_4=1.4
IMAGEM_RELEASE_1_5=1.5
IMAGEM_RELEASE_1_6=1.6
IMAGEM_RELEASE_1_7=1.7
NGINX_DEFAULT_PORT=80 NGINX_DEFAULT_PORT=80
# ── MongoDB ───────────────────────────────────────────────
MONGO_PORT=${MONGO_PORT}
MONGODB_CONNECTION_STRING=mongodb://mongodb:27017/suitedb
MONGODB_DATABASE=suitedb
# ── Sistema Base ────────────────────────────────────────── # ── Sistema Base ──────────────────────────────────────────
SYSTEM_BASE_CONN=${SYSTEM_BASE_CONN} SYSTEM_BASE_CONN=${SYSTEM_BASE_CONN}
SYSTEM_BASE_HOST=${SYSTEM_BASE_HOST} SYSTEM_BASE_HOST=${SYSTEM_BASE_HOST}
@@ -340,16 +380,34 @@ INTERNAL_HOST=${INTERNAL_HOST}
EXTERNAL_HOST=${EXTERNAL_HOST} EXTERNAL_HOST=${EXTERNAL_HOST}
# ── Backend ─────────────────────────────────────────────── # ── Backend ───────────────────────────────────────────────
BACKEND_SUITE_API_INTERNAL_PORT=${BACKEND_SUITE_API_INTERNAL_PORT}
BACKEND_SUITE_API_EXTERNAL_PORT=${BACKEND_SUITE_API_EXTERNAL_PORT}
BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT=${BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT} BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT=${BACKEND_ATTENDANCESYSTEM_API_INTERNAL_PORT}
BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT=${BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT} BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT=${BACKEND_ATTENDANCESYSTEM_API_EXTERNAL_PORT}
BACKEND_PEOPLE_API_INTERNAL_PORT=${BACKEND_PEOPLE_API_INTERNAL_PORT}
BACKEND_PEOPLE_API_EXTERNAL_PORT=${BACKEND_PEOPLE_API_EXTERNAL_PORT}
BACKEND_ACCOUNT_API_INTERNAL_PORT=${BACKEND_ACCOUNT_API_INTERNAL_PORT}
BACKEND_ACCOUNT_API_EXTERNAL_PORT=${BACKEND_ACCOUNT_API_EXTERNAL_PORT}
BACKEND_ATTENDANCESYSTEM_API_APPLICATIONNAME=AttendanceSystem BACKEND_ATTENDANCESYSTEM_API_APPLICATIONNAME=AttendanceSystem
BACKEND_ATTENDANCESYSTEM_API_NAME=attendancesystem-api BACKEND_ATTENDANCESYSTEM_API_NAME=attendancesystem-api
# ── Frontend ────────────────────────────────────────────── # ── Frontend ──────────────────────────────────────────────
FRONTEND_SUITE_APP_INTERNAL_PORT=${FRONTEND_SUITE_APP_INTERNAL_PORT}
FRONTEND_SUITE_APP_EXTERNAL_PORT=${FRONTEND_SUITE_APP_EXTERNAL_PORT}
FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT=${FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT} FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT=${FRONTEND_ATTENDANCESYSTEM_APP_INTERNAL_PORT}
FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT=${FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT} FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT=${FRONTEND_ATTENDANCESYSTEM_APP_EXTERNAL_PORT}
FRONTEND_PEOPLE_APP_INTERNAL_PORT=${FRONTEND_PEOPLE_APP_INTERNAL_PORT}
FRONTEND_PEOPLE_APP_EXTERNAL_PORT=${FRONTEND_PEOPLE_APP_EXTERNAL_PORT}
FRONTEND_ACCOUNT_APP_INTERNAL_PORT=${FRONTEND_ACCOUNT_APP_INTERNAL_PORT}
FRONTEND_ACCOUNT_APP_EXTERNAL_PORT=${FRONTEND_ACCOUNT_APP_EXTERNAL_PORT}
# ── Keepalive ───────────────────────────────────────────── # ── Keepalive ─────────────────────────────────────────────
KEEPALIVE_ATTENDANCE_SYSTEM_BACKEND_HOST=${KEEPALIVE_BACKEND} KEEPALIVE_ATTENDANCE_SYSTEM_BACKEND_HOST=${KEEPALIVE_BACKEND}
KEEPALIVE_ATTENDANCE_SYSTEM_FRONTEND_HOST=${KEEPALIVE_FRONTEND} KEEPALIVE_ATTENDANCE_SYSTEM_FRONTEND_HOST=${KEEPALIVE_FRONTEND}
@@ -372,12 +430,15 @@ start_environment() {
echo -e " ║ ✅ Instalação concluída com sucesso! ║" echo -e " ║ ✅ Instalação concluída com sucesso! ║"
echo -e " ╚══════════════════════════════════════════════╝${NC}" echo -e " ╚══════════════════════════════════════════════╝${NC}"
echo "" echo ""
echo -e " Menu do usuário: Monitoramento V1" echo -e " Acesse o sistema em:"
echo -e " ${CYAN}${BOLD} ${SYSTEM_BASE_CONN}${NC}"
echo -e " Menu do usuário: Monitoramento (beta)"
echo "" echo ""
echo -e " Comandos úteis (dentro da pasta ${BOLD}${INSTALL_DIR}${NC}):" echo -e " Comandos úteis (dentro da pasta ${BOLD}${INSTALL_DIR}${NC}):"
echo -e " ${BOLD}make install${NC} → sobe o projeto" echo -e " ${BOLD}make install${NC} → sobe o projeto"
echo -e " ${BOLD}make update${NC} → atualiza o projeto" echo -e " ${BOLD}make update${NC} → atualiza o projeto"
echo -e " ${BOLD}make app${NC} → sobe apenas a aplicação" echo -e " ${BOLD}make app${NC} → sobe apenas a aplicação"
echo -e " ${BOLD}make infra${NC} → sobe apenas a infra (MongoDB)"
echo -e " ${BOLD}make nuke-project${NC} → limpa o projeto" echo -e " ${BOLD}make nuke-project${NC} → limpa o projeto"
echo -e " ${BOLD}make nuke${NC} → limpa tudo (cuidado!)" echo -e " ${BOLD}make nuke${NC} → limpa tudo (cuidado!)"
echo "" echo ""