2023-07-01 12:26:43 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
2025-12-15 14:20:24 +00:00
|
|
|
set -eu
|
2025-12-15 14:09:46 +00:00
|
|
|
|
2025-12-15 14:20:24 +00:00
|
|
|
: "${MAX_GEODATA_DIR_WAIT:=30}"
|
|
|
|
|
: "${WAIT_INTERVAL:=10}"
|
|
|
|
|
: "${GEODATA_DIR:?GEODATA_DIR is required}"
|
2025-12-15 14:09:46 +00:00
|
|
|
|
2025-11-24 23:10:02 +00:00
|
|
|
FINISH_FILE="$GEODATA_DIR/cron-job-finished.txt"
|
2025-12-03 17:33:43 +00:00
|
|
|
ELAPSED=0
|
|
|
|
|
|
2025-12-15 12:30:20 +00:00
|
|
|
while [ ! -f "$FINISH_FILE" ] && [ "$ELAPSED" -lt "$MAX_GEODATA_DIR_WAIT" ]; do
|
|
|
|
|
echo "Waiting for geodata initialization... ($ELAPSED/$MAX_GEODATA_DIR_WAIT seconds)"
|
2025-12-15 14:20:24 +00:00
|
|
|
sleep $WAIT_INTERVAL
|
|
|
|
|
ELAPSED=$((ELAPSED + WAIT_INTERVAL))
|
2025-11-24 23:10:02 +00:00
|
|
|
done
|
|
|
|
|
|
2025-12-03 17:33:43 +00:00
|
|
|
if [ ! -f "$FINISH_FILE" ]; then
|
2025-12-15 12:30:20 +00:00
|
|
|
echo "ERROR: Geodata initialization timed out after $MAX_GEODATA_DIR_WAIT seconds"
|
2025-12-03 17:33:43 +00:00
|
|
|
echo "Container startup aborted."
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
2023-07-01 12:26:43 +00:00
|
|
|
# Start fail2ban
|
2025-11-23 14:16:16 +00:00
|
|
|
[ "$XUI_ENABLE_FAIL2BAN" = "true" ] && fail2ban-client -x start
|
2023-07-01 12:26:43 +00:00
|
|
|
|
|
|
|
|
# Run x-ui
|
|
|
|
|
exec /app/x-ui
|