- Disable set -e during permission testing - Add explicit error checks with clear messages - Verify token is set before starting - Add directory listings if dist/index.js missing - More verbose logging throughout - Check return codes explicitly
125 lines
3.3 KiB
Bash
Executable File
125 lines
3.3 KiB
Bash
Executable File
#!/bin/sh
|
|
# Render startup script - creates config and starts gateway
|
|
# Don't use set -e initially - we'll enable it after setup
|
|
|
|
echo "=== Render startup script ==="
|
|
echo "HOME=${HOME:-not set}"
|
|
echo "CLAWDBOT_STATE_DIR=${CLAWDBOT_STATE_DIR:-not set}"
|
|
echo "User: $(whoami 2>/dev/null || echo unknown)"
|
|
echo "UID: $(id -u 2>/dev/null || echo unknown)"
|
|
echo "PWD: $(pwd)"
|
|
|
|
# Set HOME if not set (node user's home is /home/node)
|
|
if [ -z "${HOME}" ]; then
|
|
if [ -d "/home/node" ]; then
|
|
export HOME="/home/node"
|
|
else
|
|
export HOME="/tmp"
|
|
fi
|
|
echo "Set HOME to: ${HOME}"
|
|
fi
|
|
|
|
# Use CLAWDBOT_STATE_DIR if set and writable, otherwise use HOME/.clawdbot
|
|
CONFIG_DIR="${HOME}/.clawdbot"
|
|
if [ -n "${CLAWDBOT_STATE_DIR}" ]; then
|
|
# Test if we can write to it (disable exit on error for this test)
|
|
set +e
|
|
mkdir -p "${CLAWDBOT_STATE_DIR}" 2>/dev/null
|
|
touch "${CLAWDBOT_STATE_DIR}/.test" 2>/dev/null
|
|
if [ $? -eq 0 ]; then
|
|
rm -f "${CLAWDBOT_STATE_DIR}/.test" 2>/dev/null
|
|
CONFIG_DIR="${CLAWDBOT_STATE_DIR}"
|
|
echo "Using CLAWDBOT_STATE_DIR: ${CONFIG_DIR}"
|
|
else
|
|
echo "Warning: ${CLAWDBOT_STATE_DIR} not writable, using ${CONFIG_DIR}"
|
|
fi
|
|
set -e
|
|
fi
|
|
|
|
CONFIG_FILE="${CONFIG_DIR}/clawdbot.json"
|
|
|
|
echo "Config dir: ${CONFIG_DIR}"
|
|
echo "Config file: ${CONFIG_FILE}"
|
|
|
|
# Create config directory (this should always work for HOME/.clawdbot)
|
|
if ! mkdir -p "${CONFIG_DIR}" 2>/dev/null; then
|
|
echo "ERROR: Failed to create config directory: ${CONFIG_DIR}"
|
|
exit 1
|
|
fi
|
|
|
|
# Write config file
|
|
if ! cat > "${CONFIG_FILE}" << 'EOF'
|
|
{
|
|
"gateway": {
|
|
"mode": "local",
|
|
"trustedProxies": ["10.0.0.0/8", "172.16.0.0/12", "192.168.0.0/16"],
|
|
"controlUi": {
|
|
"allowInsecureAuth": true
|
|
}
|
|
}
|
|
}
|
|
EOF
|
|
then
|
|
echo "ERROR: Failed to write config file: ${CONFIG_FILE}"
|
|
exit 1
|
|
fi
|
|
|
|
echo "=== Config written to ${CONFIG_FILE} ==="
|
|
cat "${CONFIG_FILE}" || echo "Warning: Could not read config file"
|
|
|
|
# Verify config file exists and is readable
|
|
if [ ! -f "${CONFIG_FILE}" ]; then
|
|
echo "ERROR: Config file does not exist: ${CONFIG_FILE}"
|
|
exit 1
|
|
fi
|
|
|
|
# Set environment variables for gateway
|
|
export CLAWDBOT_STATE_DIR="${CONFIG_DIR}"
|
|
export CLAWDBOT_CONFIG_PATH="${CONFIG_FILE}"
|
|
export CLAWDBOT_CONFIG_CACHE_MS=0
|
|
|
|
echo "=== Starting gateway ==="
|
|
echo "CLAWDBOT_STATE_DIR=${CLAWDBOT_STATE_DIR}"
|
|
echo "CLAWDBOT_CONFIG_PATH=${CLAWDBOT_CONFIG_PATH}"
|
|
|
|
# Verify node is available
|
|
if ! command -v node >/dev/null 2>&1; then
|
|
echo "ERROR: node command not found"
|
|
echo "PATH: ${PATH}"
|
|
exit 1
|
|
fi
|
|
|
|
echo "Node version: $(node --version)"
|
|
|
|
# Verify dist/index.js exists
|
|
if [ ! -f "dist/index.js" ]; then
|
|
echo "ERROR: dist/index.js not found"
|
|
echo "Contents of /app:"
|
|
ls -la /app 2>/dev/null || echo "Cannot list /app"
|
|
echo "Contents of current directory:"
|
|
ls -la . 2>/dev/null || echo "Cannot list current directory"
|
|
exit 1
|
|
fi
|
|
|
|
echo "Found dist/index.js"
|
|
|
|
# Check if token is set
|
|
if [ -z "${CLAWDBOT_GATEWAY_TOKEN}" ]; then
|
|
echo "ERROR: CLAWDBOT_GATEWAY_TOKEN is not set"
|
|
exit 1
|
|
fi
|
|
|
|
echo "Token is set (length: ${#CLAWDBOT_GATEWAY_TOKEN})"
|
|
|
|
# Enable strict error handling for the final exec
|
|
set -e
|
|
|
|
# Start gateway
|
|
echo "Executing: node dist/index.js gateway --port 8080 --bind lan --auth token --allow-unconfigured"
|
|
exec node dist/index.js gateway \
|
|
--port 8080 \
|
|
--bind lan \
|
|
--auth token \
|
|
--token "${CLAWDBOT_GATEWAY_TOKEN}" \
|
|
--allow-unconfigured
|