first commit

This commit is contained in:
nasir@endelospay.com
2025-08-12 02:54:17 +05:00
commit d97cad1736
225 changed files with 137626 additions and 0 deletions

View File

@@ -0,0 +1,64 @@
#!/bin/bash
# 获取脚本所在的绝对目录
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
LOG_DIR="/Users/hang/code/tencent/ai/chrome-mcp-server/app/native-server/dist/logs" # 或者你选择的、确定有写入权限的目录
# 获取当前时间戳用于日志文件名,避免覆盖
TIMESTAMP=$(date +"%Y%m%d_%H%M%S")
WRAPPER_LOG="${LOG_DIR}/native_host_wrapper_${TIMESTAMP}.log"
# Node.js 脚本的实际路径
NODE_SCRIPT="${SCRIPT_DIR}/index.js"
# 确保日志目录存在
mkdir -p "${LOG_DIR}"
# 记录 wrapper 脚本被调用的信息
echo "Wrapper script called at $(date)" > "${WRAPPER_LOG}"
echo "SCRIPT_DIR: ${SCRIPT_DIR}" >> "${WRAPPER_LOG}"
echo "LOG_DIR: ${LOG_DIR}" >> "${WRAPPER_LOG}"
echo "NODE_SCRIPT: ${NODE_SCRIPT}" >> "${WRAPPER_LOG}"
echo "Initial PATH: ${PATH}" >> "${WRAPPER_LOG}"
# 动态查找 Node.js 可执行文件
NODE_EXEC=""
# 1. 尝试用 which (它会使用当前环境的 PATH, 但 Chrome 的 PATH 可能不完整)
if command -v node &>/dev/null; then
NODE_EXEC=$(command -v node)
echo "Found node using 'command -v node': ${NODE_EXEC}" >> "${WRAPPER_LOG}"
fi
# 2. 如果 which 找不到,尝试一些 macOS 上常见的 Node.js 安装路径
if [ -z "${NODE_EXEC}" ]; then
COMMON_NODE_PATHS=(
"/usr/local/bin/node" # Homebrew on Intel Macs / direct install
"/opt/homebrew/bin/node" # Homebrew on Apple Silicon
"$HOME/.nvm/versions/node/$(ls -t $HOME/.nvm/versions/node | head -n 1)/bin/node" # NVM (latest installed)
# 你可以根据需要添加更多你环境中可能存在的路径
)
for path_to_node in "${COMMON_NODE_PATHS[@]}"; do
if [ -x "${path_to_node}" ]; then
NODE_EXEC="${path_to_node}"
echo "Found node at common path: ${NODE_EXEC}" >> "${WRAPPER_LOG}"
break
fi
done
fi
# 3. 如果还是找不到,记录错误并退出
if [ -z "${NODE_EXEC}" ]; then
echo "ERROR: Node.js executable not found!" >> "${WRAPPER_LOG}"
echo "Please ensure Node.js is installed and its path is accessible or configured in this script." >> "${WRAPPER_LOG}"
# 对于 Native Host它需要保持运行以接收消息直接退出可能不是最佳
# 但如果node都找不到也无法执行目标脚本
# 这里可以考虑输出一个符合 Native Messaging 协议的错误消息给扩展(如果可以的话)
# 或者就让它失败Chrome会报告 Native Host Exited.
exit 1 # 必须退出,否则下面的 exec 会失败
fi
echo "Using Node executable: ${NODE_EXEC}" >> "${WRAPPER_LOG}"
echo "Node version found by script: $(${NODE_EXEC} -v)" >> "${WRAPPER_LOG}"
echo "Executing: ${NODE_EXEC} ${NODE_SCRIPT}" >> "${WRAPPER_LOG}"
echo "PWD: $(pwd)" >> "${WRAPPER_LOG}" # PWD 记录一下,有时有用
exec "${NODE_EXEC}" "${NODE_SCRIPT}" 2>> "${LOG_DIR}/native_host_stderr_${TIMESTAMP}.log"