mirror of
https://github.com/yuaotian/go-cursor-help.git
synced 2025-06-08 04:22:06 +08:00
fix(mac): 修复mac环境下无法成功修改MAC地址的问题
This commit is contained in:
parent
d01dcdb7ba
commit
363518ad40
263
scripts/run/cursor_mac_id_modifier.sh
Normal file → Executable file
263
scripts/run/cursor_mac_id_modifier.sh
Normal file → Executable file
@ -110,6 +110,7 @@ _change_mac_for_one_interface() {
|
|||||||
|
|
||||||
# 尝试修改 MAC 地址
|
# 尝试修改 MAC 地址
|
||||||
log_info "尝试为接口 '$interface_name' 设置 MAC 地址: $random_mac"
|
log_info "尝试为接口 '$interface_name' 设置 MAC 地址: $random_mac"
|
||||||
|
sudo ifconfig $interface_name up
|
||||||
if sudo ifconfig "$interface_name" ether "$random_mac"; then
|
if sudo ifconfig "$interface_name" ether "$random_mac"; then
|
||||||
log_info "尝试修改接口 '$interface_name' 的 MAC 地址为: $random_mac [成功]"
|
log_info "尝试修改接口 '$interface_name' 的 MAC 地址为: $random_mac [成功]"
|
||||||
local new_mac_check=$(ifconfig "$interface_name" | awk '/ether/{print $2}')
|
local new_mac_check=$(ifconfig "$interface_name" | awk '/ether/{print $2}')
|
||||||
@ -170,50 +171,50 @@ check_permissions() {
|
|||||||
# 检查并关闭 Cursor 进程
|
# 检查并关闭 Cursor 进程
|
||||||
check_and_kill_cursor() {
|
check_and_kill_cursor() {
|
||||||
log_info "检查 Cursor 进程..."
|
log_info "检查 Cursor 进程..."
|
||||||
|
|
||||||
local attempt=1
|
local attempt=1
|
||||||
local max_attempts=5
|
local max_attempts=5
|
||||||
|
|
||||||
# 函数:获取进程详细信息
|
# 函数:获取进程详细信息
|
||||||
get_process_details() {
|
get_process_details() {
|
||||||
local process_name="$1"
|
local process_name="$1"
|
||||||
log_debug "正在获取 $process_name 进程详细信息:"
|
log_debug "正在获取 $process_name 进程详细信息:"
|
||||||
ps aux | grep -i "/Applications/Cursor.app" | grep -v grep
|
ps aux | grep -i "/Applications/Cursor.app" | grep -v grep
|
||||||
}
|
}
|
||||||
|
|
||||||
while [ $attempt -le $max_attempts ]; do
|
while [ $attempt -le $max_attempts ]; do
|
||||||
# 使用更精确的匹配来获取 Cursor 进程
|
# 使用更精确的匹配来获取 Cursor 进程
|
||||||
CURSOR_PIDS=$(ps aux | grep -i "/Applications/Cursor.app" | grep -v grep | awk '{print $2}')
|
CURSOR_PIDS=$(ps aux | grep -i "/Applications/Cursor.app" | grep -v grep | awk '{print $2}')
|
||||||
|
|
||||||
if [ -z "$CURSOR_PIDS" ]; then
|
if [ -z "$CURSOR_PIDS" ]; then
|
||||||
log_info "未发现运行中的 Cursor 进程"
|
log_info "未发现运行中的 Cursor 进程"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_warn "发现 Cursor 进程正在运行"
|
log_warn "发现 Cursor 进程正在运行"
|
||||||
get_process_details "cursor"
|
get_process_details "cursor"
|
||||||
|
|
||||||
log_warn "尝试关闭 Cursor 进程..."
|
log_warn "尝试关闭 Cursor 进程..."
|
||||||
|
|
||||||
if [ $attempt -eq $max_attempts ]; then
|
if [ $attempt -eq $max_attempts ]; then
|
||||||
log_warn "尝试强制终止进程..."
|
log_warn "尝试强制终止进程..."
|
||||||
kill -9 $CURSOR_PIDS 2>/dev/null || true
|
kill -9 $CURSOR_PIDS 2>/dev/null || true
|
||||||
else
|
else
|
||||||
kill $CURSOR_PIDS 2>/dev/null || true
|
kill $CURSOR_PIDS 2>/dev/null || true
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sleep 1
|
sleep 1
|
||||||
|
|
||||||
# 同样使用更精确的匹配来检查进程是否还在运行
|
# 同样使用更精确的匹配来检查进程是否还在运行
|
||||||
if ! ps aux | grep -i "/Applications/Cursor.app" | grep -v grep > /dev/null; then
|
if ! ps aux | grep -i "/Applications/Cursor.app" | grep -v grep > /dev/null; then
|
||||||
log_info "Cursor 进程已成功关闭"
|
log_info "Cursor 进程已成功关闭"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_warn "等待进程关闭,尝试 $attempt/$max_attempts..."
|
log_warn "等待进程关闭,尝试 $attempt/$max_attempts..."
|
||||||
((attempt++))
|
((attempt++))
|
||||||
done
|
done
|
||||||
|
|
||||||
log_error "在 $max_attempts 次尝试后仍无法关闭 Cursor 进程"
|
log_error "在 $max_attempts 次尝试后仍无法关闭 Cursor 进程"
|
||||||
get_process_details "cursor"
|
get_process_details "cursor"
|
||||||
log_error "请手动关闭进程后重试"
|
log_error "请手动关闭进程后重试"
|
||||||
@ -226,10 +227,10 @@ backup_config() {
|
|||||||
log_warn "配置文件不存在,跳过备份"
|
log_warn "配置文件不存在,跳过备份"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p "$BACKUP_DIR"
|
mkdir -p "$BACKUP_DIR"
|
||||||
local backup_file="$BACKUP_DIR/storage.json.backup_$(date +%Y%m%d_%H%M%S)"
|
local backup_file="$BACKUP_DIR/storage.json.backup_$(date +%Y%m%d_%H%M%S)"
|
||||||
|
|
||||||
if cp "$STORAGE_FILE" "$backup_file"; then
|
if cp "$STORAGE_FILE" "$backup_file"; then
|
||||||
chmod 644 "$backup_file"
|
chmod 644 "$backup_file"
|
||||||
chown "$CURRENT_USER" "$backup_file"
|
chown "$CURRENT_USER" "$backup_file"
|
||||||
@ -345,21 +346,21 @@ modify_or_add_config() {
|
|||||||
local key="$1"
|
local key="$1"
|
||||||
local value="$2"
|
local value="$2"
|
||||||
local file="$3"
|
local file="$3"
|
||||||
|
|
||||||
if [ ! -f "$file" ]; then
|
if [ ! -f "$file" ]; then
|
||||||
log_error "文件不存在: $file"
|
log_error "文件不存在: $file"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 确保文件可写
|
# 确保文件可写
|
||||||
chmod 644 "$file" || {
|
chmod 644 "$file" || {
|
||||||
log_error "无法修改文件权限: $file"
|
log_error "无法修改文件权限: $file"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
# 创建临时文件
|
# 创建临时文件
|
||||||
local temp_file=$(mktemp)
|
local temp_file=$(mktemp)
|
||||||
|
|
||||||
# 检查key是否存在
|
# 检查key是否存在
|
||||||
if grep -q "\"$key\":" "$file"; then
|
if grep -q "\"$key\":" "$file"; then
|
||||||
# key存在,执行替换
|
# key存在,执行替换
|
||||||
@ -376,59 +377,59 @@ modify_or_add_config() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 检查临时文件是否为空
|
# 检查临时文件是否为空
|
||||||
if [ ! -s "$temp_file" ]; then
|
if [ ! -s "$temp_file" ]; then
|
||||||
log_error "生成的临时文件为空"
|
log_error "生成的临时文件为空"
|
||||||
rm -f "$temp_file"
|
rm -f "$temp_file"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 使用 cat 替换原文件内容
|
# 使用 cat 替换原文件内容
|
||||||
cat "$temp_file" > "$file" || {
|
cat "$temp_file" > "$file" || {
|
||||||
log_error "无法写入文件: $file"
|
log_error "无法写入文件: $file"
|
||||||
rm -f "$temp_file"
|
rm -f "$temp_file"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
rm -f "$temp_file"
|
rm -f "$temp_file"
|
||||||
|
|
||||||
# 恢复文件权限
|
# 恢复文件权限
|
||||||
chmod 444 "$file"
|
chmod 444 "$file"
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
# 清理 Cursor 之前的修改
|
# 清理 Cursor 之前的修改
|
||||||
clean_cursor_app() {
|
clean_cursor_app() {
|
||||||
log_info "尝试清理 Cursor 之前的修改..."
|
log_info "尝试清理 Cursor 之前的修改..."
|
||||||
|
|
||||||
# 如果存在备份,直接恢复备份
|
# 如果存在备份,直接恢复备份
|
||||||
local latest_backup=""
|
local latest_backup=""
|
||||||
|
|
||||||
# 查找最新的备份
|
# 查找最新的备份
|
||||||
latest_backup=$(find /tmp -name "Cursor.app.backup_*" -type d -print 2>/dev/null | sort -r | head -1)
|
latest_backup=$(find /tmp -name "Cursor.app.backup_*" -type d -print 2>/dev/null | sort -r | head -1)
|
||||||
|
|
||||||
if [ -n "$latest_backup" ] && [ -d "$latest_backup" ]; then
|
if [ -n "$latest_backup" ] && [ -d "$latest_backup" ]; then
|
||||||
log_info "找到现有备份: $latest_backup"
|
log_info "找到现有备份: $latest_backup"
|
||||||
log_info "正在恢复原始版本..."
|
log_info "正在恢复原始版本..."
|
||||||
|
|
||||||
# 停止 Cursor 进程
|
# 停止 Cursor 进程
|
||||||
check_and_kill_cursor
|
check_and_kill_cursor
|
||||||
|
|
||||||
# 恢复备份
|
# 恢复备份
|
||||||
sudo rm -rf "$CURSOR_APP_PATH"
|
sudo rm -rf "$CURSOR_APP_PATH"
|
||||||
sudo cp -R "$latest_backup" "$CURSOR_APP_PATH"
|
sudo cp -R "$latest_backup" "$CURSOR_APP_PATH"
|
||||||
sudo chown -R "$CURRENT_USER:staff" "$CURSOR_APP_PATH"
|
sudo chown -R "$CURRENT_USER:staff" "$CURSOR_APP_PATH"
|
||||||
sudo chmod -R 755 "$CURSOR_APP_PATH"
|
sudo chmod -R 755 "$CURSOR_APP_PATH"
|
||||||
|
|
||||||
log_info "已恢复原始版本"
|
log_info "已恢复原始版本"
|
||||||
return 0
|
return 0
|
||||||
else
|
else
|
||||||
log_warn "未找到现有备份,尝试重新安装 Cursor..."
|
log_warn "未找到现有备份,尝试重新安装 Cursor..."
|
||||||
echo "您可以从 https://cursor.sh 下载并重新安装 Cursor"
|
echo "您可以从 https://cursor.sh 下载并重新安装 Cursor"
|
||||||
echo "或者继续执行此脚本,将尝试修复现有安装"
|
echo "或者继续执行此脚本,将尝试修复现有安装"
|
||||||
|
|
||||||
# 可以在这里添加重新下载和安装的逻辑
|
# 可以在这里添加重新下载和安装的逻辑
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@ -438,10 +439,10 @@ clean_cursor_app() {
|
|||||||
modify_cursor_app_files() {
|
modify_cursor_app_files() {
|
||||||
log_info "正在安全修改 Cursor 主程序文件..."
|
log_info "正在安全修改 Cursor 主程序文件..."
|
||||||
log_info "详细日志将记录到: $LOG_FILE"
|
log_info "详细日志将记录到: $LOG_FILE"
|
||||||
|
|
||||||
# 先清理之前的修改
|
# 先清理之前的修改
|
||||||
clean_cursor_app
|
clean_cursor_app
|
||||||
|
|
||||||
# 验证应用是否存在
|
# 验证应用是否存在
|
||||||
if [ ! -d "$CURSOR_APP_PATH" ]; then
|
if [ ! -d "$CURSOR_APP_PATH" ]; then
|
||||||
log_error "未找到 Cursor.app,请确认安装路径: $CURSOR_APP_PATH"
|
log_error "未找到 Cursor.app,请确认安装路径: $CURSOR_APP_PATH"
|
||||||
@ -454,11 +455,11 @@ modify_cursor_app_files() {
|
|||||||
"${CURSOR_APP_PATH}/Contents/Resources/app/out/main.js"
|
"${CURSOR_APP_PATH}/Contents/Resources/app/out/main.js"
|
||||||
"${CURSOR_APP_PATH}/Contents/Resources/app/out/vs/code/node/cliProcessMain.js"
|
"${CURSOR_APP_PATH}/Contents/Resources/app/out/vs/code/node/cliProcessMain.js"
|
||||||
)
|
)
|
||||||
|
|
||||||
# 检查文件是否存在并且是否已修改
|
# 检查文件是否存在并且是否已修改
|
||||||
local need_modification=false
|
local need_modification=false
|
||||||
local missing_files=false
|
local missing_files=false
|
||||||
|
|
||||||
log_debug "检查目标文件..."
|
log_debug "检查目标文件..."
|
||||||
for file in "${target_files[@]}"; do
|
for file in "${target_files[@]}"; do
|
||||||
if [ ! -f "$file" ]; then
|
if [ ! -f "$file" ]; then
|
||||||
@ -467,9 +468,9 @@ modify_cursor_app_files() {
|
|||||||
missing_files=true
|
missing_files=true
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "[FILE_CHECK] 文件存在: $file ($(wc -c < "$file") 字节)" >> "$LOG_FILE"
|
echo "[FILE_CHECK] 文件存在: $file ($(wc -c < "$file") 字节)" >> "$LOG_FILE"
|
||||||
|
|
||||||
if ! grep -q "return crypto.randomUUID()" "$file" 2>/dev/null; then
|
if ! grep -q "return crypto.randomUUID()" "$file" 2>/dev/null; then
|
||||||
log_info "文件需要修改: ${file/$CURSOR_APP_PATH\//}"
|
log_info "文件需要修改: ${file/$CURSOR_APP_PATH\//}"
|
||||||
grep -n "IOPlatformUUID" "$file" | head -3 >> "$LOG_FILE" || echo "[FILE_CHECK] 未找到 IOPlatformUUID" >> "$LOG_FILE"
|
grep -n "IOPlatformUUID" "$file" | head -3 >> "$LOG_FILE" || echo "[FILE_CHECK] 未找到 IOPlatformUUID" >> "$LOG_FILE"
|
||||||
@ -479,13 +480,13 @@ modify_cursor_app_files() {
|
|||||||
log_info "文件已修改: ${file/$CURSOR_APP_PATH\//}"
|
log_info "文件已修改: ${file/$CURSOR_APP_PATH\//}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# 如果所有文件都已修改或不存在,则退出
|
# 如果所有文件都已修改或不存在,则退出
|
||||||
if [ "$missing_files" = true ]; then
|
if [ "$missing_files" = true ]; then
|
||||||
log_error "部分目标文件不存在,请确认 Cursor 安装是否完整"
|
log_error "部分目标文件不存在,请确认 Cursor 安装是否完整"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$need_modification" = false ]; then
|
if [ "$need_modification" = false ]; then
|
||||||
log_info "所有目标文件已经被修改过,无需重复操作"
|
log_info "所有目标文件已经被修改过,无需重复操作"
|
||||||
return 0
|
return 0
|
||||||
@ -496,16 +497,16 @@ modify_cursor_app_files() {
|
|||||||
local temp_dir="/tmp/cursor_reset_${timestamp}"
|
local temp_dir="/tmp/cursor_reset_${timestamp}"
|
||||||
local temp_app="${temp_dir}/Cursor.app"
|
local temp_app="${temp_dir}/Cursor.app"
|
||||||
local backup_app="/tmp/Cursor.app.backup_${timestamp}"
|
local backup_app="/tmp/Cursor.app.backup_${timestamp}"
|
||||||
|
|
||||||
log_debug "创建临时目录: $temp_dir"
|
log_debug "创建临时目录: $temp_dir"
|
||||||
echo "[TEMP_DIR] 创建临时目录: $temp_dir" >> "$LOG_FILE"
|
echo "[TEMP_DIR] 创建临时目录: $temp_dir" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 清理可能存在的旧临时目录
|
# 清理可能存在的旧临时目录
|
||||||
if [ -d "$temp_dir" ]; then
|
if [ -d "$temp_dir" ]; then
|
||||||
log_info "清理已存在的临时目录..."
|
log_info "清理已存在的临时目录..."
|
||||||
rm -rf "$temp_dir"
|
rm -rf "$temp_dir"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 创建新的临时目录
|
# 创建新的临时目录
|
||||||
mkdir -p "$temp_dir" || {
|
mkdir -p "$temp_dir" || {
|
||||||
log_error "无法创建临时目录: $temp_dir"
|
log_error "无法创建临时目录: $temp_dir"
|
||||||
@ -516,27 +517,27 @@ modify_cursor_app_files() {
|
|||||||
# 备份原应用
|
# 备份原应用
|
||||||
log_info "备份原应用..."
|
log_info "备份原应用..."
|
||||||
echo "[BACKUP] 开始备份: $CURSOR_APP_PATH -> $backup_app" >> "$LOG_FILE"
|
echo "[BACKUP] 开始备份: $CURSOR_APP_PATH -> $backup_app" >> "$LOG_FILE"
|
||||||
|
|
||||||
cp -R "$CURSOR_APP_PATH" "$backup_app" || {
|
cp -R "$CURSOR_APP_PATH" "$backup_app" || {
|
||||||
log_error "无法创建应用备份"
|
log_error "无法创建应用备份"
|
||||||
echo "[ERROR] 备份失败: $CURSOR_APP_PATH -> $backup_app" >> "$LOG_FILE"
|
echo "[ERROR] 备份失败: $CURSOR_APP_PATH -> $backup_app" >> "$LOG_FILE"
|
||||||
rm -rf "$temp_dir"
|
rm -rf "$temp_dir"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
echo "[BACKUP] 备份完成" >> "$LOG_FILE"
|
echo "[BACKUP] 备份完成" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 复制应用到临时目录
|
# 复制应用到临时目录
|
||||||
log_info "创建临时工作副本..."
|
log_info "创建临时工作副本..."
|
||||||
echo "[COPY] 开始复制: $CURSOR_APP_PATH -> $temp_dir" >> "$LOG_FILE"
|
echo "[COPY] 开始复制: $CURSOR_APP_PATH -> $temp_dir" >> "$LOG_FILE"
|
||||||
|
|
||||||
cp -R "$CURSOR_APP_PATH" "$temp_dir" || {
|
cp -R "$CURSOR_APP_PATH" "$temp_dir" || {
|
||||||
log_error "无法复制应用到临时目录"
|
log_error "无法复制应用到临时目录"
|
||||||
echo "[ERROR] 复制失败: $CURSOR_APP_PATH -> $temp_dir" >> "$LOG_FILE"
|
echo "[ERROR] 复制失败: $CURSOR_APP_PATH -> $temp_dir" >> "$LOG_FILE"
|
||||||
rm -rf "$temp_dir" "$backup_app"
|
rm -rf "$temp_dir" "$backup_app"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
echo "[COPY] 复制完成" >> "$LOG_FILE"
|
echo "[COPY] 复制完成" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 确保临时目录的权限正确
|
# 确保临时目录的权限正确
|
||||||
@ -546,7 +547,7 @@ modify_cursor_app_files() {
|
|||||||
# 移除签名(增强兼容性)
|
# 移除签名(增强兼容性)
|
||||||
log_info "移除应用签名..."
|
log_info "移除应用签名..."
|
||||||
echo "[CODESIGN] 移除签名: $temp_app" >> "$LOG_FILE"
|
echo "[CODESIGN] 移除签名: $temp_app" >> "$LOG_FILE"
|
||||||
|
|
||||||
codesign --remove-signature "$temp_app" 2>> "$LOG_FILE" || {
|
codesign --remove-signature "$temp_app" 2>> "$LOG_FILE" || {
|
||||||
log_warn "移除应用签名失败"
|
log_warn "移除应用签名失败"
|
||||||
echo "[WARN] 移除签名失败: $temp_app" >> "$LOG_FILE"
|
echo "[WARN] 移除签名失败: $temp_app" >> "$LOG_FILE"
|
||||||
@ -568,7 +569,7 @@ modify_cursor_app_files() {
|
|||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# 修改目标文件 - 优先处理js文件
|
# 修改目标文件 - 优先处理js文件
|
||||||
local modified_count=0
|
local modified_count=0
|
||||||
local files=(
|
local files=(
|
||||||
@ -576,22 +577,22 @@ modify_cursor_app_files() {
|
|||||||
"${temp_app}/Contents/Resources/app/out/main.js"
|
"${temp_app}/Contents/Resources/app/out/main.js"
|
||||||
"${temp_app}/Contents/Resources/app/out/vs/code/node/cliProcessMain.js"
|
"${temp_app}/Contents/Resources/app/out/vs/code/node/cliProcessMain.js"
|
||||||
)
|
)
|
||||||
|
|
||||||
for file in "${files[@]}"; do
|
for file in "${files[@]}"; do
|
||||||
if [ ! -f "$file" ]; then
|
if [ ! -f "$file" ]; then
|
||||||
log_warn "文件不存在: ${file/$temp_dir\//}"
|
log_warn "文件不存在: ${file/$temp_dir\//}"
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_debug "处理文件: ${file/$temp_dir\//}"
|
log_debug "处理文件: ${file/$temp_dir\//}"
|
||||||
echo "[PROCESS] 开始处理文件: $file" >> "$LOG_FILE"
|
echo "[PROCESS] 开始处理文件: $file" >> "$LOG_FILE"
|
||||||
echo "[PROCESS] 文件大小: $(wc -c < "$file") 字节" >> "$LOG_FILE"
|
echo "[PROCESS] 文件大小: $(wc -c < "$file") 字节" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 输出文件部分内容到日志
|
# 输出文件部分内容到日志
|
||||||
echo "[FILE_CONTENT] 文件头部 100 行:" >> "$LOG_FILE"
|
echo "[FILE_CONTENT] 文件头部 100 行:" >> "$LOG_FILE"
|
||||||
head -100 "$file" 2>/dev/null | grep -v "^$" | head -50 >> "$LOG_FILE"
|
head -100 "$file" 2>/dev/null | grep -v "^$" | head -50 >> "$LOG_FILE"
|
||||||
echo "[FILE_CONTENT] ..." >> "$LOG_FILE"
|
echo "[FILE_CONTENT] ..." >> "$LOG_FILE"
|
||||||
|
|
||||||
# 创建文件备份
|
# 创建文件备份
|
||||||
cp "$file" "${file}.bak" || {
|
cp "$file" "${file}.bak" || {
|
||||||
log_error "无法创建文件备份: ${file/$temp_dir\//}"
|
log_error "无法创建文件备份: ${file/$temp_dir\//}"
|
||||||
@ -603,15 +604,15 @@ modify_cursor_app_files() {
|
|||||||
if [[ "$file" == *"extensionHostProcess.js"* ]]; then
|
if [[ "$file" == *"extensionHostProcess.js"* ]]; then
|
||||||
log_debug "处理 extensionHostProcess.js 文件..."
|
log_debug "处理 extensionHostProcess.js 文件..."
|
||||||
echo "[PROCESS_DETAIL] 开始处理 extensionHostProcess.js 文件" >> "$LOG_FILE"
|
echo "[PROCESS_DETAIL] 开始处理 extensionHostProcess.js 文件" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 检查是否包含目标代码
|
# 检查是否包含目标代码
|
||||||
if grep -q 'i.header.set("x-cursor-checksum' "$file"; then
|
if grep -q 'i.header.set("x-cursor-checksum' "$file"; then
|
||||||
log_debug "找到 x-cursor-checksum 设置代码"
|
log_debug "找到 x-cursor-checksum 设置代码"
|
||||||
echo "[FOUND] 找到 x-cursor-checksum 设置代码" >> "$LOG_FILE"
|
echo "[FOUND] 找到 x-cursor-checksum 设置代码" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 记录匹配的行到日志
|
# 记录匹配的行到日志
|
||||||
grep -n 'i.header.set("x-cursor-checksum' "$file" >> "$LOG_FILE"
|
grep -n 'i.header.set("x-cursor-checksum' "$file" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 执行特定的替换
|
# 执行特定的替换
|
||||||
if sed -i.tmp 's/i\.header\.set("x-cursor-checksum",e===void 0?`${p}${t}`:`${p}${t}\/${e}`)/i.header.set("x-cursor-checksum",e===void 0?`${p}${t}`:`${p}${t}\/${p}`)/' "$file"; then
|
if sed -i.tmp 's/i\.header\.set("x-cursor-checksum",e===void 0?`${p}${t}`:`${p}${t}\/${e}`)/i.header.set("x-cursor-checksum",e===void 0?`${p}${t}`:`${p}${t}\/${p}`)/' "$file"; then
|
||||||
log_info "成功修改 x-cursor-checksum 设置代码"
|
log_info "成功修改 x-cursor-checksum 设置代码"
|
||||||
@ -627,21 +628,21 @@ modify_cursor_app_files() {
|
|||||||
else
|
else
|
||||||
log_warn "未找到 x-cursor-checksum 设置代码"
|
log_warn "未找到 x-cursor-checksum 设置代码"
|
||||||
echo "[FILE_CHECK] 未找到 x-cursor-checksum 设置代码" >> "$LOG_FILE"
|
echo "[FILE_CHECK] 未找到 x-cursor-checksum 设置代码" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 记录文件部分内容到日志以便排查
|
# 记录文件部分内容到日志以便排查
|
||||||
echo "[FILE_CONTENT] 文件中包含 'header.set' 的行:" >> "$LOG_FILE"
|
echo "[FILE_CONTENT] 文件中包含 'header.set' 的行:" >> "$LOG_FILE"
|
||||||
grep -n "header.set" "$file" | head -20 >> "$LOG_FILE"
|
grep -n "header.set" "$file" | head -20 >> "$LOG_FILE"
|
||||||
|
|
||||||
echo "[FILE_CONTENT] 文件中包含 'checksum' 的行:" >> "$LOG_FILE"
|
echo "[FILE_CONTENT] 文件中包含 'checksum' 的行:" >> "$LOG_FILE"
|
||||||
grep -n "checksum" "$file" | head -20 >> "$LOG_FILE"
|
grep -n "checksum" "$file" | head -20 >> "$LOG_FILE"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "[PROCESS_DETAIL] 完成处理 extensionHostProcess.js 文件" >> "$LOG_FILE"
|
echo "[PROCESS_DETAIL] 完成处理 extensionHostProcess.js 文件" >> "$LOG_FILE"
|
||||||
elif grep -q "IOPlatformUUID" "$file"; then
|
elif grep -q "IOPlatformUUID" "$file"; then
|
||||||
log_debug "找到 IOPlatformUUID 关键字"
|
log_debug "找到 IOPlatformUUID 关键字"
|
||||||
echo "[FOUND] 找到 IOPlatformUUID 关键字" >> "$LOG_FILE"
|
echo "[FOUND] 找到 IOPlatformUUID 关键字" >> "$LOG_FILE"
|
||||||
grep -n "IOPlatformUUID" "$file" | head -5 >> "$LOG_FILE"
|
grep -n "IOPlatformUUID" "$file" | head -5 >> "$LOG_FILE"
|
||||||
|
|
||||||
# 定位 IOPlatformUUID 相关函数
|
# 定位 IOPlatformUUID 相关函数
|
||||||
if grep -q "function a\$" "$file"; then
|
if grep -q "function a\$" "$file"; then
|
||||||
# 检查是否已经修改过
|
# 检查是否已经修改过
|
||||||
@ -650,7 +651,7 @@ modify_cursor_app_files() {
|
|||||||
((modified_count++))
|
((modified_count++))
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 针对 main.js 中发现的代码结构进行修改
|
# 针对 main.js 中发现的代码结构进行修改
|
||||||
if sed -i.tmp 's/function a\$(t){switch/function a\$(t){return crypto.randomUUID(); switch/' "$file"; then
|
if sed -i.tmp 's/function a\$(t){switch/function a\$(t){return crypto.randomUUID(); switch/' "$file"; then
|
||||||
log_debug "成功注入 randomUUID 调用到 a\$ 函数"
|
log_debug "成功注入 randomUUID 调用到 a\$ 函数"
|
||||||
@ -667,7 +668,7 @@ modify_cursor_app_files() {
|
|||||||
((modified_count++))
|
((modified_count++))
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 替代方法 - 修改 v5 函数
|
# 替代方法 - 修改 v5 函数
|
||||||
if sed -i.tmp 's/async function v5(t){let e=/async function v5(t){return crypto.randomUUID(); let e=/' "$file"; then
|
if sed -i.tmp 's/async function v5(t){let e=/async function v5(t){return crypto.randomUUID(); let e=/' "$file"; then
|
||||||
log_debug "成功注入 randomUUID 调用到 v5 函数"
|
log_debug "成功注入 randomUUID 调用到 v5 函数"
|
||||||
@ -713,11 +714,11 @@ const randomDeviceId_$(date +%s) = () => {
|
|||||||
echo "$inject_code" > "${file}.new"
|
echo "$inject_code" > "${file}.new"
|
||||||
cat "$file" >> "${file}.new"
|
cat "$file" >> "${file}.new"
|
||||||
mv "${file}.new" "$file"
|
mv "${file}.new" "$file"
|
||||||
|
|
||||||
# 替换调用点
|
# 替换调用点
|
||||||
sed -i.tmp 's/await v5(!1)/randomDeviceId_'"$(date +%s)"'()/g' "$file"
|
sed -i.tmp 's/await v5(!1)/randomDeviceId_'"$(date +%s)"'()/g' "$file"
|
||||||
sed -i.tmp 's/a\$(t)/randomDeviceId_'"$(date +%s)"'()/g' "$file"
|
sed -i.tmp 's/a\$(t)/randomDeviceId_'"$(date +%s)"'()/g' "$file"
|
||||||
|
|
||||||
log_debug "完成通用修改"
|
log_debug "完成通用修改"
|
||||||
((modified_count++))
|
((modified_count++))
|
||||||
log_info "使用通用方法成功修改文件: ${file/$temp_dir\//}"
|
log_info "使用通用方法成功修改文件: ${file/$temp_dir\//}"
|
||||||
@ -725,36 +726,36 @@ const randomDeviceId_$(date +%s) = () => {
|
|||||||
else
|
else
|
||||||
# 未找到 IOPlatformUUID,可能是文件结构变化
|
# 未找到 IOPlatformUUID,可能是文件结构变化
|
||||||
log_warn "未找到 IOPlatformUUID,尝试替代方法"
|
log_warn "未找到 IOPlatformUUID,尝试替代方法"
|
||||||
|
|
||||||
# 检查是否已经注入或修改过
|
# 检查是否已经注入或修改过
|
||||||
if grep -q "return crypto.randomUUID()" "$file" || grep -q "// Cursor ID 修改工具注入" "$file"; then
|
if grep -q "return crypto.randomUUID()" "$file" || grep -q "// Cursor ID 修改工具注入" "$file"; then
|
||||||
log_info "文件已经被修改过,跳过修改"
|
log_info "文件已经被修改过,跳过修改"
|
||||||
((modified_count++))
|
((modified_count++))
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 尝试找其他关键函数如 getMachineId 或 getDeviceId
|
# 尝试找其他关键函数如 getMachineId 或 getDeviceId
|
||||||
if grep -q "function t\$()" "$file" || grep -q "async function y5" "$file"; then
|
if grep -q "function t\$()" "$file" || grep -q "async function y5" "$file"; then
|
||||||
log_debug "找到设备ID相关函数"
|
log_debug "找到设备ID相关函数"
|
||||||
|
|
||||||
# 修改 MAC 地址获取函数
|
# 修改 MAC 地址获取函数
|
||||||
if grep -q "function t\$()" "$file"; then
|
if grep -q "function t\$()" "$file"; then
|
||||||
sed -i.tmp 's/function t\$(){/function t\$(){return "00:00:00:00:00:00";/' "$file"
|
sed -i.tmp 's/function t\$(){/function t\$(){return "00:00:00:00:00:00";/' "$file"
|
||||||
log_debug "修改 MAC 地址获取函数成功"
|
log_debug "修改 MAC 地址获取函数成功"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 修改设备ID获取函数
|
# 修改设备ID获取函数
|
||||||
if grep -q "async function y5" "$file"; then
|
if grep -q "async function y5" "$file"; then
|
||||||
sed -i.tmp 's/async function y5(t){/async function y5(t){return crypto.randomUUID();/' "$file"
|
sed -i.tmp 's/async function y5(t){/async function y5(t){return crypto.randomUUID();/' "$file"
|
||||||
log_debug "修改设备ID获取函数成功"
|
log_debug "修改设备ID获取函数成功"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
((modified_count++))
|
((modified_count++))
|
||||||
log_info "使用替代方法成功修改文件: ${file/$temp_dir\//}"
|
log_info "使用替代方法成功修改文件: ${file/$temp_dir\//}"
|
||||||
else
|
else
|
||||||
# 最后尝试的通用方法 - 在文件顶部插入重写函数定义
|
# 最后尝试的通用方法 - 在文件顶部插入重写函数定义
|
||||||
log_warn "未找到任何已知函数,使用最通用的方法"
|
log_warn "未找到任何已知函数,使用最通用的方法"
|
||||||
|
|
||||||
inject_universal_code="
|
inject_universal_code="
|
||||||
// Cursor ID 修改工具注入 - $(date +%Y%m%d%H%M%S)
|
// Cursor ID 修改工具注入 - $(date +%Y%m%d%H%M%S)
|
||||||
// 全局拦截设备标识符 - $(date +%s)
|
// 全局拦截设备标识符 - $(date +%s)
|
||||||
@ -780,46 +781,46 @@ global.macMachineId = '${mac_machine_id}';
|
|||||||
local machine_id="auth0|user_$(openssl rand -hex 16)"
|
local machine_id="auth0|user_$(openssl rand -hex 16)"
|
||||||
local device_id=$(uuidgen | tr '[:upper:]' '[:lower:]')
|
local device_id=$(uuidgen | tr '[:upper:]' '[:lower:]')
|
||||||
local mac_machine_id=$(openssl rand -hex 32)
|
local mac_machine_id=$(openssl rand -hex 32)
|
||||||
|
|
||||||
inject_universal_code=${inject_universal_code//\$\{new_uuid\}/$new_uuid}
|
inject_universal_code=${inject_universal_code//\$\{new_uuid\}/$new_uuid}
|
||||||
inject_universal_code=${inject_universal_code//\$\{machine_id\}/$machine_id}
|
inject_universal_code=${inject_universal_code//\$\{machine_id\}/$machine_id}
|
||||||
inject_universal_code=${inject_universal_code//\$\{device_id\}/$device_id}
|
inject_universal_code=${inject_universal_code//\$\{device_id\}/$device_id}
|
||||||
inject_universal_code=${inject_universal_code//\$\{mac_machine_id\}/$mac_machine_id}
|
inject_universal_code=${inject_universal_code//\$\{mac_machine_id\}/$mac_machine_id}
|
||||||
|
|
||||||
echo "$inject_universal_code" > "${file}.new"
|
echo "$inject_universal_code" > "${file}.new"
|
||||||
cat "$file" >> "${file}.new"
|
cat "$file" >> "${file}.new"
|
||||||
mv "${file}.new" "$file"
|
mv "${file}.new" "$file"
|
||||||
|
|
||||||
log_debug "完成通用覆盖"
|
log_debug "完成通用覆盖"
|
||||||
((modified_count++))
|
((modified_count++))
|
||||||
log_info "使用最通用方法成功修改文件: ${file/$temp_dir\//}"
|
log_info "使用最通用方法成功修改文件: ${file/$temp_dir\//}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 添加在关键操作后记录日志
|
# 添加在关键操作后记录日志
|
||||||
echo "[MODIFIED] 文件修改后内容:" >> "$LOG_FILE"
|
echo "[MODIFIED] 文件修改后内容:" >> "$LOG_FILE"
|
||||||
grep -n "return crypto.randomUUID()" "$file" | head -3 >> "$LOG_FILE"
|
grep -n "return crypto.randomUUID()" "$file" | head -3 >> "$LOG_FILE"
|
||||||
|
|
||||||
# 清理临时文件
|
# 清理临时文件
|
||||||
rm -f "${file}.tmp" "${file}.bak"
|
rm -f "${file}.tmp" "${file}.bak"
|
||||||
echo "[PROCESS] 文件处理完成: $file" >> "$LOG_FILE"
|
echo "[PROCESS] 文件处理完成: $file" >> "$LOG_FILE"
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "$modified_count" -eq 0 ]; then
|
if [ "$modified_count" -eq 0 ]; then
|
||||||
log_error "未能成功修改任何文件"
|
log_error "未能成功修改任何文件"
|
||||||
rm -rf "$temp_dir"
|
rm -rf "$temp_dir"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 重新签名应用(增加重试机制)
|
# 重新签名应用(增加重试机制)
|
||||||
local max_retry=3
|
local max_retry=3
|
||||||
local retry_count=0
|
local retry_count=0
|
||||||
local sign_success=false
|
local sign_success=false
|
||||||
|
|
||||||
while [ $retry_count -lt $max_retry ]; do
|
while [ $retry_count -lt $max_retry ]; do
|
||||||
((retry_count++))
|
((retry_count++))
|
||||||
log_info "尝试签名 (第 $retry_count 次)..."
|
log_info "尝试签名 (第 $retry_count 次)..."
|
||||||
|
|
||||||
# 使用更详细的签名参数
|
# 使用更详细的签名参数
|
||||||
if codesign --sign - --force --deep --preserve-metadata=entitlements,identifier,flags "$temp_app" 2>&1 | tee /tmp/codesign.log; then
|
if codesign --sign - --force --deep --preserve-metadata=entitlements,identifier,flags "$temp_app" 2>&1 | tee /tmp/codesign.log; then
|
||||||
# 验证签名
|
# 验证签名
|
||||||
@ -835,7 +836,7 @@ global.macMachineId = '${mac_machine_id}';
|
|||||||
log_warn "签名失败,错误日志:"
|
log_warn "签名失败,错误日志:"
|
||||||
cat /tmp/codesign.log
|
cat /tmp/codesign.log
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sleep 1
|
sleep 1
|
||||||
done
|
done
|
||||||
|
|
||||||
@ -858,14 +859,14 @@ global.macMachineId = '${mac_machine_id}';
|
|||||||
rm -rf "$temp_dir" "$backup_app"
|
rm -rf "$temp_dir" "$backup_app"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 清理临时文件
|
# 清理临时文件
|
||||||
rm -rf "$temp_dir" "$backup_app"
|
rm -rf "$temp_dir" "$backup_app"
|
||||||
|
|
||||||
# 设置权限
|
# 设置权限
|
||||||
sudo chown -R "$CURRENT_USER:staff" "$CURSOR_APP_PATH"
|
sudo chown -R "$CURRENT_USER:staff" "$CURSOR_APP_PATH"
|
||||||
sudo chmod -R 755 "$CURSOR_APP_PATH"
|
sudo chmod -R 755 "$CURSOR_APP_PATH"
|
||||||
|
|
||||||
log_info "Cursor 主程序文件修改完成!原版备份在: ${backup_app/$HOME/\~}"
|
log_info "Cursor 主程序文件修改完成!原版备份在: ${backup_app/$HOME/\~}"
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
@ -879,7 +880,7 @@ show_file_tree() {
|
|||||||
echo "├── globalStorage"
|
echo "├── globalStorage"
|
||||||
echo "│ ├── storage.json (已修改)"
|
echo "│ ├── storage.json (已修改)"
|
||||||
echo "│ └── backups"
|
echo "│ └── backups"
|
||||||
|
|
||||||
# 列出备份文件
|
# 列出备份文件
|
||||||
if [ -d "$BACKUP_DIR" ]; then
|
if [ -d "$BACKUP_DIR" ]; then
|
||||||
local backup_files=("$BACKUP_DIR"/*)
|
local backup_files=("$BACKUP_DIR"/*)
|
||||||
@ -909,17 +910,17 @@ show_follow_info() {
|
|||||||
disable_auto_update() {
|
disable_auto_update() {
|
||||||
local updater_path="$HOME/Library/Application Support/Caches/cursor-updater"
|
local updater_path="$HOME/Library/Application Support/Caches/cursor-updater"
|
||||||
local app_update_yml="/Applications/Cursor.app/Contents/Resources/app-update.yml"
|
local app_update_yml="/Applications/Cursor.app/Contents/Resources/app-update.yml"
|
||||||
|
|
||||||
echo
|
echo
|
||||||
log_info "正在禁用 Cursor 自动更新..."
|
log_info "正在禁用 Cursor 自动更新..."
|
||||||
|
|
||||||
# 备份并清空 app-update.yml
|
# 备份并清空 app-update.yml
|
||||||
if [ -f "$app_update_yml" ]; then
|
if [ -f "$app_update_yml" ]; then
|
||||||
log_info "备份并修改 app-update.yml..."
|
log_info "备份并修改 app-update.yml..."
|
||||||
if ! sudo cp "$app_update_yml" "${app_update_yml}.bak" 2>/dev/null; then
|
if ! sudo cp "$app_update_yml" "${app_update_yml}.bak" 2>/dev/null; then
|
||||||
log_warn "备份 app-update.yml 失败,继续执行..."
|
log_warn "备份 app-update.yml 失败,继续执行..."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if sudo bash -c "echo '' > \"$app_update_yml\"" && \
|
if sudo bash -c "echo '' > \"$app_update_yml\"" && \
|
||||||
sudo chmod 444 "$app_update_yml"; then
|
sudo chmod 444 "$app_update_yml"; then
|
||||||
log_info "成功禁用 app-update.yml"
|
log_info "成功禁用 app-update.yml"
|
||||||
@ -932,7 +933,7 @@ disable_auto_update() {
|
|||||||
else
|
else
|
||||||
log_warn "未找到 app-update.yml 文件"
|
log_warn "未找到 app-update.yml 文件"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 同时也处理 cursor-updater
|
# 同时也处理 cursor-updater
|
||||||
log_info "处理 cursor-updater..."
|
log_info "处理 cursor-updater..."
|
||||||
if sudo rm -rf "$updater_path" && \
|
if sudo rm -rf "$updater_path" && \
|
||||||
@ -943,7 +944,7 @@ disable_auto_update() {
|
|||||||
log_error "禁用 cursor-updater 失败,请手动执行以下命令:"
|
log_error "禁用 cursor-updater 失败,请手动执行以下命令:"
|
||||||
echo -e "${BLUE}sudo rm -rf \"$updater_path\" && sudo touch \"$updater_path\" && sudo chmod 444 \"$updater_path\"${NC}"
|
echo -e "${BLUE}sudo rm -rf \"$updater_path\" && sudo touch \"$updater_path\" && sudo chmod 444 \"$updater_path\"${NC}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo
|
echo
|
||||||
log_info "验证方法:"
|
log_info "验证方法:"
|
||||||
echo "1. 运行命令:ls -l \"$updater_path\""
|
echo "1. 运行命令:ls -l \"$updater_path\""
|
||||||
@ -967,41 +968,41 @@ restore_feature() {
|
|||||||
while IFS= read -r file; do
|
while IFS= read -r file; do
|
||||||
[ -f "$file" ] && backup_files+=("$file")
|
[ -f "$file" ] && backup_files+=("$file")
|
||||||
done < <(find "$BACKUP_DIR" -name "*.backup_*" -type f 2>/dev/null | sort)
|
done < <(find "$BACKUP_DIR" -name "*.backup_*" -type f 2>/dev/null | sort)
|
||||||
|
|
||||||
# 检查是否找到备份文件
|
# 检查是否找到备份文件
|
||||||
if [ ${#backup_files[@]} -eq 0 ]; then
|
if [ ${#backup_files[@]} -eq 0 ]; then
|
||||||
log_warn "未找到任何备份文件"
|
log_warn "未找到任何备份文件"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo
|
echo
|
||||||
log_info "可用的备份文件:"
|
log_info "可用的备份文件:"
|
||||||
|
|
||||||
# 构建菜单选项字符串
|
# 构建菜单选项字符串
|
||||||
menu_options="退出 - 不恢复任何文件"
|
menu_options="退出 - 不恢复任何文件"
|
||||||
for i in "${!backup_files[@]}"; do
|
for i in "${!backup_files[@]}"; do
|
||||||
menu_options="$menu_options|$(basename "${backup_files[$i]}")"
|
menu_options="$menu_options|$(basename "${backup_files[$i]}")"
|
||||||
done
|
done
|
||||||
|
|
||||||
# 使用菜单选择函数
|
# 使用菜单选择函数
|
||||||
select_menu_option "请使用上下箭头选择要恢复的备份文件,按Enter确认:" "$menu_options" 0
|
select_menu_option "请使用上下箭头选择要恢复的备份文件,按Enter确认:" "$menu_options" 0
|
||||||
choice=$?
|
choice=$?
|
||||||
|
|
||||||
# 处理用户输入
|
# 处理用户输入
|
||||||
if [ "$choice" = "0" ]; then
|
if [ "$choice" = "0" ]; then
|
||||||
log_info "跳过恢复操作"
|
log_info "跳过恢复操作"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 获取选择的备份文件 (减1是因为第一个选项是"退出")
|
# 获取选择的备份文件 (减1是因为第一个选项是"退出")
|
||||||
local selected_backup="${backup_files[$((choice-1))]}"
|
local selected_backup="${backup_files[$((choice-1))]}"
|
||||||
|
|
||||||
# 验证文件存在性和可读性
|
# 验证文件存在性和可读性
|
||||||
if [ ! -f "$selected_backup" ] || [ ! -r "$selected_backup" ]; then
|
if [ ! -f "$selected_backup" ] || [ ! -r "$selected_backup" ]; then
|
||||||
log_error "无法访问选择的备份文件"
|
log_error "无法访问选择的备份文件"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 尝试恢复配置
|
# 尝试恢复配置
|
||||||
if cp "$selected_backup" "$STORAGE_FILE"; then
|
if cp "$selected_backup" "$STORAGE_FILE"; then
|
||||||
chmod 644 "$STORAGE_FILE"
|
chmod 644 "$STORAGE_FILE"
|
||||||
@ -1017,27 +1018,27 @@ restore_feature() {
|
|||||||
# 解决"应用已损坏,无法打开"问题
|
# 解决"应用已损坏,无法打开"问题
|
||||||
fix_damaged_app() {
|
fix_damaged_app() {
|
||||||
log_info "正在修复"应用已损坏"问题..."
|
log_info "正在修复"应用已损坏"问题..."
|
||||||
|
|
||||||
# 检查Cursor应用是否存在
|
# 检查Cursor应用是否存在
|
||||||
if [ ! -d "$CURSOR_APP_PATH" ]; then
|
if [ ! -d "$CURSOR_APP_PATH" ]; then
|
||||||
log_error "未找到Cursor应用: $CURSOR_APP_PATH"
|
log_error "未找到Cursor应用: $CURSOR_APP_PATH"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_info "尝试移除隔离属性..."
|
log_info "尝试移除隔离属性..."
|
||||||
if sudo xattr -rd com.apple.quarantine "$CURSOR_APP_PATH" 2>/dev/null; then
|
if sudo xattr -rd com.apple.quarantine "$CURSOR_APP_PATH" 2>/dev/null; then
|
||||||
log_info "成功移除隔离属性"
|
log_info "成功移除隔离属性"
|
||||||
else
|
else
|
||||||
log_warn "移除隔离属性失败,尝试其他方法..."
|
log_warn "移除隔离属性失败,尝试其他方法..."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_info "尝试重新签名应用..."
|
log_info "尝试重新签名应用..."
|
||||||
if sudo codesign --force --deep --sign - "$CURSOR_APP_PATH" 2>/dev/null; then
|
if sudo codesign --force --deep --sign - "$CURSOR_APP_PATH" 2>/dev/null; then
|
||||||
log_info "应用重新签名成功"
|
log_info "应用重新签名成功"
|
||||||
else
|
else
|
||||||
log_warn "应用重新签名失败"
|
log_warn "应用重新签名失败"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo
|
echo
|
||||||
log_info "修复完成!请尝试重新打开Cursor应用"
|
log_info "修复完成!请尝试重新打开Cursor应用"
|
||||||
echo
|
echo
|
||||||
@ -1047,12 +1048,12 @@ fix_damaged_app() {
|
|||||||
echo "3. 重新下载安装Cursor应用"
|
echo "3. 重新下载安装Cursor应用"
|
||||||
echo
|
echo
|
||||||
echo -e "${BLUE}参考链接: https://sysin.org/blog/macos-if-crashes-when-opening/${NC}"
|
echo -e "${BLUE}参考链接: https://sysin.org/blog/macos-if-crashes-when-opening/${NC}"
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
# 新增:通用菜单选择函数
|
# 新增:通用菜单选择函数
|
||||||
# 参数:
|
# 参数:
|
||||||
# $1 - 提示信息
|
# $1 - 提示信息
|
||||||
# $2 - 选项数组,格式为 "选项1|选项2|选项3"
|
# $2 - 选项数组,格式为 "选项1|选项2|选项3"
|
||||||
# $3 - 默认选项索引 (从0开始)
|
# $3 - 默认选项索引 (从0开始)
|
||||||
@ -1066,13 +1067,13 @@ select_menu_option() {
|
|||||||
local cursor_up='\033[A'
|
local cursor_up='\033[A'
|
||||||
local cursor_down='\033[B'
|
local cursor_down='\033[B'
|
||||||
local enter_key=$'\n'
|
local enter_key=$'\n'
|
||||||
|
|
||||||
# 保存光标位置
|
# 保存光标位置
|
||||||
tput sc
|
tput sc
|
||||||
|
|
||||||
# 显示提示信息
|
# 显示提示信息
|
||||||
echo -e "$prompt"
|
echo -e "$prompt"
|
||||||
|
|
||||||
# 第一次显示菜单
|
# 第一次显示菜单
|
||||||
for i in "${!options[@]}"; do
|
for i in "${!options[@]}"; do
|
||||||
if [ $i -eq $selected_index ]; then
|
if [ $i -eq $selected_index ]; then
|
||||||
@ -1081,12 +1082,12 @@ select_menu_option() {
|
|||||||
echo -e " ${options[$i]}"
|
echo -e " ${options[$i]}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# 循环处理键盘输入
|
# 循环处理键盘输入
|
||||||
while true; do
|
while true; do
|
||||||
# 读取单个按键
|
# 读取单个按键
|
||||||
read -rsn3 key_input
|
read -rsn3 key_input
|
||||||
|
|
||||||
# 检测按键
|
# 检测按键
|
||||||
case "$key_input" in
|
case "$key_input" in
|
||||||
# 上箭头键
|
# 上箭头键
|
||||||
@ -1108,10 +1109,10 @@ select_menu_option() {
|
|||||||
return $selected_index
|
return $selected_index
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# 恢复光标位置
|
# 恢复光标位置
|
||||||
tput rc
|
tput rc
|
||||||
|
|
||||||
# 重新显示菜单
|
# 重新显示菜单
|
||||||
for i in "${!options[@]}"; do
|
for i in "${!options[@]}"; do
|
||||||
if [ $i -eq $selected_index ]; then
|
if [ $i -eq $selected_index ]; then
|
||||||
@ -1125,28 +1126,28 @@ select_menu_option() {
|
|||||||
|
|
||||||
# 主函数
|
# 主函数
|
||||||
main() {
|
main() {
|
||||||
|
|
||||||
# 初始化日志文件
|
# 初始化日志文件
|
||||||
initialize_log
|
initialize_log
|
||||||
log_info "脚本启动..."
|
log_info "脚本启动..."
|
||||||
|
|
||||||
# 记录系统信息
|
# 记录系统信息
|
||||||
log_info "系统信息: $(uname -a)"
|
log_info "系统信息: $(uname -a)"
|
||||||
log_info "当前用户: $CURRENT_USER"
|
log_info "当前用户: $CURRENT_USER"
|
||||||
log_cmd_output "sw_vers" "macOS 版本信息"
|
log_cmd_output "sw_vers" "macOS 版本信息"
|
||||||
log_cmd_output "which codesign" "codesign 路径"
|
log_cmd_output "which codesign" "codesign 路径"
|
||||||
log_cmd_output "ls -ld "$CURSOR_APP_PATH"" "Cursor 应用信息"
|
log_cmd_output "ls -ld "$CURSOR_APP_PATH"" "Cursor 应用信息"
|
||||||
|
|
||||||
# 新增环境检查
|
# 新增环境检查
|
||||||
if [[ $(uname) != "Darwin" ]]; then
|
if [[ $(uname) != "Darwin" ]]; then
|
||||||
log_error "本脚本仅支持 macOS 系统"
|
log_error "本脚本仅支持 macOS 系统"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
clear
|
clear
|
||||||
# 显示 Logo
|
# 显示 Logo
|
||||||
echo -e "
|
echo -e "
|
||||||
██████╗██╗ ██╗██████╗ ███████╗ ██████╗ ██████╗
|
██████╗██╗ ██╗██████╗ ███████╗ ██████╗ ██████╗
|
||||||
██╔════╝██║ ██║██╔══██╗██╔════╝██╔═══██╗██╔══██╗
|
██╔════╝██║ ██║██╔══██╗██╔════╝██╔═══██╗██╔══██╗
|
||||||
██║ ██║ ██║██████╔╝███████╗██║ ██║██████╔╝
|
██║ ██║ ██║██████╔╝███████╗██║ ██║██████╔╝
|
||||||
██║ ██║ ██║██╔══██╗╚════██║██║ ██║██╔══██╗
|
██║ ██║ ██║██╔══██╗╚════██║██║ ██║██╔══██╗
|
||||||
@ -1162,18 +1163,18 @@ main() {
|
|||||||
echo -e "${YELLOW}[重要提示]${NC} 本工具默认会修改系统 MAC 地址 (临时) 并修改 JS 文件以重置设备标识。"
|
echo -e "${YELLOW}[重要提示]${NC} 本工具默认会修改系统 MAC 地址 (临时) 并修改 JS 文件以重置设备标识。"
|
||||||
echo -e "${YELLOW}[重要提示]${NC} 本工具免费,如果对您有帮助,请关注公众号【煎饼果子卷AI】"
|
echo -e "${YELLOW}[重要提示]${NC} 本工具免费,如果对您有帮助,请关注公众号【煎饼果子卷AI】"
|
||||||
echo
|
echo
|
||||||
|
|
||||||
# 执行主要功能
|
# 执行主要功能
|
||||||
check_permissions
|
check_permissions
|
||||||
check_and_kill_cursor
|
check_and_kill_cursor
|
||||||
backup_config
|
backup_config
|
||||||
|
|
||||||
# 新增:默认执行系统 MAC 地址修改
|
# 新增:默认执行系统 MAC 地址修改
|
||||||
change_system_mac_address || true
|
change_system_mac_address || true
|
||||||
|
|
||||||
# 执行主程序文件修改
|
# 执行主程序文件修改
|
||||||
log_info "正在执行主程序文件修改..."
|
log_info "正在执行主程序文件修改..."
|
||||||
|
|
||||||
# 使用子shell执行修改,避免错误导致整个脚本退出
|
# 使用子shell执行修改,避免错误导致整个脚本退出
|
||||||
(
|
(
|
||||||
if modify_cursor_app_files; then
|
if modify_cursor_app_files; then
|
||||||
@ -1183,13 +1184,13 @@ main() {
|
|||||||
log_warn "如果重启后 Cursor 仍然提示设备被禁用,请重新运行此脚本"
|
log_warn "如果重启后 Cursor 仍然提示设备被禁用,请重新运行此脚本"
|
||||||
fi
|
fi
|
||||||
)
|
)
|
||||||
|
|
||||||
# 恢复错误处理
|
# 恢复错误处理
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
show_file_tree
|
show_file_tree
|
||||||
show_follow_info
|
show_follow_info
|
||||||
|
|
||||||
# 直接执行禁用自动更新
|
# 直接执行禁用自动更新
|
||||||
disable_auto_update
|
disable_auto_update
|
||||||
|
|
||||||
@ -1201,17 +1202,17 @@ main() {
|
|||||||
# 提供修复选项(移到最后)
|
# 提供修复选项(移到最后)
|
||||||
echo
|
echo
|
||||||
log_warn "Cursor 修复选项"
|
log_warn "Cursor 修复选项"
|
||||||
|
|
||||||
# 使用新的菜单选择函数
|
# 使用新的菜单选择函数
|
||||||
select_menu_option "请使用上下箭头选择,按Enter确认:" "忽略 - 不执行修复操作|修复模式 - 恢复原始的 Cursor 安装" 0
|
select_menu_option "请使用上下箭头选择,按Enter确认:" "忽略 - 不执行修复操作|修复模式 - 恢复原始的 Cursor 安装" 0
|
||||||
fix_choice=$?
|
fix_choice=$?
|
||||||
|
|
||||||
# 记录日志以便调试
|
# 记录日志以便调试
|
||||||
echo "[INPUT_DEBUG] 修复选项选择: $fix_choice" >> "$LOG_FILE"
|
echo "[INPUT_DEBUG] 修复选项选择: $fix_choice" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 确保脚本不会因为输入问题而终止
|
# 确保脚本不会因为输入问题而终止
|
||||||
set +e
|
set +e
|
||||||
|
|
||||||
# 处理用户选择 - 索引1对应"修复模式"选项
|
# 处理用户选择 - 索引1对应"修复模式"选项
|
||||||
if [ "$fix_choice" = "1" ]; then
|
if [ "$fix_choice" = "1" ]; then
|
||||||
log_info "您选择了修复模式"
|
log_info "您选择了修复模式"
|
||||||
@ -1228,32 +1229,32 @@ main() {
|
|||||||
else
|
else
|
||||||
log_info "已跳过修复操作"
|
log_info "已跳过修复操作"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 恢复错误处理
|
# 恢复错误处理
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
# 记录脚本完成信息
|
# 记录脚本完成信息
|
||||||
log_info "脚本执行完成"
|
log_info "脚本执行完成"
|
||||||
echo "========== Cursor ID 修改工具日志结束 $(date) ==========" >> "$LOG_FILE"
|
echo "========== Cursor ID 修改工具日志结束 $(date) ==========" >> "$LOG_FILE"
|
||||||
|
|
||||||
# 显示日志文件位置
|
# 显示日志文件位置
|
||||||
echo
|
echo
|
||||||
log_info "详细日志已保存到: $LOG_FILE"
|
log_info "详细日志已保存到: $LOG_FILE"
|
||||||
echo "如遇问题请将此日志文件提供给开发者以协助排查"
|
echo "如遇问题请将此日志文件提供给开发者以协助排查"
|
||||||
echo
|
echo
|
||||||
|
|
||||||
# 添加修复"应用已损坏"选项
|
# 添加修复"应用已损坏"选项
|
||||||
echo
|
echo
|
||||||
log_warn "应用修复选项"
|
log_warn "应用修复选项"
|
||||||
|
|
||||||
# 使用新的菜单选择函数
|
# 使用新的菜单选择函数
|
||||||
select_menu_option "请使用上下箭头选择,按Enter确认:" "忽略 - 不执行修复操作|修复"应用已损坏"问题 - 解决macOS提示应用已损坏无法打开的问题" 0
|
select_menu_option "请使用上下箭头选择,按Enter确认:" "忽略 - 不执行修复操作|修复"应用已损坏"问题 - 解决macOS提示应用已损坏无法打开的问题" 0
|
||||||
damaged_choice=$?
|
damaged_choice=$?
|
||||||
|
|
||||||
echo "[INPUT_DEBUG] 应用修复选项选择: $damaged_choice" >> "$LOG_FILE"
|
echo "[INPUT_DEBUG] 应用修复选项选择: $damaged_choice" >> "$LOG_FILE"
|
||||||
|
|
||||||
set +e
|
set +e
|
||||||
|
|
||||||
# 处理用户选择 - 索引1对应"修复应用已损坏"选项
|
# 处理用户选择 - 索引1对应"修复应用已损坏"选项
|
||||||
if [ "$damaged_choice" = "1" ]; then
|
if [ "$damaged_choice" = "1" ]; then
|
||||||
log_info "您选择了修复"应用已损坏"问题"
|
log_info "您选择了修复"应用已损坏"问题"
|
||||||
@ -1267,7 +1268,7 @@ main() {
|
|||||||
else
|
else
|
||||||
log_info "已跳过应用修复操作"
|
log_info "已跳过应用修复操作"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user