 3e182978ad
			
		
	
	
		3e182978ad
		
			
		
	
	
	
	
		
			
			* Improve npmplus credential retrieval and messaging Enhanced the install script to attempt live log monitoring for credentials if not found initially, and updated the info message in npmplus.json to guide users to check docker logs if the credentials file is missing. * Update npmplus.json * Change updateable status to true in npmplus.json
		
			
				
	
	
		
			125 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| # Copyright (c) 2021-2025 community-scripts ORG
 | |
| # Author: MickLesk (CanbiZ)
 | |
| # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | |
| # Source: https://github.com/ZoeyVid/NPMplus
 | |
| 
 | |
| source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | |
| color
 | |
| verb_ip6
 | |
| catch_errors
 | |
| setting_up_container
 | |
| network_check
 | |
| update_os
 | |
| 
 | |
| msg_info "Installing Dependencies"
 | |
| $STD apk add \
 | |
|   tzdata \
 | |
|   gawk \
 | |
|   yq
 | |
| msg_ok "Installed Dependencies"
 | |
| 
 | |
| msg_info "Installing Docker & Compose"
 | |
| $STD apk add docker
 | |
| $STD rc-service docker start
 | |
| $STD rc-update add docker default
 | |
| 
 | |
| get_latest_release() {
 | |
|   curl -fsSL https://api.github.com/repos/$1/releases/latest | grep '"tag_name":' | cut -d'"' -f4
 | |
| }
 | |
| DOCKER_COMPOSE_LATEST_VERSION=$(get_latest_release "docker/compose")
 | |
| DOCKER_CONFIG=${DOCKER_CONFIG:-$HOME/.docker}
 | |
| mkdir -p $DOCKER_CONFIG/cli-plugins
 | |
| curl -fsSL https://github.com/docker/compose/releases/download/$DOCKER_COMPOSE_LATEST_VERSION/docker-compose-linux-x86_64 -o ~/.docker/cli-plugins/docker-compose
 | |
| chmod +x $DOCKER_CONFIG/cli-plugins/docker-compose
 | |
| msg_ok "Installed Docker & Compose"
 | |
| 
 | |
| msg_info "Fetching NPMplus"
 | |
| cd /opt
 | |
| curl -fsSL "https://raw.githubusercontent.com/ZoeyVid/NPMplus/refs/heads/develop/compose.yaml" -o compose.yaml
 | |
| msg_ok "Fetched NPMplus"
 | |
| 
 | |
| attempts=0
 | |
| while true; do
 | |
|   read -r -p "${TAB3}Enter your TZ Identifier (e.g., Europe/Berlin): " TZ_INPUT
 | |
|   if validate_tz "$TZ_INPUT"; then
 | |
|     break
 | |
|   fi
 | |
|   msg_error "Invalid timezone! Please enter a valid TZ identifier."
 | |
| 
 | |
|   attempts=$((attempts + 1))
 | |
|   if [[ "$attempts" -ge 3 ]]; then
 | |
|     msg_error "Maximum attempts reached. Exiting."
 | |
|     exit 1
 | |
|   fi
 | |
| done
 | |
| 
 | |
| read -r -p "${TAB3}Enter your ACME Email: " ACME_EMAIL_INPUT
 | |
| 
 | |
| yq -i "
 | |
|   .services.npmplus.environment |=
 | |
|     (map(select(. != \"TZ=*\" and . != \"ACME_EMAIL=*\")) +
 | |
|     [\"TZ=$TZ_INPUT\", \"ACME_EMAIL=$ACME_EMAIL_INPUT\"])
 | |
| " /opt/compose.yaml
 | |
| 
 | |
| msg_info "Building and Starting NPMplus (Patience)"
 | |
| $STD docker compose up -d
 | |
| CONTAINER_ID=""
 | |
| for i in {1..60}; do
 | |
|   CONTAINER_ID=$(docker ps --filter "name=npmplus" --format "{{.ID}}")
 | |
|   if [[ -n "$CONTAINER_ID" ]]; then
 | |
|     STATUS=$(docker inspect --format '{{.State.Health.Status}}' "$CONTAINER_ID" 2>/dev/null || echo "starting")
 | |
|     if [[ "$STATUS" == "healthy" ]]; then
 | |
|       msg_ok "NPMplus is running and healthy"
 | |
|       break
 | |
|     elif [[ "$STATUS" == "unhealthy" ]]; then
 | |
|       msg_error "NPMplus container is unhealthy! Check logs."
 | |
|       docker logs "$CONTAINER_ID"
 | |
|       exit 1
 | |
|     fi
 | |
|   fi
 | |
|   sleep 2
 | |
|   [[ $i -eq 60 ]] && msg_error "NPMplus container did not become healthy within 120s." && docker logs "$CONTAINER_ID" && exit 1
 | |
| done
 | |
| msg_ok "Builded and started NPMplus"
 | |
| 
 | |
| motd_ssh
 | |
| customize
 | |
| 
 | |
| msg_info "Retrieving Default Login (Patience)"
 | |
| PASSWORD_FOUND=0
 | |
| 
 | |
| for i in {1..60}; do
 | |
|   PASSWORD_LINE=$(
 | |
|     { awk '/Creating a new user:/{print; exit}' < <(docker logs "$CONTAINER_ID" 2>&1); } || true
 | |
|   )
 | |
| 
 | |
|   if [[ -n "${PASSWORD_LINE:-}" ]]; then
 | |
|     PASSWORD="${PASSWORD_LINE#*password: }"
 | |
|     printf 'username: admin@example.org\npassword: %s\n' "$PASSWORD" >/opt/.npm_pwd
 | |
|     msg_ok "Saved default login to /opt/.npm_pwd"
 | |
|     PASSWORD_FOUND=1
 | |
|     break
 | |
|   fi
 | |
|   sleep 2
 | |
| done
 | |
| if [[ $PASSWORD_FOUND -eq 0 ]]; then
 | |
|   PASSWORD_LINE=$(
 | |
|     timeout 30s bash -c '
 | |
|       docker logs -f --since=0s --tail=0 "$1" 2>&1 | awk "/Creating a new user:/{print; exit}"
 | |
|     ' _ "$CONTAINER_ID" || true
 | |
|   )
 | |
|   if [[ -n "${PASSWORD_LINE:-}" ]]; then
 | |
|     PASSWORD="${PASSWORD_LINE#*password: }"
 | |
|     printf 'username: admin@example.org\npassword: %s\n' "$PASSWORD" >/opt/.npm_pwd
 | |
|     msg_ok "Saved default login to /opt/.npm_pwd (live)"
 | |
|     PASSWORD_FOUND=1
 | |
|   fi
 | |
| fi
 | |
| 
 | |
| if [[ $PASSWORD_FOUND -eq 0 ]]; then
 | |
|   msg_error "Could not retrieve default login after 120s."
 | |
|   echo -e "\nYou can manually check the container logs with:\n  docker logs $CONTAINER_ID | grep 'Creating a new user:'\n"
 | |
| fi
 |